diff options
author | Jonathan Gray <jsg@cvs.openbsd.org> | 2019-12-01 13:10:52 +0000 |
---|---|---|
committer | Jonathan Gray <jsg@cvs.openbsd.org> | 2019-12-01 13:10:52 +0000 |
commit | 4dc745576fc50502703ecf84b7558559482a9b16 (patch) | |
tree | ea0a252001d7a82c9ecce69ff471ce1d41c632dc | |
parent | fffb14807c0bc19ce8401c48720ab2b5699748c5 (diff) |
Change Elf64 types and structs to match the System V ABI specification.
Change Elf64_Half from a uint32_t type to a uint16_t type. The size of
structs do not change as the previous uses of Elf64_Half become
Elf64_Word (uint32_t).
Remove Elf64_Quarter as 16 bit values now use Elf64_Half.
Replace Elf_Byte use with unsigned char.
Change some uses of Elf64_Xword to Elf64_Addr (both uint64_t).
Corrects behaviour with libelf where the file size of a symtab section
came back as 26 not 24 as libelf determines this by the size of a the
involved types not the size of the struct in exec_elf.h. As a result
libelf's elf_getdata() returned ELF_E_SECTION due to the size of the
section not being a multiple of the file size of the section type.
This occurred with the new runtime linker for radeon shaders in
Mesa 19.2.
Sync description of Elf32 and Elf64 types in elf(5) with FreeBSD and
adjust types in structs mentioned.
ok guenther@ deraadt@
-rw-r--r-- | share/man/man5/elf.5 | 90 | ||||
-rw-r--r-- | sys/sys/exec_elf.h | 65 |
2 files changed, 76 insertions, 79 deletions
diff --git a/share/man/man5/elf.5 b/share/man/man5/elf.5 index 70796f2afea..d22279f6738 100644 --- a/share/man/man5/elf.5 +++ b/share/man/man5/elf.5 @@ -1,4 +1,4 @@ -.\" $OpenBSD: elf.5,v 1.36 2019/06/17 08:53:01 kevlo Exp $ +.\" $OpenBSD: elf.5,v 1.37 2019/12/01 13:10:51 jsg Exp $ .\"Copyright (c) 1999 Jeroen Ruigrok van der Werven .\"All rights reserved. .\" @@ -25,7 +25,7 @@ .\" .\" $FreeBSD: src/share/man/man5/elf.5,v 1.21 2001/10/01 16:09:23 ru Exp $ .\" -.Dd $Mdocdate: June 17 2019 $ +.Dd $Mdocdate: December 1 2019 $ .Dt ELF 5 .Os .Sh NAME @@ -79,24 +79,24 @@ symbol tables. .Pp The following types are used for 32-bit architectures: .Bd -literal -offset indent -Elf32_Addr Unsigned program address -Elf32_Off Unsigned file offset -Elf32_Sword Signed large integer -Elf32_Word Unsigned large integer -Elf32_Half Unsigned medium integer +Elf32_Addr Unsigned 32-bit program address +Elf32_Half Unsigned 16-bit field +Elf32_Lword Unsigned 64-bit field +Elf32_Off Unsigned 32-bit file offset +Elf32_Sword Signed 32-bit field or integer +Elf32_Word Unsigned 32-bit field or integer .Ed .Pp And the following types are used for 64-bit architectures: .Bd -literal -offset indent -Elf64_Addr Unsigned program address -Elf64_Off Unsigned file offset -Elf64_Shalf Signed halfword field -Elf64_Sword Signed large integer -Elf64_Word Field or unsigned large integer -Elf64_Sxword Signed object size or alignment -Elf64_Xword Unsigned object size or alignment -Elf64_Half Unsigned halfword field -Elf64_Quarter Unsigned quarterword field +Elf64_Addr Unsigned 64-bit program address +Elf64_Half Unsigned 16-bit field +Elf64_Lword Unsigned 64-bit field +Elf64_Off Unsigned 64-bit file offset +Elf64_Sword Signed 32-bit field +Elf64_Sxword Signed 64-bit field or integer +Elf64_Word Unsigned 32-bit field +Elf64_Xword Unsigned 64-bit field or integer .Ed .Pp All data structures that the file format defines follow the @@ -128,19 +128,19 @@ typedef struct { .Bd -literal -offset indent typedef struct { unsigned char e_ident[EI_NIDENT]; - Elf64_Quarter e_type; - Elf64_Quarter e_machine; - Elf64_Half e_version; + Elf64_Half e_type; + Elf64_Half e_machine; + Elf64_Word e_version; Elf64_Addr e_entry; Elf64_Off e_phoff; Elf64_Off e_shoff; - Elf64_Half e_flags; - Elf64_Quarter e_ehsize; - Elf64_Quarter e_phentsize; - Elf64_Quarter e_phnum; - Elf64_Quarter e_shentsize; - Elf64_Quarter e_shnum; - Elf64_Quarter e_shstrndx; + Elf64_Word e_flags; + Elf64_Half e_ehsize; + Elf64_Half e_phentsize; + Elf64_Half e_phnum; + Elf64_Half e_shentsize; + Elf64_Half e_shnum; + Elf64_Half e_shstrndx; } Elf64_Ehdr; .Ed .Pp @@ -428,8 +428,8 @@ typedef struct { .Ed .Bd -literal -offset indent typedef struct { - Elf64_Half p_type; - Elf64_Half p_flags; + Elf64_Word p_type; + Elf64_Word p_flags; Elf64_Off p_offset; Elf64_Addr p_vaddr; Elf64_Addr p_paddr; @@ -693,14 +693,14 @@ typedef struct { .Ed .Bd -literal -offset indent typedef struct { - Elf64_Half sh_name; - Elf64_Half sh_type; + Elf64_Word sh_name; + Elf64_Word sh_type; Elf64_Xword sh_flags; Elf64_Addr sh_addr; Elf64_Off sh_offset; Elf64_Xword sh_size; - Elf64_Half sh_link; - Elf64_Half sh_info; + Elf64_Word sh_link; + Elf64_Word sh_info; Elf64_Xword sh_addralign; Elf64_Xword sh_entsize; } Elf64_Shdr; @@ -1178,11 +1178,11 @@ typedef struct { .Ed .Bd -literal -offset indent typedef struct { - Elf64_Half st_name; - Elf_Byte st_info; - Elf_Byte st_other; - Elf64_Quarter st_shndx; - Elf64_Xword st_value; + Elf64_Word st_name; + unsigned char st_info; + unsigned char st_other; + Elf64_Half st_shndx; + Elf64_Addr st_value; Elf64_Xword st_size; } Elf64_Sym; .Ed @@ -1310,7 +1310,7 @@ typedef struct { .Ed .Bd -literal -offset indent typedef struct { - Elf64_Xword r_offset; + Elf64_Addr r_offset; Elf64_Xword r_info; } Elf64_Rel; .Ed @@ -1325,7 +1325,7 @@ typedef struct { .Ed .Bd -literal -offset indent typedef struct { - Elf64_Xword r_offset; + Elf64_Addr r_offset; Elf64_Xword r_info; Elf64_Sxword r_addend; } Elf64_Rela; @@ -1364,15 +1364,15 @@ followed by the section name and the section description. The actual note contents follow thereafter. .Bd -literal -offset indent typedef struct { -Elf32_Word namesz; -Elf32_Word descsz; -Elf32_Word type; + Elf32_Word namesz; + Elf32_Word descsz; + Elf32_Word type; } Elf32_Note; typedef struct { -Elf64_Half namesz; -Elf64_Half descsz; -Elf64_Half type; + Elf64_Word namesz; + Elf64_Word descsz; + Elf64_Word type; } Elf64_Note; .Ed .Bl -tag -width "r_offset" diff --git a/sys/sys/exec_elf.h b/sys/sys/exec_elf.h index 8a88773093c..a40e0510273 100644 --- a/sys/sys/exec_elf.h +++ b/sys/sys/exec_elf.h @@ -1,4 +1,4 @@ -/* $OpenBSD: exec_elf.h,v 1.86 2019/12/01 10:25:50 jsg Exp $ */ +/* $OpenBSD: exec_elf.h,v 1.87 2019/12/01 13:10:51 jsg Exp $ */ /* * Copyright (c) 1995, 1996 Erik Theisen. All rights reserved. * @@ -36,8 +36,6 @@ #include <sys/types.h> #include <machine/exec.h> -typedef __uint8_t Elf_Byte; - typedef __uint32_t Elf32_Addr; /* Unsigned program address */ typedef __uint32_t Elf32_Off; /* Unsigned file offset */ typedef __int32_t Elf32_Sword; /* Signed large integer */ @@ -56,8 +54,7 @@ typedef __int64_t Elf64_Sxword; typedef __uint64_t Elf64_Xword; typedef __uint64_t Elf64_Lword; -typedef __uint32_t Elf64_Half; -typedef __uint16_t Elf64_Quarter; +typedef __uint16_t Elf64_Half; /* * e_ident[] identification indexes @@ -139,19 +136,19 @@ typedef struct elfhdr { typedef struct { unsigned char e_ident[EI_NIDENT]; /* Id bytes */ - Elf64_Quarter e_type; /* file type */ - Elf64_Quarter e_machine; /* machine type */ - Elf64_Half e_version; /* version number */ + Elf64_Half e_type; /* file type */ + Elf64_Half e_machine; /* machine type */ + Elf64_Word e_version; /* version number */ Elf64_Addr e_entry; /* entry point */ Elf64_Off e_phoff; /* Program hdr offset */ Elf64_Off e_shoff; /* Section hdr offset */ - Elf64_Half e_flags; /* Processor flags */ - Elf64_Quarter e_ehsize; /* sizeof ehdr */ - Elf64_Quarter e_phentsize; /* Program header entry size */ - Elf64_Quarter e_phnum; /* Number of program headers */ - Elf64_Quarter e_shentsize; /* Section header entry size */ - Elf64_Quarter e_shnum; /* Number of section headers */ - Elf64_Quarter e_shstrndx; /* String table index */ + Elf64_Word e_flags; /* Processor flags */ + Elf64_Half e_ehsize; /* sizeof ehdr */ + Elf64_Half e_phentsize; /* Program header entry size */ + Elf64_Half e_phnum; /* Number of program headers */ + Elf64_Half e_shentsize; /* Section header entry size */ + Elf64_Half e_shnum; /* Number of section headers */ + Elf64_Half e_shstrndx; /* String table index */ } Elf64_Ehdr; /* e_type */ @@ -225,14 +222,14 @@ typedef struct { } Elf32_Shdr; typedef struct { - Elf64_Half sh_name; /* section name */ - Elf64_Half sh_type; /* section type */ + Elf64_Word sh_name; /* section name */ + Elf64_Word sh_type; /* section type */ Elf64_Xword sh_flags; /* section flags */ Elf64_Addr sh_addr; /* virtual address */ Elf64_Off sh_offset; /* file offset */ Elf64_Xword sh_size; /* section size */ - Elf64_Half sh_link; /* link to another */ - Elf64_Half sh_info; /* misc info */ + Elf64_Word sh_link; /* link to another */ + Elf64_Word sh_info; /* misc info */ Elf64_Xword sh_addralign; /* memory alignment */ Elf64_Xword sh_entsize; /* table entry size */ } Elf64_Shdr; @@ -335,11 +332,11 @@ typedef struct elf32_sym { } Elf32_Sym; typedef struct { - Elf64_Half st_name; /* Symbol name index in str table */ - Elf_Byte st_info; /* type / binding attrs */ - Elf_Byte st_other; /* unused */ - Elf64_Quarter st_shndx; /* section index of symbol */ - Elf64_Xword st_value; /* value of symbol */ + Elf64_Word st_name; /* Symbol name index in str table */ + unsigned char st_info; /* type / binding attrs */ + unsigned char st_other; /* unused */ + Elf64_Half st_shndx; /* section index of symbol */ + Elf64_Addr st_value; /* value of symbol */ Elf64_Xword st_size; /* size of symbol */ } Elf64_Sym; @@ -402,12 +399,12 @@ typedef struct { #define ELF32_R_INFO(s,t) (((s) << 8) + (unsigned char)(t)) typedef struct { - Elf64_Xword r_offset; /* where to do it */ + Elf64_Addr r_offset; /* where to do it */ Elf64_Xword r_info; /* index & type of relocation */ } Elf64_Rel; typedef struct { - Elf64_Xword r_offset; /* where to do it */ + Elf64_Addr r_offset; /* where to do it */ Elf64_Xword r_info; /* index & type of relocation */ Elf64_Sxword r_addend; /* adjustment value */ } Elf64_Rela; @@ -443,8 +440,8 @@ typedef struct { } Elf32_Phdr; typedef struct { - Elf64_Half p_type; /* entry type */ - Elf64_Half p_flags; /* flags */ + Elf64_Word p_type; /* entry type */ + Elf64_Word p_flags; /* flags */ Elf64_Off p_offset; /* offset */ Elf64_Addr p_vaddr; /* virtual address */ Elf64_Addr p_paddr; /* physical address */ @@ -578,9 +575,9 @@ typedef struct { } Elf32_Nhdr; typedef struct { - Elf64_Half n_namesz; - Elf64_Half n_descsz; - Elf64_Half n_type; + Elf64_Word n_namesz; + Elf64_Word n_descsz; + Elf64_Word n_type; } Elf64_Nhdr; /* @@ -593,9 +590,9 @@ typedef struct { } Elf32_Note; typedef struct { - Elf64_Half namesz; - Elf64_Half descsz; - Elf64_Half type; + Elf64_Word namesz; + Elf64_Word descsz; + Elf64_Word type; } Elf64_Note; /* Values for n_type. */ |