| elf_repl.h | | elf_repl.h | |
| /* | | /* | |
|
| * elf_repl.h - public header file for systems that lack it. | | elf_repl.h - public header file for systems that lack it. | |
| * Copyright (C) 1995 - 2006 Michael Riepe | | Copyright (C) 1995 - 2002 Michael Riepe <michael@stud.uni-hannover.de> | |
| * | | | |
| * This library is free software; you can redistribute it and/or | | | |
| * modify it under the terms of the GNU Library General Public | | | |
| * License as published by the Free Software Foundation; either | | | |
| * version 2 of the License, or (at your option) any later version. | | | |
| * | | | |
| * This library is distributed in the hope that it will be useful, | | | |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of | | | |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | | | |
| * Library General Public License for more details. | | | |
| * | | | |
| * You should have received a copy of the GNU Library General Public | | | |
| * License along with this library; if not, write to the Free Software | | | |
| * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 US | | | |
| A | | | |
| */ | | | |
| | | | |
|
| /* @(#) $Id: elf_repl.h,v 1.20 2006/07/07 22:16:15 michael Exp $ */ | | This library is free software; you can redistribute it and/or | |
| | | modify it under the terms of the GNU Library General Public | |
| | | License as published by the Free Software Foundation; either | |
| | | version 2 of the License, or (at your option) any later version. | |
| | | | |
| | | This library is distributed in the hope that it will be useful, | |
| | | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| | | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
| | | Library General Public License for more details. | |
| | | | |
| | | You should have received a copy of the GNU Library General Public | |
| | | License along with this library; if not, write to the Free Software | |
| | | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | |
| | | */ | |
| | | | |
| | | /* @(#) $Id: elf_repl.h,v 1.12 2003/01/02 04:34:47 michael Exp $ */ | |
| | | | |
| /* | | /* | |
| * NEVER INCLUDE THIS FILE DIRECTLY - USE <libelf.h> INSTEAD! | | * NEVER INCLUDE THIS FILE DIRECTLY - USE <libelf.h> INSTEAD! | |
| */ | | */ | |
| | | | |
| #ifndef _ELF_REPL_H | | #ifndef _ELF_REPL_H | |
| #define _ELF_REPL_H | | #define _ELF_REPL_H | |
| | | | |
| #ifdef __cplusplus | | #ifdef __cplusplus | |
| extern "C" { | | extern "C" { | |
| | | | |
| skipping to change at line 169 | | skipping to change at line 169 | |
| #define ELFOSABI_LINUX 3 /* Linux */ | | #define ELFOSABI_LINUX 3 /* Linux */ | |
| #define ELFOSABI_SOLARIS 6 /* Sun Solaris */ | | #define ELFOSABI_SOLARIS 6 /* Sun Solaris */ | |
| #define ELFOSABI_AIX 7 /* AIX */ | | #define ELFOSABI_AIX 7 /* AIX */ | |
| #define ELFOSABI_IRIX 8 /* IRIX */ | | #define ELFOSABI_IRIX 8 /* IRIX */ | |
| #define ELFOSABI_FREEBSD 9 /* FreeBSD */ | | #define ELFOSABI_FREEBSD 9 /* FreeBSD */ | |
| #define ELFOSABI_TRU64 10 /* Compaq TRU64 UNIX */ | | #define ELFOSABI_TRU64 10 /* Compaq TRU64 UNIX */ | |
| #define ELFOSABI_MODESTO 11 /* Novell Modesto */ | | #define ELFOSABI_MODESTO 11 /* Novell Modesto */ | |
| #define ELFOSABI_OPENBSD 12 /* Open BSD */ | | #define ELFOSABI_OPENBSD 12 /* Open BSD */ | |
| #define ELFOSABI_OPENVMS 13 /* Open VMS */ | | #define ELFOSABI_OPENVMS 13 /* Open VMS */ | |
| #define ELFOSABI_NSK 14 /* Hewlett-Packard Non-Stop Kernel *
/ | | #define ELFOSABI_NSK 14 /* Hewlett-Packard Non-Stop Kernel *
/ | |
|
| #define ELFOSABI_AROS 15 /* Amiga Research OS */ | | | |
| /* these are probably obsolete: */ | | /* these are probably obsolete: */ | |
| #define ELFOSABI_ARM 97 /* ARM */ | | #define ELFOSABI_ARM 97 /* ARM */ | |
| #define ELFOSABI_STANDALONE 255 /* standalone (embedded) application
*/ | | #define ELFOSABI_STANDALONE 255 /* standalone (embedded) application
*/ | |
| | | | |
| /* | | /* | |
| * e_type | | * e_type | |
| */ | | */ | |
| #define ET_NONE 0 | | #define ET_NONE 0 | |
| #define ET_REL 1 | | #define ET_REL 1 | |
| #define ET_EXEC 2 | | #define ET_EXEC 2 | |
| | | | |
| skipping to change at line 202 | | skipping to change at line 201 | |
| #define EM_M32 1 /* AT&T WE 32100 */ | | #define EM_M32 1 /* AT&T WE 32100 */ | |
| #define EM_SPARC 2 /* SPARC */ | | #define EM_SPARC 2 /* SPARC */ | |
| #define EM_386 3 /* Intel 80386 */ | | #define EM_386 3 /* Intel 80386 */ | |
| #define EM_68K 4 /* Motorola 68000 */ | | #define EM_68K 4 /* Motorola 68000 */ | |
| #define EM_88K 5 /* Motorola 88000 */ | | #define EM_88K 5 /* Motorola 88000 */ | |
| #define EM_486 6 /* Intel i486 (DO NOT USE THIS ONE) */ | | #define EM_486 6 /* Intel i486 (DO NOT USE THIS ONE) */ | |
| #define EM_860 7 /* Intel 80860 */ | | #define EM_860 7 /* Intel 80860 */ | |
| #define EM_MIPS 8 /* MIPS I Architecture */ | | #define EM_MIPS 8 /* MIPS I Architecture */ | |
| #define EM_S370 9 /* IBM System/370 Processor */ | | #define EM_S370 9 /* IBM System/370 Processor */ | |
| #define EM_MIPS_RS3_LE 10 /* MIPS RS3000 Little-endian */ | | #define EM_MIPS_RS3_LE 10 /* MIPS RS3000 Little-endian */ | |
|
| #define EM_SPARC64 11 /* SPARC 64-bit */ | | | |
| #define EM_PARISC 15 /* Hewlett-Packard PA-RISC */ | | #define EM_PARISC 15 /* Hewlett-Packard PA-RISC */ | |
| #define EM_VPP500 17 /* Fujitsu VPP500 */ | | #define EM_VPP500 17 /* Fujitsu VPP500 */ | |
| #define EM_SPARC32PLUS 18 /* Enhanced instruction set SPARC */ | | #define EM_SPARC32PLUS 18 /* Enhanced instruction set SPARC */ | |
| #define EM_960 19 /* Intel 80960 */ | | #define EM_960 19 /* Intel 80960 */ | |
| #define EM_PPC 20 /* PowerPC */ | | #define EM_PPC 20 /* PowerPC */ | |
| #define EM_PPC64 21 /* 64-bit PowerPC */ | | #define EM_PPC64 21 /* 64-bit PowerPC */ | |
| #define EM_S390 22 /* IBM System/390 Processor */ | | #define EM_S390 22 /* IBM System/390 Processor */ | |
| #define EM_V800 36 /* NEC V800 */ | | #define EM_V800 36 /* NEC V800 */ | |
| #define EM_FR20 37 /* Fujitsu FR20 */ | | #define EM_FR20 37 /* Fujitsu FR20 */ | |
| #define EM_RH32 38 /* TRW RH-32 */ | | #define EM_RH32 38 /* TRW RH-32 */ | |
| | | | |
| skipping to change at line 237 | | skipping to change at line 235 | |
| #define EM_68HC12 53 /* Motorola M68HC12 */ | | #define EM_68HC12 53 /* Motorola M68HC12 */ | |
| #define EM_MMA 54 /* Fujitsu MMA Multimedia Accelerator */ | | #define EM_MMA 54 /* Fujitsu MMA Multimedia Accelerator */ | |
| #define EM_PCP 55 /* Siemens PCP */ | | #define EM_PCP 55 /* Siemens PCP */ | |
| #define EM_NCPU 56 /* Sony nCPU embedded RISC processor
*/ | | #define EM_NCPU 56 /* Sony nCPU embedded RISC processor
*/ | |
| #define EM_NDR1 57 /* Denso NDR1 microprocessor */ | | #define EM_NDR1 57 /* Denso NDR1 microprocessor */ | |
| #define EM_STARCORE 58 /* Motorola Star*Core processor */ | | #define EM_STARCORE 58 /* Motorola Star*Core processor */ | |
| #define EM_ME16 59 /* Toyota ME16 processor */ | | #define EM_ME16 59 /* Toyota ME16 processor */ | |
| #define EM_ST100 60 /* STMicroelectronics ST100 processor */ | | #define EM_ST100 60 /* STMicroelectronics ST100 processor */ | |
| #define EM_TINYJ 61 /* Advanced Logic Corp. TinyJ embedded proce
ssor family */ | | #define EM_TINYJ 61 /* Advanced Logic Corp. TinyJ embedded proce
ssor family */ | |
| #define EM_X86_64 62 /* AMD x86-64 architecture */ | | #define EM_X86_64 62 /* AMD x86-64 architecture */ | |
|
| #define EM_AMD64 EM_X86_64 | | | |
| #define EM_PDSP 63 /* Sony DSP Processor */ | | #define EM_PDSP 63 /* Sony DSP Processor */ | |
| #define EM_FX66 66 /* Siemens FX66 microcontroller */ | | #define EM_FX66 66 /* Siemens FX66 microcontroller */ | |
| #define EM_ST9PLUS 67 /* STMicroelectronics ST9+ 8/16 bit microcon
troller */ | | #define EM_ST9PLUS 67 /* STMicroelectronics ST9+ 8/16 bit microcon
troller */ | |
| #define EM_ST7 68 /* STMicroelectronics ST7 8-bit microcontrol
ler */ | | #define EM_ST7 68 /* STMicroelectronics ST7 8-bit microcontrol
ler */ | |
| #define EM_68HC16 69 /* Motorola MC68HC16 Microcontroller */ | | #define EM_68HC16 69 /* Motorola MC68HC16 Microcontroller */ | |
| #define EM_68HC11 70 /* Motorola MC68HC11 Microcontroller */ | | #define EM_68HC11 70 /* Motorola MC68HC11 Microcontroller */ | |
| #define EM_68HC08 71 /* Motorola MC68HC08 Microcontroller */ | | #define EM_68HC08 71 /* Motorola MC68HC08 Microcontroller */ | |
| #define EM_68HC05 72 /* Motorola MC68HC05 Microcontroller */ | | #define EM_68HC05 72 /* Motorola MC68HC05 Microcontroller */ | |
| #define EM_SVX 73 /* Silicon Graphics SVx */ | | #define EM_SVX 73 /* Silicon Graphics SVx */ | |
| #define EM_ST19 74 /* STMicroelectronics ST19 8-bit mic
rocontroller */ | | #define EM_ST19 74 /* STMicroelectronics ST19 8-bit mic
rocontroller */ | |
| | | | |
| skipping to change at line 274 | | skipping to change at line 271 | |
| #define EM_PJ 91 /* picoJava */ | | #define EM_PJ 91 /* picoJava */ | |
| #define EM_OPENRISC 92 /* OpenRISC 32-bit embedded processor */ | | #define EM_OPENRISC 92 /* OpenRISC 32-bit embedded processor */ | |
| #define EM_ARC_A5 93 /* ARC Cores Tangent-A5 */ | | #define EM_ARC_A5 93 /* ARC Cores Tangent-A5 */ | |
| #define EM_XTENSA 94 /* Tensilica Xtensa Architecture */ | | #define EM_XTENSA 94 /* Tensilica Xtensa Architecture */ | |
| #define EM_VIDEOCORE 95 /* Alphamosaic VideoCore processor */ | | #define EM_VIDEOCORE 95 /* Alphamosaic VideoCore processor */ | |
| #define EM_TMM_GPP 96 /* Thompson Multimedia General Purpose Proce
ssor */ | | #define EM_TMM_GPP 96 /* Thompson Multimedia General Purpose Proce
ssor */ | |
| #define EM_NS32K 97 /* National Semiconductor 32000 series */ | | #define EM_NS32K 97 /* National Semiconductor 32000 series */ | |
| #define EM_TPC 98 /* Tenor Network TPC processor */ | | #define EM_TPC 98 /* Tenor Network TPC processor */ | |
| #define EM_SNP1K 99 /* Trebia SNP 1000 processor */ | | #define EM_SNP1K 99 /* Trebia SNP 1000 processor */ | |
| #define EM_ST200 100 /* STMicroelectronics (www.st.com) ST200 mic
rocontroller */ | | #define EM_ST200 100 /* STMicroelectronics (www.st.com) ST200 mic
rocontroller */ | |
|
| #define EM_IP2K 101 /* Ubicom IP2xxx microcontroller family */ | | #define EM_NUM 101 | |
| #define EM_MAX 102 /* MAX Processor */ | | | |
| #define EM_CR 103 /* National Semiconductor CompactRISC microp | | | |
| rocessor */ | | | |
| #define EM_F2MC16 104 /* Fujitsu F2MC16 */ | | | |
| #define EM_MSP430 105 /* Texas Instruments embedded microcontrolle | | | |
| r msp430 */ | | | |
| #define EM_BLACKFIN 106 /* Analog Devices Blackfin (DSP) processor * | | | |
| / | | | |
| #define EM_SE_C33 107 /* S1C33 Family of Seiko Epson processors */ | | | |
| #define EM_SEP 108 /* Sharp embedded microprocessor */ | | | |
| #define EM_ARCA 109 /* Arca RISC Microprocessor */ | | | |
| #define EM_UNICORE 110 /* Microprocessor series from PKU-Unity Ltd. | | | |
| and MPRC of Peking University */ | | | |
| #define EM_NUM 111 | | | |
| | | | |
| /* | | /* | |
| * e_ident[EI_VERSION], e_version | | * e_ident[EI_VERSION], e_version | |
| */ | | */ | |
| #define EV_NONE 0 | | #define EV_NONE 0 | |
| #define EV_CURRENT 1 | | #define EV_CURRENT 1 | |
| #define EV_NUM 2 | | #define EV_NUM 2 | |
| | | | |
| /* | | /* | |
| * Section header | | * Section header | |
| | | | |
| skipping to change at line 369 | | skipping to change at line 356 | |
| #define SHT_LOOS 0x60000000 | | #define SHT_LOOS 0x60000000 | |
| #define SHT_HIOS 0x6fffffff | | #define SHT_HIOS 0x6fffffff | |
| #define SHT_LOPROC 0x70000000 | | #define SHT_LOPROC 0x70000000 | |
| #define SHT_HIPROC 0x7fffffff | | #define SHT_HIPROC 0x7fffffff | |
| #define SHT_LOUSER 0x80000000 | | #define SHT_LOUSER 0x80000000 | |
| #define SHT_HIUSER 0xffffffff | | #define SHT_HIUSER 0xffffffff | |
| | | | |
| /* | | /* | |
| * Solaris extensions | | * Solaris extensions | |
| */ | | */ | |
|
| #define SHT_LOSUNW 0x6ffffff4 | | | |
| #define SHT_SUNW_dof 0x6ffffff4 | | | |
| #define SHT_SUNW_cap 0x6ffffff5 | | | |
| #define SHT_SUNW_SIGNATURE 0x6ffffff6 | | | |
| #define SHT_SUNW_ANNOTATE 0x6ffffff7 | | | |
| #define SHT_SUNW_DEBUGSTR 0x6ffffff8 | | | |
| #define SHT_SUNW_DEBUG 0x6ffffff9 | | | |
| #define SHT_SUNW_move 0x6ffffffa | | #define SHT_SUNW_move 0x6ffffffa | |
| #define SHT_SUNW_COMDAT 0x6ffffffb | | #define SHT_SUNW_COMDAT 0x6ffffffb | |
| #define SHT_SUNW_syminfo 0x6ffffffc | | #define SHT_SUNW_syminfo 0x6ffffffc | |
| #define SHT_SUNW_verdef 0x6ffffffd | | #define SHT_SUNW_verdef 0x6ffffffd | |
| #define SHT_SUNW_verneed 0x6ffffffe | | #define SHT_SUNW_verneed 0x6ffffffe | |
| #define SHT_SUNW_versym 0x6fffffff | | #define SHT_SUNW_versym 0x6fffffff | |
|
| #define SHT_HISUNW 0x6fffffff | | | |
| | | | |
| #define SHT_SPARC_GOTDATA 0x70000000 | | | |
| #define SHT_AMD64_UNWIND 0x70000001 | | | |
| | | | |
| /* | | /* | |
| * GNU extensions | | * GNU extensions | |
| */ | | */ | |
| #define SHT_GNU_verdef 0x6ffffffd | | #define SHT_GNU_verdef 0x6ffffffd | |
| #define SHT_GNU_verneed 0x6ffffffe | | #define SHT_GNU_verneed 0x6ffffffe | |
| #define SHT_GNU_versym 0x6fffffff | | #define SHT_GNU_versym 0x6fffffff | |
| | | | |
| /* | | /* | |
| * sh_flags | | * sh_flags | |
| | | | |
| skipping to change at line 411 | | skipping to change at line 387 | |
| #define SHF_STRINGS 0x20 | | #define SHF_STRINGS 0x20 | |
| #define SHF_INFO_LINK 0x40 | | #define SHF_INFO_LINK 0x40 | |
| #define SHF_LINK_ORDER 0x80 | | #define SHF_LINK_ORDER 0x80 | |
| #define SHF_OS_NONCONFORMING 0x100 | | #define SHF_OS_NONCONFORMING 0x100 | |
| #define SHF_GROUP 0x200 | | #define SHF_GROUP 0x200 | |
| #define SHF_TLS 0x400 | | #define SHF_TLS 0x400 | |
| #define SHF_MASKOS 0x0ff00000 | | #define SHF_MASKOS 0x0ff00000 | |
| #define SHF_MASKPROC 0xf0000000 | | #define SHF_MASKPROC 0xf0000000 | |
| | | | |
| /* | | /* | |
|
| * Solaris extensions | | | |
| */ | | | |
| #define SHF_AMD64_LARGE 0x10000000 | | | |
| #define SHF_ORDERED 0x40000000 | | | |
| #define SHF_EXCLUDE 0x80000000 | | | |
| | | | |
| /* | | | |
| * Section group flags | | * Section group flags | |
| */ | | */ | |
|
| #define GRP_COMDAT 0x1 | | #define GRP_COMDAT 0x1 | |
| #define GRP_MASKOS 0x0ff00000 | | #define GRP_MASKOS 0x0ff00000 | |
| #define GRP_MASKPROC 0xf0000000 | | #define GRP_MASKPROC 0xf0000000 | |
| | | | |
| /* | | /* | |
| * Symbol table | | * Symbol table | |
| */ | | */ | |
| typedef struct { | | typedef struct { | |
| Elf32_Word st_name; | | Elf32_Word st_name; | |
| Elf32_Addr st_value; | | Elf32_Addr st_value; | |
| Elf32_Word st_size; | | Elf32_Word st_size; | |
| unsigned char st_info; | | unsigned char st_info; | |
| unsigned char st_other; | | unsigned char st_other; | |
| | | | |
| skipping to change at line 560 | | skipping to change at line 529 | |
| * Note entry header | | * Note entry header | |
| */ | | */ | |
| typedef struct { | | typedef struct { | |
| Elf32_Word n_namesz; /* name size */ | | Elf32_Word n_namesz; /* name size */ | |
| Elf32_Word n_descsz; /* descriptor size */ | | Elf32_Word n_descsz; /* descriptor size */ | |
| Elf32_Word n_type; /* descriptor type */ | | Elf32_Word n_type; /* descriptor type */ | |
| } Elf32_Nhdr; | | } Elf32_Nhdr; | |
| | | | |
| #if __LIBELF64 | | #if __LIBELF64 | |
| /* Solaris and GNU use this layout. Be compatible. */ | | /* Solaris and GNU use this layout. Be compatible. */ | |
|
| /* XXX: Latest ELF specs say it's 64-bit!!! */ | | /* XXX: Latest ELF specs say it's 64-bit?! */ | |
| typedef struct { | | typedef struct { | |
| Elf64_Word n_namesz; /* name size */ | | Elf64_Word n_namesz; /* name size */ | |
| Elf64_Word n_descsz; /* descriptor size */ | | Elf64_Word n_descsz; /* descriptor size */ | |
| Elf64_Word n_type; /* descriptor type */ | | Elf64_Word n_type; /* descriptor type */ | |
| } Elf64_Nhdr; | | } Elf64_Nhdr; | |
| #endif /* __LIBELF64 */ | | #endif /* __LIBELF64 */ | |
| | | | |
| /* | | /* | |
| * Well-known descriptor types for ET_CORE files | | * Well-known descriptor types for ET_CORE files | |
| */ | | */ | |
| | | | |
| skipping to change at line 603 | | skipping to change at line 572 | |
| Elf64_Off p_offset; | | Elf64_Off p_offset; | |
| Elf64_Addr p_vaddr; | | Elf64_Addr p_vaddr; | |
| Elf64_Addr p_paddr; | | Elf64_Addr p_paddr; | |
| Elf64_Xword p_filesz; | | Elf64_Xword p_filesz; | |
| Elf64_Xword p_memsz; | | Elf64_Xword p_memsz; | |
| Elf64_Xword p_align; | | Elf64_Xword p_align; | |
| } Elf64_Phdr; | | } Elf64_Phdr; | |
| #endif /* __LIBELF64 */ | | #endif /* __LIBELF64 */ | |
| | | | |
| /* | | /* | |
|
| * Special numbers | | | |
| */ | | | |
| #define PN_XNUM 0xffff | | | |
| | | | |
| /* | | | |
| * p_type | | * p_type | |
| */ | | */ | |
| #define PT_NULL 0 | | #define PT_NULL 0 | |
| #define PT_LOAD 1 | | #define PT_LOAD 1 | |
| #define PT_DYNAMIC 2 | | #define PT_DYNAMIC 2 | |
| #define PT_INTERP 3 | | #define PT_INTERP 3 | |
| #define PT_NOTE 4 | | #define PT_NOTE 4 | |
| #define PT_SHLIB 5 | | #define PT_SHLIB 5 | |
| #define PT_PHDR 6 | | #define PT_PHDR 6 | |
| #define PT_TLS 7 | | #define PT_TLS 7 | |
| #define PT_NUM 8 | | #define PT_NUM 8 | |
| #define PT_LOOS 0x60000000 | | #define PT_LOOS 0x60000000 | |
| #define PT_HIOS 0x6fffffff | | #define PT_HIOS 0x6fffffff | |
| #define PT_LOPROC 0x70000000 | | #define PT_LOPROC 0x70000000 | |
| #define PT_HIPROC 0x7fffffff | | #define PT_HIPROC 0x7fffffff | |
| | | | |
| /* | | /* | |
|
| * Solaris extensions | | | |
| */ | | | |
| | | | |
| #define PT_SUNW_UNWIND 0x6464e550 | | | |
| #define PT_LOSUNW 0x6ffffffa | | | |
| #define PT_SUNWBSS 0x6ffffffa | | | |
| #define PT_SUNWSTACK 0x6ffffffb | | | |
| #define PT_SUNWDTRACE 0x6ffffffc | | | |
| #define PT_SUNWCAP 0x6ffffffd | | | |
| #define PT_HISUNW 0x6fffffff | | | |
| | | | |
| /* | | | |
| * p_flags | | * p_flags | |
| */ | | */ | |
| #define PF_X 0x1 | | #define PF_X 0x1 | |
| #define PF_W 0x2 | | #define PF_W 0x2 | |
| #define PF_R 0x4 | | #define PF_R 0x4 | |
| #define PF_MASKOS 0x0ff00000 | | #define PF_MASKOS 0x0ff00000 | |
| #define PF_MASKPROC 0xf0000000 | | #define PF_MASKPROC 0xf0000000 | |
| | | | |
| /* | | /* | |
| * Dynamic structure | | * Dynamic structure | |
| | | | |
| skipping to change at line 929 | | skipping to change at line 881 | |
| #define VER_FLG_BASE 0x1 /* vd_flags only */ | | #define VER_FLG_BASE 0x1 /* vd_flags only */ | |
| #define VER_FLG_WEAK 0x2 | | #define VER_FLG_WEAK 0x2 | |
| | | | |
| /* | | /* | |
| * Elf*_Versym special values | | * Elf*_Versym special values | |
| */ | | */ | |
| #define VER_NDX_LOCAL 0 | | #define VER_NDX_LOCAL 0 | |
| #define VER_NDX_GLOBAL 1 | | #define VER_NDX_GLOBAL 1 | |
| | | | |
| /* | | /* | |
|
| * Solaris extensions | | | |
| */ | | | |
| | | | |
| /* | | | |
| * Move section | | * Move section | |
| */ | | */ | |
| #if __LIBELF64 | | #if __LIBELF64 | |
| | | | |
| typedef struct { | | typedef struct { | |
| Elf32_Lword m_value; | | Elf32_Lword m_value; | |
| Elf32_Word m_info; | | Elf32_Word m_info; | |
| Elf32_Word m_poffset; | | Elf32_Word m_poffset; | |
| Elf32_Half m_repeat; | | Elf32_Half m_repeat; | |
| Elf32_Half m_stride; | | Elf32_Half m_stride; | |
| | | | |
| skipping to change at line 963 | | skipping to change at line 911 | |
| #define ELF32_M_SYM(info) ((info)>>8) | | #define ELF32_M_SYM(info) ((info)>>8) | |
| #define ELF32_M_SIZE(info) ((unsigned char)(info)) | | #define ELF32_M_SIZE(info) ((unsigned char)(info)) | |
| #define ELF32_M_INFO(sym, sz) (((sym)<<8)+(unsigned char)(sz)) | | #define ELF32_M_INFO(sym, sz) (((sym)<<8)+(unsigned char)(sz)) | |
| | | | |
| #define ELF64_M_SYM(info) ((Elf64_Xword)(info)>>8) | | #define ELF64_M_SYM(info) ((Elf64_Xword)(info)>>8) | |
| #define ELF64_M_SIZE(info) ((unsigned char)(info)) | | #define ELF64_M_SIZE(info) ((unsigned char)(info)) | |
| #define ELF64_M_INFO(sym, sz) (((Elf64_Xword)(sym)<<8)+(unsigned char)(sz)
) | | #define ELF64_M_INFO(sym, sz) (((Elf64_Xword)(sym)<<8)+(unsigned char)(sz)
) | |
| | | | |
| #endif /* __LIBELF64 */ | | #endif /* __LIBELF64 */ | |
| | | | |
|
| /* | | | |
| * Capabilities | | | |
| */ | | | |
| | | | |
| typedef struct { | | | |
| Elf32_Word c_tag; | | | |
| union { | | | |
| Elf32_Word c_val; | | | |
| Elf32_Addr c_ptr; | | | |
| } c_un; | | | |
| } Elf32_Cap; | | | |
| | | | |
| typedef struct { | | | |
| Elf64_Xword c_tag; | | | |
| union { | | | |
| Elf64_Xword c_val; | | | |
| Elf64_Addr c_ptr; | | | |
| } c_un; | | | |
| } Elf64_Cap; | | | |
| | | | |
| #define CA_SUNW_NULL 0 /* c_un ignored */ | | | |
| #define CA_SUNW_HW_1 1 /* c_un.c_val */ | | | |
| #define CA_SUNW_SF_1 2 /* c_un.c_val */ | | | |
| | | | |
| #ifdef __cplusplus | | #ifdef __cplusplus | |
| } | | } | |
| #endif /* __cplusplus */ | | #endif /* __cplusplus */ | |
| | | | |
| #endif /* _ELF_REPL_H */ | | #endif /* _ELF_REPL_H */ | |
| | | | |
End of changes. 15 change blocks. |
| 104 lines changed or deleted | | 23 lines changed or added | |
|