1 //===-- ObjDumper.h ---------------------------------------------*- C++ -*-===//
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
7 //===----------------------------------------------------------------------===//
9 #ifndef LLVM_TOOLS_LLVM_READOBJ_OBJDUMPER_H
10 #define LLVM_TOOLS_LLVM_READOBJ_OBJDUMPER_H
14 #include <system_error>
16 #include "llvm/ADT/SmallVector.h"
17 #include "llvm/ADT/StringRef.h"
18 #include "llvm/Object/ObjectFile.h"
19 #include "llvm/Support/CommandLine.h"
21 #include <unordered_set>
28 class XCOFFObjectFile
;
29 class ELFObjectFileBase
;
32 class GlobalTypeTableBuilder
;
33 class MergingTypeTableBuilder
;
34 } // namespace codeview
38 // Comparator to compare symbols.
39 // Usage: the caller registers predicates (i.e., how to compare the symbols) by
40 // calling addPredicate(). The order in which predicates are registered is also
42 class SymbolComparator
{
45 std::function
<bool(object::SymbolRef
, object::SymbolRef
)>;
47 // Each Obj format has a slightly different way of retrieving a symbol's info
48 // So we defer the predicate's impl to each format.
49 void addPredicate(CompPredicate Pred
) { Predicates
.push_back(Pred
); }
51 bool operator()(object::SymbolRef LHS
, object::SymbolRef RHS
) {
52 for (CompPredicate Pred
: Predicates
) {
62 SmallVector
<CompPredicate
, 2> Predicates
;
67 ObjDumper(ScopedPrinter
&Writer
, StringRef ObjName
);
70 virtual bool canDumpContent() { return true; }
72 virtual void printFileSummary(StringRef FileStr
, object::ObjectFile
&Obj
,
73 ArrayRef
<std::string
> InputFilenames
,
74 const object::Archive
*A
);
75 virtual void printFileHeaders() = 0;
76 virtual void printSectionHeaders() = 0;
77 virtual void printRelocations() = 0;
78 virtual void printSymbols(bool PrintSymbols
, bool PrintDynamicSymbols
,
81 printSymbols(ExtraSymInfo
);
82 if (PrintDynamicSymbols
)
83 printDynamicSymbols();
85 virtual void printSymbols(bool PrintSymbols
, bool PrintDynamicSymbols
,
87 std::optional
<SymbolComparator
> SymComp
) {
90 printSymbols(SymComp
);
91 if (PrintDynamicSymbols
)
92 printDynamicSymbols(SymComp
);
94 printSymbols(PrintSymbols
, PrintDynamicSymbols
, ExtraSymInfo
);
97 virtual void printProgramHeaders(bool PrintProgramHeaders
,
98 cl::boolOrDefault PrintSectionMapping
) {
99 if (PrintProgramHeaders
)
100 printProgramHeaders();
101 if (PrintSectionMapping
== cl::BOU_TRUE
)
102 printSectionMapping();
105 virtual void printUnwindInfo() = 0;
107 // Symbol comparison functions.
108 virtual bool canCompareSymbols() const { return false; }
109 virtual bool compareSymbolsByName(object::SymbolRef LHS
,
110 object::SymbolRef RHS
) const {
113 virtual bool compareSymbolsByType(object::SymbolRef LHS
,
114 object::SymbolRef RHS
) const {
118 // Only implemented for ELF at this time.
119 virtual void printDependentLibs() {}
120 virtual void printDynamicRelocations() { }
121 virtual void printDynamicTable() { }
122 virtual void printNeededLibraries() { }
123 virtual void printSectionAsHex(StringRef SectionName
) {}
124 virtual void printHashTable() { }
125 virtual void printGnuHashTable() {}
126 virtual void printHashSymbols() {}
127 virtual void printLoadName() {}
128 virtual void printVersionInfo() {}
129 virtual void printGroupSections() {}
130 virtual void printHashHistograms() {}
131 virtual void printCGProfile() {}
132 // If PrettyPGOAnalysis is true, prints BFI as relative frequency and BPI as
133 // percentage. Otherwise raw values are displayed.
134 virtual void printBBAddrMaps(bool PrettyPGOAnalysis
) {}
135 virtual void printAddrsig() {}
136 virtual void printNotes() {}
137 virtual void printELFLinkerOptions() {}
138 virtual void printStackSizes() {}
139 virtual void printSectionDetails() {}
140 virtual void printArchSpecificInfo() {}
141 virtual void printMemtag() {}
143 // Only implemented for PE/COFF.
144 virtual void printCOFFImports() { }
145 virtual void printCOFFExports() { }
146 virtual void printCOFFDirectives() { }
147 virtual void printCOFFBaseReloc() { }
148 virtual void printCOFFDebugDirectory() { }
149 virtual void printCOFFTLSDirectory() {}
150 virtual void printCOFFResources() {}
151 virtual void printCOFFLoadConfig() { }
152 virtual void printCodeViewDebugInfo() { }
154 mergeCodeViewTypes(llvm::codeview::MergingTypeTableBuilder
&CVIDs
,
155 llvm::codeview::MergingTypeTableBuilder
&CVTypes
,
156 llvm::codeview::GlobalTypeTableBuilder
&GlobalCVIDs
,
157 llvm::codeview::GlobalTypeTableBuilder
&GlobalCVTypes
,
160 // Only implemented for XCOFF.
161 virtual void printStringTable() {}
162 virtual void printAuxiliaryHeader() {}
163 virtual void printExceptionSection() {}
164 virtual void printLoaderSection(bool PrintHeader
, bool PrintSymbols
,
165 bool PrintRelocations
) {}
167 // Only implemented for MachO.
168 virtual void printMachODataInCode() { }
169 virtual void printMachOVersionMin() { }
170 virtual void printMachODysymtab() { }
171 virtual void printMachOSegment() { }
172 virtual void printMachOIndirectSymbols() { }
173 virtual void printMachOLinkerOptions() { }
175 virtual void printStackMap() const = 0;
177 void printAsStringList(StringRef StringContent
, size_t StringDataOffset
= 0);
179 void printSectionsAsString(const object::ObjectFile
&Obj
,
180 ArrayRef
<std::string
> Sections
, bool Decompress
);
181 void printSectionsAsHex(const object::ObjectFile
&Obj
,
182 ArrayRef
<std::string
> Sections
, bool Decompress
);
184 std::function
<Error(const Twine
&Msg
)> WarningHandler
;
185 void reportUniqueWarning(Error Err
) const;
186 void reportUniqueWarning(const Twine
&Msg
) const;
192 virtual void printSymbols(bool ExtraSymInfo
) {}
193 virtual void printSymbols(std::optional
<SymbolComparator
> Comp
) {}
194 virtual void printDynamicSymbols() {}
195 virtual void printDynamicSymbols(std::optional
<SymbolComparator
> Comp
) {}
196 virtual void printProgramHeaders() {}
197 virtual void printSectionMapping() {}
199 std::unordered_set
<std::string
> Warnings
;
202 std::unique_ptr
<ObjDumper
> createCOFFDumper(const object::COFFObjectFile
&Obj
,
203 ScopedPrinter
&Writer
);
205 std::unique_ptr
<ObjDumper
> createELFDumper(const object::ELFObjectFileBase
&Obj
,
206 ScopedPrinter
&Writer
);
208 std::unique_ptr
<ObjDumper
> createMachODumper(const object::MachOObjectFile
&Obj
,
209 ScopedPrinter
&Writer
);
211 std::unique_ptr
<ObjDumper
> createWasmDumper(const object::WasmObjectFile
&Obj
,
212 ScopedPrinter
&Writer
);
214 std::unique_ptr
<ObjDumper
> createXCOFFDumper(const object::XCOFFObjectFile
&Obj
,
215 ScopedPrinter
&Writer
);
217 void dumpCOFFImportFile(const object::COFFImportFile
*File
,
218 ScopedPrinter
&Writer
);
220 void dumpCodeViewMergedTypes(ScopedPrinter
&Writer
,
221 ArrayRef
<ArrayRef
<uint8_t>> IpiRecords
,
222 ArrayRef
<ArrayRef
<uint8_t>> TpiRecords
);