xref: /netbsd-src/sys/arch/powerpc/include/elf_machdep.h (revision bd776e8c02a998b5f886e2c5db11c225bf418b1a)
1*bd776e8cSuwe /*	$NetBSD: elf_machdep.h,v 1.16 2019/12/08 21:46:03 uwe Exp $	*/
210432e09Smatt 
310432e09Smatt #ifndef _POWERPC_ELF_MACHDEP_H_
410432e09Smatt #define _POWERPC_ELF_MACHDEP_H_
536a0d584Sthorpej 
6522cbf02Skleink #define	ELF32_MACHDEP_ENDIANNESS	ELFDATA2MSB
736a0d584Sthorpej #define	ELF32_MACHDEP_ID_CASES						\
8522cbf02Skleink 		case EM_PPC:						\
936a0d584Sthorpej 			break;
1036a0d584Sthorpej 
11dd8ab8abSross #define	ELF64_MACHDEP_ENDIANNESS	ELFDATA2MSB
1236a0d584Sthorpej #define	ELF64_MACHDEP_ID_CASES						\
13dd8ab8abSross 		case EM_PPC64:						\
14dd8ab8abSross 			break;
1536a0d584Sthorpej 
1651535d4bSthorpej #define	ELF32_MACHDEP_ID	EM_PPC
17dd8ab8abSross #define	ELF64_MACHDEP_ID	EM_PPC64
1851535d4bSthorpej 
19dc2ac295Schristos 
20dd8ab8abSross #ifdef _LP64
2183e9db99Schristos #define KERN_ELFSIZE		64
22dd8ab8abSross #define ARCH_ELFSIZE		64	/* MD native binary size */
23dd8ab8abSross #else
2483e9db99Schristos #define KERN_ELFSIZE		32
2578b10569Sminoura #define ARCH_ELFSIZE		32	/* MD native binary size */
26dd8ab8abSross #endif
2778b10569Sminoura 
281446ab5eSmatt /* Specify the value of _GLOBAL_OFFSET_TABLE_ */
291446ab5eSmatt #define	DT_PPC_GOT		DT_LOPROC
301de63f39Smatt #define	DT_PPC64_GLINK		(DT_LOPROC + 0)
311de63f39Smatt #define	DT_PPC64_OPD		(DT_LOPROC + 1)
321de63f39Smatt #define	DT_PPC64_OPDSZ		(DT_LOPROC + 2)
331de63f39Smatt #define	DT_PPC64_TLSOPT		(DT_LOPROC + 3)
341446ab5eSmatt 
3510432e09Smatt // A = the addend used to compute the value of relocatable field
3610432e09Smatt // B = the base address of the shared object
3710432e09Smatt // G = offset into the global offset table
3810432e09Smatt // L = section offset or address of the procedure link table entry for the
3910432e09Smatt //     symbol + addend
4010432e09Smatt // M = similar to G except the address which is stored may be the address of
4110432e09Smatt //     the procedure linkage table entry for the symbol
4210432e09Smatt // P = the place (section offset or address) of the storage unit being
4310432e09Smatt //     relocated (computed using r_offset)
4410432e09Smatt // R = the offset of the symbol with the section in which the symbol is defined
4510432e09Smatt // S = the value of the symbol whose index resides in the relocation entry
4610432e09Smatt //
4710432e09Smatt // @dtpmod
4810432e09Smatt //   Computes the load module index of the load module that contains the
4910432e09Smatt //   definition of sym.  The addend, if present, is ignored.
5010432e09Smatt // @dtprel
5110432e09Smatt //   Computes a dtv-relative displacement, the difference between the value of
5210432e09Smatt //   S + A and the base address of the thread-local storage block that contains
5310432e09Smatt //   the definition of the symbol, minus 0x8000.
5410432e09Smatt // @tprel
5510432e09Smatt //   Computes a tp-relative displacement, the difference between the value of
5610432e09Smatt //   S + A and the value of the thread pointer (r13).
5710432e09Smatt // @got@tlsgd
5810432e09Smatt //   Allocates two contiguous entries in the GOT to hold a tls_index structure,
5910432e09Smatt //   with values @dtpmod and @dtprel, and computes the offset to the first
6010432e09Smatt //   entry relative to the TOC base (r2).
6110432e09Smatt // @got@tlsld
6210432e09Smatt //   Allocates two contiguous entries in the GOT to hold a tls_index structure,
6310432e09Smatt //   with values @dtpmod and zero, and computes the offset to the first entry
6410432e09Smatt //   relative to the TOC base (r2).
6510432e09Smatt // @got@dtprel
6610432e09Smatt //   Allocates an entry in the GOT with value @dtprel, and computes the offset
6710432e09Smatt //   to the entry relative to the TOC base (r2).
6810432e09Smatt // @got@tprel
6910432e09Smatt //   Allocates an entry in the GOT with value @tprel, and computes the offset
7010432e09Smatt //   to the entry relative to the TOC base (r2).
7110432e09Smatt //
7210432e09Smatt // #lo(x) = (x & 0xffff)
7310432e09Smatt // #hi(x) = ((x >> 16) & 0xffff)
74*bd776e8cSuwe // #ha(x) = (((x >> 16) + ((x & 0x8000) == 0x8000)) & 0xffff)
7510432e09Smatt // #higher(x) = ((x >> 32) & 0xffff)
7610432e09Smatt // #highera(x) =
7710432e09Smatt //    (((x >> 32) + ((x & 0xffff8000) == 0xffff8000)) & 0xffff)
7810432e09Smatt // #highest(x) = ((x >> 48) & 0xffff)
7910432e09Smatt // #highesta(x) =
8010432e09Smatt //    (((x >> 48) + ((x & 0xffffffff8000) == 0xffffffff8000)) & 0xffff)
8110432e09Smatt // .TOC. = base TOC base of TOC section for object being relocated
8210432e09Smatt 
8324a77a11Sfreza #define	R_PPC_NONE 		0
8410432e09Smatt #define	R_PPC_ADDR32 		1	// S + A
8510432e09Smatt #define	R_PPC_ADDR24 		2	// (S + A) >> 2
8610432e09Smatt #define	R_PPC_ADDR16 		3	// S + A
8710432e09Smatt #define	R_PPC_ADDR16_LO 	4	// #lo(S + A)
8810432e09Smatt #define	R_PPC_ADDR16_HI 	5	// #hi(S + A)
8910432e09Smatt #define	R_PPC_ADDR16_HA 	6	// #ha(S + A)
9010432e09Smatt #define	R_PPC_ADDR14 		7	// (S + A) >> 2
9110432e09Smatt #define	R_PPC_ADDR14_TAKEN 	8	// (S + A) >> 2
9210432e09Smatt #define	R_PPC_ADDR14_NTAKEN 	9	// (S + A) >> 2
9310432e09Smatt #define	R_PPC_REL24 		10 	// (S + A - P) >> 2
9410432e09Smatt #define	R_PPC_REL14 		11	// (S + A - P) >> 2
9510432e09Smatt #define	R_PPC_REL14_TAKEN 	12	// (S + A - P) >> 2
9610432e09Smatt #define	R_PPC_REL14_NTAKEN 	13	// (S + A - P) >> 2
9710432e09Smatt #define	R_PPC_GOT16 		14	// G + A
9810432e09Smatt #define	R_PPC_GOT16_LO 		15	// #lo(G + A)
9910432e09Smatt #define	R_PPC_GOT16_HI 		16	// #hi(G + A)
10010432e09Smatt #define	R_PPC_GOT16_HA 		17	// #ha(G + A)
10110432e09Smatt #define	R_PPC_PLTREL24 		18	// (L + A - P) >> 2
10210432e09Smatt #define	R_PPC_COPY 		19	// none
10310432e09Smatt #define	R_PPC_GLOB_DAT 		20	// S + A
10424a77a11Sfreza #define	R_PPC_JMP_SLOT 		21
10510432e09Smatt #define	R_PPC_RELATIVE 		22	// B + A
10610432e09Smatt #define	R_PPC_LOCAL24PC 	23	// (see R_PPC_REL24)
10710432e09Smatt #define	R_PPC_UADDR32 		24	// S + A
10810432e09Smatt #define	R_PPC_UADDR16 		25	// S + A
10910432e09Smatt #define	R_PPC_REL32 		26	// S + A - P
11010432e09Smatt #define	R_PPC_PLT32 		27	// L
11110432e09Smatt #define	R_PPC_PLTREL 		28	// L - P
11210432e09Smatt #define	R_PPC_PLT16_LO 		29	// #lo(L)
11310432e09Smatt #define	R_PPC_PLT16_HI 		30	// #hi(L)
11410432e09Smatt #define	R_PPC_PLT16_HA 		31	// #ha(L)
11510432e09Smatt #define	R_PPC_SDAREL16 		32	// S + A - _SDA_BASE_
11610432e09Smatt #define	R_PPC_SECTOFF 		33	// R + A
11710432e09Smatt #define	R_PPC_SECTOFF_LO 	34	// #lo(R + A)
11810432e09Smatt #define	R_PPC_SECTOFF_HI	35	// #lo(R + A)
11910432e09Smatt #define	R_PPC_SECTOFF_HA	36	// #ha(R + A)
12010432e09Smatt #define	R_PPC_ADDR30 		37	// (S + A - P) >> 2
12110432e09Smatt /* PPC64 relocations */
12210432e09Smatt #define R_PPC_ADDR64		38	// S + A
12310432e09Smatt #define R_PPC_ADDR16_HIGHER	39	// #higher(S + A)
12410432e09Smatt #define R_PPC_ADDR16_HIGHERA	40	// #highera(S + A)
12510432e09Smatt #define R_PPC_ADDR16_HIGHEST	41	// #highest(S + A)
12610432e09Smatt #define R_PPC_ADDR16_HIGHESTA	42	// #highesta(S + A)
12710432e09Smatt #define R_PPC_UADDR64		43	// S + A
12810432e09Smatt #define R_PPC_REL64		44	// S + A - P
12910432e09Smatt #define R_PPC_PLT64		45	// L
13010432e09Smatt #define R_PPC_PLTREL4		46	// L - P
13110432e09Smatt #define	R_PPC_TOC16 		47	// S + A - .TOC.
13210432e09Smatt #define	R_PPC_TOC16_LO 		48	// #lo(S + A - .TOC.)
13310432e09Smatt #define	R_PPC_TOC16_HI		49	// #lo(S + A - .TOC.)
13410432e09Smatt #define	R_PPC_TOC16_HA		50	// #ha(S + A - .TOC.)
13510432e09Smatt #define R_PPC_TOC		51	// .TOC.
13610432e09Smatt #define	R_PPC_PLTGOT16 		52	// M
13710432e09Smatt #define	R_PPC_PLTGOT16_LO 	53	// #lo(M)
13810432e09Smatt #define	R_PPC_PLTGOT16_HI	54	// #lo(M)
13910432e09Smatt #define	R_PPC_PLTGOT16_HA	55	// #ha(M)
14010432e09Smatt #define	R_PPC_ADDR16_DS		56	// (S + A) >> 2
14110432e09Smatt #define	R_PPC_ADDR16_LO_DS 	57	// #lo(S + A) >> 2
14210432e09Smatt #define	R_PPC_GOT16_DS 		58	// G >> 2
14310432e09Smatt #define	R_PPC_GOT16_LO_DS 	59	// #lo(G) >> 2
14410432e09Smatt #define	R_PPC_PLT16_LO_DS 	60	// #lo(L) >> 2
14510432e09Smatt #define	R_PPC_SECTOFF16_DS	61	// (R + A) >> 2
14610432e09Smatt #define	R_PPC_SECTOFF16_LO_DS 	62	// #lo(R + A) >> 2
14710432e09Smatt #define	R_PPC_TOC16_DS		63	// (S + A - .TOC.) >> 2
14810432e09Smatt #define	R_PPC_TOC16_LO_DS 	64	// #lo(S + A - .TOC.) >> 2
14910432e09Smatt #define	R_PPC_PLTGOT16_DS	65	// M >> 2
15010432e09Smatt #define	R_PPC_PLTGOT16_LO_DS 	66	// #lo(M) >> 2
151ac7d3e64Stsubai 
152e0397662Sskrll /* TLS relocations */
15310432e09Smatt #define	R_PPC_TLS		67	// none
154e0397662Sskrll 
15510432e09Smatt #define	R_PPC_DTPMOD		68
15610432e09Smatt #define	R_PPC_TPREL16		69	// @tprel
15710432e09Smatt #define	R_PPC_TPREL16_LO	70	// #lo(@tprel)
15810432e09Smatt #define	R_PPC_TPREL16_HI	71	// #hi(@tprel)
15910432e09Smatt #define	R_PPC_TPREL16_HA	72	// #ha(@tprel)
16010432e09Smatt #define	R_PPC_TPREL		73	// @tprel
16110432e09Smatt #define	R_PPC_DTPREL16		74	// @got@dtprel
16210432e09Smatt #define	R_PPC_DTPREL16_LO	75	// #lo(@dtprel)
16310432e09Smatt #define	R_PPC_DTPREL16_HI	76	// #hi(@dtprel)
16410432e09Smatt #define	R_PPC_DTPREL16_HA	77	// #ha(@dtprel)
16510432e09Smatt #define	R_PPC_DTPREL		78	// @dtprel
166e0397662Sskrll 
16710432e09Smatt #define	R_PPC_GOT_TLSGD16	79	// @got@tlsgd
16810432e09Smatt #define	R_PPC_GOT_TLSGD16_LO	80	// #lo(@got@tlsgd)
16910432e09Smatt #define	R_PPC_GOT_TLSGD16_HI	81	// #hi(@got@tlsgd)
17010432e09Smatt #define	R_PPC_GOT_TLSGD16_HA	82	// #ha(@got@tlsgd)
17110432e09Smatt #define	R_PPC_GOT_TLSLD16	83	// @got@tlsld
17210432e09Smatt #define	R_PPC_GOT_TLSLD16_LO	84	// #lo(@got@tlsld)
17310432e09Smatt #define	R_PPC_GOT_TLSLD16_HI	85	// #hi(@got@tlsld)
17410432e09Smatt #define	R_PPC_GOT_TLSLD16_HA	86	// #ha(@got@tlsld)
175e0397662Sskrll 
17610432e09Smatt #define	R_PPC_GOT_TPREL16	87	// @got@tprel
17710432e09Smatt #define	R_PPC_GOT_TPREL16_LO	88	// #lo(@got@tprel)
17810432e09Smatt #define	R_PPC_GOT_TPREL16_HI	89	// #hi(@got@tprel)
17910432e09Smatt #define	R_PPC_GOT_TPREL16_HA	90	// #ha(@got@tprel)
18010432e09Smatt #define	R_PPC_GOT_DTPREL16	91	// @got@dtprel
18110432e09Smatt #define	R_PPC_GOT_DTPREL16_LO	92	// #lo(@got@dtprel)
18210432e09Smatt #define	R_PPC_GOT_DTPREL16_HI	93	// #hi(@got@dtprel)
18310432e09Smatt #define	R_PPC_GOT_DTPREL16_HA	94	// #ha(@got@dtprel)
184e0397662Sskrll #define	R_PPC_TLSGD		95
185e0397662Sskrll #define	R_PPC_TLSLD		96
186e0397662Sskrll 
18710432e09Smatt /* PPC64 relocations */
18810432e09Smatt #define	R_PPC_TPREL16_DS	95	// @tprel
18910432e09Smatt #define	R_PPC_TPREL16_LO_DS	96	// #lo(@tprel)
19010432e09Smatt #define	R_PPC_TPREL16_HIGHER	97	// #higher(@tprel)
19110432e09Smatt #define	R_PPC_TPREL16_HIGHERA	98	// #highera(@tprel)
19210432e09Smatt #define	R_PPC_TPREL16_HIGHEST	99	// #highest(@tprel)
19310432e09Smatt #define	R_PPC_TPREL16_HIGHESTA	100	// #highesta(@tprel)
19410432e09Smatt 
19510432e09Smatt #define	R_PPC_DTPREL16_DS	101	// @dtprel
19610432e09Smatt #define	R_PPC_DTPREL16_LO_DS	102	// #lo(@dtprel)
19710432e09Smatt #define	R_PPC_DTPREL16_HIGHER	103	// #higher(@dtprel)
19810432e09Smatt #define	R_PPC_DTPREL16_HIGHERA	104	// #highera(@dtprel)
19910432e09Smatt #define	R_PPC_DTPREL16_HIGHEST	105	// #highest(@dtprel)
20010432e09Smatt #define	R_PPC_DTPREL16_HIGHESTA	106	// #highesta(@dtprel)
20110432e09Smatt 
202e78cfb8eSjoerg /* Indirect-function support */
203e78cfb8eSjoerg #define	R_PPC_IRELATIVE		248
204e78cfb8eSjoerg 
2051446ab5eSmatt /* Used for the secure-plt PIC code sequences */
20610432e09Smatt #define	R_PPC_REL16		249	// S + A - P
20710432e09Smatt #define	R_PPC_REL16_LO		250	// #lo(S + A - P)
20810432e09Smatt #define	R_PPC_REL16_HI		251	// #hi(S + A - P)
20910432e09Smatt #define	R_PPC_REL16_HA		252	// #ha(S + A - P)
2101446ab5eSmatt 
21124a77a11Sfreza #define R_TYPE(name) 		__CONCAT(R_PPC_,name)
21210432e09Smatt 
21310432e09Smatt #endif /* _POWERPC_ELF_MACHDEP_H_ */
214