xref: /dflybsd-src/contrib/binutils-2.27/include/elf/ppc.h (revision e656dc90e3d65d744d534af2f5ea88cf8101ebcf)
1*a9fa9459Szrj /* PPC ELF support for BFD.
2*a9fa9459Szrj    Copyright (C) 1995-2016 Free Software Foundation, Inc.
3*a9fa9459Szrj 
4*a9fa9459Szrj    By Michael Meissner, Cygnus Support, <meissner@cygnus.com>,
5*a9fa9459Szrj    from information in the System V Application Binary Interface,
6*a9fa9459Szrj    PowerPC Processor Supplement and the PowerPC Embedded Application
7*a9fa9459Szrj    Binary Interface (eabi).
8*a9fa9459Szrj 
9*a9fa9459Szrj    This file is part of BFD, the Binary File Descriptor library.
10*a9fa9459Szrj 
11*a9fa9459Szrj    This program is free software; you can redistribute it and/or modify
12*a9fa9459Szrj    it under the terms of the GNU General Public License as published by
13*a9fa9459Szrj    the Free Software Foundation; either version 3 of the License, or
14*a9fa9459Szrj    (at your option) any later version.
15*a9fa9459Szrj 
16*a9fa9459Szrj    This program is distributed in the hope that it will be useful,
17*a9fa9459Szrj    but WITHOUT ANY WARRANTY; without even the implied warranty of
18*a9fa9459Szrj    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19*a9fa9459Szrj    GNU General Public License for more details.
20*a9fa9459Szrj 
21*a9fa9459Szrj    You should have received a copy of the GNU General Public License
22*a9fa9459Szrj    along with this program; if not, write to the Free Software
23*a9fa9459Szrj    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
24*a9fa9459Szrj    MA 02110-1301, USA.  */
25*a9fa9459Szrj 
26*a9fa9459Szrj /* This file holds definitions specific to the PPC ELF ABI.  Note
27*a9fa9459Szrj    that most of this is not actually implemented by BFD.  */
28*a9fa9459Szrj 
29*a9fa9459Szrj #ifndef _ELF_PPC_H
30*a9fa9459Szrj #define _ELF_PPC_H
31*a9fa9459Szrj 
32*a9fa9459Szrj #include "elf/reloc-macros.h"
33*a9fa9459Szrj 
34*a9fa9459Szrj /* Relocations.  */
35*a9fa9459Szrj START_RELOC_NUMBERS (elf_ppc_reloc_type)
36*a9fa9459Szrj   RELOC_NUMBER (R_PPC_NONE,		  0)
37*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR32,		  1)
38*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR24,		  2)
39*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR16,		  3)
40*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR16_LO,	  4)
41*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR16_HI,	  5)
42*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR16_HA,	  6)
43*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR14,		  7)
44*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR14_BRTAKEN,	  8)
45*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR14_BRNTAKEN,	  9)
46*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL24,		 10)
47*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL14,		 11)
48*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL14_BRTAKEN,	 12)
49*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL14_BRNTAKEN,	 13)
50*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT16,		 14)
51*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT16_LO,		 15)
52*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT16_HI,		 16)
53*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT16_HA,		 17)
54*a9fa9459Szrj   RELOC_NUMBER (R_PPC_PLTREL24,		 18)
55*a9fa9459Szrj   RELOC_NUMBER (R_PPC_COPY,		 19)
56*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GLOB_DAT,		 20)
57*a9fa9459Szrj   RELOC_NUMBER (R_PPC_JMP_SLOT,		 21)
58*a9fa9459Szrj   RELOC_NUMBER (R_PPC_RELATIVE,		 22)
59*a9fa9459Szrj   RELOC_NUMBER (R_PPC_LOCAL24PC,	 23)
60*a9fa9459Szrj   RELOC_NUMBER (R_PPC_UADDR32,		 24)
61*a9fa9459Szrj   RELOC_NUMBER (R_PPC_UADDR16,		 25)
62*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL32,		 26)
63*a9fa9459Szrj   RELOC_NUMBER (R_PPC_PLT32,		 27)
64*a9fa9459Szrj   RELOC_NUMBER (R_PPC_PLTREL32,		 28)
65*a9fa9459Szrj   RELOC_NUMBER (R_PPC_PLT16_LO,		 29)
66*a9fa9459Szrj   RELOC_NUMBER (R_PPC_PLT16_HI,		 30)
67*a9fa9459Szrj   RELOC_NUMBER (R_PPC_PLT16_HA,		 31)
68*a9fa9459Szrj   RELOC_NUMBER (R_PPC_SDAREL16,		 32)
69*a9fa9459Szrj   RELOC_NUMBER (R_PPC_SECTOFF,		 33)
70*a9fa9459Szrj   RELOC_NUMBER (R_PPC_SECTOFF_LO,	 34)
71*a9fa9459Szrj   RELOC_NUMBER (R_PPC_SECTOFF_HI,	 35)
72*a9fa9459Szrj   RELOC_NUMBER (R_PPC_SECTOFF_HA,	 36)
73*a9fa9459Szrj   RELOC_NUMBER (R_PPC_ADDR30,		 37)
74*a9fa9459Szrj 
75*a9fa9459Szrj #ifndef RELOC_MACROS_GEN_FUNC
76*a9fa9459Szrj /* Fake relocations for branch stubs, only used internally by ld.  */
77*a9fa9459Szrj   RELOC_NUMBER (R_PPC_RELAX,		 48)
78*a9fa9459Szrj   RELOC_NUMBER (R_PPC_RELAX_PLT,	 49)
79*a9fa9459Szrj   RELOC_NUMBER (R_PPC_RELAX_PLTREL24,	 50)
80*a9fa9459Szrj #endif
81*a9fa9459Szrj 
82*a9fa9459Szrj   /* Relocs added to support TLS.  */
83*a9fa9459Szrj   RELOC_NUMBER (R_PPC_TLS,		 67)
84*a9fa9459Szrj   RELOC_NUMBER (R_PPC_DTPMOD32,		 68)
85*a9fa9459Szrj   RELOC_NUMBER (R_PPC_TPREL16,		 69)
86*a9fa9459Szrj   RELOC_NUMBER (R_PPC_TPREL16_LO,	 70)
87*a9fa9459Szrj   RELOC_NUMBER (R_PPC_TPREL16_HI,	 71)
88*a9fa9459Szrj   RELOC_NUMBER (R_PPC_TPREL16_HA,	 72)
89*a9fa9459Szrj   RELOC_NUMBER (R_PPC_TPREL32,		 73)
90*a9fa9459Szrj   RELOC_NUMBER (R_PPC_DTPREL16,		 74)
91*a9fa9459Szrj   RELOC_NUMBER (R_PPC_DTPREL16_LO,	 75)
92*a9fa9459Szrj   RELOC_NUMBER (R_PPC_DTPREL16_HI,	 76)
93*a9fa9459Szrj   RELOC_NUMBER (R_PPC_DTPREL16_HA,	 77)
94*a9fa9459Szrj   RELOC_NUMBER (R_PPC_DTPREL32,		 78)
95*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TLSGD16,	 79)
96*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TLSGD16_LO,	 80)
97*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TLSGD16_HI,	 81)
98*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TLSGD16_HA,	 82)
99*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TLSLD16,	 83)
100*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TLSLD16_LO,	 84)
101*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TLSLD16_HI,	 85)
102*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TLSLD16_HA,	 86)
103*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TPREL16,	 87)
104*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TPREL16_LO,	 88)
105*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TPREL16_HI,	 89)
106*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_TPREL16_HA,	 90)
107*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_DTPREL16,	 91)
108*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_DTPREL16_LO,	 92)
109*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_DTPREL16_HI,	 93)
110*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GOT_DTPREL16_HA,	 94)
111*a9fa9459Szrj   RELOC_NUMBER (R_PPC_TLSGD,		 95)
112*a9fa9459Szrj   RELOC_NUMBER (R_PPC_TLSLD,		 96)
113*a9fa9459Szrj 
114*a9fa9459Szrj /* The remaining relocs are from the Embedded ELF ABI, and are not
115*a9fa9459Szrj    in the SVR4 ELF ABI.  */
116*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_NADDR32,	101)
117*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_NADDR16,	102)
118*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_NADDR16_LO,	103)
119*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_NADDR16_HI,	104)
120*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_NADDR16_HA,	105)
121*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_SDAI16,	106)
122*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_SDA2I16,	107)
123*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_SDA2REL,	108)
124*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_SDA21,	109)
125*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_MRKREF,	110)
126*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_RELSEC16,	111)
127*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_RELST_LO,	112)
128*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_RELST_HI,	113)
129*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_RELST_HA,	114)
130*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_BIT_FLD,	115)
131*a9fa9459Szrj   RELOC_NUMBER (R_PPC_EMB_RELSDA,	116)
132*a9fa9459Szrj 
133*a9fa9459Szrj /* PowerPC VLE relocations.  */
134*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_REL8,		216)
135*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_REL15,	217)
136*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_REL24,	218)
137*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_LO16A,	219)
138*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_LO16D,	220)
139*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_HI16A,	221)
140*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_HI16D,	222)
141*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_HA16A,	223)
142*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_HA16D,	224)
143*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_SDA21,	225)
144*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_SDA21_LO,	226)
145*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_SDAREL_LO16A,	227)
146*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_SDAREL_LO16D,	228)
147*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_SDAREL_HI16A,	229)
148*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_SDAREL_HI16D,	230)
149*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_SDAREL_HA16A,	231)
150*a9fa9459Szrj   RELOC_NUMBER (R_PPC_VLE_SDAREL_HA16D,	232)
151*a9fa9459Szrj 
152*a9fa9459Szrj /* Power9 split rel16 for addpcis.  */
153*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL16DX_HA,	246)
154*a9fa9459Szrj 
155*a9fa9459Szrj /* Support STT_GNU_IFUNC plt calls.  */
156*a9fa9459Szrj   RELOC_NUMBER (R_PPC_IRELATIVE,	248)
157*a9fa9459Szrj 
158*a9fa9459Szrj /* These are GNU extensions used in PIC code sequences.  */
159*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL16,		249)
160*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL16_LO,		250)
161*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL16_HI,		251)
162*a9fa9459Szrj   RELOC_NUMBER (R_PPC_REL16_HA,		252)
163*a9fa9459Szrj 
164*a9fa9459Szrj /* These are GNU extensions to enable C++ vtable garbage collection.  */
165*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GNU_VTINHERIT,	253)
166*a9fa9459Szrj   RELOC_NUMBER (R_PPC_GNU_VTENTRY,	254)
167*a9fa9459Szrj 
168*a9fa9459Szrj /* This is a phony reloc to handle any old fashioned TOC16 references
169*a9fa9459Szrj    that may still be in object files.  */
170*a9fa9459Szrj   RELOC_NUMBER (R_PPC_TOC16,		255)
171*a9fa9459Szrj 
172*a9fa9459Szrj END_RELOC_NUMBERS (R_PPC_max)
173*a9fa9459Szrj 
174*a9fa9459Szrj #define IS_PPC_TLS_RELOC(R) \
175*a9fa9459Szrj   ((R) >= R_PPC_TLS && (R) <= R_PPC_GOT_DTPREL16_HA)
176*a9fa9459Szrj 
177*a9fa9459Szrj /* Specify the value of _GLOBAL_OFFSET_TABLE_.  */
178*a9fa9459Szrj #define DT_PPC_GOT		(DT_LOPROC)
179*a9fa9459Szrj 
180*a9fa9459Szrj /* Specify that tls descriptors should be optimized.  */
181*a9fa9459Szrj #define DT_PPC_OPT		(DT_LOPROC + 1)
182*a9fa9459Szrj #define PPC_OPT_TLS		1
183*a9fa9459Szrj 
184*a9fa9459Szrj /* Processor specific flags for the ELF header e_flags field.  */
185*a9fa9459Szrj 
186*a9fa9459Szrj #define	EF_PPC_EMB		0x80000000	/* PowerPC embedded flag.  */
187*a9fa9459Szrj 
188*a9fa9459Szrj #define	EF_PPC_RELOCATABLE	0x00010000	/* PowerPC -mrelocatable flag.  */
189*a9fa9459Szrj #define	EF_PPC_RELOCATABLE_LIB	0x00008000	/* PowerPC -mrelocatable-lib flag.  */
190*a9fa9459Szrj 
191*a9fa9459Szrj /* Processor specific program headers, p_flags field.  */
192*a9fa9459Szrj #define PF_PPC_VLE		0x10000000	/* PowerPC VLE.  */
193*a9fa9459Szrj 
194*a9fa9459Szrj /* Processor specific section headers, sh_flags field.  */
195*a9fa9459Szrj #define SHF_PPC_VLE		0x10000000	/* PowerPC VLE text section.  */
196*a9fa9459Szrj 
197*a9fa9459Szrj /* Processor specific section headers, sh_type field.  */
198*a9fa9459Szrj 
199*a9fa9459Szrj #define SHT_ORDERED		SHT_HIPROC	/* Link editor is to sort the \
200*a9fa9459Szrj 						   entries in this section \
201*a9fa9459Szrj 						   based on the address \
202*a9fa9459Szrj 						   specified in the associated \
203*a9fa9459Szrj 						   symbol table entry.  */
204*a9fa9459Szrj 
205*a9fa9459Szrj /* APUinfo note section.  */
206*a9fa9459Szrj #define APUINFO_SECTION_NAME	".PPC.EMB.apuinfo"
207*a9fa9459Szrj #define APUINFO_LABEL		"APUinfo"
208*a9fa9459Szrj 
209*a9fa9459Szrj #define PPC_APUINFO_ISEL	0x40
210*a9fa9459Szrj #define PPC_APUINFO_PMR		0x41
211*a9fa9459Szrj #define PPC_APUINFO_RFMCI	0x42
212*a9fa9459Szrj #define PPC_APUINFO_CACHELCK	0x43
213*a9fa9459Szrj #define PPC_APUINFO_SPE		0x100
214*a9fa9459Szrj #define PPC_APUINFO_EFS		0x101
215*a9fa9459Szrj #define PPC_APUINFO_BRLOCK	0x102
216*a9fa9459Szrj #define PPC_APUINFO_VLE		0x104
217*a9fa9459Szrj 
218*a9fa9459Szrj /* Object attribute tags.  */
219*a9fa9459Szrj enum
220*a9fa9459Szrj {
221*a9fa9459Szrj   /* 0-3 are generic.  */
222*a9fa9459Szrj   Tag_GNU_Power_ABI_FP = 4, /* Value 1 for hard-float, 2 for
223*a9fa9459Szrj 			       soft-float, 3 for single=precision
224*a9fa9459Szrj 			       hard-float; 0 for not tagged or not
225*a9fa9459Szrj 			       using any ABIs affected by the
226*a9fa9459Szrj 			       differences.  */
227*a9fa9459Szrj 
228*a9fa9459Szrj   /* Value 1 for general purpose registers only, 2 for AltiVec
229*a9fa9459Szrj      registers, 3 for SPE registers; 0 for not tagged or not using any
230*a9fa9459Szrj      ABIs affected by the differences.  */
231*a9fa9459Szrj   Tag_GNU_Power_ABI_Vector = 8,
232*a9fa9459Szrj 
233*a9fa9459Szrj   /* Value 1 for ABIs using r3/r4 for returning structures <= 8 bytes,
234*a9fa9459Szrj      2 for ABIs using memory; 0 for not tagged or not using any ABIs
235*a9fa9459Szrj      affected by the differences.  */
236*a9fa9459Szrj   Tag_GNU_Power_ABI_Struct_Return = 12
237*a9fa9459Szrj };
238*a9fa9459Szrj 
239*a9fa9459Szrj #endif /* _ELF_PPC_H */
240