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