1 // elfcpp_internal.h -- internals for elfcpp -*- C++ -*- 2 3 // Copyright (C) 2006-2016 Free Software Foundation, Inc. 4 // Written by Ian Lance Taylor <iant (at) google.com>. 5 6 // This file is part of elfcpp. 7 8 // This program is free software; you can redistribute it and/or 9 // modify it under the terms of the GNU Library General Public License 10 // as published by the Free Software Foundation; either version 2, or 11 // (at your option) any later version. 12 13 // In addition to the permissions in the GNU Library General Public 14 // License, the Free Software Foundation gives you unlimited 15 // permission to link the compiled version of this file into 16 // combinations with other programs, and to distribute those 17 // combinations without any restriction coming from the use of this 18 // file. (The Library Public License restrictions do apply in other 19 // respects; for example, they cover modification of the file, and 20 /// distribution when not linked into a combined executable.) 21 22 // This program is distributed in the hope that it will be useful, but 23 // WITHOUT ANY WARRANTY; without even the implied warranty of 24 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 25 // Library General Public License for more details. 26 27 // You should have received a copy of the GNU Library General Public 28 // License along with this program; if not, write to the Free Software 29 // Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 30 // 02110-1301, USA. 31 32 // This is included by elfcpp.h, the external interface, but holds 33 // information which we want to keep private. 34 35 #ifndef ELFCPP_INTERNAL_H 36 #define ELFCPP_INTERNAL_H 37 38 namespace elfcpp 39 { 40 41 namespace internal 42 { 43 44 // The ELF file header. 45 46 template<int size> 47 struct Ehdr_data 48 { 49 unsigned char e_ident[EI_NIDENT]; 50 Elf_Half e_type; 51 Elf_Half e_machine; 52 Elf_Word e_version; 53 typename Elf_types<size>::Elf_Addr e_entry; 54 typename Elf_types<size>::Elf_Off e_phoff; 55 typename Elf_types<size>::Elf_Off e_shoff; 56 Elf_Word e_flags; 57 Elf_Half e_ehsize; 58 Elf_Half e_phentsize; 59 Elf_Half e_phnum; 60 Elf_Half e_shentsize; 61 Elf_Half e_shnum; 62 Elf_Half e_shstrndx; 63 }; 64 65 // An ELF section header. 66 67 template<int size> 68 struct Shdr_data 69 { 70 Elf_Word sh_name; 71 Elf_Word sh_type; 72 typename Elf_types<size>::Elf_WXword sh_flags; 73 typename Elf_types<size>::Elf_Addr sh_addr; 74 typename Elf_types<size>::Elf_Off sh_offset; 75 typename Elf_types<size>::Elf_WXword sh_size; 76 Elf_Word sh_link; 77 Elf_Word sh_info; 78 typename Elf_types<size>::Elf_WXword sh_addralign; 79 typename Elf_types<size>::Elf_WXword sh_entsize; 80 }; 81 82 // An ELF compression header. 83 84 template<int size> 85 struct Chdr_data; 86 87 template<> 88 struct Chdr_data<32> 89 { 90 Elf_Word ch_type; 91 Elf_Word ch_size; 92 Elf_Word ch_addralign; 93 }; 94 95 template<> 96 struct Chdr_data<64> 97 { 98 Elf_Word ch_type; 99 Elf_Word ch_reserved; 100 Elf_Xword ch_size; 101 Elf_Xword ch_addralign; 102 }; 103 104 // An ELF segment header. We use template specialization for the 105 // 32-bit and 64-bit versions because the fields are in a different 106 // order. 107 108 template<int size> 109 struct Phdr_data; 110 111 template<> 112 struct Phdr_data<32> 113 { 114 Elf_Word p_type; 115 Elf_types<32>::Elf_Off p_offset; 116 Elf_types<32>::Elf_Addr p_vaddr; 117 Elf_types<32>::Elf_Addr p_paddr; 118 Elf_Word p_filesz; 119 Elf_Word p_memsz; 120 Elf_Word p_flags; 121 Elf_Word p_align; 122 }; 123 124 template<> 125 struct Phdr_data<64> 126 { 127 Elf_Word p_type; 128 Elf_Word p_flags; 129 Elf_types<64>::Elf_Off p_offset; 130 Elf_types<64>::Elf_Addr p_vaddr; 131 Elf_types<64>::Elf_Addr p_paddr; 132 Elf_Xword p_filesz; 133 Elf_Xword p_memsz; 134 Elf_Xword p_align; 135 }; 136 137 // An ELF symbol table entry. We use template specialization for the 138 // 32-bit and 64-bit versions because the fields are in a different 139 // order. 140 141 template<int size> 142 struct Sym_data; 143 144 template<> 145 struct Sym_data<32> 146 { 147 Elf_Word st_name; 148 Elf_types<32>::Elf_Addr st_value; 149 Elf_Word st_size; 150 unsigned char st_info; 151 unsigned char st_other; 152 Elf_Half st_shndx; 153 }; 154 155 template<> 156 struct Sym_data<64> 157 { 158 Elf_Word st_name; 159 unsigned char st_info; 160 unsigned char st_other; 161 Elf_Half st_shndx; 162 Elf_types<64>::Elf_Addr st_value; 163 Elf_Xword st_size; 164 }; 165 166 // ELF relocation table entries. 167 168 template<int size> 169 struct Rel_data 170 { 171 typename Elf_types<size>::Elf_Addr r_offset; 172 typename Elf_types<size>::Elf_WXword r_info; 173 }; 174 175 template<int size> 176 struct Rela_data 177 { 178 typename Elf_types<size>::Elf_Addr r_offset; 179 typename Elf_types<size>::Elf_WXword r_info; 180 typename Elf_types<size>::Elf_Swxword r_addend; 181 }; 182 183 template<int size> 184 struct Relr_data 185 { 186 typename Elf_types<size>::Elf_WXword r_data; 187 }; 188 189 // MIPS-64 has a non-standard layout for relocations. 190 191 struct Mips64_rel_data 192 { 193 Elf_types<64>::Elf_Addr r_offset; 194 Elf_Word r_sym; 195 unsigned char r_ssym; 196 unsigned char r_type3; 197 unsigned char r_type2; 198 unsigned char r_type; 199 }; 200 201 struct Mips64_rela_data 202 { 203 Elf_types<64>::Elf_Addr r_offset; 204 Elf_Word r_sym; 205 unsigned char r_ssym; 206 unsigned char r_type3; 207 unsigned char r_type2; 208 unsigned char r_type; 209 Elf_types<64>::Elf_Swxword r_addend; 210 }; 211 212 // An entry in the ELF SHT_DYNAMIC section aka PT_DYNAMIC segment. 213 214 template<int size> 215 struct Dyn_data 216 { 217 typename Elf_types<size>::Elf_Swxword d_tag; 218 typename Elf_types<size>::Elf_WXword d_val; 219 }; 220 221 // An entry in a SHT_GNU_verdef section. This structure is the same 222 // in 32-bit and 64-bit ELF files. 223 224 struct Verdef_data 225 { 226 // Version number of structure (VER_DEF_*). 227 Elf_Half vd_version; 228 // Bit flags (VER_FLG_*). 229 Elf_Half vd_flags; 230 // Version index. 231 Elf_Half vd_ndx; 232 // Number of auxiliary Verdaux entries. 233 Elf_Half vd_cnt; 234 // Hash of name. 235 Elf_Word vd_hash; 236 // Byte offset to first Verdaux entry. 237 Elf_Word vd_aux; 238 // Byte offset to next Verdef entry. 239 Elf_Word vd_next; 240 }; 241 242 // An auxiliary entry in a SHT_GNU_verdef section. This structure is 243 // the same in 32-bit and 64-bit ELF files. 244 245 struct Verdaux_data 246 { 247 // Offset in string table of version name. 248 Elf_Word vda_name; 249 // Byte offset to next Verdaux entry. 250 Elf_Word vda_next; 251 }; 252 253 // An entry in a SHT_GNU_verneed section. This structure is the same 254 // in 32-bit and 64-bit ELF files. 255 256 struct Verneed_data 257 { 258 // Version number of structure (VER_NEED_*). 259 Elf_Half vn_version; 260 // Number of auxiliary Vernaux entries. 261 Elf_Half vn_cnt; 262 // Offset in string table of library name. 263 Elf_Word vn_file; 264 // Byte offset to first Vernaux entry. 265 Elf_Word vn_aux; 266 // Byt eoffset to next Verneed entry. 267 Elf_Word vn_next; 268 }; 269 270 // An auxiliary entry in a SHT_GNU_verneed section. This structure is 271 // the same in 32-bit and 64-bit ELF files. 272 273 struct Vernaux_data 274 { 275 // Hash of dependency name. 276 Elf_Word vna_hash; 277 // Bit flags (VER_FLG_*). 278 Elf_Half vna_flags; 279 // Version index used in SHT_GNU_versym entries. 280 Elf_Half vna_other; 281 // Offset in string table of version name. 282 Elf_Word vna_name; 283 // Byte offset to next Vernaux entry. 284 Elf_Word vna_next; 285 }; 286 287 } // End namespace internal. 288 289 } // End namespace elfcpp. 290 291 #endif // !defined(ELFCPP_INTERNAL_H) 292