summaryrefslogtreecommitdiffstats
path: root/sys
diff options
context:
space:
mode:
authorjb <jb@FreeBSD.org>1998-09-05 23:07:59 +0000
committerjb <jb@FreeBSD.org>1998-09-05 23:07:59 +0000
commitdfdc8cd38c61441f5e768b4a792d3200bf926727 (patch)
tree18fd53f289585cccced3c866cdf599f5e2696997 /sys
parent966b082e7861776d68745c782d44e1012b3e68b0 (diff)
downloadFreeBSD-src-dfdc8cd38c61441f5e768b4a792d3200bf926727.zip
FreeBSD-src-dfdc8cd38c61441f5e768b4a792d3200bf926727.tar.gz
Change the ELF64_R_SYM() to shift 32 bits instead of 8 bits to match
binutils. Ensure that three of the structures are the size that binutils writes them. I just love code that doesn't share header files to avoid problems like these. With this change rtld-elf works on alpha.
Diffstat (limited to 'sys')
-rw-r--r--sys/sys/elf64.h47
1 files changed, 24 insertions, 23 deletions
diff --git a/sys/sys/elf64.h b/sys/sys/elf64.h
index 2d6a23d..38ff648 100644
--- a/sys/sys/elf64.h
+++ b/sys/sys/elf64.h
@@ -23,7 +23,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
- * $Id: elf64.h,v 1.3 1998/07/07 23:32:57 jdp Exp $
+ * $Id: elf64.h,v 1.4 1998/08/16 03:03:38 jdp Exp $
*/
#ifndef _SYS_ELF64_H_
@@ -36,11 +36,12 @@
*/
typedef u_int64_t Elf64_Addr;
-typedef u_int16_t Elf64_Half;
+typedef u_int32_t Elf64_Half;
typedef u_int64_t Elf64_Off;
-typedef int32_t Elf64_Sword;
-typedef u_int32_t Elf64_Word;
+typedef int64_t Elf64_Sword;
+typedef u_int64_t Elf64_Word;
typedef u_int64_t Elf64_Size;
+typedef u_int16_t Elf64_Quarter;
/*
* ELF header.
@@ -48,19 +49,19 @@ typedef u_int64_t Elf64_Size;
typedef struct {
unsigned char e_ident[EI_NIDENT]; /* File identification. */
- Elf64_Half e_type; /* File type. */
- Elf64_Half e_machine; /* Machine architecture. */
- Elf64_Word e_version; /* ELF format version. */
+ Elf64_Quarter e_type; /* File type. */
+ Elf64_Quarter e_machine; /* Machine architecture. */
+ Elf64_Half e_version; /* ELF format version. */
Elf64_Addr e_entry; /* Entry point. */
Elf64_Off e_phoff; /* Program header file offset. */
Elf64_Off e_shoff; /* Section header file offset. */
- Elf64_Word e_flags; /* Architecture-specific flags. */
- Elf64_Half e_ehsize; /* Size of ELF header in bytes. */
- Elf64_Half e_phentsize; /* Size of program header entry. */
- Elf64_Half e_phnum; /* Number of program header entries. */
- Elf64_Half e_shentsize; /* Size of section header entry. */
- Elf64_Half e_shnum; /* Number of section header entries. */
- Elf64_Half e_shstrndx; /* Section name strings section. */
+ Elf64_Half e_flags; /* Architecture-specific flags. */
+ Elf64_Quarter e_ehsize; /* Size of ELF header in bytes. */
+ Elf64_Quarter e_phentsize; /* Size of program header entry. */
+ Elf64_Quarter e_phnum; /* Number of program header entries. */
+ Elf64_Quarter e_shentsize; /* Size of section header entry. */
+ Elf64_Quarter e_shnum; /* Number of section header entries. */
+ Elf64_Quarter e_shstrndx; /* Section name strings section. */
} Elf64_Ehdr;
/*
@@ -68,15 +69,15 @@ typedef struct {
*/
typedef struct {
- Elf64_Word sh_name; /* Section name (index into the
+ Elf64_Half sh_name; /* Section name (index into the
section header string table). */
- Elf64_Word sh_type; /* Section type. */
+ Elf64_Half sh_type; /* Section type. */
Elf64_Size sh_flags; /* Section flags. */
Elf64_Addr sh_addr; /* Address in memory image. */
Elf64_Off sh_offset; /* Offset in file. */
Elf64_Size sh_size; /* Size in bytes. */
- Elf64_Word sh_link; /* Index of a related section. */
- Elf64_Word sh_info; /* Depends on section type. */
+ Elf64_Half sh_link; /* Index of a related section. */
+ Elf64_Half sh_info; /* Depends on section type. */
Elf64_Size sh_addralign; /* Alignment in bytes. */
Elf64_Size sh_entsize; /* Size of each entry in section. */
} Elf64_Shdr;
@@ -86,8 +87,8 @@ typedef struct {
*/
typedef struct {
- Elf64_Word p_type; /* Entry type. */
- Elf64_Word p_flags; /* Access permission flags. */
+ Elf64_Half p_type; /* Entry type. */
+ Elf64_Half p_flags; /* Access permission flags. */
Elf64_Off p_offset; /* File offset of contents. */
Elf64_Addr p_vaddr; /* Virtual address in memory image. */
Elf64_Addr p_paddr; /* Physical address (not used). */
@@ -126,7 +127,7 @@ typedef struct {
} Elf64_Rela;
/* Macros for accessing the fields of r_info. */
-#define ELF64_R_SYM(info) ((info) >> 8)
+#define ELF64_R_SYM(info) ((info) >> 32)
#define ELF64_R_TYPE(info) ((unsigned char)(info))
/* Macro for constructing r_info from field values. */
@@ -137,10 +138,10 @@ typedef struct {
*/
typedef struct {
- Elf64_Word st_name; /* String table index of name. */
+ Elf64_Half st_name; /* String table index of name. */
unsigned char st_info; /* Type and binding information. */
unsigned char st_other; /* Reserved (not used). */
- Elf64_Half st_shndx; /* Section index of symbol. */
+ Elf64_Quarter st_shndx; /* Section index of symbol. */
Elf64_Addr st_value; /* Symbol value. */
Elf64_Size st_size; /* Size of associated object. */
} Elf64_Sym;
OpenPOWER on IntegriCloud