1 //===- ELFDumper.cpp - ELF-specific dumper --------------------------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 /// 10 /// \file 11 /// This file implements the ELF-specific dumper for llvm-readobj. 12 /// 13 //===----------------------------------------------------------------------===// 14 15 #include "ARMEHABIPrinter.h" 16 #include "DwarfCFIEHPrinter.h" 17 #include "Error.h" 18 #include "ObjDumper.h" 19 #include "StackMapPrinter.h" 20 #include "llvm-readobj.h" 21 #include "llvm/ADT/ArrayRef.h" 22 #include "llvm/ADT/DenseMap.h" 23 #include "llvm/ADT/Optional.h" 24 #include "llvm/ADT/PointerIntPair.h" 25 #include "llvm/ADT/STLExtras.h" 26 #include "llvm/ADT/SmallString.h" 27 #include "llvm/ADT/SmallVector.h" 28 #include "llvm/ADT/StringExtras.h" 29 #include "llvm/ADT/StringRef.h" 30 #include "llvm/ADT/Twine.h" 31 #include "llvm/BinaryFormat/ELF.h" 32 #include "llvm/Object/ELF.h" 33 #include "llvm/Object/ELFObjectFile.h" 34 #include "llvm/Object/ELFTypes.h" 35 #include "llvm/Object/Error.h" 36 #include "llvm/Object/ObjectFile.h" 37 #include "llvm/Object/StackMapParser.h" 38 #include "llvm/Support/AMDGPUMetadata.h" 39 #include "llvm/Support/ARMAttributeParser.h" 40 #include "llvm/Support/ARMBuildAttributes.h" 41 #include "llvm/Support/Casting.h" 42 #include "llvm/Support/Compiler.h" 43 #include "llvm/Support/Endian.h" 44 #include "llvm/Support/ErrorHandling.h" 45 #include "llvm/Support/Format.h" 46 #include "llvm/Support/FormatVariadic.h" 47 #include "llvm/Support/FormattedStream.h" 48 #include "llvm/Support/LEB128.h" 49 #include "llvm/Support/MathExtras.h" 50 #include "llvm/Support/MipsABIFlags.h" 51 #include "llvm/Support/ScopedPrinter.h" 52 #include "llvm/Support/raw_ostream.h" 53 #include <algorithm> 54 #include <cinttypes> 55 #include <cstddef> 56 #include <cstdint> 57 #include <cstdlib> 58 #include <iterator> 59 #include <memory> 60 #include <string> 61 #include <system_error> 62 #include <vector> 63 64 using namespace llvm; 65 using namespace llvm::object; 66 using namespace ELF; 67 68 #define LLVM_READOBJ_ENUM_CASE(ns, enum) \ 69 case ns::enum: return #enum; 70 71 #define ENUM_ENT(enum, altName) \ 72 { #enum, altName, ELF::enum } 73 74 #define ENUM_ENT_1(enum) \ 75 { #enum, #enum, ELF::enum } 76 77 #define LLVM_READOBJ_PHDR_ENUM(ns, enum) \ 78 case ns::enum: \ 79 return std::string(#enum).substr(3); 80 81 #define TYPEDEF_ELF_TYPES(ELFT) \ 82 using ELFO = ELFFile<ELFT>; \ 83 using Elf_Addr = typename ELFT::Addr; \ 84 using Elf_Shdr = typename ELFT::Shdr; \ 85 using Elf_Sym = typename ELFT::Sym; \ 86 using Elf_Dyn = typename ELFT::Dyn; \ 87 using Elf_Dyn_Range = typename ELFT::DynRange; \ 88 using Elf_Rel = typename ELFT::Rel; \ 89 using Elf_Rela = typename ELFT::Rela; \ 90 using Elf_Relr = typename ELFT::Relr; \ 91 using Elf_Rel_Range = typename ELFT::RelRange; \ 92 using Elf_Rela_Range = typename ELFT::RelaRange; \ 93 using Elf_Relr_Range = typename ELFT::RelrRange; \ 94 using Elf_Phdr = typename ELFT::Phdr; \ 95 using Elf_Half = typename ELFT::Half; \ 96 using Elf_Ehdr = typename ELFT::Ehdr; \ 97 using Elf_Word = typename ELFT::Word; \ 98 using Elf_Hash = typename ELFT::Hash; \ 99 using Elf_GnuHash = typename ELFT::GnuHash; \ 100 using Elf_Note = typename ELFT::Note; \ 101 using Elf_Sym_Range = typename ELFT::SymRange; \ 102 using Elf_Versym = typename ELFT::Versym; \ 103 using Elf_Verneed = typename ELFT::Verneed; \ 104 using Elf_Vernaux = typename ELFT::Vernaux; \ 105 using Elf_Verdef = typename ELFT::Verdef; \ 106 using Elf_Verdaux = typename ELFT::Verdaux; \ 107 using Elf_CGProfile = typename ELFT::CGProfile; \ 108 using uintX_t = typename ELFT::uint; 109 110 namespace { 111 112 template <class ELFT> class DumpStyle; 113 114 /// Represents a contiguous uniform range in the file. We cannot just create a 115 /// range directly because when creating one of these from the .dynamic table 116 /// the size, entity size and virtual address are different entries in arbitrary 117 /// order (DT_REL, DT_RELSZ, DT_RELENT for example). 118 struct DynRegionInfo { 119 DynRegionInfo() = default; 120 DynRegionInfo(const void *A, uint64_t S, uint64_t ES) 121 : Addr(A), Size(S), EntSize(ES) {} 122 123 /// Address in current address space. 124 const void *Addr = nullptr; 125 /// Size in bytes of the region. 126 uint64_t Size = 0; 127 /// Size of each entity in the region. 128 uint64_t EntSize = 0; 129 130 template <typename Type> ArrayRef<Type> getAsArrayRef() const { 131 const Type *Start = reinterpret_cast<const Type *>(Addr); 132 if (!Start) 133 return {Start, Start}; 134 if (EntSize != sizeof(Type) || Size % EntSize) 135 reportError("Invalid entity size"); 136 return {Start, Start + (Size / EntSize)}; 137 } 138 }; 139 140 template<typename ELFT> 141 class ELFDumper : public ObjDumper { 142 public: 143 ELFDumper(const ELFFile<ELFT> *Obj, ScopedPrinter &Writer); 144 145 void printFileHeaders() override; 146 void printSectionHeaders() override; 147 void printRelocations() override; 148 void printDynamicRelocations() override; 149 void printSymbols() override; 150 void printDynamicSymbols() override; 151 void printUnwindInfo() override; 152 153 void printDynamicTable() override; 154 void printNeededLibraries() override; 155 void printProgramHeaders() override; 156 void printHashTable() override; 157 void printGnuHashTable() override; 158 void printLoadName() override; 159 void printVersionInfo() override; 160 void printGroupSections() override; 161 162 void printAttributes() override; 163 void printMipsPLTGOT() override; 164 void printMipsABIFlags() override; 165 void printMipsReginfo() override; 166 void printMipsOptions() override; 167 168 void printStackMap() const override; 169 170 void printHashHistogram() override; 171 172 void printCGProfile() override; 173 void printAddrsig() override; 174 175 void printNotes() override; 176 177 void printELFLinkerOptions() override; 178 179 private: 180 std::unique_ptr<DumpStyle<ELFT>> ELFDumperStyle; 181 182 TYPEDEF_ELF_TYPES(ELFT) 183 184 DynRegionInfo checkDRI(DynRegionInfo DRI) { 185 if (DRI.Addr < Obj->base() || 186 (const uint8_t *)DRI.Addr + DRI.Size > Obj->base() + Obj->getBufSize()) 187 error(llvm::object::object_error::parse_failed); 188 return DRI; 189 } 190 191 DynRegionInfo createDRIFrom(const Elf_Phdr *P, uintX_t EntSize) { 192 return checkDRI({Obj->base() + P->p_offset, P->p_filesz, EntSize}); 193 } 194 195 DynRegionInfo createDRIFrom(const Elf_Shdr *S) { 196 return checkDRI({Obj->base() + S->sh_offset, S->sh_size, S->sh_entsize}); 197 } 198 199 void parseDynamicTable(ArrayRef<const Elf_Phdr *> LoadSegments); 200 201 void printValue(uint64_t Type, uint64_t Value); 202 203 StringRef getDynamicString(uint64_t Offset) const; 204 StringRef getSymbolVersion(StringRef StrTab, const Elf_Sym *symb, 205 bool &IsDefault) const; 206 void LoadVersionMap() const; 207 void LoadVersionNeeds(const Elf_Shdr *ec) const; 208 void LoadVersionDefs(const Elf_Shdr *sec) const; 209 210 const ELFO *Obj; 211 DynRegionInfo DynRelRegion; 212 DynRegionInfo DynRelaRegion; 213 DynRegionInfo DynRelrRegion; 214 DynRegionInfo DynPLTRelRegion; 215 DynRegionInfo DynSymRegion; 216 DynRegionInfo DynamicTable; 217 StringRef DynamicStringTable; 218 StringRef SOName; 219 const Elf_Hash *HashTable = nullptr; 220 const Elf_GnuHash *GnuHashTable = nullptr; 221 const Elf_Shdr *DotSymtabSec = nullptr; 222 const Elf_Shdr *DotCGProfileSec = nullptr; 223 const Elf_Shdr *DotAddrsigSec = nullptr; 224 StringRef DynSymtabName; 225 ArrayRef<Elf_Word> ShndxTable; 226 227 const Elf_Shdr *dot_gnu_version_sec = nullptr; // .gnu.version 228 const Elf_Shdr *dot_gnu_version_r_sec = nullptr; // .gnu.version_r 229 const Elf_Shdr *dot_gnu_version_d_sec = nullptr; // .gnu.version_d 230 231 // Records for each version index the corresponding Verdef or Vernaux entry. 232 // This is filled the first time LoadVersionMap() is called. 233 class VersionMapEntry : public PointerIntPair<const void *, 1> { 234 public: 235 // If the integer is 0, this is an Elf_Verdef*. 236 // If the integer is 1, this is an Elf_Vernaux*. 237 VersionMapEntry() : PointerIntPair<const void *, 1>(nullptr, 0) {} 238 VersionMapEntry(const Elf_Verdef *verdef) 239 : PointerIntPair<const void *, 1>(verdef, 0) {} 240 VersionMapEntry(const Elf_Vernaux *vernaux) 241 : PointerIntPair<const void *, 1>(vernaux, 1) {} 242 243 bool isNull() const { return getPointer() == nullptr; } 244 bool isVerdef() const { return !isNull() && getInt() == 0; } 245 bool isVernaux() const { return !isNull() && getInt() == 1; } 246 const Elf_Verdef *getVerdef() const { 247 return isVerdef() ? (const Elf_Verdef *)getPointer() : nullptr; 248 } 249 const Elf_Vernaux *getVernaux() const { 250 return isVernaux() ? (const Elf_Vernaux *)getPointer() : nullptr; 251 } 252 }; 253 mutable SmallVector<VersionMapEntry, 16> VersionMap; 254 255 public: 256 Elf_Dyn_Range dynamic_table() const { 257 return DynamicTable.getAsArrayRef<Elf_Dyn>(); 258 } 259 260 Elf_Sym_Range dynamic_symbols() const { 261 return DynSymRegion.getAsArrayRef<Elf_Sym>(); 262 } 263 264 Elf_Rel_Range dyn_rels() const; 265 Elf_Rela_Range dyn_relas() const; 266 Elf_Relr_Range dyn_relrs() const; 267 std::string getFullSymbolName(const Elf_Sym *Symbol, StringRef StrTable, 268 bool IsDynamic) const; 269 void getSectionNameIndex(const Elf_Sym *Symbol, const Elf_Sym *FirstSym, 270 StringRef &SectionName, 271 unsigned &SectionIndex) const; 272 StringRef getStaticSymbolName(uint32_t Index) const; 273 274 void printSymbolsHelper(bool IsDynamic) const; 275 const Elf_Shdr *getDotSymtabSec() const { return DotSymtabSec; } 276 const Elf_Shdr *getDotCGProfileSec() const { return DotCGProfileSec; } 277 const Elf_Shdr *getDotAddrsigSec() const { return DotAddrsigSec; } 278 ArrayRef<Elf_Word> getShndxTable() const { return ShndxTable; } 279 StringRef getDynamicStringTable() const { return DynamicStringTable; } 280 const DynRegionInfo &getDynRelRegion() const { return DynRelRegion; } 281 const DynRegionInfo &getDynRelaRegion() const { return DynRelaRegion; } 282 const DynRegionInfo &getDynRelrRegion() const { return DynRelrRegion; } 283 const DynRegionInfo &getDynPLTRelRegion() const { return DynPLTRelRegion; } 284 const Elf_Hash *getHashTable() const { return HashTable; } 285 const Elf_GnuHash *getGnuHashTable() const { return GnuHashTable; } 286 }; 287 288 template <class ELFT> 289 void ELFDumper<ELFT>::printSymbolsHelper(bool IsDynamic) const { 290 StringRef StrTable, SymtabName; 291 size_t Entries = 0; 292 Elf_Sym_Range Syms(nullptr, nullptr); 293 if (IsDynamic) { 294 StrTable = DynamicStringTable; 295 Syms = dynamic_symbols(); 296 SymtabName = DynSymtabName; 297 if (DynSymRegion.Addr) 298 Entries = DynSymRegion.Size / DynSymRegion.EntSize; 299 } else { 300 if (!DotSymtabSec) 301 return; 302 StrTable = unwrapOrError(Obj->getStringTableForSymtab(*DotSymtabSec)); 303 Syms = unwrapOrError(Obj->symbols(DotSymtabSec)); 304 SymtabName = unwrapOrError(Obj->getSectionName(DotSymtabSec)); 305 Entries = DotSymtabSec->getEntityCount(); 306 } 307 if (Syms.begin() == Syms.end()) 308 return; 309 ELFDumperStyle->printSymtabMessage(Obj, SymtabName, Entries); 310 for (const auto &Sym : Syms) 311 ELFDumperStyle->printSymbol(Obj, &Sym, Syms.begin(), StrTable, IsDynamic); 312 } 313 314 template <class ELFT> class MipsGOTParser; 315 316 template <typename ELFT> class DumpStyle { 317 public: 318 using Elf_Shdr = typename ELFT::Shdr; 319 using Elf_Sym = typename ELFT::Sym; 320 321 DumpStyle(ELFDumper<ELFT> *Dumper) : Dumper(Dumper) {} 322 virtual ~DumpStyle() = default; 323 324 virtual void printFileHeaders(const ELFFile<ELFT> *Obj) = 0; 325 virtual void printGroupSections(const ELFFile<ELFT> *Obj) = 0; 326 virtual void printRelocations(const ELFFile<ELFT> *Obj) = 0; 327 virtual void printSectionHeaders(const ELFFile<ELFT> *Obj) = 0; 328 virtual void printSymbols(const ELFFile<ELFT> *Obj) = 0; 329 virtual void printDynamicSymbols(const ELFFile<ELFT> *Obj) = 0; 330 virtual void printDynamicRelocations(const ELFFile<ELFT> *Obj) = 0; 331 virtual void printSymtabMessage(const ELFFile<ELFT> *obj, StringRef Name, 332 size_t Offset) {} 333 virtual void printSymbol(const ELFFile<ELFT> *Obj, const Elf_Sym *Symbol, 334 const Elf_Sym *FirstSym, StringRef StrTable, 335 bool IsDynamic) = 0; 336 virtual void printProgramHeaders(const ELFFile<ELFT> *Obj) = 0; 337 virtual void printHashHistogram(const ELFFile<ELFT> *Obj) = 0; 338 virtual void printCGProfile(const ELFFile<ELFT> *Obj) = 0; 339 virtual void printAddrsig(const ELFFile<ELFT> *Obj) = 0; 340 virtual void printNotes(const ELFFile<ELFT> *Obj) = 0; 341 virtual void printELFLinkerOptions(const ELFFile<ELFT> *Obj) = 0; 342 virtual void printMipsGOT(const MipsGOTParser<ELFT> &Parser) = 0; 343 virtual void printMipsPLT(const MipsGOTParser<ELFT> &Parser) = 0; 344 const ELFDumper<ELFT> *dumper() const { return Dumper; } 345 346 private: 347 const ELFDumper<ELFT> *Dumper; 348 }; 349 350 template <typename ELFT> class GNUStyle : public DumpStyle<ELFT> { 351 formatted_raw_ostream OS; 352 353 public: 354 TYPEDEF_ELF_TYPES(ELFT) 355 356 GNUStyle(ScopedPrinter &W, ELFDumper<ELFT> *Dumper) 357 : DumpStyle<ELFT>(Dumper), OS(W.getOStream()) {} 358 359 void printFileHeaders(const ELFO *Obj) override; 360 void printGroupSections(const ELFFile<ELFT> *Obj) override; 361 void printRelocations(const ELFO *Obj) override; 362 void printSectionHeaders(const ELFO *Obj) override; 363 void printSymbols(const ELFO *Obj) override; 364 void printDynamicSymbols(const ELFO *Obj) override; 365 void printDynamicRelocations(const ELFO *Obj) override; 366 void printSymtabMessage(const ELFO *Obj, StringRef Name, 367 size_t Offset) override; 368 void printProgramHeaders(const ELFO *Obj) override; 369 void printHashHistogram(const ELFFile<ELFT> *Obj) override; 370 void printCGProfile(const ELFFile<ELFT> *Obj) override; 371 void printAddrsig(const ELFFile<ELFT> *Obj) override; 372 void printNotes(const ELFFile<ELFT> *Obj) override; 373 void printELFLinkerOptions(const ELFFile<ELFT> *Obj) override; 374 void printMipsGOT(const MipsGOTParser<ELFT> &Parser) override; 375 void printMipsPLT(const MipsGOTParser<ELFT> &Parser) override; 376 377 private: 378 struct Field { 379 StringRef Str; 380 unsigned Column; 381 382 Field(StringRef S, unsigned Col) : Str(S), Column(Col) {} 383 Field(unsigned Col) : Str(""), Column(Col) {} 384 }; 385 386 template <typename T, typename TEnum> 387 std::string printEnum(T Value, ArrayRef<EnumEntry<TEnum>> EnumValues) { 388 for (const auto &EnumItem : EnumValues) 389 if (EnumItem.Value == Value) 390 return EnumItem.AltName; 391 return to_hexString(Value, false); 392 } 393 394 template <typename T, typename TEnum> 395 std::string printFlags(T Value, ArrayRef<EnumEntry<TEnum>> EnumValues, 396 TEnum EnumMask1 = {}, TEnum EnumMask2 = {}, 397 TEnum EnumMask3 = {}) { 398 std::string Str; 399 for (const auto &Flag : EnumValues) { 400 if (Flag.Value == 0) 401 continue; 402 403 TEnum EnumMask{}; 404 if (Flag.Value & EnumMask1) 405 EnumMask = EnumMask1; 406 else if (Flag.Value & EnumMask2) 407 EnumMask = EnumMask2; 408 else if (Flag.Value & EnumMask3) 409 EnumMask = EnumMask3; 410 bool IsEnum = (Flag.Value & EnumMask) != 0; 411 if ((!IsEnum && (Value & Flag.Value) == Flag.Value) || 412 (IsEnum && (Value & EnumMask) == Flag.Value)) { 413 if (!Str.empty()) 414 Str += ", "; 415 Str += Flag.AltName; 416 } 417 } 418 return Str; 419 } 420 421 formatted_raw_ostream &printField(struct Field F) { 422 if (F.Column != 0) 423 OS.PadToColumn(F.Column); 424 OS << F.Str; 425 OS.flush(); 426 return OS; 427 } 428 void printHashedSymbol(const ELFO *Obj, const Elf_Sym *FirstSym, uint32_t Sym, 429 StringRef StrTable, uint32_t Bucket); 430 void printRelocHeader(unsigned SType); 431 void printRelocation(const ELFO *Obj, const Elf_Shdr *SymTab, 432 const Elf_Rela &R, bool IsRela); 433 void printSymbol(const ELFO *Obj, const Elf_Sym *Symbol, const Elf_Sym *First, 434 StringRef StrTable, bool IsDynamic) override; 435 std::string getSymbolSectionNdx(const ELFO *Obj, const Elf_Sym *Symbol, 436 const Elf_Sym *FirstSym); 437 void printDynamicRelocation(const ELFO *Obj, Elf_Rela R, bool IsRela); 438 bool checkTLSSections(const Elf_Phdr &Phdr, const Elf_Shdr &Sec); 439 bool checkoffsets(const Elf_Phdr &Phdr, const Elf_Shdr &Sec); 440 bool checkVMA(const Elf_Phdr &Phdr, const Elf_Shdr &Sec); 441 bool checkPTDynamic(const Elf_Phdr &Phdr, const Elf_Shdr &Sec); 442 }; 443 444 template <typename ELFT> class LLVMStyle : public DumpStyle<ELFT> { 445 public: 446 TYPEDEF_ELF_TYPES(ELFT) 447 448 LLVMStyle(ScopedPrinter &W, ELFDumper<ELFT> *Dumper) 449 : DumpStyle<ELFT>(Dumper), W(W) {} 450 451 void printFileHeaders(const ELFO *Obj) override; 452 void printGroupSections(const ELFFile<ELFT> *Obj) override; 453 void printRelocations(const ELFO *Obj) override; 454 void printRelocations(const Elf_Shdr *Sec, const ELFO *Obj); 455 void printSectionHeaders(const ELFO *Obj) override; 456 void printSymbols(const ELFO *Obj) override; 457 void printDynamicSymbols(const ELFO *Obj) override; 458 void printDynamicRelocations(const ELFO *Obj) override; 459 void printProgramHeaders(const ELFO *Obj) override; 460 void printHashHistogram(const ELFFile<ELFT> *Obj) override; 461 void printCGProfile(const ELFFile<ELFT> *Obj) override; 462 void printAddrsig(const ELFFile<ELFT> *Obj) override; 463 void printNotes(const ELFFile<ELFT> *Obj) override; 464 void printELFLinkerOptions(const ELFFile<ELFT> *Obj) override; 465 void printMipsGOT(const MipsGOTParser<ELFT> &Parser) override; 466 void printMipsPLT(const MipsGOTParser<ELFT> &Parser) override; 467 468 private: 469 void printRelocation(const ELFO *Obj, Elf_Rela Rel, const Elf_Shdr *SymTab); 470 void printDynamicRelocation(const ELFO *Obj, Elf_Rela Rel); 471 void printSymbol(const ELFO *Obj, const Elf_Sym *Symbol, const Elf_Sym *First, 472 StringRef StrTable, bool IsDynamic) override; 473 474 ScopedPrinter &W; 475 }; 476 477 } // end anonymous namespace 478 479 namespace llvm { 480 481 template <class ELFT> 482 static std::error_code createELFDumper(const ELFFile<ELFT> *Obj, 483 ScopedPrinter &Writer, 484 std::unique_ptr<ObjDumper> &Result) { 485 Result.reset(new ELFDumper<ELFT>(Obj, Writer)); 486 return readobj_error::success; 487 } 488 489 std::error_code createELFDumper(const object::ObjectFile *Obj, 490 ScopedPrinter &Writer, 491 std::unique_ptr<ObjDumper> &Result) { 492 // Little-endian 32-bit 493 if (const ELF32LEObjectFile *ELFObj = dyn_cast<ELF32LEObjectFile>(Obj)) 494 return createELFDumper(ELFObj->getELFFile(), Writer, Result); 495 496 // Big-endian 32-bit 497 if (const ELF32BEObjectFile *ELFObj = dyn_cast<ELF32BEObjectFile>(Obj)) 498 return createELFDumper(ELFObj->getELFFile(), Writer, Result); 499 500 // Little-endian 64-bit 501 if (const ELF64LEObjectFile *ELFObj = dyn_cast<ELF64LEObjectFile>(Obj)) 502 return createELFDumper(ELFObj->getELFFile(), Writer, Result); 503 504 // Big-endian 64-bit 505 if (const ELF64BEObjectFile *ELFObj = dyn_cast<ELF64BEObjectFile>(Obj)) 506 return createELFDumper(ELFObj->getELFFile(), Writer, Result); 507 508 return readobj_error::unsupported_obj_file_format; 509 } 510 511 } // end namespace llvm 512 513 // Iterate through the versions needed section, and place each Elf_Vernaux 514 // in the VersionMap according to its index. 515 template <class ELFT> 516 void ELFDumper<ELFT>::LoadVersionNeeds(const Elf_Shdr *sec) const { 517 unsigned vn_size = sec->sh_size; // Size of section in bytes 518 unsigned vn_count = sec->sh_info; // Number of Verneed entries 519 const char *sec_start = (const char *)Obj->base() + sec->sh_offset; 520 const char *sec_end = sec_start + vn_size; 521 // The first Verneed entry is at the start of the section. 522 const char *p = sec_start; 523 for (unsigned i = 0; i < vn_count; i++) { 524 if (p + sizeof(Elf_Verneed) > sec_end) 525 report_fatal_error("Section ended unexpectedly while scanning " 526 "version needed records."); 527 const Elf_Verneed *vn = reinterpret_cast<const Elf_Verneed *>(p); 528 if (vn->vn_version != ELF::VER_NEED_CURRENT) 529 report_fatal_error("Unexpected verneed version"); 530 // Iterate through the Vernaux entries 531 const char *paux = p + vn->vn_aux; 532 for (unsigned j = 0; j < vn->vn_cnt; j++) { 533 if (paux + sizeof(Elf_Vernaux) > sec_end) 534 report_fatal_error("Section ended unexpected while scanning auxiliary " 535 "version needed records."); 536 const Elf_Vernaux *vna = reinterpret_cast<const Elf_Vernaux *>(paux); 537 size_t index = vna->vna_other & ELF::VERSYM_VERSION; 538 if (index >= VersionMap.size()) 539 VersionMap.resize(index + 1); 540 VersionMap[index] = VersionMapEntry(vna); 541 paux += vna->vna_next; 542 } 543 p += vn->vn_next; 544 } 545 } 546 547 // Iterate through the version definitions, and place each Elf_Verdef 548 // in the VersionMap according to its index. 549 template <class ELFT> 550 void ELFDumper<ELFT>::LoadVersionDefs(const Elf_Shdr *sec) const { 551 unsigned vd_size = sec->sh_size; // Size of section in bytes 552 unsigned vd_count = sec->sh_info; // Number of Verdef entries 553 const char *sec_start = (const char *)Obj->base() + sec->sh_offset; 554 const char *sec_end = sec_start + vd_size; 555 // The first Verdef entry is at the start of the section. 556 const char *p = sec_start; 557 for (unsigned i = 0; i < vd_count; i++) { 558 if (p + sizeof(Elf_Verdef) > sec_end) 559 report_fatal_error("Section ended unexpectedly while scanning " 560 "version definitions."); 561 const Elf_Verdef *vd = reinterpret_cast<const Elf_Verdef *>(p); 562 if (vd->vd_version != ELF::VER_DEF_CURRENT) 563 report_fatal_error("Unexpected verdef version"); 564 size_t index = vd->vd_ndx & ELF::VERSYM_VERSION; 565 if (index >= VersionMap.size()) 566 VersionMap.resize(index + 1); 567 VersionMap[index] = VersionMapEntry(vd); 568 p += vd->vd_next; 569 } 570 } 571 572 template <class ELFT> void ELFDumper<ELFT>::LoadVersionMap() const { 573 // If there is no dynamic symtab or version table, there is nothing to do. 574 if (!DynSymRegion.Addr || !dot_gnu_version_sec) 575 return; 576 577 // Has the VersionMap already been loaded? 578 if (VersionMap.size() > 0) 579 return; 580 581 // The first two version indexes are reserved. 582 // Index 0 is LOCAL, index 1 is GLOBAL. 583 VersionMap.push_back(VersionMapEntry()); 584 VersionMap.push_back(VersionMapEntry()); 585 586 if (dot_gnu_version_d_sec) 587 LoadVersionDefs(dot_gnu_version_d_sec); 588 589 if (dot_gnu_version_r_sec) 590 LoadVersionNeeds(dot_gnu_version_r_sec); 591 } 592 593 template <typename ELFO, class ELFT> 594 static void printVersionSymbolSection(ELFDumper<ELFT> *Dumper, const ELFO *Obj, 595 const typename ELFO::Elf_Shdr *Sec, 596 ScopedPrinter &W) { 597 DictScope SS(W, "Version symbols"); 598 if (!Sec) 599 return; 600 StringRef Name = unwrapOrError(Obj->getSectionName(Sec)); 601 W.printNumber("Section Name", Name, Sec->sh_name); 602 W.printHex("Address", Sec->sh_addr); 603 W.printHex("Offset", Sec->sh_offset); 604 W.printNumber("Link", Sec->sh_link); 605 606 const uint8_t *P = (const uint8_t *)Obj->base() + Sec->sh_offset; 607 StringRef StrTable = Dumper->getDynamicStringTable(); 608 609 // Same number of entries in the dynamic symbol table (DT_SYMTAB). 610 ListScope Syms(W, "Symbols"); 611 for (const typename ELFO::Elf_Sym &Sym : Dumper->dynamic_symbols()) { 612 DictScope S(W, "Symbol"); 613 std::string FullSymbolName = 614 Dumper->getFullSymbolName(&Sym, StrTable, true /* IsDynamic */); 615 W.printNumber("Version", *P); 616 W.printString("Name", FullSymbolName); 617 P += sizeof(typename ELFO::Elf_Half); 618 } 619 } 620 621 static const EnumEntry<unsigned> SymVersionFlags[] = { 622 {"Base", "BASE", VER_FLG_BASE}, 623 {"Weak", "WEAK", VER_FLG_WEAK}, 624 {"Info", "INFO", VER_FLG_INFO}}; 625 626 template <typename ELFO, class ELFT> 627 static void printVersionDefinitionSection(ELFDumper<ELFT> *Dumper, 628 const ELFO *Obj, 629 const typename ELFO::Elf_Shdr *Sec, 630 ScopedPrinter &W) { 631 using VerDef = typename ELFO::Elf_Verdef; 632 using VerdAux = typename ELFO::Elf_Verdaux; 633 634 DictScope SD(W, "SHT_GNU_verdef"); 635 if (!Sec) 636 return; 637 638 // The number of entries in the section SHT_GNU_verdef 639 // is determined by DT_VERDEFNUM tag. 640 unsigned VerDefsNum = 0; 641 for (const typename ELFO::Elf_Dyn &Dyn : Dumper->dynamic_table()) { 642 if (Dyn.d_tag == DT_VERDEFNUM) 643 VerDefsNum = Dyn.d_un.d_val; 644 } 645 const uint8_t *SecStartAddress = 646 (const uint8_t *)Obj->base() + Sec->sh_offset; 647 const uint8_t *SecEndAddress = SecStartAddress + Sec->sh_size; 648 const uint8_t *P = SecStartAddress; 649 const typename ELFO::Elf_Shdr *StrTab = 650 unwrapOrError(Obj->getSection(Sec->sh_link)); 651 652 while (VerDefsNum--) { 653 if (P + sizeof(VerDef) > SecEndAddress) 654 report_fatal_error("invalid offset in the section"); 655 656 auto *VD = reinterpret_cast<const VerDef *>(P); 657 DictScope Def(W, "Definition"); 658 W.printNumber("Version", VD->vd_version); 659 W.printEnum("Flags", VD->vd_flags, makeArrayRef(SymVersionFlags)); 660 W.printNumber("Index", VD->vd_ndx); 661 W.printNumber("Hash", VD->vd_hash); 662 W.printString("Name", 663 StringRef((const char *)(Obj->base() + StrTab->sh_offset + 664 VD->getAux()->vda_name))); 665 if (!VD->vd_cnt) 666 report_fatal_error("at least one definition string must exist"); 667 if (VD->vd_cnt > 2) 668 report_fatal_error("more than one predecessor is not expected"); 669 670 if (VD->vd_cnt == 2) { 671 const uint8_t *PAux = P + VD->vd_aux + VD->getAux()->vda_next; 672 const VerdAux *Aux = reinterpret_cast<const VerdAux *>(PAux); 673 W.printString("Predecessor", 674 StringRef((const char *)(Obj->base() + StrTab->sh_offset + 675 Aux->vda_name))); 676 } 677 678 P += VD->vd_next; 679 } 680 } 681 682 template <typename ELFO, class ELFT> 683 static void printVersionDependencySection(ELFDumper<ELFT> *Dumper, 684 const ELFO *Obj, 685 const typename ELFO::Elf_Shdr *Sec, 686 ScopedPrinter &W) { 687 using VerNeed = typename ELFO::Elf_Verneed; 688 using VernAux = typename ELFO::Elf_Vernaux; 689 690 DictScope SD(W, "SHT_GNU_verneed"); 691 if (!Sec) 692 return; 693 694 unsigned VerNeedNum = 0; 695 for (const typename ELFO::Elf_Dyn &Dyn : Dumper->dynamic_table()) 696 if (Dyn.d_tag == DT_VERNEEDNUM) 697 VerNeedNum = Dyn.d_un.d_val; 698 699 const uint8_t *SecData = (const uint8_t *)Obj->base() + Sec->sh_offset; 700 const typename ELFO::Elf_Shdr *StrTab = 701 unwrapOrError(Obj->getSection(Sec->sh_link)); 702 703 const uint8_t *P = SecData; 704 for (unsigned I = 0; I < VerNeedNum; ++I) { 705 const VerNeed *Need = reinterpret_cast<const VerNeed *>(P); 706 DictScope Entry(W, "Dependency"); 707 W.printNumber("Version", Need->vn_version); 708 W.printNumber("Count", Need->vn_cnt); 709 W.printString("FileName", 710 StringRef((const char *)(Obj->base() + StrTab->sh_offset + 711 Need->vn_file))); 712 713 const uint8_t *PAux = P + Need->vn_aux; 714 for (unsigned J = 0; J < Need->vn_cnt; ++J) { 715 const VernAux *Aux = reinterpret_cast<const VernAux *>(PAux); 716 DictScope Entry(W, "Entry"); 717 W.printNumber("Hash", Aux->vna_hash); 718 W.printEnum("Flags", Aux->vna_flags, makeArrayRef(SymVersionFlags)); 719 W.printNumber("Index", Aux->vna_other); 720 W.printString("Name", 721 StringRef((const char *)(Obj->base() + StrTab->sh_offset + 722 Aux->vna_name))); 723 PAux += Aux->vna_next; 724 } 725 P += Need->vn_next; 726 } 727 } 728 729 template <typename ELFT> void ELFDumper<ELFT>::printVersionInfo() { 730 // Dump version symbol section. 731 printVersionSymbolSection(this, Obj, dot_gnu_version_sec, W); 732 733 // Dump version definition section. 734 printVersionDefinitionSection(this, Obj, dot_gnu_version_d_sec, W); 735 736 // Dump version dependency section. 737 printVersionDependencySection(this, Obj, dot_gnu_version_r_sec, W); 738 } 739 740 template <typename ELFT> 741 StringRef ELFDumper<ELFT>::getSymbolVersion(StringRef StrTab, 742 const Elf_Sym *symb, 743 bool &IsDefault) const { 744 // This is a dynamic symbol. Look in the GNU symbol version table. 745 if (!dot_gnu_version_sec) { 746 // No version table. 747 IsDefault = false; 748 return StringRef(""); 749 } 750 751 // Determine the position in the symbol table of this entry. 752 size_t entry_index = (reinterpret_cast<uintptr_t>(symb) - 753 reinterpret_cast<uintptr_t>(DynSymRegion.Addr)) / 754 sizeof(Elf_Sym); 755 756 // Get the corresponding version index entry 757 const Elf_Versym *vs = unwrapOrError( 758 Obj->template getEntry<Elf_Versym>(dot_gnu_version_sec, entry_index)); 759 size_t version_index = vs->vs_index & ELF::VERSYM_VERSION; 760 761 // Special markers for unversioned symbols. 762 if (version_index == ELF::VER_NDX_LOCAL || 763 version_index == ELF::VER_NDX_GLOBAL) { 764 IsDefault = false; 765 return StringRef(""); 766 } 767 768 // Lookup this symbol in the version table 769 LoadVersionMap(); 770 if (version_index >= VersionMap.size() || VersionMap[version_index].isNull()) 771 reportError("Invalid version entry"); 772 const VersionMapEntry &entry = VersionMap[version_index]; 773 774 // Get the version name string 775 size_t name_offset; 776 if (entry.isVerdef()) { 777 // The first Verdaux entry holds the name. 778 name_offset = entry.getVerdef()->getAux()->vda_name; 779 IsDefault = !(vs->vs_index & ELF::VERSYM_HIDDEN); 780 } else { 781 name_offset = entry.getVernaux()->vna_name; 782 IsDefault = false; 783 } 784 if (name_offset >= StrTab.size()) 785 reportError("Invalid string offset"); 786 return StringRef(StrTab.data() + name_offset); 787 } 788 789 template <typename ELFT> 790 StringRef ELFDumper<ELFT>::getStaticSymbolName(uint32_t Index) const { 791 StringRef StrTable = unwrapOrError(Obj->getStringTableForSymtab(*DotSymtabSec)); 792 Elf_Sym_Range Syms = unwrapOrError(Obj->symbols(DotSymtabSec)); 793 if (Index >= Syms.size()) 794 reportError("Invalid symbol index"); 795 const Elf_Sym *Sym = &Syms[Index]; 796 return unwrapOrError(Sym->getName(StrTable)); 797 } 798 799 template <typename ELFT> 800 std::string ELFDumper<ELFT>::getFullSymbolName(const Elf_Sym *Symbol, 801 StringRef StrTable, 802 bool IsDynamic) const { 803 StringRef SymbolName = unwrapOrError(Symbol->getName(StrTable)); 804 if (!IsDynamic) 805 return SymbolName; 806 807 std::string FullSymbolName(SymbolName); 808 809 bool IsDefault; 810 StringRef Version = getSymbolVersion(StrTable, &*Symbol, IsDefault); 811 FullSymbolName += (IsDefault ? "@@" : "@"); 812 FullSymbolName += Version; 813 return FullSymbolName; 814 } 815 816 template <typename ELFT> 817 void ELFDumper<ELFT>::getSectionNameIndex(const Elf_Sym *Symbol, 818 const Elf_Sym *FirstSym, 819 StringRef &SectionName, 820 unsigned &SectionIndex) const { 821 SectionIndex = Symbol->st_shndx; 822 if (Symbol->isUndefined()) 823 SectionName = "Undefined"; 824 else if (Symbol->isProcessorSpecific()) 825 SectionName = "Processor Specific"; 826 else if (Symbol->isOSSpecific()) 827 SectionName = "Operating System Specific"; 828 else if (Symbol->isAbsolute()) 829 SectionName = "Absolute"; 830 else if (Symbol->isCommon()) 831 SectionName = "Common"; 832 else if (Symbol->isReserved() && SectionIndex != SHN_XINDEX) 833 SectionName = "Reserved"; 834 else { 835 if (SectionIndex == SHN_XINDEX) 836 SectionIndex = unwrapOrError(object::getExtendedSymbolTableIndex<ELFT>( 837 Symbol, FirstSym, ShndxTable)); 838 const typename ELFT::Shdr *Sec = 839 unwrapOrError(Obj->getSection(SectionIndex)); 840 SectionName = unwrapOrError(Obj->getSectionName(Sec)); 841 } 842 } 843 844 template <class ELFO> 845 static const typename ELFO::Elf_Shdr * 846 findNotEmptySectionByAddress(const ELFO *Obj, uint64_t Addr) { 847 for (const auto &Shdr : unwrapOrError(Obj->sections())) 848 if (Shdr.sh_addr == Addr && Shdr.sh_size > 0) 849 return &Shdr; 850 return nullptr; 851 } 852 853 template <class ELFO> 854 static const typename ELFO::Elf_Shdr *findSectionByName(const ELFO &Obj, 855 StringRef Name) { 856 for (const auto &Shdr : unwrapOrError(Obj.sections())) { 857 if (Name == unwrapOrError(Obj.getSectionName(&Shdr))) 858 return &Shdr; 859 } 860 return nullptr; 861 } 862 863 static const EnumEntry<unsigned> ElfClass[] = { 864 {"None", "none", ELF::ELFCLASSNONE}, 865 {"32-bit", "ELF32", ELF::ELFCLASS32}, 866 {"64-bit", "ELF64", ELF::ELFCLASS64}, 867 }; 868 869 static const EnumEntry<unsigned> ElfDataEncoding[] = { 870 {"None", "none", ELF::ELFDATANONE}, 871 {"LittleEndian", "2's complement, little endian", ELF::ELFDATA2LSB}, 872 {"BigEndian", "2's complement, big endian", ELF::ELFDATA2MSB}, 873 }; 874 875 static const EnumEntry<unsigned> ElfObjectFileType[] = { 876 {"None", "NONE (none)", ELF::ET_NONE}, 877 {"Relocatable", "REL (Relocatable file)", ELF::ET_REL}, 878 {"Executable", "EXEC (Executable file)", ELF::ET_EXEC}, 879 {"SharedObject", "DYN (Shared object file)", ELF::ET_DYN}, 880 {"Core", "CORE (Core file)", ELF::ET_CORE}, 881 }; 882 883 static const EnumEntry<unsigned> ElfOSABI[] = { 884 {"SystemV", "UNIX - System V", ELF::ELFOSABI_NONE}, 885 {"HPUX", "UNIX - HP-UX", ELF::ELFOSABI_HPUX}, 886 {"NetBSD", "UNIX - NetBSD", ELF::ELFOSABI_NETBSD}, 887 {"GNU/Linux", "UNIX - GNU", ELF::ELFOSABI_LINUX}, 888 {"GNU/Hurd", "GNU/Hurd", ELF::ELFOSABI_HURD}, 889 {"Solaris", "UNIX - Solaris", ELF::ELFOSABI_SOLARIS}, 890 {"AIX", "UNIX - AIX", ELF::ELFOSABI_AIX}, 891 {"IRIX", "UNIX - IRIX", ELF::ELFOSABI_IRIX}, 892 {"FreeBSD", "UNIX - FreeBSD", ELF::ELFOSABI_FREEBSD}, 893 {"TRU64", "UNIX - TRU64", ELF::ELFOSABI_TRU64}, 894 {"Modesto", "Novell - Modesto", ELF::ELFOSABI_MODESTO}, 895 {"OpenBSD", "UNIX - OpenBSD", ELF::ELFOSABI_OPENBSD}, 896 {"OpenVMS", "VMS - OpenVMS", ELF::ELFOSABI_OPENVMS}, 897 {"NSK", "HP - Non-Stop Kernel", ELF::ELFOSABI_NSK}, 898 {"AROS", "AROS", ELF::ELFOSABI_AROS}, 899 {"FenixOS", "FenixOS", ELF::ELFOSABI_FENIXOS}, 900 {"CloudABI", "CloudABI", ELF::ELFOSABI_CLOUDABI}, 901 {"Standalone", "Standalone App", ELF::ELFOSABI_STANDALONE} 902 }; 903 904 static const EnumEntry<unsigned> AMDGPUElfOSABI[] = { 905 {"AMDGPU_HSA", "AMDGPU - HSA", ELF::ELFOSABI_AMDGPU_HSA}, 906 {"AMDGPU_PAL", "AMDGPU - PAL", ELF::ELFOSABI_AMDGPU_PAL}, 907 {"AMDGPU_MESA3D", "AMDGPU - MESA3D", ELF::ELFOSABI_AMDGPU_MESA3D} 908 }; 909 910 static const EnumEntry<unsigned> ARMElfOSABI[] = { 911 {"ARM", "ARM", ELF::ELFOSABI_ARM} 912 }; 913 914 static const EnumEntry<unsigned> C6000ElfOSABI[] = { 915 {"C6000_ELFABI", "Bare-metal C6000", ELF::ELFOSABI_C6000_ELFABI}, 916 {"C6000_LINUX", "Linux C6000", ELF::ELFOSABI_C6000_LINUX} 917 }; 918 919 static const EnumEntry<unsigned> ElfMachineType[] = { 920 ENUM_ENT(EM_NONE, "None"), 921 ENUM_ENT(EM_M32, "WE32100"), 922 ENUM_ENT(EM_SPARC, "Sparc"), 923 ENUM_ENT(EM_386, "Intel 80386"), 924 ENUM_ENT(EM_68K, "MC68000"), 925 ENUM_ENT(EM_88K, "MC88000"), 926 ENUM_ENT(EM_IAMCU, "EM_IAMCU"), 927 ENUM_ENT(EM_860, "Intel 80860"), 928 ENUM_ENT(EM_MIPS, "MIPS R3000"), 929 ENUM_ENT(EM_S370, "IBM System/370"), 930 ENUM_ENT(EM_MIPS_RS3_LE, "MIPS R3000 little-endian"), 931 ENUM_ENT(EM_PARISC, "HPPA"), 932 ENUM_ENT(EM_VPP500, "Fujitsu VPP500"), 933 ENUM_ENT(EM_SPARC32PLUS, "Sparc v8+"), 934 ENUM_ENT(EM_960, "Intel 80960"), 935 ENUM_ENT(EM_PPC, "PowerPC"), 936 ENUM_ENT(EM_PPC64, "PowerPC64"), 937 ENUM_ENT(EM_S390, "IBM S/390"), 938 ENUM_ENT(EM_SPU, "SPU"), 939 ENUM_ENT(EM_V800, "NEC V800 series"), 940 ENUM_ENT(EM_FR20, "Fujistsu FR20"), 941 ENUM_ENT(EM_RH32, "TRW RH-32"), 942 ENUM_ENT(EM_RCE, "Motorola RCE"), 943 ENUM_ENT(EM_ARM, "ARM"), 944 ENUM_ENT(EM_ALPHA, "EM_ALPHA"), 945 ENUM_ENT(EM_SH, "Hitachi SH"), 946 ENUM_ENT(EM_SPARCV9, "Sparc v9"), 947 ENUM_ENT(EM_TRICORE, "Siemens Tricore"), 948 ENUM_ENT(EM_ARC, "ARC"), 949 ENUM_ENT(EM_H8_300, "Hitachi H8/300"), 950 ENUM_ENT(EM_H8_300H, "Hitachi H8/300H"), 951 ENUM_ENT(EM_H8S, "Hitachi H8S"), 952 ENUM_ENT(EM_H8_500, "Hitachi H8/500"), 953 ENUM_ENT(EM_IA_64, "Intel IA-64"), 954 ENUM_ENT(EM_MIPS_X, "Stanford MIPS-X"), 955 ENUM_ENT(EM_COLDFIRE, "Motorola Coldfire"), 956 ENUM_ENT(EM_68HC12, "Motorola MC68HC12 Microcontroller"), 957 ENUM_ENT(EM_MMA, "Fujitsu Multimedia Accelerator"), 958 ENUM_ENT(EM_PCP, "Siemens PCP"), 959 ENUM_ENT(EM_NCPU, "Sony nCPU embedded RISC processor"), 960 ENUM_ENT(EM_NDR1, "Denso NDR1 microprocesspr"), 961 ENUM_ENT(EM_STARCORE, "Motorola Star*Core processor"), 962 ENUM_ENT(EM_ME16, "Toyota ME16 processor"), 963 ENUM_ENT(EM_ST100, "STMicroelectronics ST100 processor"), 964 ENUM_ENT(EM_TINYJ, "Advanced Logic Corp. TinyJ embedded processor"), 965 ENUM_ENT(EM_X86_64, "Advanced Micro Devices X86-64"), 966 ENUM_ENT(EM_PDSP, "Sony DSP processor"), 967 ENUM_ENT(EM_PDP10, "Digital Equipment Corp. PDP-10"), 968 ENUM_ENT(EM_PDP11, "Digital Equipment Corp. PDP-11"), 969 ENUM_ENT(EM_FX66, "Siemens FX66 microcontroller"), 970 ENUM_ENT(EM_ST9PLUS, "STMicroelectronics ST9+ 8/16 bit microcontroller"), 971 ENUM_ENT(EM_ST7, "STMicroelectronics ST7 8-bit microcontroller"), 972 ENUM_ENT(EM_68HC16, "Motorola MC68HC16 Microcontroller"), 973 ENUM_ENT(EM_68HC11, "Motorola MC68HC11 Microcontroller"), 974 ENUM_ENT(EM_68HC08, "Motorola MC68HC08 Microcontroller"), 975 ENUM_ENT(EM_68HC05, "Motorola MC68HC05 Microcontroller"), 976 ENUM_ENT(EM_SVX, "Silicon Graphics SVx"), 977 ENUM_ENT(EM_ST19, "STMicroelectronics ST19 8-bit microcontroller"), 978 ENUM_ENT(EM_VAX, "Digital VAX"), 979 ENUM_ENT(EM_CRIS, "Axis Communications 32-bit embedded processor"), 980 ENUM_ENT(EM_JAVELIN, "Infineon Technologies 32-bit embedded cpu"), 981 ENUM_ENT(EM_FIREPATH, "Element 14 64-bit DSP processor"), 982 ENUM_ENT(EM_ZSP, "LSI Logic's 16-bit DSP processor"), 983 ENUM_ENT(EM_MMIX, "Donald Knuth's educational 64-bit processor"), 984 ENUM_ENT(EM_HUANY, "Harvard Universitys's machine-independent object format"), 985 ENUM_ENT(EM_PRISM, "Vitesse Prism"), 986 ENUM_ENT(EM_AVR, "Atmel AVR 8-bit microcontroller"), 987 ENUM_ENT(EM_FR30, "Fujitsu FR30"), 988 ENUM_ENT(EM_D10V, "Mitsubishi D10V"), 989 ENUM_ENT(EM_D30V, "Mitsubishi D30V"), 990 ENUM_ENT(EM_V850, "NEC v850"), 991 ENUM_ENT(EM_M32R, "Renesas M32R (formerly Mitsubishi M32r)"), 992 ENUM_ENT(EM_MN10300, "Matsushita MN10300"), 993 ENUM_ENT(EM_MN10200, "Matsushita MN10200"), 994 ENUM_ENT(EM_PJ, "picoJava"), 995 ENUM_ENT(EM_OPENRISC, "OpenRISC 32-bit embedded processor"), 996 ENUM_ENT(EM_ARC_COMPACT, "EM_ARC_COMPACT"), 997 ENUM_ENT(EM_XTENSA, "Tensilica Xtensa Processor"), 998 ENUM_ENT(EM_VIDEOCORE, "Alphamosaic VideoCore processor"), 999 ENUM_ENT(EM_TMM_GPP, "Thompson Multimedia General Purpose Processor"), 1000 ENUM_ENT(EM_NS32K, "National Semiconductor 32000 series"), 1001 ENUM_ENT(EM_TPC, "Tenor Network TPC processor"), 1002 ENUM_ENT(EM_SNP1K, "EM_SNP1K"), 1003 ENUM_ENT(EM_ST200, "STMicroelectronics ST200 microcontroller"), 1004 ENUM_ENT(EM_IP2K, "Ubicom IP2xxx 8-bit microcontrollers"), 1005 ENUM_ENT(EM_MAX, "MAX Processor"), 1006 ENUM_ENT(EM_CR, "National Semiconductor CompactRISC"), 1007 ENUM_ENT(EM_F2MC16, "Fujitsu F2MC16"), 1008 ENUM_ENT(EM_MSP430, "Texas Instruments msp430 microcontroller"), 1009 ENUM_ENT(EM_BLACKFIN, "Analog Devices Blackfin"), 1010 ENUM_ENT(EM_SE_C33, "S1C33 Family of Seiko Epson processors"), 1011 ENUM_ENT(EM_SEP, "Sharp embedded microprocessor"), 1012 ENUM_ENT(EM_ARCA, "Arca RISC microprocessor"), 1013 ENUM_ENT(EM_UNICORE, "Unicore"), 1014 ENUM_ENT(EM_EXCESS, "eXcess 16/32/64-bit configurable embedded CPU"), 1015 ENUM_ENT(EM_DXP, "Icera Semiconductor Inc. Deep Execution Processor"), 1016 ENUM_ENT(EM_ALTERA_NIOS2, "Altera Nios"), 1017 ENUM_ENT(EM_CRX, "National Semiconductor CRX microprocessor"), 1018 ENUM_ENT(EM_XGATE, "Motorola XGATE embedded processor"), 1019 ENUM_ENT(EM_C166, "Infineon Technologies xc16x"), 1020 ENUM_ENT(EM_M16C, "Renesas M16C"), 1021 ENUM_ENT(EM_DSPIC30F, "Microchip Technology dsPIC30F Digital Signal Controller"), 1022 ENUM_ENT(EM_CE, "Freescale Communication Engine RISC core"), 1023 ENUM_ENT(EM_M32C, "Renesas M32C"), 1024 ENUM_ENT(EM_TSK3000, "Altium TSK3000 core"), 1025 ENUM_ENT(EM_RS08, "Freescale RS08 embedded processor"), 1026 ENUM_ENT(EM_SHARC, "EM_SHARC"), 1027 ENUM_ENT(EM_ECOG2, "Cyan Technology eCOG2 microprocessor"), 1028 ENUM_ENT(EM_SCORE7, "SUNPLUS S+Core"), 1029 ENUM_ENT(EM_DSP24, "New Japan Radio (NJR) 24-bit DSP Processor"), 1030 ENUM_ENT(EM_VIDEOCORE3, "Broadcom VideoCore III processor"), 1031 ENUM_ENT(EM_LATTICEMICO32, "Lattice Mico32"), 1032 ENUM_ENT(EM_SE_C17, "Seiko Epson C17 family"), 1033 ENUM_ENT(EM_TI_C6000, "Texas Instruments TMS320C6000 DSP family"), 1034 ENUM_ENT(EM_TI_C2000, "Texas Instruments TMS320C2000 DSP family"), 1035 ENUM_ENT(EM_TI_C5500, "Texas Instruments TMS320C55x DSP family"), 1036 ENUM_ENT(EM_MMDSP_PLUS, "STMicroelectronics 64bit VLIW Data Signal Processor"), 1037 ENUM_ENT(EM_CYPRESS_M8C, "Cypress M8C microprocessor"), 1038 ENUM_ENT(EM_R32C, "Renesas R32C series microprocessors"), 1039 ENUM_ENT(EM_TRIMEDIA, "NXP Semiconductors TriMedia architecture family"), 1040 ENUM_ENT(EM_HEXAGON, "Qualcomm Hexagon"), 1041 ENUM_ENT(EM_8051, "Intel 8051 and variants"), 1042 ENUM_ENT(EM_STXP7X, "STMicroelectronics STxP7x family"), 1043 ENUM_ENT(EM_NDS32, "Andes Technology compact code size embedded RISC processor family"), 1044 ENUM_ENT(EM_ECOG1, "Cyan Technology eCOG1 microprocessor"), 1045 ENUM_ENT(EM_ECOG1X, "Cyan Technology eCOG1X family"), 1046 ENUM_ENT(EM_MAXQ30, "Dallas Semiconductor MAXQ30 Core microcontrollers"), 1047 ENUM_ENT(EM_XIMO16, "New Japan Radio (NJR) 16-bit DSP Processor"), 1048 ENUM_ENT(EM_MANIK, "M2000 Reconfigurable RISC Microprocessor"), 1049 ENUM_ENT(EM_CRAYNV2, "Cray Inc. NV2 vector architecture"), 1050 ENUM_ENT(EM_RX, "Renesas RX"), 1051 ENUM_ENT(EM_METAG, "Imagination Technologies Meta processor architecture"), 1052 ENUM_ENT(EM_MCST_ELBRUS, "MCST Elbrus general purpose hardware architecture"), 1053 ENUM_ENT(EM_ECOG16, "Cyan Technology eCOG16 family"), 1054 ENUM_ENT(EM_CR16, "Xilinx MicroBlaze"), 1055 ENUM_ENT(EM_ETPU, "Freescale Extended Time Processing Unit"), 1056 ENUM_ENT(EM_SLE9X, "Infineon Technologies SLE9X core"), 1057 ENUM_ENT(EM_L10M, "EM_L10M"), 1058 ENUM_ENT(EM_K10M, "EM_K10M"), 1059 ENUM_ENT(EM_AARCH64, "AArch64"), 1060 ENUM_ENT(EM_AVR32, "Atmel Corporation 32-bit microprocessor family"), 1061 ENUM_ENT(EM_STM8, "STMicroeletronics STM8 8-bit microcontroller"), 1062 ENUM_ENT(EM_TILE64, "Tilera TILE64 multicore architecture family"), 1063 ENUM_ENT(EM_TILEPRO, "Tilera TILEPro multicore architecture family"), 1064 ENUM_ENT(EM_CUDA, "NVIDIA CUDA architecture"), 1065 ENUM_ENT(EM_TILEGX, "Tilera TILE-Gx multicore architecture family"), 1066 ENUM_ENT(EM_CLOUDSHIELD, "EM_CLOUDSHIELD"), 1067 ENUM_ENT(EM_COREA_1ST, "EM_COREA_1ST"), 1068 ENUM_ENT(EM_COREA_2ND, "EM_COREA_2ND"), 1069 ENUM_ENT(EM_ARC_COMPACT2, "EM_ARC_COMPACT2"), 1070 ENUM_ENT(EM_OPEN8, "EM_OPEN8"), 1071 ENUM_ENT(EM_RL78, "Renesas RL78"), 1072 ENUM_ENT(EM_VIDEOCORE5, "Broadcom VideoCore V processor"), 1073 ENUM_ENT(EM_78KOR, "EM_78KOR"), 1074 ENUM_ENT(EM_56800EX, "EM_56800EX"), 1075 ENUM_ENT(EM_AMDGPU, "EM_AMDGPU"), 1076 ENUM_ENT(EM_RISCV, "RISC-V"), 1077 ENUM_ENT(EM_LANAI, "EM_LANAI"), 1078 ENUM_ENT(EM_BPF, "EM_BPF"), 1079 }; 1080 1081 static const EnumEntry<unsigned> ElfSymbolBindings[] = { 1082 {"Local", "LOCAL", ELF::STB_LOCAL}, 1083 {"Global", "GLOBAL", ELF::STB_GLOBAL}, 1084 {"Weak", "WEAK", ELF::STB_WEAK}, 1085 {"Unique", "UNIQUE", ELF::STB_GNU_UNIQUE}}; 1086 1087 static const EnumEntry<unsigned> ElfSymbolVisibilities[] = { 1088 {"DEFAULT", "DEFAULT", ELF::STV_DEFAULT}, 1089 {"INTERNAL", "INTERNAL", ELF::STV_INTERNAL}, 1090 {"HIDDEN", "HIDDEN", ELF::STV_HIDDEN}, 1091 {"PROTECTED", "PROTECTED", ELF::STV_PROTECTED}}; 1092 1093 static const EnumEntry<unsigned> ElfSymbolTypes[] = { 1094 {"None", "NOTYPE", ELF::STT_NOTYPE}, 1095 {"Object", "OBJECT", ELF::STT_OBJECT}, 1096 {"Function", "FUNC", ELF::STT_FUNC}, 1097 {"Section", "SECTION", ELF::STT_SECTION}, 1098 {"File", "FILE", ELF::STT_FILE}, 1099 {"Common", "COMMON", ELF::STT_COMMON}, 1100 {"TLS", "TLS", ELF::STT_TLS}, 1101 {"GNU_IFunc", "IFUNC", ELF::STT_GNU_IFUNC}}; 1102 1103 static const EnumEntry<unsigned> AMDGPUSymbolTypes[] = { 1104 { "AMDGPU_HSA_KERNEL", ELF::STT_AMDGPU_HSA_KERNEL } 1105 }; 1106 1107 static const char *getGroupType(uint32_t Flag) { 1108 if (Flag & ELF::GRP_COMDAT) 1109 return "COMDAT"; 1110 else 1111 return "(unknown)"; 1112 } 1113 1114 static const EnumEntry<unsigned> ElfSectionFlags[] = { 1115 ENUM_ENT(SHF_WRITE, "W"), 1116 ENUM_ENT(SHF_ALLOC, "A"), 1117 ENUM_ENT(SHF_EXCLUDE, "E"), 1118 ENUM_ENT(SHF_EXECINSTR, "X"), 1119 ENUM_ENT(SHF_MERGE, "M"), 1120 ENUM_ENT(SHF_STRINGS, "S"), 1121 ENUM_ENT(SHF_INFO_LINK, "I"), 1122 ENUM_ENT(SHF_LINK_ORDER, "L"), 1123 ENUM_ENT(SHF_OS_NONCONFORMING, "o"), 1124 ENUM_ENT(SHF_GROUP, "G"), 1125 ENUM_ENT(SHF_TLS, "T"), 1126 ENUM_ENT(SHF_MASKOS, "o"), 1127 ENUM_ENT(SHF_MASKPROC, "p"), 1128 ENUM_ENT_1(SHF_COMPRESSED), 1129 }; 1130 1131 static const EnumEntry<unsigned> ElfXCoreSectionFlags[] = { 1132 LLVM_READOBJ_ENUM_ENT(ELF, XCORE_SHF_CP_SECTION), 1133 LLVM_READOBJ_ENUM_ENT(ELF, XCORE_SHF_DP_SECTION) 1134 }; 1135 1136 static const EnumEntry<unsigned> ElfARMSectionFlags[] = { 1137 LLVM_READOBJ_ENUM_ENT(ELF, SHF_ARM_PURECODE) 1138 }; 1139 1140 static const EnumEntry<unsigned> ElfHexagonSectionFlags[] = { 1141 LLVM_READOBJ_ENUM_ENT(ELF, SHF_HEX_GPREL) 1142 }; 1143 1144 static const EnumEntry<unsigned> ElfMipsSectionFlags[] = { 1145 LLVM_READOBJ_ENUM_ENT(ELF, SHF_MIPS_NODUPES), 1146 LLVM_READOBJ_ENUM_ENT(ELF, SHF_MIPS_NAMES ), 1147 LLVM_READOBJ_ENUM_ENT(ELF, SHF_MIPS_LOCAL ), 1148 LLVM_READOBJ_ENUM_ENT(ELF, SHF_MIPS_NOSTRIP), 1149 LLVM_READOBJ_ENUM_ENT(ELF, SHF_MIPS_GPREL ), 1150 LLVM_READOBJ_ENUM_ENT(ELF, SHF_MIPS_MERGE ), 1151 LLVM_READOBJ_ENUM_ENT(ELF, SHF_MIPS_ADDR ), 1152 LLVM_READOBJ_ENUM_ENT(ELF, SHF_MIPS_STRING ) 1153 }; 1154 1155 static const EnumEntry<unsigned> ElfX86_64SectionFlags[] = { 1156 LLVM_READOBJ_ENUM_ENT(ELF, SHF_X86_64_LARGE) 1157 }; 1158 1159 static std::string getGNUFlags(uint64_t Flags) { 1160 std::string Str; 1161 for (auto Entry : ElfSectionFlags) { 1162 uint64_t Flag = Entry.Value & Flags; 1163 Flags &= ~Entry.Value; 1164 switch (Flag) { 1165 case ELF::SHF_WRITE: 1166 case ELF::SHF_ALLOC: 1167 case ELF::SHF_EXECINSTR: 1168 case ELF::SHF_MERGE: 1169 case ELF::SHF_STRINGS: 1170 case ELF::SHF_INFO_LINK: 1171 case ELF::SHF_LINK_ORDER: 1172 case ELF::SHF_OS_NONCONFORMING: 1173 case ELF::SHF_GROUP: 1174 case ELF::SHF_TLS: 1175 case ELF::SHF_EXCLUDE: 1176 Str += Entry.AltName; 1177 break; 1178 default: 1179 if (Flag & ELF::SHF_MASKOS) 1180 Str += "o"; 1181 else if (Flag & ELF::SHF_MASKPROC) 1182 Str += "p"; 1183 else if (Flag) 1184 Str += "x"; 1185 } 1186 } 1187 return Str; 1188 } 1189 1190 static const char *getElfSegmentType(unsigned Arch, unsigned Type) { 1191 // Check potentially overlapped processor-specific 1192 // program header type. 1193 switch (Arch) { 1194 case ELF::EM_ARM: 1195 switch (Type) { 1196 LLVM_READOBJ_ENUM_CASE(ELF, PT_ARM_EXIDX); 1197 } 1198 break; 1199 case ELF::EM_MIPS: 1200 case ELF::EM_MIPS_RS3_LE: 1201 switch (Type) { 1202 LLVM_READOBJ_ENUM_CASE(ELF, PT_MIPS_REGINFO); 1203 LLVM_READOBJ_ENUM_CASE(ELF, PT_MIPS_RTPROC); 1204 LLVM_READOBJ_ENUM_CASE(ELF, PT_MIPS_OPTIONS); 1205 LLVM_READOBJ_ENUM_CASE(ELF, PT_MIPS_ABIFLAGS); 1206 } 1207 break; 1208 } 1209 1210 switch (Type) { 1211 LLVM_READOBJ_ENUM_CASE(ELF, PT_NULL ); 1212 LLVM_READOBJ_ENUM_CASE(ELF, PT_LOAD ); 1213 LLVM_READOBJ_ENUM_CASE(ELF, PT_DYNAMIC); 1214 LLVM_READOBJ_ENUM_CASE(ELF, PT_INTERP ); 1215 LLVM_READOBJ_ENUM_CASE(ELF, PT_NOTE ); 1216 LLVM_READOBJ_ENUM_CASE(ELF, PT_SHLIB ); 1217 LLVM_READOBJ_ENUM_CASE(ELF, PT_PHDR ); 1218 LLVM_READOBJ_ENUM_CASE(ELF, PT_TLS ); 1219 1220 LLVM_READOBJ_ENUM_CASE(ELF, PT_GNU_EH_FRAME); 1221 LLVM_READOBJ_ENUM_CASE(ELF, PT_SUNW_UNWIND); 1222 1223 LLVM_READOBJ_ENUM_CASE(ELF, PT_GNU_STACK); 1224 LLVM_READOBJ_ENUM_CASE(ELF, PT_GNU_RELRO); 1225 1226 LLVM_READOBJ_ENUM_CASE(ELF, PT_OPENBSD_RANDOMIZE); 1227 LLVM_READOBJ_ENUM_CASE(ELF, PT_OPENBSD_WXNEEDED); 1228 LLVM_READOBJ_ENUM_CASE(ELF, PT_OPENBSD_BOOTDATA); 1229 1230 default: return ""; 1231 } 1232 } 1233 1234 static std::string getElfPtType(unsigned Arch, unsigned Type) { 1235 switch (Type) { 1236 LLVM_READOBJ_PHDR_ENUM(ELF, PT_NULL) 1237 LLVM_READOBJ_PHDR_ENUM(ELF, PT_LOAD) 1238 LLVM_READOBJ_PHDR_ENUM(ELF, PT_DYNAMIC) 1239 LLVM_READOBJ_PHDR_ENUM(ELF, PT_INTERP) 1240 LLVM_READOBJ_PHDR_ENUM(ELF, PT_NOTE) 1241 LLVM_READOBJ_PHDR_ENUM(ELF, PT_SHLIB) 1242 LLVM_READOBJ_PHDR_ENUM(ELF, PT_PHDR) 1243 LLVM_READOBJ_PHDR_ENUM(ELF, PT_TLS) 1244 LLVM_READOBJ_PHDR_ENUM(ELF, PT_GNU_EH_FRAME) 1245 LLVM_READOBJ_PHDR_ENUM(ELF, PT_SUNW_UNWIND) 1246 LLVM_READOBJ_PHDR_ENUM(ELF, PT_GNU_STACK) 1247 LLVM_READOBJ_PHDR_ENUM(ELF, PT_GNU_RELRO) 1248 default: 1249 // All machine specific PT_* types 1250 switch (Arch) { 1251 case ELF::EM_ARM: 1252 if (Type == ELF::PT_ARM_EXIDX) 1253 return "EXIDX"; 1254 break; 1255 case ELF::EM_MIPS: 1256 case ELF::EM_MIPS_RS3_LE: 1257 switch (Type) { 1258 case PT_MIPS_REGINFO: 1259 return "REGINFO"; 1260 case PT_MIPS_RTPROC: 1261 return "RTPROC"; 1262 case PT_MIPS_OPTIONS: 1263 return "OPTIONS"; 1264 case PT_MIPS_ABIFLAGS: 1265 return "ABIFLAGS"; 1266 } 1267 break; 1268 } 1269 } 1270 return std::string("<unknown>: ") + to_string(format_hex(Type, 1)); 1271 } 1272 1273 static const EnumEntry<unsigned> ElfSegmentFlags[] = { 1274 LLVM_READOBJ_ENUM_ENT(ELF, PF_X), 1275 LLVM_READOBJ_ENUM_ENT(ELF, PF_W), 1276 LLVM_READOBJ_ENUM_ENT(ELF, PF_R) 1277 }; 1278 1279 static const EnumEntry<unsigned> ElfHeaderMipsFlags[] = { 1280 ENUM_ENT(EF_MIPS_NOREORDER, "noreorder"), 1281 ENUM_ENT(EF_MIPS_PIC, "pic"), 1282 ENUM_ENT(EF_MIPS_CPIC, "cpic"), 1283 ENUM_ENT(EF_MIPS_ABI2, "abi2"), 1284 ENUM_ENT(EF_MIPS_32BITMODE, "32bitmode"), 1285 ENUM_ENT(EF_MIPS_FP64, "fp64"), 1286 ENUM_ENT(EF_MIPS_NAN2008, "nan2008"), 1287 ENUM_ENT(EF_MIPS_ABI_O32, "o32"), 1288 ENUM_ENT(EF_MIPS_ABI_O64, "o64"), 1289 ENUM_ENT(EF_MIPS_ABI_EABI32, "eabi32"), 1290 ENUM_ENT(EF_MIPS_ABI_EABI64, "eabi64"), 1291 ENUM_ENT(EF_MIPS_MACH_3900, "3900"), 1292 ENUM_ENT(EF_MIPS_MACH_4010, "4010"), 1293 ENUM_ENT(EF_MIPS_MACH_4100, "4100"), 1294 ENUM_ENT(EF_MIPS_MACH_4650, "4650"), 1295 ENUM_ENT(EF_MIPS_MACH_4120, "4120"), 1296 ENUM_ENT(EF_MIPS_MACH_4111, "4111"), 1297 ENUM_ENT(EF_MIPS_MACH_SB1, "sb1"), 1298 ENUM_ENT(EF_MIPS_MACH_OCTEON, "octeon"), 1299 ENUM_ENT(EF_MIPS_MACH_XLR, "xlr"), 1300 ENUM_ENT(EF_MIPS_MACH_OCTEON2, "octeon2"), 1301 ENUM_ENT(EF_MIPS_MACH_OCTEON3, "octeon3"), 1302 ENUM_ENT(EF_MIPS_MACH_5400, "5400"), 1303 ENUM_ENT(EF_MIPS_MACH_5900, "5900"), 1304 ENUM_ENT(EF_MIPS_MACH_5500, "5500"), 1305 ENUM_ENT(EF_MIPS_MACH_9000, "9000"), 1306 ENUM_ENT(EF_MIPS_MACH_LS2E, "loongson-2e"), 1307 ENUM_ENT(EF_MIPS_MACH_LS2F, "loongson-2f"), 1308 ENUM_ENT(EF_MIPS_MACH_LS3A, "loongson-3a"), 1309 ENUM_ENT(EF_MIPS_MICROMIPS, "micromips"), 1310 ENUM_ENT(EF_MIPS_ARCH_ASE_M16, "mips16"), 1311 ENUM_ENT(EF_MIPS_ARCH_ASE_MDMX, "mdmx"), 1312 ENUM_ENT(EF_MIPS_ARCH_1, "mips1"), 1313 ENUM_ENT(EF_MIPS_ARCH_2, "mips2"), 1314 ENUM_ENT(EF_MIPS_ARCH_3, "mips3"), 1315 ENUM_ENT(EF_MIPS_ARCH_4, "mips4"), 1316 ENUM_ENT(EF_MIPS_ARCH_5, "mips5"), 1317 ENUM_ENT(EF_MIPS_ARCH_32, "mips32"), 1318 ENUM_ENT(EF_MIPS_ARCH_64, "mips64"), 1319 ENUM_ENT(EF_MIPS_ARCH_32R2, "mips32r2"), 1320 ENUM_ENT(EF_MIPS_ARCH_64R2, "mips64r2"), 1321 ENUM_ENT(EF_MIPS_ARCH_32R6, "mips32r6"), 1322 ENUM_ENT(EF_MIPS_ARCH_64R6, "mips64r6") 1323 }; 1324 1325 static const EnumEntry<unsigned> ElfHeaderAMDGPUFlags[] = { 1326 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_NONE), 1327 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_R600), 1328 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_R630), 1329 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_RS880), 1330 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_RV670), 1331 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_RV710), 1332 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_RV730), 1333 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_RV770), 1334 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_CEDAR), 1335 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_CYPRESS), 1336 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_JUNIPER), 1337 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_REDWOOD), 1338 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_SUMO), 1339 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_BARTS), 1340 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_CAICOS), 1341 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_CAYMAN), 1342 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_R600_TURKS), 1343 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX600), 1344 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX601), 1345 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX700), 1346 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX701), 1347 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX702), 1348 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX703), 1349 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX704), 1350 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX801), 1351 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX802), 1352 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX803), 1353 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX810), 1354 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX900), 1355 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX902), 1356 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX904), 1357 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX906), 1358 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_MACH_AMDGCN_GFX909), 1359 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_XNACK), 1360 LLVM_READOBJ_ENUM_ENT(ELF, EF_AMDGPU_SRAM_ECC) 1361 }; 1362 1363 static const EnumEntry<unsigned> ElfHeaderRISCVFlags[] = { 1364 ENUM_ENT(EF_RISCV_RVC, "RVC"), 1365 ENUM_ENT(EF_RISCV_FLOAT_ABI_SINGLE, "single-float ABI"), 1366 ENUM_ENT(EF_RISCV_FLOAT_ABI_DOUBLE, "double-float ABI"), 1367 ENUM_ENT(EF_RISCV_FLOAT_ABI_QUAD, "quad-float ABI"), 1368 ENUM_ENT(EF_RISCV_RVE, "RVE") 1369 }; 1370 1371 static const EnumEntry<unsigned> ElfSymOtherFlags[] = { 1372 LLVM_READOBJ_ENUM_ENT(ELF, STV_INTERNAL), 1373 LLVM_READOBJ_ENUM_ENT(ELF, STV_HIDDEN), 1374 LLVM_READOBJ_ENUM_ENT(ELF, STV_PROTECTED) 1375 }; 1376 1377 static const EnumEntry<unsigned> ElfMipsSymOtherFlags[] = { 1378 LLVM_READOBJ_ENUM_ENT(ELF, STO_MIPS_OPTIONAL), 1379 LLVM_READOBJ_ENUM_ENT(ELF, STO_MIPS_PLT), 1380 LLVM_READOBJ_ENUM_ENT(ELF, STO_MIPS_PIC), 1381 LLVM_READOBJ_ENUM_ENT(ELF, STO_MIPS_MICROMIPS) 1382 }; 1383 1384 static const EnumEntry<unsigned> ElfMips16SymOtherFlags[] = { 1385 LLVM_READOBJ_ENUM_ENT(ELF, STO_MIPS_OPTIONAL), 1386 LLVM_READOBJ_ENUM_ENT(ELF, STO_MIPS_PLT), 1387 LLVM_READOBJ_ENUM_ENT(ELF, STO_MIPS_MIPS16) 1388 }; 1389 1390 static const char *getElfMipsOptionsOdkType(unsigned Odk) { 1391 switch (Odk) { 1392 LLVM_READOBJ_ENUM_CASE(ELF, ODK_NULL); 1393 LLVM_READOBJ_ENUM_CASE(ELF, ODK_REGINFO); 1394 LLVM_READOBJ_ENUM_CASE(ELF, ODK_EXCEPTIONS); 1395 LLVM_READOBJ_ENUM_CASE(ELF, ODK_PAD); 1396 LLVM_READOBJ_ENUM_CASE(ELF, ODK_HWPATCH); 1397 LLVM_READOBJ_ENUM_CASE(ELF, ODK_FILL); 1398 LLVM_READOBJ_ENUM_CASE(ELF, ODK_TAGS); 1399 LLVM_READOBJ_ENUM_CASE(ELF, ODK_HWAND); 1400 LLVM_READOBJ_ENUM_CASE(ELF, ODK_HWOR); 1401 LLVM_READOBJ_ENUM_CASE(ELF, ODK_GP_GROUP); 1402 LLVM_READOBJ_ENUM_CASE(ELF, ODK_IDENT); 1403 LLVM_READOBJ_ENUM_CASE(ELF, ODK_PAGESIZE); 1404 default: 1405 return "Unknown"; 1406 } 1407 } 1408 1409 template <typename ELFT> 1410 ELFDumper<ELFT>::ELFDumper(const ELFFile<ELFT> *Obj, ScopedPrinter &Writer) 1411 : ObjDumper(Writer), Obj(Obj) { 1412 SmallVector<const Elf_Phdr *, 4> LoadSegments; 1413 for (const Elf_Phdr &Phdr : unwrapOrError(Obj->program_headers())) { 1414 if (Phdr.p_type == ELF::PT_DYNAMIC) { 1415 DynamicTable = createDRIFrom(&Phdr, sizeof(Elf_Dyn)); 1416 continue; 1417 } 1418 if (Phdr.p_type != ELF::PT_LOAD || Phdr.p_filesz == 0) 1419 continue; 1420 LoadSegments.push_back(&Phdr); 1421 } 1422 1423 for (const Elf_Shdr &Sec : unwrapOrError(Obj->sections())) { 1424 switch (Sec.sh_type) { 1425 case ELF::SHT_SYMTAB: 1426 if (DotSymtabSec != nullptr) 1427 reportError("Multiple SHT_SYMTAB"); 1428 DotSymtabSec = &Sec; 1429 break; 1430 case ELF::SHT_DYNSYM: 1431 if (DynSymRegion.Size) 1432 reportError("Multiple SHT_DYNSYM"); 1433 DynSymRegion = createDRIFrom(&Sec); 1434 // This is only used (if Elf_Shdr present)for naming section in GNU style 1435 DynSymtabName = unwrapOrError(Obj->getSectionName(&Sec)); 1436 DynamicStringTable = unwrapOrError(Obj->getStringTableForSymtab(Sec)); 1437 break; 1438 case ELF::SHT_SYMTAB_SHNDX: 1439 ShndxTable = unwrapOrError(Obj->getSHNDXTable(Sec)); 1440 break; 1441 case ELF::SHT_GNU_versym: 1442 if (dot_gnu_version_sec != nullptr) 1443 reportError("Multiple SHT_GNU_versym"); 1444 dot_gnu_version_sec = &Sec; 1445 break; 1446 case ELF::SHT_GNU_verdef: 1447 if (dot_gnu_version_d_sec != nullptr) 1448 reportError("Multiple SHT_GNU_verdef"); 1449 dot_gnu_version_d_sec = &Sec; 1450 break; 1451 case ELF::SHT_GNU_verneed: 1452 if (dot_gnu_version_r_sec != nullptr) 1453 reportError("Multiple SHT_GNU_verneed"); 1454 dot_gnu_version_r_sec = &Sec; 1455 break; 1456 case ELF::SHT_LLVM_CALL_GRAPH_PROFILE: 1457 if (DotCGProfileSec != nullptr) 1458 reportError("Multiple .llvm.call-graph-profile"); 1459 DotCGProfileSec = &Sec; 1460 break; 1461 case ELF::SHT_LLVM_ADDRSIG: 1462 if (DotAddrsigSec != nullptr) 1463 reportError("Multiple .llvm_addrsig"); 1464 DotAddrsigSec = &Sec; 1465 break; 1466 } 1467 } 1468 1469 parseDynamicTable(LoadSegments); 1470 1471 if (opts::Output == opts::GNU) 1472 ELFDumperStyle.reset(new GNUStyle<ELFT>(Writer, this)); 1473 else 1474 ELFDumperStyle.reset(new LLVMStyle<ELFT>(Writer, this)); 1475 } 1476 1477 template <typename ELFT> 1478 void ELFDumper<ELFT>::parseDynamicTable( 1479 ArrayRef<const Elf_Phdr *> LoadSegments) { 1480 auto toMappedAddr = [&](uint64_t VAddr) -> const uint8_t * { 1481 const Elf_Phdr *const *I = 1482 std::upper_bound(LoadSegments.begin(), LoadSegments.end(), VAddr, 1483 [](uint64_t VAddr, const Elf_Phdr_Impl<ELFT> *Phdr) { 1484 return VAddr < Phdr->p_vaddr; 1485 }); 1486 if (I == LoadSegments.begin()) 1487 report_fatal_error("Virtual address is not in any segment"); 1488 --I; 1489 const Elf_Phdr &Phdr = **I; 1490 uint64_t Delta = VAddr - Phdr.p_vaddr; 1491 if (Delta >= Phdr.p_filesz) 1492 report_fatal_error("Virtual address is not in any segment"); 1493 return Obj->base() + Phdr.p_offset + Delta; 1494 }; 1495 1496 uint64_t SONameOffset = 0; 1497 const char *StringTableBegin = nullptr; 1498 uint64_t StringTableSize = 0; 1499 for (const Elf_Dyn &Dyn : dynamic_table()) { 1500 switch (Dyn.d_tag) { 1501 case ELF::DT_HASH: 1502 HashTable = 1503 reinterpret_cast<const Elf_Hash *>(toMappedAddr(Dyn.getPtr())); 1504 break; 1505 case ELF::DT_GNU_HASH: 1506 GnuHashTable = 1507 reinterpret_cast<const Elf_GnuHash *>(toMappedAddr(Dyn.getPtr())); 1508 break; 1509 case ELF::DT_STRTAB: 1510 StringTableBegin = (const char *)toMappedAddr(Dyn.getPtr()); 1511 break; 1512 case ELF::DT_STRSZ: 1513 StringTableSize = Dyn.getVal(); 1514 break; 1515 case ELF::DT_SYMTAB: 1516 DynSymRegion.Addr = toMappedAddr(Dyn.getPtr()); 1517 DynSymRegion.EntSize = sizeof(Elf_Sym); 1518 break; 1519 case ELF::DT_RELA: 1520 DynRelaRegion.Addr = toMappedAddr(Dyn.getPtr()); 1521 break; 1522 case ELF::DT_RELASZ: 1523 DynRelaRegion.Size = Dyn.getVal(); 1524 break; 1525 case ELF::DT_RELAENT: 1526 DynRelaRegion.EntSize = Dyn.getVal(); 1527 break; 1528 case ELF::DT_SONAME: 1529 SONameOffset = Dyn.getVal(); 1530 break; 1531 case ELF::DT_REL: 1532 DynRelRegion.Addr = toMappedAddr(Dyn.getPtr()); 1533 break; 1534 case ELF::DT_RELSZ: 1535 DynRelRegion.Size = Dyn.getVal(); 1536 break; 1537 case ELF::DT_RELENT: 1538 DynRelRegion.EntSize = Dyn.getVal(); 1539 break; 1540 case ELF::DT_RELR: 1541 case ELF::DT_ANDROID_RELR: 1542 DynRelrRegion.Addr = toMappedAddr(Dyn.getPtr()); 1543 break; 1544 case ELF::DT_RELRSZ: 1545 case ELF::DT_ANDROID_RELRSZ: 1546 DynRelrRegion.Size = Dyn.getVal(); 1547 break; 1548 case ELF::DT_RELRENT: 1549 case ELF::DT_ANDROID_RELRENT: 1550 DynRelrRegion.EntSize = Dyn.getVal(); 1551 break; 1552 case ELF::DT_PLTREL: 1553 if (Dyn.getVal() == DT_REL) 1554 DynPLTRelRegion.EntSize = sizeof(Elf_Rel); 1555 else if (Dyn.getVal() == DT_RELA) 1556 DynPLTRelRegion.EntSize = sizeof(Elf_Rela); 1557 else 1558 reportError(Twine("unknown DT_PLTREL value of ") + 1559 Twine((uint64_t)Dyn.getVal())); 1560 break; 1561 case ELF::DT_JMPREL: 1562 DynPLTRelRegion.Addr = toMappedAddr(Dyn.getPtr()); 1563 break; 1564 case ELF::DT_PLTRELSZ: 1565 DynPLTRelRegion.Size = Dyn.getVal(); 1566 break; 1567 } 1568 } 1569 if (StringTableBegin) 1570 DynamicStringTable = StringRef(StringTableBegin, StringTableSize); 1571 if (SONameOffset) 1572 SOName = getDynamicString(SONameOffset); 1573 } 1574 1575 template <typename ELFT> 1576 typename ELFDumper<ELFT>::Elf_Rel_Range ELFDumper<ELFT>::dyn_rels() const { 1577 return DynRelRegion.getAsArrayRef<Elf_Rel>(); 1578 } 1579 1580 template <typename ELFT> 1581 typename ELFDumper<ELFT>::Elf_Rela_Range ELFDumper<ELFT>::dyn_relas() const { 1582 return DynRelaRegion.getAsArrayRef<Elf_Rela>(); 1583 } 1584 1585 template <typename ELFT> 1586 typename ELFDumper<ELFT>::Elf_Relr_Range ELFDumper<ELFT>::dyn_relrs() const { 1587 return DynRelrRegion.getAsArrayRef<Elf_Relr>(); 1588 } 1589 1590 template<class ELFT> 1591 void ELFDumper<ELFT>::printFileHeaders() { 1592 ELFDumperStyle->printFileHeaders(Obj); 1593 } 1594 1595 template <class ELFT> void ELFDumper<ELFT>::printSectionHeaders() { 1596 ELFDumperStyle->printSectionHeaders(Obj); 1597 } 1598 1599 template<class ELFT> 1600 void ELFDumper<ELFT>::printRelocations() { 1601 ELFDumperStyle->printRelocations(Obj); 1602 } 1603 1604 template <class ELFT> void ELFDumper<ELFT>::printProgramHeaders() { 1605 ELFDumperStyle->printProgramHeaders(Obj); 1606 } 1607 1608 template <class ELFT> void ELFDumper<ELFT>::printDynamicRelocations() { 1609 ELFDumperStyle->printDynamicRelocations(Obj); 1610 } 1611 1612 template<class ELFT> 1613 void ELFDumper<ELFT>::printSymbols() { 1614 ELFDumperStyle->printSymbols(Obj); 1615 } 1616 1617 template<class ELFT> 1618 void ELFDumper<ELFT>::printDynamicSymbols() { 1619 ELFDumperStyle->printDynamicSymbols(Obj); 1620 } 1621 1622 template <class ELFT> void ELFDumper<ELFT>::printHashHistogram() { 1623 ELFDumperStyle->printHashHistogram(Obj); 1624 } 1625 1626 template <class ELFT> void ELFDumper<ELFT>::printCGProfile() { 1627 ELFDumperStyle->printCGProfile(Obj); 1628 } 1629 1630 template <class ELFT> void ELFDumper<ELFT>::printNotes() { 1631 ELFDumperStyle->printNotes(Obj); 1632 } 1633 1634 template <class ELFT> void ELFDumper<ELFT>::printELFLinkerOptions() { 1635 ELFDumperStyle->printELFLinkerOptions(Obj); 1636 } 1637 1638 static const char *getTypeString(unsigned Arch, uint64_t Type) { 1639 #define DYNAMIC_TAG(n, v) 1640 switch (Arch) { 1641 case EM_HEXAGON: 1642 switch (Type) { 1643 #define HEXAGON_DYNAMIC_TAG(name, value) \ 1644 case DT_##name: \ 1645 return #name; 1646 #include "llvm/BinaryFormat/DynamicTags.def" 1647 #undef HEXAGON_DYNAMIC_TAG 1648 } 1649 break; 1650 1651 case EM_MIPS: 1652 switch (Type) { 1653 #define MIPS_DYNAMIC_TAG(name, value) \ 1654 case DT_##name: \ 1655 return #name; 1656 #include "llvm/BinaryFormat/DynamicTags.def" 1657 #undef MIPS_DYNAMIC_TAG 1658 } 1659 break; 1660 1661 case EM_PPC64: 1662 switch(Type) { 1663 #define PPC64_DYNAMIC_TAG(name, value) \ 1664 case DT_##name: \ 1665 return #name; 1666 #include "llvm/BinaryFormat/DynamicTags.def" 1667 #undef PPC64_DYNAMIC_TAG 1668 } 1669 break; 1670 } 1671 #undef DYNAMIC_TAG 1672 switch (Type) { 1673 // Now handle all dynamic tags except the architecture specific ones 1674 #define MIPS_DYNAMIC_TAG(name, value) 1675 #define HEXAGON_DYNAMIC_TAG(name, value) 1676 #define PPC64_DYNAMIC_TAG(name, value) 1677 // Also ignore marker tags such as DT_HIOS (maps to DT_VERNEEDNUM), etc. 1678 #define DYNAMIC_TAG_MARKER(name, value) 1679 #define DYNAMIC_TAG(name, value) \ 1680 case DT_##name: \ 1681 return #name; 1682 #include "llvm/BinaryFormat/DynamicTags.def" 1683 #undef DYNAMIC_TAG 1684 #undef MIPS_DYNAMIC_TAG 1685 #undef HEXAGON_DYNAMIC_TAG 1686 #undef PPC64_DYNAMIC_TAG 1687 #undef DYNAMIC_TAG_MARKER 1688 default: return "unknown"; 1689 } 1690 } 1691 1692 #define LLVM_READOBJ_DT_FLAG_ENT(prefix, enum) \ 1693 { #enum, prefix##_##enum } 1694 1695 static const EnumEntry<unsigned> ElfDynamicDTFlags[] = { 1696 LLVM_READOBJ_DT_FLAG_ENT(DF, ORIGIN), 1697 LLVM_READOBJ_DT_FLAG_ENT(DF, SYMBOLIC), 1698 LLVM_READOBJ_DT_FLAG_ENT(DF, TEXTREL), 1699 LLVM_READOBJ_DT_FLAG_ENT(DF, BIND_NOW), 1700 LLVM_READOBJ_DT_FLAG_ENT(DF, STATIC_TLS) 1701 }; 1702 1703 static const EnumEntry<unsigned> ElfDynamicDTFlags1[] = { 1704 LLVM_READOBJ_DT_FLAG_ENT(DF_1, NOW), 1705 LLVM_READOBJ_DT_FLAG_ENT(DF_1, GLOBAL), 1706 LLVM_READOBJ_DT_FLAG_ENT(DF_1, GROUP), 1707 LLVM_READOBJ_DT_FLAG_ENT(DF_1, NODELETE), 1708 LLVM_READOBJ_DT_FLAG_ENT(DF_1, LOADFLTR), 1709 LLVM_READOBJ_DT_FLAG_ENT(DF_1, INITFIRST), 1710 LLVM_READOBJ_DT_FLAG_ENT(DF_1, NOOPEN), 1711 LLVM_READOBJ_DT_FLAG_ENT(DF_1, ORIGIN), 1712 LLVM_READOBJ_DT_FLAG_ENT(DF_1, DIRECT), 1713 LLVM_READOBJ_DT_FLAG_ENT(DF_1, TRANS), 1714 LLVM_READOBJ_DT_FLAG_ENT(DF_1, INTERPOSE), 1715 LLVM_READOBJ_DT_FLAG_ENT(DF_1, NODEFLIB), 1716 LLVM_READOBJ_DT_FLAG_ENT(DF_1, NODUMP), 1717 LLVM_READOBJ_DT_FLAG_ENT(DF_1, CONFALT), 1718 LLVM_READOBJ_DT_FLAG_ENT(DF_1, ENDFILTEE), 1719 LLVM_READOBJ_DT_FLAG_ENT(DF_1, DISPRELDNE), 1720 LLVM_READOBJ_DT_FLAG_ENT(DF_1, NODIRECT), 1721 LLVM_READOBJ_DT_FLAG_ENT(DF_1, IGNMULDEF), 1722 LLVM_READOBJ_DT_FLAG_ENT(DF_1, NOKSYMS), 1723 LLVM_READOBJ_DT_FLAG_ENT(DF_1, NOHDR), 1724 LLVM_READOBJ_DT_FLAG_ENT(DF_1, EDITED), 1725 LLVM_READOBJ_DT_FLAG_ENT(DF_1, NORELOC), 1726 LLVM_READOBJ_DT_FLAG_ENT(DF_1, SYMINTPOSE), 1727 LLVM_READOBJ_DT_FLAG_ENT(DF_1, GLOBAUDIT), 1728 LLVM_READOBJ_DT_FLAG_ENT(DF_1, SINGLETON) 1729 }; 1730 1731 static const EnumEntry<unsigned> ElfDynamicDTMipsFlags[] = { 1732 LLVM_READOBJ_DT_FLAG_ENT(RHF, NONE), 1733 LLVM_READOBJ_DT_FLAG_ENT(RHF, QUICKSTART), 1734 LLVM_READOBJ_DT_FLAG_ENT(RHF, NOTPOT), 1735 LLVM_READOBJ_DT_FLAG_ENT(RHS, NO_LIBRARY_REPLACEMENT), 1736 LLVM_READOBJ_DT_FLAG_ENT(RHF, NO_MOVE), 1737 LLVM_READOBJ_DT_FLAG_ENT(RHF, SGI_ONLY), 1738 LLVM_READOBJ_DT_FLAG_ENT(RHF, GUARANTEE_INIT), 1739 LLVM_READOBJ_DT_FLAG_ENT(RHF, DELTA_C_PLUS_PLUS), 1740 LLVM_READOBJ_DT_FLAG_ENT(RHF, GUARANTEE_START_INIT), 1741 LLVM_READOBJ_DT_FLAG_ENT(RHF, PIXIE), 1742 LLVM_READOBJ_DT_FLAG_ENT(RHF, DEFAULT_DELAY_LOAD), 1743 LLVM_READOBJ_DT_FLAG_ENT(RHF, REQUICKSTART), 1744 LLVM_READOBJ_DT_FLAG_ENT(RHF, REQUICKSTARTED), 1745 LLVM_READOBJ_DT_FLAG_ENT(RHF, CORD), 1746 LLVM_READOBJ_DT_FLAG_ENT(RHF, NO_UNRES_UNDEF), 1747 LLVM_READOBJ_DT_FLAG_ENT(RHF, RLD_ORDER_SAFE) 1748 }; 1749 1750 #undef LLVM_READOBJ_DT_FLAG_ENT 1751 1752 template <typename T, typename TFlag> 1753 void printFlags(T Value, ArrayRef<EnumEntry<TFlag>> Flags, raw_ostream &OS) { 1754 using FlagEntry = EnumEntry<TFlag>; 1755 using FlagVector = SmallVector<FlagEntry, 10>; 1756 FlagVector SetFlags; 1757 1758 for (const auto &Flag : Flags) { 1759 if (Flag.Value == 0) 1760 continue; 1761 1762 if ((Value & Flag.Value) == Flag.Value) 1763 SetFlags.push_back(Flag); 1764 } 1765 1766 for (const auto &Flag : SetFlags) { 1767 OS << Flag.Name << " "; 1768 } 1769 } 1770 1771 template <class ELFT> 1772 StringRef ELFDumper<ELFT>::getDynamicString(uint64_t Value) const { 1773 if (Value >= DynamicStringTable.size()) 1774 reportError("Invalid dynamic string table reference"); 1775 return StringRef(DynamicStringTable.data() + Value); 1776 } 1777 1778 static void printLibrary(raw_ostream &OS, const Twine &Tag, const Twine &Name) { 1779 OS << Tag << ": [" << Name << "]"; 1780 } 1781 1782 template <class ELFT> 1783 void ELFDumper<ELFT>::printValue(uint64_t Type, uint64_t Value) { 1784 raw_ostream &OS = W.getOStream(); 1785 const char* ConvChar = (opts::Output == opts::GNU) ? "0x%" PRIx64 : "0x%" PRIX64; 1786 switch (Type) { 1787 case DT_PLTREL: 1788 if (Value == DT_REL) { 1789 OS << "REL"; 1790 break; 1791 } else if (Value == DT_RELA) { 1792 OS << "RELA"; 1793 break; 1794 } 1795 LLVM_FALLTHROUGH; 1796 case DT_PLTGOT: 1797 case DT_HASH: 1798 case DT_STRTAB: 1799 case DT_SYMTAB: 1800 case DT_RELA: 1801 case DT_INIT: 1802 case DT_FINI: 1803 case DT_REL: 1804 case DT_JMPREL: 1805 case DT_INIT_ARRAY: 1806 case DT_FINI_ARRAY: 1807 case DT_PREINIT_ARRAY: 1808 case DT_DEBUG: 1809 case DT_VERDEF: 1810 case DT_VERNEED: 1811 case DT_VERSYM: 1812 case DT_GNU_HASH: 1813 case DT_NULL: 1814 case DT_MIPS_BASE_ADDRESS: 1815 case DT_MIPS_GOTSYM: 1816 case DT_MIPS_RLD_MAP: 1817 case DT_MIPS_RLD_MAP_REL: 1818 case DT_MIPS_PLTGOT: 1819 case DT_MIPS_OPTIONS: 1820 OS << format(ConvChar, Value); 1821 break; 1822 case DT_RELACOUNT: 1823 case DT_RELCOUNT: 1824 case DT_VERDEFNUM: 1825 case DT_VERNEEDNUM: 1826 case DT_MIPS_RLD_VERSION: 1827 case DT_MIPS_LOCAL_GOTNO: 1828 case DT_MIPS_SYMTABNO: 1829 case DT_MIPS_UNREFEXTNO: 1830 OS << Value; 1831 break; 1832 case DT_PLTRELSZ: 1833 case DT_RELASZ: 1834 case DT_RELAENT: 1835 case DT_STRSZ: 1836 case DT_SYMENT: 1837 case DT_RELSZ: 1838 case DT_RELENT: 1839 case DT_INIT_ARRAYSZ: 1840 case DT_FINI_ARRAYSZ: 1841 case DT_PREINIT_ARRAYSZ: 1842 case DT_ANDROID_RELSZ: 1843 case DT_ANDROID_RELASZ: 1844 OS << Value << " (bytes)"; 1845 break; 1846 case DT_NEEDED: 1847 printLibrary(OS, "Shared library", getDynamicString(Value)); 1848 break; 1849 case DT_SONAME: 1850 printLibrary(OS, "Library soname", getDynamicString(Value)); 1851 break; 1852 case DT_AUXILIARY: 1853 printLibrary(OS, "Auxiliary library", getDynamicString(Value)); 1854 break; 1855 case DT_FILTER: 1856 printLibrary(OS, "Filter library", getDynamicString(Value)); 1857 break; 1858 case DT_RPATH: 1859 case DT_RUNPATH: 1860 OS << getDynamicString(Value); 1861 break; 1862 case DT_MIPS_FLAGS: 1863 printFlags(Value, makeArrayRef(ElfDynamicDTMipsFlags), OS); 1864 break; 1865 case DT_FLAGS: 1866 printFlags(Value, makeArrayRef(ElfDynamicDTFlags), OS); 1867 break; 1868 case DT_FLAGS_1: 1869 printFlags(Value, makeArrayRef(ElfDynamicDTFlags1), OS); 1870 break; 1871 default: 1872 OS << format(ConvChar, Value); 1873 break; 1874 } 1875 } 1876 1877 template<class ELFT> 1878 void ELFDumper<ELFT>::printUnwindInfo() { 1879 const unsigned Machine = Obj->getHeader()->e_machine; 1880 if (Machine == EM_386 || Machine == EM_X86_64) { 1881 DwarfCFIEH::PrinterContext<ELFT> Ctx(W, Obj); 1882 return Ctx.printUnwindInformation(); 1883 } 1884 W.startLine() << "UnwindInfo not implemented.\n"; 1885 } 1886 1887 namespace { 1888 1889 template <> void ELFDumper<ELF32LE>::printUnwindInfo() { 1890 const unsigned Machine = Obj->getHeader()->e_machine; 1891 if (Machine == EM_ARM) { 1892 ARM::EHABI::PrinterContext<ELF32LE> Ctx(W, Obj, DotSymtabSec); 1893 return Ctx.PrintUnwindInformation(); 1894 } 1895 W.startLine() << "UnwindInfo not implemented.\n"; 1896 } 1897 1898 } // end anonymous namespace 1899 1900 template<class ELFT> 1901 void ELFDumper<ELFT>::printDynamicTable() { 1902 auto I = dynamic_table().begin(); 1903 auto E = dynamic_table().end(); 1904 1905 if (I == E) 1906 return; 1907 1908 --E; 1909 while (I != E && E->getTag() == ELF::DT_NULL) 1910 --E; 1911 if (E->getTag() != ELF::DT_NULL) 1912 ++E; 1913 ++E; 1914 1915 ptrdiff_t Total = std::distance(I, E); 1916 if (Total == 0) 1917 return; 1918 1919 raw_ostream &OS = W.getOStream(); 1920 W.startLine() << "DynamicSection [ (" << Total << " entries)\n"; 1921 1922 bool Is64 = ELFT::Is64Bits; 1923 1924 W.startLine() 1925 << " Tag" << (Is64 ? " " : " ") << "Type" 1926 << " " << "Name/Value\n"; 1927 while (I != E) { 1928 const Elf_Dyn &Entry = *I; 1929 uintX_t Tag = Entry.getTag(); 1930 ++I; 1931 W.startLine() << " " << format_hex(Tag, Is64 ? 18 : 10, opts::Output != opts::GNU) << " " 1932 << format("%-21s", getTypeString(Obj->getHeader()->e_machine, Tag)); 1933 printValue(Tag, Entry.getVal()); 1934 OS << "\n"; 1935 } 1936 1937 W.startLine() << "]\n"; 1938 } 1939 1940 template<class ELFT> 1941 void ELFDumper<ELFT>::printNeededLibraries() { 1942 ListScope D(W, "NeededLibraries"); 1943 1944 using LibsTy = std::vector<StringRef>; 1945 LibsTy Libs; 1946 1947 for (const auto &Entry : dynamic_table()) 1948 if (Entry.d_tag == ELF::DT_NEEDED) 1949 Libs.push_back(getDynamicString(Entry.d_un.d_val)); 1950 1951 std::stable_sort(Libs.begin(), Libs.end()); 1952 1953 for (const auto &L : Libs) 1954 W.startLine() << L << "\n"; 1955 } 1956 1957 1958 template <typename ELFT> 1959 void ELFDumper<ELFT>::printHashTable() { 1960 DictScope D(W, "HashTable"); 1961 if (!HashTable) 1962 return; 1963 W.printNumber("Num Buckets", HashTable->nbucket); 1964 W.printNumber("Num Chains", HashTable->nchain); 1965 W.printList("Buckets", HashTable->buckets()); 1966 W.printList("Chains", HashTable->chains()); 1967 } 1968 1969 template <typename ELFT> 1970 void ELFDumper<ELFT>::printGnuHashTable() { 1971 DictScope D(W, "GnuHashTable"); 1972 if (!GnuHashTable) 1973 return; 1974 W.printNumber("Num Buckets", GnuHashTable->nbuckets); 1975 W.printNumber("First Hashed Symbol Index", GnuHashTable->symndx); 1976 W.printNumber("Num Mask Words", GnuHashTable->maskwords); 1977 W.printNumber("Shift Count", GnuHashTable->shift2); 1978 W.printHexList("Bloom Filter", GnuHashTable->filter()); 1979 W.printList("Buckets", GnuHashTable->buckets()); 1980 Elf_Sym_Range Syms = dynamic_symbols(); 1981 unsigned NumSyms = std::distance(Syms.begin(), Syms.end()); 1982 if (!NumSyms) 1983 reportError("No dynamic symbol section"); 1984 W.printHexList("Values", GnuHashTable->values(NumSyms)); 1985 } 1986 1987 template <typename ELFT> void ELFDumper<ELFT>::printLoadName() { 1988 W.printString("LoadName", SOName); 1989 } 1990 1991 template <class ELFT> 1992 void ELFDumper<ELFT>::printAttributes() { 1993 W.startLine() << "Attributes not implemented.\n"; 1994 } 1995 1996 namespace { 1997 1998 template <> void ELFDumper<ELF32LE>::printAttributes() { 1999 if (Obj->getHeader()->e_machine != EM_ARM) { 2000 W.startLine() << "Attributes not implemented.\n"; 2001 return; 2002 } 2003 2004 DictScope BA(W, "BuildAttributes"); 2005 for (const ELFO::Elf_Shdr &Sec : unwrapOrError(Obj->sections())) { 2006 if (Sec.sh_type != ELF::SHT_ARM_ATTRIBUTES) 2007 continue; 2008 2009 ArrayRef<uint8_t> Contents = unwrapOrError(Obj->getSectionContents(&Sec)); 2010 if (Contents[0] != ARMBuildAttrs::Format_Version) { 2011 errs() << "unrecognised FormatVersion: 0x" 2012 << Twine::utohexstr(Contents[0]) << '\n'; 2013 continue; 2014 } 2015 2016 W.printHex("FormatVersion", Contents[0]); 2017 if (Contents.size() == 1) 2018 continue; 2019 2020 ARMAttributeParser(&W).Parse(Contents, true); 2021 } 2022 } 2023 2024 template <class ELFT> class MipsGOTParser { 2025 public: 2026 TYPEDEF_ELF_TYPES(ELFT) 2027 using Entry = typename ELFO::Elf_Addr; 2028 using Entries = ArrayRef<Entry>; 2029 2030 const bool IsStatic; 2031 const ELFO * const Obj; 2032 2033 MipsGOTParser(const ELFO *Obj, Elf_Dyn_Range DynTable, Elf_Sym_Range DynSyms); 2034 2035 bool hasGot() const { return !GotEntries.empty(); } 2036 bool hasPlt() const { return !PltEntries.empty(); } 2037 2038 uint64_t getGp() const; 2039 2040 const Entry *getGotLazyResolver() const; 2041 const Entry *getGotModulePointer() const; 2042 const Entry *getPltLazyResolver() const; 2043 const Entry *getPltModulePointer() const; 2044 2045 Entries getLocalEntries() const; 2046 Entries getGlobalEntries() const; 2047 Entries getOtherEntries() const; 2048 Entries getPltEntries() const; 2049 2050 uint64_t getGotAddress(const Entry * E) const; 2051 int64_t getGotOffset(const Entry * E) const; 2052 const Elf_Sym *getGotSym(const Entry *E) const; 2053 2054 uint64_t getPltAddress(const Entry * E) const; 2055 const Elf_Sym *getPltSym(const Entry *E) const; 2056 2057 StringRef getPltStrTable() const { return PltStrTable; } 2058 2059 private: 2060 const Elf_Shdr *GotSec; 2061 size_t LocalNum; 2062 size_t GlobalNum; 2063 2064 const Elf_Shdr *PltSec; 2065 const Elf_Shdr *PltRelSec; 2066 const Elf_Shdr *PltSymTable; 2067 Elf_Sym_Range GotDynSyms; 2068 StringRef PltStrTable; 2069 2070 Entries GotEntries; 2071 Entries PltEntries; 2072 }; 2073 2074 } // end anonymous namespace 2075 2076 template <class ELFT> 2077 MipsGOTParser<ELFT>::MipsGOTParser(const ELFO *Obj, Elf_Dyn_Range DynTable, 2078 Elf_Sym_Range DynSyms) 2079 : IsStatic(DynTable.empty()), Obj(Obj), GotSec(nullptr), LocalNum(0), 2080 GlobalNum(0), PltSec(nullptr), PltRelSec(nullptr), PltSymTable(nullptr) { 2081 // See "Global Offset Table" in Chapter 5 in the following document 2082 // for detailed GOT description. 2083 // ftp://www.linux-mips.org/pub/linux/mips/doc/ABI/mipsabi.pdf 2084 2085 // Find static GOT secton. 2086 if (IsStatic) { 2087 GotSec = findSectionByName(*Obj, ".got"); 2088 if (!GotSec) 2089 reportError("Cannot find .got section"); 2090 2091 ArrayRef<uint8_t> Content = unwrapOrError(Obj->getSectionContents(GotSec)); 2092 GotEntries = Entries(reinterpret_cast<const Entry *>(Content.data()), 2093 Content.size() / sizeof(Entry)); 2094 LocalNum = GotEntries.size(); 2095 return; 2096 } 2097 2098 // Lookup dynamic table tags which define GOT/PLT layouts. 2099 Optional<uint64_t> DtPltGot; 2100 Optional<uint64_t> DtLocalGotNum; 2101 Optional<uint64_t> DtGotSym; 2102 Optional<uint64_t> DtMipsPltGot; 2103 Optional<uint64_t> DtJmpRel; 2104 for (const auto &Entry : DynTable) { 2105 switch (Entry.getTag()) { 2106 case ELF::DT_PLTGOT: 2107 DtPltGot = Entry.getVal(); 2108 break; 2109 case ELF::DT_MIPS_LOCAL_GOTNO: 2110 DtLocalGotNum = Entry.getVal(); 2111 break; 2112 case ELF::DT_MIPS_GOTSYM: 2113 DtGotSym = Entry.getVal(); 2114 break; 2115 case ELF::DT_MIPS_PLTGOT: 2116 DtMipsPltGot = Entry.getVal(); 2117 break; 2118 case ELF::DT_JMPREL: 2119 DtJmpRel = Entry.getVal(); 2120 break; 2121 } 2122 } 2123 2124 // Find dynamic GOT section. 2125 if (DtPltGot || DtLocalGotNum || DtGotSym) { 2126 if (!DtPltGot) 2127 report_fatal_error("Cannot find PLTGOT dynamic table tag."); 2128 if (!DtLocalGotNum) 2129 report_fatal_error("Cannot find MIPS_LOCAL_GOTNO dynamic table tag."); 2130 if (!DtGotSym) 2131 report_fatal_error("Cannot find MIPS_GOTSYM dynamic table tag."); 2132 2133 size_t DynSymTotal = DynSyms.size(); 2134 if (*DtGotSym > DynSymTotal) 2135 reportError("MIPS_GOTSYM exceeds a number of dynamic symbols"); 2136 2137 GotSec = findNotEmptySectionByAddress(Obj, *DtPltGot); 2138 if (!GotSec) 2139 reportError("There is no not empty GOT section at 0x" + 2140 Twine::utohexstr(*DtPltGot)); 2141 2142 LocalNum = *DtLocalGotNum; 2143 GlobalNum = DynSymTotal - *DtGotSym; 2144 2145 ArrayRef<uint8_t> Content = unwrapOrError(Obj->getSectionContents(GotSec)); 2146 GotEntries = Entries(reinterpret_cast<const Entry *>(Content.data()), 2147 Content.size() / sizeof(Entry)); 2148 GotDynSyms = DynSyms.drop_front(*DtGotSym); 2149 } 2150 2151 // Find PLT section. 2152 if (DtMipsPltGot || DtJmpRel) { 2153 if (!DtMipsPltGot) 2154 report_fatal_error("Cannot find MIPS_PLTGOT dynamic table tag."); 2155 if (!DtJmpRel) 2156 report_fatal_error("Cannot find JMPREL dynamic table tag."); 2157 2158 PltSec = findNotEmptySectionByAddress(Obj, *DtMipsPltGot); 2159 if (!PltSec) 2160 report_fatal_error("There is no not empty PLTGOT section at 0x " + 2161 Twine::utohexstr(*DtMipsPltGot)); 2162 2163 PltRelSec = findNotEmptySectionByAddress(Obj, *DtJmpRel); 2164 if (!PltRelSec) 2165 report_fatal_error("There is no not empty RELPLT section at 0x" + 2166 Twine::utohexstr(*DtJmpRel)); 2167 2168 ArrayRef<uint8_t> PltContent = 2169 unwrapOrError(Obj->getSectionContents(PltSec)); 2170 PltEntries = Entries(reinterpret_cast<const Entry *>(PltContent.data()), 2171 PltContent.size() / sizeof(Entry)); 2172 2173 PltSymTable = unwrapOrError(Obj->getSection(PltRelSec->sh_link)); 2174 PltStrTable = unwrapOrError(Obj->getStringTableForSymtab(*PltSymTable)); 2175 } 2176 } 2177 2178 template <class ELFT> uint64_t MipsGOTParser<ELFT>::getGp() const { 2179 return GotSec->sh_addr + 0x7ff0; 2180 } 2181 2182 template <class ELFT> 2183 const typename MipsGOTParser<ELFT>::Entry * 2184 MipsGOTParser<ELFT>::getGotLazyResolver() const { 2185 return LocalNum > 0 ? &GotEntries[0] : nullptr; 2186 } 2187 2188 template <class ELFT> 2189 const typename MipsGOTParser<ELFT>::Entry * 2190 MipsGOTParser<ELFT>::getGotModulePointer() const { 2191 if (LocalNum < 2) 2192 return nullptr; 2193 const Entry &E = GotEntries[1]; 2194 if ((E >> (sizeof(Entry) * 8 - 1)) == 0) 2195 return nullptr; 2196 return &E; 2197 } 2198 2199 template <class ELFT> 2200 typename MipsGOTParser<ELFT>::Entries 2201 MipsGOTParser<ELFT>::getLocalEntries() const { 2202 size_t Skip = getGotModulePointer() ? 2 : 1; 2203 if (LocalNum - Skip <= 0) 2204 return Entries(); 2205 return GotEntries.slice(Skip, LocalNum - Skip); 2206 } 2207 2208 template <class ELFT> 2209 typename MipsGOTParser<ELFT>::Entries 2210 MipsGOTParser<ELFT>::getGlobalEntries() const { 2211 if (GlobalNum == 0) 2212 return Entries(); 2213 return GotEntries.slice(LocalNum, GlobalNum); 2214 } 2215 2216 template <class ELFT> 2217 typename MipsGOTParser<ELFT>::Entries 2218 MipsGOTParser<ELFT>::getOtherEntries() const { 2219 size_t OtherNum = GotEntries.size() - LocalNum - GlobalNum; 2220 if (OtherNum == 0) 2221 return Entries(); 2222 return GotEntries.slice(LocalNum + GlobalNum, OtherNum); 2223 } 2224 2225 template <class ELFT> 2226 uint64_t MipsGOTParser<ELFT>::getGotAddress(const Entry *E) const { 2227 int64_t Offset = std::distance(GotEntries.data(), E) * sizeof(Entry); 2228 return GotSec->sh_addr + Offset; 2229 } 2230 2231 template <class ELFT> 2232 int64_t MipsGOTParser<ELFT>::getGotOffset(const Entry *E) const { 2233 int64_t Offset = std::distance(GotEntries.data(), E) * sizeof(Entry); 2234 return Offset - 0x7ff0; 2235 } 2236 2237 template <class ELFT> 2238 const typename MipsGOTParser<ELFT>::Elf_Sym * 2239 MipsGOTParser<ELFT>::getGotSym(const Entry *E) const { 2240 int64_t Offset = std::distance(GotEntries.data(), E); 2241 return &GotDynSyms[Offset - LocalNum]; 2242 } 2243 2244 template <class ELFT> 2245 const typename MipsGOTParser<ELFT>::Entry * 2246 MipsGOTParser<ELFT>::getPltLazyResolver() const { 2247 return PltEntries.empty() ? nullptr : &PltEntries[0]; 2248 } 2249 2250 template <class ELFT> 2251 const typename MipsGOTParser<ELFT>::Entry * 2252 MipsGOTParser<ELFT>::getPltModulePointer() const { 2253 return PltEntries.size() < 2 ? nullptr : &PltEntries[1]; 2254 } 2255 2256 template <class ELFT> 2257 typename MipsGOTParser<ELFT>::Entries 2258 MipsGOTParser<ELFT>::getPltEntries() const { 2259 if (PltEntries.size() <= 2) 2260 return Entries(); 2261 return PltEntries.slice(2, PltEntries.size() - 2); 2262 } 2263 2264 template <class ELFT> 2265 uint64_t MipsGOTParser<ELFT>::getPltAddress(const Entry *E) const { 2266 int64_t Offset = std::distance(PltEntries.data(), E) * sizeof(Entry); 2267 return PltSec->sh_addr + Offset; 2268 } 2269 2270 template <class ELFT> 2271 const typename MipsGOTParser<ELFT>::Elf_Sym * 2272 MipsGOTParser<ELFT>::getPltSym(const Entry *E) const { 2273 int64_t Offset = std::distance(getPltEntries().data(), E); 2274 if (PltRelSec->sh_type == ELF::SHT_REL) { 2275 Elf_Rel_Range Rels = unwrapOrError(Obj->rels(PltRelSec)); 2276 return unwrapOrError(Obj->getRelocationSymbol(&Rels[Offset], PltSymTable)); 2277 } else { 2278 Elf_Rela_Range Rels = unwrapOrError(Obj->relas(PltRelSec)); 2279 return unwrapOrError(Obj->getRelocationSymbol(&Rels[Offset], PltSymTable)); 2280 } 2281 } 2282 2283 template <class ELFT> void ELFDumper<ELFT>::printMipsPLTGOT() { 2284 if (Obj->getHeader()->e_machine != EM_MIPS) 2285 reportError("MIPS PLT GOT is available for MIPS targets only"); 2286 2287 MipsGOTParser<ELFT> Parser(Obj, dynamic_table(), dynamic_symbols()); 2288 if (Parser.hasGot()) 2289 ELFDumperStyle->printMipsGOT(Parser); 2290 if (Parser.hasPlt()) 2291 ELFDumperStyle->printMipsPLT(Parser); 2292 } 2293 2294 static const EnumEntry<unsigned> ElfMipsISAExtType[] = { 2295 {"None", Mips::AFL_EXT_NONE}, 2296 {"Broadcom SB-1", Mips::AFL_EXT_SB1}, 2297 {"Cavium Networks Octeon", Mips::AFL_EXT_OCTEON}, 2298 {"Cavium Networks Octeon2", Mips::AFL_EXT_OCTEON2}, 2299 {"Cavium Networks OcteonP", Mips::AFL_EXT_OCTEONP}, 2300 {"Cavium Networks Octeon3", Mips::AFL_EXT_OCTEON3}, 2301 {"LSI R4010", Mips::AFL_EXT_4010}, 2302 {"Loongson 2E", Mips::AFL_EXT_LOONGSON_2E}, 2303 {"Loongson 2F", Mips::AFL_EXT_LOONGSON_2F}, 2304 {"Loongson 3A", Mips::AFL_EXT_LOONGSON_3A}, 2305 {"MIPS R4650", Mips::AFL_EXT_4650}, 2306 {"MIPS R5900", Mips::AFL_EXT_5900}, 2307 {"MIPS R10000", Mips::AFL_EXT_10000}, 2308 {"NEC VR4100", Mips::AFL_EXT_4100}, 2309 {"NEC VR4111/VR4181", Mips::AFL_EXT_4111}, 2310 {"NEC VR4120", Mips::AFL_EXT_4120}, 2311 {"NEC VR5400", Mips::AFL_EXT_5400}, 2312 {"NEC VR5500", Mips::AFL_EXT_5500}, 2313 {"RMI Xlr", Mips::AFL_EXT_XLR}, 2314 {"Toshiba R3900", Mips::AFL_EXT_3900} 2315 }; 2316 2317 static const EnumEntry<unsigned> ElfMipsASEFlags[] = { 2318 {"DSP", Mips::AFL_ASE_DSP}, 2319 {"DSPR2", Mips::AFL_ASE_DSPR2}, 2320 {"Enhanced VA Scheme", Mips::AFL_ASE_EVA}, 2321 {"MCU", Mips::AFL_ASE_MCU}, 2322 {"MDMX", Mips::AFL_ASE_MDMX}, 2323 {"MIPS-3D", Mips::AFL_ASE_MIPS3D}, 2324 {"MT", Mips::AFL_ASE_MT}, 2325 {"SmartMIPS", Mips::AFL_ASE_SMARTMIPS}, 2326 {"VZ", Mips::AFL_ASE_VIRT}, 2327 {"MSA", Mips::AFL_ASE_MSA}, 2328 {"MIPS16", Mips::AFL_ASE_MIPS16}, 2329 {"microMIPS", Mips::AFL_ASE_MICROMIPS}, 2330 {"XPA", Mips::AFL_ASE_XPA}, 2331 {"CRC", Mips::AFL_ASE_CRC}, 2332 {"GINV", Mips::AFL_ASE_GINV}, 2333 }; 2334 2335 static const EnumEntry<unsigned> ElfMipsFpABIType[] = { 2336 {"Hard or soft float", Mips::Val_GNU_MIPS_ABI_FP_ANY}, 2337 {"Hard float (double precision)", Mips::Val_GNU_MIPS_ABI_FP_DOUBLE}, 2338 {"Hard float (single precision)", Mips::Val_GNU_MIPS_ABI_FP_SINGLE}, 2339 {"Soft float", Mips::Val_GNU_MIPS_ABI_FP_SOFT}, 2340 {"Hard float (MIPS32r2 64-bit FPU 12 callee-saved)", 2341 Mips::Val_GNU_MIPS_ABI_FP_OLD_64}, 2342 {"Hard float (32-bit CPU, Any FPU)", Mips::Val_GNU_MIPS_ABI_FP_XX}, 2343 {"Hard float (32-bit CPU, 64-bit FPU)", Mips::Val_GNU_MIPS_ABI_FP_64}, 2344 {"Hard float compat (32-bit CPU, 64-bit FPU)", 2345 Mips::Val_GNU_MIPS_ABI_FP_64A} 2346 }; 2347 2348 static const EnumEntry<unsigned> ElfMipsFlags1[] { 2349 {"ODDSPREG", Mips::AFL_FLAGS1_ODDSPREG}, 2350 }; 2351 2352 static int getMipsRegisterSize(uint8_t Flag) { 2353 switch (Flag) { 2354 case Mips::AFL_REG_NONE: 2355 return 0; 2356 case Mips::AFL_REG_32: 2357 return 32; 2358 case Mips::AFL_REG_64: 2359 return 64; 2360 case Mips::AFL_REG_128: 2361 return 128; 2362 default: 2363 return -1; 2364 } 2365 } 2366 2367 template <class ELFT> void ELFDumper<ELFT>::printMipsABIFlags() { 2368 const Elf_Shdr *Shdr = findSectionByName(*Obj, ".MIPS.abiflags"); 2369 if (!Shdr) { 2370 W.startLine() << "There is no .MIPS.abiflags section in the file.\n"; 2371 return; 2372 } 2373 ArrayRef<uint8_t> Sec = unwrapOrError(Obj->getSectionContents(Shdr)); 2374 if (Sec.size() != sizeof(Elf_Mips_ABIFlags<ELFT>)) { 2375 W.startLine() << "The .MIPS.abiflags section has a wrong size.\n"; 2376 return; 2377 } 2378 2379 auto *Flags = reinterpret_cast<const Elf_Mips_ABIFlags<ELFT> *>(Sec.data()); 2380 2381 raw_ostream &OS = W.getOStream(); 2382 DictScope GS(W, "MIPS ABI Flags"); 2383 2384 W.printNumber("Version", Flags->version); 2385 W.startLine() << "ISA: "; 2386 if (Flags->isa_rev <= 1) 2387 OS << format("MIPS%u", Flags->isa_level); 2388 else 2389 OS << format("MIPS%ur%u", Flags->isa_level, Flags->isa_rev); 2390 OS << "\n"; 2391 W.printEnum("ISA Extension", Flags->isa_ext, makeArrayRef(ElfMipsISAExtType)); 2392 W.printFlags("ASEs", Flags->ases, makeArrayRef(ElfMipsASEFlags)); 2393 W.printEnum("FP ABI", Flags->fp_abi, makeArrayRef(ElfMipsFpABIType)); 2394 W.printNumber("GPR size", getMipsRegisterSize(Flags->gpr_size)); 2395 W.printNumber("CPR1 size", getMipsRegisterSize(Flags->cpr1_size)); 2396 W.printNumber("CPR2 size", getMipsRegisterSize(Flags->cpr2_size)); 2397 W.printFlags("Flags 1", Flags->flags1, makeArrayRef(ElfMipsFlags1)); 2398 W.printHex("Flags 2", Flags->flags2); 2399 } 2400 2401 template <class ELFT> 2402 static void printMipsReginfoData(ScopedPrinter &W, 2403 const Elf_Mips_RegInfo<ELFT> &Reginfo) { 2404 W.printHex("GP", Reginfo.ri_gp_value); 2405 W.printHex("General Mask", Reginfo.ri_gprmask); 2406 W.printHex("Co-Proc Mask0", Reginfo.ri_cprmask[0]); 2407 W.printHex("Co-Proc Mask1", Reginfo.ri_cprmask[1]); 2408 W.printHex("Co-Proc Mask2", Reginfo.ri_cprmask[2]); 2409 W.printHex("Co-Proc Mask3", Reginfo.ri_cprmask[3]); 2410 } 2411 2412 template <class ELFT> void ELFDumper<ELFT>::printMipsReginfo() { 2413 const Elf_Shdr *Shdr = findSectionByName(*Obj, ".reginfo"); 2414 if (!Shdr) { 2415 W.startLine() << "There is no .reginfo section in the file.\n"; 2416 return; 2417 } 2418 ArrayRef<uint8_t> Sec = unwrapOrError(Obj->getSectionContents(Shdr)); 2419 if (Sec.size() != sizeof(Elf_Mips_RegInfo<ELFT>)) { 2420 W.startLine() << "The .reginfo section has a wrong size.\n"; 2421 return; 2422 } 2423 2424 DictScope GS(W, "MIPS RegInfo"); 2425 auto *Reginfo = reinterpret_cast<const Elf_Mips_RegInfo<ELFT> *>(Sec.data()); 2426 printMipsReginfoData(W, *Reginfo); 2427 } 2428 2429 template <class ELFT> void ELFDumper<ELFT>::printMipsOptions() { 2430 const Elf_Shdr *Shdr = findSectionByName(*Obj, ".MIPS.options"); 2431 if (!Shdr) { 2432 W.startLine() << "There is no .MIPS.options section in the file.\n"; 2433 return; 2434 } 2435 2436 DictScope GS(W, "MIPS Options"); 2437 2438 ArrayRef<uint8_t> Sec = unwrapOrError(Obj->getSectionContents(Shdr)); 2439 while (!Sec.empty()) { 2440 if (Sec.size() < sizeof(Elf_Mips_Options<ELFT>)) { 2441 W.startLine() << "The .MIPS.options section has a wrong size.\n"; 2442 return; 2443 } 2444 auto *O = reinterpret_cast<const Elf_Mips_Options<ELFT> *>(Sec.data()); 2445 DictScope GS(W, getElfMipsOptionsOdkType(O->kind)); 2446 switch (O->kind) { 2447 case ODK_REGINFO: 2448 printMipsReginfoData(W, O->getRegInfo()); 2449 break; 2450 default: 2451 W.startLine() << "Unsupported MIPS options tag.\n"; 2452 break; 2453 } 2454 Sec = Sec.slice(O->size); 2455 } 2456 } 2457 2458 template <class ELFT> void ELFDumper<ELFT>::printStackMap() const { 2459 const Elf_Shdr *StackMapSection = nullptr; 2460 for (const auto &Sec : unwrapOrError(Obj->sections())) { 2461 StringRef Name = unwrapOrError(Obj->getSectionName(&Sec)); 2462 if (Name == ".llvm_stackmaps") { 2463 StackMapSection = &Sec; 2464 break; 2465 } 2466 } 2467 2468 if (!StackMapSection) 2469 return; 2470 2471 ArrayRef<uint8_t> StackMapContentsArray = 2472 unwrapOrError(Obj->getSectionContents(StackMapSection)); 2473 2474 prettyPrintStackMap( 2475 W, StackMapV2Parser<ELFT::TargetEndianness>(StackMapContentsArray)); 2476 } 2477 2478 template <class ELFT> void ELFDumper<ELFT>::printGroupSections() { 2479 ELFDumperStyle->printGroupSections(Obj); 2480 } 2481 2482 template <class ELFT> void ELFDumper<ELFT>::printAddrsig() { 2483 ELFDumperStyle->printAddrsig(Obj); 2484 } 2485 2486 static inline void printFields(formatted_raw_ostream &OS, StringRef Str1, 2487 StringRef Str2) { 2488 OS.PadToColumn(2u); 2489 OS << Str1; 2490 OS.PadToColumn(37u); 2491 OS << Str2 << "\n"; 2492 OS.flush(); 2493 } 2494 2495 template <class ELFT> 2496 static std::string getSectionHeadersNumString(const ELFFile<ELFT> *Obj) { 2497 const typename ELFT::Ehdr *ElfHeader = Obj->getHeader(); 2498 if (ElfHeader->e_shnum != 0) 2499 return to_string(ElfHeader->e_shnum); 2500 2501 ArrayRef<typename ELFT::Shdr> Arr = unwrapOrError(Obj->sections()); 2502 if (Arr.empty()) 2503 return "0"; 2504 return "0 (" + to_string(Arr[0].sh_size) + ")"; 2505 } 2506 2507 template <class ELFT> 2508 static std::string getSectionHeaderTableIndexString(const ELFFile<ELFT> *Obj) { 2509 const typename ELFT::Ehdr *ElfHeader = Obj->getHeader(); 2510 if (ElfHeader->e_shstrndx != SHN_XINDEX) 2511 return to_string(ElfHeader->e_shstrndx); 2512 2513 ArrayRef<typename ELFT::Shdr> Arr = unwrapOrError(Obj->sections()); 2514 if (Arr.empty()) 2515 return "65535 (corrupt: out of range)"; 2516 return to_string(ElfHeader->e_shstrndx) + " (" + to_string(Arr[0].sh_link) + ")"; 2517 } 2518 2519 template <class ELFT> void GNUStyle<ELFT>::printFileHeaders(const ELFO *Obj) { 2520 const Elf_Ehdr *e = Obj->getHeader(); 2521 OS << "ELF Header:\n"; 2522 OS << " Magic: "; 2523 std::string Str; 2524 for (int i = 0; i < ELF::EI_NIDENT; i++) 2525 OS << format(" %02x", static_cast<int>(e->e_ident[i])); 2526 OS << "\n"; 2527 Str = printEnum(e->e_ident[ELF::EI_CLASS], makeArrayRef(ElfClass)); 2528 printFields(OS, "Class:", Str); 2529 Str = printEnum(e->e_ident[ELF::EI_DATA], makeArrayRef(ElfDataEncoding)); 2530 printFields(OS, "Data:", Str); 2531 OS.PadToColumn(2u); 2532 OS << "Version:"; 2533 OS.PadToColumn(37u); 2534 OS << to_hexString(e->e_ident[ELF::EI_VERSION]); 2535 if (e->e_version == ELF::EV_CURRENT) 2536 OS << " (current)"; 2537 OS << "\n"; 2538 Str = printEnum(e->e_ident[ELF::EI_OSABI], makeArrayRef(ElfOSABI)); 2539 printFields(OS, "OS/ABI:", Str); 2540 Str = "0x" + to_hexString(e->e_ident[ELF::EI_ABIVERSION]); 2541 printFields(OS, "ABI Version:", Str); 2542 Str = printEnum(e->e_type, makeArrayRef(ElfObjectFileType)); 2543 printFields(OS, "Type:", Str); 2544 Str = printEnum(e->e_machine, makeArrayRef(ElfMachineType)); 2545 printFields(OS, "Machine:", Str); 2546 Str = "0x" + to_hexString(e->e_version); 2547 printFields(OS, "Version:", Str); 2548 Str = "0x" + to_hexString(e->e_entry); 2549 printFields(OS, "Entry point address:", Str); 2550 Str = to_string(e->e_phoff) + " (bytes into file)"; 2551 printFields(OS, "Start of program headers:", Str); 2552 Str = to_string(e->e_shoff) + " (bytes into file)"; 2553 printFields(OS, "Start of section headers:", Str); 2554 std::string ElfFlags; 2555 if (e->e_machine == EM_MIPS) 2556 ElfFlags = 2557 printFlags(e->e_flags, makeArrayRef(ElfHeaderMipsFlags), 2558 unsigned(ELF::EF_MIPS_ARCH), unsigned(ELF::EF_MIPS_ABI), 2559 unsigned(ELF::EF_MIPS_MACH)); 2560 else if (e->e_machine == EM_RISCV) 2561 ElfFlags = printFlags(e->e_flags, makeArrayRef(ElfHeaderRISCVFlags)); 2562 Str = "0x" + to_hexString(e->e_flags); 2563 if (!ElfFlags.empty()) 2564 Str = Str + ", " + ElfFlags; 2565 printFields(OS, "Flags:", Str); 2566 Str = to_string(e->e_ehsize) + " (bytes)"; 2567 printFields(OS, "Size of this header:", Str); 2568 Str = to_string(e->e_phentsize) + " (bytes)"; 2569 printFields(OS, "Size of program headers:", Str); 2570 Str = to_string(e->e_phnum); 2571 printFields(OS, "Number of program headers:", Str); 2572 Str = to_string(e->e_shentsize) + " (bytes)"; 2573 printFields(OS, "Size of section headers:", Str); 2574 Str = getSectionHeadersNumString(Obj); 2575 printFields(OS, "Number of section headers:", Str); 2576 Str = getSectionHeaderTableIndexString(Obj); 2577 printFields(OS, "Section header string table index:", Str); 2578 } 2579 2580 namespace { 2581 struct GroupMember { 2582 StringRef Name; 2583 uint64_t Index; 2584 }; 2585 2586 struct GroupSection { 2587 StringRef Name; 2588 StringRef Signature; 2589 uint64_t ShName; 2590 uint64_t Index; 2591 uint32_t Link; 2592 uint32_t Info; 2593 uint32_t Type; 2594 std::vector<GroupMember> Members; 2595 }; 2596 2597 template <class ELFT> 2598 std::vector<GroupSection> getGroups(const ELFFile<ELFT> *Obj) { 2599 using Elf_Shdr = typename ELFT::Shdr; 2600 using Elf_Sym = typename ELFT::Sym; 2601 using Elf_Word = typename ELFT::Word; 2602 2603 std::vector<GroupSection> Ret; 2604 uint64_t I = 0; 2605 for (const Elf_Shdr &Sec : unwrapOrError(Obj->sections())) { 2606 ++I; 2607 if (Sec.sh_type != ELF::SHT_GROUP) 2608 continue; 2609 2610 const Elf_Shdr *Symtab = unwrapOrError(Obj->getSection(Sec.sh_link)); 2611 StringRef StrTable = unwrapOrError(Obj->getStringTableForSymtab(*Symtab)); 2612 const Elf_Sym *Sym = 2613 unwrapOrError(Obj->template getEntry<Elf_Sym>(Symtab, Sec.sh_info)); 2614 auto Data = 2615 unwrapOrError(Obj->template getSectionContentsAsArray<Elf_Word>(&Sec)); 2616 2617 StringRef Name = unwrapOrError(Obj->getSectionName(&Sec)); 2618 StringRef Signature = StrTable.data() + Sym->st_name; 2619 Ret.push_back({Name, 2620 Signature, 2621 Sec.sh_name, 2622 I - 1, 2623 Sec.sh_link, 2624 Sec.sh_info, 2625 Data[0], 2626 {}}); 2627 2628 std::vector<GroupMember> &GM = Ret.back().Members; 2629 for (uint32_t Ndx : Data.slice(1)) { 2630 auto Sec = unwrapOrError(Obj->getSection(Ndx)); 2631 const StringRef Name = unwrapOrError(Obj->getSectionName(Sec)); 2632 GM.push_back({Name, Ndx}); 2633 } 2634 } 2635 return Ret; 2636 } 2637 2638 DenseMap<uint64_t, const GroupSection *> 2639 mapSectionsToGroups(ArrayRef<GroupSection> Groups) { 2640 DenseMap<uint64_t, const GroupSection *> Ret; 2641 for (const GroupSection &G : Groups) 2642 for (const GroupMember &GM : G.Members) 2643 Ret.insert({GM.Index, &G}); 2644 return Ret; 2645 } 2646 2647 } // namespace 2648 2649 template <class ELFT> void GNUStyle<ELFT>::printGroupSections(const ELFO *Obj) { 2650 std::vector<GroupSection> V = getGroups<ELFT>(Obj); 2651 DenseMap<uint64_t, const GroupSection *> Map = mapSectionsToGroups(V); 2652 for (const GroupSection &G : V) { 2653 OS << "\n" 2654 << getGroupType(G.Type) << " group section [" 2655 << format_decimal(G.Index, 5) << "] `" << G.Name << "' [" << G.Signature 2656 << "] contains " << G.Members.size() << " sections:\n" 2657 << " [Index] Name\n"; 2658 for (const GroupMember &GM : G.Members) { 2659 const GroupSection *MainGroup = Map[GM.Index]; 2660 if (MainGroup != &G) { 2661 OS.flush(); 2662 errs() << "Error: section [" << format_decimal(GM.Index, 5) 2663 << "] in group section [" << format_decimal(G.Index, 5) 2664 << "] already in group section [" 2665 << format_decimal(MainGroup->Index, 5) << "]"; 2666 errs().flush(); 2667 continue; 2668 } 2669 OS << " [" << format_decimal(GM.Index, 5) << "] " << GM.Name << "\n"; 2670 } 2671 } 2672 2673 if (V.empty()) 2674 OS << "There are no section groups in this file.\n"; 2675 } 2676 2677 template <class ELFT> 2678 void GNUStyle<ELFT>::printRelocation(const ELFO *Obj, const Elf_Shdr *SymTab, 2679 const Elf_Rela &R, bool IsRela) { 2680 std::string Offset, Info, Addend, Value; 2681 SmallString<32> RelocName; 2682 StringRef TargetName; 2683 const Elf_Sym *Sym = nullptr; 2684 unsigned Width = ELFT::Is64Bits ? 16 : 8; 2685 unsigned Bias = ELFT::Is64Bits ? 8 : 0; 2686 2687 // First two fields are bit width dependent. The rest of them are after are 2688 // fixed width. 2689 Field Fields[5] = {0, 10 + Bias, 19 + 2 * Bias, 42 + 2 * Bias, 53 + 2 * Bias}; 2690 Obj->getRelocationTypeName(R.getType(Obj->isMips64EL()), RelocName); 2691 Sym = unwrapOrError(Obj->getRelocationSymbol(&R, SymTab)); 2692 if (Sym && Sym->getType() == ELF::STT_SECTION) { 2693 const Elf_Shdr *Sec = unwrapOrError( 2694 Obj->getSection(Sym, SymTab, this->dumper()->getShndxTable())); 2695 TargetName = unwrapOrError(Obj->getSectionName(Sec)); 2696 } else if (Sym) { 2697 StringRef StrTable = unwrapOrError(Obj->getStringTableForSymtab(*SymTab)); 2698 TargetName = unwrapOrError(Sym->getName(StrTable)); 2699 } 2700 2701 if (Sym && IsRela) { 2702 if (R.r_addend < 0) 2703 Addend = " - "; 2704 else 2705 Addend = " + "; 2706 } 2707 2708 Offset = to_string(format_hex_no_prefix(R.r_offset, Width)); 2709 Info = to_string(format_hex_no_prefix(R.r_info, Width)); 2710 2711 int64_t RelAddend = R.r_addend; 2712 if (IsRela) 2713 Addend += to_hexString(std::abs(RelAddend), false); 2714 2715 if (Sym) 2716 Value = to_string(format_hex_no_prefix(Sym->getValue(), Width)); 2717 2718 Fields[0].Str = Offset; 2719 Fields[1].Str = Info; 2720 Fields[2].Str = RelocName; 2721 Fields[3].Str = Value; 2722 Fields[4].Str = TargetName; 2723 for (auto &field : Fields) 2724 printField(field); 2725 OS << Addend; 2726 OS << "\n"; 2727 } 2728 2729 template <class ELFT> void GNUStyle<ELFT>::printRelocHeader(unsigned SType) { 2730 bool IsRela = SType == ELF::SHT_RELA || SType == ELF::SHT_ANDROID_RELA; 2731 bool IsRelr = SType == ELF::SHT_RELR || SType == ELF::SHT_ANDROID_RELR; 2732 if (ELFT::Is64Bits) 2733 OS << " "; 2734 else 2735 OS << " "; 2736 if (IsRelr && opts::RawRelr) 2737 OS << "Data "; 2738 else 2739 OS << "Offset"; 2740 if (ELFT::Is64Bits) 2741 OS << " Info Type" 2742 << " Symbol's Value Symbol's Name"; 2743 else 2744 OS << " Info Type Sym. Value Symbol's Name"; 2745 if (IsRela) 2746 OS << " + Addend"; 2747 OS << "\n"; 2748 } 2749 2750 template <class ELFT> void GNUStyle<ELFT>::printRelocations(const ELFO *Obj) { 2751 bool HasRelocSections = false; 2752 for (const Elf_Shdr &Sec : unwrapOrError(Obj->sections())) { 2753 if (Sec.sh_type != ELF::SHT_REL && 2754 Sec.sh_type != ELF::SHT_RELA && 2755 Sec.sh_type != ELF::SHT_RELR && 2756 Sec.sh_type != ELF::SHT_ANDROID_REL && 2757 Sec.sh_type != ELF::SHT_ANDROID_RELA && 2758 Sec.sh_type != ELF::SHT_ANDROID_RELR) 2759 continue; 2760 HasRelocSections = true; 2761 StringRef Name = unwrapOrError(Obj->getSectionName(&Sec)); 2762 unsigned Entries = Sec.getEntityCount(); 2763 std::vector<Elf_Rela> AndroidRelas; 2764 if (Sec.sh_type == ELF::SHT_ANDROID_REL || 2765 Sec.sh_type == ELF::SHT_ANDROID_RELA) { 2766 // Android's packed relocation section needs to be unpacked first 2767 // to get the actual number of entries. 2768 AndroidRelas = unwrapOrError(Obj->android_relas(&Sec)); 2769 Entries = AndroidRelas.size(); 2770 } 2771 std::vector<Elf_Rela> RelrRelas; 2772 if (!opts::RawRelr && (Sec.sh_type == ELF::SHT_RELR || 2773 Sec.sh_type == ELF::SHT_ANDROID_RELR)) { 2774 // .relr.dyn relative relocation section needs to be unpacked first 2775 // to get the actual number of entries. 2776 Elf_Relr_Range Relrs = unwrapOrError(Obj->relrs(&Sec)); 2777 RelrRelas = unwrapOrError(Obj->decode_relrs(Relrs)); 2778 Entries = RelrRelas.size(); 2779 } 2780 uintX_t Offset = Sec.sh_offset; 2781 OS << "\nRelocation section '" << Name << "' at offset 0x" 2782 << to_hexString(Offset, false) << " contains " << Entries 2783 << " entries:\n"; 2784 printRelocHeader(Sec.sh_type); 2785 const Elf_Shdr *SymTab = unwrapOrError(Obj->getSection(Sec.sh_link)); 2786 switch (Sec.sh_type) { 2787 case ELF::SHT_REL: 2788 for (const auto &R : unwrapOrError(Obj->rels(&Sec))) { 2789 Elf_Rela Rela; 2790 Rela.r_offset = R.r_offset; 2791 Rela.r_info = R.r_info; 2792 Rela.r_addend = 0; 2793 printRelocation(Obj, SymTab, Rela, false); 2794 } 2795 break; 2796 case ELF::SHT_RELA: 2797 for (const auto &R : unwrapOrError(Obj->relas(&Sec))) 2798 printRelocation(Obj, SymTab, R, true); 2799 break; 2800 case ELF::SHT_RELR: 2801 case ELF::SHT_ANDROID_RELR: 2802 if (opts::RawRelr) 2803 for (const auto &R : unwrapOrError(Obj->relrs(&Sec))) 2804 OS << to_string(format_hex_no_prefix(R, ELFT::Is64Bits ? 16 : 8)) 2805 << "\n"; 2806 else 2807 for (const auto &R : RelrRelas) 2808 printRelocation(Obj, SymTab, R, false); 2809 break; 2810 case ELF::SHT_ANDROID_REL: 2811 case ELF::SHT_ANDROID_RELA: 2812 for (const auto &R : AndroidRelas) 2813 printRelocation(Obj, SymTab, R, Sec.sh_type == ELF::SHT_ANDROID_RELA); 2814 break; 2815 } 2816 } 2817 if (!HasRelocSections) 2818 OS << "\nThere are no relocations in this file.\n"; 2819 } 2820 2821 std::string getSectionTypeString(unsigned Arch, unsigned Type) { 2822 using namespace ELF; 2823 2824 switch (Arch) { 2825 case EM_ARM: 2826 switch (Type) { 2827 case SHT_ARM_EXIDX: 2828 return "ARM_EXIDX"; 2829 case SHT_ARM_PREEMPTMAP: 2830 return "ARM_PREEMPTMAP"; 2831 case SHT_ARM_ATTRIBUTES: 2832 return "ARM_ATTRIBUTES"; 2833 case SHT_ARM_DEBUGOVERLAY: 2834 return "ARM_DEBUGOVERLAY"; 2835 case SHT_ARM_OVERLAYSECTION: 2836 return "ARM_OVERLAYSECTION"; 2837 } 2838 break; 2839 case EM_X86_64: 2840 switch (Type) { 2841 case SHT_X86_64_UNWIND: 2842 return "X86_64_UNWIND"; 2843 } 2844 break; 2845 case EM_MIPS: 2846 case EM_MIPS_RS3_LE: 2847 switch (Type) { 2848 case SHT_MIPS_REGINFO: 2849 return "MIPS_REGINFO"; 2850 case SHT_MIPS_OPTIONS: 2851 return "MIPS_OPTIONS"; 2852 case SHT_MIPS_ABIFLAGS: 2853 return "MIPS_ABIFLAGS"; 2854 case SHT_MIPS_DWARF: 2855 return "SHT_MIPS_DWARF"; 2856 } 2857 break; 2858 } 2859 switch (Type) { 2860 case SHT_NULL: 2861 return "NULL"; 2862 case SHT_PROGBITS: 2863 return "PROGBITS"; 2864 case SHT_SYMTAB: 2865 return "SYMTAB"; 2866 case SHT_STRTAB: 2867 return "STRTAB"; 2868 case SHT_RELA: 2869 return "RELA"; 2870 case SHT_HASH: 2871 return "HASH"; 2872 case SHT_DYNAMIC: 2873 return "DYNAMIC"; 2874 case SHT_NOTE: 2875 return "NOTE"; 2876 case SHT_NOBITS: 2877 return "NOBITS"; 2878 case SHT_REL: 2879 return "REL"; 2880 case SHT_SHLIB: 2881 return "SHLIB"; 2882 case SHT_DYNSYM: 2883 return "DYNSYM"; 2884 case SHT_INIT_ARRAY: 2885 return "INIT_ARRAY"; 2886 case SHT_FINI_ARRAY: 2887 return "FINI_ARRAY"; 2888 case SHT_PREINIT_ARRAY: 2889 return "PREINIT_ARRAY"; 2890 case SHT_GROUP: 2891 return "GROUP"; 2892 case SHT_SYMTAB_SHNDX: 2893 return "SYMTAB SECTION INDICES"; 2894 case SHT_RELR: 2895 case SHT_ANDROID_RELR: 2896 return "RELR"; 2897 case SHT_LLVM_ODRTAB: 2898 return "LLVM_ODRTAB"; 2899 case SHT_LLVM_LINKER_OPTIONS: 2900 return "LLVM_LINKER_OPTIONS"; 2901 case SHT_LLVM_CALL_GRAPH_PROFILE: 2902 return "LLVM_CALL_GRAPH_PROFILE"; 2903 case SHT_LLVM_ADDRSIG: 2904 return "LLVM_ADDRSIG"; 2905 // FIXME: Parse processor specific GNU attributes 2906 case SHT_GNU_ATTRIBUTES: 2907 return "ATTRIBUTES"; 2908 case SHT_GNU_HASH: 2909 return "GNU_HASH"; 2910 case SHT_GNU_verdef: 2911 return "VERDEF"; 2912 case SHT_GNU_verneed: 2913 return "VERNEED"; 2914 case SHT_GNU_versym: 2915 return "VERSYM"; 2916 default: 2917 return ""; 2918 } 2919 return ""; 2920 } 2921 2922 template <class ELFT> 2923 void GNUStyle<ELFT>::printSectionHeaders(const ELFO *Obj) { 2924 size_t SectionIndex = 0; 2925 std::string Number, Type, Size, Address, Offset, Flags, Link, Info, EntrySize, 2926 Alignment; 2927 unsigned Bias; 2928 unsigned Width; 2929 2930 if (ELFT::Is64Bits) { 2931 Bias = 0; 2932 Width = 16; 2933 } else { 2934 Bias = 8; 2935 Width = 8; 2936 } 2937 2938 ArrayRef<Elf_Shdr> Sections = unwrapOrError(Obj->sections()); 2939 OS << "There are " << to_string(Sections.size()) 2940 << " section headers, starting at offset " 2941 << "0x" << to_hexString(Obj->getHeader()->e_shoff, false) << ":\n\n"; 2942 OS << "Section Headers:\n"; 2943 Field Fields[11] = {{"[Nr]", 2}, 2944 {"Name", 7}, 2945 {"Type", 25}, 2946 {"Address", 41}, 2947 {"Off", 58 - Bias}, 2948 {"Size", 65 - Bias}, 2949 {"ES", 72 - Bias}, 2950 {"Flg", 75 - Bias}, 2951 {"Lk", 79 - Bias}, 2952 {"Inf", 82 - Bias}, 2953 {"Al", 86 - Bias}}; 2954 for (auto &f : Fields) 2955 printField(f); 2956 OS << "\n"; 2957 2958 for (const Elf_Shdr &Sec : Sections) { 2959 Number = to_string(SectionIndex); 2960 Fields[0].Str = Number; 2961 Fields[1].Str = unwrapOrError(Obj->getSectionName(&Sec)); 2962 Type = getSectionTypeString(Obj->getHeader()->e_machine, Sec.sh_type); 2963 Fields[2].Str = Type; 2964 Address = to_string(format_hex_no_prefix(Sec.sh_addr, Width)); 2965 Fields[3].Str = Address; 2966 Offset = to_string(format_hex_no_prefix(Sec.sh_offset, 6)); 2967 Fields[4].Str = Offset; 2968 Size = to_string(format_hex_no_prefix(Sec.sh_size, 6)); 2969 Fields[5].Str = Size; 2970 EntrySize = to_string(format_hex_no_prefix(Sec.sh_entsize, 2)); 2971 Fields[6].Str = EntrySize; 2972 Flags = getGNUFlags(Sec.sh_flags); 2973 Fields[7].Str = Flags; 2974 Link = to_string(Sec.sh_link); 2975 Fields[8].Str = Link; 2976 Info = to_string(Sec.sh_info); 2977 Fields[9].Str = Info; 2978 Alignment = to_string(Sec.sh_addralign); 2979 Fields[10].Str = Alignment; 2980 OS.PadToColumn(Fields[0].Column); 2981 OS << "[" << right_justify(Fields[0].Str, 2) << "]"; 2982 for (int i = 1; i < 7; i++) 2983 printField(Fields[i]); 2984 OS.PadToColumn(Fields[7].Column); 2985 OS << right_justify(Fields[7].Str, 3); 2986 OS.PadToColumn(Fields[8].Column); 2987 OS << right_justify(Fields[8].Str, 2); 2988 OS.PadToColumn(Fields[9].Column); 2989 OS << right_justify(Fields[9].Str, 3); 2990 OS.PadToColumn(Fields[10].Column); 2991 OS << right_justify(Fields[10].Str, 2); 2992 OS << "\n"; 2993 ++SectionIndex; 2994 } 2995 OS << "Key to Flags:\n" 2996 << " W (write), A (alloc), X (execute), M (merge), S (strings), l " 2997 "(large)\n" 2998 << " I (info), L (link order), G (group), T (TLS), E (exclude),\ 2999 x (unknown)\n" 3000 << " O (extra OS processing required) o (OS specific),\ 3001 p (processor specific)\n"; 3002 } 3003 3004 template <class ELFT> 3005 void GNUStyle<ELFT>::printSymtabMessage(const ELFO *Obj, StringRef Name, 3006 size_t Entries) { 3007 if (!Name.empty()) 3008 OS << "\nSymbol table '" << Name << "' contains " << Entries 3009 << " entries:\n"; 3010 else 3011 OS << "\n Symbol table for image:\n"; 3012 3013 if (ELFT::Is64Bits) 3014 OS << " Num: Value Size Type Bind Vis Ndx Name\n"; 3015 else 3016 OS << " Num: Value Size Type Bind Vis Ndx Name\n"; 3017 } 3018 3019 template <class ELFT> 3020 std::string GNUStyle<ELFT>::getSymbolSectionNdx(const ELFO *Obj, 3021 const Elf_Sym *Symbol, 3022 const Elf_Sym *FirstSym) { 3023 unsigned SectionIndex = Symbol->st_shndx; 3024 switch (SectionIndex) { 3025 case ELF::SHN_UNDEF: 3026 return "UND"; 3027 case ELF::SHN_ABS: 3028 return "ABS"; 3029 case ELF::SHN_COMMON: 3030 return "COM"; 3031 case ELF::SHN_XINDEX: 3032 SectionIndex = unwrapOrError(object::getExtendedSymbolTableIndex<ELFT>( 3033 Symbol, FirstSym, this->dumper()->getShndxTable())); 3034 LLVM_FALLTHROUGH; 3035 default: 3036 // Find if: 3037 // Processor specific 3038 if (SectionIndex >= ELF::SHN_LOPROC && SectionIndex <= ELF::SHN_HIPROC) 3039 return std::string("PRC[0x") + 3040 to_string(format_hex_no_prefix(SectionIndex, 4)) + "]"; 3041 // OS specific 3042 if (SectionIndex >= ELF::SHN_LOOS && SectionIndex <= ELF::SHN_HIOS) 3043 return std::string("OS[0x") + 3044 to_string(format_hex_no_prefix(SectionIndex, 4)) + "]"; 3045 // Architecture reserved: 3046 if (SectionIndex >= ELF::SHN_LORESERVE && 3047 SectionIndex <= ELF::SHN_HIRESERVE) 3048 return std::string("RSV[0x") + 3049 to_string(format_hex_no_prefix(SectionIndex, 4)) + "]"; 3050 // A normal section with an index 3051 return to_string(format_decimal(SectionIndex, 3)); 3052 } 3053 } 3054 3055 template <class ELFT> 3056 void GNUStyle<ELFT>::printSymbol(const ELFO *Obj, const Elf_Sym *Symbol, 3057 const Elf_Sym *FirstSym, StringRef StrTable, 3058 bool IsDynamic) { 3059 static int Idx = 0; 3060 static bool Dynamic = true; 3061 size_t Width; 3062 3063 // If this function was called with a different value from IsDynamic 3064 // from last call, happens when we move from dynamic to static symbol 3065 // table, "Num" field should be reset. 3066 if (!Dynamic != !IsDynamic) { 3067 Idx = 0; 3068 Dynamic = false; 3069 } 3070 std::string Num, Name, Value, Size, Binding, Type, Visibility, Section; 3071 unsigned Bias = 0; 3072 if (ELFT::Is64Bits) { 3073 Bias = 8; 3074 Width = 16; 3075 } else { 3076 Bias = 0; 3077 Width = 8; 3078 } 3079 Field Fields[8] = {0, 8, 17 + Bias, 23 + Bias, 3080 31 + Bias, 38 + Bias, 47 + Bias, 51 + Bias}; 3081 Num = to_string(format_decimal(Idx++, 6)) + ":"; 3082 Value = to_string(format_hex_no_prefix(Symbol->st_value, Width)); 3083 Size = to_string(format_decimal(Symbol->st_size, 5)); 3084 unsigned char SymbolType = Symbol->getType(); 3085 if (Obj->getHeader()->e_machine == ELF::EM_AMDGPU && 3086 SymbolType >= ELF::STT_LOOS && SymbolType < ELF::STT_HIOS) 3087 Type = printEnum(SymbolType, makeArrayRef(AMDGPUSymbolTypes)); 3088 else 3089 Type = printEnum(SymbolType, makeArrayRef(ElfSymbolTypes)); 3090 unsigned Vis = Symbol->getVisibility(); 3091 Binding = printEnum(Symbol->getBinding(), makeArrayRef(ElfSymbolBindings)); 3092 Visibility = printEnum(Vis, makeArrayRef(ElfSymbolVisibilities)); 3093 Section = getSymbolSectionNdx(Obj, Symbol, FirstSym); 3094 Name = this->dumper()->getFullSymbolName(Symbol, StrTable, IsDynamic); 3095 Fields[0].Str = Num; 3096 Fields[1].Str = Value; 3097 Fields[2].Str = Size; 3098 Fields[3].Str = Type; 3099 Fields[4].Str = Binding; 3100 Fields[5].Str = Visibility; 3101 Fields[6].Str = Section; 3102 Fields[7].Str = Name; 3103 for (auto &Entry : Fields) 3104 printField(Entry); 3105 OS << "\n"; 3106 } 3107 template <class ELFT> 3108 void GNUStyle<ELFT>::printHashedSymbol(const ELFO *Obj, const Elf_Sym *FirstSym, 3109 uint32_t Sym, StringRef StrTable, 3110 uint32_t Bucket) { 3111 std::string Num, Buc, Name, Value, Size, Binding, Type, Visibility, Section; 3112 unsigned Width, Bias = 0; 3113 if (ELFT::Is64Bits) { 3114 Bias = 8; 3115 Width = 16; 3116 } else { 3117 Bias = 0; 3118 Width = 8; 3119 } 3120 Field Fields[9] = {0, 6, 11, 20 + Bias, 25 + Bias, 3121 34 + Bias, 41 + Bias, 49 + Bias, 53 + Bias}; 3122 Num = to_string(format_decimal(Sym, 5)); 3123 Buc = to_string(format_decimal(Bucket, 3)) + ":"; 3124 3125 const auto Symbol = FirstSym + Sym; 3126 Value = to_string(format_hex_no_prefix(Symbol->st_value, Width)); 3127 Size = to_string(format_decimal(Symbol->st_size, 5)); 3128 unsigned char SymbolType = Symbol->getType(); 3129 if (Obj->getHeader()->e_machine == ELF::EM_AMDGPU && 3130 SymbolType >= ELF::STT_LOOS && SymbolType < ELF::STT_HIOS) 3131 Type = printEnum(SymbolType, makeArrayRef(AMDGPUSymbolTypes)); 3132 else 3133 Type = printEnum(SymbolType, makeArrayRef(ElfSymbolTypes)); 3134 unsigned Vis = Symbol->getVisibility(); 3135 Binding = printEnum(Symbol->getBinding(), makeArrayRef(ElfSymbolBindings)); 3136 Visibility = printEnum(Vis, makeArrayRef(ElfSymbolVisibilities)); 3137 Section = getSymbolSectionNdx(Obj, Symbol, FirstSym); 3138 Name = this->dumper()->getFullSymbolName(Symbol, StrTable, true); 3139 Fields[0].Str = Num; 3140 Fields[1].Str = Buc; 3141 Fields[2].Str = Value; 3142 Fields[3].Str = Size; 3143 Fields[4].Str = Type; 3144 Fields[5].Str = Binding; 3145 Fields[6].Str = Visibility; 3146 Fields[7].Str = Section; 3147 Fields[8].Str = Name; 3148 for (auto &Entry : Fields) 3149 printField(Entry); 3150 OS << "\n"; 3151 } 3152 3153 template <class ELFT> void GNUStyle<ELFT>::printSymbols(const ELFO *Obj) { 3154 if (opts::DynamicSymbols) 3155 return; 3156 this->dumper()->printSymbolsHelper(true); 3157 this->dumper()->printSymbolsHelper(false); 3158 } 3159 3160 template <class ELFT> 3161 void GNUStyle<ELFT>::printDynamicSymbols(const ELFO *Obj) { 3162 if (this->dumper()->getDynamicStringTable().empty()) 3163 return; 3164 auto StringTable = this->dumper()->getDynamicStringTable(); 3165 auto DynSyms = this->dumper()->dynamic_symbols(); 3166 auto GnuHash = this->dumper()->getGnuHashTable(); 3167 auto SysVHash = this->dumper()->getHashTable(); 3168 3169 // If no hash or .gnu.hash found, try using symbol table 3170 if (GnuHash == nullptr && SysVHash == nullptr) 3171 this->dumper()->printSymbolsHelper(true); 3172 3173 // Try printing .hash 3174 if (this->dumper()->getHashTable()) { 3175 OS << "\n Symbol table of .hash for image:\n"; 3176 if (ELFT::Is64Bits) 3177 OS << " Num Buc: Value Size Type Bind Vis Ndx Name"; 3178 else 3179 OS << " Num Buc: Value Size Type Bind Vis Ndx Name"; 3180 OS << "\n"; 3181 3182 uint32_t NBuckets = SysVHash->nbucket; 3183 uint32_t NChains = SysVHash->nchain; 3184 auto Buckets = SysVHash->buckets(); 3185 auto Chains = SysVHash->chains(); 3186 for (uint32_t Buc = 0; Buc < NBuckets; Buc++) { 3187 if (Buckets[Buc] == ELF::STN_UNDEF) 3188 continue; 3189 for (uint32_t Ch = Buckets[Buc]; Ch < NChains; Ch = Chains[Ch]) { 3190 if (Ch == ELF::STN_UNDEF) 3191 break; 3192 printHashedSymbol(Obj, &DynSyms[0], Ch, StringTable, Buc); 3193 } 3194 } 3195 } 3196 3197 // Try printing .gnu.hash 3198 if (GnuHash) { 3199 OS << "\n Symbol table of .gnu.hash for image:\n"; 3200 if (ELFT::Is64Bits) 3201 OS << " Num Buc: Value Size Type Bind Vis Ndx Name"; 3202 else 3203 OS << " Num Buc: Value Size Type Bind Vis Ndx Name"; 3204 OS << "\n"; 3205 uint32_t NBuckets = GnuHash->nbuckets; 3206 auto Buckets = GnuHash->buckets(); 3207 for (uint32_t Buc = 0; Buc < NBuckets; Buc++) { 3208 if (Buckets[Buc] == ELF::STN_UNDEF) 3209 continue; 3210 uint32_t Index = Buckets[Buc]; 3211 uint32_t GnuHashable = Index - GnuHash->symndx; 3212 // Print whole chain 3213 while (true) { 3214 printHashedSymbol(Obj, &DynSyms[0], Index++, StringTable, Buc); 3215 // Chain ends at symbol with stopper bit 3216 if ((GnuHash->values(DynSyms.size())[GnuHashable++] & 1) == 1) 3217 break; 3218 } 3219 } 3220 } 3221 } 3222 3223 static inline std::string printPhdrFlags(unsigned Flag) { 3224 std::string Str; 3225 Str = (Flag & PF_R) ? "R" : " "; 3226 Str += (Flag & PF_W) ? "W" : " "; 3227 Str += (Flag & PF_X) ? "E" : " "; 3228 return Str; 3229 } 3230 3231 // SHF_TLS sections are only in PT_TLS, PT_LOAD or PT_GNU_RELRO 3232 // PT_TLS must only have SHF_TLS sections 3233 template <class ELFT> 3234 bool GNUStyle<ELFT>::checkTLSSections(const Elf_Phdr &Phdr, 3235 const Elf_Shdr &Sec) { 3236 return (((Sec.sh_flags & ELF::SHF_TLS) && 3237 ((Phdr.p_type == ELF::PT_TLS) || (Phdr.p_type == ELF::PT_LOAD) || 3238 (Phdr.p_type == ELF::PT_GNU_RELRO))) || 3239 (!(Sec.sh_flags & ELF::SHF_TLS) && Phdr.p_type != ELF::PT_TLS)); 3240 } 3241 3242 // Non-SHT_NOBITS must have its offset inside the segment 3243 // Only non-zero section can be at end of segment 3244 template <class ELFT> 3245 bool GNUStyle<ELFT>::checkoffsets(const Elf_Phdr &Phdr, const Elf_Shdr &Sec) { 3246 if (Sec.sh_type == ELF::SHT_NOBITS) 3247 return true; 3248 bool IsSpecial = 3249 (Sec.sh_type == ELF::SHT_NOBITS) && ((Sec.sh_flags & ELF::SHF_TLS) != 0); 3250 // .tbss is special, it only has memory in PT_TLS and has NOBITS properties 3251 auto SectionSize = 3252 (IsSpecial && Phdr.p_type != ELF::PT_TLS) ? 0 : Sec.sh_size; 3253 if (Sec.sh_offset >= Phdr.p_offset) 3254 return ((Sec.sh_offset + SectionSize <= Phdr.p_filesz + Phdr.p_offset) 3255 /*only non-zero sized sections at end*/ && 3256 (Sec.sh_offset + 1 <= Phdr.p_offset + Phdr.p_filesz)); 3257 return false; 3258 } 3259 3260 // SHF_ALLOC must have VMA inside segment 3261 // Only non-zero section can be at end of segment 3262 template <class ELFT> 3263 bool GNUStyle<ELFT>::checkVMA(const Elf_Phdr &Phdr, const Elf_Shdr &Sec) { 3264 if (!(Sec.sh_flags & ELF::SHF_ALLOC)) 3265 return true; 3266 bool IsSpecial = 3267 (Sec.sh_type == ELF::SHT_NOBITS) && ((Sec.sh_flags & ELF::SHF_TLS) != 0); 3268 // .tbss is special, it only has memory in PT_TLS and has NOBITS properties 3269 auto SectionSize = 3270 (IsSpecial && Phdr.p_type != ELF::PT_TLS) ? 0 : Sec.sh_size; 3271 if (Sec.sh_addr >= Phdr.p_vaddr) 3272 return ((Sec.sh_addr + SectionSize <= Phdr.p_vaddr + Phdr.p_memsz) && 3273 (Sec.sh_addr + 1 <= Phdr.p_vaddr + Phdr.p_memsz)); 3274 return false; 3275 } 3276 3277 // No section with zero size must be at start or end of PT_DYNAMIC 3278 template <class ELFT> 3279 bool GNUStyle<ELFT>::checkPTDynamic(const Elf_Phdr &Phdr, const Elf_Shdr &Sec) { 3280 if (Phdr.p_type != ELF::PT_DYNAMIC || Sec.sh_size != 0 || Phdr.p_memsz == 0) 3281 return true; 3282 // Is section within the phdr both based on offset and VMA ? 3283 return ((Sec.sh_type == ELF::SHT_NOBITS) || 3284 (Sec.sh_offset > Phdr.p_offset && 3285 Sec.sh_offset < Phdr.p_offset + Phdr.p_filesz)) && 3286 (!(Sec.sh_flags & ELF::SHF_ALLOC) || 3287 (Sec.sh_addr > Phdr.p_vaddr && Sec.sh_addr < Phdr.p_memsz)); 3288 } 3289 3290 template <class ELFT> 3291 void GNUStyle<ELFT>::printProgramHeaders(const ELFO *Obj) { 3292 unsigned Bias = ELFT::Is64Bits ? 8 : 0; 3293 unsigned Width = ELFT::Is64Bits ? 18 : 10; 3294 unsigned SizeWidth = ELFT::Is64Bits ? 8 : 7; 3295 std::string Type, Offset, VMA, LMA, FileSz, MemSz, Flag, Align; 3296 3297 const Elf_Ehdr *Header = Obj->getHeader(); 3298 Field Fields[8] = {2, 17, 26, 37 + Bias, 3299 48 + Bias, 56 + Bias, 64 + Bias, 68 + Bias}; 3300 OS << "\nElf file type is " 3301 << printEnum(Header->e_type, makeArrayRef(ElfObjectFileType)) << "\n" 3302 << "Entry point " << format_hex(Header->e_entry, 3) << "\n" 3303 << "There are " << Header->e_phnum << " program headers," 3304 << " starting at offset " << Header->e_phoff << "\n\n" 3305 << "Program Headers:\n"; 3306 if (ELFT::Is64Bits) 3307 OS << " Type Offset VirtAddr PhysAddr " 3308 << " FileSiz MemSiz Flg Align\n"; 3309 else 3310 OS << " Type Offset VirtAddr PhysAddr FileSiz " 3311 << "MemSiz Flg Align\n"; 3312 for (const auto &Phdr : unwrapOrError(Obj->program_headers())) { 3313 Type = getElfPtType(Header->e_machine, Phdr.p_type); 3314 Offset = to_string(format_hex(Phdr.p_offset, 8)); 3315 VMA = to_string(format_hex(Phdr.p_vaddr, Width)); 3316 LMA = to_string(format_hex(Phdr.p_paddr, Width)); 3317 FileSz = to_string(format_hex(Phdr.p_filesz, SizeWidth)); 3318 MemSz = to_string(format_hex(Phdr.p_memsz, SizeWidth)); 3319 Flag = printPhdrFlags(Phdr.p_flags); 3320 Align = to_string(format_hex(Phdr.p_align, 1)); 3321 Fields[0].Str = Type; 3322 Fields[1].Str = Offset; 3323 Fields[2].Str = VMA; 3324 Fields[3].Str = LMA; 3325 Fields[4].Str = FileSz; 3326 Fields[5].Str = MemSz; 3327 Fields[6].Str = Flag; 3328 Fields[7].Str = Align; 3329 for (auto Field : Fields) 3330 printField(Field); 3331 if (Phdr.p_type == ELF::PT_INTERP) { 3332 OS << "\n [Requesting program interpreter: "; 3333 OS << reinterpret_cast<const char *>(Obj->base()) + Phdr.p_offset << "]"; 3334 } 3335 OS << "\n"; 3336 } 3337 OS << "\n Section to Segment mapping:\n Segment Sections...\n"; 3338 int Phnum = 0; 3339 for (const Elf_Phdr &Phdr : unwrapOrError(Obj->program_headers())) { 3340 std::string Sections; 3341 OS << format(" %2.2d ", Phnum++); 3342 for (const Elf_Shdr &Sec : unwrapOrError(Obj->sections())) { 3343 // Check if each section is in a segment and then print mapping. 3344 // readelf additionally makes sure it does not print zero sized sections 3345 // at end of segments and for PT_DYNAMIC both start and end of section 3346 // .tbss must only be shown in PT_TLS section. 3347 bool TbssInNonTLS = (Sec.sh_type == ELF::SHT_NOBITS) && 3348 ((Sec.sh_flags & ELF::SHF_TLS) != 0) && 3349 Phdr.p_type != ELF::PT_TLS; 3350 if (!TbssInNonTLS && checkTLSSections(Phdr, Sec) && 3351 checkoffsets(Phdr, Sec) && checkVMA(Phdr, Sec) && 3352 checkPTDynamic(Phdr, Sec) && (Sec.sh_type != ELF::SHT_NULL)) 3353 Sections += unwrapOrError(Obj->getSectionName(&Sec)).str() + " "; 3354 } 3355 OS << Sections << "\n"; 3356 OS.flush(); 3357 } 3358 } 3359 3360 template <class ELFT> 3361 void GNUStyle<ELFT>::printDynamicRelocation(const ELFO *Obj, Elf_Rela R, 3362 bool IsRela) { 3363 SmallString<32> RelocName; 3364 StringRef SymbolName; 3365 unsigned Width = ELFT::Is64Bits ? 16 : 8; 3366 unsigned Bias = ELFT::Is64Bits ? 8 : 0; 3367 // First two fields are bit width dependent. The rest of them are after are 3368 // fixed width. 3369 Field Fields[5] = {0, 10 + Bias, 19 + 2 * Bias, 42 + 2 * Bias, 53 + 2 * Bias}; 3370 3371 uint32_t SymIndex = R.getSymbol(Obj->isMips64EL()); 3372 const Elf_Sym *Sym = this->dumper()->dynamic_symbols().begin() + SymIndex; 3373 Obj->getRelocationTypeName(R.getType(Obj->isMips64EL()), RelocName); 3374 SymbolName = 3375 unwrapOrError(Sym->getName(this->dumper()->getDynamicStringTable())); 3376 std::string Addend, Info, Offset, Value; 3377 Offset = to_string(format_hex_no_prefix(R.r_offset, Width)); 3378 Info = to_string(format_hex_no_prefix(R.r_info, Width)); 3379 Value = to_string(format_hex_no_prefix(Sym->getValue(), Width)); 3380 int64_t RelAddend = R.r_addend; 3381 if (!SymbolName.empty() && IsRela) { 3382 if (R.r_addend < 0) 3383 Addend = " - "; 3384 else 3385 Addend = " + "; 3386 } 3387 3388 if (SymbolName.empty() && Sym->getValue() == 0) 3389 Value = ""; 3390 3391 if (IsRela) 3392 Addend += to_string(format_hex_no_prefix(std::abs(RelAddend), 1)); 3393 3394 3395 Fields[0].Str = Offset; 3396 Fields[1].Str = Info; 3397 Fields[2].Str = RelocName.c_str(); 3398 Fields[3].Str = Value; 3399 Fields[4].Str = SymbolName; 3400 for (auto &Field : Fields) 3401 printField(Field); 3402 OS << Addend; 3403 OS << "\n"; 3404 } 3405 3406 template <class ELFT> 3407 void GNUStyle<ELFT>::printDynamicRelocations(const ELFO *Obj) { 3408 const DynRegionInfo &DynRelRegion = this->dumper()->getDynRelRegion(); 3409 const DynRegionInfo &DynRelaRegion = this->dumper()->getDynRelaRegion(); 3410 const DynRegionInfo &DynRelrRegion = this->dumper()->getDynRelrRegion(); 3411 const DynRegionInfo &DynPLTRelRegion = this->dumper()->getDynPLTRelRegion(); 3412 if (DynRelaRegion.Size > 0) { 3413 OS << "\n'RELA' relocation section at offset " 3414 << format_hex(reinterpret_cast<const uint8_t *>(DynRelaRegion.Addr) - 3415 Obj->base(), 3416 1) << " contains " << DynRelaRegion.Size << " bytes:\n"; 3417 printRelocHeader(ELF::SHT_RELA); 3418 for (const Elf_Rela &Rela : this->dumper()->dyn_relas()) 3419 printDynamicRelocation(Obj, Rela, true); 3420 } 3421 if (DynRelRegion.Size > 0) { 3422 OS << "\n'REL' relocation section at offset " 3423 << format_hex(reinterpret_cast<const uint8_t *>(DynRelRegion.Addr) - 3424 Obj->base(), 3425 1) << " contains " << DynRelRegion.Size << " bytes:\n"; 3426 printRelocHeader(ELF::SHT_REL); 3427 for (const Elf_Rel &Rel : this->dumper()->dyn_rels()) { 3428 Elf_Rela Rela; 3429 Rela.r_offset = Rel.r_offset; 3430 Rela.r_info = Rel.r_info; 3431 Rela.r_addend = 0; 3432 printDynamicRelocation(Obj, Rela, false); 3433 } 3434 } 3435 if (DynRelrRegion.Size > 0) { 3436 OS << "\n'RELR' relocation section at offset " 3437 << format_hex(reinterpret_cast<const uint8_t *>(DynRelrRegion.Addr) - 3438 Obj->base(), 3439 1) << " contains " << DynRelrRegion.Size << " bytes:\n"; 3440 printRelocHeader(ELF::SHT_REL); 3441 Elf_Relr_Range Relrs = this->dumper()->dyn_relrs(); 3442 std::vector<Elf_Rela> RelrRelas = unwrapOrError(Obj->decode_relrs(Relrs)); 3443 for (const Elf_Rela &Rela : RelrRelas) { 3444 printDynamicRelocation(Obj, Rela, false); 3445 } 3446 } 3447 if (DynPLTRelRegion.Size) { 3448 OS << "\n'PLT' relocation section at offset " 3449 << format_hex(reinterpret_cast<const uint8_t *>(DynPLTRelRegion.Addr) - 3450 Obj->base(), 3451 1) << " contains " << DynPLTRelRegion.Size << " bytes:\n"; 3452 } 3453 if (DynPLTRelRegion.EntSize == sizeof(Elf_Rela)) { 3454 printRelocHeader(ELF::SHT_RELA); 3455 for (const Elf_Rela &Rela : DynPLTRelRegion.getAsArrayRef<Elf_Rela>()) 3456 printDynamicRelocation(Obj, Rela, true); 3457 } else { 3458 printRelocHeader(ELF::SHT_REL); 3459 for (const Elf_Rel &Rel : DynPLTRelRegion.getAsArrayRef<Elf_Rel>()) { 3460 Elf_Rela Rela; 3461 Rela.r_offset = Rel.r_offset; 3462 Rela.r_info = Rel.r_info; 3463 Rela.r_addend = 0; 3464 printDynamicRelocation(Obj, Rela, false); 3465 } 3466 } 3467 } 3468 3469 // Hash histogram shows statistics of how efficient the hash was for the 3470 // dynamic symbol table. The table shows number of hash buckets for different 3471 // lengths of chains as absolute number and percentage of the total buckets. 3472 // Additionally cumulative coverage of symbols for each set of buckets. 3473 template <class ELFT> 3474 void GNUStyle<ELFT>::printHashHistogram(const ELFFile<ELFT> *Obj) { 3475 3476 const Elf_Hash *HashTable = this->dumper()->getHashTable(); 3477 const Elf_GnuHash *GnuHashTable = this->dumper()->getGnuHashTable(); 3478 3479 // Print histogram for .hash section 3480 if (HashTable) { 3481 size_t NBucket = HashTable->nbucket; 3482 size_t NChain = HashTable->nchain; 3483 ArrayRef<Elf_Word> Buckets = HashTable->buckets(); 3484 ArrayRef<Elf_Word> Chains = HashTable->chains(); 3485 size_t TotalSyms = 0; 3486 // If hash table is correct, we have at least chains with 0 length 3487 size_t MaxChain = 1; 3488 size_t CumulativeNonZero = 0; 3489 3490 if (NChain == 0 || NBucket == 0) 3491 return; 3492 3493 std::vector<size_t> ChainLen(NBucket, 0); 3494 // Go over all buckets and and note chain lengths of each bucket (total 3495 // unique chain lengths). 3496 for (size_t B = 0; B < NBucket; B++) { 3497 for (size_t C = Buckets[B]; C > 0 && C < NChain; C = Chains[C]) 3498 if (MaxChain <= ++ChainLen[B]) 3499 MaxChain++; 3500 TotalSyms += ChainLen[B]; 3501 } 3502 3503 if (!TotalSyms) 3504 return; 3505 3506 std::vector<size_t> Count(MaxChain, 0) ; 3507 // Count how long is the chain for each bucket 3508 for (size_t B = 0; B < NBucket; B++) 3509 ++Count[ChainLen[B]]; 3510 // Print Number of buckets with each chain lengths and their cumulative 3511 // coverage of the symbols 3512 OS << "Histogram for bucket list length (total of " << NBucket 3513 << " buckets)\n" 3514 << " Length Number % of total Coverage\n"; 3515 for (size_t I = 0; I < MaxChain; I++) { 3516 CumulativeNonZero += Count[I] * I; 3517 OS << format("%7lu %-10lu (%5.1f%%) %5.1f%%\n", I, Count[I], 3518 (Count[I] * 100.0) / NBucket, 3519 (CumulativeNonZero * 100.0) / TotalSyms); 3520 } 3521 } 3522 3523 // Print histogram for .gnu.hash section 3524 if (GnuHashTable) { 3525 size_t NBucket = GnuHashTable->nbuckets; 3526 ArrayRef<Elf_Word> Buckets = GnuHashTable->buckets(); 3527 unsigned NumSyms = this->dumper()->dynamic_symbols().size(); 3528 if (!NumSyms) 3529 return; 3530 ArrayRef<Elf_Word> Chains = GnuHashTable->values(NumSyms); 3531 size_t Symndx = GnuHashTable->symndx; 3532 size_t TotalSyms = 0; 3533 size_t MaxChain = 1; 3534 size_t CumulativeNonZero = 0; 3535 3536 if (Chains.empty() || NBucket == 0) 3537 return; 3538 3539 std::vector<size_t> ChainLen(NBucket, 0); 3540 3541 for (size_t B = 0; B < NBucket; B++) { 3542 if (!Buckets[B]) 3543 continue; 3544 size_t Len = 1; 3545 for (size_t C = Buckets[B] - Symndx; 3546 C < Chains.size() && (Chains[C] & 1) == 0; C++) 3547 if (MaxChain < ++Len) 3548 MaxChain++; 3549 ChainLen[B] = Len; 3550 TotalSyms += Len; 3551 } 3552 MaxChain++; 3553 3554 if (!TotalSyms) 3555 return; 3556 3557 std::vector<size_t> Count(MaxChain, 0) ; 3558 for (size_t B = 0; B < NBucket; B++) 3559 ++Count[ChainLen[B]]; 3560 // Print Number of buckets with each chain lengths and their cumulative 3561 // coverage of the symbols 3562 OS << "Histogram for `.gnu.hash' bucket list length (total of " << NBucket 3563 << " buckets)\n" 3564 << " Length Number % of total Coverage\n"; 3565 for (size_t I = 0; I <MaxChain; I++) { 3566 CumulativeNonZero += Count[I] * I; 3567 OS << format("%7lu %-10lu (%5.1f%%) %5.1f%%\n", I, Count[I], 3568 (Count[I] * 100.0) / NBucket, 3569 (CumulativeNonZero * 100.0) / TotalSyms); 3570 } 3571 } 3572 } 3573 3574 template <class ELFT> 3575 void GNUStyle<ELFT>::printCGProfile(const ELFFile<ELFT> *Obj) { 3576 OS << "GNUStyle::printCGProfile not implemented\n"; 3577 } 3578 3579 template <class ELFT> 3580 void GNUStyle<ELFT>::printAddrsig(const ELFFile<ELFT> *Obj) { 3581 OS << "GNUStyle::printAddrsig not implemented\n"; 3582 } 3583 3584 static std::string getGNUNoteTypeName(const uint32_t NT) { 3585 static const struct { 3586 uint32_t ID; 3587 const char *Name; 3588 } Notes[] = { 3589 {ELF::NT_GNU_ABI_TAG, "NT_GNU_ABI_TAG (ABI version tag)"}, 3590 {ELF::NT_GNU_HWCAP, "NT_GNU_HWCAP (DSO-supplied software HWCAP info)"}, 3591 {ELF::NT_GNU_BUILD_ID, "NT_GNU_BUILD_ID (unique build ID bitstring)"}, 3592 {ELF::NT_GNU_GOLD_VERSION, "NT_GNU_GOLD_VERSION (gold version)"}, 3593 {ELF::NT_GNU_PROPERTY_TYPE_0, "NT_GNU_PROPERTY_TYPE_0 (property note)"}, 3594 }; 3595 3596 for (const auto &Note : Notes) 3597 if (Note.ID == NT) 3598 return std::string(Note.Name); 3599 3600 std::string string; 3601 raw_string_ostream OS(string); 3602 OS << format("Unknown note type (0x%08x)", NT); 3603 return OS.str(); 3604 } 3605 3606 static std::string getFreeBSDNoteTypeName(const uint32_t NT) { 3607 static const struct { 3608 uint32_t ID; 3609 const char *Name; 3610 } Notes[] = { 3611 {ELF::NT_FREEBSD_THRMISC, "NT_THRMISC (thrmisc structure)"}, 3612 {ELF::NT_FREEBSD_PROCSTAT_PROC, "NT_PROCSTAT_PROC (proc data)"}, 3613 {ELF::NT_FREEBSD_PROCSTAT_FILES, "NT_PROCSTAT_FILES (files data)"}, 3614 {ELF::NT_FREEBSD_PROCSTAT_VMMAP, "NT_PROCSTAT_VMMAP (vmmap data)"}, 3615 {ELF::NT_FREEBSD_PROCSTAT_GROUPS, "NT_PROCSTAT_GROUPS (groups data)"}, 3616 {ELF::NT_FREEBSD_PROCSTAT_UMASK, "NT_PROCSTAT_UMASK (umask data)"}, 3617 {ELF::NT_FREEBSD_PROCSTAT_RLIMIT, "NT_PROCSTAT_RLIMIT (rlimit data)"}, 3618 {ELF::NT_FREEBSD_PROCSTAT_OSREL, "NT_PROCSTAT_OSREL (osreldate data)"}, 3619 {ELF::NT_FREEBSD_PROCSTAT_PSSTRINGS, 3620 "NT_PROCSTAT_PSSTRINGS (ps_strings data)"}, 3621 {ELF::NT_FREEBSD_PROCSTAT_AUXV, "NT_PROCSTAT_AUXV (auxv data)"}, 3622 }; 3623 3624 for (const auto &Note : Notes) 3625 if (Note.ID == NT) 3626 return std::string(Note.Name); 3627 3628 std::string string; 3629 raw_string_ostream OS(string); 3630 OS << format("Unknown note type (0x%08x)", NT); 3631 return OS.str(); 3632 } 3633 3634 static std::string getAMDGPUNoteTypeName(const uint32_t NT) { 3635 static const struct { 3636 uint32_t ID; 3637 const char *Name; 3638 } Notes[] = { 3639 {ELF::NT_AMD_AMDGPU_HSA_METADATA, 3640 "NT_AMD_AMDGPU_HSA_METADATA (HSA Metadata)"}, 3641 {ELF::NT_AMD_AMDGPU_ISA, 3642 "NT_AMD_AMDGPU_ISA (ISA Version)"}, 3643 {ELF::NT_AMD_AMDGPU_PAL_METADATA, 3644 "NT_AMD_AMDGPU_PAL_METADATA (PAL Metadata)"} 3645 }; 3646 3647 for (const auto &Note : Notes) 3648 if (Note.ID == NT) 3649 return std::string(Note.Name); 3650 3651 std::string string; 3652 raw_string_ostream OS(string); 3653 OS << format("Unknown note type (0x%08x)", NT); 3654 return OS.str(); 3655 } 3656 3657 template <typename ELFT> 3658 static std::string getGNUProperty(uint32_t Type, uint32_t DataSize, 3659 ArrayRef<uint8_t> Data) { 3660 std::string str; 3661 raw_string_ostream OS(str); 3662 switch (Type) { 3663 default: 3664 OS << format("<application-specific type 0x%x>", Type); 3665 return OS.str(); 3666 case GNU_PROPERTY_STACK_SIZE: { 3667 OS << "stack size: "; 3668 if (DataSize == sizeof(typename ELFT::uint)) 3669 OS << formatv("{0:x}", 3670 (uint64_t)(*(const typename ELFT::Addr *)Data.data())); 3671 else 3672 OS << format("<corrupt length: 0x%x>", DataSize); 3673 return OS.str(); 3674 } 3675 case GNU_PROPERTY_NO_COPY_ON_PROTECTED: 3676 OS << "no copy on protected"; 3677 if (DataSize) 3678 OS << format(" <corrupt length: 0x%x>", DataSize); 3679 return OS.str(); 3680 case GNU_PROPERTY_X86_FEATURE_1_AND: 3681 OS << "X86 features: "; 3682 if (DataSize != 4 && DataSize != 8) { 3683 OS << format("<corrupt length: 0x%x>", DataSize); 3684 return OS.str(); 3685 } 3686 uint64_t CFProtection = 3687 (DataSize == 4) 3688 ? support::endian::read32<ELFT::TargetEndianness>(Data.data()) 3689 : support::endian::read64<ELFT::TargetEndianness>(Data.data()); 3690 if (CFProtection == 0) { 3691 OS << "none"; 3692 return OS.str(); 3693 } 3694 if (CFProtection & GNU_PROPERTY_X86_FEATURE_1_IBT) { 3695 OS << "IBT"; 3696 CFProtection &= ~GNU_PROPERTY_X86_FEATURE_1_IBT; 3697 if (CFProtection) 3698 OS << ", "; 3699 } 3700 if (CFProtection & GNU_PROPERTY_X86_FEATURE_1_SHSTK) { 3701 OS << "SHSTK"; 3702 CFProtection &= ~GNU_PROPERTY_X86_FEATURE_1_SHSTK; 3703 if (CFProtection) 3704 OS << ", "; 3705 } 3706 if (CFProtection) 3707 OS << format("<unknown flags: 0x%llx>", CFProtection); 3708 return OS.str(); 3709 } 3710 } 3711 3712 template <typename ELFT> 3713 static SmallVector<std::string, 4> 3714 getGNUPropertyList(ArrayRef<uint8_t> Arr) { 3715 using Elf_Word = typename ELFT::Word; 3716 3717 SmallVector<std::string, 4> Properties; 3718 while (Arr.size() >= 8) { 3719 uint32_t Type = *reinterpret_cast<const Elf_Word *>(Arr.data()); 3720 uint32_t DataSize = *reinterpret_cast<const Elf_Word *>(Arr.data() + 4); 3721 Arr = Arr.drop_front(8); 3722 3723 // Take padding size into account if present. 3724 uint64_t PaddedSize = alignTo(DataSize, sizeof(typename ELFT::uint)); 3725 std::string str; 3726 raw_string_ostream OS(str); 3727 if (Arr.size() < PaddedSize) { 3728 OS << format("<corrupt type (0x%x) datasz: 0x%x>", Type, DataSize); 3729 Properties.push_back(OS.str()); 3730 break; 3731 } 3732 Properties.push_back( 3733 getGNUProperty<ELFT>(Type, DataSize, Arr.take_front(PaddedSize))); 3734 Arr = Arr.drop_front(PaddedSize); 3735 } 3736 3737 if (!Arr.empty()) 3738 Properties.push_back("<corrupted GNU_PROPERTY_TYPE_0>"); 3739 3740 return Properties; 3741 } 3742 3743 struct GNUAbiTag { 3744 std::string OSName; 3745 std::string ABI; 3746 bool IsValid; 3747 }; 3748 3749 template <typename ELFT> 3750 static GNUAbiTag getGNUAbiTag(ArrayRef<uint8_t> Desc) { 3751 typedef typename ELFT::Word Elf_Word; 3752 3753 ArrayRef<Elf_Word> Words(reinterpret_cast<const Elf_Word*>(Desc.begin()), 3754 reinterpret_cast<const Elf_Word*>(Desc.end())); 3755 3756 if (Words.size() < 4) 3757 return {"", "", /*IsValid=*/false}; 3758 3759 static const char *OSNames[] = { 3760 "Linux", "Hurd", "Solaris", "FreeBSD", "NetBSD", "Syllable", "NaCl", 3761 }; 3762 StringRef OSName = "Unknown"; 3763 if (Words[0] < array_lengthof(OSNames)) 3764 OSName = OSNames[Words[0]]; 3765 uint32_t Major = Words[1], Minor = Words[2], Patch = Words[3]; 3766 std::string str; 3767 raw_string_ostream ABI(str); 3768 ABI << Major << "." << Minor << "." << Patch; 3769 return {OSName, ABI.str(), /*IsValid=*/true}; 3770 } 3771 3772 static std::string getGNUBuildId(ArrayRef<uint8_t> Desc) { 3773 std::string str; 3774 raw_string_ostream OS(str); 3775 for (const auto &B : Desc) 3776 OS << format_hex_no_prefix(B, 2); 3777 return OS.str(); 3778 } 3779 3780 static StringRef getGNUGoldVersion(ArrayRef<uint8_t> Desc) { 3781 return StringRef(reinterpret_cast<const char *>(Desc.data()), Desc.size()); 3782 } 3783 3784 template <typename ELFT> 3785 static void printGNUNote(raw_ostream &OS, uint32_t NoteType, 3786 ArrayRef<uint8_t> Desc) { 3787 switch (NoteType) { 3788 default: 3789 return; 3790 case ELF::NT_GNU_ABI_TAG: { 3791 const GNUAbiTag &AbiTag = getGNUAbiTag<ELFT>(Desc); 3792 if (!AbiTag.IsValid) 3793 OS << " <corrupt GNU_ABI_TAG>"; 3794 else 3795 OS << " OS: " << AbiTag.OSName << ", ABI: " << AbiTag.ABI; 3796 break; 3797 } 3798 case ELF::NT_GNU_BUILD_ID: { 3799 OS << " Build ID: " << getGNUBuildId(Desc); 3800 break; 3801 } 3802 case ELF::NT_GNU_GOLD_VERSION: 3803 OS << " Version: " << getGNUGoldVersion(Desc); 3804 break; 3805 case ELF::NT_GNU_PROPERTY_TYPE_0: 3806 OS << " Properties:"; 3807 for (const auto &Property : getGNUPropertyList<ELFT>(Desc)) 3808 OS << " " << Property << "\n"; 3809 break; 3810 } 3811 OS << '\n'; 3812 } 3813 3814 struct AMDGPUNote { 3815 std::string type; 3816 std::string value; 3817 }; 3818 3819 template <typename ELFT> 3820 static AMDGPUNote getAMDGPUNote(uint32_t NoteType, 3821 ArrayRef<uint8_t> Desc) { 3822 switch (NoteType) { 3823 default: 3824 return {"", ""}; 3825 case ELF::NT_AMD_AMDGPU_HSA_METADATA: 3826 return {"HSA Metadata", 3827 std::string(reinterpret_cast<const char *>(Desc.data()), 3828 Desc.size())}; 3829 case ELF::NT_AMD_AMDGPU_ISA: 3830 return {"ISA Version", 3831 std::string(reinterpret_cast<const char *>(Desc.data()), 3832 Desc.size())}; 3833 case ELF::NT_AMD_AMDGPU_PAL_METADATA: 3834 const uint32_t *PALMetadataBegin = 3835 reinterpret_cast<const uint32_t *>(Desc.data()); 3836 const uint32_t *PALMetadataEnd = PALMetadataBegin + Desc.size(); 3837 std::vector<uint32_t> PALMetadata(PALMetadataBegin, PALMetadataEnd); 3838 std::string PALMetadataString; 3839 auto Error = AMDGPU::PALMD::toString(PALMetadata, PALMetadataString); 3840 if (Error) { 3841 return {"PAL Metadata", "Invalid"}; 3842 } 3843 return {"PAL Metadata", PALMetadataString}; 3844 } 3845 } 3846 3847 template <class ELFT> 3848 void GNUStyle<ELFT>::printNotes(const ELFFile<ELFT> *Obj) { 3849 const Elf_Ehdr *e = Obj->getHeader(); 3850 bool IsCore = e->e_type == ELF::ET_CORE; 3851 3852 auto PrintHeader = [&](const typename ELFT::Off Offset, 3853 const typename ELFT::Addr Size) { 3854 OS << "Displaying notes found at file offset " << format_hex(Offset, 10) 3855 << " with length " << format_hex(Size, 10) << ":\n" 3856 << " Owner Data size\tDescription\n"; 3857 }; 3858 3859 auto ProcessNote = [&](const Elf_Note &Note) { 3860 StringRef Name = Note.getName(); 3861 ArrayRef<uint8_t> Descriptor = Note.getDesc(); 3862 Elf_Word Type = Note.getType(); 3863 3864 OS << " " << Name << std::string(22 - Name.size(), ' ') 3865 << format_hex(Descriptor.size(), 10) << '\t'; 3866 3867 if (Name == "GNU") { 3868 OS << getGNUNoteTypeName(Type) << '\n'; 3869 printGNUNote<ELFT>(OS, Type, Descriptor); 3870 } else if (Name == "FreeBSD") { 3871 OS << getFreeBSDNoteTypeName(Type) << '\n'; 3872 } else if (Name == "AMD") { 3873 OS << getAMDGPUNoteTypeName(Type) << '\n'; 3874 const AMDGPUNote N = getAMDGPUNote<ELFT>(Type, Descriptor); 3875 if (!N.type.empty()) 3876 OS << " " << N.type << ":\n " << N.value << '\n'; 3877 } else { 3878 OS << "Unknown note type: (" << format_hex(Type, 10) << ')'; 3879 } 3880 OS << '\n'; 3881 }; 3882 3883 if (IsCore) { 3884 for (const auto &P : unwrapOrError(Obj->program_headers())) { 3885 if (P.p_type != PT_NOTE) 3886 continue; 3887 PrintHeader(P.p_offset, P.p_filesz); 3888 Error Err = Error::success(); 3889 for (const auto &Note : Obj->notes(P, Err)) 3890 ProcessNote(Note); 3891 if (Err) 3892 error(std::move(Err)); 3893 } 3894 } else { 3895 for (const auto &S : unwrapOrError(Obj->sections())) { 3896 if (S.sh_type != SHT_NOTE) 3897 continue; 3898 PrintHeader(S.sh_offset, S.sh_size); 3899 Error Err = Error::success(); 3900 for (const auto &Note : Obj->notes(S, Err)) 3901 ProcessNote(Note); 3902 if (Err) 3903 error(std::move(Err)); 3904 } 3905 } 3906 } 3907 3908 template <class ELFT> 3909 void GNUStyle<ELFT>::printELFLinkerOptions(const ELFFile<ELFT> *Obj) { 3910 OS << "printELFLinkerOptions not implemented!\n"; 3911 } 3912 3913 template <class ELFT> 3914 void GNUStyle<ELFT>::printMipsGOT(const MipsGOTParser<ELFT> &Parser) { 3915 size_t Bias = ELFT::Is64Bits ? 8 : 0; 3916 auto PrintEntry = [&](const Elf_Addr *E, StringRef Purpose) { 3917 OS.PadToColumn(2); 3918 OS << format_hex_no_prefix(Parser.getGotAddress(E), 8 + Bias); 3919 OS.PadToColumn(11 + Bias); 3920 OS << format_decimal(Parser.getGotOffset(E), 6) << "(gp)"; 3921 OS.PadToColumn(22 + Bias); 3922 OS << format_hex_no_prefix(*E, 8 + Bias); 3923 OS.PadToColumn(31 + 2 * Bias); 3924 OS << Purpose << "\n"; 3925 }; 3926 3927 OS << (Parser.IsStatic ? "Static GOT:\n" : "Primary GOT:\n"); 3928 OS << " Canonical gp value: " 3929 << format_hex_no_prefix(Parser.getGp(), 8 + Bias) << "\n\n"; 3930 3931 OS << " Reserved entries:\n"; 3932 OS << " Address Access Initial Purpose\n"; 3933 PrintEntry(Parser.getGotLazyResolver(), "Lazy resolver"); 3934 if (Parser.getGotModulePointer()) 3935 PrintEntry(Parser.getGotModulePointer(), "Module pointer (GNU extension)"); 3936 3937 if (!Parser.getLocalEntries().empty()) { 3938 OS << "\n"; 3939 OS << " Local entries:\n"; 3940 OS << " Address Access Initial\n"; 3941 for (auto &E : Parser.getLocalEntries()) 3942 PrintEntry(&E, ""); 3943 } 3944 3945 if (Parser.IsStatic) 3946 return; 3947 3948 if (!Parser.getGlobalEntries().empty()) { 3949 OS << "\n"; 3950 OS << " Global entries:\n"; 3951 OS << " Address Access Initial Sym.Val. Type Ndx Name\n"; 3952 for (auto &E : Parser.getGlobalEntries()) { 3953 const Elf_Sym *Sym = Parser.getGotSym(&E); 3954 std::string SymName = this->dumper()->getFullSymbolName( 3955 Sym, this->dumper()->getDynamicStringTable(), false); 3956 3957 OS.PadToColumn(2); 3958 OS << to_string(format_hex_no_prefix(Parser.getGotAddress(&E), 8 + Bias)); 3959 OS.PadToColumn(11 + Bias); 3960 OS << to_string(format_decimal(Parser.getGotOffset(&E), 6)) + "(gp)"; 3961 OS.PadToColumn(22 + Bias); 3962 OS << to_string(format_hex_no_prefix(E, 8 + Bias)); 3963 OS.PadToColumn(31 + 2 * Bias); 3964 OS << to_string(format_hex_no_prefix(Sym->st_value, 8 + Bias)); 3965 OS.PadToColumn(40 + 3 * Bias); 3966 OS << printEnum(Sym->getType(), makeArrayRef(ElfSymbolTypes)); 3967 OS.PadToColumn(48 + 3 * Bias); 3968 OS << getSymbolSectionNdx(Parser.Obj, Sym, 3969 this->dumper()->dynamic_symbols().begin()); 3970 OS.PadToColumn(52 + 3 * Bias); 3971 OS << SymName << "\n"; 3972 } 3973 } 3974 3975 if (!Parser.getOtherEntries().empty()) 3976 OS << "\n Number of TLS and multi-GOT entries " 3977 << Parser.getOtherEntries().size() << "\n"; 3978 } 3979 3980 template <class ELFT> 3981 void GNUStyle<ELFT>::printMipsPLT(const MipsGOTParser<ELFT> &Parser) { 3982 size_t Bias = ELFT::Is64Bits ? 8 : 0; 3983 auto PrintEntry = [&](const Elf_Addr *E, StringRef Purpose) { 3984 OS.PadToColumn(2); 3985 OS << format_hex_no_prefix(Parser.getGotAddress(E), 8 + Bias); 3986 OS.PadToColumn(11 + Bias); 3987 OS << format_hex_no_prefix(*E, 8 + Bias); 3988 OS.PadToColumn(20 + 2 * Bias); 3989 OS << Purpose << "\n"; 3990 }; 3991 3992 OS << "PLT GOT:\n\n"; 3993 3994 OS << " Reserved entries:\n"; 3995 OS << " Address Initial Purpose\n"; 3996 PrintEntry(Parser.getPltLazyResolver(), "PLT lazy resolver"); 3997 if (Parser.getPltModulePointer()) 3998 PrintEntry(Parser.getGotModulePointer(), "Module pointer"); 3999 4000 if (!Parser.getPltEntries().empty()) { 4001 OS << "\n"; 4002 OS << " Entries:\n"; 4003 OS << " Address Initial Sym.Val. Type Ndx Name\n"; 4004 for (auto &E : Parser.getPltEntries()) { 4005 const Elf_Sym *Sym = Parser.getPltSym(&E); 4006 std::string SymName = this->dumper()->getFullSymbolName( 4007 Sym, this->dumper()->getDynamicStringTable(), false); 4008 4009 OS.PadToColumn(2); 4010 OS << to_string(format_hex_no_prefix(Parser.getGotAddress(&E), 8 + Bias)); 4011 OS.PadToColumn(11 + Bias); 4012 OS << to_string(format_hex_no_prefix(E, 8 + Bias)); 4013 OS.PadToColumn(20 + 2 * Bias); 4014 OS << to_string(format_hex_no_prefix(Sym->st_value, 8 + Bias)); 4015 OS.PadToColumn(29 + 3 * Bias); 4016 OS << printEnum(Sym->getType(), makeArrayRef(ElfSymbolTypes)); 4017 OS.PadToColumn(37 + 3 * Bias); 4018 OS << getSymbolSectionNdx(Parser.Obj, Sym, 4019 this->dumper()->dynamic_symbols().begin()); 4020 OS.PadToColumn(41 + 3 * Bias); 4021 OS << SymName << "\n"; 4022 } 4023 } 4024 } 4025 4026 template <class ELFT> void LLVMStyle<ELFT>::printFileHeaders(const ELFO *Obj) { 4027 const Elf_Ehdr *e = Obj->getHeader(); 4028 { 4029 DictScope D(W, "ElfHeader"); 4030 { 4031 DictScope D(W, "Ident"); 4032 W.printBinary("Magic", makeArrayRef(e->e_ident).slice(ELF::EI_MAG0, 4)); 4033 W.printEnum("Class", e->e_ident[ELF::EI_CLASS], makeArrayRef(ElfClass)); 4034 W.printEnum("DataEncoding", e->e_ident[ELF::EI_DATA], 4035 makeArrayRef(ElfDataEncoding)); 4036 W.printNumber("FileVersion", e->e_ident[ELF::EI_VERSION]); 4037 4038 auto OSABI = makeArrayRef(ElfOSABI); 4039 if (e->e_ident[ELF::EI_OSABI] >= ELF::ELFOSABI_FIRST_ARCH && 4040 e->e_ident[ELF::EI_OSABI] <= ELF::ELFOSABI_LAST_ARCH) { 4041 switch (e->e_machine) { 4042 case ELF::EM_AMDGPU: 4043 OSABI = makeArrayRef(AMDGPUElfOSABI); 4044 break; 4045 case ELF::EM_ARM: 4046 OSABI = makeArrayRef(ARMElfOSABI); 4047 break; 4048 case ELF::EM_TI_C6000: 4049 OSABI = makeArrayRef(C6000ElfOSABI); 4050 break; 4051 } 4052 } 4053 W.printEnum("OS/ABI", e->e_ident[ELF::EI_OSABI], OSABI); 4054 W.printNumber("ABIVersion", e->e_ident[ELF::EI_ABIVERSION]); 4055 W.printBinary("Unused", makeArrayRef(e->e_ident).slice(ELF::EI_PAD)); 4056 } 4057 4058 W.printEnum("Type", e->e_type, makeArrayRef(ElfObjectFileType)); 4059 W.printEnum("Machine", e->e_machine, makeArrayRef(ElfMachineType)); 4060 W.printNumber("Version", e->e_version); 4061 W.printHex("Entry", e->e_entry); 4062 W.printHex("ProgramHeaderOffset", e->e_phoff); 4063 W.printHex("SectionHeaderOffset", e->e_shoff); 4064 if (e->e_machine == EM_MIPS) 4065 W.printFlags("Flags", e->e_flags, makeArrayRef(ElfHeaderMipsFlags), 4066 unsigned(ELF::EF_MIPS_ARCH), unsigned(ELF::EF_MIPS_ABI), 4067 unsigned(ELF::EF_MIPS_MACH)); 4068 else if (e->e_machine == EM_AMDGPU) 4069 W.printFlags("Flags", e->e_flags, makeArrayRef(ElfHeaderAMDGPUFlags), 4070 unsigned(ELF::EF_AMDGPU_MACH)); 4071 else if (e->e_machine == EM_RISCV) 4072 W.printFlags("Flags", e->e_flags, makeArrayRef(ElfHeaderRISCVFlags)); 4073 else 4074 W.printFlags("Flags", e->e_flags); 4075 W.printNumber("HeaderSize", e->e_ehsize); 4076 W.printNumber("ProgramHeaderEntrySize", e->e_phentsize); 4077 W.printNumber("ProgramHeaderCount", e->e_phnum); 4078 W.printNumber("SectionHeaderEntrySize", e->e_shentsize); 4079 W.printString("SectionHeaderCount", getSectionHeadersNumString(Obj)); 4080 W.printString("StringTableSectionIndex", getSectionHeaderTableIndexString(Obj)); 4081 } 4082 } 4083 4084 template <class ELFT> 4085 void LLVMStyle<ELFT>::printGroupSections(const ELFO *Obj) { 4086 DictScope Lists(W, "Groups"); 4087 std::vector<GroupSection> V = getGroups<ELFT>(Obj); 4088 DenseMap<uint64_t, const GroupSection *> Map = mapSectionsToGroups(V); 4089 for (const GroupSection &G : V) { 4090 DictScope D(W, "Group"); 4091 W.printNumber("Name", G.Name, G.ShName); 4092 W.printNumber("Index", G.Index); 4093 W.printNumber("Link", G.Link); 4094 W.printNumber("Info", G.Info); 4095 W.printHex("Type", getGroupType(G.Type), G.Type); 4096 W.startLine() << "Signature: " << G.Signature << "\n"; 4097 4098 ListScope L(W, "Section(s) in group"); 4099 for (const GroupMember &GM : G.Members) { 4100 const GroupSection *MainGroup = Map[GM.Index]; 4101 if (MainGroup != &G) { 4102 W.flush(); 4103 errs() << "Error: " << GM.Name << " (" << GM.Index 4104 << ") in a group " + G.Name + " (" << G.Index 4105 << ") is already in a group " + MainGroup->Name + " (" 4106 << MainGroup->Index << ")\n"; 4107 errs().flush(); 4108 continue; 4109 } 4110 W.startLine() << GM.Name << " (" << GM.Index << ")\n"; 4111 } 4112 } 4113 4114 if (V.empty()) 4115 W.startLine() << "There are no group sections in the file.\n"; 4116 } 4117 4118 template <class ELFT> void LLVMStyle<ELFT>::printRelocations(const ELFO *Obj) { 4119 ListScope D(W, "Relocations"); 4120 4121 int SectionNumber = -1; 4122 for (const Elf_Shdr &Sec : unwrapOrError(Obj->sections())) { 4123 ++SectionNumber; 4124 4125 if (Sec.sh_type != ELF::SHT_REL && 4126 Sec.sh_type != ELF::SHT_RELA && 4127 Sec.sh_type != ELF::SHT_RELR && 4128 Sec.sh_type != ELF::SHT_ANDROID_REL && 4129 Sec.sh_type != ELF::SHT_ANDROID_RELA && 4130 Sec.sh_type != ELF::SHT_ANDROID_RELR) 4131 continue; 4132 4133 StringRef Name = unwrapOrError(Obj->getSectionName(&Sec)); 4134 4135 W.startLine() << "Section (" << SectionNumber << ") " << Name << " {\n"; 4136 W.indent(); 4137 4138 printRelocations(&Sec, Obj); 4139 4140 W.unindent(); 4141 W.startLine() << "}\n"; 4142 } 4143 } 4144 4145 template <class ELFT> 4146 void LLVMStyle<ELFT>::printRelocations(const Elf_Shdr *Sec, const ELFO *Obj) { 4147 const Elf_Shdr *SymTab = unwrapOrError(Obj->getSection(Sec->sh_link)); 4148 4149 switch (Sec->sh_type) { 4150 case ELF::SHT_REL: 4151 for (const Elf_Rel &R : unwrapOrError(Obj->rels(Sec))) { 4152 Elf_Rela Rela; 4153 Rela.r_offset = R.r_offset; 4154 Rela.r_info = R.r_info; 4155 Rela.r_addend = 0; 4156 printRelocation(Obj, Rela, SymTab); 4157 } 4158 break; 4159 case ELF::SHT_RELA: 4160 for (const Elf_Rela &R : unwrapOrError(Obj->relas(Sec))) 4161 printRelocation(Obj, R, SymTab); 4162 break; 4163 case ELF::SHT_RELR: 4164 case ELF::SHT_ANDROID_RELR: { 4165 Elf_Relr_Range Relrs = unwrapOrError(Obj->relrs(Sec)); 4166 if (opts::RawRelr) { 4167 for (const Elf_Relr &R : Relrs) 4168 W.startLine() << W.hex(R) << "\n"; 4169 } else { 4170 std::vector<Elf_Rela> RelrRelas = unwrapOrError(Obj->decode_relrs(Relrs)); 4171 for (const Elf_Rela &R : RelrRelas) 4172 printRelocation(Obj, R, SymTab); 4173 } 4174 break; 4175 } 4176 case ELF::SHT_ANDROID_REL: 4177 case ELF::SHT_ANDROID_RELA: 4178 for (const Elf_Rela &R : unwrapOrError(Obj->android_relas(Sec))) 4179 printRelocation(Obj, R, SymTab); 4180 break; 4181 } 4182 } 4183 4184 template <class ELFT> 4185 void LLVMStyle<ELFT>::printRelocation(const ELFO *Obj, Elf_Rela Rel, 4186 const Elf_Shdr *SymTab) { 4187 SmallString<32> RelocName; 4188 Obj->getRelocationTypeName(Rel.getType(Obj->isMips64EL()), RelocName); 4189 StringRef TargetName; 4190 const Elf_Sym *Sym = unwrapOrError(Obj->getRelocationSymbol(&Rel, SymTab)); 4191 if (Sym && Sym->getType() == ELF::STT_SECTION) { 4192 const Elf_Shdr *Sec = unwrapOrError( 4193 Obj->getSection(Sym, SymTab, this->dumper()->getShndxTable())); 4194 TargetName = unwrapOrError(Obj->getSectionName(Sec)); 4195 } else if (Sym) { 4196 StringRef StrTable = unwrapOrError(Obj->getStringTableForSymtab(*SymTab)); 4197 TargetName = unwrapOrError(Sym->getName(StrTable)); 4198 } 4199 4200 if (opts::ExpandRelocs) { 4201 DictScope Group(W, "Relocation"); 4202 W.printHex("Offset", Rel.r_offset); 4203 W.printNumber("Type", RelocName, (int)Rel.getType(Obj->isMips64EL())); 4204 W.printNumber("Symbol", !TargetName.empty() ? TargetName : "-", 4205 Rel.getSymbol(Obj->isMips64EL())); 4206 W.printHex("Addend", Rel.r_addend); 4207 } else { 4208 raw_ostream &OS = W.startLine(); 4209 OS << W.hex(Rel.r_offset) << " " << RelocName << " " 4210 << (!TargetName.empty() ? TargetName : "-") << " " 4211 << W.hex(Rel.r_addend) << "\n"; 4212 } 4213 } 4214 4215 template <class ELFT> 4216 void LLVMStyle<ELFT>::printSectionHeaders(const ELFO *Obj) { 4217 ListScope SectionsD(W, "Sections"); 4218 4219 int SectionIndex = -1; 4220 for (const Elf_Shdr &Sec : unwrapOrError(Obj->sections())) { 4221 ++SectionIndex; 4222 4223 StringRef Name = unwrapOrError(Obj->getSectionName(&Sec)); 4224 4225 DictScope SectionD(W, "Section"); 4226 W.printNumber("Index", SectionIndex); 4227 W.printNumber("Name", Name, Sec.sh_name); 4228 W.printHex( 4229 "Type", 4230 object::getELFSectionTypeName(Obj->getHeader()->e_machine, Sec.sh_type), 4231 Sec.sh_type); 4232 std::vector<EnumEntry<unsigned>> SectionFlags(std::begin(ElfSectionFlags), 4233 std::end(ElfSectionFlags)); 4234 switch (Obj->getHeader()->e_machine) { 4235 case EM_ARM: 4236 SectionFlags.insert(SectionFlags.end(), std::begin(ElfARMSectionFlags), 4237 std::end(ElfARMSectionFlags)); 4238 break; 4239 case EM_HEXAGON: 4240 SectionFlags.insert(SectionFlags.end(), 4241 std::begin(ElfHexagonSectionFlags), 4242 std::end(ElfHexagonSectionFlags)); 4243 break; 4244 case EM_MIPS: 4245 SectionFlags.insert(SectionFlags.end(), std::begin(ElfMipsSectionFlags), 4246 std::end(ElfMipsSectionFlags)); 4247 break; 4248 case EM_X86_64: 4249 SectionFlags.insert(SectionFlags.end(), std::begin(ElfX86_64SectionFlags), 4250 std::end(ElfX86_64SectionFlags)); 4251 break; 4252 case EM_XCORE: 4253 SectionFlags.insert(SectionFlags.end(), std::begin(ElfXCoreSectionFlags), 4254 std::end(ElfXCoreSectionFlags)); 4255 break; 4256 default: 4257 // Nothing to do. 4258 break; 4259 } 4260 W.printFlags("Flags", Sec.sh_flags, makeArrayRef(SectionFlags)); 4261 W.printHex("Address", Sec.sh_addr); 4262 W.printHex("Offset", Sec.sh_offset); 4263 W.printNumber("Size", Sec.sh_size); 4264 W.printNumber("Link", Sec.sh_link); 4265 W.printNumber("Info", Sec.sh_info); 4266 W.printNumber("AddressAlignment", Sec.sh_addralign); 4267 W.printNumber("EntrySize", Sec.sh_entsize); 4268 4269 if (opts::SectionRelocations) { 4270 ListScope D(W, "Relocations"); 4271 printRelocations(&Sec, Obj); 4272 } 4273 4274 if (opts::SectionSymbols) { 4275 ListScope D(W, "Symbols"); 4276 const Elf_Shdr *Symtab = this->dumper()->getDotSymtabSec(); 4277 StringRef StrTable = unwrapOrError(Obj->getStringTableForSymtab(*Symtab)); 4278 4279 for (const Elf_Sym &Sym : unwrapOrError(Obj->symbols(Symtab))) { 4280 const Elf_Shdr *SymSec = unwrapOrError( 4281 Obj->getSection(&Sym, Symtab, this->dumper()->getShndxTable())); 4282 if (SymSec == &Sec) 4283 printSymbol(Obj, &Sym, unwrapOrError(Obj->symbols(Symtab)).begin(), 4284 StrTable, false); 4285 } 4286 } 4287 4288 if (opts::SectionData && Sec.sh_type != ELF::SHT_NOBITS) { 4289 ArrayRef<uint8_t> Data = unwrapOrError(Obj->getSectionContents(&Sec)); 4290 W.printBinaryBlock("SectionData", 4291 StringRef((const char *)Data.data(), Data.size())); 4292 } 4293 } 4294 } 4295 4296 template <class ELFT> 4297 void LLVMStyle<ELFT>::printSymbol(const ELFO *Obj, const Elf_Sym *Symbol, 4298 const Elf_Sym *First, StringRef StrTable, 4299 bool IsDynamic) { 4300 unsigned SectionIndex = 0; 4301 StringRef SectionName; 4302 this->dumper()->getSectionNameIndex(Symbol, First, SectionName, SectionIndex); 4303 std::string FullSymbolName = 4304 this->dumper()->getFullSymbolName(Symbol, StrTable, IsDynamic); 4305 unsigned char SymbolType = Symbol->getType(); 4306 4307 DictScope D(W, "Symbol"); 4308 W.printNumber("Name", FullSymbolName, Symbol->st_name); 4309 W.printHex("Value", Symbol->st_value); 4310 W.printNumber("Size", Symbol->st_size); 4311 W.printEnum("Binding", Symbol->getBinding(), makeArrayRef(ElfSymbolBindings)); 4312 if (Obj->getHeader()->e_machine == ELF::EM_AMDGPU && 4313 SymbolType >= ELF::STT_LOOS && SymbolType < ELF::STT_HIOS) 4314 W.printEnum("Type", SymbolType, makeArrayRef(AMDGPUSymbolTypes)); 4315 else 4316 W.printEnum("Type", SymbolType, makeArrayRef(ElfSymbolTypes)); 4317 if (Symbol->st_other == 0) 4318 // Usually st_other flag is zero. Do not pollute the output 4319 // by flags enumeration in that case. 4320 W.printNumber("Other", 0); 4321 else { 4322 std::vector<EnumEntry<unsigned>> SymOtherFlags(std::begin(ElfSymOtherFlags), 4323 std::end(ElfSymOtherFlags)); 4324 if (Obj->getHeader()->e_machine == EM_MIPS) { 4325 // Someones in their infinite wisdom decided to make STO_MIPS_MIPS16 4326 // flag overlapped with other ST_MIPS_xxx flags. So consider both 4327 // cases separately. 4328 if ((Symbol->st_other & STO_MIPS_MIPS16) == STO_MIPS_MIPS16) 4329 SymOtherFlags.insert(SymOtherFlags.end(), 4330 std::begin(ElfMips16SymOtherFlags), 4331 std::end(ElfMips16SymOtherFlags)); 4332 else 4333 SymOtherFlags.insert(SymOtherFlags.end(), 4334 std::begin(ElfMipsSymOtherFlags), 4335 std::end(ElfMipsSymOtherFlags)); 4336 } 4337 W.printFlags("Other", Symbol->st_other, makeArrayRef(SymOtherFlags), 0x3u); 4338 } 4339 W.printHex("Section", SectionName, SectionIndex); 4340 } 4341 4342 template <class ELFT> void LLVMStyle<ELFT>::printSymbols(const ELFO *Obj) { 4343 ListScope Group(W, "Symbols"); 4344 this->dumper()->printSymbolsHelper(false); 4345 } 4346 4347 template <class ELFT> 4348 void LLVMStyle<ELFT>::printDynamicSymbols(const ELFO *Obj) { 4349 ListScope Group(W, "DynamicSymbols"); 4350 this->dumper()->printSymbolsHelper(true); 4351 } 4352 4353 template <class ELFT> 4354 void LLVMStyle<ELFT>::printDynamicRelocations(const ELFO *Obj) { 4355 const DynRegionInfo &DynRelRegion = this->dumper()->getDynRelRegion(); 4356 const DynRegionInfo &DynRelaRegion = this->dumper()->getDynRelaRegion(); 4357 const DynRegionInfo &DynRelrRegion = this->dumper()->getDynRelrRegion(); 4358 const DynRegionInfo &DynPLTRelRegion = this->dumper()->getDynPLTRelRegion(); 4359 if (DynRelRegion.Size && DynRelaRegion.Size) 4360 report_fatal_error("There are both REL and RELA dynamic relocations"); 4361 W.startLine() << "Dynamic Relocations {\n"; 4362 W.indent(); 4363 if (DynRelaRegion.Size > 0) 4364 for (const Elf_Rela &Rela : this->dumper()->dyn_relas()) 4365 printDynamicRelocation(Obj, Rela); 4366 else 4367 for (const Elf_Rel &Rel : this->dumper()->dyn_rels()) { 4368 Elf_Rela Rela; 4369 Rela.r_offset = Rel.r_offset; 4370 Rela.r_info = Rel.r_info; 4371 Rela.r_addend = 0; 4372 printDynamicRelocation(Obj, Rela); 4373 } 4374 if (DynRelrRegion.Size > 0) { 4375 Elf_Relr_Range Relrs = this->dumper()->dyn_relrs(); 4376 std::vector<Elf_Rela> RelrRelas = unwrapOrError(Obj->decode_relrs(Relrs)); 4377 for (const Elf_Rela &Rela : RelrRelas) 4378 printDynamicRelocation(Obj, Rela); 4379 } 4380 if (DynPLTRelRegion.EntSize == sizeof(Elf_Rela)) 4381 for (const Elf_Rela &Rela : DynPLTRelRegion.getAsArrayRef<Elf_Rela>()) 4382 printDynamicRelocation(Obj, Rela); 4383 else 4384 for (const Elf_Rel &Rel : DynPLTRelRegion.getAsArrayRef<Elf_Rel>()) { 4385 Elf_Rela Rela; 4386 Rela.r_offset = Rel.r_offset; 4387 Rela.r_info = Rel.r_info; 4388 Rela.r_addend = 0; 4389 printDynamicRelocation(Obj, Rela); 4390 } 4391 W.unindent(); 4392 W.startLine() << "}\n"; 4393 } 4394 4395 template <class ELFT> 4396 void LLVMStyle<ELFT>::printDynamicRelocation(const ELFO *Obj, Elf_Rela Rel) { 4397 SmallString<32> RelocName; 4398 Obj->getRelocationTypeName(Rel.getType(Obj->isMips64EL()), RelocName); 4399 StringRef SymbolName; 4400 uint32_t SymIndex = Rel.getSymbol(Obj->isMips64EL()); 4401 const Elf_Sym *Sym = this->dumper()->dynamic_symbols().begin() + SymIndex; 4402 SymbolName = 4403 unwrapOrError(Sym->getName(this->dumper()->getDynamicStringTable())); 4404 if (opts::ExpandRelocs) { 4405 DictScope Group(W, "Relocation"); 4406 W.printHex("Offset", Rel.r_offset); 4407 W.printNumber("Type", RelocName, (int)Rel.getType(Obj->isMips64EL())); 4408 W.printString("Symbol", !SymbolName.empty() ? SymbolName : "-"); 4409 W.printHex("Addend", Rel.r_addend); 4410 } else { 4411 raw_ostream &OS = W.startLine(); 4412 OS << W.hex(Rel.r_offset) << " " << RelocName << " " 4413 << (!SymbolName.empty() ? SymbolName : "-") << " " 4414 << W.hex(Rel.r_addend) << "\n"; 4415 } 4416 } 4417 4418 template <class ELFT> 4419 void LLVMStyle<ELFT>::printProgramHeaders(const ELFO *Obj) { 4420 ListScope L(W, "ProgramHeaders"); 4421 4422 for (const Elf_Phdr &Phdr : unwrapOrError(Obj->program_headers())) { 4423 DictScope P(W, "ProgramHeader"); 4424 W.printHex("Type", 4425 getElfSegmentType(Obj->getHeader()->e_machine, Phdr.p_type), 4426 Phdr.p_type); 4427 W.printHex("Offset", Phdr.p_offset); 4428 W.printHex("VirtualAddress", Phdr.p_vaddr); 4429 W.printHex("PhysicalAddress", Phdr.p_paddr); 4430 W.printNumber("FileSize", Phdr.p_filesz); 4431 W.printNumber("MemSize", Phdr.p_memsz); 4432 W.printFlags("Flags", Phdr.p_flags, makeArrayRef(ElfSegmentFlags)); 4433 W.printNumber("Alignment", Phdr.p_align); 4434 } 4435 } 4436 4437 template <class ELFT> 4438 void LLVMStyle<ELFT>::printHashHistogram(const ELFFile<ELFT> *Obj) { 4439 W.startLine() << "Hash Histogram not implemented!\n"; 4440 } 4441 4442 template <class ELFT> 4443 void LLVMStyle<ELFT>::printCGProfile(const ELFFile<ELFT> *Obj) { 4444 ListScope L(W, "CGProfile"); 4445 if (!this->dumper()->getDotCGProfileSec()) 4446 return; 4447 auto CGProfile = 4448 unwrapOrError(Obj->template getSectionContentsAsArray<Elf_CGProfile>( 4449 this->dumper()->getDotCGProfileSec())); 4450 for (const Elf_CGProfile &CGPE : CGProfile) { 4451 DictScope D(W, "CGProfileEntry"); 4452 W.printNumber("From", this->dumper()->getStaticSymbolName(CGPE.cgp_from), 4453 CGPE.cgp_from); 4454 W.printNumber("To", this->dumper()->getStaticSymbolName(CGPE.cgp_to), 4455 CGPE.cgp_to); 4456 W.printNumber("Weight", CGPE.cgp_weight); 4457 } 4458 } 4459 4460 template <class ELFT> 4461 void LLVMStyle<ELFT>::printAddrsig(const ELFFile<ELFT> *Obj) { 4462 ListScope L(W, "Addrsig"); 4463 if (!this->dumper()->getDotAddrsigSec()) 4464 return; 4465 ArrayRef<uint8_t> Contents = unwrapOrError( 4466 Obj->getSectionContents(this->dumper()->getDotAddrsigSec())); 4467 const uint8_t *Cur = Contents.begin(); 4468 const uint8_t *End = Contents.end(); 4469 while (Cur != End) { 4470 unsigned Size; 4471 const char *Err; 4472 uint64_t SymIndex = decodeULEB128(Cur, &Size, End, &Err); 4473 if (Err) 4474 reportError(Err); 4475 W.printNumber("Sym", this->dumper()->getStaticSymbolName(SymIndex), 4476 SymIndex); 4477 Cur += Size; 4478 } 4479 } 4480 4481 template <typename ELFT> 4482 static void printGNUNoteLLVMStyle(uint32_t NoteType, 4483 ArrayRef<uint8_t> Desc, 4484 ScopedPrinter &W) { 4485 switch (NoteType) { 4486 default: 4487 return; 4488 case ELF::NT_GNU_ABI_TAG: { 4489 const GNUAbiTag &AbiTag = getGNUAbiTag<ELFT>(Desc); 4490 if (!AbiTag.IsValid) { 4491 W.printString("ABI", "<corrupt GNU_ABI_TAG>"); 4492 } else { 4493 W.printString("OS", AbiTag.OSName); 4494 W.printString("ABI", AbiTag.ABI); 4495 } 4496 break; 4497 } 4498 case ELF::NT_GNU_BUILD_ID: { 4499 W.printString("Build ID", getGNUBuildId(Desc)); 4500 break; 4501 } 4502 case ELF::NT_GNU_GOLD_VERSION: 4503 W.printString("Version", getGNUGoldVersion(Desc)); 4504 break; 4505 case ELF::NT_GNU_PROPERTY_TYPE_0: 4506 ListScope D(W, "Property"); 4507 for (const auto &Property : getGNUPropertyList<ELFT>(Desc)) 4508 W.printString(Property); 4509 break; 4510 } 4511 } 4512 4513 template <class ELFT> 4514 void LLVMStyle<ELFT>::printNotes(const ELFFile<ELFT> *Obj) { 4515 ListScope L(W, "Notes"); 4516 const Elf_Ehdr *e = Obj->getHeader(); 4517 bool IsCore = e->e_type == ELF::ET_CORE; 4518 4519 auto PrintHeader = [&](const typename ELFT::Off Offset, 4520 const typename ELFT::Addr Size) { 4521 W.printHex("Offset", Offset); 4522 W.printHex("Size", Size); 4523 }; 4524 4525 auto ProcessNote = [&](const Elf_Note &Note) { 4526 DictScope D2(W, "Note"); 4527 StringRef Name = Note.getName(); 4528 ArrayRef<uint8_t> Descriptor = Note.getDesc(); 4529 Elf_Word Type = Note.getType(); 4530 4531 W.printString("Owner", Name); 4532 W.printHex("Data size", Descriptor.size()); 4533 if (Name == "GNU") { 4534 W.printString("Type", getGNUNoteTypeName(Type)); 4535 printGNUNoteLLVMStyle<ELFT>(Type, Descriptor, W); 4536 } else if (Name == "FreeBSD") { 4537 W.printString("Type", getFreeBSDNoteTypeName(Type)); 4538 } else if (Name == "AMD") { 4539 W.printString("Type", getAMDGPUNoteTypeName(Type)); 4540 const AMDGPUNote N = getAMDGPUNote<ELFT>(Type, Descriptor); 4541 if (!N.type.empty()) 4542 W.printString(N.type, N.value); 4543 } else { 4544 W.getOStream() << "Unknown note type: (" << format_hex(Type, 10) << ')'; 4545 } 4546 }; 4547 4548 if (IsCore) { 4549 for (const auto &P : unwrapOrError(Obj->program_headers())) { 4550 if (P.p_type != PT_NOTE) 4551 continue; 4552 DictScope D(W, "NoteSection"); 4553 PrintHeader(P.p_offset, P.p_filesz); 4554 Error Err = Error::success(); 4555 for (const auto &Note : Obj->notes(P, Err)) 4556 ProcessNote(Note); 4557 if (Err) 4558 error(std::move(Err)); 4559 } 4560 } else { 4561 for (const auto &S : unwrapOrError(Obj->sections())) { 4562 if (S.sh_type != SHT_NOTE) 4563 continue; 4564 DictScope D(W, "NoteSection"); 4565 PrintHeader(S.sh_offset, S.sh_size); 4566 Error Err = Error::success(); 4567 for (const auto &Note : Obj->notes(S, Err)) 4568 ProcessNote(Note); 4569 if (Err) 4570 error(std::move(Err)); 4571 } 4572 } 4573 } 4574 4575 template <class ELFT> 4576 void LLVMStyle<ELFT>::printELFLinkerOptions(const ELFFile<ELFT> *Obj) { 4577 ListScope L(W, "LinkerOptions"); 4578 4579 for (const Elf_Shdr &Shdr : unwrapOrError(Obj->sections())) { 4580 if (Shdr.sh_type != ELF::SHT_LLVM_LINKER_OPTIONS) 4581 continue; 4582 4583 ArrayRef<uint8_t> Contents = unwrapOrError(Obj->getSectionContents(&Shdr)); 4584 for (const uint8_t *P = Contents.begin(), *E = Contents.end(); P < E; ) { 4585 StringRef Key = StringRef(reinterpret_cast<const char *>(P)); 4586 StringRef Value = 4587 StringRef(reinterpret_cast<const char *>(P) + Key.size() + 1); 4588 4589 W.printString(Key, Value); 4590 4591 P = P + Key.size() + Value.size() + 2; 4592 } 4593 } 4594 } 4595 4596 template <class ELFT> 4597 void LLVMStyle<ELFT>::printMipsGOT(const MipsGOTParser<ELFT> &Parser) { 4598 auto PrintEntry = [&](const Elf_Addr *E) { 4599 W.printHex("Address", Parser.getGotAddress(E)); 4600 W.printNumber("Access", Parser.getGotOffset(E)); 4601 W.printHex("Initial", *E); 4602 }; 4603 4604 DictScope GS(W, Parser.IsStatic ? "Static GOT" : "Primary GOT"); 4605 4606 W.printHex("Canonical gp value", Parser.getGp()); 4607 { 4608 ListScope RS(W, "Reserved entries"); 4609 { 4610 DictScope D(W, "Entry"); 4611 PrintEntry(Parser.getGotLazyResolver()); 4612 W.printString("Purpose", StringRef("Lazy resolver")); 4613 } 4614 4615 if (Parser.getGotModulePointer()) { 4616 DictScope D(W, "Entry"); 4617 PrintEntry(Parser.getGotModulePointer()); 4618 W.printString("Purpose", StringRef("Module pointer (GNU extension)")); 4619 } 4620 } 4621 { 4622 ListScope LS(W, "Local entries"); 4623 for (auto &E : Parser.getLocalEntries()) { 4624 DictScope D(W, "Entry"); 4625 PrintEntry(&E); 4626 } 4627 } 4628 4629 if (Parser.IsStatic) 4630 return; 4631 4632 { 4633 ListScope GS(W, "Global entries"); 4634 for (auto &E : Parser.getGlobalEntries()) { 4635 DictScope D(W, "Entry"); 4636 4637 PrintEntry(&E); 4638 4639 const Elf_Sym *Sym = Parser.getGotSym(&E); 4640 W.printHex("Value", Sym->st_value); 4641 W.printEnum("Type", Sym->getType(), makeArrayRef(ElfSymbolTypes)); 4642 4643 unsigned SectionIndex = 0; 4644 StringRef SectionName; 4645 this->dumper()->getSectionNameIndex( 4646 Sym, this->dumper()->dynamic_symbols().begin(), SectionName, 4647 SectionIndex); 4648 W.printHex("Section", SectionName, SectionIndex); 4649 4650 std::string SymName = this->dumper()->getFullSymbolName( 4651 Sym, this->dumper()->getDynamicStringTable(), true); 4652 W.printNumber("Name", SymName, Sym->st_name); 4653 } 4654 } 4655 4656 W.printNumber("Number of TLS and multi-GOT entries", 4657 uint64_t(Parser.getOtherEntries().size())); 4658 } 4659 4660 template <class ELFT> 4661 void LLVMStyle<ELFT>::printMipsPLT(const MipsGOTParser<ELFT> &Parser) { 4662 auto PrintEntry = [&](const Elf_Addr *E) { 4663 W.printHex("Address", Parser.getPltAddress(E)); 4664 W.printHex("Initial", *E); 4665 }; 4666 4667 DictScope GS(W, "PLT GOT"); 4668 4669 { 4670 ListScope RS(W, "Reserved entries"); 4671 { 4672 DictScope D(W, "Entry"); 4673 PrintEntry(Parser.getPltLazyResolver()); 4674 W.printString("Purpose", StringRef("PLT lazy resolver")); 4675 } 4676 4677 if (auto E = Parser.getPltModulePointer()) { 4678 DictScope D(W, "Entry"); 4679 PrintEntry(E); 4680 W.printString("Purpose", StringRef("Module pointer")); 4681 } 4682 } 4683 { 4684 ListScope LS(W, "Entries"); 4685 for (auto &E : Parser.getPltEntries()) { 4686 DictScope D(W, "Entry"); 4687 PrintEntry(&E); 4688 4689 const Elf_Sym *Sym = Parser.getPltSym(&E); 4690 W.printHex("Value", Sym->st_value); 4691 W.printEnum("Type", Sym->getType(), makeArrayRef(ElfSymbolTypes)); 4692 4693 unsigned SectionIndex = 0; 4694 StringRef SectionName; 4695 this->dumper()->getSectionNameIndex( 4696 Sym, this->dumper()->dynamic_symbols().begin(), SectionName, 4697 SectionIndex); 4698 W.printHex("Section", SectionName, SectionIndex); 4699 4700 std::string SymName = 4701 this->dumper()->getFullSymbolName(Sym, Parser.getPltStrTable(), true); 4702 W.printNumber("Name", SymName, Sym->st_name); 4703 } 4704 } 4705 } 4706