xref: /openbmc/u-boot/include/elf.h (revision 2846ea81a0295b47dda75111cfef099d5eed85e2)
183d290c5STom Rini /* SPDX-License-Identifier: BSD-3-Clause */
2a2cecab6Swdenk /*
3a2cecab6Swdenk  * Copyright (c) 1995, 1996, 2001, 2002
4a2cecab6Swdenk  * Erik Theisen.  All rights reserved.
5a2cecab6Swdenk  */
6a2cecab6Swdenk 
7df635df2SBin Meng /* This is the ELF ABI header file formerly known as "elf_abi.h" */
8a2cecab6Swdenk 
9a2cecab6Swdenk #ifndef _ELF_H
10a2cecab6Swdenk #define _ELF_H
11a2cecab6Swdenk 
12c70f74a0SSimon Glass #ifndef __ASSEMBLER__
1337566090SMike Frysinger #include "compiler.h"
14a2cecab6Swdenk 
15df635df2SBin Meng /* This version doesn't work for 64-bit ABIs - Erik */
16a2cecab6Swdenk 
17df635df2SBin Meng /* These typedefs need to be handled better */
18a2cecab6Swdenk typedef uint32_t	Elf32_Addr;	/* Unsigned program address */
19a2cecab6Swdenk typedef uint32_t	Elf32_Off;	/* Unsigned file offset */
20a2cecab6Swdenk typedef int32_t		Elf32_Sword;	/* Signed large integer */
21a2cecab6Swdenk typedef uint32_t	Elf32_Word;	/* Unsigned large integer */
22a2cecab6Swdenk typedef uint16_t	Elf32_Half;	/* Unsigned medium integer */
23a2cecab6Swdenk 
24df635df2SBin Meng /* 64-bit ELF base types */
255efa2813SSimon Glass typedef uint64_t	Elf64_Addr;
265efa2813SSimon Glass typedef uint16_t	Elf64_Half;
275efa2813SSimon Glass typedef int16_t		Elf64_SHalf;
285efa2813SSimon Glass typedef uint64_t	Elf64_Off;
295efa2813SSimon Glass typedef int32_t		Elf64_Sword;
305efa2813SSimon Glass typedef uint32_t	Elf64_Word;
315efa2813SSimon Glass typedef uint64_t	Elf64_Xword;
325efa2813SSimon Glass typedef int64_t		Elf64_Sxword;
335efa2813SSimon Glass 
34a2cecab6Swdenk /* e_ident[] identification indexes */
35a2cecab6Swdenk #define EI_MAG0		0		/* file ID */
36a2cecab6Swdenk #define EI_MAG1		1		/* file ID */
37a2cecab6Swdenk #define EI_MAG2		2		/* file ID */
38a2cecab6Swdenk #define EI_MAG3		3		/* file ID */
39a2cecab6Swdenk #define EI_CLASS	4		/* file class */
40a2cecab6Swdenk #define EI_DATA		5		/* data encoding */
41a2cecab6Swdenk #define EI_VERSION	6		/* ELF header version */
42a2cecab6Swdenk #define EI_OSABI	7		/* OS/ABI specific ELF extensions */
43a2cecab6Swdenk #define EI_ABIVERSION	8		/* ABI target version */
44a2cecab6Swdenk #define EI_PAD		9		/* start of pad bytes */
45a2cecab6Swdenk #define EI_NIDENT	16		/* Size of e_ident[] */
46a2cecab6Swdenk 
47a2cecab6Swdenk /* e_ident[] magic number */
48a2cecab6Swdenk #define	ELFMAG0		0x7f		/* e_ident[EI_MAG0] */
49a2cecab6Swdenk #define	ELFMAG1		'E'		/* e_ident[EI_MAG1] */
50a2cecab6Swdenk #define	ELFMAG2		'L'		/* e_ident[EI_MAG2] */
51a2cecab6Swdenk #define	ELFMAG3		'F'		/* e_ident[EI_MAG3] */
52a2cecab6Swdenk #define	ELFMAG		"\177ELF"	/* magic */
53a2cecab6Swdenk #define	SELFMAG		4		/* size of magic */
54a2cecab6Swdenk 
55a2cecab6Swdenk /* e_ident[] file class */
56a2cecab6Swdenk #define	ELFCLASSNONE	0		/* invalid */
57a2cecab6Swdenk #define	ELFCLASS32	1		/* 32-bit objs */
58a2cecab6Swdenk #define	ELFCLASS64	2		/* 64-bit objs */
59a2cecab6Swdenk #define	ELFCLASSNUM	3		/* number of classes */
60a2cecab6Swdenk 
61a2cecab6Swdenk /* e_ident[] data encoding */
62a2cecab6Swdenk #define ELFDATANONE	0		/* invalid */
63a2cecab6Swdenk #define ELFDATA2LSB	1		/* Little-Endian */
64a2cecab6Swdenk #define ELFDATA2MSB	2		/* Big-Endian */
65a2cecab6Swdenk #define ELFDATANUM	3		/* number of data encode defines */
66a2cecab6Swdenk 
67a2cecab6Swdenk /* e_ident[] OS/ABI specific ELF extensions */
68a2cecab6Swdenk #define ELFOSABI_NONE		0	/* No extension specified */
69a2cecab6Swdenk #define ELFOSABI_HPUX		1	/* Hewlett-Packard HP-UX */
70a2cecab6Swdenk #define ELFOSABI_NETBSD		2	/* NetBSD */
71a2cecab6Swdenk #define ELFOSABI_LINUX		3	/* Linux */
72a2cecab6Swdenk #define ELFOSABI_SOLARIS	6	/* Sun Solaris */
73a2cecab6Swdenk #define ELFOSABI_AIX		7	/* AIX */
74a2cecab6Swdenk #define ELFOSABI_IRIX		8	/* IRIX */
75a2cecab6Swdenk #define ELFOSABI_FREEBSD	9	/* FreeBSD */
76a2cecab6Swdenk #define ELFOSABI_TRU64		10	/* Compaq TRU64 UNIX */
77a2cecab6Swdenk #define ELFOSABI_MODESTO	11	/* Novell Modesto */
78a2cecab6Swdenk #define ELFOSABI_OPENBSD	12	/* OpenBSD */
79a2cecab6Swdenk /* 64-255 Architecture-specific value range */
80a2cecab6Swdenk 
81a2cecab6Swdenk /* e_ident[] ABI Version */
82a2cecab6Swdenk #define ELFABIVERSION		0
83a2cecab6Swdenk 
84a2cecab6Swdenk /* e_ident */
85a2cecab6Swdenk #define IS_ELF(ehdr) ((ehdr).e_ident[EI_MAG0] == ELFMAG0 && \
86a2cecab6Swdenk 		      (ehdr).e_ident[EI_MAG1] == ELFMAG1 && \
87a2cecab6Swdenk 		      (ehdr).e_ident[EI_MAG2] == ELFMAG2 && \
88a2cecab6Swdenk 		      (ehdr).e_ident[EI_MAG3] == ELFMAG3)
89a2cecab6Swdenk 
90a2cecab6Swdenk /* ELF Header */
91df635df2SBin Meng typedef struct {
92a2cecab6Swdenk 	unsigned char	e_ident[EI_NIDENT]; /* ELF Identification */
93a2cecab6Swdenk 	Elf32_Half	e_type;		/* object file type */
94a2cecab6Swdenk 	Elf32_Half	e_machine;	/* machine */
95a2cecab6Swdenk 	Elf32_Word	e_version;	/* object file version */
96a2cecab6Swdenk 	Elf32_Addr	e_entry;	/* virtual entry point */
97a2cecab6Swdenk 	Elf32_Off	e_phoff;	/* program header table offset */
98a2cecab6Swdenk 	Elf32_Off	e_shoff;	/* section header table offset */
99a2cecab6Swdenk 	Elf32_Word	e_flags;	/* processor-specific flags */
100a2cecab6Swdenk 	Elf32_Half	e_ehsize;	/* ELF header size */
101a2cecab6Swdenk 	Elf32_Half	e_phentsize;	/* program header entry size */
102a2cecab6Swdenk 	Elf32_Half	e_phnum;	/* number of program header entries */
103a2cecab6Swdenk 	Elf32_Half	e_shentsize;	/* section header entry size */
104a2cecab6Swdenk 	Elf32_Half	e_shnum;	/* number of section header entries */
105a2cecab6Swdenk 	Elf32_Half	e_shstrndx;	/* section header table's "section
106a2cecab6Swdenk 					   header string table" entry offset */
107a2cecab6Swdenk } Elf32_Ehdr;
108a2cecab6Swdenk 
1092bce3f59SBin Meng typedef struct {
1102bce3f59SBin Meng 	unsigned char	e_ident[EI_NIDENT]; /* ELF Identification */
1112bce3f59SBin Meng 	Elf64_Half	e_type;		/* object file type */
1122bce3f59SBin Meng 	Elf64_Half	e_machine;	/* machine */
1132bce3f59SBin Meng 	Elf64_Word	e_version;	/* object file version */
1142bce3f59SBin Meng 	Elf64_Addr	e_entry;	/* virtual entry point */
1152bce3f59SBin Meng 	Elf64_Off	e_phoff;	/* program header table offset */
1162bce3f59SBin Meng 	Elf64_Off	e_shoff;	/* section header table offset */
1172bce3f59SBin Meng 	Elf64_Word	e_flags;	/* processor-specific flags */
1182bce3f59SBin Meng 	Elf64_Half	e_ehsize;	/* ELF header size */
1192bce3f59SBin Meng 	Elf64_Half	e_phentsize;	/* program header entry size */
1202bce3f59SBin Meng 	Elf64_Half	e_phnum;	/* number of program header entries */
1212bce3f59SBin Meng 	Elf64_Half	e_shentsize;	/* section header entry size */
1222bce3f59SBin Meng 	Elf64_Half	e_shnum;	/* number of section header entries */
1232bce3f59SBin Meng 	Elf64_Half	e_shstrndx;	/* section header table's "section
1242bce3f59SBin Meng 					   header string table" entry offset */
1252bce3f59SBin Meng } Elf64_Ehdr;
1262bce3f59SBin Meng 
127a2cecab6Swdenk /* e_type */
128a2cecab6Swdenk #define ET_NONE		0		/* No file type */
129a2cecab6Swdenk #define ET_REL		1		/* relocatable file */
130a2cecab6Swdenk #define ET_EXEC		2		/* executable file */
131a2cecab6Swdenk #define ET_DYN		3		/* shared object file */
132a2cecab6Swdenk #define ET_CORE		4		/* core file */
133a2cecab6Swdenk #define ET_NUM		5		/* number of types */
134a2cecab6Swdenk #define ET_LOOS		0xfe00		/* reserved range for operating */
135a2cecab6Swdenk #define ET_HIOS		0xfeff		/* system specific e_type */
136a2cecab6Swdenk #define ET_LOPROC	0xff00		/* reserved range for processor */
137a2cecab6Swdenk #define ET_HIPROC	0xffff		/* specific e_type */
138a2cecab6Swdenk 
139a2cecab6Swdenk /* e_machine */
140a2cecab6Swdenk #define EM_NONE		0		/* No Machine */
141a2cecab6Swdenk #define EM_M32		1		/* AT&T WE 32100 */
142a2cecab6Swdenk #define EM_SPARC	2		/* SPARC */
143a2cecab6Swdenk #define EM_386		3		/* Intel 80386 */
144a2cecab6Swdenk #define EM_68K		4		/* Motorola 68000 */
145a2cecab6Swdenk #define EM_88K		5		/* Motorola 88000 */
146a2cecab6Swdenk #if 0
147a2cecab6Swdenk #define EM_486		6		/* RESERVED - was Intel 80486 */
148a2cecab6Swdenk #endif
149a2cecab6Swdenk #define EM_860		7		/* Intel 80860 */
150a2cecab6Swdenk #define EM_MIPS		8		/* MIPS R3000 Big-Endian only */
151a2cecab6Swdenk #define EM_S370		9		/* IBM System/370 Processor */
152a2cecab6Swdenk #define EM_MIPS_RS4_BE	10		/* MIPS R4000 Big-Endian */
153a2cecab6Swdenk #if 0
154a2cecab6Swdenk #define EM_SPARC64	11		/* RESERVED - was SPARC v9
155a2cecab6Swdenk 					     64-bit unoffical */
156a2cecab6Swdenk #endif
157a2cecab6Swdenk /* RESERVED 11-14 for future use */
158a2cecab6Swdenk #define EM_PARISC	15		/* HPPA */
159a2cecab6Swdenk /* RESERVED 16 for future use */
160a2cecab6Swdenk #define EM_VPP500	17		/* Fujitsu VPP500 */
161a2cecab6Swdenk #define EM_SPARC32PLUS	18		/* Enhanced instruction set SPARC */
162a2cecab6Swdenk #define EM_960		19		/* Intel 80960 */
163a2cecab6Swdenk #define EM_PPC		20		/* PowerPC */
164a2cecab6Swdenk #define EM_PPC64	21		/* 64-bit PowerPC */
165a2cecab6Swdenk #define EM_S390		22		/* IBM System/390 Processor */
166a2cecab6Swdenk /* RESERVED 23-35 for future use */
167a2cecab6Swdenk #define EM_V800		36		/* NEC V800 */
168a2cecab6Swdenk #define EM_FR20		37		/* Fujitsu FR20 */
169a2cecab6Swdenk #define EM_RH32		38		/* TRW RH-32 */
170a2cecab6Swdenk #define EM_RCE		39		/* Motorola RCE */
171a2cecab6Swdenk #define EM_ARM		40		/* Advanced Risc Machines ARM */
172a2cecab6Swdenk #define EM_ALPHA	41		/* Digital Alpha */
173a2cecab6Swdenk #define EM_SH		42		/* Hitachi SH */
174a2cecab6Swdenk #define EM_SPARCV9	43		/* SPARC Version 9 */
175a2cecab6Swdenk #define EM_TRICORE	44		/* Siemens TriCore embedded processor */
176a2cecab6Swdenk #define EM_ARC		45		/* Argonaut RISC Core */
177a2cecab6Swdenk #define EM_H8_300	46		/* Hitachi H8/300 */
178a2cecab6Swdenk #define EM_H8_300H	47		/* Hitachi H8/300H */
179a2cecab6Swdenk #define EM_H8S		48		/* Hitachi H8S */
180a2cecab6Swdenk #define EM_H8_500	49		/* Hitachi H8/500 */
181a2cecab6Swdenk #define EM_IA_64	50		/* Intel Merced */
182a2cecab6Swdenk #define EM_MIPS_X	51		/* Stanford MIPS-X */
183a2cecab6Swdenk #define EM_COLDFIRE	52		/* Motorola Coldfire */
184a2cecab6Swdenk #define EM_68HC12	53		/* Motorola M68HC12 */
185a2cecab6Swdenk #define EM_MMA		54		/* Fujitsu MMA Multimedia Accelerator*/
186a2cecab6Swdenk #define EM_PCP		55		/* Siemens PCP */
187a2cecab6Swdenk #define EM_NCPU		56		/* Sony nCPU embeeded RISC */
188a2cecab6Swdenk #define EM_NDR1		57		/* Denso NDR1 microprocessor */
189a2cecab6Swdenk #define EM_STARCORE	58		/* Motorola Start*Core processor */
190a2cecab6Swdenk #define EM_ME16		59		/* Toyota ME16 processor */
191a2cecab6Swdenk #define EM_ST100	60		/* STMicroelectronic ST100 processor */
192a2cecab6Swdenk #define EM_TINYJ	61		/* Advanced Logic Corp. Tinyj emb.fam*/
193a2cecab6Swdenk #define EM_X86_64	62		/* AMD x86-64 */
194a2cecab6Swdenk #define EM_PDSP		63		/* Sony DSP Processor */
195a2cecab6Swdenk /* RESERVED 64,65 for future use */
196a2cecab6Swdenk #define EM_FX66		66		/* Siemens FX66 microcontroller */
197a2cecab6Swdenk #define EM_ST9PLUS	67		/* STMicroelectronics ST9+ 8/16 mc */
198a2cecab6Swdenk #define EM_ST7		68		/* STmicroelectronics ST7 8 bit mc */
199a2cecab6Swdenk #define EM_68HC16	69		/* Motorola MC68HC16 microcontroller */
200a2cecab6Swdenk #define EM_68HC11	70		/* Motorola MC68HC11 microcontroller */
201a2cecab6Swdenk #define EM_68HC08	71		/* Motorola MC68HC08 microcontroller */
202a2cecab6Swdenk #define EM_68HC05	72		/* Motorola MC68HC05 microcontroller */
203a2cecab6Swdenk #define EM_SVX		73		/* Silicon Graphics SVx */
204a2cecab6Swdenk #define EM_ST19		74		/* STMicroelectronics ST19 8 bit mc */
205a2cecab6Swdenk #define EM_VAX		75		/* Digital VAX */
206a2cecab6Swdenk #define EM_CHRIS	76		/* Axis Communications embedded proc. */
207a2cecab6Swdenk #define EM_JAVELIN	77		/* Infineon Technologies emb. proc. */
208a2cecab6Swdenk #define EM_FIREPATH	78		/* Element 14 64-bit DSP Processor */
209a2cecab6Swdenk #define EM_ZSP		79		/* LSI Logic 16-bit DSP Processor */
210a2cecab6Swdenk #define EM_MMIX		80		/* Donald Knuth's edu 64-bit proc. */
211a2cecab6Swdenk #define EM_HUANY	81		/* Harvard University mach-indep objs */
212a2cecab6Swdenk #define EM_PRISM	82		/* SiTera Prism */
213a2cecab6Swdenk #define EM_AVR		83		/* Atmel AVR 8-bit microcontroller */
214a2cecab6Swdenk #define EM_FR30		84		/* Fujitsu FR30 */
215a2cecab6Swdenk #define EM_D10V		85		/* Mitsubishi DV10V */
216a2cecab6Swdenk #define EM_D30V		86		/* Mitsubishi DV30V */
217a2cecab6Swdenk #define EM_V850		87		/* NEC v850 */
218a2cecab6Swdenk #define EM_M32R		88		/* Mitsubishi M32R */
219a2cecab6Swdenk #define EM_MN10300	89		/* Matsushita MN10200 */
220a2cecab6Swdenk #define EM_MN10200	90		/* Matsushita MN10200 */
221a2cecab6Swdenk #define EM_PJ		91		/* picoJava */
222a2cecab6Swdenk #define EM_NUM		92		/* number of machine types */
223a2cecab6Swdenk 
224a2cecab6Swdenk /* Version */
225a2cecab6Swdenk #define EV_NONE		0		/* Invalid */
226a2cecab6Swdenk #define EV_CURRENT	1		/* Current */
227a2cecab6Swdenk #define EV_NUM		2		/* number of versions */
228a2cecab6Swdenk 
229a2cecab6Swdenk /* Section Header */
230a2cecab6Swdenk typedef struct {
231a2cecab6Swdenk 	Elf32_Word	sh_name;	/* name - index into section header
232a2cecab6Swdenk 					   string table section */
233a2cecab6Swdenk 	Elf32_Word	sh_type;	/* type */
234a2cecab6Swdenk 	Elf32_Word	sh_flags;	/* flags */
235a2cecab6Swdenk 	Elf32_Addr	sh_addr;	/* address */
236a2cecab6Swdenk 	Elf32_Off	sh_offset;	/* file offset */
237a2cecab6Swdenk 	Elf32_Word	sh_size;	/* section size */
238a2cecab6Swdenk 	Elf32_Word	sh_link;	/* section header table index link */
239a2cecab6Swdenk 	Elf32_Word	sh_info;	/* extra information */
240a2cecab6Swdenk 	Elf32_Word	sh_addralign;	/* address alignment */
241a2cecab6Swdenk 	Elf32_Word	sh_entsize;	/* section entry size */
242a2cecab6Swdenk } Elf32_Shdr;
243a2cecab6Swdenk 
2442bce3f59SBin Meng typedef struct {
2452bce3f59SBin Meng 	Elf64_Word	sh_name;	/* name - index into section header
2462bce3f59SBin Meng 					   string table section */
2472bce3f59SBin Meng 	Elf64_Word	sh_type;	/* type */
2482bce3f59SBin Meng 	Elf64_Xword	sh_flags;	/* flags */
2492bce3f59SBin Meng 	Elf64_Addr	sh_addr;	/* address */
2502bce3f59SBin Meng 	Elf64_Off	sh_offset;	/* file offset */
2512bce3f59SBin Meng 	Elf64_Xword	sh_size;	/* section size */
2522bce3f59SBin Meng 	Elf64_Word	sh_link;	/* section header table index link */
2532bce3f59SBin Meng 	Elf64_Word	sh_info;	/* extra information */
2542bce3f59SBin Meng 	Elf64_Xword	sh_addralign;	/* address alignment */
2552bce3f59SBin Meng 	Elf64_Xword	sh_entsize;	/* section entry size */
2562bce3f59SBin Meng } Elf64_Shdr;
2572bce3f59SBin Meng 
258a2cecab6Swdenk /* Special Section Indexes */
259a2cecab6Swdenk #define SHN_UNDEF	0		/* undefined */
260a2cecab6Swdenk #define SHN_LORESERVE	0xff00		/* lower bounds of reserved indexes */
261a2cecab6Swdenk #define SHN_LOPROC	0xff00		/* reserved range for processor */
262a2cecab6Swdenk #define SHN_HIPROC	0xff1f		/* specific section indexes */
263a2cecab6Swdenk #define SHN_LOOS	0xff20		/* reserved range for operating */
264a2cecab6Swdenk #define SHN_HIOS	0xff3f		/* specific semantics */
265a2cecab6Swdenk #define SHN_ABS		0xfff1		/* absolute value */
266a2cecab6Swdenk #define SHN_COMMON	0xfff2		/* common symbol */
267a2cecab6Swdenk #define SHN_XINDEX	0xffff		/* Index is an extra table */
268a2cecab6Swdenk #define SHN_HIRESERVE	0xffff		/* upper bounds of reserved indexes */
269a2cecab6Swdenk 
270a2cecab6Swdenk /* sh_type */
271a2cecab6Swdenk #define SHT_NULL	0		/* inactive */
272a2cecab6Swdenk #define SHT_PROGBITS	1		/* program defined information */
273a2cecab6Swdenk #define SHT_SYMTAB	2		/* symbol table section */
274a2cecab6Swdenk #define SHT_STRTAB	3		/* string table section */
275a2cecab6Swdenk #define SHT_RELA	4		/* relocation section with addends*/
276a2cecab6Swdenk #define SHT_HASH	5		/* symbol hash table section */
277a2cecab6Swdenk #define SHT_DYNAMIC	6		/* dynamic section */
278a2cecab6Swdenk #define SHT_NOTE	7		/* note section */
279a2cecab6Swdenk #define SHT_NOBITS	8		/* no space section */
280a2cecab6Swdenk #define SHT_REL		9		/* relation section without addends */
281a2cecab6Swdenk #define SHT_SHLIB	10		/* reserved - purpose unknown */
282a2cecab6Swdenk #define SHT_DYNSYM	11		/* dynamic symbol table section */
283a2cecab6Swdenk #define SHT_INIT_ARRAY	14		/* Array of constructors */
284a2cecab6Swdenk #define SHT_FINI_ARRAY	15		/* Array of destructors */
285a2cecab6Swdenk #define SHT_PREINIT_ARRAY 16		/* Array of pre-constructors */
286a2cecab6Swdenk #define SHT_GROUP	17		/* Section group */
287a2cecab6Swdenk #define SHT_SYMTAB_SHNDX 18		/* Extended section indeces */
288a2cecab6Swdenk #define SHT_NUM		19		/* number of section types */
289a2cecab6Swdenk #define SHT_LOOS	0x60000000	/* Start OS-specific */
290a2cecab6Swdenk #define SHT_HIOS	0x6fffffff	/* End OS-specific */
291a2cecab6Swdenk #define SHT_LOPROC	0x70000000	/* reserved range for processor */
292a2cecab6Swdenk #define SHT_HIPROC	0x7fffffff	/* specific section header types */
293a2cecab6Swdenk #define SHT_LOUSER	0x80000000	/* reserved range for application */
294a2cecab6Swdenk #define SHT_HIUSER	0xffffffff	/* specific indexes */
295a2cecab6Swdenk 
296a2cecab6Swdenk /* Section names */
297a2cecab6Swdenk #define ELF_BSS		".bss"		/* uninitialized data */
298a2cecab6Swdenk #define ELF_COMMENT	".comment"	/* version control information */
299a2cecab6Swdenk #define ELF_DATA	".data"		/* initialized data */
300a2cecab6Swdenk #define ELF_DATA1	".data1"	/* initialized data */
301a2cecab6Swdenk #define ELF_DEBUG	".debug"	/* debug */
302a2cecab6Swdenk #define ELF_DYNAMIC	".dynamic"	/* dynamic linking information */
303a2cecab6Swdenk #define ELF_DYNSTR	".dynstr"	/* dynamic string table */
304a2cecab6Swdenk #define ELF_DYNSYM	".dynsym"	/* dynamic symbol table */
305a2cecab6Swdenk #define ELF_FINI	".fini"		/* termination code */
306a2cecab6Swdenk #define ELF_FINI_ARRAY	".fini_array"	/* Array of destructors */
307a2cecab6Swdenk #define ELF_GOT		".got"		/* global offset table */
308a2cecab6Swdenk #define ELF_HASH	".hash"		/* symbol hash table */
309a2cecab6Swdenk #define ELF_INIT	".init"		/* initialization code */
310a2cecab6Swdenk #define ELF_INIT_ARRAY	".init_array"	/* Array of constuctors */
311a2cecab6Swdenk #define ELF_INTERP	".interp"	/* Pathname of program interpreter */
312a2cecab6Swdenk #define ELF_LINE	".line"		/* Symbolic line numnber information */
313a2cecab6Swdenk #define ELF_NOTE	".note"		/* Contains note section */
314a2cecab6Swdenk #define ELF_PLT		".plt"		/* Procedure linkage table */
315a2cecab6Swdenk #define ELF_PREINIT_ARRAY ".preinit_array" /* Array of pre-constructors */
316a2cecab6Swdenk #define ELF_REL_DATA	".rel.data"	/* relocation data */
317a2cecab6Swdenk #define ELF_REL_FINI	".rel.fini"	/* relocation termination code */
318a2cecab6Swdenk #define ELF_REL_INIT	".rel.init"	/* relocation initialization code */
319a2cecab6Swdenk #define ELF_REL_DYN	".rel.dyn"	/* relocaltion dynamic link info */
320a2cecab6Swdenk #define ELF_REL_RODATA	".rel.rodata"	/* relocation read-only data */
321a2cecab6Swdenk #define ELF_REL_TEXT	".rel.text"	/* relocation code */
322a2cecab6Swdenk #define ELF_RODATA	".rodata"	/* read-only data */
323a2cecab6Swdenk #define ELF_RODATA1	".rodata1"	/* read-only data */
324a2cecab6Swdenk #define ELF_SHSTRTAB	".shstrtab"	/* section header string table */
325a2cecab6Swdenk #define ELF_STRTAB	".strtab"	/* string table */
326a2cecab6Swdenk #define ELF_SYMTAB	".symtab"	/* symbol table */
327a2cecab6Swdenk #define ELF_SYMTAB_SHNDX ".symtab_shndx"/* symbol table section index */
328a2cecab6Swdenk #define ELF_TBSS	".tbss"		/* thread local uninit data */
329a2cecab6Swdenk #define ELF_TDATA	".tdata"	/* thread local init data */
330a2cecab6Swdenk #define ELF_TDATA1	".tdata1"	/* thread local init data */
331a2cecab6Swdenk #define ELF_TEXT	".text"		/* code */
332a2cecab6Swdenk 
333a2cecab6Swdenk /* Section Attribute Flags - sh_flags */
334a2cecab6Swdenk #define SHF_WRITE	0x1		/* Writable */
335a2cecab6Swdenk #define SHF_ALLOC	0x2		/* occupies memory */
336a2cecab6Swdenk #define SHF_EXECINSTR	0x4		/* executable */
337a2cecab6Swdenk #define SHF_MERGE	0x10		/* Might be merged */
338a2cecab6Swdenk #define SHF_STRINGS	0x20		/* Contains NULL terminated strings */
339a2cecab6Swdenk #define SHF_INFO_LINK	0x40		/* sh_info contains SHT index */
340a2cecab6Swdenk #define SHF_LINK_ORDER	0x80		/* Preserve order after combining*/
341a2cecab6Swdenk #define SHF_OS_NONCONFORMING 0x100	/* Non-standard OS specific handling */
342a2cecab6Swdenk #define SHF_GROUP	0x200		/* Member of section group */
343a2cecab6Swdenk #define SHF_TLS		0x400		/* Thread local storage */
344a2cecab6Swdenk #define SHF_MASKOS	0x0ff00000	/* OS specific */
345a2cecab6Swdenk #define SHF_MASKPROC	0xf0000000	/* reserved bits for processor */
346a2cecab6Swdenk 					/* specific section attributes */
347a2cecab6Swdenk 
348a2cecab6Swdenk /* Section Group Flags */
349a2cecab6Swdenk #define GRP_COMDAT	0x1		/* COMDAT group */
350a2cecab6Swdenk #define GRP_MASKOS	0x0ff00000	/* Mask OS specific flags */
351a2cecab6Swdenk #define GRP_MASKPROC	0xf0000000	/* Mask processor specific flags */
352a2cecab6Swdenk 
353a2cecab6Swdenk /* Symbol Table Entry */
354df635df2SBin Meng typedef struct {
355a2cecab6Swdenk 	Elf32_Word	st_name;	/* name - index into string table */
356a2cecab6Swdenk 	Elf32_Addr	st_value;	/* symbol value */
357a2cecab6Swdenk 	Elf32_Word	st_size;	/* symbol size */
358a2cecab6Swdenk 	unsigned char	st_info;	/* type and binding */
359a2cecab6Swdenk 	unsigned char	st_other;	/* 0 - no defined meaning */
360a2cecab6Swdenk 	Elf32_Half	st_shndx;	/* section header index */
361a2cecab6Swdenk } Elf32_Sym;
362a2cecab6Swdenk 
363a2cecab6Swdenk /* Symbol table index */
364a2cecab6Swdenk #define STN_UNDEF	0		/* undefined */
365a2cecab6Swdenk 
366a2cecab6Swdenk /* Extract symbol info - st_info */
367a2cecab6Swdenk #define ELF32_ST_BIND(x)	((x) >> 4)
368a2cecab6Swdenk #define ELF32_ST_TYPE(x)	(((unsigned int) x) & 0xf)
369a2cecab6Swdenk #define ELF32_ST_INFO(b,t)	(((b) << 4) + ((t) & 0xf))
370a2cecab6Swdenk #define ELF32_ST_VISIBILITY(x)	((x) & 0x3)
371a2cecab6Swdenk 
372a2cecab6Swdenk /* Symbol Binding - ELF32_ST_BIND - st_info */
373a2cecab6Swdenk #define STB_LOCAL	0		/* Local symbol */
374a2cecab6Swdenk #define STB_GLOBAL	1		/* Global symbol */
375a2cecab6Swdenk #define STB_WEAK	2		/* like global - lower precedence */
376a2cecab6Swdenk #define STB_NUM		3		/* number of symbol bindings */
377a2cecab6Swdenk #define STB_LOOS	10		/* reserved range for operating */
378a2cecab6Swdenk #define STB_HIOS	12		/* system specific symbol bindings */
379a2cecab6Swdenk #define STB_LOPROC	13		/* reserved range for processor */
380a2cecab6Swdenk #define STB_HIPROC	15		/* specific symbol bindings */
381a2cecab6Swdenk 
382a2cecab6Swdenk /* Symbol type - ELF32_ST_TYPE - st_info */
383a2cecab6Swdenk #define STT_NOTYPE	0		/* not specified */
384a2cecab6Swdenk #define STT_OBJECT	1		/* data object */
385a2cecab6Swdenk #define STT_FUNC	2		/* function */
386a2cecab6Swdenk #define STT_SECTION	3		/* section */
387a2cecab6Swdenk #define STT_FILE	4		/* file */
388a2cecab6Swdenk #define STT_NUM		5		/* number of symbol types */
389a2cecab6Swdenk #define STT_TLS		6		/* Thread local storage symbol */
390a2cecab6Swdenk #define STT_LOOS	10		/* reserved range for operating */
391a2cecab6Swdenk #define STT_HIOS	12		/* system specific symbol types */
392a2cecab6Swdenk #define STT_LOPROC	13		/* reserved range for processor */
393a2cecab6Swdenk #define STT_HIPROC	15		/* specific symbol types */
394a2cecab6Swdenk 
395a2cecab6Swdenk /* Symbol visibility - ELF32_ST_VISIBILITY - st_other */
396a2cecab6Swdenk #define STV_DEFAULT	0		/* Normal visibility rules */
397a2cecab6Swdenk #define STV_INTERNAL	1		/* Processor specific hidden class */
398a2cecab6Swdenk #define STV_HIDDEN	2		/* Symbol unavailable in other mods */
399a2cecab6Swdenk #define STV_PROTECTED	3		/* Not preemptible, not exported */
400a2cecab6Swdenk 
401a2cecab6Swdenk /* Relocation entry with implicit addend */
402df635df2SBin Meng typedef struct {
403a2cecab6Swdenk 	Elf32_Addr	r_offset;	/* offset of relocation */
404a2cecab6Swdenk 	Elf32_Word	r_info;		/* symbol table index and type */
405a2cecab6Swdenk } Elf32_Rel;
406a2cecab6Swdenk 
407a2cecab6Swdenk /* Relocation entry with explicit addend */
408df635df2SBin Meng typedef struct {
409a2cecab6Swdenk 	Elf32_Addr	r_offset;	/* offset of relocation */
410a2cecab6Swdenk 	Elf32_Word	r_info;		/* symbol table index and type */
411a2cecab6Swdenk 	Elf32_Sword	r_addend;
412a2cecab6Swdenk } Elf32_Rela;
413a2cecab6Swdenk 
4145efa2813SSimon Glass typedef struct {
4155efa2813SSimon Glass 	Elf64_Addr r_offset;	/* Location at which to apply the action */
4165efa2813SSimon Glass 	Elf64_Xword r_info;	/* index and type of relocation */
4175efa2813SSimon Glass } Elf64_Rel;
4185efa2813SSimon Glass 
4192547f3edSSimon Glass typedef struct {
4202547f3edSSimon Glass 	Elf64_Addr r_offset;	/* Location at which to apply the action */
4212547f3edSSimon Glass 	Elf64_Xword r_info;	/* index and type of relocation */
4222547f3edSSimon Glass 	Elf64_Sxword r_addend;	/* Constant addend used to compute value */
4232547f3edSSimon Glass } Elf64_Rela;
4242547f3edSSimon Glass 
425a2cecab6Swdenk /* Extract relocation info - r_info */
426a2cecab6Swdenk #define ELF32_R_SYM(i)		((i) >> 8)
427a2cecab6Swdenk #define ELF32_R_TYPE(i)		((unsigned char) (i))
428a2cecab6Swdenk #define ELF32_R_INFO(s,t)	(((s) << 8) + (unsigned char)(t))
429a2cecab6Swdenk 
430a2cecab6Swdenk /* Program Header */
431a2cecab6Swdenk typedef struct {
432a2cecab6Swdenk 	Elf32_Word	p_type;		/* segment type */
433a2cecab6Swdenk 	Elf32_Off	p_offset;	/* segment offset */
434a2cecab6Swdenk 	Elf32_Addr	p_vaddr;	/* virtual address of segment */
435df635df2SBin Meng 	Elf32_Addr	p_paddr;	/* physical address of segment */
436df635df2SBin Meng 	Elf32_Word	p_filesz;	/* number of bytes in file for seg */
437df635df2SBin Meng 	Elf32_Word	p_memsz;	/* number of bytes in mem. for seg */
438a2cecab6Swdenk 	Elf32_Word	p_flags;	/* flags */
439a2cecab6Swdenk 	Elf32_Word	p_align;	/* memory alignment */
440a2cecab6Swdenk } Elf32_Phdr;
441a2cecab6Swdenk 
4422bce3f59SBin Meng typedef struct {
4432bce3f59SBin Meng 	Elf64_Word	p_type;		/* segment type */
4442bce3f59SBin Meng 	Elf64_Word	p_flags;	/* flags */
4452bce3f59SBin Meng 	Elf64_Off	p_offset;	/* segment offset */
4462bce3f59SBin Meng 	Elf64_Addr	p_vaddr;	/* virtual address of segment */
4472bce3f59SBin Meng 	Elf64_Addr	p_paddr;	/* physical address of segment */
4482bce3f59SBin Meng 	Elf64_Xword	p_filesz;	/* number of bytes in file for seg */
4492bce3f59SBin Meng 	Elf64_Xword	p_memsz;	/* number of bytes in mem. for seg */
4502bce3f59SBin Meng 	Elf64_Xword	p_align;	/* memory alignment */
4512bce3f59SBin Meng } Elf64_Phdr;
4522bce3f59SBin Meng 
453a2cecab6Swdenk /* Segment types - p_type */
454a2cecab6Swdenk #define PT_NULL		0		/* unused */
455a2cecab6Swdenk #define PT_LOAD		1		/* loadable segment */
456a2cecab6Swdenk #define PT_DYNAMIC	2		/* dynamic linking section */
457a2cecab6Swdenk #define PT_INTERP	3		/* the RTLD */
458a2cecab6Swdenk #define PT_NOTE		4		/* auxiliary information */
459a2cecab6Swdenk #define PT_SHLIB	5		/* reserved - purpose undefined */
460a2cecab6Swdenk #define PT_PHDR		6		/* program header */
461a2cecab6Swdenk #define PT_TLS		7		/* Thread local storage template */
462a2cecab6Swdenk #define PT_NUM		8		/* Number of segment types */
463a2cecab6Swdenk #define PT_LOOS		0x60000000	/* reserved range for operating */
464a2cecab6Swdenk #define PT_HIOS		0x6fffffff	/* system specific segment types */
465a2cecab6Swdenk #define PT_LOPROC	0x70000000	/* reserved range for processor */
466a2cecab6Swdenk #define PT_HIPROC	0x7fffffff	/* specific segment types */
467a2cecab6Swdenk 
468a2cecab6Swdenk /* Segment flags - p_flags */
469a2cecab6Swdenk #define PF_X		0x1		/* Executable */
470a2cecab6Swdenk #define PF_W		0x2		/* Writable */
471a2cecab6Swdenk #define PF_R		0x4		/* Readable */
472a2cecab6Swdenk #define PF_MASKOS	0x0ff00000	/* OS specific segment flags */
473a2cecab6Swdenk #define PF_MASKPROC	0xf0000000	/* reserved bits for processor */
474a2cecab6Swdenk 					/* specific segment flags */
475a2cecab6Swdenk /* Dynamic structure */
476df635df2SBin Meng typedef struct {
477a2cecab6Swdenk 	Elf32_Sword	d_tag;		/* controls meaning of d_val */
478df635df2SBin Meng 	union {
479a2cecab6Swdenk 		Elf32_Word	d_val;	/* Multiple meanings - see d_tag */
480a2cecab6Swdenk 		Elf32_Addr	d_ptr;	/* program virtual address */
481a2cecab6Swdenk 	} d_un;
482a2cecab6Swdenk } Elf32_Dyn;
483a2cecab6Swdenk 
484a2cecab6Swdenk extern Elf32_Dyn	_DYNAMIC[];
485a2cecab6Swdenk 
4865efa2813SSimon Glass typedef struct {
4875efa2813SSimon Glass 	Elf64_Sxword d_tag;		/* entry tag value */
4885efa2813SSimon Glass 	union {
4895efa2813SSimon Glass 		Elf64_Xword d_val;
4905efa2813SSimon Glass 		Elf64_Addr d_ptr;
4915efa2813SSimon Glass 	} d_un;
4925efa2813SSimon Glass } Elf64_Dyn;
4935efa2813SSimon Glass 
4945efa2813SSimon Glass #define ELF64_R_SYM(i)			((i) >> 32)
4955efa2813SSimon Glass #define ELF64_R_TYPE(i)			((i) & 0xffffffff)
4965efa2813SSimon Glass 
497a2cecab6Swdenk /* Dynamic Array Tags - d_tag */
498a2cecab6Swdenk #define DT_NULL		0		/* marks end of _DYNAMIC array */
499a2cecab6Swdenk #define DT_NEEDED	1		/* string table offset of needed lib */
500a2cecab6Swdenk #define DT_PLTRELSZ	2		/* size of relocation entries in PLT */
501a2cecab6Swdenk #define DT_PLTGOT	3		/* address PLT/GOT */
502a2cecab6Swdenk #define DT_HASH		4		/* address of symbol hash table */
503a2cecab6Swdenk #define DT_STRTAB	5		/* address of string table */
504a2cecab6Swdenk #define DT_SYMTAB	6		/* address of symbol table */
505a2cecab6Swdenk #define DT_RELA		7		/* address of relocation table */
506a2cecab6Swdenk #define DT_RELASZ	8		/* size of relocation table */
507a2cecab6Swdenk #define DT_RELAENT	9		/* size of relocation entry */
508a2cecab6Swdenk #define DT_STRSZ	10		/* size of string table */
509a2cecab6Swdenk #define DT_SYMENT	11		/* size of symbol table entry */
510df635df2SBin Meng #define DT_INIT		12		/* address of initialization func */
511a2cecab6Swdenk #define DT_FINI		13		/* address of termination function */
512a2cecab6Swdenk #define DT_SONAME	14		/* string table offset of shared obj */
513a2cecab6Swdenk #define DT_RPATH	15		/* string table offset of library
514a2cecab6Swdenk 					   search path */
515df635df2SBin Meng #define DT_SYMBOLIC	16		/* start sym search in shared obj */
516a2cecab6Swdenk #define DT_REL		17		/* address of rel. tbl. w addends */
517a2cecab6Swdenk #define DT_RELSZ	18		/* size of DT_REL relocation table */
518a2cecab6Swdenk #define DT_RELENT	19		/* size of DT_REL relocation entry */
519a2cecab6Swdenk #define DT_PLTREL	20		/* PLT referenced relocation entry */
520a2cecab6Swdenk #define DT_DEBUG	21		/* bugger */
521a2cecab6Swdenk #define DT_TEXTREL	22		/* Allow rel. mod. to unwritable seg */
522a2cecab6Swdenk #define DT_JMPREL	23		/* add. of PLT's relocation entries */
523a2cecab6Swdenk #define DT_BIND_NOW	24		/* Process relocations of object */
524a2cecab6Swdenk #define DT_INIT_ARRAY	25		/* Array with addresses of init fct */
525a2cecab6Swdenk #define DT_FINI_ARRAY	26		/* Array with addresses of fini fct */
526a2cecab6Swdenk #define DT_INIT_ARRAYSZ	27		/* Size in bytes of DT_INIT_ARRAY */
527a2cecab6Swdenk #define DT_FINI_ARRAYSZ	28		/* Size in bytes of DT_FINI_ARRAY */
528a2cecab6Swdenk #define DT_RUNPATH	29		/* Library search path */
529a2cecab6Swdenk #define DT_FLAGS	30		/* Flags for the object being loaded */
530a2cecab6Swdenk #define DT_ENCODING	32		/* Start of encoded range */
531a2cecab6Swdenk #define DT_PREINIT_ARRAY 32		/* Array with addresses of preinit fct*/
532a2cecab6Swdenk #define DT_PREINIT_ARRAYSZ 33		/* size in bytes of DT_PREINIT_ARRAY */
533df635df2SBin Meng #define DT_NUM		34		/* Number used */
534a2cecab6Swdenk #define DT_LOOS		0x60000000	/* reserved range for OS */
535a2cecab6Swdenk #define DT_HIOS		0x6fffffff	/* specific dynamic array tags */
536a2cecab6Swdenk #define DT_LOPROC	0x70000000	/* reserved range for processor */
537a2cecab6Swdenk #define DT_HIPROC	0x7fffffff	/* specific dynamic array tags */
538a2cecab6Swdenk 
539a2cecab6Swdenk /* Dynamic Tag Flags - d_un.d_val */
540a2cecab6Swdenk #define DF_ORIGIN	0x01		/* Object may use DF_ORIGIN */
541a2cecab6Swdenk #define DF_SYMBOLIC	0x02		/* Symbol resolutions starts here */
542a2cecab6Swdenk #define DF_TEXTREL	0x04		/* Object contains text relocations */
543a2cecab6Swdenk #define DF_BIND_NOW	0x08		/* No lazy binding for this object */
544a2cecab6Swdenk #define DF_STATIC_TLS	0x10		/* Static thread local storage */
545a2cecab6Swdenk 
546a2cecab6Swdenk /* Standard ELF hashing function */
547a2cecab6Swdenk unsigned long elf_hash(const unsigned char *name);
548a2cecab6Swdenk 
549a2cecab6Swdenk #define ELF_TARG_VER	1	/* The ver for which this code is intended */
550a2cecab6Swdenk 
551c70f74a0SSimon Glass #endif /* __ASSEMBLER */
552c70f74a0SSimon Glass 
553dae73c4cSAlexander Graf /* ELF register definitions */
554dae73c4cSAlexander Graf #define R_386_NONE	0
555dae73c4cSAlexander Graf #define R_386_32	1
556dae73c4cSAlexander Graf #define R_386_PC32	2
557dae73c4cSAlexander Graf #define R_386_GOT32	3
558dae73c4cSAlexander Graf #define R_386_PLT32	4
559dae73c4cSAlexander Graf #define R_386_COPY	5
560dae73c4cSAlexander Graf #define R_386_GLOB_DAT	6
561dae73c4cSAlexander Graf #define R_386_JMP_SLOT	7
562dae73c4cSAlexander Graf #define R_386_RELATIVE	8
563dae73c4cSAlexander Graf #define R_386_GOTOFF	9
564dae73c4cSAlexander Graf #define R_386_GOTPC	10
565dae73c4cSAlexander Graf #define R_386_NUM	11
566dae73c4cSAlexander Graf 
567dae73c4cSAlexander Graf /* x86-64 relocation types */
568dae73c4cSAlexander Graf #define R_X86_64_NONE		0	/* No reloc */
569dae73c4cSAlexander Graf #define R_X86_64_64		1	/* Direct 64 bit  */
570dae73c4cSAlexander Graf #define R_X86_64_PC32		2	/* PC relative 32 bit signed */
571dae73c4cSAlexander Graf #define R_X86_64_GOT32		3	/* 32 bit GOT entry */
572dae73c4cSAlexander Graf #define R_X86_64_PLT32		4	/* 32 bit PLT address */
573dae73c4cSAlexander Graf #define R_X86_64_COPY		5	/* Copy symbol at runtime */
574dae73c4cSAlexander Graf #define R_X86_64_GLOB_DAT	6	/* Create GOT entry */
575dae73c4cSAlexander Graf #define R_X86_64_JUMP_SLOT	7	/* Create PLT entry */
576dae73c4cSAlexander Graf #define R_X86_64_RELATIVE	8	/* Adjust by program base */
577dae73c4cSAlexander Graf /* 32 bit signed pc relative offset to GOT */
578dae73c4cSAlexander Graf #define R_X86_64_GOTPCREL	9
579dae73c4cSAlexander Graf #define R_X86_64_32		10	/* Direct 32 bit zero extended */
580dae73c4cSAlexander Graf #define R_X86_64_32S		11	/* Direct 32 bit sign extended */
581dae73c4cSAlexander Graf #define R_X86_64_16		12	/* Direct 16 bit zero extended */
582dae73c4cSAlexander Graf #define R_X86_64_PC16		13	/* 16 bit sign extended pc relative */
583dae73c4cSAlexander Graf #define R_X86_64_8		14	/* Direct 8 bit sign extended  */
584dae73c4cSAlexander Graf #define R_X86_64_PC8		15	/* 8 bit sign extended pc relative */
585dae73c4cSAlexander Graf 
586dae73c4cSAlexander Graf #define R_X86_64_NUM		16
587dae73c4cSAlexander Graf 
588a2cecab6Swdenk /*
589a2cecab6Swdenk  * XXX - PowerPC defines really don't belong in here,
590a2cecab6Swdenk  * but we'll put them in for simplicity.
591a2cecab6Swdenk  */
592a2cecab6Swdenk 
593df635df2SBin Meng /* Values for Elf32/64_Ehdr.e_flags */
594a2cecab6Swdenk #define EF_PPC_EMB		0x80000000	/* PowerPC embedded flag */
595a2cecab6Swdenk 
596*2846ea81SRob Bracero #define EF_PPC64_ELFV1_ABI	0x00000001
597*2846ea81SRob Bracero #define EF_PPC64_ELFV2_ABI	0x00000002
598*2846ea81SRob Bracero 
599a2cecab6Swdenk /* Cygnus local bits below */
600a2cecab6Swdenk #define EF_PPC_RELOCATABLE	0x00010000	/* PowerPC -mrelocatable flag*/
601a2cecab6Swdenk #define EF_PPC_RELOCATABLE_LIB	0x00008000	/* PowerPC -mrelocatable-lib
602a2cecab6Swdenk 						   flag */
603a2cecab6Swdenk 
604a2cecab6Swdenk /* PowerPC relocations defined by the ABIs */
605a2cecab6Swdenk #define R_PPC_NONE		0
606a2cecab6Swdenk #define R_PPC_ADDR32		1	/* 32bit absolute address */
607df635df2SBin Meng #define R_PPC_ADDR24		2	/* 26bit address, 2 bits ignored */
608a2cecab6Swdenk #define R_PPC_ADDR16		3	/* 16bit absolute address */
609a2cecab6Swdenk #define R_PPC_ADDR16_LO		4	/* lower 16bit of absolute address */
610a2cecab6Swdenk #define R_PPC_ADDR16_HI		5	/* high 16bit of absolute address */
611a2cecab6Swdenk #define R_PPC_ADDR16_HA		6	/* adjusted high 16bit */
612a2cecab6Swdenk #define R_PPC_ADDR14		7	/* 16bit address, 2 bits ignored */
613a2cecab6Swdenk #define R_PPC_ADDR14_BRTAKEN	8
614a2cecab6Swdenk #define R_PPC_ADDR14_BRNTAKEN	9
615a2cecab6Swdenk #define R_PPC_REL24		10	/* PC relative 26 bit */
616a2cecab6Swdenk #define R_PPC_REL14		11	/* PC relative 16 bit */
617a2cecab6Swdenk #define R_PPC_REL14_BRTAKEN	12
618a2cecab6Swdenk #define R_PPC_REL14_BRNTAKEN	13
619a2cecab6Swdenk #define R_PPC_GOT16		14
620a2cecab6Swdenk #define R_PPC_GOT16_LO		15
621a2cecab6Swdenk #define R_PPC_GOT16_HI		16
622a2cecab6Swdenk #define R_PPC_GOT16_HA		17
623a2cecab6Swdenk #define R_PPC_PLTREL24		18
624a2cecab6Swdenk #define R_PPC_COPY		19
625a2cecab6Swdenk #define R_PPC_GLOB_DAT		20
626a2cecab6Swdenk #define R_PPC_JMP_SLOT		21
627a2cecab6Swdenk #define R_PPC_RELATIVE		22
628a2cecab6Swdenk #define R_PPC_LOCAL24PC		23
629a2cecab6Swdenk #define R_PPC_UADDR32		24
630a2cecab6Swdenk #define R_PPC_UADDR16		25
631a2cecab6Swdenk #define R_PPC_REL32		26
632a2cecab6Swdenk #define R_PPC_PLT32		27
633a2cecab6Swdenk #define R_PPC_PLTREL32		28
634a2cecab6Swdenk #define R_PPC_PLT16_LO		29
635a2cecab6Swdenk #define R_PPC_PLT16_HI		30
636a2cecab6Swdenk #define R_PPC_PLT16_HA		31
637a2cecab6Swdenk #define R_PPC_SDAREL16		32
638a2cecab6Swdenk #define R_PPC_SECTOFF		33
639a2cecab6Swdenk #define R_PPC_SECTOFF_LO	34
640a2cecab6Swdenk #define R_PPC_SECTOFF_HI	35
641a2cecab6Swdenk #define R_PPC_SECTOFF_HA	36
642df635df2SBin Meng /* Keep this the last entry */
643a2cecab6Swdenk #define R_PPC_NUM		37
644a2cecab6Swdenk 
645df635df2SBin Meng /*
646df635df2SBin Meng  * The remaining relocs are from the Embedded ELF ABI, and are not
647df635df2SBin Meng  * in the SVR4 ELF ABI.
648df635df2SBin Meng  */
649a2cecab6Swdenk #define R_PPC_EMB_NADDR32	101
650a2cecab6Swdenk #define R_PPC_EMB_NADDR16	102
651a2cecab6Swdenk #define R_PPC_EMB_NADDR16_LO	103
652a2cecab6Swdenk #define R_PPC_EMB_NADDR16_HI	104
653a2cecab6Swdenk #define R_PPC_EMB_NADDR16_HA	105
654a2cecab6Swdenk #define R_PPC_EMB_SDAI16	106
655a2cecab6Swdenk #define R_PPC_EMB_SDA2I16	107
656a2cecab6Swdenk #define R_PPC_EMB_SDA2REL	108
657a2cecab6Swdenk #define R_PPC_EMB_SDA21		109	/* 16 bit offset in SDA */
658a2cecab6Swdenk #define R_PPC_EMB_MRKREF	110
659a2cecab6Swdenk #define R_PPC_EMB_RELSEC16	111
660a2cecab6Swdenk #define R_PPC_EMB_RELST_LO	112
661a2cecab6Swdenk #define R_PPC_EMB_RELST_HI	113
662a2cecab6Swdenk #define R_PPC_EMB_RELST_HA	114
663a2cecab6Swdenk #define R_PPC_EMB_BIT_FLD	115
664a2cecab6Swdenk #define R_PPC_EMB_RELSDA	116	/* 16 bit relative offset in SDA */
665a2cecab6Swdenk 
666df635df2SBin Meng /* Diab tool relocations */
667a2cecab6Swdenk #define R_PPC_DIAB_SDA21_LO	180	/* like EMB_SDA21, but lower 16 bit */
668a2cecab6Swdenk #define R_PPC_DIAB_SDA21_HI	181	/* like EMB_SDA21, but high 16 bit */
669a2cecab6Swdenk #define R_PPC_DIAB_SDA21_HA	182	/* like EMB_SDA21, adjusted high 16 */
670a2cecab6Swdenk #define R_PPC_DIAB_RELSDA_LO	183	/* like EMB_RELSDA, but lower 16 bit */
671a2cecab6Swdenk #define R_PPC_DIAB_RELSDA_HI	184	/* like EMB_RELSDA, but high 16 bit */
672a2cecab6Swdenk #define R_PPC_DIAB_RELSDA_HA	185	/* like EMB_RELSDA, adjusted high 16 */
673a2cecab6Swdenk 
674df635df2SBin Meng /*
675df635df2SBin Meng  * This is a phony reloc to handle any old fashioned TOC16 references
676df635df2SBin Meng  * that may still be in object files.
677df635df2SBin Meng  */
678a2cecab6Swdenk #define R_PPC_TOC16		255
679a2cecab6Swdenk 
680c70f74a0SSimon Glass  /* ARM relocs */
681c70f74a0SSimon Glass #define R_ARM_NONE		0	/* No reloc */
682c70f74a0SSimon Glass #define R_ARM_RELATIVE		23	/* Adjust by program base */
683c70f74a0SSimon Glass 
684c70f74a0SSimon Glass /* AArch64 relocs */
685df635df2SBin Meng #define R_AARCH64_NONE		0	/* No relocation */
686df635df2SBin Meng #define R_AARCH64_RELATIVE	1027	/* Adjust by program base */
687c70f74a0SSimon Glass 
688068feb9bSRick Chen /* RISC-V relocations */
689068feb9bSRick Chen #define R_RISCV_32		1
690068feb9bSRick Chen #define R_RISCV_64		2
691068feb9bSRick Chen #define R_RISCV_RELATIVE	3
692068feb9bSRick Chen 
693c70f74a0SSimon Glass #ifndef __ASSEMBLER__
6946f38477dSJeroen Hofstee int valid_elf_image(unsigned long addr);
695c70f74a0SSimon Glass #endif
6966f38477dSJeroen Hofstee 
697a2cecab6Swdenk #endif /* _ELF_H */
698