diff options
Diffstat (limited to 'llvm/tools')
-rw-r--r-- | llvm/tools/llvm-readobj/COFFDumper.cpp | 15 | ||||
-rw-r--r-- | llvm/tools/llvm-readobj/ObjDumper.h | 3 | ||||
-rw-r--r-- | llvm/tools/llvm-readobj/llvm-readobj.cpp | 6 |
3 files changed, 24 insertions, 0 deletions
diff --git a/llvm/tools/llvm-readobj/COFFDumper.cpp b/llvm/tools/llvm-readobj/COFFDumper.cpp index 3d71d832f99..a3692af41fe 100644 --- a/llvm/tools/llvm-readobj/COFFDumper.cpp +++ b/llvm/tools/llvm-readobj/COFFDumper.cpp @@ -55,6 +55,7 @@ public: void printSymbols() override; void printDynamicSymbols() override; void printUnwindInfo() override; + void printCOFFImports() override; private: void printSymbol(const SymbolRef &Sym); @@ -882,3 +883,17 @@ void COFFDumper::printUnwindInfo() { } } +void COFFDumper::printCOFFImports() { + for (auto I = Obj->import_directory_begin(), E = Obj->import_directory_end(); + I != E; ++I) { + DictScope Import(W, "Import"); + StringRef Name; + if (error(I->getName(Name))) return; + W.printString("Name", Name); + uint32_t Addr; + if (error(I->getImportLookupTableRVA(Addr))) return; + W.printHex("ImportLookupTableRVA", Addr); + if (error(I->getImportAddressTableRVA(Addr))) return; + W.printHex("ImportAddressTableRVA", Addr); + } +} diff --git a/llvm/tools/llvm-readobj/ObjDumper.h b/llvm/tools/llvm-readobj/ObjDumper.h index 7adf76a6946..8f0c171233e 100644 --- a/llvm/tools/llvm-readobj/ObjDumper.h +++ b/llvm/tools/llvm-readobj/ObjDumper.h @@ -43,6 +43,9 @@ public: // Only implemented for MIPS ELF at this time. virtual void printMipsPLTGOT() { } + // Only implemented for PE/COFF. + virtual void printCOFFImports() { } + protected: StreamWriter& W; }; diff --git a/llvm/tools/llvm-readobj/llvm-readobj.cpp b/llvm/tools/llvm-readobj/llvm-readobj.cpp index a20164a3c23..31a011d2b9e 100644 --- a/llvm/tools/llvm-readobj/llvm-readobj.cpp +++ b/llvm/tools/llvm-readobj/llvm-readobj.cpp @@ -141,6 +141,10 @@ namespace opts { cl::opt<bool> MipsPLTGOT("mips-plt-got", cl::desc("Display the MIPS GOT and PLT GOT sections")); + + // -coff-imports + cl::opt<bool> + COFFImports("coff-imports", cl::desc("Display the PE/COFF import table")); } // namespace opts static int ReturnValue = EXIT_SUCCESS; @@ -266,6 +270,8 @@ static void dumpObject(const ObjectFile *Obj) { if (isMipsArch(Obj->getArch()) && Obj->isELF()) if (opts::MipsPLTGOT) Dumper->printMipsPLTGOT(); + if (opts::COFFImports) + Dumper->printCOFFImports(); } |