147
|
1 //===- tools/dsymutil/DwarfStreamer.h - Dwarf Streamer ----------*- C++ -*-===//
|
|
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 #ifndef LLVM_TOOLS_DSYMUTIL_DWARFSTREAMER_H
|
|
10 #define LLVM_TOOLS_DSYMUTIL_DWARFSTREAMER_H
|
|
11
|
|
12 #include "CompileUnit.h"
|
|
13 #include "DebugMap.h"
|
|
14 #include "LinkUtils.h"
|
|
15 #include "NonRelocatableStringpool.h"
|
|
16 #include "llvm/CodeGen/AccelTable.h"
|
|
17 #include "llvm/CodeGen/AsmPrinter.h"
|
|
18 #include "llvm/DebugInfo/DWARF/DWARFDebugLine.h"
|
|
19 #include "llvm/DebugInfo/DWARF/DWARFDebugRangeList.h"
|
|
20 #include "llvm/MC/MCAsmBackend.h"
|
|
21 #include "llvm/MC/MCAsmInfo.h"
|
|
22 #include "llvm/MC/MCCodeEmitter.h"
|
|
23 #include "llvm/MC/MCContext.h"
|
|
24 #include "llvm/MC/MCDwarf.h"
|
|
25 #include "llvm/MC/MCInstrInfo.h"
|
|
26 #include "llvm/MC/MCObjectFileInfo.h"
|
|
27 #include "llvm/MC/MCObjectWriter.h"
|
|
28 #include "llvm/MC/MCRegisterInfo.h"
|
|
29 #include "llvm/MC/MCSection.h"
|
|
30 #include "llvm/MC/MCStreamer.h"
|
|
31 #include "llvm/MC/MCSubtargetInfo.h"
|
|
32 #include "llvm/MC/MCSymbol.h"
|
|
33 #include "llvm/MC/MCTargetOptions.h"
|
|
34 #include "llvm/Target/TargetMachine.h"
|
|
35 #include "llvm/Target/TargetOptions.h"
|
|
36
|
|
37 namespace llvm {
|
|
38 namespace dsymutil {
|
|
39
|
|
40 /// The Dwarf streaming logic.
|
|
41 ///
|
|
42 /// All interactions with the MC layer that is used to build the debug
|
|
43 /// information binary representation are handled in this class.
|
|
44 class DwarfStreamer {
|
|
45 public:
|
|
46 DwarfStreamer(raw_fd_ostream &OutFile, LinkOptions Options)
|
|
47 : OutFile(OutFile), Options(std::move(Options)) {}
|
|
48
|
|
49 bool init(Triple TheTriple);
|
|
50
|
|
51 /// Dump the file to the disk.
|
|
52 bool finish(const DebugMap &, SymbolMapTranslator &T);
|
|
53
|
|
54 AsmPrinter &getAsmPrinter() const { return *Asm; }
|
|
55
|
|
56 /// Set the current output section to debug_info and change
|
|
57 /// the MC Dwarf version to \p DwarfVersion.
|
|
58 void switchToDebugInfoSection(unsigned DwarfVersion);
|
|
59
|
|
60 /// Emit the compilation unit header for \p Unit in the
|
|
61 /// debug_info section.
|
|
62 ///
|
|
63 /// As a side effect, this also switches the current Dwarf version
|
|
64 /// of the MC layer to the one of U.getOrigUnit().
|
|
65 void emitCompileUnitHeader(CompileUnit &Unit);
|
|
66
|
|
67 /// Recursively emit the DIE tree rooted at \p Die.
|
|
68 void emitDIE(DIE &Die);
|
|
69
|
|
70 /// Emit the abbreviation table \p Abbrevs to the debug_abbrev section.
|
|
71 void emitAbbrevs(const std::vector<std::unique_ptr<DIEAbbrev>> &Abbrevs,
|
|
72 unsigned DwarfVersion);
|
|
73
|
|
74 /// Emit the string table described by \p Pool.
|
|
75 void emitStrings(const NonRelocatableStringpool &Pool);
|
|
76
|
|
77 /// Emit the swift_ast section stored in \p Buffer.
|
|
78 void emitSwiftAST(StringRef Buffer);
|
|
79
|
|
80 /// Emit debug_ranges for \p FuncRange by translating the
|
|
81 /// original \p Entries.
|
|
82 void emitRangesEntries(
|
|
83 int64_t UnitPcOffset, uint64_t OrigLowPc,
|
|
84 const FunctionIntervals::const_iterator &FuncRange,
|
|
85 const std::vector<DWARFDebugRangeList::RangeListEntry> &Entries,
|
|
86 unsigned AddressSize);
|
|
87
|
|
88 /// Emit debug_aranges entries for \p Unit and if \p DoRangesSection is true,
|
|
89 /// also emit the debug_ranges entries for the DW_TAG_compile_unit's
|
|
90 /// DW_AT_ranges attribute.
|
|
91 void emitUnitRangesEntries(CompileUnit &Unit, bool DoRangesSection);
|
|
92
|
|
93 uint32_t getRangesSectionSize() const { return RangesSectionSize; }
|
|
94
|
|
95 /// Emit the debug_loc contribution for \p Unit by copying the entries from
|
|
96 /// \p Dwarf and offsetting them. Update the location attributes to point to
|
|
97 /// the new entries.
|
|
98 void emitLocationsForUnit(
|
|
99 const CompileUnit &Unit, DWARFContext &Dwarf,
|
|
100 std::function<void(StringRef, SmallVectorImpl<uint8_t> &)> ProcessExpr);
|
|
101
|
|
102 /// Emit the line table described in \p Rows into the debug_line section.
|
|
103 void emitLineTableForUnit(MCDwarfLineTableParams Params,
|
|
104 StringRef PrologueBytes, unsigned MinInstLength,
|
|
105 std::vector<DWARFDebugLine::Row> &Rows,
|
|
106 unsigned AdddressSize);
|
|
107
|
|
108 /// Copy the debug_line over to the updated binary while unobfuscating the
|
|
109 /// file names and directories.
|
|
110 void translateLineTable(DataExtractor LineData, uint64_t Offset);
|
|
111
|
|
112 /// Copy over the debug sections that are not modified when updating.
|
|
113 void copyInvariantDebugSection(const object::ObjectFile &Obj);
|
|
114
|
|
115 uint64_t getLineSectionSize() const { return LineSectionSize; }
|
|
116
|
|
117 /// Emit the .debug_pubnames contribution for \p Unit.
|
|
118 void emitPubNamesForUnit(const CompileUnit &Unit);
|
|
119
|
|
120 /// Emit the .debug_pubtypes contribution for \p Unit.
|
|
121 void emitPubTypesForUnit(const CompileUnit &Unit);
|
|
122
|
|
123 /// Emit a CIE.
|
|
124 void emitCIE(StringRef CIEBytes);
|
|
125
|
|
126 /// Emit an FDE with data \p Bytes.
|
|
127 void emitFDE(uint32_t CIEOffset, uint32_t AddreSize, uint32_t Address,
|
|
128 StringRef Bytes);
|
|
129
|
|
130 /// Emit DWARF debug names.
|
|
131 void emitDebugNames(AccelTable<DWARF5AccelTableStaticData> &Table);
|
|
132
|
|
133 /// Emit Apple namespaces accelerator table.
|
|
134 void emitAppleNamespaces(AccelTable<AppleAccelTableStaticOffsetData> &Table);
|
|
135
|
|
136 /// Emit Apple names accelerator table.
|
|
137 void emitAppleNames(AccelTable<AppleAccelTableStaticOffsetData> &Table);
|
|
138
|
|
139 /// Emit Apple Objective-C accelerator table.
|
|
140 void emitAppleObjc(AccelTable<AppleAccelTableStaticOffsetData> &Table);
|
|
141
|
|
142 /// Emit Apple type accelerator table.
|
|
143 void emitAppleTypes(AccelTable<AppleAccelTableStaticTypeData> &Table);
|
|
144
|
|
145 uint32_t getFrameSectionSize() const { return FrameSectionSize; }
|
|
146
|
|
147 private:
|
|
148 /// \defgroup MCObjects MC layer objects constructed by the streamer
|
|
149 /// @{
|
|
150 std::unique_ptr<MCRegisterInfo> MRI;
|
|
151 std::unique_ptr<MCAsmInfo> MAI;
|
|
152 std::unique_ptr<MCObjectFileInfo> MOFI;
|
|
153 std::unique_ptr<MCContext> MC;
|
|
154 MCAsmBackend *MAB; // Owned by MCStreamer
|
|
155 std::unique_ptr<MCInstrInfo> MII;
|
|
156 std::unique_ptr<MCSubtargetInfo> MSTI;
|
|
157 MCInstPrinter *MIP; // Owned by AsmPrinter
|
|
158 MCCodeEmitter *MCE; // Owned by MCStreamer
|
|
159 MCStreamer *MS; // Owned by AsmPrinter
|
|
160 std::unique_ptr<TargetMachine> TM;
|
|
161 std::unique_ptr<AsmPrinter> Asm;
|
|
162 /// @}
|
|
163
|
|
164 /// The file we stream the linked Dwarf to.
|
|
165 raw_fd_ostream &OutFile;
|
|
166
|
|
167 LinkOptions Options;
|
|
168
|
|
169 uint32_t RangesSectionSize;
|
|
170 uint32_t LocSectionSize;
|
|
171 uint64_t LineSectionSize;
|
|
172 uint32_t FrameSectionSize;
|
|
173
|
|
174 /// Keep track of emitted CUs and their Unique ID.
|
|
175 struct EmittedUnit {
|
|
176 unsigned ID;
|
|
177 MCSymbol *LabelBegin;
|
|
178 };
|
|
179 std::vector<EmittedUnit> EmittedUnits;
|
|
180
|
|
181 /// Emit the pubnames or pubtypes section contribution for \p
|
|
182 /// Unit into \p Sec. The data is provided in \p Names.
|
|
183 void emitPubSectionForUnit(MCSection *Sec, StringRef Name,
|
|
184 const CompileUnit &Unit,
|
|
185 const std::vector<CompileUnit::AccelInfo> &Names);
|
|
186 };
|
|
187
|
|
188 } // end namespace dsymutil
|
|
189 } // end namespace llvm
|
|
190
|
|
191 #endif // LLVM_TOOLS_DSYMUTIL_DWARFSTREAMER_H
|