xref: /dflybsd-src/contrib/binutils-2.27/include/elf/tilepro.h (revision e656dc90e3d65d744d534af2f5ea88cf8101ebcf)
1*a9fa9459Szrj /* TILEPro ELF support for BFD.
2*a9fa9459Szrj    Copyright (C) 2011-2016 Free Software Foundation, Inc.
3*a9fa9459Szrj 
4*a9fa9459Szrj    This file is part of BFD, the Binary File Descriptor library.
5*a9fa9459Szrj 
6*a9fa9459Szrj    This program is free software; you can redistribute it and/or modify
7*a9fa9459Szrj    it under the terms of the GNU General Public License as published by
8*a9fa9459Szrj    the Free Software Foundation; either version 3 of the License, or
9*a9fa9459Szrj    (at your option) any later version.
10*a9fa9459Szrj 
11*a9fa9459Szrj    This program is distributed in the hope that it will be useful,
12*a9fa9459Szrj    but WITHOUT ANY WARRANTY; without even the implied warranty of
13*a9fa9459Szrj    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14*a9fa9459Szrj    GNU General Public License for more details.
15*a9fa9459Szrj 
16*a9fa9459Szrj    You should have received a copy of the GNU General Public License
17*a9fa9459Szrj    along with this program; if not, write to the Free Software
18*a9fa9459Szrj    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
19*a9fa9459Szrj    MA 02110-1301, USA.  */
20*a9fa9459Szrj 
21*a9fa9459Szrj #ifndef _ELF_TILEPRO_H
22*a9fa9459Szrj #define _ELF_TILEPRO_H
23*a9fa9459Szrj 
24*a9fa9459Szrj #include "elf/reloc-macros.h"
25*a9fa9459Szrj 
26*a9fa9459Szrj /* Relocations.  */
27*a9fa9459Szrj START_RELOC_NUMBERS (elf_tilepro_reloc_type)
28*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_NONE,        0)
29*a9fa9459Szrj 
30*a9fa9459Szrj   /* Standard relocations */
31*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_32,                  1)
32*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_16,                  2)
33*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_8,                   3)
34*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_32_PCREL,            4)
35*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_16_PCREL,            5)
36*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_8_PCREL,             6)
37*a9fa9459Szrj 
38*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_LO16,                7)
39*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_HI16,                8)
40*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_HA16,                9)
41*a9fa9459Szrj 
42*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_COPY,               10)
43*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_GLOB_DAT,           11)
44*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_JMP_SLOT,           12)
45*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_RELATIVE,           13)
46*a9fa9459Szrj 
47*a9fa9459Szrj   /* Branch/jump offsets */
48*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_BROFF_X1,           14)
49*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_JOFFLONG_X1,        15)
50*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_JOFFLONG_X1_PLT,    16)
51*a9fa9459Szrj 
52*a9fa9459Szrj   /* Immediate operands. */
53*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM8_X0,            17)
54*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM8_Y0,            18)
55*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM8_X1,            19)
56*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM8_Y1,            20)
57*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_MT_IMM15_X1,        21)
58*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_MF_IMM15_X1,        22)
59*a9fa9459Szrj 
60*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0,           23)
61*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1,           24)
62*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_LO,        25)
63*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_LO,        26)
64*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_HI,        27)
65*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_HI,        28)
66*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_HA,        29)
67*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_HA,        30)
68*a9fa9459Szrj 
69*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_PCREL,     31)
70*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_PCREL,     32)
71*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_LO_PCREL,  33)
72*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_LO_PCREL,  34)
73*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_HI_PCREL,  35)
74*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_HI_PCREL,  36)
75*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_HA_PCREL,  37)
76*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_HA_PCREL,  38)
77*a9fa9459Szrj 
78*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT,       39)
79*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT,       40)
80*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT_LO,    41)
81*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT_LO,    42)
82*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT_HI,    43)
83*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT_HI,    44)
84*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_GOT_HA,    45)
85*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_GOT_HA,    46)
86*a9fa9459Szrj 
87*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_MMSTART_X0,         47)
88*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_MMEND_X0,           48)
89*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_MMSTART_X1,         49)
90*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_MMEND_X1,           50)
91*a9fa9459Szrj 
92*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_SHAMT_X0,           51)
93*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_SHAMT_X1,           52)
94*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_SHAMT_Y0,           53)
95*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_SHAMT_Y1,           54)
96*a9fa9459Szrj 
97*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_DEST_IMM8_X1,       55)
98*a9fa9459Szrj 
99*a9fa9459Szrj   /* Relocs 56-59 are currently not defined.  */
100*a9fa9459Szrj 
101*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_TLS_GD_CALL,        60)
102*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM8_X0_TLS_GD_ADD, 61)
103*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM8_X1_TLS_GD_ADD, 62)
104*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM8_Y0_TLS_GD_ADD, 63)
105*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM8_Y1_TLS_GD_ADD, 64)
106*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_TLS_IE_LOAD,        65)
107*a9fa9459Szrj 
108*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD,    66)
109*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD,    67)
110*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD_LO, 68)
111*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD_LO, 69)
112*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD_HI, 70)
113*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD_HI, 71)
114*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_GD_HA, 72)
115*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_GD_HA, 73)
116*a9fa9459Szrj 
117*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE,    74)
118*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE,    75)
119*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE_LO, 76)
120*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE_LO, 77)
121*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE_HI, 78)
122*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE_HI, 79)
123*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_IE_HA, 80)
124*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_IE_HA, 81)
125*a9fa9459Szrj 
126*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_TLS_DTPMOD32,       82)
127*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_TLS_DTPOFF32,       83)
128*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_TLS_TPOFF32,        84)
129*a9fa9459Szrj 
130*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_LE,    85)
131*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_LE,    86)
132*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_LE_LO, 87)
133*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_LE_LO, 88)
134*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_LE_HI, 89)
135*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_LE_HI, 90)
136*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X0_TLS_LE_HA, 91)
137*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_IMM16_X1_TLS_LE_HA, 92)
138*a9fa9459Szrj 
139*a9fa9459Szrj /* These are GNU extensions to enable C++ vtable garbage collection.  */
140*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_GNU_VTINHERIT, 128)
141*a9fa9459Szrj   RELOC_NUMBER (R_TILEPRO_GNU_VTENTRY, 129)
142*a9fa9459Szrj END_RELOC_NUMBERS (R_TILEPRO_max)
143*a9fa9459Szrj 
144*a9fa9459Szrj #endif /* _ELF_TILEPRO_H */
145