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