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