2529 lines
96 KiB
C
2529 lines
96 KiB
C
/*-
|
|
* Copyright (c) 2010 Joseph Koshy
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
* SUCH DAMAGE.
|
|
*
|
|
* $Id$
|
|
*/
|
|
|
|
/*
|
|
* These definitions are based on:
|
|
* - The public specification of the ELF format as defined in the
|
|
* October 2009 draft of System V ABI.
|
|
* See: http://www.sco.com/developers/gabi/latest/ch4.intro.html
|
|
* - The May 1998 (version 1.5) draft of "The ELF-64 object format".
|
|
* - Processor-specific ELF ABI definitions for sparc, i386, amd64, mips,
|
|
* ia64, and powerpc processors.
|
|
* - The "Linkers and Libraries Guide", from Sun Microsystems.
|
|
*/
|
|
|
|
#ifndef _ELFDEFINITIONS_H_
|
|
#define _ELFDEFINITIONS_H_
|
|
|
|
#include <stdint.h>
|
|
|
|
/*
|
|
* Types of capabilities.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_CAPABILITIES() \
|
|
_ELF_DEFINE_CA(CA_SUNW_NULL, 0, "ignored") \
|
|
_ELF_DEFINE_CA(CA_SUNW_HW_1, 1, "hardware capability") \
|
|
_ELF_DEFINE_CA(CA_SUNW_SW_1, 2, "software capability")
|
|
|
|
#undef _ELF_DEFINE_CA
|
|
#define _ELF_DEFINE_CA(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_CAPABILITIES()
|
|
CA__LAST__
|
|
};
|
|
|
|
/*
|
|
* Flags used with dynamic linking entries.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_DYN_FLAGS() \
|
|
_ELF_DEFINE_DF(DF_ORIGIN, 0x1, \
|
|
"object being loaded may refer to $ORIGIN") \
|
|
_ELF_DEFINE_DF(DF_SYMBOLIC, 0x2, \
|
|
"search library for references before executable") \
|
|
_ELF_DEFINE_DF(DF_TEXTREL, 0x4, \
|
|
"relocation entries may modify text segment") \
|
|
_ELF_DEFINE_DF(DF_BIND_NOW, 0x8, \
|
|
"process relocation entries at load time") \
|
|
_ELF_DEFINE_DF(DF_STATIC_TLS, 0x10, \
|
|
"uses static thread-local storage")
|
|
#undef _ELF_DEFINE_DF
|
|
#define _ELF_DEFINE_DF(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_DYN_FLAGS()
|
|
DF__LAST__
|
|
};
|
|
|
|
|
|
/*
|
|
* Dynamic linking entry types.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_DYN_TYPES() \
|
|
_ELF_DEFINE_DT(DT_NULL, 0, "end of array") \
|
|
_ELF_DEFINE_DT(DT_NEEDED, 1, "names a needed library") \
|
|
_ELF_DEFINE_DT(DT_PLTRELSZ, 2, \
|
|
"size in bytes of associated relocation entries") \
|
|
_ELF_DEFINE_DT(DT_PLTGOT, 3, \
|
|
"address associated with the procedure linkage table") \
|
|
_ELF_DEFINE_DT(DT_HASH, 4, \
|
|
"address of the symbol hash table") \
|
|
_ELF_DEFINE_DT(DT_STRTAB, 5, \
|
|
"address of the string table") \
|
|
_ELF_DEFINE_DT(DT_SYMTAB, 6, \
|
|
"address of the symbol table") \
|
|
_ELF_DEFINE_DT(DT_RELA, 7, \
|
|
"address of the relocation table") \
|
|
_ELF_DEFINE_DT(DT_RELASZ, 8, "size of the DT_RELA table") \
|
|
_ELF_DEFINE_DT(DT_RELAENT, 9, "size of each DT_RELA entry") \
|
|
_ELF_DEFINE_DT(DT_STRSZ, 10, "size of the string table") \
|
|
_ELF_DEFINE_DT(DT_SYMENT, 11, \
|
|
"size of a symbol table entry") \
|
|
_ELF_DEFINE_DT(DT_INIT, 12, \
|
|
"address of the initialization function") \
|
|
_ELF_DEFINE_DT(DT_FINI, 13, \
|
|
"address of the finalization function") \
|
|
_ELF_DEFINE_DT(DT_SONAME, 14, "names the shared object") \
|
|
_ELF_DEFINE_DT(DT_RPATH, 15, \
|
|
"runtime library search path") \
|
|
_ELF_DEFINE_DT(DT_SYMBOLIC, 16, \
|
|
"alter symbol resolution algorithm") \
|
|
_ELF_DEFINE_DT(DT_REL, 17, \
|
|
"address of the DT_REL table") \
|
|
_ELF_DEFINE_DT(DT_RELSZ, 18, "size of the DT_REL table") \
|
|
_ELF_DEFINE_DT(DT_RELENT, 19, "size of each DT_REL entry") \
|
|
_ELF_DEFINE_DT(DT_PLTREL, 20, \
|
|
"type of relocation entry in the procedure linkage table") \
|
|
_ELF_DEFINE_DT(DT_DEBUG, 21, "used for debugging") \
|
|
_ELF_DEFINE_DT(DT_TEXTREL, 22, \
|
|
"text segment may be written to during relocation") \
|
|
_ELF_DEFINE_DT(DT_JMPREL, 23, \
|
|
"address of relocation entries associated with the procedure linkage table") \
|
|
_ELF_DEFINE_DT(DT_BIND_NOW, 24, \
|
|
"bind symbols at loading time") \
|
|
_ELF_DEFINE_DT(DT_INIT_ARRAY, 25, \
|
|
"pointers to initialization functions") \
|
|
_ELF_DEFINE_DT(DT_FINI_ARRAY, 26, \
|
|
"pointers to termination functions") \
|
|
_ELF_DEFINE_DT(DT_INIT_ARRAYSZ, 27, "size of the DT_INIT_ARRAY") \
|
|
_ELF_DEFINE_DT(DT_FINI_ARRAYSZ, 28, "size of the DT_FINI_ARRAY") \
|
|
_ELF_DEFINE_DT(DT_RUNPATH, 29, \
|
|
"index of library search path string") \
|
|
_ELF_DEFINE_DT(DT_FLAGS, 30, \
|
|
"flags specific to the object being loaded") \
|
|
_ELF_DEFINE_DT(DT_ENCODING, 32, "standard semantics") \
|
|
_ELF_DEFINE_DT(DT_PREINIT_ARRAY, 32, \
|
|
"pointers to pre-initialization functions") \
|
|
_ELF_DEFINE_DT(DT_PREINIT_ARRAYSZ, 33, \
|
|
"size of pre-initialization array") \
|
|
_ELF_DEFINE_DT(DT_MAXPOSTAGS, 34, \
|
|
"the number of positive tags") \
|
|
_ELF_DEFINE_DT(DT_LOOS, 0x6000000DUL, \
|
|
"start of OS-specific types") \
|
|
_ELF_DEFINE_DT(DT_SUNW_AUXILIARY, 0x6000000DUL, \
|
|
"offset of string naming auxiliary filtees") \
|
|
_ELF_DEFINE_DT(DT_SUNW_RTLDINF, 0x6000000EUL, "rtld internal use") \
|
|
_ELF_DEFINE_DT(DT_SUNW_FILTER, 0x6000000FUL, \
|
|
"offset of string naming standard filtees") \
|
|
_ELF_DEFINE_DT(DT_SUNW_CAP, 0x60000010UL, \
|
|
"address of hardware capabilities section") \
|
|
_ELF_DEFINE_DT(DT_HIOS, 0x6FFFF000UL, \
|
|
"end of OS-specific types") \
|
|
_ELF_DEFINE_DT(DT_VALRNGLO, 0x6FFFFD00UL, \
|
|
"start of range using the d_val field") \
|
|
_ELF_DEFINE_DT(DT_GNU_PRELINKED, 0x6FFFFDF5UL, \
|
|
"prelinking timestamp") \
|
|
_ELF_DEFINE_DT(DT_GNU_CONFLICTSZ, 0x6FFFFDF6UL, \
|
|
"size of conflict section") \
|
|
_ELF_DEFINE_DT(DT_GNU_LIBLISTSZ, 0x6FFFFDF7UL, \
|
|
"size of library list") \
|
|
_ELF_DEFINE_DT(DT_CHECKSUM, 0x6FFFFDF8UL, \
|
|
"checksum for the object") \
|
|
_ELF_DEFINE_DT(DT_PLTPADSZ, 0x6FFFFDF9UL, \
|
|
"size of PLT padding") \
|
|
_ELF_DEFINE_DT(DT_MOVEENT, 0x6FFFFDFAUL, \
|
|
"size of DT_MOVETAB entries") \
|
|
_ELF_DEFINE_DT(DT_MOVESZ, 0x6FFFFDFBUL, \
|
|
"total size of the MOVETAB table") \
|
|
_ELF_DEFINE_DT(DT_FEATURE_1, 0x6FFFFDFCUL, "feature values") \
|
|
_ELF_DEFINE_DT(DT_POSFLAG_1, 0x6FFFFDFDUL, \
|
|
"dynamic position flags") \
|
|
_ELF_DEFINE_DT(DT_SYMINSZ, 0x6FFFFDFEUL, \
|
|
"size of the DT_SYMINFO table") \
|
|
_ELF_DEFINE_DT(DT_SYMINENT, 0x6FFFFDFFUL, \
|
|
"size of a DT_SYMINFO entry") \
|
|
_ELF_DEFINE_DT(DT_VALRNGHI, 0x6FFFFDFFUL, \
|
|
"end of range using the d_val field") \
|
|
_ELF_DEFINE_DT(DT_ADDRRNGLO, 0x6FFFFE00UL, \
|
|
"start of range using the d_ptr field") \
|
|
_ELF_DEFINE_DT(DT_GNU_HASH, 0x6FFFFEF5UL, \
|
|
"GNU style hash tables") \
|
|
_ELF_DEFINE_DT(DT_GNU_CONFLICT, 0x6FFFFEF8UL, \
|
|
"address of conflict section") \
|
|
_ELF_DEFINE_DT(DT_GNU_LIBLIST, 0x6FFFFEF9UL, \
|
|
"address of conflict section") \
|
|
_ELF_DEFINE_DT(DT_CONFIG, 0x6FFFFEFAUL, \
|
|
"configuration file") \
|
|
_ELF_DEFINE_DT(DT_DEPAUDIT, 0x6FFFFEFBUL, \
|
|
"string defining audit libraries") \
|
|
_ELF_DEFINE_DT(DT_AUDIT, 0x6FFFFEFCUL, \
|
|
"string defining audit libraries") \
|
|
_ELF_DEFINE_DT(DT_PLTPAD, 0x6FFFFEFDUL, "PLT padding") \
|
|
_ELF_DEFINE_DT(DT_MOVETAB, 0x6FFFFEFEUL, \
|
|
"address of a move table") \
|
|
_ELF_DEFINE_DT(DT_SYMINFO, 0x6FFFFEFFUL, \
|
|
"address of the symbol information table") \
|
|
_ELF_DEFINE_DT(DT_ADDRRNGHI, 0x6FFFFEFFUL, \
|
|
"end of range using the d_ptr field") \
|
|
_ELF_DEFINE_DT(DT_VERSYM, 0x6FFFFFF0UL, \
|
|
"address of the version section") \
|
|
_ELF_DEFINE_DT(DT_RELACOUNT, 0x6FFFFFF9UL, \
|
|
"count of RELA relocations") \
|
|
_ELF_DEFINE_DT(DT_RELCOUNT, 0x6FFFFFFAUL, \
|
|
"count of REL relocations") \
|
|
_ELF_DEFINE_DT(DT_FLAGS_1, 0x6FFFFFFBUL, "flag values") \
|
|
_ELF_DEFINE_DT(DT_VERDEF, 0x6FFFFFFCUL, \
|
|
"address of the version definition segment") \
|
|
_ELF_DEFINE_DT(DT_VERDEFNUM, 0x6FFFFFFDUL, \
|
|
"the number of version definition entries") \
|
|
_ELF_DEFINE_DT(DT_VERNEED, 0x6FFFFFFEUL, \
|
|
"address of section with needed versions") \
|
|
_ELF_DEFINE_DT(DT_VERNEEDNUM, 0x6FFFFFFFUL, \
|
|
"the number of version needed entries") \
|
|
_ELF_DEFINE_DT(DT_LOPROC, 0x70000000UL, \
|
|
"start of processor-specific types") \
|
|
_ELF_DEFINE_DT(DT_ARM_SYMTABSZ, 0x70000001UL, \
|
|
"number of entries in the dynamic symbol table") \
|
|
_ELF_DEFINE_DT(DT_SPARC_REGISTER, 0x70000001UL, \
|
|
"index of an STT_SPARC_REGISTER symbol") \
|
|
_ELF_DEFINE_DT(DT_ARM_PREEMPTMAP, 0x70000002UL, \
|
|
"address of the preemption map") \
|
|
_ELF_DEFINE_DT(DT_MIPS_RLD_VERSION, 0x70000001UL, \
|
|
"version ID for runtime linker interface") \
|
|
_ELF_DEFINE_DT(DT_MIPS_TIME_STAMP, 0x70000002UL, \
|
|
"timestamp") \
|
|
_ELF_DEFINE_DT(DT_MIPS_ICHECKSUM, 0x70000003UL, \
|
|
"checksum of all external strings and common sizes") \
|
|
_ELF_DEFINE_DT(DT_MIPS_IVERSION, 0x70000004UL, \
|
|
"string table index of a version string") \
|
|
_ELF_DEFINE_DT(DT_MIPS_FLAGS, 0x70000005UL, \
|
|
"MIPS-specific flags") \
|
|
_ELF_DEFINE_DT(DT_MIPS_BASE_ADDRESS, 0x70000006UL, \
|
|
"base address for the executable/DSO") \
|
|
_ELF_DEFINE_DT(DT_MIPS_CONFLICT, 0x70000008UL, \
|
|
"address of .conflict section") \
|
|
_ELF_DEFINE_DT(DT_MIPS_LIBLIST, 0x70000009UL, \
|
|
"address of .liblist section") \
|
|
_ELF_DEFINE_DT(DT_MIPS_LOCAL_GOTNO, 0x7000000AUL, \
|
|
"number of local GOT entries") \
|
|
_ELF_DEFINE_DT(DT_MIPS_CONFLICTNO, 0x7000000BUL, \
|
|
"number of entries in the .conflict section") \
|
|
_ELF_DEFINE_DT(DT_MIPS_LIBLISTNO, 0x70000010UL, \
|
|
"number of entries in the .liblist section") \
|
|
_ELF_DEFINE_DT(DT_MIPS_SYMTABNO, 0x70000011UL, \
|
|
"number of entries in the .dynsym section") \
|
|
_ELF_DEFINE_DT(DT_MIPS_UNREFEXTNO, 0x70000012UL, \
|
|
"index of first external dynamic symbol not ref'ed locally") \
|
|
_ELF_DEFINE_DT(DT_MIPS_GOTSYM, 0x70000013UL, \
|
|
"index of first dynamic symbol corresponds to a GOT entry") \
|
|
_ELF_DEFINE_DT(DT_MIPS_HIPAGENO, 0x70000014UL, \
|
|
"number of page table entries in GOT") \
|
|
_ELF_DEFINE_DT(DT_MIPS_RLD_MAP, 0x70000016UL, \
|
|
"address of runtime linker map") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_CLASS, 0x70000017UL, \
|
|
"Delta C++ class definition") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_CLASS_NO, 0x70000018UL, \
|
|
"number of entries in DT_MIPS_DELTA_CLASS") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_INSTANCE, 0x70000019UL, \
|
|
"Delta C++ class instances") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_INSTANCE_NO, 0x7000001AUL, \
|
|
"number of entries in DT_MIPS_DELTA_INSTANCE") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_RELOC, 0x7000001BUL, \
|
|
"Delta relocations") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_RELOC_NO, 0x7000001CUL, \
|
|
"number of entries in DT_MIPS_DELTA_RELOC") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_SYM, 0x7000001DUL, \
|
|
"Delta symbols refered by Delta relocations") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_SYM_NO, 0x7000001EUL, \
|
|
"number of entries in DT_MIPS_DELTA_SYM") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_CLASSSYM, 0x70000020UL, \
|
|
"Delta symbols for class declarations") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DELTA_CLASSSYM_NO, 0x70000021UL, \
|
|
"number of entries in DT_MIPS_DELTA_CLASSSYM") \
|
|
_ELF_DEFINE_DT(DT_MIPS_CXX_FLAGS, 0x70000022UL, \
|
|
"C++ flavor flags") \
|
|
_ELF_DEFINE_DT(DT_MIPS_PIXIE_INIT, 0x70000023UL, \
|
|
"address of an initialization routine created by pixie") \
|
|
_ELF_DEFINE_DT(DT_MIPS_SYMBOL_LIB, 0x70000024UL, \
|
|
"address of .MIPS.symlib section") \
|
|
_ELF_DEFINE_DT(DT_MIPS_LOCALPAGE_GOTIDX, 0x70000025UL, \
|
|
"GOT index of first page table entry for a segment") \
|
|
_ELF_DEFINE_DT(DT_MIPS_LOCAL_GOTIDX, 0x70000026UL, \
|
|
"GOT index of first page table entry for a local symbol") \
|
|
_ELF_DEFINE_DT(DT_MIPS_HIDDEN_GOTIDX, 0x70000027UL, \
|
|
"GOT index of first page table entry for a hidden symbol") \
|
|
_ELF_DEFINE_DT(DT_MIPS_PROTECTED_GOTIDX, 0x70000028UL, \
|
|
"GOT index of first page table entry for a protected symbol") \
|
|
_ELF_DEFINE_DT(DT_MIPS_OPTIONS, 0x70000029UL, \
|
|
"address of .MIPS.options section") \
|
|
_ELF_DEFINE_DT(DT_MIPS_INTERFACE, 0x7000002AUL, \
|
|
"address of .MIPS.interface section") \
|
|
_ELF_DEFINE_DT(DT_MIPS_DYNSTR_ALIGN, 0x7000002BUL, "???") \
|
|
_ELF_DEFINE_DT(DT_MIPS_INTERFACE_SIZE, 0x7000002CUL, \
|
|
"size of .MIPS.interface section") \
|
|
_ELF_DEFINE_DT(DT_MIPS_RLD_TEXT_RESOLVE_ADDR, 0x7000002DUL, \
|
|
"address of _rld_text_resolve in GOT") \
|
|
_ELF_DEFINE_DT(DT_MIPS_PERF_SUFFIX, 0x7000002EUL, \
|
|
"default suffix of DSO to be appended by dlopen") \
|
|
_ELF_DEFINE_DT(DT_MIPS_COMPACT_SIZE, 0x7000002FUL, \
|
|
"size of a ucode compact relocation record (o32)") \
|
|
_ELF_DEFINE_DT(DT_MIPS_GP_VALUE, 0x70000030UL, \
|
|
"GP value of a specified GP relative range") \
|
|
_ELF_DEFINE_DT(DT_MIPS_AUX_DYNAMIC, 0x70000031UL, \
|
|
"address of an auxiliary dynamic table") \
|
|
_ELF_DEFINE_DT(DT_MIPS_PLTGOT, 0x70000032UL, \
|
|
"address of the PLTGOT") \
|
|
_ELF_DEFINE_DT(DT_MIPS_RLD_OBJ_UPDATE, 0x70000033UL, \
|
|
"object list update callback") \
|
|
_ELF_DEFINE_DT(DT_MIPS_RWPLT, 0x70000034UL, \
|
|
"address of a writable PLT") \
|
|
_ELF_DEFINE_DT(DT_PPC_GOT, 0x70000000UL, \
|
|
"value of _GLOBAL_OFFSET_TABLE_") \
|
|
_ELF_DEFINE_DT(DT_PPC_TLSOPT, 0x70000001UL, \
|
|
"TLS descriptor should be optimized") \
|
|
_ELF_DEFINE_DT(DT_PPC64_GLINK, 0x70000000UL, \
|
|
"address of .glink section") \
|
|
_ELF_DEFINE_DT(DT_PPC64_OPD, 0x70000001UL, \
|
|
"address of .opd section") \
|
|
_ELF_DEFINE_DT(DT_PPC64_OPDSZ, 0x70000002UL, \
|
|
"size of .opd section") \
|
|
_ELF_DEFINE_DT(DT_PPC64_TLSOPT, 0x70000003UL, \
|
|
"TLS descriptor should be optimized") \
|
|
_ELF_DEFINE_DT(DT_AUXILIARY, 0x7FFFFFFDUL, \
|
|
"offset of string naming auxiliary filtees") \
|
|
_ELF_DEFINE_DT(DT_USED, 0x7FFFFFFEUL, "ignored") \
|
|
_ELF_DEFINE_DT(DT_FILTER, 0x7FFFFFFFUL, \
|
|
"index of string naming filtees") \
|
|
_ELF_DEFINE_DT(DT_HIPROC, 0x7FFFFFFFUL, \
|
|
"end of processor-specific types")
|
|
|
|
#undef _ELF_DEFINE_DT
|
|
#define _ELF_DEFINE_DT(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_DYN_TYPES()
|
|
DT__LAST__ = DT_HIPROC
|
|
};
|
|
|
|
#define DT_DEPRECATED_SPARC_REGISTER DT_SPARC_REGISTER
|
|
|
|
/*
|
|
* Flags used in the executable header (field: e_flags).
|
|
*/
|
|
#define _ELF_DEFINE_EHDR_FLAGS() \
|
|
_ELF_DEFINE_EF(EF_ARM_RELEXEC, 0x00000001UL, \
|
|
"dynamic segment describes only how to relocate segments") \
|
|
_ELF_DEFINE_EF(EF_ARM_HASENTRY, 0x00000002UL, \
|
|
"e_entry contains a program entry point") \
|
|
_ELF_DEFINE_EF(EF_ARM_SYMSARESORTED, 0x00000004UL, \
|
|
"subsection of symbol table is sorted by symbol value") \
|
|
_ELF_DEFINE_EF(EF_ARM_DYNSYMSUSESEGIDX, 0x00000008UL, \
|
|
"dynamic symbol st_shndx = containing segment index + 1") \
|
|
_ELF_DEFINE_EF(EF_ARM_MAPSYMSFIRST, 0x00000010UL, \
|
|
"mapping symbols precede other local symbols in symtab") \
|
|
_ELF_DEFINE_EF(EF_ARM_BE8, 0x00800000UL, \
|
|
"file contains BE-8 code") \
|
|
_ELF_DEFINE_EF(EF_ARM_LE8, 0x00400000UL, \
|
|
"file contains LE-8 code") \
|
|
_ELF_DEFINE_EF(EF_ARM_EABIMASK, 0xFF000000UL, \
|
|
"mask for ARM EABI version number (0 denotes GNU or unknown)") \
|
|
_ELF_DEFINE_EF(EF_ARM_INTERWORK, 0x00000004UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_ARM_APCS_26, 0x00000008UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_ARM_APCS_FLOAT, 0x00000010UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_ARM_PIC, 0x00000020UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_ARM_ALIGN8, 0x00000040UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_ARM_NEW_ABI, 0x00000080UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_ARM_OLD_ABI, 0x00000100UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_ARM_SOFT_FLOAT, 0x00000200UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_ARM_VFP_FLOAT, 0x00000400UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_ARM_MAVERICK_FLOAT, 0x00000800UL, \
|
|
"GNU EABI extension") \
|
|
_ELF_DEFINE_EF(EF_MIPS_NOREORDER, 0x00000001UL, \
|
|
"at least one .noreorder directive appeared in the source") \
|
|
_ELF_DEFINE_EF(EF_MIPS_PIC, 0x00000002UL, \
|
|
"file contains position independent code") \
|
|
_ELF_DEFINE_EF(EF_MIPS_CPIC, 0x00000004UL, \
|
|
"file's code uses standard conventions for calling PIC") \
|
|
_ELF_DEFINE_EF(EF_MIPS_UCODE, 0x00000010UL, \
|
|
"file contains UCODE (obsolete)") \
|
|
_ELF_DEFINE_EF(EF_MIPS_ABI2, 0x00000020UL, \
|
|
"file follows MIPS III 32-bit ABI") \
|
|
_ELF_DEFINE_EF(EF_MIPS_OPTIONS_FIRST, 0x00000080UL, \
|
|
"ld(1) should process .MIPS.options section first") \
|
|
_ELF_DEFINE_EF(EF_MIPS_ARCH_ASE, 0x0F000000UL, \
|
|
"file uses application-specific architectural extensions") \
|
|
_ELF_DEFINE_EF(EF_MIPS_ARCH_ASE_MDMX, 0x08000000UL, \
|
|
"file uses MDMX multimedia extensions") \
|
|
_ELF_DEFINE_EF(EF_MIPS_ARCH_ASE_M16, 0x04000000UL, \
|
|
"file uses MIPS-16 ISA extensions") \
|
|
_ELF_DEFINE_EF(EF_MIPS_ARCH, 0xF0000000UL, \
|
|
"4-bit MIPS architecture field") \
|
|
_ELF_DEFINE_EF(EF_PPC_EMB, 0x80000000UL, \
|
|
"Embedded PowerPC flag") \
|
|
_ELF_DEFINE_EF(EF_PPC_RELOCATABLE, 0x00010000UL, \
|
|
"-mrelocatable flag") \
|
|
_ELF_DEFINE_EF(EF_PPC_RELOCATABLE_LIB, 0x00008000UL, \
|
|
"-mrelocatable-lib flag") \
|
|
_ELF_DEFINE_EF(EF_SPARC_EXT_MASK, 0x00ffff00UL, \
|
|
"Vendor Extension mask") \
|
|
_ELF_DEFINE_EF(EF_SPARC_32PLUS, 0x00000100UL, \
|
|
"Generic V8+ features") \
|
|
_ELF_DEFINE_EF(EF_SPARC_SUN_US1, 0x00000200UL, \
|
|
"Sun UltraSPARCTM 1 Extensions") \
|
|
_ELF_DEFINE_EF(EF_SPARC_HAL_R1, 0x00000400UL, "HAL R1 Extensions") \
|
|
_ELF_DEFINE_EF(EF_SPARC_SUN_US3, 0x00000800UL, \
|
|
"Sun UltraSPARC 3 Extensions") \
|
|
_ELF_DEFINE_EF(EF_SPARCV9_MM, 0x00000003UL, \
|
|
"Mask for Memory Model") \
|
|
_ELF_DEFINE_EF(EF_SPARCV9_TSO, 0x00000000UL, \
|
|
"Total Store Ordering") \
|
|
_ELF_DEFINE_EF(EF_SPARCV9_PSO, 0x00000001UL, \
|
|
"Partial Store Ordering") \
|
|
_ELF_DEFINE_EF(EF_SPARCV9_RMO, 0x00000002UL, \
|
|
"Relaxed Memory Ordering")
|
|
|
|
#undef _ELF_DEFINE_EF
|
|
#define _ELF_DEFINE_EF(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_EHDR_FLAGS()
|
|
EF__LAST__
|
|
};
|
|
|
|
/*
|
|
* Offsets in the `ei_ident[]` field of an ELF executable header.
|
|
*/
|
|
#define _ELF_DEFINE_EI_OFFSETS() \
|
|
_ELF_DEFINE_EI(EI_MAG0, 0, "magic number") \
|
|
_ELF_DEFINE_EI(EI_MAG1, 1, "magic number") \
|
|
_ELF_DEFINE_EI(EI_MAG2, 2, "magic number") \
|
|
_ELF_DEFINE_EI(EI_MAG3, 3, "magic number") \
|
|
_ELF_DEFINE_EI(EI_CLASS, 4, "file class") \
|
|
_ELF_DEFINE_EI(EI_DATA, 5, "data encoding") \
|
|
_ELF_DEFINE_EI(EI_VERSION, 6, "file version") \
|
|
_ELF_DEFINE_EI(EI_OSABI, 7, "OS ABI kind") \
|
|
_ELF_DEFINE_EI(EI_ABIVERSION, 8, "OS ABI version") \
|
|
_ELF_DEFINE_EI(EI_PAD, 9, "padding start") \
|
|
_ELF_DEFINE_EI(EI_NIDENT, 16, "total size")
|
|
|
|
#undef _ELF_DEFINE_EI
|
|
#define _ELF_DEFINE_EI(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_EI_OFFSETS()
|
|
EI__LAST__
|
|
};
|
|
|
|
/*
|
|
* The ELF class of an object.
|
|
*/
|
|
#define _ELF_DEFINE_ELFCLASS() \
|
|
_ELF_DEFINE_EC(ELFCLASSNONE, 0, "Unknown ELF class") \
|
|
_ELF_DEFINE_EC(ELFCLASS32, 1, "32 bit objects") \
|
|
_ELF_DEFINE_EC(ELFCLASS64, 2, "64 bit objects")
|
|
|
|
#undef _ELF_DEFINE_EC
|
|
#define _ELF_DEFINE_EC(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ELFCLASS()
|
|
EC__LAST__
|
|
};
|
|
|
|
/*
|
|
* Endianness of data in an ELF object.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_ELF_DATA_ENDIANNESS() \
|
|
_ELF_DEFINE_ED(ELFDATANONE, 0, "Unknown data endianness") \
|
|
_ELF_DEFINE_ED(ELFDATA2LSB, 1, "little endian") \
|
|
_ELF_DEFINE_ED(ELFDATA2MSB, 2, "big endian")
|
|
|
|
#undef _ELF_DEFINE_ED
|
|
#define _ELF_DEFINE_ED(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ELF_DATA_ENDIANNESS()
|
|
ED__LAST__
|
|
};
|
|
|
|
/*
|
|
* Values of the magic numbers used in identification array.
|
|
*/
|
|
#define _ELF_DEFINE_ELF_MAGIC() \
|
|
_ELF_DEFINE_EMAG(ELFMAG0, 0x7FU) \
|
|
_ELF_DEFINE_EMAG(ELFMAG1, 'E') \
|
|
_ELF_DEFINE_EMAG(ELFMAG2, 'L') \
|
|
_ELF_DEFINE_EMAG(ELFMAG3, 'F')
|
|
|
|
#undef _ELF_DEFINE_EMAG
|
|
#define _ELF_DEFINE_EMAG(N, V) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ELF_MAGIC()
|
|
ELFMAG__LAST__
|
|
};
|
|
|
|
/*
|
|
* ELF OS ABI field.
|
|
*/
|
|
#define _ELF_DEFINE_ELF_OSABI() \
|
|
_ELF_DEFINE_EABI(ELFOSABI_NONE, 0, \
|
|
"No extensions or unspecified") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_SYSV, 0, "SYSV") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_HPUX, 1, "Hewlett-Packard HP-UX") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_NETBSD, 2, "NetBSD") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_LINUX, 3, "Linux") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_HURD, 4, "GNU/HURD") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_86OPEN, 5, "86Open Common ABI") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_SOLARIS, 6, "Sun Solaris") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_AIX, 7, "AIX") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_IRIX, 8, "IRIX") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_FREEBSD, 9, "FreeBSD") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_TRU64, 10, "Compaq TRU64 UNIX") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_MODESTO, 11, "Novell Modesto") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_OPENBSD, 12, "Open BSD") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_OPENVMS, 13, "Open VMS") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_NSK, 14, \
|
|
"Hewlett-Packard Non-Stop Kernel") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_AROS, 15, "Amiga Research OS") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_FENIXOS, 16, \
|
|
"The FenixOS highly scalable multi-core OS") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_ARM_AEABI, 64, \
|
|
"ARM specific symbol versioning extensions") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_ARM, 97, "ARM ABI") \
|
|
_ELF_DEFINE_EABI(ELFOSABI_STANDALONE, 255, \
|
|
"Standalone (embedded) application")
|
|
|
|
#undef _ELF_DEFINE_EABI
|
|
#define _ELF_DEFINE_EABI(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ELF_OSABI()
|
|
ELFOSABI__LAST__
|
|
};
|
|
|
|
/*
|
|
* ELF Machine types: (EM_*).
|
|
*/
|
|
#define _ELF_DEFINE_ELF_MACHINES() \
|
|
_ELF_DEFINE_EM(EM_NONE, 0, "No machine") \
|
|
_ELF_DEFINE_EM(EM_M32, 1, "AT&T WE 32100") \
|
|
_ELF_DEFINE_EM(EM_SPARC, 2, "SPARC") \
|
|
_ELF_DEFINE_EM(EM_386, 3, "Intel 80386") \
|
|
_ELF_DEFINE_EM(EM_68K, 4, "Motorola 68000") \
|
|
_ELF_DEFINE_EM(EM_88K, 5, "Motorola 88000") \
|
|
_ELF_DEFINE_EM(EM_860, 7, "Intel 80860") \
|
|
_ELF_DEFINE_EM(EM_MIPS, 8, "MIPS I Architecture") \
|
|
_ELF_DEFINE_EM(EM_S370, 9, "IBM System/370 Processor") \
|
|
_ELF_DEFINE_EM(EM_MIPS_RS3_LE, 10, "MIPS RS3000 Little-endian") \
|
|
_ELF_DEFINE_EM(EM_PARISC, 15, "Hewlett-Packard PA-RISC") \
|
|
_ELF_DEFINE_EM(EM_VPP500, 17, "Fujitsu VPP500") \
|
|
_ELF_DEFINE_EM(EM_SPARC32PLUS, 18, \
|
|
"Enhanced instruction set SPARC") \
|
|
_ELF_DEFINE_EM(EM_960, 19, "Intel 80960") \
|
|
_ELF_DEFINE_EM(EM_PPC, 20, "PowerPC") \
|
|
_ELF_DEFINE_EM(EM_PPC64, 21, "64-bit PowerPC") \
|
|
_ELF_DEFINE_EM(EM_S390, 22, "IBM System/390 Processor") \
|
|
_ELF_DEFINE_EM(EM_SPU, 23, "IBM SPU/SPC") \
|
|
_ELF_DEFINE_EM(EM_V800, 36, "NEC V800") \
|
|
_ELF_DEFINE_EM(EM_FR20, 37, "Fujitsu FR20") \
|
|
_ELF_DEFINE_EM(EM_RH32, 38, "TRW RH-32") \
|
|
_ELF_DEFINE_EM(EM_RCE, 39, "Motorola RCE") \
|
|
_ELF_DEFINE_EM(EM_ARM, 40, "Advanced RISC Machines ARM") \
|
|
_ELF_DEFINE_EM(EM_ALPHA, 41, "Digital Alpha") \
|
|
_ELF_DEFINE_EM(EM_SH, 42, "Hitachi SH") \
|
|
_ELF_DEFINE_EM(EM_SPARCV9, 43, "SPARC Version 9") \
|
|
_ELF_DEFINE_EM(EM_TRICORE, 44, \
|
|
"Siemens TriCore embedded processor") \
|
|
_ELF_DEFINE_EM(EM_ARC, 45, \
|
|
"Argonaut RISC Core, Argonaut Technologies Inc.") \
|
|
_ELF_DEFINE_EM(EM_H8_300, 46, "Hitachi H8/300") \
|
|
_ELF_DEFINE_EM(EM_H8_300H, 47, "Hitachi H8/300H") \
|
|
_ELF_DEFINE_EM(EM_H8S, 48, "Hitachi H8S") \
|
|
_ELF_DEFINE_EM(EM_H8_500, 49, "Hitachi H8/500") \
|
|
_ELF_DEFINE_EM(EM_IA_64, 50, \
|
|
"Intel IA-64 processor architecture") \
|
|
_ELF_DEFINE_EM(EM_MIPS_X, 51, "Stanford MIPS-X") \
|
|
_ELF_DEFINE_EM(EM_COLDFIRE, 52, "Motorola ColdFire") \
|
|
_ELF_DEFINE_EM(EM_68HC12, 53, "Motorola M68HC12") \
|
|
_ELF_DEFINE_EM(EM_MMA, 54, \
|
|
"Fujitsu MMA Multimedia Accelerator") \
|
|
_ELF_DEFINE_EM(EM_PCP, 55, "Siemens PCP") \
|
|
_ELF_DEFINE_EM(EM_NCPU, 56, \
|
|
"Sony nCPU embedded RISC processor") \
|
|
_ELF_DEFINE_EM(EM_NDR1, 57, "Denso NDR1 microprocessor") \
|
|
_ELF_DEFINE_EM(EM_STARCORE, 58, "Motorola Star*Core processor") \
|
|
_ELF_DEFINE_EM(EM_ME16, 59, "Toyota ME16 processor") \
|
|
_ELF_DEFINE_EM(EM_ST100, 60, \
|
|
"STMicroelectronics ST100 processor") \
|
|
_ELF_DEFINE_EM(EM_TINYJ, 61, \
|
|
"Advanced Logic Corp. TinyJ embedded processor family") \
|
|
_ELF_DEFINE_EM(EM_X86_64, 62, "AMD x86-64 architecture") \
|
|
_ELF_DEFINE_EM(EM_PDSP, 63, "Sony DSP Processor") \
|
|
_ELF_DEFINE_EM(EM_PDP10, 64, \
|
|
"Digital Equipment Corp. PDP-10") \
|
|
_ELF_DEFINE_EM(EM_PDP11, 65, \
|
|
"Digital Equipment Corp. PDP-11") \
|
|
_ELF_DEFINE_EM(EM_FX66, 66, "Siemens FX66 microcontroller") \
|
|
_ELF_DEFINE_EM(EM_ST9PLUS, 67, \
|
|
"STMicroelectronics ST9+ 8/16 bit microcontroller") \
|
|
_ELF_DEFINE_EM(EM_ST7, 68, \
|
|
"STMicroelectronics ST7 8-bit microcontroller") \
|
|
_ELF_DEFINE_EM(EM_68HC16, 69, \
|
|
"Motorola MC68HC16 Microcontroller") \
|
|
_ELF_DEFINE_EM(EM_68HC11, 70, \
|
|
"Motorola MC68HC11 Microcontroller") \
|
|
_ELF_DEFINE_EM(EM_68HC08, 71, \
|
|
"Motorola MC68HC08 Microcontroller") \
|
|
_ELF_DEFINE_EM(EM_68HC05, 72, \
|
|
"Motorola MC68HC05 Microcontroller") \
|
|
_ELF_DEFINE_EM(EM_SVX, 73, "Silicon Graphics SVx") \
|
|
_ELF_DEFINE_EM(EM_ST19, 74, \
|
|
"STMicroelectronics ST19 8-bit microcontroller") \
|
|
_ELF_DEFINE_EM(EM_VAX, 75, "Digital VAX") \
|
|
_ELF_DEFINE_EM(EM_CRIS, 76, \
|
|
"Axis Communications 32-bit embedded processor") \
|
|
_ELF_DEFINE_EM(EM_JAVELIN, 77, \
|
|
"Infineon Technologies 32-bit embedded processor") \
|
|
_ELF_DEFINE_EM(EM_FIREPATH, 78, \
|
|
"Element 14 64-bit DSP Processor") \
|
|
_ELF_DEFINE_EM(EM_ZSP, 79, \
|
|
"LSI Logic 16-bit DSP Processor") \
|
|
_ELF_DEFINE_EM(EM_MMIX, 80, \
|
|
"Donald Knuth's educational 64-bit processor") \
|
|
_ELF_DEFINE_EM(EM_HUANY, 81, \
|
|
"Harvard University machine-independent object files") \
|
|
_ELF_DEFINE_EM(EM_PRISM, 82, "SiTera Prism") \
|
|
_ELF_DEFINE_EM(EM_AVR, 83, \
|
|
"Atmel AVR 8-bit microcontroller") \
|
|
_ELF_DEFINE_EM(EM_FR30, 84, "Fujitsu FR30") \
|
|
_ELF_DEFINE_EM(EM_D10V, 85, "Mitsubishi D10V") \
|
|
_ELF_DEFINE_EM(EM_D30V, 86, "Mitsubishi D30V") \
|
|
_ELF_DEFINE_EM(EM_V850, 87, "NEC v850") \
|
|
_ELF_DEFINE_EM(EM_M32R, 88, "Mitsubishi M32R") \
|
|
_ELF_DEFINE_EM(EM_MN10300, 89, "Matsushita MN10300") \
|
|
_ELF_DEFINE_EM(EM_MN10200, 90, "Matsushita MN10200") \
|
|
_ELF_DEFINE_EM(EM_PJ, 91, "picoJava") \
|
|
_ELF_DEFINE_EM(EM_OPENRISC, 92, \
|
|
"OpenRISC 32-bit embedded processor") \
|
|
_ELF_DEFINE_EM(EM_ARC_COMPACT, 93, \
|
|
"ARC International ARCompact processor") \
|
|
_ELF_DEFINE_EM(EM_XTENSA, 94, \
|
|
"Tensilica Xtensa Architecture") \
|
|
_ELF_DEFINE_EM(EM_VIDEOCORE, 95, \
|
|
"Alphamosaic VideoCore processor") \
|
|
_ELF_DEFINE_EM(EM_TMM_GPP, 96, \
|
|
"Thompson Multimedia General Purpose Processor") \
|
|
_ELF_DEFINE_EM(EM_NS32K, 97, \
|
|
"National Semiconductor 32000 series") \
|
|
_ELF_DEFINE_EM(EM_TPC, 98, "Tenor Network TPC processor") \
|
|
_ELF_DEFINE_EM(EM_SNP1K, 99, "Trebia SNP 1000 processor") \
|
|
_ELF_DEFINE_EM(EM_ST200, 100, \
|
|
"STMicroelectronics (www.st.com) ST200 microcontroller") \
|
|
_ELF_DEFINE_EM(EM_IP2K, 101, \
|
|
"Ubicom IP2xxx microcontroller family") \
|
|
_ELF_DEFINE_EM(EM_MAX, 102, "MAX Processor") \
|
|
_ELF_DEFINE_EM(EM_CR, 103, \
|
|
"National Semiconductor CompactRISC microprocessor") \
|
|
_ELF_DEFINE_EM(EM_F2MC16, 104, "Fujitsu F2MC16") \
|
|
_ELF_DEFINE_EM(EM_MSP430, 105, \
|
|
"Texas Instruments embedded microcontroller msp430") \
|
|
_ELF_DEFINE_EM(EM_BLACKFIN, 106, \
|
|
"Analog Devices Blackfin (DSP) processor") \
|
|
_ELF_DEFINE_EM(EM_SE_C33, 107, \
|
|
"S1C33 Family of Seiko Epson processors") \
|
|
_ELF_DEFINE_EM(EM_SEP, 108, \
|
|
"Sharp embedded microprocessor") \
|
|
_ELF_DEFINE_EM(EM_ARCA, 109, "Arca RISC Microprocessor") \
|
|
_ELF_DEFINE_EM(EM_UNICORE, 110, \
|
|
"Microprocessor series from PKU-Unity Ltd. and MPRC of Peking University") \
|
|
_ELF_DEFINE_EM(EM_EXCESS, 111, \
|
|
"eXcess: 16/32/64-bit configurable embedded CPU") \
|
|
_ELF_DEFINE_EM(EM_DXP, 112, \
|
|
"Icera Semiconductor Inc. Deep Execution Processor") \
|
|
_ELF_DEFINE_EM(EM_ALTERA_NIOS2, 113, \
|
|
"Altera Nios II soft-core processor") \
|
|
_ELF_DEFINE_EM(EM_CRX, 114, \
|
|
"National Semiconductor CompactRISC CRX microprocessor") \
|
|
_ELF_DEFINE_EM(EM_XGATE, 115, \
|
|
"Motorola XGATE embedded processor") \
|
|
_ELF_DEFINE_EM(EM_C166, 116, \
|
|
"Infineon C16x/XC16x processor") \
|
|
_ELF_DEFINE_EM(EM_M16C, 117, \
|
|
"Renesas M16C series microprocessors") \
|
|
_ELF_DEFINE_EM(EM_DSPIC30F, 118, \
|
|
"Microchip Technology dsPIC30F Digital Signal Controller") \
|
|
_ELF_DEFINE_EM(EM_CE, 119, \
|
|
"Freescale Communication Engine RISC core") \
|
|
_ELF_DEFINE_EM(EM_M32C, 120, \
|
|
"Renesas M32C series microprocessors") \
|
|
_ELF_DEFINE_EM(EM_TSK3000, 131, "Altium TSK3000 core") \
|
|
_ELF_DEFINE_EM(EM_RS08, 132, \
|
|
"Freescale RS08 embedded processor") \
|
|
_ELF_DEFINE_EM(EM_ECOG2, 134, \
|
|
"Cyan Technology eCOG2 microprocessor") \
|
|
_ELF_DEFINE_EM(EM_SCORE7, 135, \
|
|
"Sunplus S+core7 RISC processor") \
|
|
_ELF_DEFINE_EM(EM_DSP24, 136, \
|
|
"New Japan Radio (NJR) 24-bit DSP Processor") \
|
|
_ELF_DEFINE_EM(EM_VIDEOCORE3, 137, \
|
|
"Broadcom VideoCore III processor") \
|
|
_ELF_DEFINE_EM(EM_LATTICEMICO32, 138, \
|
|
"RISC processor for Lattice FPGA architecture") \
|
|
_ELF_DEFINE_EM(EM_SE_C17, 139, "Seiko Epson C17 family") \
|
|
_ELF_DEFINE_EM(EM_TI_C6000, 140, \
|
|
"The Texas Instruments TMS320C6000 DSP family") \
|
|
_ELF_DEFINE_EM(EM_TI_C2000, 141, \
|
|
"The Texas Instruments TMS320C2000 DSP family") \
|
|
_ELF_DEFINE_EM(EM_TI_C5500, 142, \
|
|
"The Texas Instruments TMS320C55x DSP family") \
|
|
_ELF_DEFINE_EM(EM_MMDSP_PLUS, 160, \
|
|
"STMicroelectronics 64bit VLIW Data Signal Processor") \
|
|
_ELF_DEFINE_EM(EM_CYPRESS_M8C, 161, "Cypress M8C microprocessor") \
|
|
_ELF_DEFINE_EM(EM_R32C, 162, \
|
|
"Renesas R32C series microprocessors") \
|
|
_ELF_DEFINE_EM(EM_TRIMEDIA, 163, \
|
|
"NXP Semiconductors TriMedia architecture family") \
|
|
_ELF_DEFINE_EM(EM_QDSP6, 164, "QUALCOMM DSP6 Processor") \
|
|
_ELF_DEFINE_EM(EM_8051, 165, "Intel 8051 and variants") \
|
|
_ELF_DEFINE_EM(EM_STXP7X, 166, \
|
|
"STMicroelectronics STxP7x family of configurable and extensible RISC processors") \
|
|
_ELF_DEFINE_EM(EM_NDS32, 167, \
|
|
"Andes Technology compact code size embedded RISC processor family") \
|
|
_ELF_DEFINE_EM(EM_ECOG1, 168, \
|
|
"Cyan Technology eCOG1X family") \
|
|
_ELF_DEFINE_EM(EM_ECOG1X, 168, \
|
|
"Cyan Technology eCOG1X family") \
|
|
_ELF_DEFINE_EM(EM_MAXQ30, 169, \
|
|
"Dallas Semiconductor MAXQ30 Core Micro-controllers") \
|
|
_ELF_DEFINE_EM(EM_XIMO16, 170, \
|
|
"New Japan Radio (NJR) 16-bit DSP Processor") \
|
|
_ELF_DEFINE_EM(EM_MANIK, 171, \
|
|
"M2000 Reconfigurable RISC Microprocessor") \
|
|
_ELF_DEFINE_EM(EM_CRAYNV2, 172, \
|
|
"Cray Inc. NV2 vector architecture") \
|
|
_ELF_DEFINE_EM(EM_RX, 173, "Renesas RX family") \
|
|
_ELF_DEFINE_EM(EM_METAG, 174, \
|
|
"Imagination Technologies META processor architecture") \
|
|
_ELF_DEFINE_EM(EM_MCST_ELBRUS, 175, \
|
|
"MCST Elbrus general purpose hardware architecture") \
|
|
_ELF_DEFINE_EM(EM_ECOG16, 176, \
|
|
"Cyan Technology eCOG16 family") \
|
|
_ELF_DEFINE_EM(EM_CR16, 177, \
|
|
"National Semiconductor CompactRISC CR16 16-bit microprocessor") \
|
|
_ELF_DEFINE_EM(EM_ETPU, 178, \
|
|
"Freescale Extended Time Processing Unit") \
|
|
_ELF_DEFINE_EM(EM_SLE9X, 179, \
|
|
"Infineon Technologies SLE9X core") \
|
|
_ELF_DEFINE_EM(EM_AVR32, 185, \
|
|
"Atmel Corporation 32-bit microprocessor family") \
|
|
_ELF_DEFINE_EM(EM_STM8, 186, \
|
|
"STMicroeletronics STM8 8-bit microcontroller") \
|
|
_ELF_DEFINE_EM(EM_TILE64, 187, \
|
|
"Tilera TILE64 multicore architecture family") \
|
|
_ELF_DEFINE_EM(EM_TILEPRO, 188, \
|
|
"Tilera TILEPro multicore architecture family") \
|
|
_ELF_DEFINE_EM(EM_MICROBLAZE, 189, \
|
|
"Xilinx MicroBlaze 32-bit RISC soft processor core") \
|
|
_ELF_DEFINE_EM(EM_CUDA, 190, "NVIDIA CUDA architecture")
|
|
|
|
#undef _ELF_DEFINE_EM
|
|
#define _ELF_DEFINE_EM(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ELF_MACHINES()
|
|
EM__LAST__
|
|
};
|
|
|
|
/* Older synonyms. */
|
|
#define EM_ARC_A5 EM_ARC_COMPACT
|
|
|
|
/*
|
|
* ELF file types: (ET_*).
|
|
*/
|
|
#define _ELF_DEFINE_ELF_TYPES() \
|
|
_ELF_DEFINE_ET(ET_NONE, 0, "No file type") \
|
|
_ELF_DEFINE_ET(ET_REL, 1, "Relocatable object") \
|
|
_ELF_DEFINE_ET(ET_EXEC, 2, "Executable") \
|
|
_ELF_DEFINE_ET(ET_DYN, 3, "Shared object") \
|
|
_ELF_DEFINE_ET(ET_CORE, 4, "Core file") \
|
|
_ELF_DEFINE_ET(ET_LOOS, 0xFE00U, "Begin OS-specific range") \
|
|
_ELF_DEFINE_ET(ET_HIOS, 0xFEFFU, "End OS-specific range") \
|
|
_ELF_DEFINE_ET(ET_LOPROC, 0xFF00U, "Begin processor-specific range") \
|
|
_ELF_DEFINE_ET(ET_HIPROC, 0xFFFFU, "End processor-specific range")
|
|
|
|
#undef _ELF_DEFINE_ET
|
|
#define _ELF_DEFINE_ET(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ELF_TYPES()
|
|
ET__LAST__
|
|
};
|
|
|
|
/* ELF file format version numbers. */
|
|
#define EV_NONE 0
|
|
#define EV_CURRENT 1
|
|
|
|
/*
|
|
* Flags for section groups.
|
|
*/
|
|
#define GRP_COMDAT 0x1 /* COMDAT semantics */
|
|
#define GRP_MASKOS 0x0ff00000 /* OS-specific flags */
|
|
#define GRP_MASKPROC 0xf0000000 /* processor-specific flags */
|
|
|
|
/*
|
|
* Flags used by program header table entries.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_PHDR_FLAGS() \
|
|
_ELF_DEFINE_PF(PF_X, 0x1, "Execute") \
|
|
_ELF_DEFINE_PF(PF_W, 0x2, "Write") \
|
|
_ELF_DEFINE_PF(PF_R, 0x4, "Read") \
|
|
_ELF_DEFINE_PF(PF_MASKOS, 0x0ff00000, "OS-specific flags") \
|
|
_ELF_DEFINE_PF(PF_MASKPROC, 0xf0000000, "Processor-specific flags") \
|
|
_ELF_DEFINE_PF(PF_ARM_SB, 0x10000000, \
|
|
"segment contains the location addressed by the static base") \
|
|
_ELF_DEFINE_PF(PF_ARM_PI, 0x20000000, \
|
|
"segment is position-independent") \
|
|
_ELF_DEFINE_PF(PF_ARM_ABS, 0x40000000, \
|
|
"segment must be loaded at its base address")
|
|
|
|
#undef _ELF_DEFINE_PF
|
|
#define _ELF_DEFINE_PF(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_PHDR_FLAGS()
|
|
PF__LAST__
|
|
};
|
|
|
|
/*
|
|
* Types of program header table entries.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_PHDR_TYPES() \
|
|
_ELF_DEFINE_PT(PT_NULL, 0, "ignored entry") \
|
|
_ELF_DEFINE_PT(PT_LOAD, 1, "loadable segment") \
|
|
_ELF_DEFINE_PT(PT_DYNAMIC, 2, \
|
|
"contains dynamic linking information") \
|
|
_ELF_DEFINE_PT(PT_INTERP, 3, "names an interpreter") \
|
|
_ELF_DEFINE_PT(PT_NOTE, 4, "auxiliary information") \
|
|
_ELF_DEFINE_PT(PT_SHLIB, 5, "reserved") \
|
|
_ELF_DEFINE_PT(PT_PHDR, 6, \
|
|
"describes the program header itself") \
|
|
_ELF_DEFINE_PT(PT_TLS, 7, "thread local storage") \
|
|
_ELF_DEFINE_PT(PT_LOOS, 0x60000000UL, \
|
|
"start of OS-specific range") \
|
|
_ELF_DEFINE_PT(PT_GNU_EH_FRAME, 0x6474E550UL, \
|
|
"GCC generated .eh_frame_hdr segment ") \
|
|
_ELF_DEFINE_PT(PT_GNU_STACK, 0x6474E551UL, \
|
|
"Stack flags") \
|
|
_ELF_DEFINE_PT(PT_GNU_RELRO, 0x6474E552UL, \
|
|
"Segment becomes read-only after relocation") \
|
|
_ELF_DEFINE_PT(PT_HIOS, 0x6FFFFFFFUL, \
|
|
"end of OS-specific range") \
|
|
_ELF_DEFINE_PT(PT_LOPROC, 0x70000000UL, \
|
|
"start of processor-specific range") \
|
|
_ELF_DEFINE_PT(PT_ARM_ARCHEXT, 0x70000000UL, \
|
|
"platform architecture compatibility information") \
|
|
_ELF_DEFINE_PT(PT_ARM_EXIDX, 0x70000001UL, \
|
|
"exception unwind tables") \
|
|
_ELF_DEFINE_PT(PT_MIPS_REGINFO, 0x70000000UL, \
|
|
"register usage information") \
|
|
_ELF_DEFINE_PT(PT_MIPS_RTPROC, 0x70000001UL, \
|
|
"runtime procedure table") \
|
|
_ELF_DEFINE_PT(PT_MIPS_OPTIONS, 0x70000002UL, \
|
|
"options segment") \
|
|
_ELF_DEFINE_PT(PT_HIPROC, 0x7FFFFFFFUL, \
|
|
"end of processor-specific range")
|
|
|
|
#undef _ELF_DEFINE_PT
|
|
#define _ELF_DEFINE_PT(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_PHDR_TYPES()
|
|
PT__LAST__ = PT_HIPROC
|
|
};
|
|
|
|
/* synonyms. */
|
|
#define PT_ARM_UNWIND PT_ARM_EXIDX
|
|
|
|
/*
|
|
* Section flags.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_SECTION_FLAGS() \
|
|
_ELF_DEFINE_SHF(SHF_WRITE, 0x1, \
|
|
"writable during program execution") \
|
|
_ELF_DEFINE_SHF(SHF_ALLOC, 0x2, \
|
|
"occupies memory during program execution") \
|
|
_ELF_DEFINE_SHF(SHF_EXECINSTR, 0x4, "executable instructions") \
|
|
_ELF_DEFINE_SHF(SHF_MERGE, 0x10, \
|
|
"may be merged to prevent duplication") \
|
|
_ELF_DEFINE_SHF(SHF_STRINGS, 0x20, \
|
|
"NUL-terminated character strings") \
|
|
_ELF_DEFINE_SHF(SHF_INFO_LINK, 0x40, \
|
|
"the sh_info field holds a link") \
|
|
_ELF_DEFINE_SHF(SHF_LINK_ORDER, 0x80, \
|
|
"special ordering requirements during linking") \
|
|
_ELF_DEFINE_SHF(SHF_OS_NONCONFORMING, 0x100, \
|
|
"requires OS-specific processing during linking") \
|
|
_ELF_DEFINE_SHF(SHF_GROUP, 0x200, \
|
|
"member of a section group") \
|
|
_ELF_DEFINE_SHF(SHF_TLS, 0x400, \
|
|
"holds thread-local storage") \
|
|
_ELF_DEFINE_SHF(SHF_MASKOS, 0x0FF00000UL, \
|
|
"bits reserved for OS-specific semantics") \
|
|
_ELF_DEFINE_SHF(SHF_AMD64_LARGE, 0x10000000UL, \
|
|
"section uses large code model") \
|
|
_ELF_DEFINE_SHF(SHF_ENTRYSECT, 0x10000000UL, \
|
|
"section contains an entry point (ARM)") \
|
|
_ELF_DEFINE_SHF(SHF_COMDEF, 0x80000000UL, \
|
|
"section may be multiply defined in input to link step (ARM)") \
|
|
_ELF_DEFINE_SHF(SHF_MIPS_GPREL, 0x10000000UL, \
|
|
"section must be part of global data area") \
|
|
_ELF_DEFINE_SHF(SHF_MIPS_MERGE, 0x20000000UL, \
|
|
"section data should be merged to eliminate duplication") \
|
|
_ELF_DEFINE_SHF(SHF_MIPS_ADDR, 0x40000000UL, \
|
|
"section data is addressed by default") \
|
|
_ELF_DEFINE_SHF(SHF_MIPS_STRING, 0x80000000UL, \
|
|
"section data is string data by default") \
|
|
_ELF_DEFINE_SHF(SHF_MIPS_NOSTRIP, 0x08000000UL, \
|
|
"section data may not be stripped") \
|
|
_ELF_DEFINE_SHF(SHF_MIPS_LOCAL, 0x04000000UL, \
|
|
"section data local to process") \
|
|
_ELF_DEFINE_SHF(SHF_MIPS_NAMES, 0x02000000UL, \
|
|
"linker must generate implicit hidden weak names") \
|
|
_ELF_DEFINE_SHF(SHF_MIPS_NODUPE, 0x01000000UL, \
|
|
"linker must retain only one copy") \
|
|
_ELF_DEFINE_SHF(SHF_ORDERED, 0x40000000UL, \
|
|
"section is ordered with respect to other sections") \
|
|
_ELF_DEFINE_SHF(SHF_EXCLUDE, 0x80000000UL, \
|
|
"section is excluded from executables and shared objects") \
|
|
_ELF_DEFINE_SHF(SHF_MASKPROC, 0xF0000000UL, \
|
|
"bits reserved for processor-specific semantics")
|
|
|
|
#undef _ELF_DEFINE_SHF
|
|
#define _ELF_DEFINE_SHF(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_SECTION_FLAGS()
|
|
SHF__LAST__
|
|
};
|
|
|
|
/*
|
|
* Special section indices.
|
|
*/
|
|
#define _ELF_DEFINE_SECTION_INDICES() \
|
|
_ELF_DEFINE_SHN(SHN_UNDEF, 0, "undefined section") \
|
|
_ELF_DEFINE_SHN(SHN_LORESERVE, 0xFF00U, "start of reserved area") \
|
|
_ELF_DEFINE_SHN(SHN_LOPROC, 0xFF00U, \
|
|
"start of processor-specific range") \
|
|
_ELF_DEFINE_SHN(SHN_BEFORE, 0xFF00U, "used for section ordering") \
|
|
_ELF_DEFINE_SHN(SHN_AFTER, 0xFF01U, "used for section ordering") \
|
|
_ELF_DEFINE_SHN(SHN_AMD64_LCOMMON, 0xFF02U, "large common block label") \
|
|
_ELF_DEFINE_SHN(SHN_MIPS_ACOMMON, 0xFF00U, \
|
|
"allocated common symbols in a DSO") \
|
|
_ELF_DEFINE_SHN(SHN_MIPS_TEXT, 0xFF01U, "Reserved (obsolete)") \
|
|
_ELF_DEFINE_SHN(SHN_MIPS_DATA, 0xFF02U, "Reserved (obsolete)") \
|
|
_ELF_DEFINE_SHN(SHN_MIPS_SCOMMON, 0xFF03U, \
|
|
"gp-addressable common symbols") \
|
|
_ELF_DEFINE_SHN(SHN_MIPS_SUNDEFINED, 0xFF04U, \
|
|
"gp-addressable undefined symbols") \
|
|
_ELF_DEFINE_SHN(SHN_MIPS_LCOMMON, 0xFF05U, "local common symbols") \
|
|
_ELF_DEFINE_SHN(SHN_MIPS_LUNDEFINED, 0xFF06U, \
|
|
"local undefined symbols") \
|
|
_ELF_DEFINE_SHN(SHN_HIPROC, 0xFF1FU, \
|
|
"end of processor-specific range") \
|
|
_ELF_DEFINE_SHN(SHN_LOOS, 0xFF20U, \
|
|
"start of OS-specific range") \
|
|
_ELF_DEFINE_SHN(SHN_SUNW_IGNORE, 0xFF3FU, "used by dtrace") \
|
|
_ELF_DEFINE_SHN(SHN_HIOS, 0xFF3FU, \
|
|
"end of OS-specific range") \
|
|
_ELF_DEFINE_SHN(SHN_ABS, 0xFFF1U, "absolute references") \
|
|
_ELF_DEFINE_SHN(SHN_COMMON, 0xFFF2U, "references to COMMON areas") \
|
|
_ELF_DEFINE_SHN(SHN_XINDEX, 0xFFFFU, "extended index") \
|
|
_ELF_DEFINE_SHN(SHN_HIRESERVE, 0xFFFFU, "end of reserved area")
|
|
|
|
#undef _ELF_DEFINE_SHN
|
|
#define _ELF_DEFINE_SHN(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_SECTION_INDICES()
|
|
SHN__LAST__
|
|
};
|
|
|
|
/*
|
|
* Section types.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_SECTION_TYPES() \
|
|
_ELF_DEFINE_SHT(SHT_NULL, 0, "inactive header") \
|
|
_ELF_DEFINE_SHT(SHT_PROGBITS, 1, "program defined information") \
|
|
_ELF_DEFINE_SHT(SHT_SYMTAB, 2, "symbol table") \
|
|
_ELF_DEFINE_SHT(SHT_STRTAB, 3, "string table") \
|
|
_ELF_DEFINE_SHT(SHT_RELA, 4, \
|
|
"relocation entries with addends") \
|
|
_ELF_DEFINE_SHT(SHT_HASH, 5, "symbol hash table") \
|
|
_ELF_DEFINE_SHT(SHT_DYNAMIC, 6, \
|
|
"information for dynamic linking") \
|
|
_ELF_DEFINE_SHT(SHT_NOTE, 7, "additional notes") \
|
|
_ELF_DEFINE_SHT(SHT_NOBITS, 8, "section occupying no space") \
|
|
_ELF_DEFINE_SHT(SHT_REL, 9, \
|
|
"relocation entries without addends") \
|
|
_ELF_DEFINE_SHT(SHT_SHLIB, 10, "reserved") \
|
|
_ELF_DEFINE_SHT(SHT_DYNSYM, 11, "symbol table") \
|
|
_ELF_DEFINE_SHT(SHT_INIT_ARRAY, 14, \
|
|
"pointers to initialization functions") \
|
|
_ELF_DEFINE_SHT(SHT_FINI_ARRAY, 15, \
|
|
"pointers to termination functions") \
|
|
_ELF_DEFINE_SHT(SHT_PREINIT_ARRAY, 16, \
|
|
"pointers to functions called before initialization") \
|
|
_ELF_DEFINE_SHT(SHT_GROUP, 17, "defines a section group") \
|
|
_ELF_DEFINE_SHT(SHT_SYMTAB_SHNDX, 18, \
|
|
"used for extended section numbering") \
|
|
_ELF_DEFINE_SHT(SHT_LOOS, 0x60000000UL, \
|
|
"start of OS-specific range") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_dof, 0x6FFFFFF4UL, \
|
|
"used by dtrace") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_cap, 0x6FFFFFF5UL, \
|
|
"capability requirements") \
|
|
_ELF_DEFINE_SHT(SHT_GNU_ATTRIBUTES, 0x6FFFFFF5UL, \
|
|
"object attributes") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_SIGNATURE, 0x6FFFFFF6UL, \
|
|
"module verification signature") \
|
|
_ELF_DEFINE_SHT(SHT_GNU_HASH, 0x6FFFFFF6UL, \
|
|
"GNU Hash sections") \
|
|
_ELF_DEFINE_SHT(SHT_GNU_LIBLIST, 0x6FFFFFF7UL, \
|
|
"List of libraries to be prelinked") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_ANNOTATE, 0x6FFFFFF7UL, \
|
|
"special section where unresolved references are allowed") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_DEBUGSTR, 0x6FFFFFF8UL, \
|
|
"debugging information") \
|
|
_ELF_DEFINE_SHT(SHT_CHECKSUM, 0x6FFFFFF8UL, \
|
|
"checksum for dynamic shared objects") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_DEBUG, 0x6FFFFFF9UL, \
|
|
"debugging information") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_move, 0x6FFFFFFAUL, \
|
|
"information to handle partially initialized symbols") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_COMDAT, 0x6FFFFFFBUL, \
|
|
"section supporting merging of multiple copies of data") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_syminfo, 0x6FFFFFFCUL, \
|
|
"additional symbol information") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_verdef, 0x6FFFFFFDUL, \
|
|
"symbol versioning information") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_verneed, 0x6FFFFFFEUL, \
|
|
"symbol versioning requirements") \
|
|
_ELF_DEFINE_SHT(SHT_SUNW_versym, 0x6FFFFFFFUL, \
|
|
"symbol versioning table") \
|
|
_ELF_DEFINE_SHT(SHT_HIOS, 0x6FFFFFFFUL, \
|
|
"end of OS-specific range") \
|
|
_ELF_DEFINE_SHT(SHT_LOPROC, 0x70000000UL, \
|
|
"start of processor-specific range") \
|
|
_ELF_DEFINE_SHT(SHT_ARM_EXIDX, 0x70000001UL, \
|
|
"exception index table") \
|
|
_ELF_DEFINE_SHT(SHT_ARM_PREEMPTMAP, 0x70000002UL, \
|
|
"BPABI DLL dynamic linking preemption map") \
|
|
_ELF_DEFINE_SHT(SHT_ARM_ATTRIBUTES, 0x70000003UL, \
|
|
"object file compatibility attributes") \
|
|
_ELF_DEFINE_SHT(SHT_ARM_DEBUGOVERLAY, 0x70000004UL, \
|
|
"overlay debug information") \
|
|
_ELF_DEFINE_SHT(SHT_ARM_OVERLAYSECTION, 0x70000005UL, \
|
|
"overlay debug information") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_LIBLIST, 0x70000000UL, \
|
|
"DSO library information used in link") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_MSYM, 0x70000001UL, \
|
|
"MIPS symbol table extension") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_CONFLICT, 0x70000002UL, \
|
|
"symbol conflicting with DSO-defined symbols ") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_GPTAB, 0x70000003UL, \
|
|
"global pointer table") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_UCODE, 0x70000004UL, \
|
|
"reserved") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_DEBUG, 0x70000005UL, \
|
|
"reserved (obsolete debug information)") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_REGINFO, 0x70000006UL, \
|
|
"register usage information") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_PACKAGE, 0x70000007UL, \
|
|
"OSF reserved") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_PACKSYM, 0x70000008UL, \
|
|
"OSF reserved") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_RELD, 0x70000009UL, \
|
|
"dynamic relocation") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_IFACE, 0x7000000BUL, \
|
|
"subprogram interface information") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_CONTENT, 0x7000000CUL, \
|
|
"section content classification") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_OPTIONS, 0x7000000DUL, \
|
|
"general options") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_DELTASYM, 0x7000001BUL, \
|
|
"Delta C++: symbol table") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_DELTAINST, 0x7000001CUL, \
|
|
"Delta C++: instance table") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_DELTACLASS, 0x7000001DUL, \
|
|
"Delta C++: class table") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_DWARF, 0x7000001EUL, \
|
|
"DWARF debug information") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_DELTADECL, 0x7000001FUL, \
|
|
"Delta C++: declarations") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_SYMBOL_LIB, 0x70000020UL, \
|
|
"symbol-to-library mapping") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_EVENTS, 0x70000021UL, \
|
|
"event locations") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_TRANSLATE, 0x70000022UL, \
|
|
"???") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_PIXIE, 0x70000023UL, \
|
|
"special pixie sections") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_XLATE, 0x70000024UL, \
|
|
"address translation table") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_XLATE_DEBUG, 0x70000025UL, \
|
|
"SGI internal address translation table") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_WHIRL, 0x70000026UL, \
|
|
"intermediate code") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_EH_REGION, 0x70000027UL, \
|
|
"C++ exception handling region info") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_XLATE_OLD, 0x70000028UL, \
|
|
"obsolete") \
|
|
_ELF_DEFINE_SHT(SHT_MIPS_PDR_EXCEPTION, 0x70000029UL, \
|
|
"runtime procedure descriptor table exception information") \
|
|
_ELF_DEFINE_SHT(SHT_SPARC_GOTDATA, 0x70000000UL, \
|
|
"SPARC-specific data") \
|
|
_ELF_DEFINE_SHT(SHT_AMD64_UNWIND, 0x70000001UL, \
|
|
"unwind tables for the AMD64") \
|
|
_ELF_DEFINE_SHT(SHT_ORDERED, 0x7FFFFFFFUL, \
|
|
"sort entries in the section") \
|
|
_ELF_DEFINE_SHT(SHT_HIPROC, 0x7FFFFFFFUL, \
|
|
"end of processor-specific range") \
|
|
_ELF_DEFINE_SHT(SHT_LOUSER, 0x80000000UL, \
|
|
"start of application-specific range") \
|
|
_ELF_DEFINE_SHT(SHT_HIUSER, 0xFFFFFFFFUL, \
|
|
"end of application-specific range")
|
|
|
|
#undef _ELF_DEFINE_SHT
|
|
#define _ELF_DEFINE_SHT(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_SECTION_TYPES()
|
|
SHT__LAST__ = SHT_HIUSER
|
|
};
|
|
|
|
/* Aliases for section types. */
|
|
#define SHT_GNU_verdef SHT_SUNW_verdef
|
|
#define SHT_GNU_verneed SHT_SUNW_verneed
|
|
#define SHT_GNU_versym SHT_SUNW_versym
|
|
|
|
/*
|
|
* Symbol binding information.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_SYMBOL_BINDING() \
|
|
_ELF_DEFINE_STB(STB_LOCAL, 0, \
|
|
"not visible outside defining object file") \
|
|
_ELF_DEFINE_STB(STB_GLOBAL, 1, \
|
|
"visible across all object files being combined") \
|
|
_ELF_DEFINE_STB(STB_WEAK, 2, \
|
|
"visible across all object files but with low precedence") \
|
|
_ELF_DEFINE_STB(STB_LOOS, 10, "start of OS-specific range") \
|
|
_ELF_DEFINE_STB(STB_HIOS, 12, "end of OS-specific range") \
|
|
_ELF_DEFINE_STB(STB_LOPROC, 13, \
|
|
"start of processor-specific range") \
|
|
_ELF_DEFINE_STB(STB_HIPROC, 15, \
|
|
"end of processor-specific range")
|
|
|
|
#undef _ELF_DEFINE_STB
|
|
#define _ELF_DEFINE_STB(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_SYMBOL_BINDING()
|
|
STB__LAST__
|
|
};
|
|
|
|
/*
|
|
* Symbol types
|
|
*/
|
|
|
|
#define _ELF_DEFINE_SYMBOL_TYPES() \
|
|
_ELF_DEFINE_STT(STT_NOTYPE, 0, "unspecified type") \
|
|
_ELF_DEFINE_STT(STT_OBJECT, 1, "data object") \
|
|
_ELF_DEFINE_STT(STT_FUNC, 2, "executable code") \
|
|
_ELF_DEFINE_STT(STT_SECTION, 3, "section") \
|
|
_ELF_DEFINE_STT(STT_FILE, 4, "source file") \
|
|
_ELF_DEFINE_STT(STT_COMMON, 5, "uninitialized common block") \
|
|
_ELF_DEFINE_STT(STT_TLS, 6, "thread local storage") \
|
|
_ELF_DEFINE_STT(STT_LOOS, 10, "start of OS-specific types") \
|
|
_ELF_DEFINE_STT(STT_HIOS, 12, "end of OS-specific types") \
|
|
_ELF_DEFINE_STT(STT_LOPROC, 13, \
|
|
"start of processor-specific types") \
|
|
_ELF_DEFINE_STT(STT_ARM_TFUNC, 13, "Thumb function (GNU)") \
|
|
_ELF_DEFINE_STT(STT_ARM_16BIT, 15, "Thumb label (GNU)") \
|
|
_ELF_DEFINE_STT(STT_HIPROC, 15, \
|
|
"end of processor-specific types")
|
|
|
|
#undef _ELF_DEFINE_STT
|
|
#define _ELF_DEFINE_STT(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_SYMBOL_TYPES()
|
|
STT__LAST__
|
|
};
|
|
|
|
/*
|
|
* Symbol binding.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_SYMBOL_BINDING_KINDS() \
|
|
_ELF_DEFINE_SYB(SYMINFO_BT_SELF, 0xFFFFU, \
|
|
"bound to self") \
|
|
_ELF_DEFINE_SYB(SYMINFO_BT_PARENT, 0xFFFEU, \
|
|
"bound to parent") \
|
|
_ELF_DEFINE_SYB(SYMINFO_BT_NONE, 0xFFFDU, \
|
|
"no special binding")
|
|
|
|
#undef _ELF_DEFINE_SYB
|
|
#define _ELF_DEFINE_SYB(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_SYMBOL_BINDING_KINDS()
|
|
SYMINFO__LAST__
|
|
};
|
|
|
|
/*
|
|
* Symbol visibility.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_SYMBOL_VISIBILITY() \
|
|
_ELF_DEFINE_STV(STV_DEFAULT, 0, \
|
|
"as specified by symbol type") \
|
|
_ELF_DEFINE_STV(STV_INTERNAL, 1, \
|
|
"as defined by processor semantics") \
|
|
_ELF_DEFINE_STV(STV_HIDDEN, 2, \
|
|
"hidden from other components") \
|
|
_ELF_DEFINE_STV(STV_PROTECTED, 3, \
|
|
"local references are not preemptable")
|
|
|
|
#undef _ELF_DEFINE_STV
|
|
#define _ELF_DEFINE_STV(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_SYMBOL_VISIBILITY()
|
|
STV__LAST__
|
|
};
|
|
|
|
/*
|
|
* Symbol flags.
|
|
*/
|
|
#define _ELF_DEFINE_SYMBOL_FLAGS() \
|
|
_ELF_DEFINE_SYF(SYMINFO_FLG_DIRECT, 0x01, \
|
|
"directly assocated reference") \
|
|
_ELF_DEFINE_SYF(SYMINFO_FLG_COPY, 0x04, \
|
|
"definition by copy-relocation") \
|
|
_ELF_DEFINE_SYF(SYMINFO_FLG_LAZYLOAD, 0x08, \
|
|
"object should be lazily loaded") \
|
|
_ELF_DEFINE_SYF(SYMINFO_FLG_DIRECTBIND, 0x10, \
|
|
"reference should be directly bound") \
|
|
_ELF_DEFINE_SYF(SYMINFO_FLG_NOEXTDIRECT, 0x20, \
|
|
"external references not allowed to bind to definition")
|
|
|
|
#undef _ELF_DEFINE_SYF
|
|
#define _ELF_DEFINE_SYF(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_SYMBOL_FLAGS()
|
|
SYMINFO_FLG__LAST__
|
|
};
|
|
|
|
/*
|
|
* Version dependencies.
|
|
*/
|
|
#define _ELF_DEFINE_VERSIONING_DEPENDENCIES() \
|
|
_ELF_DEFINE_VERD(VER_NDX_LOCAL, 0, "local scope") \
|
|
_ELF_DEFINE_VERD(VER_NDX_GLOBAL, 1, "global scope")
|
|
#undef _ELF_DEFINE_VERD
|
|
#define _ELF_DEFINE_VERD(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_VERSIONING_DEPENDENCIES()
|
|
VER_NDX__LAST__
|
|
};
|
|
|
|
/*
|
|
* Version flags.
|
|
*/
|
|
#define _ELF_DEFINE_VERSIONING_FLAGS() \
|
|
_ELF_DEFINE_VERF(VER_FLG_BASE, 0x1, "file version") \
|
|
_ELF_DEFINE_VERF(VER_FLG_WEAK, 0x2, "weak version")
|
|
#undef _ELF_DEFINE_VERF
|
|
#define _ELF_DEFINE_VERF(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_VERSIONING_FLAGS()
|
|
VER_FLG__LAST__
|
|
};
|
|
|
|
/*
|
|
* Version needs
|
|
*/
|
|
#define _ELF_DEFINE_VERSIONING_NEEDS() \
|
|
_ELF_DEFINE_VRN(VER_NEED_NONE, 0, "invalid version") \
|
|
_ELF_DEFINE_VRN(VER_NEED_CURRENT, 1, "current version")
|
|
#undef _ELF_DEFINE_VRN
|
|
#define _ELF_DEFINE_VRN(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_VERSIONING_NEEDS()
|
|
VER_NEED__LAST__
|
|
};
|
|
|
|
/*
|
|
* Version numbers.
|
|
*/
|
|
#define _ELF_DEFINE_VERSIONING_NUMBERS() \
|
|
_ELF_DEFINE_VRNU(VER_DEF_NONE, 0, "invalid version") \
|
|
_ELF_DEFINE_VRNU(VER_DEF_CURRENT, 1, "current version")
|
|
#undef _ELF_DEFINE_VRNU
|
|
#define _ELF_DEFINE_VRNU(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_VERSIONING_NUMBERS()
|
|
VER_DEF__LAST__
|
|
};
|
|
|
|
/**
|
|
** Relocation types.
|
|
**/
|
|
|
|
#define _ELF_DEFINE_386_RELOCATIONS() \
|
|
_ELF_DEFINE_RELOC(R_386_NONE, 0) \
|
|
_ELF_DEFINE_RELOC(R_386_32, 1) \
|
|
_ELF_DEFINE_RELOC(R_386_PC32, 2) \
|
|
_ELF_DEFINE_RELOC(R_386_GOT32, 3) \
|
|
_ELF_DEFINE_RELOC(R_386_PLT32, 4) \
|
|
_ELF_DEFINE_RELOC(R_386_COPY, 5) \
|
|
_ELF_DEFINE_RELOC(R_386_GLOB_DAT, 6) \
|
|
_ELF_DEFINE_RELOC(R_386_JMP_SLOT, 7) \
|
|
_ELF_DEFINE_RELOC(R_386_RELATIVE, 8) \
|
|
_ELF_DEFINE_RELOC(R_386_GOTOFF, 9) \
|
|
_ELF_DEFINE_RELOC(R_386_GOTPC, 10) \
|
|
_ELF_DEFINE_RELOC(R_386_32PLT, 11) \
|
|
_ELF_DEFINE_RELOC(R_386_16, 20) \
|
|
_ELF_DEFINE_RELOC(R_386_PC16, 21) \
|
|
_ELF_DEFINE_RELOC(R_386_8, 22) \
|
|
_ELF_DEFINE_RELOC(R_386_PC8, 23)
|
|
|
|
/*
|
|
* These are the symbols used in the Sun ``Linkers and Loaders
|
|
* Guide'', Document No: 817-1984-17. See the X86_64 relocations list
|
|
* below for the spellings used in the ELF specification.
|
|
*/
|
|
#define _ELF_DEFINE_AMD64_RELOCATIONS() \
|
|
_ELF_DEFINE_RELOC(R_AMD64_NONE, 0) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_64, 1) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_PC32, 2) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_GOT32, 3) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_PLT32, 4) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_COPY, 5) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_GLOB_DAT, 6) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_JUMP_SLOT, 7) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_RELATIVE, 8) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_GOTPCREL, 9) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_32, 10) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_32S, 11) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_16, 12) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_PC16, 13) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_8, 14) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_PC8, 15) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_PC64, 24) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_GOTOFF64, 25) \
|
|
_ELF_DEFINE_RELOC(R_AMD64_GOTPC32, 26)
|
|
|
|
#define _ELF_DEFINE_ARM_RELOCATIONS() \
|
|
_ELF_DEFINE_RELOC(R_ARM_NONE, 0) \
|
|
_ELF_DEFINE_RELOC(R_ARM_PC24, 1) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ABS32, 2) \
|
|
_ELF_DEFINE_RELOC(R_ARM_REL32, 3) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDR_PC_G0, 4) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ABS16, 5) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ABS12, 6) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_ABS5, 7) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ABS8, 8) \
|
|
_ELF_DEFINE_RELOC(R_ARM_SBREL32, 9) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_CALL, 10) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_PC8, 11) \
|
|
_ELF_DEFINE_RELOC(R_ARM_BREL_ADJ, 12) \
|
|
_ELF_DEFINE_RELOC(R_ARM_SWI24, 13) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_SWI8, 14) \
|
|
_ELF_DEFINE_RELOC(R_ARM_XPC25, 15) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_XPC22, 16) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_DTPMOD32, 17) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_DTPOFF32, 18) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_TPOFF32, 19) \
|
|
_ELF_DEFINE_RELOC(R_ARM_COPY, 20) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GLOB_DAT, 21) \
|
|
_ELF_DEFINE_RELOC(R_ARM_JUMP_SLOT, 22) \
|
|
_ELF_DEFINE_RELOC(R_ARM_RELATIVE, 23) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GOTOFF32, 24) \
|
|
_ELF_DEFINE_RELOC(R_ARM_BASE_PREL, 25) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GOT_BREL, 26) \
|
|
_ELF_DEFINE_RELOC(R_ARM_PLT32, 27) \
|
|
_ELF_DEFINE_RELOC(R_ARM_CALL, 28) \
|
|
_ELF_DEFINE_RELOC(R_ARM_JUMP24, 29) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_JUMP24, 30) \
|
|
_ELF_DEFINE_RELOC(R_ARM_BASE_ABS, 31) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_PCREL7_0, 32) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_PCREL15_8, 33) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_PCREL23_15, 34) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDR_SBREL_11_0, 35) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_SBREL_19_12, 36) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_SBREL_27_20, 37) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TARGET1, 38) \
|
|
_ELF_DEFINE_RELOC(R_ARM_SBREL31, 39) \
|
|
_ELF_DEFINE_RELOC(R_ARM_V4BX, 40) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TARGET2, 41) \
|
|
_ELF_DEFINE_RELOC(R_ARM_PREL31, 42) \
|
|
_ELF_DEFINE_RELOC(R_ARM_MOVW_ABS_NC, 43) \
|
|
_ELF_DEFINE_RELOC(R_ARM_MOVT_ABS, 44) \
|
|
_ELF_DEFINE_RELOC(R_ARM_MOVW_PREL_NC, 45) \
|
|
_ELF_DEFINE_RELOC(R_ARM_MOVT_PREL, 46) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_MOVW_ABS_NC, 47) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_MOVT_ABS, 48) \
|
|
_ELF_DEFINE_RELOC(R_ARM_MOVW_PREL_NC, 49) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_MOVT_PREL, 50) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_JUMP19, 51) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_JUMP6, 52) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_ALU_PREL_11_0, 53) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_PC12, 54) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ABS32_NOI, 55) \
|
|
_ELF_DEFINE_RELOC(R_ARM_REL32_NOI, 56) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_PC_G0_NC, 57) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_PC_G0, 58) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_PC_G1_NC, 59) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_PC_G1, 60) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_PC_G2, 61) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDR_PC_G1, 62) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDR_PC_G2, 63) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDRS_PC_G0, 64) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDRS_PC_G1, 65) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDRS_PC_G2, 66) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDC_PC_G0, 67) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDC_PC_G1, 68) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDC_PC_G2, 69) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_SB_G0_NC, 70) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_SB_G0, 71) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_SB_G1_NC, 72) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_SB_G1, 73) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ALU_SB_G2, 74) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDR_SB_G0, 75) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDR_SB_G1, 76) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDR_SB_G2, 77) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDRS_SB_G0, 78) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDRS_SB_G1, 79) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDRS_SB_G2, 80) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDC_SB_G0, 81) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDC_SB_G1, 82) \
|
|
_ELF_DEFINE_RELOC(R_ARM_LDC_SB_G2, 83) \
|
|
_ELF_DEFINE_RELOC(R_ARM_MOVW_BREL_NC, 84) \
|
|
_ELF_DEFINE_RELOC(R_ARM_MOVT_BREL, 85) \
|
|
_ELF_DEFINE_RELOC(R_ARM_MOVW_BREL, 86) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_MOVW_BREL_NC, 87) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_MOVT_BREL, 88) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_MOVW_BREL, 89) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_GOTDESC, 90) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_CALL, 91) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_DESCSEQ, 92) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_TLS_CALL, 93) \
|
|
_ELF_DEFINE_RELOC(R_ARM_PLT32_ABS, 94) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GOT_ABS, 95) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GOT_PREL, 96) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GOT_BREL12, 97) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GOTOFF12, 98) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GOTRELAX, 99) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GNU_VTENTRY, 100) \
|
|
_ELF_DEFINE_RELOC(R_ARM_GNU_VTINHERIT, 101) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_JUMP11, 102) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_JUMP8, 103) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_GD32, 104) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_LDM32, 105) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_LDO32, 106) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_IE32, 107) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_LE32, 108) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_LDO12, 109) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_LE12, 110) \
|
|
_ELF_DEFINE_RELOC(R_ARM_TLS_IE12GP, 111) \
|
|
_ELF_DEFINE_RELOC(R_ARM_ME_TOO, 128) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_TLS_DESCSEQ16, 129) \
|
|
_ELF_DEFINE_RELOC(R_ARM_THM_TLS_DESCSEQ32, 130)
|
|
|
|
#define _ELF_DEFINE_IA64_RELOCATIONS() \
|
|
_ELF_DEFINE_RELOC(R_IA_64_NONE, 0) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_IMM14, 0x21) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_IMM22, 0x22) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_IMM64, 0x23) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DIR32MSB, 0x24) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DIR32LSB, 0x25) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DIR64MSB, 0x26) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DIR64LSB, 0x27) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_GPREL22, 0x2a) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_GPREL64I, 0x2b) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_GPREL32MSB, 0x2c) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_GPREL32LSB, 0x2d) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_GPREL64MSB, 0x2e) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_GPREL64LSB, 0x2f) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF22, 0x32) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF64I, 0x33) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PLTOFF22, 0x3a) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PLTOFF64I, 0x3b) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PLTOFF64MSB, 0x3e) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PLTOFF64LSB, 0x3f) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_FPTR64I, 0x43) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_FPTR32MSB, 0x44) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_FPTR32LSB, 0x45) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_FPTR64MSB, 0x46) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_FPTR64LSB, 0x47) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL60B, 0x48) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL21B, 0x49) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL21M, 0x4a) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL21F, 0x4b) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL32MSB, 0x4c) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL32LSB, 0x4d) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL64MSB, 0x4e) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL64LSB, 0x4f) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF_FPTR22, 0x52) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF_FPTR64I, 0x53) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF_FPTR32MSB, 0x54) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF_FPTR32LSB, 0x55) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF_FPTR64MSB, 0x56) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF_FPTR64LSB, 0x57) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_SEGREL32MSB, 0x5c) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_SEGREL32LSB, 0x5d) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_SEGREL64MSB, 0x5e) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_SEGREL64LSB, 0x5f) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_SECREL32MSB, 0x64) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_SECREL32LSB, 0x65) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_SECREL64MSB, 0x66) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_SECREL64LSB, 0x67) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_REL32MSB, 0x6c) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_REL32LSB, 0x6d) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_REL64MSB, 0x6e) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_REL64LSB, 0x6f) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTV32MSB, 0x74) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTV32LSB, 0x75) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTV64MSB, 0x76) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTV64LSB, 0x77) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL21BIa, 0x79) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL22, 0x7A) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_PCREL64I, 0x7B) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_IPLTMSB, 0x80) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_IPLTLSB, 0x81) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_SUB, 0x85) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF22X, 0x86) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LDXMOV, 0x87) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_TPREL14, 0x91) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_TPREL22, 0x92) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_TPREL64I, 0x93) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_TPREL64MSB, 0x96) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_TPREL64LSB, 0x97) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF_TPREL22, 0x9A) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DTPMOD64MSB, 0xA6) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DTPMOD64LSB, 0xA7) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF_DTPMOD22, 0xAA) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DTPREL14, 0xB1) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DTPREL22, 0xB2) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DTPREL64I, 0xB3) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DTPREL32MSB, 0xB4) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DTPREL32LSB, 0xB5) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DTPREL64MSB, 0xB6) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_DTPREL64LSB, 0xB7) \
|
|
_ELF_DEFINE_RELOC(R_IA_64_LTOFF_DTPREL22, 0xBA)
|
|
|
|
#define _ELF_DEFINE_MIPS_RELOCATIONS() \
|
|
_ELF_DEFINE_RELOC(R_MIPS_NONE, 0) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_16, 1) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_32, 2) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_REL32, 3) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_26, 4) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_HI16, 5) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_LO16, 6) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_GPREL16, 7) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_LITERAL, 8) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_GOT16, 9) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_PC16, 10) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_CALL16, 11) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_GPREL32, 12) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_GOTHI16, 21) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_GOTLO16, 22) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_CALLHI16, 30) \
|
|
_ELF_DEFINE_RELOC(R_MIPS_CALLLO16, 31)
|
|
|
|
#define _ELF_DEFINE_PPC32_RELOCATIONS() \
|
|
_ELF_DEFINE_RELOC(R_PPC_NONE, 0) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR32, 1) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR24, 2) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR16, 3) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR16_LO, 4) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR16_HI, 5) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR16_HA, 6) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR14, 7) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR14_BRTAKEN, 8) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR14_BRNTAKEN, 9) \
|
|
_ELF_DEFINE_RELOC(R_PPC_REL24, 10) \
|
|
_ELF_DEFINE_RELOC(R_PPC_REL14, 11) \
|
|
_ELF_DEFINE_RELOC(R_PPC_REL14_BRTAKEN, 12) \
|
|
_ELF_DEFINE_RELOC(R_PPC_REL14_BRNTAKEN, 13) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT16, 14) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT16_LO, 15) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT16_HI, 16) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT16_HA, 17) \
|
|
_ELF_DEFINE_RELOC(R_PPC_PLTREL24, 18) \
|
|
_ELF_DEFINE_RELOC(R_PPC_COPY, 19) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GLOB_DAT, 20) \
|
|
_ELF_DEFINE_RELOC(R_PPC_JMP_SLOT, 21) \
|
|
_ELF_DEFINE_RELOC(R_PPC_RELATIVE, 22) \
|
|
_ELF_DEFINE_RELOC(R_PPC_LOCAL24PC, 23) \
|
|
_ELF_DEFINE_RELOC(R_PPC_UADDR32, 24) \
|
|
_ELF_DEFINE_RELOC(R_PPC_UADDR16, 25) \
|
|
_ELF_DEFINE_RELOC(R_PPC_REL32, 26) \
|
|
_ELF_DEFINE_RELOC(R_PPC_PLT32, 27) \
|
|
_ELF_DEFINE_RELOC(R_PPC_PLTREL32, 28) \
|
|
_ELF_DEFINE_RELOC(R_PPC_PLT16_LO, 29) \
|
|
_ELF_DEFINE_RELOC(R_PPL_PLT16_HI, 30) \
|
|
_ELF_DEFINE_RELOC(R_PPC_PLT16_HA, 31) \
|
|
_ELF_DEFINE_RELOC(R_PPC_SDAREL16, 32) \
|
|
_ELF_DEFINE_RELOC(R_PPC_SECTOFF, 33) \
|
|
_ELF_DEFINE_RELOC(R_PPC_SECTOFF_LO, 34) \
|
|
_ELF_DEFINE_RELOC(R_PPC_SECTOFF_HI, 35) \
|
|
_ELF_DEFINE_RELOC(R_PPC_SECTOFF_HA, 36) \
|
|
_ELF_DEFINE_RELOC(R_PPC_ADDR30, 37) \
|
|
_ELF_DEFINE_RELOC(R_PPC_TLS, 67) \
|
|
_ELF_DEFINE_RELOC(R_PPC_DTPMOD32, 68) \
|
|
_ELF_DEFINE_RELOC(R_PPC_TPREL16, 69) \
|
|
_ELF_DEFINE_RELOC(R_PPC_TPREL16_LO, 70) \
|
|
_ELF_DEFINE_RELOC(R_PPC_TPREL16_HI, 71) \
|
|
_ELF_DEFINE_RELOC(R_PPC_TPREL16_HA, 72) \
|
|
_ELF_DEFINE_RELOC(R_PPC_TPREL32, 73) \
|
|
_ELF_DEFINE_RELOC(R_PPC_DTPREL16, 74) \
|
|
_ELF_DEFINE_RELOC(R_PPC_DTPREL16_LO, 75) \
|
|
_ELF_DEFINE_RELOC(R_PPC_DTPREL16_HI, 76) \
|
|
_ELF_DEFINE_RELOC(R_PPC_DTPREL16_HA, 77) \
|
|
_ELF_DEFINE_RELOC(R_PPC_DTPREL32, 78) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TLSGD16, 79) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TLSGD16_LO, 80) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TLSGD16_HI, 81) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TLSGD16_HA, 82) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TLSLD16, 83) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TLSLD16_LO, 84) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TLSLD16_HI, 85) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TLSLD16_HA, 86) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TPREL16, 87) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TPREL16_LO, 88) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TPREL16_HI, 89) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_TPREL16_HA, 90) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_DTPREL16, 91) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_DTPREL16_LO, 92) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_DTPREL16_HI, 93) \
|
|
_ELF_DEFINE_RELOC(R_PPC_GOT_DTPREL16_HA, 94) \
|
|
_ELF_DEFINE_RELOC(R_PPC_TLSGD, 95) \
|
|
_ELF_DEFINE_RELOC(R_PPC_TLSLD, 96) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_NADDR32, 101) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_NADDR16, 102) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_NADDR16_LO, 103) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_NADDR16_HI, 104) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_NADDR16_HA, 105) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_SDAI16, 106) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_SDA2I16, 107) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_SDA2REL, 108) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_SDA21, 109) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_MRKREF, 110) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_RELSEC16, 111) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_RELST_LO, 112) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_RELST_HI, 113) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_RELST_HA, 114) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_BIT_FLD, 115) \
|
|
_ELF_DEFINE_RELOC(R_PPC_EMB_RELSDA, 116) \
|
|
|
|
#define _ELF_DEFINE_PPC64_RELOCATIONS() \
|
|
_ELF_DEFINE_RELOC(R_PPC64_NONE, 0) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR32, 1) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR24, 2) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16, 3) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16_LO, 4) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16_HI, 5) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16_HA, 6) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR14, 7) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR14_BRTAKEN, 8) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR14_BRNTAKEN, 9) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_REL24, 10) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_REL14, 11) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_REL14_BRTAKEN, 12) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_REL14_BRNTAKEN, 13) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT16, 14) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT16_LO, 15) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT16_HI, 16) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT16_HA, 17) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_COPY, 19) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GLOB_DAT, 20) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_JMP_SLOT, 21) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_RELATIVE, 22) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_UADDR32, 24) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_UADDR16, 25) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_REL32, 26) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLT32, 27) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLTREL32, 28) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLT16_LO, 29) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLT16_HI, 30) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLT16_HA, 31) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_SECTOFF, 33) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_SECTOFF_LO, 34) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_SECTOFF_HI, 35) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_SECTOFF_HA, 36) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR30, 37) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR64, 38) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16_HIGHER, 39) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16_HIGHERA, 40) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16_HIGHEST, 41) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16_HIGHESTA, 42) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_UADDR64, 43) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_REL64, 44) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLT64, 45) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLTREL64, 46) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TOC16, 47) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TOC16_LO, 48) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TOC16_HI, 49) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TOC16_HA, 50) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TOC, 51) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLTGOT16, 52) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLTGOT16_LO, 53) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLTGOT16_HI, 54) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLTGOT16_HA, 55) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16_DS, 56) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_ADDR16_LO_DS, 57) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT16_DS, 58) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT16_LO_DS, 59) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLT16_LO_DS, 60) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_SECTOFF_DS, 61) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_SECTOFF_LO_DS, 62) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TOC16_DS, 63) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TOC16_LO_DS, 64) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLTGOT16_DS, 65) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_PLTGOT16_LO_DS, 66) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TLS, 67) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPMOD64, 68) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16, 69) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16_LO, 60) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16_HI, 71) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16_HA, 72) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL64, 73) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16, 74) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16_LO, 75) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16_HI, 76) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16_HA, 77) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL64, 78) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TLSGD16, 79) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TLSGD16_LO, 80) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TLSGD16_HI, 81) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TLSGD16_HA, 82) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TLSLD16, 83) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TLSLD16_LO, 84) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TLSLD16_HI, 85) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TLSLD16_HA, 86) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TPREL16_DS, 87) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TPREL16_LO_DS, 88) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TPREL16_HI, 89) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_TPREL16_HA, 90) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_DTPREL16_DS, 91) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_DTPREL16_LO_DS, 92) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_DTPREL16_HI, 93) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_GOT_DTPREL16_HA, 94) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16_DS, 95) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16_LO_DS, 96) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16_HIGHER, 97) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16_HIGHERA, 98) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16_HIGHEST, 99) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TPREL16_HIGHESTA, 100) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16_DS, 101) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16_LO_DS, 102) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16_HIGHER, 103) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16_HIGHERA, 104) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16_HIGHEST, 105) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_DTPREL16_HIGHESTA, 106) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TLSGD, 107) \
|
|
_ELF_DEFINE_RELOC(R_PPC64_TLSLD, 108)
|
|
|
|
#define _ELF_DEFINE_SPARC_RELOCATIONS() \
|
|
_ELF_DEFINE_RELOC(R_SPARC_NONE, 0) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_8, 1) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_16, 2) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_32, 3) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_DISP8, 4) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_DISP16, 5) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_DISP32, 6) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_WDISP30, 7) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_WDISP22, 8) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_HI22, 9) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_22, 10) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_13, 11) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_LO10, 12) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_GOT10, 13) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_GOT13, 14) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_GOT22, 15) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PC10, 16) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PC22, 17) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_WPLT30, 18) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_COPY, 19) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_GLOB_DAT, 20) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_JMP_SLOT, 21) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_RELATIVE, 22) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_UA32, 23) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PLT32, 24) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_HIPLT22, 25) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_LOPLT10, 26) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PCPLT32, 27) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PCPLT22, 28) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PCPLT10, 29) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_10, 30) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_11, 31) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_64, 32) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_OLO10, 33) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_HH22, 34) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_HM10, 35) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_LM22, 36) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PC_HH22, 37) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PC_HM10, 38) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PC_LM22, 39) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_WDISP16, 40) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_WDISP19, 41) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_7, 43) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_5, 44) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_6, 45) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_DISP64, 46) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_PLT64, 47) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_HIX22, 48) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_LOX10, 49) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_H44, 50) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_M44, 51) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_L44, 52) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_REGISTER, 53) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_UA64, 54) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_UA16, 55) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_GOTDATA_HIX22, 80) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_GOTDATA_LOX10, 81) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_GOTDATA_OP_HIX22, 82) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_GOTDATA_OP_LOX10, 83) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_GOTDATA_OP, 84) \
|
|
_ELF_DEFINE_RELOC(R_SPARC_H34, 85)
|
|
|
|
#define _ELF_DEFINE_X86_64_RELOCATIONS() \
|
|
_ELF_DEFINE_RELOC(R_X86_64_NONE, 0) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_64, 1) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_PC32, 2) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_GOT32, 3) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_PLT32, 4) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_COPY, 5) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_GLOB_DAT, 6) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_JUMP_SLOT, 7) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_RELATIVE, 8) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_GOTPCREL, 9) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_32, 10) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_32S, 11) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_16, 12) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_PC16, 13) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_8, 14) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_PC8, 15) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_DTPMOD64, 16) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_DTPOFF64, 17) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_TPOFF64, 18) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_TLSGD, 19) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_TLSLD, 20) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_DTPOFF32, 21) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_GOTTPOFF, 22) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_TPOFF32, 23) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_PC64, 24) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_GOTOFF64, 25) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_GOTPC32, 26) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_SIZE32, 32) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_SIZE64, 33) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_GOTPC32_TLSDESC, 34) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_TLSDESC_CALL, 35) \
|
|
_ELF_DEFINE_RELOC(R_X86_64_TLSDESC, 36)
|
|
|
|
#define _ELF_DEFINE_RELOCATIONS() \
|
|
_ELF_DEFINE_386_RELOCATIONS() \
|
|
_ELF_DEFINE_AMD64_RELOCATIONS() \
|
|
_ELF_DEFINE_IA64_RELOCATIONS() \
|
|
_ELF_DEFINE_MIPS_RELOCATIONS() \
|
|
_ELF_DEFINE_PPC32_RELOCATIONS() \
|
|
_ELF_DEFINE_PPC64_RELOCATIONS() \
|
|
_ELF_DEFINE_SPARC_RELOCATIONS() \
|
|
_ELF_DEFINE_X86_64_RELOCATIONS()
|
|
|
|
#undef _ELF_DEFINE_RELOC
|
|
#define _ELF_DEFINE_RELOC(N, V) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_RELOCATIONS()
|
|
R__LAST__
|
|
};
|
|
|
|
#define PN_XNUM 0xFFFFU /* Use extended section numbering. */
|
|
|
|
/**
|
|
** ELF Types.
|
|
**/
|
|
|
|
typedef uint32_t Elf32_Addr; /* Program address. */
|
|
typedef uint8_t Elf32_Byte; /* Unsigned tiny integer. */
|
|
typedef uint16_t Elf32_Half; /* Unsigned medium integer. */
|
|
typedef uint32_t Elf32_Off; /* File offset. */
|
|
typedef uint16_t Elf32_Section; /* Section index. */
|
|
typedef int32_t Elf32_Sword; /* Signed integer. */
|
|
typedef uint32_t Elf32_Word; /* Unsigned integer. */
|
|
typedef uint64_t Elf32_Lword; /* Unsigned long integer. */
|
|
|
|
typedef uint64_t Elf64_Addr; /* Program address. */
|
|
typedef uint8_t Elf64_Byte; /* Unsigned tiny integer. */
|
|
typedef uint16_t Elf64_Half; /* Unsigned medium integer. */
|
|
typedef uint64_t Elf64_Off; /* File offset. */
|
|
typedef uint16_t Elf64_Section; /* Section index. */
|
|
typedef int32_t Elf64_Sword; /* Signed integer. */
|
|
typedef uint32_t Elf64_Word; /* Unsigned integer. */
|
|
typedef uint64_t Elf64_Lword; /* Unsigned long integer. */
|
|
typedef uint64_t Elf64_Xword; /* Unsigned long integer. */
|
|
typedef int64_t Elf64_Sxword; /* Signed long integer. */
|
|
|
|
|
|
/*
|
|
* Capability descriptors.
|
|
*/
|
|
|
|
/* 32-bit capability descriptor. */
|
|
typedef struct {
|
|
Elf32_Word c_tag; /* Type of entry. */
|
|
union {
|
|
Elf32_Word c_val; /* Integer value. */
|
|
Elf32_Addr c_ptr; /* Pointer value. */
|
|
} c_un;
|
|
} Elf32_Cap;
|
|
|
|
/* 64-bit capability descriptor. */
|
|
typedef struct {
|
|
Elf64_Xword c_tag; /* Type of entry. */
|
|
union {
|
|
Elf64_Xword c_val; /* Integer value. */
|
|
Elf64_Addr c_ptr; /* Pointer value. */
|
|
} c_un;
|
|
} Elf64_Cap;
|
|
|
|
/*
|
|
* MIPS .conflict section entries.
|
|
*/
|
|
|
|
/* 32-bit entry. */
|
|
typedef struct {
|
|
Elf32_Addr c_index;
|
|
} Elf32_Conflict;
|
|
|
|
/* 64-bit entry. */
|
|
typedef struct {
|
|
Elf64_Addr c_index;
|
|
} Elf64_Conflict;
|
|
|
|
/*
|
|
* Dynamic section entries.
|
|
*/
|
|
|
|
/* 32-bit entry. */
|
|
typedef struct {
|
|
Elf32_Sword d_tag; /* Type of entry. */
|
|
union {
|
|
Elf32_Word d_val; /* Integer value. */
|
|
Elf32_Addr d_ptr; /* Pointer value. */
|
|
} d_un;
|
|
} Elf32_Dyn;
|
|
|
|
/* 64-bit entry. */
|
|
typedef struct {
|
|
Elf64_Sxword d_tag; /* Type of entry. */
|
|
union {
|
|
Elf64_Xword d_val; /* Integer value. */
|
|
Elf64_Addr d_ptr; /* Pointer value; */
|
|
} d_un;
|
|
} Elf64_Dyn;
|
|
|
|
|
|
/*
|
|
* The executable header (EHDR).
|
|
*/
|
|
|
|
/* 32 bit EHDR. */
|
|
typedef struct {
|
|
unsigned char e_ident[EI_NIDENT]; /* ELF identification. */
|
|
Elf32_Half e_type; /* Object file type (ET_*). */
|
|
Elf32_Half e_machine; /* Machine type (EM_*). */
|
|
Elf32_Word e_version; /* File format version (EV_*). */
|
|
Elf32_Addr e_entry; /* Start address. */
|
|
Elf32_Off e_phoff; /* File offset to the PHDR table. */
|
|
Elf32_Off e_shoff; /* File offset to the SHDRheader. */
|
|
Elf32_Word e_flags; /* Flags (EF_*). */
|
|
Elf32_Half e_ehsize; /* Elf header size in bytes. */
|
|
Elf32_Half e_phentsize; /* PHDR table entry size in bytes. */
|
|
Elf32_Half e_phnum; /* Number of PHDR entries. */
|
|
Elf32_Half e_shentsize; /* SHDR table entry size in bytes. */
|
|
Elf32_Half e_shnum; /* Number of SHDR entries. */
|
|
Elf32_Half e_shstrndx; /* Index of section name string table. */
|
|
} Elf32_Ehdr;
|
|
|
|
|
|
/* 64 bit EHDR. */
|
|
typedef struct {
|
|
unsigned char e_ident[EI_NIDENT]; /* ELF identification. */
|
|
Elf64_Half e_type; /* Object file type (ET_*). */
|
|
Elf64_Half e_machine; /* Machine type (EM_*). */
|
|
Elf64_Word e_version; /* File format version (EV_*). */
|
|
Elf64_Addr e_entry; /* Start address. */
|
|
Elf64_Off e_phoff; /* File offset to the PHDR table. */
|
|
Elf64_Off e_shoff; /* File offset to the SHDRheader. */
|
|
Elf64_Word e_flags; /* Flags (EF_*). */
|
|
Elf64_Half e_ehsize; /* Elf header size in bytes. */
|
|
Elf64_Half e_phentsize; /* PHDR table entry size in bytes. */
|
|
Elf64_Half e_phnum; /* Number of PHDR entries. */
|
|
Elf64_Half e_shentsize; /* SHDR table entry size in bytes. */
|
|
Elf64_Half e_shnum; /* Number of SHDR entries. */
|
|
Elf64_Half e_shstrndx; /* Index of section name string table. */
|
|
} Elf64_Ehdr;
|
|
|
|
|
|
/*
|
|
* Shared object information.
|
|
*/
|
|
|
|
/* 32-bit entry. */
|
|
typedef struct {
|
|
Elf32_Word l_name; /* The name of a shared object. */
|
|
Elf32_Word l_time_stamp; /* 32-bit timestamp. */
|
|
Elf32_Word l_checksum; /* Checksum of visible symbols, sizes. */
|
|
Elf32_Word l_version; /* Interface version string index. */
|
|
Elf32_Word l_flags; /* Flags (LL_*). */
|
|
} Elf32_Lib;
|
|
|
|
/* 64-bit entry. */
|
|
typedef struct {
|
|
Elf64_Word l_name;
|
|
Elf64_Word l_time_stamp;
|
|
Elf64_Word l_checksum;
|
|
Elf64_Word l_version;
|
|
Elf64_Word l_flags;
|
|
} Elf64_Lib;
|
|
|
|
#define _ELF_DEFINE_LL_FLAGS() \
|
|
_ELF_DEFINE_LL(LL_NONE, 0, \
|
|
"no flags") \
|
|
_ELF_DEFINE_LL(LL_EXACT_MATCH, 0x1, \
|
|
"require an exact match") \
|
|
_ELF_DEFINE_LL(LL_IGNORE_INT_VER, 0x2, \
|
|
"ignore version incompatibilities") \
|
|
_ELF_DEFINE_LL(LL_REQUIRE_MINOR, 0x4, \
|
|
"") \
|
|
_ELF_DEFINE_LL(LL_EXPORTS, 0x8, \
|
|
"") \
|
|
_ELF_DEFINE_LL(LL_DELAY_LOAD, 0x10, \
|
|
"") \
|
|
_ELF_DEFINE_LL(LL_DELTA, 0x20, \
|
|
"")
|
|
|
|
#undef _ELF_DEFINE_LL
|
|
#define _ELF_DEFINE_LL(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_LL_FLAGS()
|
|
LL__LAST__
|
|
};
|
|
|
|
/*
|
|
* Note tags
|
|
*/
|
|
|
|
#define _ELF_DEFINE_NOTE_ENTRY_TYPES() \
|
|
_ELF_DEFINE_NT(NT_ABI_TAG, 1, "Tag indicating the ABI") \
|
|
_ELF_DEFINE_NT(NT_GNU_HWCAP, 2, "Hardware capabilities") \
|
|
_ELF_DEFINE_NT(NT_GNU_BUILD_ID, 3, "Build id, set by ld(1)") \
|
|
_ELF_DEFINE_NT(NT_GNU_GOLD_VERSION, 4, \
|
|
"Version number of the GNU gold linker") \
|
|
_ELF_DEFINE_NT(NT_PRSTATUS, 1, "Process status") \
|
|
_ELF_DEFINE_NT(NT_FPREGSET, 2, "Floating point information") \
|
|
_ELF_DEFINE_NT(NT_PRPSINFO, 3, "Process information") \
|
|
_ELF_DEFINE_NT(NT_AUXV, 6, "Auxiliary vector") \
|
|
_ELF_DEFINE_NT(NT_PRXFPREG, 0x46E62B7FUL, \
|
|
"Linux user_xfpregs structure") \
|
|
_ELF_DEFINE_NT(NT_PSTATUS, 10, "Linux process status") \
|
|
_ELF_DEFINE_NT(NT_FPREGS, 12, "Linux floating point regset") \
|
|
_ELF_DEFINE_NT(NT_PSINFO, 13, "Linux process information") \
|
|
_ELF_DEFINE_NT(NT_LWPSTATUS, 16, "Linux lwpstatus_t type") \
|
|
_ELF_DEFINE_NT(NT_LWPSINFO, 17, "Linux lwpinfo_t type")
|
|
|
|
#undef _ELF_DEFINE_NT
|
|
#define _ELF_DEFINE_NT(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_NOTE_ENTRY_TYPES()
|
|
NT__LAST__
|
|
};
|
|
|
|
/* Aliases for the ABI tag. */
|
|
#define NT_FREEBSD_ABI_TAG NT_ABI_TAG
|
|
#define NT_GNU_ABI_TAG NT_ABI_TAG
|
|
#define NT_NETBSD_IDENT NT_ABI_TAG
|
|
#define NT_OPENBSD_IDENT NT_ABI_TAG
|
|
|
|
/*
|
|
* Note descriptors.
|
|
*/
|
|
|
|
typedef struct {
|
|
uint32_t n_namesz; /* Length of note's name. */
|
|
uint32_t n_descsz; /* Length of note's value. */
|
|
uint32_t n_type; /* Type of note. */
|
|
} Elf_Note;
|
|
|
|
typedef Elf_Note Elf32_Nhdr; /* 32-bit note header. */
|
|
typedef Elf_Note Elf64_Nhdr; /* 64-bit note header. */
|
|
|
|
/*
|
|
* MIPS ELF options descriptor header.
|
|
*/
|
|
|
|
typedef struct {
|
|
Elf64_Byte kind; /* Type of options. */
|
|
Elf64_Byte size; /* Size of option descriptor. */
|
|
Elf64_Half section; /* Index of section affected. */
|
|
Elf64_Word info; /* Kind-specific information. */
|
|
} Elf_Options;
|
|
|
|
/*
|
|
* Option kinds.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_OPTION_KINDS() \
|
|
_ELF_DEFINE_ODK(ODK_NULL, 0, "undefined") \
|
|
_ELF_DEFINE_ODK(ODK_REGINFO, 1, "register usage info") \
|
|
_ELF_DEFINE_ODK(ODK_EXCEPTIONS, 2, "exception processing info") \
|
|
_ELF_DEFINE_ODK(ODK_PAD, 3, "section padding") \
|
|
_ELF_DEFINE_ODK(ODK_HWPATCH, 4, "hardware patch applied") \
|
|
_ELF_DEFINE_ODK(ODK_FILL, 5, "fill value used by linker") \
|
|
_ELF_DEFINE_ODK(ODK_TAGS, 6, "reserved space for tools") \
|
|
_ELF_DEFINE_ODK(ODK_HWAND, 7, "hardware AND patch applied") \
|
|
_ELF_DEFINE_ODK(ODK_HWOR, 8, "hardware OR patch applied") \
|
|
_ELF_DEFINE_ODK(ODK_GP_GROUP, 9, \
|
|
"GP group to use for text/data sections") \
|
|
_ELF_DEFINE_ODK(ODK_IDENT, 10, "ID information") \
|
|
_ELF_DEFINE_ODK(ODK_PAGESIZE, 11, "page size infomation")
|
|
|
|
#undef _ELF_DEFINE_ODK
|
|
#define _ELF_DEFINE_ODK(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_OPTION_KINDS()
|
|
ODK__LAST__
|
|
};
|
|
|
|
/*
|
|
* ODK_EXCEPTIONS info field masks.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_ODK_EXCEPTIONS_MASK() \
|
|
_ELF_DEFINE_OEX(OEX_FPU_MIN, 0x0000001FUL, \
|
|
"minimum FPU exception which must be enabled") \
|
|
_ELF_DEFINE_OEX(OEX_FPU_MAX, 0x00001F00UL, \
|
|
"maximum FPU exception which can be enabled") \
|
|
_ELF_DEFINE_OEX(OEX_PAGE0, 0x00010000UL, \
|
|
"page zero must be mapped") \
|
|
_ELF_DEFINE_OEX(OEX_SMM, 0x00020000UL, \
|
|
"run in sequential memory mode") \
|
|
_ELF_DEFINE_OEX(OEX_PRECISEFP, 0x00040000UL, \
|
|
"run in precise FP exception mode") \
|
|
_ELF_DEFINE_OEX(OEX_DISMISS, 0x00080000UL, \
|
|
"dismiss invalid address traps")
|
|
|
|
#undef _ELF_DEFINE_OEX
|
|
#define _ELF_DEFINE_OEX(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ODK_EXCEPTIONS_MASK()
|
|
OEX__LAST__
|
|
};
|
|
|
|
/*
|
|
* ODK_PAD info field masks.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_ODK_PAD_MASK() \
|
|
_ELF_DEFINE_OPAD(OPAD_PREFIX, 0x0001) \
|
|
_ELF_DEFINE_OPAD(OPAD_POSTFIX, 0x0002) \
|
|
_ELF_DEFINE_OPAD(OPAD_SYMBOL, 0x0004)
|
|
|
|
#undef _ELF_DEFINE_OPAD
|
|
#define _ELF_DEFINE_OPAD(N, V) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ODK_PAD_MASK()
|
|
OPAD__LAST__
|
|
};
|
|
|
|
/*
|
|
* ODK_HWPATCH info field masks.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_ODK_HWPATCH_MASK() \
|
|
_ELF_DEFINE_OHW(OHW_R4KEOP, 0x00000001UL, \
|
|
"patch for R4000 branch at end-of-page bug") \
|
|
_ELF_DEFINE_OHW(OHW_R8KPFETCH, 0x00000002UL, \
|
|
"R8000 prefetch bug may occur") \
|
|
_ELF_DEFINE_OHW(OHW_R5KEOP, 0x00000004UL, \
|
|
"patch for R5000 branch at end-of-page bug") \
|
|
_ELF_DEFINE_OHW(OHW_R5KCVTL, 0x00000008UL, \
|
|
"R5000 cvt.[ds].l bug: clean == 1") \
|
|
_ELF_DEFINE_OHW(OHW_R10KLDL, 0x00000010UL, \
|
|
"needd patch for R10000 misaligned load")
|
|
|
|
#undef _ELF_DEFINE_OHW
|
|
#define _ELF_DEFINE_OHW(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ODK_HWPATCH_MASK()
|
|
OHW__LAST__
|
|
};
|
|
|
|
/*
|
|
* ODK_HWAND/ODK_HWOR info field and hwp_flags[12] masks.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_ODK_HWP_MASK() \
|
|
_ELF_DEFINE_HWP(OHWA0_R4KEOP_CHECKED, 0x00000001UL, \
|
|
"object checked for R4000 end-of-page bug") \
|
|
_ELF_DEFINE_HWP(OHWA0_R4KEOP_CLEAN, 0x00000002UL, \
|
|
"object verified clean for R4000 end-of-page bug") \
|
|
_ELF_DEFINE_HWP(OHWO0_FIXADE, 0x00000001UL, \
|
|
"object requires call to fixade")
|
|
|
|
#undef _ELF_DEFINE_HWP
|
|
#define _ELF_DEFINE_HWP(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ODK_HWP_MASK()
|
|
OHWX0__LAST__
|
|
};
|
|
|
|
/*
|
|
* ODK_IDENT/ODK_GP_GROUP info field masks.
|
|
*/
|
|
|
|
#define _ELF_DEFINE_ODK_GP_MASK() \
|
|
_ELF_DEFINE_OGP(OGP_GROUP, 0x0000FFFFUL, "GP group number") \
|
|
_ELF_DEFINE_OGP(OGP_SELF, 0x00010000UL, \
|
|
"GP group is self-contained")
|
|
|
|
#undef _ELF_DEFINE_OGP
|
|
#define _ELF_DEFINE_OGP(N, V, DESCR) N = V ,
|
|
enum {
|
|
_ELF_DEFINE_ODK_GP_MASK()
|
|
OGP__LAST__
|
|
};
|
|
|
|
/*
|
|
* MIPS ELF register info descriptor.
|
|
*/
|
|
|
|
/* 32 bit RegInfo entry. */
|
|
typedef struct {
|
|
Elf32_Word ri_gprmask; /* Mask of general register used. */
|
|
Elf32_Word ri_cprmask[4]; /* Mask of coprocessor register used. */
|
|
Elf32_Addr ri_gp_value; /* GP register value. */
|
|
} Elf32_RegInfo;
|
|
|
|
/* 64 bit RegInfo entry. */
|
|
typedef struct {
|
|
Elf64_Word ri_gprmask; /* Mask of general register used. */
|
|
Elf64_Word ri_pad; /* Padding. */
|
|
Elf64_Word ri_cprmask[4]; /* Mask of coprocessor register used. */
|
|
Elf64_Addr ri_gp_value; /* GP register value. */
|
|
} Elf64_RegInfo;
|
|
|
|
/*
|
|
* Program Header Table (PHDR) entries.
|
|
*/
|
|
|
|
/* 32 bit PHDR entry. */
|
|
typedef struct {
|
|
Elf32_Word p_type; /* Type of segment. */
|
|
Elf32_Off p_offset; /* File offset to segment. */
|
|
Elf32_Addr p_vaddr; /* Virtual address in memory. */
|
|
Elf32_Addr p_paddr; /* Physical address (if relevant). */
|
|
Elf32_Word p_filesz; /* Size of segment in file. */
|
|
Elf32_Word p_memsz; /* Size of segment in memory. */
|
|
Elf32_Word p_flags; /* Segment flags. */
|
|
Elf32_Word p_align; /* Alignment constraints. */
|
|
} Elf32_Phdr;
|
|
|
|
/* 64 bit PHDR entry. */
|
|
typedef struct {
|
|
Elf64_Word p_type; /* Type of segment. */
|
|
Elf64_Word p_flags; /* File offset to segment. */
|
|
Elf64_Off p_offset; /* Virtual address in memory. */
|
|
Elf64_Addr p_vaddr; /* Physical address (if relevant). */
|
|
Elf64_Addr p_paddr; /* Size of segment in file. */
|
|
Elf64_Xword p_filesz; /* Size of segment in memory. */
|
|
Elf64_Xword p_memsz; /* Segment flags. */
|
|
Elf64_Xword p_align; /* Alignment constraints. */
|
|
} Elf64_Phdr;
|
|
|
|
|
|
/*
|
|
* Move entries, for describing data in COMMON blocks in a compact
|
|
* manner.
|
|
*/
|
|
|
|
/* 32-bit move entry. */
|
|
typedef struct {
|
|
Elf32_Lword m_value; /* Initialization value. */
|
|
Elf32_Word m_info; /* Encoded size and index. */
|
|
Elf32_Word m_poffset; /* Offset relative to symbol. */
|
|
Elf32_Half m_repeat; /* Repeat count. */
|
|
Elf32_Half m_stride; /* Number of units to skip. */
|
|
} Elf32_Move;
|
|
|
|
/* 64-bit move entry. */
|
|
typedef struct {
|
|
Elf64_Lword m_value; /* Initialization value. */
|
|
Elf64_Xword m_info; /* Encoded size and index. */
|
|
Elf64_Xword m_poffset; /* Offset relative to symbol. */
|
|
Elf64_Half m_repeat; /* Repeat count. */
|
|
Elf64_Half m_stride; /* Number of units to skip. */
|
|
} Elf64_Move;
|
|
|
|
#define ELF32_M_SYM(I) ((I) >> 8)
|
|
#define ELF32_M_SIZE(I) ((unsigned char) (I))
|
|
#define ELF32_M_INFO(M, S) (((M) << 8) + (unsigned char) (S))
|
|
|
|
#define ELF64_M_SYM(I) ((I) >> 8)
|
|
#define ELF64_M_SIZE(I) ((unsigned char) (I))
|
|
#define ELF64_M_INFO(M, S) (((M) << 8) + (unsigned char) (S))
|
|
|
|
/*
|
|
* Section Header Table (SHDR) entries.
|
|
*/
|
|
|
|
/* 32 bit SHDR */
|
|
typedef struct {
|
|
Elf32_Word sh_name; /* index of section name */
|
|
Elf32_Word sh_type; /* section type */
|
|
Elf32_Word sh_flags; /* section flags */
|
|
Elf32_Addr sh_addr; /* in-memory address of section */
|
|
Elf32_Off sh_offset; /* file offset of section */
|
|
Elf32_Word sh_size; /* section size in bytes */
|
|
Elf32_Word sh_link; /* section header table link */
|
|
Elf32_Word sh_info; /* extra information */
|
|
Elf32_Word sh_addralign; /* alignment constraint */
|
|
Elf32_Word sh_entsize; /* size for fixed-size entries */
|
|
} Elf32_Shdr;
|
|
|
|
/* 64 bit SHDR */
|
|
typedef struct {
|
|
Elf64_Word sh_name; /* index of section name */
|
|
Elf64_Word sh_type; /* section type */
|
|
Elf64_Xword sh_flags; /* section flags */
|
|
Elf64_Addr sh_addr; /* in-memory address of section */
|
|
Elf64_Off sh_offset; /* file offset of section */
|
|
Elf64_Xword sh_size; /* section size in bytes */
|
|
Elf64_Word sh_link; /* section header table link */
|
|
Elf64_Word sh_info; /* extra information */
|
|
Elf64_Xword sh_addralign; /* alignment constraint */
|
|
Elf64_Xword sh_entsize; /* size for fixed-size entries */
|
|
} Elf64_Shdr;
|
|
|
|
|
|
/*
|
|
* Symbol table entries.
|
|
*/
|
|
|
|
typedef struct {
|
|
Elf32_Word st_name; /* index of symbol's name */
|
|
Elf32_Addr st_value; /* value for the symbol */
|
|
Elf32_Word st_size; /* size of associated data */
|
|
unsigned char st_info; /* type and binding attributes */
|
|
unsigned char st_other; /* visibility */
|
|
Elf32_Half st_shndx; /* index of related section */
|
|
} Elf32_Sym;
|
|
|
|
typedef struct {
|
|
Elf64_Word st_name; /* index of symbol's name */
|
|
unsigned char st_info; /* value for the symbol */
|
|
unsigned char st_other; /* size of associated data */
|
|
Elf64_Half st_shndx; /* type and binding attributes */
|
|
Elf64_Addr st_value; /* visibility */
|
|
Elf64_Xword st_size; /* index of related section */
|
|
} Elf64_Sym;
|
|
|
|
#define ELF32_ST_BIND(I) ((I) >> 4)
|
|
#define ELF32_ST_TYPE(I) ((I) & 0xFU)
|
|
#define ELF32_ST_INFO(B,T) (((B) << 4) + ((T) & 0xF))
|
|
|
|
#define ELF64_ST_BIND(I) ((I) >> 4)
|
|
#define ELF64_ST_TYPE(I) ((I) & 0xFU)
|
|
#define ELF64_ST_INFO(B,T) (((B) << 4) + ((T) & 0xF))
|
|
|
|
#define ELF32_ST_VISIBILITY(O) ((O) & 0x3)
|
|
#define ELF64_ST_VISIBILITY(O) ((O) & 0x3)
|
|
|
|
/*
|
|
* Syminfo descriptors, containing additional symbol information.
|
|
*/
|
|
|
|
/* 32-bit entry. */
|
|
typedef struct {
|
|
Elf32_Half si_boundto; /* Entry index with additional flags. */
|
|
Elf32_Half si_flags; /* Flags. */
|
|
} Elf32_Syminfo;
|
|
|
|
/* 64-bit entry. */
|
|
typedef struct {
|
|
Elf64_Half si_boundto; /* Entry index with additional flags. */
|
|
Elf64_Half si_flags; /* Flags. */
|
|
} Elf64_Syminfo;
|
|
|
|
/*
|
|
* Relocation descriptors.
|
|
*/
|
|
|
|
typedef struct {
|
|
Elf32_Addr r_offset; /* location to apply relocation to */
|
|
Elf32_Word r_info; /* type+section for relocation */
|
|
} Elf32_Rel;
|
|
|
|
typedef struct {
|
|
Elf32_Addr r_offset; /* location to apply relocation to */
|
|
Elf32_Word r_info; /* type+section for relocation */
|
|
Elf32_Sword r_addend; /* constant addend */
|
|
} Elf32_Rela;
|
|
|
|
typedef struct {
|
|
Elf64_Addr r_offset; /* location to apply relocation to */
|
|
Elf64_Xword r_info; /* type+section for relocation */
|
|
} Elf64_Rel;
|
|
|
|
typedef struct {
|
|
Elf64_Addr r_offset; /* location to apply relocation to */
|
|
Elf64_Xword r_info; /* type+section for relocation */
|
|
Elf64_Sxword r_addend; /* constant addend */
|
|
} Elf64_Rela;
|
|
|
|
|
|
#define ELF32_R_SYM(I) ((I) >> 8)
|
|
#define ELF32_R_TYPE(I) ((unsigned char) (I))
|
|
#define ELF32_R_INFO(S,T) (((S) << 8) + (unsigned char) (T))
|
|
|
|
#define ELF64_R_SYM(I) ((I) >> 32)
|
|
#define ELF64_R_TYPE(I) ((I) & 0xFFFFFFFFUL)
|
|
#define ELF64_R_INFO(S,T) (((S) << 32) + ((T) & 0xFFFFFFFFUL))
|
|
|
|
/*
|
|
* Symbol versioning structures.
|
|
*/
|
|
|
|
/* 32-bit structures. */
|
|
typedef struct
|
|
{
|
|
Elf32_Word vda_name; /* Index to name. */
|
|
Elf32_Word vda_next; /* Offset to next entry. */
|
|
} Elf32_Verdaux;
|
|
|
|
typedef struct
|
|
{
|
|
Elf32_Word vna_hash; /* Hash value of dependency name. */
|
|
Elf32_Half vna_flags; /* Flags. */
|
|
Elf32_Half vna_other; /* Unused. */
|
|
Elf32_Word vna_name; /* Offset to dependency name. */
|
|
Elf32_Word vna_next; /* Offset to next vernaux entry. */
|
|
} Elf32_Vernaux;
|
|
|
|
typedef struct
|
|
{
|
|
Elf32_Half vd_version; /* Version information. */
|
|
Elf32_Half vd_flags; /* Flags. */
|
|
Elf32_Half vd_ndx; /* Index into the versym section. */
|
|
Elf32_Half vd_cnt; /* Number of aux entries. */
|
|
Elf32_Word vd_hash; /* Hash value of name. */
|
|
Elf32_Word vd_aux; /* Offset to aux entries. */
|
|
Elf32_Word vd_next; /* Offset to next version definition. */
|
|
} Elf32_Verdef;
|
|
|
|
typedef struct
|
|
{
|
|
Elf32_Half vn_version; /* Version number. */
|
|
Elf32_Half vn_cnt; /* Number of aux entries. */
|
|
Elf32_Word vn_file; /* Offset of associated file name. */
|
|
Elf32_Word vn_aux; /* Offset of vernaux array. */
|
|
Elf32_Word vn_next; /* Offset of next verneed entry. */
|
|
} Elf32_Verneed;
|
|
|
|
typedef Elf32_Half Elf32_Versym;
|
|
|
|
/* 64-bit structures. */
|
|
|
|
typedef struct {
|
|
Elf64_Word vda_name; /* Index to name. */
|
|
Elf64_Word vda_next; /* Offset to next entry. */
|
|
} Elf64_Verdaux;
|
|
|
|
typedef struct {
|
|
Elf64_Word vna_hash; /* Hash value of dependency name. */
|
|
Elf64_Half vna_flags; /* Flags. */
|
|
Elf64_Half vna_other; /* Unused. */
|
|
Elf64_Word vna_name; /* Offset to dependency name. */
|
|
Elf64_Word vna_next; /* Offset to next vernaux entry. */
|
|
} Elf64_Vernaux;
|
|
|
|
typedef struct {
|
|
Elf64_Half vd_version; /* Version information. */
|
|
Elf64_Half vd_flags; /* Flags. */
|
|
Elf64_Half vd_ndx; /* Index into the versym section. */
|
|
Elf64_Half vd_cnt; /* Number of aux entries. */
|
|
Elf64_Word vd_hash; /* Hash value of name. */
|
|
Elf64_Word vd_aux; /* Offset to aux entries. */
|
|
Elf64_Word vd_next; /* Offset to next version definition. */
|
|
} Elf64_Verdef;
|
|
|
|
typedef struct {
|
|
Elf64_Half vn_version; /* Version number. */
|
|
Elf64_Half vn_cnt; /* Number of aux entries. */
|
|
Elf64_Word vn_file; /* Offset of associated file name. */
|
|
Elf64_Word vn_aux; /* Offset of vernaux array. */
|
|
Elf64_Word vn_next; /* Offset of next verneed entry. */
|
|
} Elf64_Verneed;
|
|
|
|
typedef Elf64_Half Elf64_Versym;
|
|
|
|
|
|
/*
|
|
* The header for GNU-style hash sections.
|
|
*/
|
|
|
|
typedef struct {
|
|
uint32_t gh_nbuckets; /* Number of hash buckets. */
|
|
uint32_t gh_symndx; /* First visible symbol in .dynsym. */
|
|
uint32_t gh_maskwords; /* #maskwords used in bloom filter. */
|
|
uint32_t gh_shift2; /* Bloom filter shift count. */
|
|
} Elf_GNU_Hash_Header;
|
|
|
|
#endif /* _ELFDEFINITIONS_H_ */
|