summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkstailey <kstailey@cvs.openbsd.org>1999-09-07 21:52:45 +0000
committerkstailey <kstailey@cvs.openbsd.org>1999-09-07 21:52:45 +0000
commit5971815a41976adc6ad8c74b25cbbc5bd9de70d8 (patch)
tree70f087a7429dfbd17d4feadd5894fb359b228363
parent1ace7a1b4820b028c48ed7acbb03097bbe8c6284 (diff)
ELF64
-rw-r--r--sys/sys/exec_elf.h112
1 files changed, 97 insertions, 15 deletions
diff --git a/sys/sys/exec_elf.h b/sys/sys/exec_elf.h
index 9ed741773f2..6027f84398c 100644
--- a/sys/sys/exec_elf.h
+++ b/sys/sys/exec_elf.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: exec_elf.h,v 1.14 1999/02/10 08:07:20 deraadt Exp $ */
+/* $OpenBSD: exec_elf.h,v 1.15 1999/09/07 21:52:44 kstailey Exp $ */
/*
* Copyright (c) 1995, 1996 Erik Theisen. All rights reserved.
*
@@ -35,17 +35,22 @@
#include <machine/types.h>
-/*
- * These typedefs need to be handled better -
- * doesn't work on 64-bit machines. Note:
- * there currently isn't a 64-bit ABI.
- */
+typedef u_int8_t Elf_Byte;
+
typedef u_int32_t Elf32_Addr; /* Unsigned program address */
typedef u_int32_t Elf32_Off; /* Unsigned file offset */
typedef int32_t Elf32_Sword; /* Signed large integer */
typedef u_int32_t Elf32_Word; /* Unsigned large integer */
typedef u_int16_t Elf32_Half; /* Unsigned medium integer */
+typedef u_int64_t Elf64_Addr;
+typedef u_int64_t Elf64_Off;
+typedef int64_t Elf64_Sword;
+typedef int32_t Elf64_Shalf;
+typedef u_int64_t Elf64_Word;
+typedef u_int32_t Elf64_Half;
+typedef u_int16_t Elf64_Quarter;
+
/* e_ident[] identification indexes */
#define EI_MAG0 0 /* file ID */
#define EI_MAG1 1 /* file ID */
@@ -103,6 +108,23 @@ typedef struct elfhdr{
header string table" entry offset */
} Elf32_Ehdr;
+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_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_Ehdr;
+
/* e_type */
#define ET_NONE 0 /* No file type */
#define ET_REL 1 /* relocatable file */
@@ -132,7 +154,8 @@ typedef struct elfhdr{
#define EM_SPARC64 11 /* SPARC v9 64-bit unoffical */
#define EM_PARISC 15 /* HPPA */
#define EM_PPC 20 /* PowerPC */
-#define EM_NUM 13 /* number of machine types */
+#define EM_ALPHA 41 /* DEC ALPHA */
+#define EM_NUM 14 /* number of machine types */
/* Version */
#define EV_NONE 0 /* Invalid */
@@ -154,6 +177,19 @@ typedef struct {
Elf32_Word sh_entsize; /* section entry size */
} Elf32_Shdr;
+typedef struct {
+ Elf64_Half sh_name; /* section name */
+ Elf64_Half sh_type; /* section type */
+ Elf64_Word sh_flags; /* section flags */
+ Elf64_Addr sh_addr; /* virtual address */
+ Elf64_Off sh_offset; /* file offset */
+ Elf64_Word sh_size; /* section size */
+ Elf64_Half sh_link; /* link to another */
+ Elf64_Half sh_info; /* misc info */
+ Elf64_Word sh_addralign; /* memory alignment */
+ Elf64_Word sh_entsize; /* table entry size */
+} Elf64_Shdr;
+
/* Special Section Indexes */
#define SHN_UNDEF 0 /* undefined */
#define SHN_LORESERVE 0xff00 /* lower bounds of reserved indexes */
@@ -223,6 +259,15 @@ typedef struct elf32_sym {
Elf32_Half st_shndx; /* section header index */
} 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_Word st_value; /* value of symbol */
+ Elf64_Word st_size; /* size of symbol */
+} Elf64_Sym;
+
/* Symbol table index */
#define STN_UNDEF 0 /* undefined */
@@ -269,6 +314,21 @@ typedef struct
#define ELF32_R_TYPE(i) ((unsigned char) (i))
#define ELF32_R_INFO(s,t) (((s) << 8) + (unsigned char)(t))
+typedef struct {
+ Elf64_Word r_offset; /* where to do it */
+ Elf64_Word r_info; /* index & type of relocation */
+} Elf64_Rel;
+
+typedef struct {
+ Elf64_Word r_offset; /* where to do it */
+ Elf64_Word r_info; /* index & type of relocation */
+ Elf64_Word r_addend; /* adjustment value */
+} Elf64_RelA;
+
+#define ELF64_R_SYM(info) ((info) >> 32)
+#define ELF64_R_TYPE(info) ((info) & 0xFFFFFFFF)
+#define ELF64_R_INFO(s,t) (((s) << 32) + (u_int32_t)(t))
+
/* Program Header */
typedef struct {
Elf32_Word p_type; /* segment type */
@@ -281,6 +341,17 @@ typedef struct {
Elf32_Word p_align; /* memory alignment */
} Elf32_Phdr;
+typedef struct {
+ Elf64_Half p_type; /* entry type */
+ Elf64_Half p_flags; /* flags */
+ Elf64_Off p_offset; /* offset */
+ Elf64_Addr p_vaddr; /* virtual address */
+ Elf64_Addr p_paddr; /* physical address */
+ Elf64_Word p_filesz; /* file size */
+ Elf64_Word p_memsz; /* memory size */
+ Elf64_Word p_align; /* memory & file alignment */
+} Elf64_Phdr;
+
/* Segment types - p_type */
#define PT_NULL 0 /* unused */
#define PT_LOAD 1 /* loadable segment */
@@ -301,17 +372,23 @@ typedef struct {
/* specific segment flags */
/* Dynamic structure */
-typedef struct
-{
+typedef struct {
Elf32_Sword d_tag; /* controls meaning of d_val */
- union
- {
+ union {
Elf32_Word d_val; /* Multiple meanings - see d_tag */
Elf32_Addr d_ptr; /* program virtual address */
} d_un;
} Elf32_Dyn;
-extern Elf32_Dyn _DYNAMIC[];
+extern Elf32_Dyn _DYNAMIC[]; /* XXX not 64-bit clean */
+
+typedef struct {
+ Elf64_Word d_tag; /* controls meaning of d_val */
+ union {
+ Elf64_Addr d_ptr;
+ Elf64_Word d_val;
+ } d_un;
+} Elf64_Dyn;
/* Dynamic Array Tags - d_tag */
#define DT_NULL 0 /* marks end of _DYNAMIC array */
@@ -356,9 +433,14 @@ unsigned int elf_hash(const unsigned char *name);
#define ELF_AUX_ENTRIES 8 /* Size of aux array passed to loader */
typedef struct {
- int au_id;
- unsigned long au_v;
-} AuxInfo;
+ Elf32_Sword au_id; /* 32-bit id */
+ Elf32_Word au_v; /* 32-bit value */
+} AuxInfo; /* XXX needs to be Aux32Info */
+
+typedef struct {
+ Elf64_Shalf au_id; /* 32-bit id */
+ Elf64_Word au_v; /* 64-bit id */
+} Aux64Info;
enum AuxID {
AUX_null = 0,