| 1 | /*- | 
|---|
| 2 | * Copyright (c) 1996-1998 John D. Polstra. | 
|---|
| 3 | * All rights reserved. | 
|---|
| 4 | * | 
|---|
| 5 | * Redistribution and use in source and binary forms, with or without | 
|---|
| 6 | * modification, are permitted provided that the following conditions | 
|---|
| 7 | * are met: | 
|---|
| 8 | * 1. Redistributions of source code must retain the above copyright | 
|---|
| 9 | *    notice, this list of conditions and the following disclaimer. | 
|---|
| 10 | * 2. Redistributions in binary form must reproduce the above copyright | 
|---|
| 11 | *    notice, this list of conditions and the following disclaimer in the | 
|---|
| 12 | *    documentation and/or other materials provided with the distribution. | 
|---|
| 13 | * | 
|---|
| 14 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND | 
|---|
| 15 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 
|---|
| 16 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | 
|---|
| 17 | * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE | 
|---|
| 18 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | 
|---|
| 19 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | 
|---|
| 20 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | 
|---|
| 21 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | 
|---|
| 22 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | 
|---|
| 23 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | 
|---|
| 24 | * SUCH DAMAGE. | 
|---|
| 25 | * | 
|---|
| 26 | * $FreeBSD: src/sys/sys/elf64.h,v 1.10 2002/05/30 08:32:18 dfr Exp $ | 
|---|
| 27 | */ | 
|---|
| 28 |  | 
|---|
| 29 | #ifndef __kLdrModELF64_h__ | 
|---|
| 30 | #define __kLdrModELF64_h__ | 
|---|
| 31 |  | 
|---|
| 32 | #include "kLdrBase.h" | 
|---|
| 33 | #include "kLdrModELFCommon.h" | 
|---|
| 34 |  | 
|---|
| 35 | /* | 
|---|
| 36 | * ELF definitions common to all 64-bit architectures. | 
|---|
| 37 | */ | 
|---|
| 38 |  | 
|---|
| 39 | typedef uint64_t        Elf64_Addr; | 
|---|
| 40 | typedef uint32_t        Elf64_Half; | 
|---|
| 41 | typedef uint64_t        Elf64_Off; | 
|---|
| 42 | typedef int64_t         Elf64_Sword; | 
|---|
| 43 | typedef uint64_t        Elf64_Word; | 
|---|
| 44 | typedef uint64_t        Elf64_Size; | 
|---|
| 45 | typedef uint16_t        Elf64_Quarter; | 
|---|
| 46 |  | 
|---|
| 47 | /* | 
|---|
| 48 | * Types of dynamic symbol hash table bucket and chain elements. | 
|---|
| 49 | * | 
|---|
| 50 | * This is inconsistent among 64 bit architectures, so a machine dependent | 
|---|
| 51 | * typedef is required. | 
|---|
| 52 | */ | 
|---|
| 53 |  | 
|---|
| 54 | #ifdef __alpha__ | 
|---|
| 55 | typedef Elf64_Off       Elf64_Hashelt; | 
|---|
| 56 | #else | 
|---|
| 57 | typedef Elf64_Half      Elf64_Hashelt; | 
|---|
| 58 | #endif | 
|---|
| 59 |  | 
|---|
| 60 | /* | 
|---|
| 61 | * ELF header. | 
|---|
| 62 | */ | 
|---|
| 63 |  | 
|---|
| 64 | typedef struct { | 
|---|
| 65 | unsigned char   e_ident[EI_NIDENT];     /* File identification. */ | 
|---|
| 66 | Elf64_Quarter   e_type;         /* File type. */ | 
|---|
| 67 | Elf64_Quarter   e_machine;      /* Machine architecture. */ | 
|---|
| 68 | Elf64_Half      e_version;      /* ELF format version. */ | 
|---|
| 69 | Elf64_Addr      e_entry;        /* Entry point. */ | 
|---|
| 70 | Elf64_Off       e_phoff;        /* Program header file offset. */ | 
|---|
| 71 | Elf64_Off       e_shoff;        /* Section header file offset. */ | 
|---|
| 72 | Elf64_Half      e_flags;        /* Architecture-specific flags. */ | 
|---|
| 73 | Elf64_Quarter   e_ehsize;       /* Size of ELF header in bytes. */ | 
|---|
| 74 | Elf64_Quarter   e_phentsize;    /* Size of program header entry. */ | 
|---|
| 75 | Elf64_Quarter   e_phnum;        /* Number of program header entries. */ | 
|---|
| 76 | Elf64_Quarter   e_shentsize;    /* Size of section header entry. */ | 
|---|
| 77 | Elf64_Quarter   e_shnum;        /* Number of section header entries. */ | 
|---|
| 78 | Elf64_Quarter   e_shstrndx;     /* Section name strings section. */ | 
|---|
| 79 | } Elf64_Ehdr; | 
|---|
| 80 |  | 
|---|
| 81 | /* | 
|---|
| 82 | * Section header. | 
|---|
| 83 | */ | 
|---|
| 84 |  | 
|---|
| 85 | typedef struct { | 
|---|
| 86 | Elf64_Half      sh_name;        /* Section name (index into the | 
|---|
| 87 | section header string table). */ | 
|---|
| 88 | Elf64_Half      sh_type;        /* Section type. */ | 
|---|
| 89 | Elf64_Size      sh_flags;       /* Section flags. */ | 
|---|
| 90 | Elf64_Addr      sh_addr;        /* Address in memory image. */ | 
|---|
| 91 | Elf64_Off       sh_offset;      /* Offset in file. */ | 
|---|
| 92 | Elf64_Size      sh_size;        /* Size in bytes. */ | 
|---|
| 93 | Elf64_Half      sh_link;        /* Index of a related section. */ | 
|---|
| 94 | Elf64_Half      sh_info;        /* Depends on section type. */ | 
|---|
| 95 | Elf64_Size      sh_addralign;   /* Alignment in bytes. */ | 
|---|
| 96 | Elf64_Size      sh_entsize;     /* Size of each entry in section. */ | 
|---|
| 97 | } Elf64_Shdr; | 
|---|
| 98 |  | 
|---|
| 99 | /* | 
|---|
| 100 | * Program header. | 
|---|
| 101 | */ | 
|---|
| 102 |  | 
|---|
| 103 | typedef struct { | 
|---|
| 104 | Elf64_Half      p_type;         /* Entry type. */ | 
|---|
| 105 | Elf64_Half      p_flags;        /* Access permission flags. */ | 
|---|
| 106 | Elf64_Off       p_offset;       /* File offset of contents. */ | 
|---|
| 107 | Elf64_Addr      p_vaddr;        /* Virtual address in memory image. */ | 
|---|
| 108 | Elf64_Addr      p_paddr;        /* Physical address (not used). */ | 
|---|
| 109 | Elf64_Size      p_filesz;       /* Size of contents in file. */ | 
|---|
| 110 | Elf64_Size      p_memsz;        /* Size of contents in memory. */ | 
|---|
| 111 | Elf64_Size      p_align;        /* Alignment in memory and file. */ | 
|---|
| 112 | } Elf64_Phdr; | 
|---|
| 113 |  | 
|---|
| 114 | /* | 
|---|
| 115 | * Dynamic structure.  The ".dynamic" section contains an array of them. | 
|---|
| 116 | */ | 
|---|
| 117 |  | 
|---|
| 118 | typedef struct { | 
|---|
| 119 | Elf64_Size      d_tag;          /* Entry type. */ | 
|---|
| 120 | union { | 
|---|
| 121 | Elf64_Size      d_val;  /* Integer value. */ | 
|---|
| 122 | Elf64_Addr      d_ptr;  /* Address value. */ | 
|---|
| 123 | } d_un; | 
|---|
| 124 | } Elf64_Dyn; | 
|---|
| 125 |  | 
|---|
| 126 | /* | 
|---|
| 127 | * Relocation entries. | 
|---|
| 128 | */ | 
|---|
| 129 |  | 
|---|
| 130 | /* Relocations that don't need an addend field. */ | 
|---|
| 131 | typedef struct { | 
|---|
| 132 | Elf64_Addr      r_offset;       /* Location to be relocated. */ | 
|---|
| 133 | Elf64_Size      r_info;         /* Relocation type and symbol index. */ | 
|---|
| 134 | } Elf64_Rel; | 
|---|
| 135 |  | 
|---|
| 136 | /* Relocations that need an addend field. */ | 
|---|
| 137 | typedef struct { | 
|---|
| 138 | Elf64_Addr      r_offset;       /* Location to be relocated. */ | 
|---|
| 139 | Elf64_Size      r_info;         /* Relocation type and symbol index. */ | 
|---|
| 140 | Elf64_Off       r_addend;       /* Addend. */ | 
|---|
| 141 | } Elf64_Rela; | 
|---|
| 142 |  | 
|---|
| 143 | /* Macros for accessing the fields of r_info. */ | 
|---|
| 144 | #define ELF64_R_SYM(info)       ((info) >> 32) | 
|---|
| 145 | #define ELF64_R_TYPE(info)      ((unsigned char)(info)) | 
|---|
| 146 |  | 
|---|
| 147 | /* Macro for constructing r_info from field values. */ | 
|---|
| 148 | #define ELF64_R_INFO(sym, type) (((sym) << 32) + (unsigned char)(type)) | 
|---|
| 149 |  | 
|---|
| 150 | /* | 
|---|
| 151 | * Symbol table entries. | 
|---|
| 152 | */ | 
|---|
| 153 |  | 
|---|
| 154 | typedef struct { | 
|---|
| 155 | Elf64_Half      st_name;        /* String table index of name. */ | 
|---|
| 156 | unsigned char   st_info;        /* Type and binding information. */ | 
|---|
| 157 | unsigned char   st_other;       /* Reserved (not used). */ | 
|---|
| 158 | Elf64_Quarter   st_shndx;       /* Section index of symbol. */ | 
|---|
| 159 | Elf64_Addr      st_value;       /* Symbol value. */ | 
|---|
| 160 | Elf64_Size      st_size;        /* Size of associated object. */ | 
|---|
| 161 | } Elf64_Sym; | 
|---|
| 162 |  | 
|---|
| 163 | /* Macros for accessing the fields of st_info. */ | 
|---|
| 164 | #define ELF64_ST_BIND(info)             ((info) >> 4) | 
|---|
| 165 | #define ELF64_ST_TYPE(info)             ((info) & 0xf) | 
|---|
| 166 |  | 
|---|
| 167 | /* Macro for constructing st_info from field values. */ | 
|---|
| 168 | #define ELF64_ST_INFO(bind, type)       (((bind) << 4) + ((type) & 0xf)) | 
|---|
| 169 |  | 
|---|
| 170 | #endif | 
|---|
| 171 |  | 
|---|