Home | History | Annotate | Line # | Download | only in include
      1 /*	$NetBSD: elf_machdep.h,v 1.17 2025/12/01 16:39:57 jkoshy Exp $	*/
      2 
      3 #ifndef _POWERPC_ELF_MACHDEP_H_
      4 #define _POWERPC_ELF_MACHDEP_H_
      5 
      6 #if !defined(_SYS_ELFDEFINITIONS_H_)
      7 
      8 /*
      9  * psABI symbols.
     10  */
     11 
     12 /* Specify the value of _GLOBAL_OFFSET_TABLE_ */
     13 #define	DT_PPC_GOT		DT_LOPROC
     14 #define	DT_PPC64_GLINK		(DT_LOPROC + 0)
     15 #define	DT_PPC64_OPD		(DT_LOPROC + 1)
     16 #define	DT_PPC64_OPDSZ		(DT_LOPROC + 2)
     17 #define	DT_PPC64_TLSOPT		(DT_LOPROC + 3)
     18 
     19 // A = the addend used to compute the value of relocatable field
     20 // B = the base address of the shared object
     21 // G = offset into the global offset table
     22 // L = section offset or address of the procedure link table entry for the
     23 //     symbol + addend
     24 // M = similar to G except the address which is stored may be the address of
     25 //     the procedure linkage table entry for the symbol
     26 // P = the place (section offset or address) of the storage unit being
     27 //     relocated (computed using r_offset)
     28 // R = the offset of the symbol with the section in which the symbol is defined
     29 // S = the value of the symbol whose index resides in the relocation entry
     30 //
     31 // @dtpmod
     32 //   Computes the load module index of the load module that contains the
     33 //   definition of sym.  The addend, if present, is ignored.
     34 // @dtprel
     35 //   Computes a dtv-relative displacement, the difference between the value of
     36 //   S + A and the base address of the thread-local storage block that contains
     37 //   the definition of the symbol, minus 0x8000.
     38 // @tprel
     39 //   Computes a tp-relative displacement, the difference between the value of
     40 //   S + A and the value of the thread pointer (r13).
     41 // @got@tlsgd
     42 //   Allocates two contiguous entries in the GOT to hold a tls_index structure,
     43 //   with values @dtpmod and @dtprel, and computes the offset to the first
     44 //   entry relative to the TOC base (r2).
     45 // @got@tlsld
     46 //   Allocates two contiguous entries in the GOT to hold a tls_index structure,
     47 //   with values @dtpmod and zero, and computes the offset to the first entry
     48 //   relative to the TOC base (r2).
     49 // @got@dtprel
     50 //   Allocates an entry in the GOT with value @dtprel, and computes the offset
     51 //   to the entry relative to the TOC base (r2).
     52 // @got@tprel
     53 //   Allocates an entry in the GOT with value @tprel, and computes the offset
     54 //   to the entry relative to the TOC base (r2).
     55 //
     56 // #lo(x) = (x & 0xffff)
     57 // #hi(x) = ((x >> 16) & 0xffff)
     58 // #ha(x) = (((x >> 16) + ((x & 0x8000) == 0x8000)) & 0xffff)
     59 // #higher(x) = ((x >> 32) & 0xffff)
     60 // #highera(x) =
     61 //    (((x >> 32) + ((x & 0xffff8000) == 0xffff8000)) & 0xffff)
     62 // #highest(x) = ((x >> 48) & 0xffff)
     63 // #highesta(x) =
     64 //    (((x >> 48) + ((x & 0xffffffff8000) == 0xffffffff8000)) & 0xffff)
     65 // .TOC. = base TOC base of TOC section for object being relocated
     66 
     67 #define	R_PPC_NONE 		0
     68 #define	R_PPC_ADDR32 		1	// S + A
     69 #define	R_PPC_ADDR24 		2	// (S + A) >> 2
     70 #define	R_PPC_ADDR16 		3	// S + A
     71 #define	R_PPC_ADDR16_LO 	4	// #lo(S + A)
     72 #define	R_PPC_ADDR16_HI 	5	// #hi(S + A)
     73 #define	R_PPC_ADDR16_HA 	6	// #ha(S + A)
     74 #define	R_PPC_ADDR14 		7	// (S + A) >> 2
     75 #define	R_PPC_ADDR14_BRTAKEN  	8	// (S + A) >> 2
     76 #define	R_PPC_ADDR14_BRNTAKEN 	9	// (S + A) >> 2
     77 #define	R_PPC_REL24 		10 	// (S + A - P) >> 2
     78 #define	R_PPC_REL14 		11	// (S + A - P) >> 2
     79 #define	R_PPC_REL14_BRTAKEN 	12	// (S + A - P) >> 2
     80 #define	R_PPC_REL14_BRNTAKEN 	13	// (S + A - P) >> 2
     81 #define	R_PPC_GOT16 		14	// G + A
     82 #define	R_PPC_GOT16_LO 		15	// #lo(G + A)
     83 #define	R_PPC_GOT16_HI 		16	// #hi(G + A)
     84 #define	R_PPC_GOT16_HA 		17	// #ha(G + A)
     85 #define	R_PPC_PLTREL24 		18	// (L + A - P) >> 2
     86 #define	R_PPC_COPY 		19	// none
     87 #define	R_PPC_GLOB_DAT 		20	// S + A
     88 #define	R_PPC_JMP_SLOT 		21
     89 #define	R_PPC_RELATIVE 		22	// B + A
     90 #define	R_PPC_LOCAL24PC 	23	// (see R_PPC_REL24)
     91 #define	R_PPC_UADDR32 		24	// S + A
     92 #define	R_PPC_UADDR16 		25	// S + A
     93 #define	R_PPC_REL32 		26	// S + A - P
     94 #define	R_PPC_PLT32 		27	// L
     95 #define	R_PPC_PLTREL32 		28	// L - P
     96 #define	R_PPC_PLT16_LO 		29	// #lo(L)
     97 #define	R_PPC_PLT16_HI 		30	// #hi(L)
     98 #define	R_PPC_PLT16_HA 		31	// #ha(L)
     99 #define	R_PPC_SDAREL16 		32	// S + A - _SDA_BASE_
    100 #define	R_PPC_SECTOFF 		33	// R + A
    101 #define	R_PPC_SECTOFF_LO 	34	// #lo(R + A)
    102 #define	R_PPC_SECTOFF_HI	35	// #lo(R + A)
    103 #define	R_PPC_SECTOFF_HA	36	// #ha(R + A)
    104 #define	R_PPC_ADDR30 		37	// (S + A - P) >> 2
    105 
    106 /* PPC64 relocations */
    107 #define R_PPC64_ADDR64		38	// S + A
    108 #define R_PPC64_ADDR16_HIGHER	39	// #higher(S + A)
    109 #define R_PPC64_ADDR16_HIGHERA	40	// #highera(S + A)
    110 #define R_PPC64_ADDR16_HIGHEST	41	// #highest(S + A)
    111 #define R_PPC64_ADDR16_HIGHESTA	42	// #highesta(S + A)
    112 #define R_PPC64_UADDR64		43	// S + A
    113 #define R_PPC64_REL64		44	// S + A - P
    114 #define R_PPC64_PLT64		45	// L
    115 #define R_PPC64_PLTREL64	46	// L - P
    116 #define	R_PPC64_TOC16 		47	// S + A - .TOC.
    117 #define	R_PPC64_TOC16_LO	48	// #lo(S + A - .TOC.)
    118 #define	R_PPC64_TOC16_HI	49	// #lo(S + A - .TOC.)
    119 #define	R_PPC64_TOC16_HA	50	// #ha(S + A - .TOC.)
    120 #define R_PPC64_TOC		51	// .TOC.
    121 #define	R_PPC64_PLTGOT16 	52	// M
    122 #define	R_PPC64_PLTGOT16_LO 	53	// #lo(M)
    123 #define	R_PPC64_PLTGOT16_HI	54	// #lo(M)
    124 #define	R_PPC64_PLTGOT16_HA	55	// #ha(M)
    125 #define	R_PPC64_ADDR16_DS	56	// (S + A) >> 2
    126 #define	R_PPC64_ADDR16_LO_DS 	57	// #lo(S + A) >> 2
    127 #define	R_PPC64_GOT16_DS 	58	// G >> 2
    128 #define	R_PPC64_GOT16_LO_DS 	59	// #lo(G) >> 2
    129 #define	R_PPC64_PLT16_LO_DS 	60	// #lo(L) >> 2
    130 #define	R_PPC64_SECTOFF_DS	61	// (R + A) >> 2
    131 #define	R_PPC64_SECTOFF_LO_DS	62	// #lo(R + A) >> 2
    132 #define	R_PPC64_TOC16_DS	63	// (S + A - .TOC.) >> 2
    133 #define	R_PPC64_TOC16_LO_DS 	64	// #lo(S + A - .TOC.) >> 2
    134 #define	R_PPC64_PLTGOT16_DS	65	// M >> 2
    135 #define	R_PPC64_PLTGOT16_LO_DS 	66	// #lo(M) >> 2
    136 
    137 /* TLS relocations */
    138 #define	R_PPC_TLS		67	// none
    139 
    140 #define	R_PPC_DTPMOD32		68
    141 #define	R_PPC_TPREL16		69	// @tprel
    142 #define	R_PPC_TPREL16_LO	70	// #lo(@tprel)
    143 #define	R_PPC_TPREL16_HI	71	// #hi(@tprel)
    144 #define	R_PPC_TPREL16_HA	72	// #ha(@tprel)
    145 #define	R_PPC_TPREL32		73	// @tprel
    146 #define	R_PPC_DTPREL16		74	// @got@dtprel
    147 #define	R_PPC_DTPREL16_LO	75	// #lo(@dtprel)
    148 #define	R_PPC_DTPREL16_HI	76	// #hi(@dtprel)
    149 #define	R_PPC_DTPREL16_HA	77	// #ha(@dtprel)
    150 #define	R_PPC_DTPREL32		78	// @dtprel
    151 
    152 #define	R_PPC_GOT_TLSGD16	79	// @got@tlsgd
    153 #define	R_PPC_GOT_TLSGD16_LO	80	// #lo(@got@tlsgd)
    154 #define	R_PPC_GOT_TLSGD16_HI	81	// #hi(@got@tlsgd)
    155 #define	R_PPC_GOT_TLSGD16_HA	82	// #ha(@got@tlsgd)
    156 #define	R_PPC_GOT_TLSLD16	83	// @got@tlsld
    157 #define	R_PPC_GOT_TLSLD16_LO	84	// #lo(@got@tlsld)
    158 #define	R_PPC_GOT_TLSLD16_HI	85	// #hi(@got@tlsld)
    159 #define	R_PPC_GOT_TLSLD16_HA	86	// #ha(@got@tlsld)
    160 
    161 #define	R_PPC_GOT_TPREL16	87	// @got@tprel
    162 #define	R_PPC_GOT_TPREL16_LO	88	// #lo(@got@tprel)
    163 #define	R_PPC_GOT_TPREL16_HI	89	// #hi(@got@tprel)
    164 #define	R_PPC_GOT_TPREL16_HA	90	// #ha(@got@tprel)
    165 #define	R_PPC_GOT_DTPREL16	91	// @got@dtprel
    166 #define	R_PPC_GOT_DTPREL16_LO	92	// #lo(@got@dtprel)
    167 #define	R_PPC_GOT_DTPREL16_HI	93	// #hi(@got@dtprel)
    168 #define	R_PPC_GOT_DTPREL16_HA	94	// #ha(@got@dtprel)
    169 #define	R_PPC_TLSGD		95
    170 #define	R_PPC_TLSLD		96
    171 
    172 #define	R_PPC64_TPREL16_DS	95	// @tprel
    173 #define	R_PPC64_TPREL16_LO_DS	96	// #lo(@tprel)
    174 #define	R_PPC64_TPREL16_HIGHER	97	// #higher(@tprel)
    175 #define	R_PPC64_TPREL16_HIGHERA	98	// #highera(@tprel)
    176 #define	R_PPC64_TPREL16_HIGHEST	99	// #highest(@tprel)
    177 #define	R_PPC64_TPREL16_HIGHESTA 100	// #highesta(@tprel)
    178 
    179 #define	R_PPC64_DTPREL16_DS	101	// @dtprel
    180 #define	R_PPC64_DTPREL16_LO_DS	102	// #lo(@dtprel)
    181 #define	R_PPC64_DTPREL16_HIGHER	103	// #higher(@dtprel)
    182 #define	R_PPC64_DTPREL16_HIGHERA 104	// #highera(@dtprel)
    183 #define	R_PPC64_DTPREL16_HIGHEST 105	// #highest(@dtprel)
    184 #define	R_PPC64_DTPREL16_HIGHESTA 106	// #highesta(@dtprel)
    185 
    186 /* Indirect-function support */
    187 #define	R_PPC64_IRELATIVE	248
    188 #define	R_PPC_IRELATIVE		248     // GNU spelling.
    189 
    190 /* Used for the secure-plt PIC code sequences */
    191 #define	R_PPC64_REL16		249	// S + A - P
    192 #define	R_PPC64_REL16_LO	250	// #lo(S + A - P)
    193 #define	R_PPC64_REL16_HI	251	// #hi(S + A - P)
    194 #define	R_PPC64_REL16_HA	252	// #ha(S + A - P)
    195 
    196 #endif /* !defined(_SYS_ELFDEFINITIONS_H_) */
    197 
    198 /*
    199  * Local symbols.
    200  */
    201 
    202 #define	ELF32_MACHDEP_ENDIANNESS	ELFDATA2MSB
    203 #define	ELF32_MACHDEP_ID_CASES						\
    204 		case EM_PPC:						\
    205 			break;
    206 
    207 #define	ELF64_MACHDEP_ENDIANNESS	ELFDATA2MSB
    208 #define	ELF64_MACHDEP_ID_CASES						\
    209 		case EM_PPC64:						\
    210 			break;
    211 
    212 #define	ELF32_MACHDEP_ID	EM_PPC
    213 #define	ELF64_MACHDEP_ID	EM_PPC64
    214 
    215 
    216 #ifdef _LP64
    217 #define KERN_ELFSIZE		64
    218 #define ARCH_ELFSIZE		64	/* MD native binary size */
    219 #else
    220 #define KERN_ELFSIZE		32
    221 #define ARCH_ELFSIZE		32	/* MD native binary size */
    222 #endif
    223 
    224 /*
    225  * Local spellings of psABI constants.
    226  */
    227 #define	R_PPC_ADDR14_TAKEN 	8	// (S + A) >> 2
    228 #define	R_PPC_ADDR14_NTAKEN 	9	// (S + A) >> 2
    229 
    230 #define	R_PPC_REL14_TAKEN 	12	// (S + A - P) >> 2
    231 #define	R_PPC_REL14_NTAKEN 	13	// (S + A - P) >> 2
    232 
    233 #define	R_PPC_PLTREL 		28	// L - P
    234 
    235 /* PPC64 relocations */
    236 #define R_PPC_ADDR64		38	// S + A
    237 #define R_PPC_ADDR16_HIGHER	39	// #higher(S + A)
    238 #define R_PPC_ADDR16_HIGHERA	40	// #highera(S + A)
    239 #define R_PPC_ADDR16_HIGHEST	41	// #highest(S + A)
    240 #define R_PPC_ADDR16_HIGHESTA	42	// #highesta(S + A)
    241 #define R_PPC_UADDR64		43	// S + A
    242 #define R_PPC_REL64		44	// S + A - P
    243 #define R_PPC_PLT64		45	// L
    244 #define R_PPC_PLTREL4		46	// L - P
    245 #define	R_PPC_TOC16 		47	// S + A - .TOC.
    246 #define	R_PPC_TOC16_LO 		48	// #lo(S + A - .TOC.)
    247 #define	R_PPC_TOC16_HI		49	// #lo(S + A - .TOC.)
    248 #define	R_PPC_TOC16_HA		50	// #ha(S + A - .TOC.)
    249 #define R_PPC_TOC		51	// .TOC.
    250 #define	R_PPC_PLTGOT16 		52	// M
    251 #define	R_PPC_PLTGOT16_LO 	53	// #lo(M)
    252 #define	R_PPC_PLTGOT16_HI	54	// #lo(M)
    253 #define	R_PPC_PLTGOT16_HA	55	// #ha(M)
    254 #define	R_PPC_ADDR16_DS		56	// (S + A) >> 2
    255 #define	R_PPC_ADDR16_LO_DS 	57	// #lo(S + A) >> 2
    256 #define	R_PPC_GOT16_DS 		58	// G >> 2
    257 #define	R_PPC_GOT16_LO_DS 	59	// #lo(G) >> 2
    258 #define	R_PPC_PLT16_LO_DS 	60	// #lo(L) >> 2
    259 #define	R_PPC_SECTOFF16_DS	61	// (R + A) >> 2
    260 #define	R_PPC_SECTOFF16_LO_DS 	62	// #lo(R + A) >> 2
    261 #define	R_PPC_TOC16_DS		63	// (S + A - .TOC.) >> 2
    262 #define	R_PPC_TOC16_LO_DS 	64	// #lo(S + A - .TOC.) >> 2
    263 #define	R_PPC_PLTGOT16_DS	65	// M >> 2
    264 #define	R_PPC_PLTGOT16_LO_DS 	66	// #lo(M) >> 2
    265 
    266 #define	R_PPC_DTPMOD		68
    267 
    268 #define	R_PPC_TPREL		73	// @tprel
    269 
    270 #define	R_PPC_DTPREL		78	// @dtprel
    271 
    272 #define	R_PPC_TPREL16_DS	95	// @tprel
    273 #define	R_PPC_TPREL16_LO_DS	96	// #lo(@tprel)
    274 #define	R_PPC_TPREL16_HIGHER	97	// #higher(@tprel)
    275 #define	R_PPC_TPREL16_HIGHERA	98	// #highera(@tprel)
    276 #define	R_PPC_TPREL16_HIGHEST	99	// #highest(@tprel)
    277 #define	R_PPC_TPREL16_HIGHESTA	100	// #highesta(@tprel)
    278 
    279 #define	R_PPC_DTPREL16_DS	101	// @dtprel
    280 #define	R_PPC_DTPREL16_LO_DS	102	// #lo(@dtprel)
    281 #define	R_PPC_DTPREL16_HIGHER	103	// #higher(@dtprel)
    282 #define	R_PPC_DTPREL16_HIGHERA	104	// #highera(@dtprel)
    283 #define	R_PPC_DTPREL16_HIGHEST	105	// #highest(@dtprel)
    284 #define	R_PPC_DTPREL16_HIGHESTA	106	// #highesta(@dtprel)
    285 
    286 /* Used for the secure-plt PIC code sequences */
    287 #define	R_PPC_REL16		249	// S + A - P
    288 #define	R_PPC_REL16_LO		250	// #lo(S + A - P)
    289 #define	R_PPC_REL16_HI		251	// #hi(S + A - P)
    290 #define	R_PPC_REL16_HA		252	// #ha(S + A - P)
    291 
    292 #define R_TYPE(name) 		__CONCAT(R_PPC_,name)
    293 
    294 #endif /* _POWERPC_ELF_MACHDEP_H_ */
    295