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