| /* PPC ELF support for BFD. | 
 |    Copyright (C) 1995-2021 Free Software Foundation, Inc. | 
 |  | 
 |    By Michael Meissner, Cygnus Support, <meissner@cygnus.com>, | 
 |    from information in the System V Application Binary Interface, | 
 |    PowerPC Processor Supplement and the PowerPC Embedded Application | 
 |    Binary Interface (eabi). | 
 |  | 
 |    This file is part of BFD, the Binary File Descriptor library. | 
 |  | 
 |    This program is free software; you can redistribute it and/or modify | 
 |    it under the terms of the GNU General Public License as published by | 
 |    the Free Software Foundation; either version 3 of the License, or | 
 |    (at your option) any later version. | 
 |  | 
 |    This program is distributed in the hope that it will be useful, | 
 |    but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 |    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
 |    GNU General Public License for more details. | 
 |  | 
 |    You should have received a copy of the GNU General Public License | 
 |    along with this program; if not, write to the Free Software | 
 |    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, | 
 |    MA 02110-1301, USA.  */ | 
 |  | 
 | /* This file holds definitions specific to the PPC ELF ABI.  Note | 
 |    that most of this is not actually implemented by BFD.  */ | 
 |  | 
 | #ifndef _ELF_PPC_H | 
 | #define _ELF_PPC_H | 
 |  | 
 | #include "elf/reloc-macros.h" | 
 |  | 
 | /* Relocations.  */ | 
 | START_RELOC_NUMBERS (elf_ppc_reloc_type) | 
 |   RELOC_NUMBER (R_PPC_NONE,		  0) | 
 |   RELOC_NUMBER (R_PPC_ADDR32,		  1) | 
 |   RELOC_NUMBER (R_PPC_ADDR24,		  2) | 
 |   RELOC_NUMBER (R_PPC_ADDR16,		  3) | 
 |   RELOC_NUMBER (R_PPC_ADDR16_LO,	  4) | 
 |   RELOC_NUMBER (R_PPC_ADDR16_HI,	  5) | 
 |   RELOC_NUMBER (R_PPC_ADDR16_HA,	  6) | 
 |   RELOC_NUMBER (R_PPC_ADDR14,		  7) | 
 |   RELOC_NUMBER (R_PPC_ADDR14_BRTAKEN,	  8) | 
 |   RELOC_NUMBER (R_PPC_ADDR14_BRNTAKEN,	  9) | 
 |   RELOC_NUMBER (R_PPC_REL24,		 10) | 
 |   RELOC_NUMBER (R_PPC_REL14,		 11) | 
 |   RELOC_NUMBER (R_PPC_REL14_BRTAKEN,	 12) | 
 |   RELOC_NUMBER (R_PPC_REL14_BRNTAKEN,	 13) | 
 |   RELOC_NUMBER (R_PPC_GOT16,		 14) | 
 |   RELOC_NUMBER (R_PPC_GOT16_LO,		 15) | 
 |   RELOC_NUMBER (R_PPC_GOT16_HI,		 16) | 
 |   RELOC_NUMBER (R_PPC_GOT16_HA,		 17) | 
 |   RELOC_NUMBER (R_PPC_PLTREL24,		 18) | 
 |   RELOC_NUMBER (R_PPC_COPY,		 19) | 
 |   RELOC_NUMBER (R_PPC_GLOB_DAT,		 20) | 
 |   RELOC_NUMBER (R_PPC_JMP_SLOT,		 21) | 
 |   RELOC_NUMBER (R_PPC_RELATIVE,		 22) | 
 |   RELOC_NUMBER (R_PPC_LOCAL24PC,	 23) | 
 |   RELOC_NUMBER (R_PPC_UADDR32,		 24) | 
 |   RELOC_NUMBER (R_PPC_UADDR16,		 25) | 
 |   RELOC_NUMBER (R_PPC_REL32,		 26) | 
 |   RELOC_NUMBER (R_PPC_PLT32,		 27) | 
 |   RELOC_NUMBER (R_PPC_PLTREL32,		 28) | 
 |   RELOC_NUMBER (R_PPC_PLT16_LO,		 29) | 
 |   RELOC_NUMBER (R_PPC_PLT16_HI,		 30) | 
 |   RELOC_NUMBER (R_PPC_PLT16_HA,		 31) | 
 |   RELOC_NUMBER (R_PPC_SDAREL16,		 32) | 
 |   RELOC_NUMBER (R_PPC_SECTOFF,		 33) | 
 |   RELOC_NUMBER (R_PPC_SECTOFF_LO,	 34) | 
 |   RELOC_NUMBER (R_PPC_SECTOFF_HI,	 35) | 
 |   RELOC_NUMBER (R_PPC_SECTOFF_HA,	 36) | 
 |   RELOC_NUMBER (R_PPC_ADDR30,		 37) | 
 |  | 
 | #ifndef RELOC_MACROS_GEN_FUNC | 
 | /* Relocations only used internally by ld.  If you need to use these | 
 |    reloc numbers, you can change them to some other unused value | 
 |    without affecting the ABI.  They will never appear in object files.  */ | 
 |   RELOC_NUMBER (R_PPC_RELAX,		 48) | 
 |   RELOC_NUMBER (R_PPC_RELAX_PLT,	 49) | 
 |   RELOC_NUMBER (R_PPC_RELAX_PLTREL24,	 50) | 
 | /* Reloc only used internally by gas.  As above, value is unimportant.  */ | 
 |   RELOC_NUMBER (R_PPC_16DX_HA,		 51) | 
 | #endif | 
 |  | 
 |   /* Relocs added to support TLS.  */ | 
 |   RELOC_NUMBER (R_PPC_TLS,		 67) | 
 |   RELOC_NUMBER (R_PPC_DTPMOD32,		 68) | 
 |   RELOC_NUMBER (R_PPC_TPREL16,		 69) | 
 |   RELOC_NUMBER (R_PPC_TPREL16_LO,	 70) | 
 |   RELOC_NUMBER (R_PPC_TPREL16_HI,	 71) | 
 |   RELOC_NUMBER (R_PPC_TPREL16_HA,	 72) | 
 |   RELOC_NUMBER (R_PPC_TPREL32,		 73) | 
 |   RELOC_NUMBER (R_PPC_DTPREL16,		 74) | 
 |   RELOC_NUMBER (R_PPC_DTPREL16_LO,	 75) | 
 |   RELOC_NUMBER (R_PPC_DTPREL16_HI,	 76) | 
 |   RELOC_NUMBER (R_PPC_DTPREL16_HA,	 77) | 
 |   RELOC_NUMBER (R_PPC_DTPREL32,		 78) | 
 |   RELOC_NUMBER (R_PPC_GOT_TLSGD16,	 79) | 
 |   RELOC_NUMBER (R_PPC_GOT_TLSGD16_LO,	 80) | 
 |   RELOC_NUMBER (R_PPC_GOT_TLSGD16_HI,	 81) | 
 |   RELOC_NUMBER (R_PPC_GOT_TLSGD16_HA,	 82) | 
 |   RELOC_NUMBER (R_PPC_GOT_TLSLD16,	 83) | 
 |   RELOC_NUMBER (R_PPC_GOT_TLSLD16_LO,	 84) | 
 |   RELOC_NUMBER (R_PPC_GOT_TLSLD16_HI,	 85) | 
 |   RELOC_NUMBER (R_PPC_GOT_TLSLD16_HA,	 86) | 
 |   RELOC_NUMBER (R_PPC_GOT_TPREL16,	 87) | 
 |   RELOC_NUMBER (R_PPC_GOT_TPREL16_LO,	 88) | 
 |   RELOC_NUMBER (R_PPC_GOT_TPREL16_HI,	 89) | 
 |   RELOC_NUMBER (R_PPC_GOT_TPREL16_HA,	 90) | 
 |   RELOC_NUMBER (R_PPC_GOT_DTPREL16,	 91) | 
 |   RELOC_NUMBER (R_PPC_GOT_DTPREL16_LO,	 92) | 
 |   RELOC_NUMBER (R_PPC_GOT_DTPREL16_HI,	 93) | 
 |   RELOC_NUMBER (R_PPC_GOT_DTPREL16_HA,	 94) | 
 |   RELOC_NUMBER (R_PPC_TLSGD,		 95) | 
 |   RELOC_NUMBER (R_PPC_TLSLD,		 96) | 
 |  | 
 | /* The remaining relocs are from the Embedded ELF ABI, and are not | 
 |    in the SVR4 ELF ABI.  */ | 
 |   RELOC_NUMBER (R_PPC_EMB_NADDR32,	101) | 
 |   RELOC_NUMBER (R_PPC_EMB_NADDR16,	102) | 
 |   RELOC_NUMBER (R_PPC_EMB_NADDR16_LO,	103) | 
 |   RELOC_NUMBER (R_PPC_EMB_NADDR16_HI,	104) | 
 |   RELOC_NUMBER (R_PPC_EMB_NADDR16_HA,	105) | 
 |   RELOC_NUMBER (R_PPC_EMB_SDAI16,	106) | 
 |   RELOC_NUMBER (R_PPC_EMB_SDA2I16,	107) | 
 |   RELOC_NUMBER (R_PPC_EMB_SDA2REL,	108) | 
 |   RELOC_NUMBER (R_PPC_EMB_SDA21,	109) | 
 |   RELOC_NUMBER (R_PPC_EMB_MRKREF,	110) | 
 |   RELOC_NUMBER (R_PPC_EMB_RELSEC16,	111) | 
 |   RELOC_NUMBER (R_PPC_EMB_RELST_LO,	112) | 
 |   RELOC_NUMBER (R_PPC_EMB_RELST_HI,	113) | 
 |   RELOC_NUMBER (R_PPC_EMB_RELST_HA,	114) | 
 |   RELOC_NUMBER (R_PPC_EMB_BIT_FLD,	115) | 
 |   RELOC_NUMBER (R_PPC_EMB_RELSDA,	116) | 
 |  | 
 | /* Marker reloc for inline plt call insns.  */ | 
 |   RELOC_NUMBER (R_PPC_PLTSEQ,		119) | 
 |   RELOC_NUMBER (R_PPC_PLTCALL,		120) | 
 |  | 
 | /* PowerPC VLE relocations.  */ | 
 |   RELOC_NUMBER (R_PPC_VLE_REL8,		216) | 
 |   RELOC_NUMBER (R_PPC_VLE_REL15,	217) | 
 |   RELOC_NUMBER (R_PPC_VLE_REL24,	218) | 
 |   RELOC_NUMBER (R_PPC_VLE_LO16A,	219) | 
 |   RELOC_NUMBER (R_PPC_VLE_LO16D,	220) | 
 |   RELOC_NUMBER (R_PPC_VLE_HI16A,	221) | 
 |   RELOC_NUMBER (R_PPC_VLE_HI16D,	222) | 
 |   RELOC_NUMBER (R_PPC_VLE_HA16A,	223) | 
 |   RELOC_NUMBER (R_PPC_VLE_HA16D,	224) | 
 |   RELOC_NUMBER (R_PPC_VLE_SDA21,	225) | 
 |   RELOC_NUMBER (R_PPC_VLE_SDA21_LO,	226) | 
 |   RELOC_NUMBER (R_PPC_VLE_SDAREL_LO16A,	227) | 
 |   RELOC_NUMBER (R_PPC_VLE_SDAREL_LO16D,	228) | 
 |   RELOC_NUMBER (R_PPC_VLE_SDAREL_HI16A,	229) | 
 |   RELOC_NUMBER (R_PPC_VLE_SDAREL_HI16D,	230) | 
 |   RELOC_NUMBER (R_PPC_VLE_SDAREL_HA16A,	231) | 
 |   RELOC_NUMBER (R_PPC_VLE_SDAREL_HA16D,	232) | 
 |   RELOC_NUMBER (R_PPC_VLE_ADDR20,	233) | 
 |  | 
 | /* Power9 split rel16 for addpcis.  */ | 
 |   RELOC_NUMBER (R_PPC_REL16DX_HA,	246) | 
 |  | 
 | /* Support STT_GNU_IFUNC plt calls.  */ | 
 |   RELOC_NUMBER (R_PPC_IRELATIVE,	248) | 
 |  | 
 | /* These are GNU extensions used in PIC code sequences.  */ | 
 |   RELOC_NUMBER (R_PPC_REL16,		249) | 
 |   RELOC_NUMBER (R_PPC_REL16_LO,		250) | 
 |   RELOC_NUMBER (R_PPC_REL16_HI,		251) | 
 |   RELOC_NUMBER (R_PPC_REL16_HA,		252) | 
 |  | 
 | /* These are GNU extensions to enable C++ vtable garbage collection.  */ | 
 |   RELOC_NUMBER (R_PPC_GNU_VTINHERIT,	253) | 
 |   RELOC_NUMBER (R_PPC_GNU_VTENTRY,	254) | 
 |  | 
 | /* This is a phony reloc to handle any old fashioned TOC16 references | 
 |    that may still be in object files.  */ | 
 |   RELOC_NUMBER (R_PPC_TOC16,		255) | 
 |  | 
 | END_RELOC_NUMBERS (R_PPC_max) | 
 |  | 
 | #define IS_PPC_TLS_RELOC(R) \ | 
 |   ((R) >= R_PPC_TLS && (R) <= R_PPC_GOT_DTPREL16_HA) | 
 |  | 
 | /* Specify the value of _GLOBAL_OFFSET_TABLE_.  */ | 
 | #define DT_PPC_GOT		(DT_LOPROC) | 
 |  | 
 | /* Specify that tls descriptors should be optimized.  */ | 
 | #define DT_PPC_OPT		(DT_LOPROC + 1) | 
 | #define PPC_OPT_TLS		1 | 
 |  | 
 | /* Processor specific flags for the ELF header e_flags field.  */ | 
 |  | 
 | #define	EF_PPC_EMB		0x80000000	/* PowerPC embedded flag.  */ | 
 |  | 
 | #define	EF_PPC_RELOCATABLE	0x00010000	/* PowerPC -mrelocatable flag.  */ | 
 | #define	EF_PPC_RELOCATABLE_LIB	0x00008000	/* PowerPC -mrelocatable-lib flag.  */ | 
 |  | 
 | /* Processor specific program headers, p_flags field.  */ | 
 | #define PF_PPC_VLE		0x10000000	/* PowerPC VLE.  */ | 
 |  | 
 | /* Processor specific section headers, sh_flags field.  */ | 
 | #define SHF_PPC_VLE		0x10000000	/* PowerPC VLE text section.  */ | 
 |  | 
 | /* Processor specific section headers, sh_type field.  */ | 
 |  | 
 | #define SHT_ORDERED		SHT_HIPROC	/* Link editor is to sort the \ | 
 | 						   entries in this section \ | 
 | 						   based on the address \ | 
 | 						   specified in the associated \ | 
 | 						   symbol table entry.  */ | 
 |  | 
 | /* APUinfo note section.  */ | 
 | #define APUINFO_SECTION_NAME	".PPC.EMB.apuinfo" | 
 | #define APUINFO_LABEL		"APUinfo" | 
 |  | 
 | #define PPC_APUINFO_ISEL	0x40 | 
 | #define PPC_APUINFO_PMR		0x41 | 
 | #define PPC_APUINFO_RFMCI	0x42 | 
 | #define PPC_APUINFO_CACHELCK	0x43 | 
 | #define PPC_APUINFO_SPE		0x100 | 
 | #define PPC_APUINFO_EFS		0x101 | 
 | #define PPC_APUINFO_BRLOCK	0x102 | 
 | #define PPC_APUINFO_VLE		0x104 | 
 |  | 
 | /* Object attribute tags.  */ | 
 | enum | 
 | { | 
 |   /* 0-3 are generic.  */ | 
 |  | 
 |   /* FP ABI, low 2 bits: | 
 |      1 for double precision hard-float, | 
 |      2 for soft-float, | 
 |      3 for single precision hard-float. | 
 |      0 for not tagged or not using any ABIs affected by the differences. | 
 |      Next 2 bits: | 
 |      1 for ibm long double | 
 |      2 for 64-bit long double | 
 |      3 for IEEE long double. | 
 |      0 for not tagged or not using any ABIs affected by the differences.  */ | 
 |   Tag_GNU_Power_ABI_FP = 4, | 
 |  | 
 |   /* Value 1 for general purpose registers only, 2 for AltiVec | 
 |      registers, 3 for SPE registers; 0 for not tagged or not using any | 
 |      ABIs affected by the differences.  */ | 
 |   Tag_GNU_Power_ABI_Vector = 8, | 
 |  | 
 |   /* Value 1 for ABIs using r3/r4 for returning structures <= 8 bytes, | 
 |      2 for ABIs using memory; 0 for not tagged or not using any ABIs | 
 |      affected by the differences.  */ | 
 |   Tag_GNU_Power_ABI_Struct_Return = 12 | 
 | }; | 
 |  | 
 | #endif /* _ELF_PPC_H */ |