libelf/dat.h

476 lines
15 KiB
C

#define USED(x) if(x){}else{}
#define nelem(x) (sizeof(x)/sizeof((x)[0]))
extern char *machinestr[];
#define EI_NIDENT 16
enum {
Eh32sz = 52,
Sh32sz = 40,
Ph32sz = 32,
Eh64sz = 64,
Sh64sz = 64,
Ph64sz = 56,
};
/*
* ELF32 Header
*/
typedef struct {
uint8_t ident[EI_NIDENT];
uint16_t type;
uint16_t machine;
uint32_t version;
uint32_t entry;
uint32_t phoff;
uint32_t shoff;
uint32_t flags;
uint16_t ehsize;
uint16_t phentsize;
uint16_t phnum;
uint16_t shentsize;
uint16_t shnum;
uint16_t shstrndx;
} Elf32_Ehdr;
/*
* ELF64 Header
*/
typedef struct {
uint8_t ident[EI_NIDENT];
uint16_t type;
uint16_t machine;
uint32_t version;
uint64_t entry;
uint64_t phoff;
uint64_t shoff;
uint32_t flags;
uint16_t ehsize;
uint16_t phentsize;
uint16_t phnum;
uint16_t shentsize;
uint16_t shnum;
uint16_t shstrndx;
} Elf64_Ehdr;
/*
* ELF32 Section Header
*/
typedef struct {
uint32_t name;
uint32_t type;
uint32_t flags;
uint32_t addr;
uint32_t offset;
uint32_t size;
uint32_t link;
uint32_t info;
uint32_t addralign;
uint32_t entsize;
} Elf32_Shdr;
/*
* ELF64 Section Header
*/
typedef struct {
uint32_t name;
uint32_t type;
uint64_t flags;
uint64_t addr;
uint64_t offset;
uint64_t size;
uint32_t link;
uint32_t info;
uint64_t addralign;
uint64_t entsize;
} Elf64_Shdr;
/*
* ELF32 Program Header
*/
typedef struct {
uint32_t type;
uint32_t offset;
uint32_t vaddr;
uint32_t paddr;
uint32_t filesz;
uint32_t memsz;
uint32_t flags;
uint32_t align;
} Elf32_Phdr;
/*
* ELF64 Program Header
*/
typedef struct {
uint32_t type;
uint32_t flags;
uint64_t offset;
uint64_t vaddr;
uint64_t paddr;
uint64_t filesz;
uint64_t memsz;
uint64_t align;
} Elf64_Phdr;
/*
* Object file type
*/
enum {
ET_NONE = 0, /* No file type */
ET_REL = 1, /* Relocatable file */
ET_EXEC = 2, /* Executable file */
ET_DYN = 3, /* Shared object file */
ET_CORE = 4, /* Core file */
ET_LOOS = 0xfe00, /* Operating system-specific */
ET_HIOS = 0xfeff, /* Operating system-specific */
ET_LOPROC = 0xff00, /* Processor-specific */
ET_HIPROC = 0xffff, /* Processor-specific */
};
/*
* Architectures
*/
enum {
EM_NONE = 0, /* No machine */
EM_M32 = 1, /* AT&T WE 32100 */
EM_SPARC = 2, /* SPARC */
EM_386 = 3, /* Intel 80386 */
EM_68K = 4, /* Motorola 68000 */
EM_88K = 5, /* Motorola 88000 */
EM_IAMCU = 6, /* Intel MCU */
EM_860 = 7, /* Intel 80860 */
EM_MIPS = 8, /* MIPS I Architecture */
EM_S370 = 9, /* IBM System/370 Processor */
EM_MIPS_RS3_LE = 10, /* MIPS RS3000 Little-endian */
/* 11-14 Reserved for future use */
EM_PARISC = 15, /* Hewlett-Packard PA-RISC */
reserved = 16, /* Reserved for future use */
EM_VPP500 = 17, /* Fujitsu VPP500 */
EM_SPARC32PLUS = 18, /* Enhanced instruction set SPARC */
EM_960 = 19, /* Intel 80960 */
EM_PPC = 20, /* PowerPC */
EM_PPC64 = 21, /* 64-bit PowerPC */
EM_S390 = 22, /* IBM System/390 Processor */
EM_SPU = 23, /* IBM SPU/SPC */
/* 24-35 Reserved for future use */
EM_V800 = 36, /* NEC V800 */
EM_FR20 = 37, /* Fujitsu FR20 */
EM_RH32 = 38, /* TRW RH-32 */
EM_RCE = 39, /* Motorola RCE */
EM_ARM = 40, /* ARM 32-bit architecture (AARCH32) */
EM_ALPHA = 41, /* Digital Alpha */
EM_SH = 42, /* Hitachi SH */
EM_SPARCV9 = 43, /* SPARC Version 9 */
EM_TRICORE = 44, /* Siemens TriCore embedded processor */
EM_ARC = 45, /* Argonaut RISC Core, Argonaut Technologies Inc. */
EM_H8_300 = 46, /* Hitachi H8/300 */
EM_H8_300H = 47, /* Hitachi H8/300H */
EM_H8S = 48, /* Hitachi H8S */
EM_H8_500 = 49, /* Hitachi H8/500 */
EM_IA_64 = 50, /* Intel IA-64 processor architecture */
EM_MIPS_X = 51, /* Stanford MIPS-X */
EM_COLDFIRE = 52, /* Motorola ColdFire */
EM_68HC12 = 53, /* Motorola M68HC12 */
EM_MMA = 54, /* Fujitsu MMA Multimedia Accelerator */
EM_PCP = 55, /* Siemens PCP */
EM_NCPU = 56, /* Sony nCPU embedded RISC processor */
EM_NDR1 = 57, /* Denso NDR1 microprocessor */
EM_STARCORE = 58, /* Motorola Star*Core processor */
EM_ME16 = 59, /* Toyota ME16 processor */
EM_ST100 = 60, /* STMicroelectronics ST100 processor */
EM_TINYJ = 61, /* Advanced Logic Corp. TinyJ embedded processor family */
EM_X86_64 = 62, /* AMD x86-64 architecture */
EM_PDSP = 63, /* Sony DSP Processor */
EM_PDP10 = 64, /* Digital Equipment Corp. PDP-10 */
EM_PDP11 = 65, /* Digital Equipment Corp. PDP-11 */
EM_FX66 = 66, /* Siemens FX66 microcontroller */
EM_ST9PLUS = 67, /* STMicroelectronics ST9+ 8/16 bit microcontroller */
EM_ST7 = 68, /* STMicroelectronics ST7 8-bit microcontroller */
EM_68HC16 = 69, /* Motorola MC68HC16 Microcontroller */
EM_68HC11 = 70, /* Motorola MC68HC11 Microcontroller */
EM_68HC08 = 71, /* Motorola MC68HC08 Microcontroller */
EM_68HC05 = 72, /* Motorola MC68HC05 Microcontroller */
EM_SVX = 73, /* Silicon Graphics SVx */
EM_ST19 = 74, /* STMicroelectronics ST19 8-bit microcontroller */
EM_VAX = 75, /* Digital VAX */
EM_CRIS = 76, /* Axis Communications 32-bit embedded processor */
EM_JAVELIN = 77, /* Infineon Technologies 32-bit embedded processor */
EM_FIREPATH = 78, /* Element 14 64-bit DSP Processor */
EM_ZSP = 79, /* LSI Logic 16-bit DSP Processor */
EM_MMIX = 80, /* Donald Knuth's educational 64-bit processor */
EM_HUANY = 81, /* Harvard University machine-independent object files */
EM_PRISM = 82, /* SiTera Prism */
EM_AVR = 83, /* Atmel AVR 8-bit microcontroller */
EM_FR30 = 84, /* Fujitsu FR30 */
EM_D10V = 85, /* Mitsubishi D10V */
EM_D30V = 86, /* Mitsubishi D30V */
EM_V850 = 87, /* NEC v850 */
EM_M32R = 88, /* Mitsubishi M32R */
EM_MN10300 = 89, /* Matsushita MN10300 */
EM_MN10200 = 90, /* Matsushita MN10200 */
EM_PJ = 91, /* picoJava */
EM_OPENRISC = 92, /* OpenRISC 32-bit embedded processor */
EM_ARC_COMPACT = 93, /* ARC International ARCompact processor (old spelling/synonym: EM_ARC_A5) */
EM_XTENSA = 94, /* Tensilica Xtensa Architecture */
EM_VIDEOCORE = 95, /* Alphamosaic VideoCore processor */
EM_TMM_GPP = 96, /* Thompson Multimedia General Purpose Processor */
EM_NS32K = 97, /* National Semiconductor 32000 series */
EM_TPC = 98, /* Tenor Network TPC processor */
EM_SNP1K = 99, /* Trebia SNP 1000 processor */
EM_ST200 = 100, /* STMicroelectronics (www.st.com) ST200 microcontroller */
EM_IP2K = 101, /* Ubicom IP2xxx microcontroller family */
EM_MAX = 102, /* MAX Processor */
EM_CR = 103, /* National Semiconductor CompactRISC microprocessor */
EM_F2MC16 = 104, /* Fujitsu F2MC16 */
EM_MSP430 = 105, /* Texas Instruments embedded microcontroller msp430 */
EM_BLACKFIN = 106, /* Analog Devices Blackfin (DSP) processor */
EM_SE_C33 = 107, /* S1C33 Family of Seiko Epson processors */
EM_SEP = 108, /* Sharp embedded microprocessor */
EM_ARCA = 109, /* Arca RISC Microprocessor */
EM_UNICORE = 110, /* Microprocessor series from PKU-Unity Ltd. and MPRC of Peking University*/
EM_EXCESS = 111, /* eXcess: 16/32/64-bit configurable embedded CPU */
EM_DXP = 112, /* Icera Semiconductor Inc. Deep Execution Processor */
EM_ALTERA_NIOS2 = 113, /* Altera Nios II soft-core processor */
EM_CRX = 114, /* National Semiconductor CompactRISC CRX microprocessor */
EM_XGATE = 115, /* Motorola XGATE embedded processor */
EM_C166 = 116, /* Infineon C16x/XC16x processor */
EM_M16C = 117, /* Renesas M16C series microprocessors */
EM_DSPIC30F = 118, /* Microchip Technology dsPIC30F Digital Signal Controller */
EM_CE = 119, /* Freescale Communication Engine RISC core */
EM_M32C = 120, /* Renesas M32C series microprocessors */
/* 121-130 Reserved for future use */
EM_TSK3000 = 131, /* Altium TSK3000 core */
EM_RS08 = 132, /* Freescale RS08 embedded processor */
EM_SHARC = 133, /* Analog Devices SHARC family of 32-bit DSP processors */
EM_ECOG2 = 134, /* Cyan Technology eCOG2 microprocessor */
EM_SCORE7 = 135, /* Sunplus S+core7 RISC processor */
EM_DSP24 = 136, /* New Japan Radio (NJR) 24-bit DSP Processor */
EM_VIDEOCORE3 = 137, /* Broadcom VideoCore III processor */
EM_LATTICEMICO32 = 138, /* RISC processor for Lattice FPGA architecture */
EM_SE_C17 = 139, /* Seiko Epson C17 family */
EM_TI_C6000 = 140, /* The Texas Instruments TMS320C6000 DSP family */
EM_TI_C2000 = 141, /* The Texas Instruments TMS320C2000 DSP family */
EM_TI_C5500 = 142, /* The Texas Instruments TMS320C55x DSP family */
EM_TI_ARP32 = 143, /* Texas Instruments Application Specific RISC Processor, 32bit fetch */
EM_TI_PRU = 144, /* Texas Instruments Programmable Realtime Unit */
/* 145-159 Reserved for future use */
EM_MMDSP_PLUS = 160, /* STMicroelectronics 64bit VLIW Data Signal Processor */
EM_CYPRESS_M8C = 161, /* Cypress M8C microprocessor */
EM_R32C = 162, /* Renesas R32C series microprocessors */
EM_TRIMEDIA = 163, /* NXP Semiconductors TriMedia architecture family */
EM_QDSP6 = 164, /* QUALCOMM DSP6 Processor */
EM_8051 = 165, /* Intel 8051 and variants */
EM_STXP7X = 166, /* STMicroelectronics STxP7x family of configurable and extensible RISC processors */
EM_NDS32 = 167, /* Andes Technology compact code size embedded RISC processor family */
EM_ECOG1X = 168, /* Cyan Technology eCOG1X family */
EM_MAXQ30 = 169, /* Dallas Semiconductor MAXQ30 Core Micro-controllers */
EM_XIMO16 = 170, /* New Japan Radio (NJR) 16-bit DSP Processor */
EM_MANIK = 171, /* M2000 Reconfigurable RISC Microprocessor */
EM_CRAYNV2 = 172, /* Cray Inc. NV2 vector architecture */
EM_RX = 173, /* Renesas RX family */
EM_METAG = 174, /* Imagination Technologies META processor architecture */
EM_MCST_ELBRUS = 175, /* MCST Elbrus general purpose hardware architecture */
EM_ECOG16 = 176, /* Cyan Technology eCOG16 family */
EM_CR16 = 177, /* National Semiconductor CompactRISC CR16 16-bit microprocessor */
EM_ETPU = 178, /* Freescale Extended Time Processing Unit */
EM_SLE9X = 179, /* Infineon Technologies SLE9X core */
EM_L10M = 180, /* Intel L10M */
EM_K10M = 181, /* Intel K10M */
/* 182 Reserved for future Intel use */
EM_AARCH64 = 183, /* ARM 64-bit architecture (AARCH64) */
/* 184 Reserved for future ARM use */
EM_AVR32 = 185, /* Atmel Corporation 32-bit microprocessor family */
EM_STM8 = 186, /* STMicroeletronics STM8 8-bit microcontroller */
EM_TILE64 = 187, /* Tilera TILE64 multicore architecture family */
EM_TILEPRO = 188, /* Tilera TILEPro multicore architecture family */
EM_MICROBLAZE = 189, /* Xilinx MicroBlaze 32-bit RISC soft processor core */
EM_CUDA = 190, /* NVIDIA CUDA architecture */
EM_TILEGX = 191, /* Tilera TILE-Gx multicore architecture family */
EM_CLOUDSHIELD = 192, /* CloudShield architecture family */
EM_COREA_1ST = 193, /* KIPO-KAIST Core-A 1st generation processor family */
EM_COREA_2ND = 194, /* KIPO-KAIST Core-A 2nd generation processor family */
EM_ARC_COMPACT2 = 195, /* Synopsys ARCompact V2 */
EM_OPEN8 = 196, /* Open8 8-bit RISC soft processor core */
EM_RL78 = 197, /* Renesas RL78 family */
EM_VIDEOCORE5 = 198, /* Broadcom VideoCore V processor */
EM_78KOR = 199, /* Renesas 78KOR family */
EM_56800EX = 200, /* Freescale 56800EX Digital Signal Controller (DSC) */
EM_BA1 = 201, /* Beyond BA1 CPU architecture */
EM_BA2 = 202, /* Beyond BA2 CPU architecture */
EM_XCORE = 203, /* XMOS xCORE processor family */
EM_MCHP_PIC = 204, /* Microchip 8-bit PIC(r) family */
EM_INTEL205 = 205, /* Reserved by Intel */
EM_INTEL206 = 206, /* Reserved by Intel */
EM_INTEL207 = 207, /* Reserved by Intel */
EM_INTEL208 = 208, /* Reserved by Intel */
EM_INTEL209 = 209, /* Reserved by Intel */
EM_KM32 = 210, /* KM211 KM32 32-bit processor */
EM_KMX32 = 211, /* KM211 KMX32 32-bit processor */
EM_KMX16 = 212, /* KM211 KMX16 16-bit processor */
EM_KMX8 = 213, /* KM211 KMX8 8-bit processor */
EM_KVARC = 214, /* KM211 KVARC processor */
EM_CDP = 215, /* Paneve CDP architecture family */
EM_COGE = 216, /* Cognitive Smart Memory Processor */
EM_COOL = 217, /* Bluechip Systems CoolEngine */
EM_NORC = 218, /* Nanoradio Optimized RISC */
EM_CSR_KALIMBA = 219, /* CSR Kalimba architecture family */
EM_Z80 = 220, /* Zilog Z80 */
EM_VISIUM = 221, /* Controls and Data Services VISIUMcore processor */
EM_FT32 = 222, /* FTDI Chip FT32 high performance 32-bit RISC architecture */
EM_MOXIE = 223, /* Moxie processor family */
EM_AMDGPU = 224, /* AMD GPU architecture */
/* 225-242 */
EM_RISCV = 243, /* RISC-V */
};
/*
* Object file version
*/
enum {
EV_NONE = 0, /* Invalid */
EV_CURRENT = 1, /* Current */
};
/*
* Identification
*/
enum {
EI_MAG0 = 0, /* File identification */
EI_MAG1 = 1, /* File identification */
EI_MAG2 = 2, /* File identification */
EI_MAG3 = 3, /* File identification */
EI_CLASS = 4, /* File class */
EI_DATA = 5, /* Data encoding */
EI_VERSION = 6, /* File version */
EI_OSABI = 7, /* Operating system/ABI identification */
EI_ABIVERSION = 8, /* ABI version */
EI_PAD = 9, /* Start of padding bytes */
};
/*
* ELF Magic Number
*/
enum {
ELFMAG0 = 0x7f, /* e_ident[EI_MAG0] */
ELFMAG1 = 'E', /* e_ident[EI_MAG1] */
ELFMAG2 = 'L', /* e_ident[EI_MAG2] */
ELFMAG3 = 'F', /* e_ident[EI_MAG3] */
};
/*
* File class
*/
enum {
ELFCLASSNONE = 0, /* Invalid class */
ELFCLASS32 = 1, /* 32-bit objects */
ELFCLASS64 = 2, /* 64-bit objects */
};
/*
* Data encoding
*/
enum {
ELFDATANONE = 0, /* Invalid data encoding */
ELFDATA2LSB = 1, /* Litte-endian */
ELFDATA2MSB = 2, /* Big-endian */
};
/*
* Operating system/ABI identification
*/
enum {
ELFOSABI_NONE = 0, /* No extensions or unspecified */
ELFOSABI_HPUX = 1, /* Hewlett-Packard HP-UX */
ELFOSABI_NETBSD = 2, /* NetBSD */
ELFOSABI_GNU = 3, /* GNU */
ELFOSABI_SOLARIS = 6, /* Sun Solaris */
ELFOSABI_AIX = 7, /* AIX */
ELFOSABI_IRIX = 8, /* IRIX */
ELFOSABI_FREEBSD = 9, /* FreeBSD */
ELFOSABI_TRU64 = 10, /* Compaq TRU64 UNIX */
ELFOSABI_MODESTO = 11, /* Novell Modesto */
ELFOSABI_OPENBSD = 12, /* Open BSD */
ELFOSABI_OPENVMS = 13, /* Open VMS */
ELFOSABI_NSK = 14, /* Hewlett-Packard Non-Stop Kernel */
ELFOSABI_AROS = 15, /* Amiga Research OS */
ELFOSABI_FENIXOS = 16, /* The FenixOS highly scalable multi-core OS */
ELFOSABI_CLOUDABI = 17, /* Nuxi CloudABI */
ELFOSABI_OPENVOS = 18, /* Stratus Technologies OpenVOS */
/* 64-255 Architecture-specific value range */
};
/*
* Special Section Indexes
*/
enum {
SHN_UNDEF = 0,
SHN_LORESERVE = 0xff00,
SHN_LOPROC = 0xff00,
SHN_HIPROC = 0xff1f,
SHN_LOOS = 0xff20,
SHN_HIOS = 0xff3f,
SHN_ABS = 0xfff1,
SHN_COMMON = 0xfff2,
SHN_XINDEX = 0xffff,
SHN_HIRESERVE = 0xffff,
};
/*
* Section Types
*/
enum {
SHT_NULL = 0,
SHT_PROGBITS = 1,
SHT_SYMTAB = 2,
SHT_STRTAB = 3,
SHT_RELA = 4,
SHT_HASH = 5,
SHT_DYNAMIC = 6,
SHT_NOTE = 7,
SHT_NOBITS = 8,
SHT_REL = 9,
SHT_SHLIB = 10,
SHT_DYNSYM = 11,
SHT_INIT_ARRAY = 14,
SHT_FINI_ARRAY = 15,
SHT_PREINIT_ARRAY = 16,
SHT_GROUP = 17,
SHT_SYMTAB_SHNDX = 18,
SHT_LOOS = 0x60000000,
SHT_HIOS = 0x6fffffff,
SHT_LOPROC = 0x70000000,
SHT_HIPROC = 0x7fffffff,
SHT_LOUSER = 0x80000000,
SHT_HIUSER = 0xffffffff,
};
/*
* Section Attribute Flags
*/
enum {
SHF_WRITE = 0x1,
SHF_ALLOC = 0x2,
SHF_EXECINSTR = 0x4,
SHF_MERGE = 0x10,
SHF_STRINGS = 0x20,
SHF_INFO_LINK = 0x40,
SHF_LINK_ORDER = 0x80,
SHF_OS_NONCONFORMING = 0x100,
SHF_GROUP = 0x200,
SHF_TLS = 0x400,
SHF_COMPRESSED = 0x800,
SHF_MASKOS = 0x0ff00000,
SHF_MASKPROC = 0xf0000000,
};
/*
* Section Attribute Flags
*/
enum {
GRP_COMDAT = 0x1,
GRP_MASKOS = 0x0ff00000,
GRP_MASKPROC = 0xf0000000,
};