tilegx.h 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. /* TILE-Gx ELF support for BFD.
  2. Copyright (C) 2011-2022 Free Software Foundation, Inc.
  3. This file is part of BFD, the Binary File Descriptor library.
  4. This program is free software; you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation; either version 3 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program; if not, write to the Free Software
  14. Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
  15. MA 02110-1301, USA. */
  16. #ifndef _ELF_TILEGX_H
  17. #define _ELF_TILEGX_H
  18. #include "elf/reloc-macros.h"
  19. /* Relocations. */
  20. START_RELOC_NUMBERS (elf_tilegx_reloc_type)
  21. RELOC_NUMBER (R_TILEGX_NONE, 0)
  22. /* Standard relocations */
  23. RELOC_NUMBER (R_TILEGX_64, 1)
  24. RELOC_NUMBER (R_TILEGX_32, 2)
  25. RELOC_NUMBER (R_TILEGX_16, 3)
  26. RELOC_NUMBER (R_TILEGX_8, 4)
  27. RELOC_NUMBER (R_TILEGX_64_PCREL, 5)
  28. RELOC_NUMBER (R_TILEGX_32_PCREL, 6)
  29. RELOC_NUMBER (R_TILEGX_16_PCREL, 7)
  30. RELOC_NUMBER (R_TILEGX_8_PCREL, 8)
  31. /* Custom relocations */
  32. RELOC_NUMBER (R_TILEGX_HW0, 9)
  33. RELOC_NUMBER (R_TILEGX_HW1, 10)
  34. RELOC_NUMBER (R_TILEGX_HW2, 11)
  35. RELOC_NUMBER (R_TILEGX_HW3, 12)
  36. RELOC_NUMBER (R_TILEGX_HW0_LAST, 13)
  37. RELOC_NUMBER (R_TILEGX_HW1_LAST, 14)
  38. RELOC_NUMBER (R_TILEGX_HW2_LAST, 15)
  39. RELOC_NUMBER (R_TILEGX_COPY, 16)
  40. RELOC_NUMBER (R_TILEGX_GLOB_DAT, 17)
  41. RELOC_NUMBER (R_TILEGX_JMP_SLOT, 18)
  42. RELOC_NUMBER (R_TILEGX_RELATIVE, 19)
  43. /* Branch/jump offsets */
  44. RELOC_NUMBER (R_TILEGX_BROFF_X1, 20)
  45. RELOC_NUMBER (R_TILEGX_JUMPOFF_X1, 21)
  46. RELOC_NUMBER (R_TILEGX_JUMPOFF_X1_PLT, 22)
  47. /* Immediate operands. */
  48. RELOC_NUMBER (R_TILEGX_IMM8_X0, 23)
  49. RELOC_NUMBER (R_TILEGX_IMM8_Y0, 24)
  50. RELOC_NUMBER (R_TILEGX_IMM8_X1, 25)
  51. RELOC_NUMBER (R_TILEGX_IMM8_Y1, 26)
  52. RELOC_NUMBER (R_TILEGX_DEST_IMM8_X1, 27)
  53. RELOC_NUMBER (R_TILEGX_MT_IMM14_X1, 28)
  54. RELOC_NUMBER (R_TILEGX_MF_IMM14_X1, 29)
  55. RELOC_NUMBER (R_TILEGX_MMSTART_X0, 30)
  56. RELOC_NUMBER (R_TILEGX_MMEND_X0, 31)
  57. RELOC_NUMBER (R_TILEGX_SHAMT_X0, 32)
  58. RELOC_NUMBER (R_TILEGX_SHAMT_X1, 33)
  59. RELOC_NUMBER (R_TILEGX_SHAMT_Y0, 34)
  60. RELOC_NUMBER (R_TILEGX_SHAMT_Y1, 35)
  61. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0, 36)
  62. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0, 37)
  63. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1, 38)
  64. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1, 39)
  65. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2, 40)
  66. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2, 41)
  67. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW3, 42)
  68. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW3, 43)
  69. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST, 44)
  70. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST, 45)
  71. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST, 46)
  72. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST, 47)
  73. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_LAST, 48)
  74. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_LAST, 49)
  75. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_PCREL, 50)
  76. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_PCREL, 51)
  77. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_PCREL, 52)
  78. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_PCREL, 53)
  79. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_PCREL, 54)
  80. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_PCREL, 55)
  81. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW3_PCREL, 56)
  82. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW3_PCREL, 57)
  83. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_PCREL, 58)
  84. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_PCREL, 59)
  85. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_PCREL, 60)
  86. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_PCREL, 61)
  87. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_LAST_PCREL, 62)
  88. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_LAST_PCREL, 63)
  89. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_GOT, 64)
  90. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_GOT, 65)
  91. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_PLT_PCREL, 66)
  92. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_PLT_PCREL, 67)
  93. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_PLT_PCREL, 68)
  94. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_PLT_PCREL, 69)
  95. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_PLT_PCREL, 70)
  96. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_PLT_PCREL, 71)
  97. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_GOT, 72)
  98. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_GOT, 73)
  99. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_GOT, 74)
  100. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_GOT, 75)
  101. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW3_PLT_PCREL, 76)
  102. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW3_PLT_PCREL, 77)
  103. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_TLS_GD, 78)
  104. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_TLS_GD, 79)
  105. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_TLS_LE, 80)
  106. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_TLS_LE, 81)
  107. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_TLS_LE, 82)
  108. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_TLS_LE, 83)
  109. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_TLS_LE, 84)
  110. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_TLS_LE, 85)
  111. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_TLS_GD, 86)
  112. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_TLS_GD, 87)
  113. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_TLS_GD, 88)
  114. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_TLS_GD, 89)
  115. /* Relocs 90-91 are currently not defined. */
  116. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_TLS_IE, 92)
  117. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_TLS_IE, 93)
  118. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_PLT_PCREL, 94)
  119. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_PLT_PCREL, 95)
  120. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_PLT_PCREL, 96)
  121. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_PLT_PCREL, 97)
  122. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW2_LAST_PLT_PCREL, 98)
  123. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW2_LAST_PLT_PCREL, 99)
  124. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW0_LAST_TLS_IE, 100)
  125. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW0_LAST_TLS_IE, 101)
  126. RELOC_NUMBER (R_TILEGX_IMM16_X0_HW1_LAST_TLS_IE, 102)
  127. RELOC_NUMBER (R_TILEGX_IMM16_X1_HW1_LAST_TLS_IE, 103)
  128. /* Relocs 104-105 are currently not defined. */
  129. RELOC_NUMBER (R_TILEGX_TLS_DTPMOD64, 106)
  130. RELOC_NUMBER (R_TILEGX_TLS_DTPOFF64, 107)
  131. RELOC_NUMBER (R_TILEGX_TLS_TPOFF64, 108)
  132. RELOC_NUMBER (R_TILEGX_TLS_DTPMOD32, 109)
  133. RELOC_NUMBER (R_TILEGX_TLS_DTPOFF32, 110)
  134. RELOC_NUMBER (R_TILEGX_TLS_TPOFF32, 111)
  135. RELOC_NUMBER (R_TILEGX_TLS_GD_CALL, 112)
  136. RELOC_NUMBER (R_TILEGX_IMM8_X0_TLS_GD_ADD, 113)
  137. RELOC_NUMBER (R_TILEGX_IMM8_X1_TLS_GD_ADD, 114)
  138. RELOC_NUMBER (R_TILEGX_IMM8_Y0_TLS_GD_ADD, 115)
  139. RELOC_NUMBER (R_TILEGX_IMM8_Y1_TLS_GD_ADD, 116)
  140. RELOC_NUMBER (R_TILEGX_TLS_IE_LOAD, 117)
  141. RELOC_NUMBER (R_TILEGX_IMM8_X0_TLS_ADD, 118)
  142. RELOC_NUMBER (R_TILEGX_IMM8_X1_TLS_ADD, 119)
  143. RELOC_NUMBER (R_TILEGX_IMM8_Y0_TLS_ADD, 120)
  144. RELOC_NUMBER (R_TILEGX_IMM8_Y1_TLS_ADD, 121)
  145. /* These are GNU extensions to enable C++ vtable garbage collection. */
  146. RELOC_NUMBER (R_TILEGX_GNU_VTINHERIT, 128)
  147. RELOC_NUMBER (R_TILEGX_GNU_VTENTRY, 129)
  148. END_RELOC_NUMBERS (R_TILEGX_max)
  149. #endif /* _ELF_TILEGX_H */