1*a9fa9459Szrj // powerpc.h -- ELF definitions specific to EM_PPC and EM_PPC64 -*- C++ -*-
2*a9fa9459Szrj
3*a9fa9459Szrj // Copyright (C) 2008-2016 Free Software Foundation, Inc.
4*a9fa9459Szrj // Written by David S. Miller <davem@davemloft.net>.
5*a9fa9459Szrj
6*a9fa9459Szrj // This file is part of elfcpp.
7*a9fa9459Szrj
8*a9fa9459Szrj // This program is free software; you can redistribute it and/or
9*a9fa9459Szrj // modify it under the terms of the GNU Library General Public License
10*a9fa9459Szrj // as published by the Free Software Foundation; either version 2, or
11*a9fa9459Szrj // (at your option) any later version.
12*a9fa9459Szrj
13*a9fa9459Szrj // In addition to the permissions in the GNU Library General Public
14*a9fa9459Szrj // License, the Free Software Foundation gives you unlimited
15*a9fa9459Szrj // permission to link the compiled version of this file into
16*a9fa9459Szrj // combinations with other programs, and to distribute those
17*a9fa9459Szrj // combinations without any restriction coming from the use of this
18*a9fa9459Szrj // file. (The Library Public License restrictions do apply in other
19*a9fa9459Szrj // respects; for example, they cover modification of the file, and
20*a9fa9459Szrj /// distribution when not linked into a combined executable.)
21*a9fa9459Szrj
22*a9fa9459Szrj // This program is distributed in the hope that it will be useful, but
23*a9fa9459Szrj // WITHOUT ANY WARRANTY; without even the implied warranty of
24*a9fa9459Szrj // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
25*a9fa9459Szrj // Library General Public License for more details.
26*a9fa9459Szrj
27*a9fa9459Szrj // You should have received a copy of the GNU Library General Public
28*a9fa9459Szrj // License along with this program; if not, write to the Free Software
29*a9fa9459Szrj // Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
30*a9fa9459Szrj // 02110-1301, USA.
31*a9fa9459Szrj
32*a9fa9459Szrj #ifndef ELFCPP_POWERPC_H
33*a9fa9459Szrj #define ELFCPP_POWERPC_H
34*a9fa9459Szrj
35*a9fa9459Szrj namespace elfcpp
36*a9fa9459Szrj {
37*a9fa9459Szrj
38*a9fa9459Szrj // The relocation numbers for 32-bit and 64-bit powerpc are nearly
39*a9fa9459Szrj // identical. Therefore I've adopted the convention of using
40*a9fa9459Szrj // R_POWERPC_foo for values which are the same in R_PPC_* and R_PPC64_*.
41*a9fa9459Szrj // For relocations which are specific to the word size I will use
42*a9fa9459Szrj // R_PPC_foo or R_PPC64_foo.
43*a9fa9459Szrj enum
44*a9fa9459Szrj {
45*a9fa9459Szrj R_POWERPC_NONE = 0,
46*a9fa9459Szrj R_POWERPC_ADDR32 = 1,
47*a9fa9459Szrj R_POWERPC_ADDR24 = 2,
48*a9fa9459Szrj R_POWERPC_ADDR16 = 3,
49*a9fa9459Szrj R_POWERPC_ADDR16_LO = 4,
50*a9fa9459Szrj R_POWERPC_ADDR16_HI = 5,
51*a9fa9459Szrj R_POWERPC_ADDR16_HA = 6,
52*a9fa9459Szrj R_POWERPC_ADDR14 = 7,
53*a9fa9459Szrj R_POWERPC_ADDR14_BRTAKEN = 8,
54*a9fa9459Szrj R_POWERPC_ADDR14_BRNTAKEN = 9,
55*a9fa9459Szrj R_POWERPC_REL24 = 10,
56*a9fa9459Szrj R_POWERPC_REL14 = 11,
57*a9fa9459Szrj R_POWERPC_REL14_BRTAKEN = 12,
58*a9fa9459Szrj R_POWERPC_REL14_BRNTAKEN = 13,
59*a9fa9459Szrj R_POWERPC_GOT16 = 14,
60*a9fa9459Szrj R_POWERPC_GOT16_LO = 15,
61*a9fa9459Szrj R_POWERPC_GOT16_HI = 16,
62*a9fa9459Szrj R_POWERPC_GOT16_HA = 17,
63*a9fa9459Szrj R_PPC_PLTREL24 = 18,
64*a9fa9459Szrj R_POWERPC_COPY = 19,
65*a9fa9459Szrj R_POWERPC_GLOB_DAT = 20,
66*a9fa9459Szrj R_POWERPC_JMP_SLOT = 21,
67*a9fa9459Szrj R_POWERPC_RELATIVE = 22,
68*a9fa9459Szrj R_PPC_LOCAL24PC = 23,
69*a9fa9459Szrj R_POWERPC_UADDR32 = 24,
70*a9fa9459Szrj R_POWERPC_UADDR16 = 25,
71*a9fa9459Szrj R_POWERPC_REL32 = 26,
72*a9fa9459Szrj R_POWERPC_PLT32 = 27,
73*a9fa9459Szrj R_POWERPC_PLTREL32 = 28,
74*a9fa9459Szrj R_POWERPC_PLT16_LO = 29,
75*a9fa9459Szrj R_POWERPC_PLT16_HI = 30,
76*a9fa9459Szrj R_POWERPC_PLT16_HA = 31,
77*a9fa9459Szrj R_PPC_SDAREL16 = 32,
78*a9fa9459Szrj R_POWERPC_SECTOFF = 33,
79*a9fa9459Szrj R_POWERPC_SECTOFF_LO = 34,
80*a9fa9459Szrj R_POWERPC_SECTOFF_HI = 35,
81*a9fa9459Szrj R_POWERPC_SECTOFF_HA = 36,
82*a9fa9459Szrj R_POWERPC_ADDR30 = 37,
83*a9fa9459Szrj R_PPC64_ADDR64 = 38,
84*a9fa9459Szrj R_PPC64_ADDR16_HIGHER = 39,
85*a9fa9459Szrj R_PPC64_ADDR16_HIGHERA = 40,
86*a9fa9459Szrj R_PPC64_ADDR16_HIGHEST = 41,
87*a9fa9459Szrj R_PPC64_ADDR16_HIGHESTA = 42,
88*a9fa9459Szrj R_PPC64_UADDR64 = 43,
89*a9fa9459Szrj R_PPC64_REL64 = 44,
90*a9fa9459Szrj R_PPC64_PLT64 = 45,
91*a9fa9459Szrj R_PPC64_PLTREL64 = 46,
92*a9fa9459Szrj R_PPC64_TOC16 = 47,
93*a9fa9459Szrj R_PPC64_TOC16_LO = 48,
94*a9fa9459Szrj R_PPC64_TOC16_HI = 49,
95*a9fa9459Szrj R_PPC64_TOC16_HA = 50,
96*a9fa9459Szrj R_PPC64_TOC = 51,
97*a9fa9459Szrj R_PPC64_PLTGOT16 = 52,
98*a9fa9459Szrj R_PPC64_PLTGOT16_LO = 53,
99*a9fa9459Szrj R_PPC64_PLTGOT16_HI = 54,
100*a9fa9459Szrj R_PPC64_PLTGOT16_HA = 55,
101*a9fa9459Szrj R_PPC64_ADDR16_DS = 56,
102*a9fa9459Szrj R_PPC64_ADDR16_LO_DS = 57,
103*a9fa9459Szrj R_PPC64_GOT16_DS = 58,
104*a9fa9459Szrj R_PPC64_GOT16_LO_DS = 59,
105*a9fa9459Szrj R_PPC64_PLT16_LO_DS = 60,
106*a9fa9459Szrj R_PPC64_SECTOFF_DS = 61,
107*a9fa9459Szrj R_PPC64_SECTOFF_LO_DS = 62,
108*a9fa9459Szrj R_PPC64_TOC16_DS = 63,
109*a9fa9459Szrj R_PPC64_TOC16_LO_DS = 64,
110*a9fa9459Szrj R_PPC64_PLTGOT16_DS = 65,
111*a9fa9459Szrj R_PPC64_PLTGOT16_LO_DS = 66,
112*a9fa9459Szrj R_POWERPC_TLS = 67,
113*a9fa9459Szrj R_POWERPC_DTPMOD = 68,
114*a9fa9459Szrj R_POWERPC_TPREL16 = 69,
115*a9fa9459Szrj R_POWERPC_TPREL16_LO = 70,
116*a9fa9459Szrj R_POWERPC_TPREL16_HI = 71,
117*a9fa9459Szrj R_POWERPC_TPREL16_HA = 72,
118*a9fa9459Szrj R_POWERPC_TPREL = 73,
119*a9fa9459Szrj R_POWERPC_DTPREL16 = 74,
120*a9fa9459Szrj R_POWERPC_DTPREL16_LO = 75,
121*a9fa9459Szrj R_POWERPC_DTPREL16_HI = 76,
122*a9fa9459Szrj R_POWERPC_DTPREL16_HA = 77,
123*a9fa9459Szrj R_POWERPC_DTPREL = 78,
124*a9fa9459Szrj R_POWERPC_GOT_TLSGD16 = 79,
125*a9fa9459Szrj R_POWERPC_GOT_TLSGD16_LO = 80,
126*a9fa9459Szrj R_POWERPC_GOT_TLSGD16_HI = 81,
127*a9fa9459Szrj R_POWERPC_GOT_TLSGD16_HA = 82,
128*a9fa9459Szrj R_POWERPC_GOT_TLSLD16 = 83,
129*a9fa9459Szrj R_POWERPC_GOT_TLSLD16_LO = 84,
130*a9fa9459Szrj R_POWERPC_GOT_TLSLD16_HI = 85,
131*a9fa9459Szrj R_POWERPC_GOT_TLSLD16_HA = 86,
132*a9fa9459Szrj R_POWERPC_GOT_TPREL16 = 87,
133*a9fa9459Szrj R_POWERPC_GOT_TPREL16_LO = 88,
134*a9fa9459Szrj R_POWERPC_GOT_TPREL16_HI = 89,
135*a9fa9459Szrj R_POWERPC_GOT_TPREL16_HA = 90,
136*a9fa9459Szrj R_POWERPC_GOT_DTPREL16 = 91,
137*a9fa9459Szrj R_POWERPC_GOT_DTPREL16_LO = 92,
138*a9fa9459Szrj R_POWERPC_GOT_DTPREL16_HI = 93,
139*a9fa9459Szrj R_POWERPC_GOT_DTPREL16_HA = 94,
140*a9fa9459Szrj R_PPC_TLSGD = 95,
141*a9fa9459Szrj R_PPC64_TPREL16_DS = 95,
142*a9fa9459Szrj R_PPC_TLSLD = 96,
143*a9fa9459Szrj R_PPC64_TPREL16_LO_DS = 96,
144*a9fa9459Szrj R_PPC64_TPREL16_HIGHER = 97,
145*a9fa9459Szrj R_PPC64_TPREL16_HIGHERA = 98,
146*a9fa9459Szrj R_PPC64_TPREL16_HIGHEST = 99,
147*a9fa9459Szrj R_PPC64_TPREL16_HIGHESTA = 100,
148*a9fa9459Szrj R_PPC_EMB_NADDR32 = 101,
149*a9fa9459Szrj R_PPC64_DTPREL16_DS = 101,
150*a9fa9459Szrj R_PPC_EMB_NADDR16 = 102,
151*a9fa9459Szrj R_PPC64_DTPREL16_LO_DS = 102,
152*a9fa9459Szrj R_PPC_EMB_NADDR16_LO = 103,
153*a9fa9459Szrj R_PPC64_DTPREL16_HIGHER = 103,
154*a9fa9459Szrj R_PPC_EMB_NADDR16_HI = 104,
155*a9fa9459Szrj R_PPC64_DTPREL16_HIGHERA = 104,
156*a9fa9459Szrj R_PPC_EMB_NADDR16_HA = 105,
157*a9fa9459Szrj R_PPC64_DTPREL16_HIGHEST = 105,
158*a9fa9459Szrj R_PPC_EMB_SDAI16 = 106,
159*a9fa9459Szrj R_PPC64_DTPREL16_HIGHESTA = 106,
160*a9fa9459Szrj R_PPC_EMB_SDA2I16 = 107,
161*a9fa9459Szrj R_PPC64_TLSGD = 107,
162*a9fa9459Szrj R_PPC_EMB_SDA2REL = 108,
163*a9fa9459Szrj R_PPC64_TLSLD = 108,
164*a9fa9459Szrj R_PPC_EMB_SDA21 = 109,
165*a9fa9459Szrj R_PPC64_TOCSAVE = 109,
166*a9fa9459Szrj R_PPC_EMB_MRKREF = 110,
167*a9fa9459Szrj R_PPC64_ADDR16_HIGH = 110,
168*a9fa9459Szrj R_PPC_EMB_RELSEC16 = 111,
169*a9fa9459Szrj R_PPC64_ADDR16_HIGHA = 111,
170*a9fa9459Szrj R_PPC_EMB_RELST_LO = 112,
171*a9fa9459Szrj R_PPC64_TPREL16_HIGH = 112,
172*a9fa9459Szrj R_PPC_EMB_RELST_HI = 113,
173*a9fa9459Szrj R_PPC64_TPREL16_HIGHA = 113,
174*a9fa9459Szrj R_PPC_EMB_RELST_HA = 114,
175*a9fa9459Szrj R_PPC64_DTPREL16_HIGH = 114,
176*a9fa9459Szrj R_PPC_EMB_BIT_FLD = 115,
177*a9fa9459Szrj R_PPC64_DTPREL16_HIGHA = 115,
178*a9fa9459Szrj R_PPC_EMB_RELSDA = 116,
179*a9fa9459Szrj R_PPC64_REL24_NOTOC = 116,
180*a9fa9459Szrj R_PPC64_ADDR64_LOCAL = 117,
181*a9fa9459Szrj R_PPC64_ENTRY = 118,
182*a9fa9459Szrj
183*a9fa9459Szrj R_PPC_VLE_REL8 = 216,
184*a9fa9459Szrj R_PPC_VLE_REL15 = 217,
185*a9fa9459Szrj R_PPC_VLE_REL24 = 218,
186*a9fa9459Szrj R_PPC_VLE_LO16A = 219,
187*a9fa9459Szrj R_PPC_VLE_LO16D = 220,
188*a9fa9459Szrj R_PPC_VLE_HI16A = 221,
189*a9fa9459Szrj R_PPC_VLE_HI16D = 222,
190*a9fa9459Szrj R_PPC_VLE_HA16A = 223,
191*a9fa9459Szrj R_PPC_VLE_HA16D = 224,
192*a9fa9459Szrj R_PPC_VLE_SDA21 = 225,
193*a9fa9459Szrj R_PPC_VLE_SDA21_LO = 226,
194*a9fa9459Szrj R_PPC_VLE_SDAREL_LO16A = 227,
195*a9fa9459Szrj R_PPC_VLE_SDAREL_LO16D = 228,
196*a9fa9459Szrj R_PPC_VLE_SDAREL_HI16A = 229,
197*a9fa9459Szrj R_PPC_VLE_SDAREL_HI16D = 230,
198*a9fa9459Szrj R_PPC_VLE_SDAREL_HA16A = 231,
199*a9fa9459Szrj R_PPC_VLE_SDAREL_HA16D = 232,
200*a9fa9459Szrj
201*a9fa9459Szrj R_POWERPC_REL16DX_HA = 246,
202*a9fa9459Szrj R_PPC64_JMP_IREL = 247,
203*a9fa9459Szrj R_POWERPC_IRELATIVE = 248,
204*a9fa9459Szrj R_POWERPC_REL16 = 249,
205*a9fa9459Szrj R_POWERPC_REL16_LO = 250,
206*a9fa9459Szrj R_POWERPC_REL16_HI = 251,
207*a9fa9459Szrj R_POWERPC_REL16_HA = 252,
208*a9fa9459Szrj R_POWERPC_GNU_VTINHERIT = 253,
209*a9fa9459Szrj R_POWERPC_GNU_VTENTRY = 254,
210*a9fa9459Szrj R_PPC_TOC16 = 255,
211*a9fa9459Szrj };
212*a9fa9459Szrj
213*a9fa9459Szrj // e_flags values defined for powerpc
214*a9fa9459Szrj enum
215*a9fa9459Szrj {
216*a9fa9459Szrj EF_PPC_EMB = 0x80000000, // PowerPC embedded flag.
217*a9fa9459Szrj EF_PPC_RELOCATABLE = 0x00010000, // PowerPC -mrelocatable flag. */
218*a9fa9459Szrj EF_PPC_RELOCATABLE_LIB = 0x00008000, // PowerPC -mrelocatable-lib flag. */
219*a9fa9459Szrj };
220*a9fa9459Szrj
221*a9fa9459Szrj // e_flags values defined for powerpc64
222*a9fa9459Szrj enum
223*a9fa9459Szrj {
224*a9fa9459Szrj // ABI version
225*a9fa9459Szrj // 1 for original function descriptor using ABI,
226*a9fa9459Szrj // 2 for revised ABI without function descriptors,
227*a9fa9459Szrj // 0 for unspecified or not using any features affected by the differences.
228*a9fa9459Szrj EF_PPC64_ABI = 3
229*a9fa9459Szrj };
230*a9fa9459Szrj
231*a9fa9459Szrj enum
232*a9fa9459Szrj {
233*a9fa9459Szrj // The ELFv2 ABI uses three bits in the symbol st_other field of a
234*a9fa9459Szrj // function definition to specify the number of instructions between a
235*a9fa9459Szrj // function's global entry point and local entry point.
236*a9fa9459Szrj // The global entry point is used when it is necessary to set up the
237*a9fa9459Szrj // toc pointer (r2) for the function. Callers must enter the global
238*a9fa9459Szrj // entry point with r12 set to the global entry point address. On
239*a9fa9459Szrj // return from the function, r2 may have a different value to that
240*a9fa9459Szrj // which it had on entry.
241*a9fa9459Szrj // The local entry point is used when r2 is known to already be valid
242*a9fa9459Szrj // for the function. There is no requirement on r12 when using the
243*a9fa9459Szrj // local entry point, and on return r2 will contain the same value as
244*a9fa9459Szrj // at entry.
245*a9fa9459Szrj // A value of zero in these bits means that the function has a single
246*a9fa9459Szrj // entry point with no requirement on r12 or r2, and that on return r2
247*a9fa9459Szrj // will contain the same value as at entry.
248*a9fa9459Szrj // Values of one and seven are reserved.
249*a9fa9459Szrj
250*a9fa9459Szrj STO_PPC64_LOCAL_BIT = 5,
251*a9fa9459Szrj STO_PPC64_LOCAL_MASK = 0xE0
252*a9fa9459Szrj };
253*a9fa9459Szrj
254*a9fa9459Szrj // 3 bit other field to bytes.
255*a9fa9459Szrj static inline unsigned int
ppc64_decode_local_entry(unsigned int other)256*a9fa9459Szrj ppc64_decode_local_entry(unsigned int other)
257*a9fa9459Szrj {
258*a9fa9459Szrj return ((1 << other) >> 2) << 2;
259*a9fa9459Szrj }
260*a9fa9459Szrj
261*a9fa9459Szrj // bytes to field value.
262*a9fa9459Szrj static inline unsigned int
ppc64_encode_local_entry(unsigned int val)263*a9fa9459Szrj ppc64_encode_local_entry(unsigned int val)
264*a9fa9459Szrj {
265*a9fa9459Szrj return (val >= 4 * 4
266*a9fa9459Szrj ? (val >= 8 * 4
267*a9fa9459Szrj ? (val >= 16 * 4 ? 6 : 5)
268*a9fa9459Szrj : 4)
269*a9fa9459Szrj : (val >= 2 * 4
270*a9fa9459Szrj ? 3
271*a9fa9459Szrj : (val >= 1 * 4 ? 2 : 0)));
272*a9fa9459Szrj }
273*a9fa9459Szrj
274*a9fa9459Szrj } // End namespace elfcpp.
275*a9fa9459Szrj
276*a9fa9459Szrj #endif // !defined(ELFCPP_POWERPC_H)
277