blob: 71ea0fb4e72b17fe9306d5f29bc33204cf1196c1 [file] [log] [blame]
Bill Wendling2f921f82009-05-15 09:23:25 +00001//===-- llvm/CodeGen/DwarfDebug.h - Dwarf Debug Framework ------*- C++ -*--===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file contains support for writing dwarf debug info into asm files.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef CODEGEN_ASMPRINTER_DWARFDEBUG_H__
15#define CODEGEN_ASMPRINTER_DWARFDEBUG_H__
16
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +000017#include "AsmPrinterHandler.h"
Bill Wendlinge38859d2012-06-28 00:05:13 +000018#include "DIE.h"
Devang Patel018b29b2010-01-19 06:19:05 +000019#include "llvm/ADT/DenseMap.h"
Eric Christopheracbe42b2014-03-18 20:58:35 +000020#include "llvm/ADT/MapVector.h"
21#include "llvm/ADT/SmallPtrSet.h"
22#include "llvm/ADT/StringMap.h"
Bill Wendling2f921f82009-05-15 09:23:25 +000023#include "llvm/ADT/FoldingSet.h"
Chandler Carruth802d7552012-12-04 07:12:27 +000024#include "llvm/CodeGen/LexicalScopes.h"
Chandler Carruth9a4c9e52014-03-06 00:46:21 +000025#include "llvm/IR/DebugInfo.h"
Eric Christopheracbe42b2014-03-18 20:58:35 +000026#include "llvm/IR/DebugLoc.h"
Chandler Carruth802d7552012-12-04 07:12:27 +000027#include "llvm/MC/MachineLocation.h"
David Blaikie4a2f95f2014-03-18 01:17:26 +000028#include "llvm/MC/MCDwarf.h"
Chris Lattner3f3fb972010-04-05 05:24:55 +000029#include "llvm/Support/Allocator.h"
Bill Wendling2f921f82009-05-15 09:23:25 +000030
31namespace llvm {
32
Adrian Prantl702bf5a2014-03-18 02:34:52 +000033class AsmPrinter;
Eric Christopher29e874d2014-03-07 22:40:37 +000034class ByteStreamer;
Chris Lattner88fce102012-01-26 20:44:57 +000035class ConstantInt;
36class ConstantFP;
Eric Christopherce4a9442014-03-18 20:37:10 +000037class DwarfCompileUnit;
38class DwarfDebug;
39class DwarfTypeUnit;
40class DwarfUnit;
Bill Wendling2f921f82009-05-15 09:23:25 +000041class MachineModuleInfo;
Bill Wendling2f921f82009-05-15 09:23:25 +000042
43//===----------------------------------------------------------------------===//
Eric Christopheracdcbdb2012-11-27 22:43:45 +000044/// \brief This class is used to record source line correspondence.
Benjamin Kramer079b96e2013-09-11 18:05:11 +000045class SrcLineInfo {
Eric Christophera5a79422013-12-09 23:32:48 +000046 unsigned Line; // Source line number.
47 unsigned Column; // Source column.
48 unsigned SourceID; // Source ID number.
49 MCSymbol *Label; // Label in code ID number.
Bill Wendling2f921f82009-05-15 09:23:25 +000050public:
Chris Lattnerb4666f42010-03-14 08:15:55 +000051 SrcLineInfo(unsigned L, unsigned C, unsigned S, MCSymbol *label)
Eric Christophera5a79422013-12-09 23:32:48 +000052 : Line(L), Column(C), SourceID(S), Label(label) {}
Bill Wendling2f921f82009-05-15 09:23:25 +000053
54 // Accessors
55 unsigned getLine() const { return Line; }
56 unsigned getColumn() const { return Column; }
57 unsigned getSourceID() const { return SourceID; }
Chris Lattnerb4666f42010-03-14 08:15:55 +000058 MCSymbol *getLabel() const { return Label; }
Bill Wendling2f921f82009-05-15 09:23:25 +000059};
60
Eric Christopheracdcbdb2012-11-27 22:43:45 +000061/// \brief This struct describes location entries emitted in the .debug_loc
62/// section.
Eric Christopher05135fb2014-03-18 02:18:24 +000063class DebugLocEntry {
Eric Christopher25f06422013-07-03 22:40:18 +000064 // Begin and end symbols for the address range that this location is valid.
Devang Patel116a9d72011-02-04 22:57:18 +000065 const MCSymbol *Begin;
66 const MCSymbol *End;
Eric Christopher25f06422013-07-03 22:40:18 +000067
68 // Type of entry that this represents.
Eric Christopher05135fb2014-03-18 02:18:24 +000069 enum EntryType { E_Location, E_Integer, E_ConstantFP, E_ConstantInt };
Devang Pateled9fd452011-07-08 16:49:43 +000070 enum EntryType EntryKind;
71
72 union {
73 int64_t Int;
74 const ConstantFP *CFP;
75 const ConstantInt *CIP;
76 } Constants;
Eric Christopher25f06422013-07-03 22:40:18 +000077
78 // The location in the machine frame.
79 MachineLocation Loc;
80
81 // The variable to which this location entry corresponds.
82 const MDNode *Variable;
83
Eric Christopher384f3fe2014-03-20 19:16:16 +000084 // The compile unit to which this location entry is referenced by.
85 const DwarfCompileUnit *Unit;
86
Eric Christopher25f06422013-07-03 22:40:18 +000087 // Whether this location has been merged.
88 bool Merged;
89
90public:
Eric Christopher384f3fe2014-03-20 19:16:16 +000091 DebugLocEntry() : Begin(0), End(0), Variable(0), Unit(0), Merged(false) {
Eric Christopher98341b8d2013-07-03 08:26:07 +000092 Constants.Int = 0;
93 }
Eric Christopher05135fb2014-03-18 02:18:24 +000094 DebugLocEntry(const MCSymbol *B, const MCSymbol *E, MachineLocation &L,
Eric Christopher384f3fe2014-03-20 19:16:16 +000095 const MDNode *V, const DwarfCompileUnit *U)
96 : Begin(B), End(E), Loc(L), Variable(V), Unit(U), Merged(false) {
Eric Christopher98341b8d2013-07-03 08:26:07 +000097 Constants.Int = 0;
98 EntryKind = E_Location;
99 }
Eric Christopher384f3fe2014-03-20 19:16:16 +0000100 DebugLocEntry(const MCSymbol *B, const MCSymbol *E, int64_t i,
101 const DwarfCompileUnit *U)
102 : Begin(B), End(E), Variable(0), Unit(U), Merged(false) {
Eric Christopher98341b8d2013-07-03 08:26:07 +0000103 Constants.Int = i;
104 EntryKind = E_Integer;
105 }
Eric Christopher384f3fe2014-03-20 19:16:16 +0000106 DebugLocEntry(const MCSymbol *B, const MCSymbol *E, const ConstantFP *FPtr,
107 const DwarfCompileUnit *U)
108 : Begin(B), End(E), Variable(0), Unit(U), Merged(false) {
Eric Christopher98341b8d2013-07-03 08:26:07 +0000109 Constants.CFP = FPtr;
110 EntryKind = E_ConstantFP;
111 }
Eric Christopher384f3fe2014-03-20 19:16:16 +0000112 DebugLocEntry(const MCSymbol *B, const MCSymbol *E, const ConstantInt *IPtr,
113 const DwarfCompileUnit *U)
114 : Begin(B), End(E), Variable(0), Unit(U), Merged(false) {
Eric Christopher98341b8d2013-07-03 08:26:07 +0000115 Constants.CIP = IPtr;
116 EntryKind = E_ConstantInt;
117 }
Devang Patel324f8432011-06-01 22:03:25 +0000118
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000119 /// \brief Empty entries are also used as a trigger to emit temp label. Such
Devang Patel116a9d72011-02-04 22:57:18 +0000120 /// labels are referenced is used to find debug_loc offset for a given DIE.
Eric Christophereeb51952014-03-06 19:51:16 +0000121 bool isEmpty() const { return Begin == 0 && End == 0; }
122 bool isMerged() const { return Merged; }
Eric Christopher05135fb2014-03-18 02:18:24 +0000123 void Merge(DebugLocEntry *Next) {
Devang Patel116a9d72011-02-04 22:57:18 +0000124 if (!(Begin && Loc == Next->Loc && End == Next->Begin))
125 return;
126 Next->Begin = Begin;
127 Merged = true;
128 }
Eric Christophera5a79422013-12-09 23:32:48 +0000129 bool isLocation() const { return EntryKind == E_Location; }
130 bool isInt() const { return EntryKind == E_Integer; }
131 bool isConstantFP() const { return EntryKind == E_ConstantFP; }
Devang Pateled9fd452011-07-08 16:49:43 +0000132 bool isConstantInt() const { return EntryKind == E_ConstantInt; }
Eric Christophera5a79422013-12-09 23:32:48 +0000133 int64_t getInt() const { return Constants.Int; }
134 const ConstantFP *getConstantFP() const { return Constants.CFP; }
Eric Christopherc665af72013-07-03 08:13:55 +0000135 const ConstantInt *getConstantInt() const { return Constants.CIP; }
Eric Christopher25f06422013-07-03 22:40:18 +0000136 const MDNode *getVariable() const { return Variable; }
137 const MCSymbol *getBeginSym() const { return Begin; }
138 const MCSymbol *getEndSym() const { return End; }
Eric Christopher384f3fe2014-03-20 19:16:16 +0000139 const DwarfCompileUnit *getCU() const { return Unit; }
Eric Christopher25f06422013-07-03 22:40:18 +0000140 MachineLocation getLoc() const { return Loc; }
141};
Devang Patel116a9d72011-02-04 22:57:18 +0000142
Devang Patelf20c4f72011-04-12 22:53:02 +0000143//===----------------------------------------------------------------------===//
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000144/// \brief This class is used to track local variable information.
Benjamin Kramer079b96e2013-09-11 18:05:11 +0000145class DbgVariable {
Eric Christophera5a79422013-12-09 23:32:48 +0000146 DIVariable Var; // Variable Descriptor.
147 DIE *TheDIE; // Variable DIE.
148 unsigned DotDebugLocOffset; // Offset in DotDebugLocEntries.
149 DbgVariable *AbsVar; // Corresponding Abstract variable, if any.
150 const MachineInstr *MInsn; // DBG_VALUE instruction of the variable.
Devang Patel3e4a9652011-08-15 21:24:36 +0000151 int FrameIndex;
Manman Renb3388602013-10-05 01:43:03 +0000152 DwarfDebug *DD;
Eric Christophera5a79422013-12-09 23:32:48 +0000153
Devang Patelf20c4f72011-04-12 22:53:02 +0000154public:
155 // AbsVar may be NULL.
Manman Renb3388602013-10-05 01:43:03 +0000156 DbgVariable(DIVariable V, DbgVariable *AV, DwarfDebug *DD)
Eric Christophera5a79422013-12-09 23:32:48 +0000157 : Var(V), TheDIE(0), DotDebugLocOffset(~0U), AbsVar(AV), MInsn(0),
158 FrameIndex(~0), DD(DD) {}
Devang Patelf20c4f72011-04-12 22:53:02 +0000159
160 // Accessors.
Eric Christophera5a79422013-12-09 23:32:48 +0000161 DIVariable getVariable() const { return Var; }
162 void setDIE(DIE *D) { TheDIE = D; }
163 DIE *getDIE() const { return TheDIE; }
164 void setDotDebugLocOffset(unsigned O) { DotDebugLocOffset = O; }
165 unsigned getDotDebugLocOffset() const { return DotDebugLocOffset; }
166 StringRef getName() const { return Var.getName(); }
Devang Patel99819b52011-08-15 19:01:20 +0000167 DbgVariable *getAbstractVariable() const { return AbsVar; }
Eric Christophera5a79422013-12-09 23:32:48 +0000168 const MachineInstr *getMInsn() const { return MInsn; }
169 void setMInsn(const MachineInstr *M) { MInsn = M; }
170 int getFrameIndex() const { return FrameIndex; }
171 void setFrameIndex(int FI) { FrameIndex = FI; }
Eric Christopher27527b22012-11-21 00:03:28 +0000172 // Translate tag to proper Dwarf tag.
Eric Christophera5a79422013-12-09 23:32:48 +0000173 uint16_t getTag() const {
Devang Patel6e4d2c92011-08-15 18:35:42 +0000174 if (Var.getTag() == dwarf::DW_TAG_arg_variable)
175 return dwarf::DW_TAG_formal_parameter;
Eric Christopher27527b22012-11-21 00:03:28 +0000176
Devang Patel6e4d2c92011-08-15 18:35:42 +0000177 return dwarf::DW_TAG_variable;
178 }
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000179 /// \brief Return true if DbgVariable is artificial.
Eric Christophera5a79422013-12-09 23:32:48 +0000180 bool isArtificial() const {
Devang Pateld7d80aa2011-08-15 18:40:16 +0000181 if (Var.isArtificial())
182 return true;
Eric Christopherc1c8a1b2012-09-21 22:18:52 +0000183 if (getType().isArtificial())
Devang Pateld7d80aa2011-08-15 18:40:16 +0000184 return true;
185 return false;
186 }
Eric Christophere3417762012-09-12 23:36:19 +0000187
Eric Christophera5a79422013-12-09 23:32:48 +0000188 bool isObjectPointer() const {
Eric Christophere3417762012-09-12 23:36:19 +0000189 if (Var.isObjectPointer())
190 return true;
Eric Christopherc1c8a1b2012-09-21 22:18:52 +0000191 if (getType().isObjectPointer())
Eric Christophere3417762012-09-12 23:36:19 +0000192 return true;
193 return false;
194 }
Eric Christopher27527b22012-11-21 00:03:28 +0000195
Eric Christophera5a79422013-12-09 23:32:48 +0000196 bool variableHasComplexAddress() const {
Manman Ren7504ed42013-07-08 18:33:29 +0000197 assert(Var.isVariable() && "Invalid complex DbgVariable!");
Devang Patelf20c4f72011-04-12 22:53:02 +0000198 return Var.hasComplexAddress();
199 }
Adrian Prantl1a1647c2014-03-18 02:34:58 +0000200 bool isBlockByrefVariable() const;
Eric Christophera5a79422013-12-09 23:32:48 +0000201 unsigned getNumAddrElements() const {
Manman Ren7504ed42013-07-08 18:33:29 +0000202 assert(Var.isVariable() && "Invalid complex DbgVariable!");
Devang Patelf20c4f72011-04-12 22:53:02 +0000203 return Var.getNumAddrElements();
204 }
Eric Christophera5a79422013-12-09 23:32:48 +0000205 uint64_t getAddrElement(unsigned i) const { return Var.getAddrElement(i); }
Devang Patelf20c4f72011-04-12 22:53:02 +0000206 DIType getType() const;
Manman Renbe5576f2013-10-08 19:07:44 +0000207
208private:
209 /// resolve - Look in the DwarfDebug map for the MDNode that
210 /// corresponds to the reference.
211 template <typename T> T resolve(DIRef<T> Ref) const;
Devang Patelf20c4f72011-04-12 22:53:02 +0000212};
213
Eric Christopherc8a310e2012-12-10 23:34:43 +0000214/// \brief Collects and handles information specific to a particular
Eric Christopherf8194852013-12-05 18:06:10 +0000215/// collection of units. This collection represents all of the units
216/// that will be ultimately output into a single object file.
217class DwarfFile {
Eric Christopherc8a310e2012-12-10 23:34:43 +0000218 // Target of Dwarf emission, used for sizing of abbreviations.
219 AsmPrinter *Asm;
220
221 // Used to uniquely define abbreviations.
David Blaikie0504cda2013-12-05 07:43:55 +0000222 FoldingSet<DIEAbbrev> AbbreviationsSet;
Eric Christopherc8a310e2012-12-10 23:34:43 +0000223
224 // A list of all the unique abbreviations in use.
David Blaikie0504cda2013-12-05 07:43:55 +0000225 std::vector<DIEAbbrev *> Abbreviations;
Eric Christopherc8a310e2012-12-10 23:34:43 +0000226
227 // A pointer to all units in the section.
Eric Christophera5a79422013-12-09 23:32:48 +0000228 SmallVector<DwarfUnit *, 1> CUs;
Eric Christopherc8a310e2012-12-10 23:34:43 +0000229
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000230 // Collection of strings for this unit and assorted symbols.
Eric Christopher18cf0612013-07-03 20:36:36 +0000231 // A String->Symbol mapping of strings used by indirect
232 // references.
Eric Christophera5a79422013-12-09 23:32:48 +0000233 typedef StringMap<std::pair<MCSymbol *, unsigned>, BumpPtrAllocator &>
234 StrPool;
Eric Christopher27614582013-01-08 22:22:06 +0000235 StrPool StringPool;
Eric Christophere698f532012-12-20 21:58:36 +0000236 unsigned NextStringPoolNumber;
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000237 std::string StringPref;
Eric Christophere698f532012-12-20 21:58:36 +0000238
David Blaikief1a6dea2014-02-15 19:34:03 +0000239 struct AddressPoolEntry {
240 unsigned Number;
241 bool TLS;
242 AddressPoolEntry(unsigned Number, bool TLS) : Number(Number), TLS(TLS) {}
243 };
Eric Christopher962c9082013-01-15 23:56:56 +0000244 // Collection of addresses for this unit and assorted labels.
Eric Christopher18cf0612013-07-03 20:36:36 +0000245 // A Symbol->unsigned mapping of addresses used by indirect
246 // references.
David Blaikief1a6dea2014-02-15 19:34:03 +0000247 typedef DenseMap<const MCSymbol *, AddressPoolEntry> AddrPool;
Eric Christopher962c9082013-01-15 23:56:56 +0000248 AddrPool AddressPool;
249 unsigned NextAddrPoolNumber;
250
Eric Christopherc8a310e2012-12-10 23:34:43 +0000251public:
Eric Christopherf8194852013-12-05 18:06:10 +0000252 DwarfFile(AsmPrinter *AP, const char *Pref, BumpPtrAllocator &DA)
David Blaikie0504cda2013-12-05 07:43:55 +0000253 : Asm(AP), StringPool(DA), NextStringPoolNumber(0), StringPref(Pref),
254 AddressPool(), NextAddrPoolNumber(0) {}
Eric Christopherc8a310e2012-12-10 23:34:43 +0000255
Eric Christopherf8194852013-12-05 18:06:10 +0000256 ~DwarfFile();
David Blaikie72f1a3e2013-11-23 01:17:34 +0000257
Eric Christophera5a79422013-12-09 23:32:48 +0000258 const SmallVectorImpl<DwarfUnit *> &getUnits() { return CUs; }
David Blaikiefd1eff52013-11-26 19:14:34 +0000259
Eric Christopherc8a310e2012-12-10 23:34:43 +0000260 /// \brief Compute the size and offset of a DIE given an incoming Offset.
261 unsigned computeSizeAndOffset(DIE *Die, unsigned Offset);
262
263 /// \brief Compute the size and offset of all the DIEs.
264 void computeSizeAndOffsets();
265
266 /// \brief Define a unique number for the abbreviation.
267 void assignAbbrevNumber(DIEAbbrev &Abbrev);
268
269 /// \brief Add a unit to the list of CUs.
Eric Christophera5a79422013-12-09 23:32:48 +0000270 void addUnit(DwarfUnit *CU) { CUs.push_back(CU); }
Eric Christophera2de8262012-12-15 00:04:07 +0000271
272 /// \brief Emit all of the units to the section listed with the given
273 /// abbreviation section.
David Blaikief72ed5f2014-03-24 20:31:01 +0000274 void emitUnits(DwarfDebug *DD, const MCSymbol *ASectionSym);
Eric Christophere698f532012-12-20 21:58:36 +0000275
David Blaikie0504cda2013-12-05 07:43:55 +0000276 /// \brief Emit a set of abbreviations to the specific section.
277 void emitAbbrevs(const MCSection *);
278
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000279 /// \brief Emit all of the strings to the section given.
Eric Christopherdd7b4612013-07-03 21:23:59 +0000280 void emitStrings(const MCSection *StrSection, const MCSection *OffsetSection,
281 const MCSymbol *StrSecSym);
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000282
Eric Christopher962c9082013-01-15 23:56:56 +0000283 /// \brief Emit all of the addresses to the section given.
Eric Christopherdd7b4612013-07-03 21:23:59 +0000284 void emitAddresses(const MCSection *AddrSection);
Eric Christopher962c9082013-01-15 23:56:56 +0000285
Eric Christophere698f532012-12-20 21:58:36 +0000286 /// \brief Returns the entry into the start of the pool.
287 MCSymbol *getStringPoolSym();
288
289 /// \brief Returns an entry into the string pool with the given
290 /// string text.
291 MCSymbol *getStringPoolEntry(StringRef Str);
292
Eric Christopher2cbd5762013-01-07 19:32:41 +0000293 /// \brief Returns the index into the string pool with the given
294 /// string text.
295 unsigned getStringPoolIndex(StringRef Str);
296
Eric Christophere698f532012-12-20 21:58:36 +0000297 /// \brief Returns the string pool.
Eric Christopher27614582013-01-08 22:22:06 +0000298 StrPool *getStringPool() { return &StringPool; }
Eric Christopher962c9082013-01-15 23:56:56 +0000299
300 /// \brief Returns the index into the address pool with the given
301 /// label/symbol.
David Blaikief1a6dea2014-02-15 19:34:03 +0000302 unsigned getAddrPoolIndex(const MCSymbol *Sym, bool TLS = false);
Eric Christopher962c9082013-01-15 23:56:56 +0000303
304 /// \brief Returns the address pool.
305 AddrPool *getAddrPool() { return &AddressPool; }
Eric Christopherc8a310e2012-12-10 23:34:43 +0000306};
307
Eric Christopher670ee0e2013-10-24 21:20:23 +0000308/// \brief Helper used to pair up a symbol and its DWARF compile unit.
Richard Mitton21101b32013-09-19 23:21:01 +0000309struct SymbolCU {
Eric Christopher4287a492013-12-09 23:57:44 +0000310 SymbolCU(DwarfCompileUnit *CU, const MCSymbol *Sym) : Sym(Sym), CU(CU) {}
Richard Mitton21101b32013-09-19 23:21:01 +0000311 const MCSymbol *Sym;
Eric Christopher4287a492013-12-09 23:57:44 +0000312 DwarfCompileUnit *CU;
Richard Mitton21101b32013-09-19 23:21:01 +0000313};
314
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000315/// \brief Collects and handles dwarf debug information.
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000316class DwarfDebug : public AsmPrinterHandler {
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000317 // Target of Dwarf emission.
Chris Lattner3a383cb2010-04-05 00:13:49 +0000318 AsmPrinter *Asm;
Chris Lattneracda87b2010-04-05 05:31:04 +0000319
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000320 // Collected machine module information.
Chris Lattner3a383cb2010-04-05 00:13:49 +0000321 MachineModuleInfo *MMI;
322
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000323 // All DIEValues are allocated through this allocator.
Benjamin Kramer07480082012-06-09 10:34:15 +0000324 BumpPtrAllocator DIEValueAllocator;
325
Eric Christopherbfe7d292013-12-03 22:05:55 +0000326 // Handle to the compile unit used for the inline extension handling,
327 // this is just so that the DIEValue allocator has a place to store
328 // the particular elements.
329 // FIXME: Store these off of DwarfDebug instead?
Eric Christopher4287a492013-12-09 23:57:44 +0000330 DwarfCompileUnit *FirstCU;
Devang Pateleb1bb4e2011-08-16 22:09:43 +0000331
Eric Christopher4287a492013-12-09 23:57:44 +0000332 // Maps MDNode with its corresponding DwarfCompileUnit.
Eric Christopher179fba12014-01-29 22:06:23 +0000333 MapVector<const MDNode *, DwarfCompileUnit *> CUMap;
Bill Wendling2f921f82009-05-15 09:23:25 +0000334
Eric Christopher4287a492013-12-09 23:57:44 +0000335 // Maps subprogram MDNode with its corresponding DwarfCompileUnit.
336 DenseMap<const MDNode *, DwarfCompileUnit *> SPMap;
Devang Pateleb1bb4e2011-08-16 22:09:43 +0000337
Eric Christopher4287a492013-12-09 23:57:44 +0000338 // Maps a CU DIE with its corresponding DwarfCompileUnit.
339 DenseMap<const DIE *, DwarfCompileUnit *> CUDieMap;
Manman Rence20d462013-10-29 22:57:10 +0000340
Eric Christopher47f2be82014-03-20 19:16:20 +0000341 /// Maps MDNodes for type system with the corresponding DIEs. These DIEs can
Manman Ren4dbdc902013-10-31 17:54:35 +0000342 /// be shared across CUs, that is why we keep the map here instead
Eric Christopher4287a492013-12-09 23:57:44 +0000343 /// of in DwarfCompileUnit.
Manman Ren4dbdc902013-10-31 17:54:35 +0000344 DenseMap<const MDNode *, DIE *> MDTypeNodeToDieMap;
345
Alexey Samsonov4436bf02013-10-03 08:54:43 +0000346 // List of all labels used in aranges generation.
347 std::vector<SymbolCU> ArangeLabels;
Richard Mitton21101b32013-09-19 23:21:01 +0000348
Richard Mitton089ed892013-09-23 17:56:20 +0000349 // Size of each symbol emitted (for those symbols that have a specific size).
Eric Christophera5a79422013-12-09 23:32:48 +0000350 DenseMap<const MCSymbol *, uint64_t> SymSize;
Richard Mitton089ed892013-09-23 17:56:20 +0000351
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000352 // Provides a unique id per text section.
Richard Mitton21101b32013-09-19 23:21:01 +0000353 typedef DenseMap<const MCSection *, SmallVector<SymbolCU, 8> > SectionMapType;
354 SectionMapType SectionMap;
Bill Wendling2f921f82009-05-15 09:23:25 +0000355
Eric Christopheraba20dd2013-07-08 21:16:18 +0000356 // List of arguments for current function.
Devang Patel6c622ef2011-03-01 22:58:55 +0000357 SmallVector<DbgVariable *, 8> CurrentFnArguments;
358
Devang Patel7e623022011-08-10 20:55:27 +0000359 LexicalScopes LScopes;
Devang Patel95cd4b92010-03-25 15:09:44 +0000360
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000361 // Collection of abstract subprogram DIEs.
Devang Patela37a95e2010-07-07 22:20:57 +0000362 DenseMap<const MDNode *, DIE *> AbstractSPDies;
363
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000364 // Collection of dbg variables of a scope.
Eric Christophera5a79422013-12-09 23:32:48 +0000365 typedef DenseMap<LexicalScope *, SmallVector<DbgVariable *, 8> >
366 ScopeVariablesMap;
Craig Topper2b4a2012013-07-03 04:40:27 +0000367 ScopeVariablesMap ScopeVariables;
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000368
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000369 // Collection of abstract variables.
Devang Patel32cc43c2010-05-07 20:54:48 +0000370 DenseMap<const MDNode *, DbgVariable *> AbstractVariables;
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000371
Eric Christopher05135fb2014-03-18 02:18:24 +0000372 // Collection of DebugLocEntry.
373 SmallVector<DebugLocEntry, 4> DotDebugLocEntries;
Devang Patel9fc11702010-05-25 23:40:22 +0000374
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000375 // Collection of subprogram DIEs that are marked (at the end of the module)
376 // as DW_AT_inline.
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000377 SmallPtrSet<DIE *, 4> InlinedSubprogramDIEs;
378
Eric Christopher48fef592012-12-20 21:58:40 +0000379 // This is a collection of subprogram MDNodes that are processed to
380 // create DIEs.
Devang Patelf3b2db62010-06-28 18:25:03 +0000381 SmallPtrSet<const MDNode *, 16> ProcessedSPNodes;
382
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000383 // Maps instruction with label emitted before instruction.
Devang Patel6c74a872010-04-27 19:46:33 +0000384 DenseMap<const MachineInstr *, MCSymbol *> LabelsBeforeInsn;
Devang Patel3ebd8932010-04-08 16:50:29 +0000385
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000386 // Maps instruction with label emitted after instruction.
Devang Patel6c74a872010-04-27 19:46:33 +0000387 DenseMap<const MachineInstr *, MCSymbol *> LabelsAfterInsn;
Devang Patel3ebd8932010-04-08 16:50:29 +0000388
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000389 // Every user variable mentioned by a DBG_VALUE instruction in order of
390 // appearance.
Eric Christophera5a79422013-12-09 23:32:48 +0000391 SmallVector<const MDNode *, 8> UserVariables;
Devang Patel002d54d2010-05-26 19:37:24 +0000392
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000393 // For each user variable, keep a list of DBG_VALUE instructions in order.
394 // The list can also contain normal instructions that clobber the previous
395 // DBG_VALUE.
Eric Christophera5a79422013-12-09 23:32:48 +0000396 typedef DenseMap<const MDNode *, SmallVector<const MachineInstr *, 4> >
397 DbgValueHistoryMap;
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000398 DbgValueHistoryMap DbgValues;
Jakob Stoklund Olesenec0ac3c2011-03-22 22:33:08 +0000399
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000400 // Previous instruction's location information. This is used to determine
401 // label location to indicate scope boundries in dwarf debug info.
Chris Lattner915c5f92010-04-02 19:42:39 +0000402 DebugLoc PrevInstLoc;
Devang Patel12563b32010-04-16 23:33:45 +0000403 MCSymbol *PrevLabel;
Devang Patelbd477be2010-03-29 17:20:31 +0000404
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000405 // This location indicates end of function prologue and beginning of function
406 // body.
Devang Patel34a66202011-05-11 19:22:19 +0000407 DebugLoc PrologEndLoc;
408
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000409 // If nonnull, stores the current machine function we're processing.
410 const MachineFunction *CurFn;
411
412 // If nonnull, stores the current machine instruction we're processing.
413 const MachineInstr *CurMI;
414
Eric Christopher384f3fe2014-03-20 19:16:16 +0000415 // If nonnull, stores the section that the previous function was allocated to
416 // emitting.
417 const MCSection *PrevSection;
418
419 // If nonnull, stores the CU in which the previous subprogram was contained.
420 const DwarfCompileUnit *PrevCU;
421
Chris Lattner6629ca92010-04-04 22:59:04 +0000422 // Section Symbols: these are assembler temporary labels that are emitted at
423 // the beginning of each supported dwarf section. These are used to form
424 // section offsets and are created by EmitSectionLabels.
Rafael Espindolaa7160962011-05-06 14:56:22 +0000425 MCSymbol *DwarfInfoSectionSym, *DwarfAbbrevSectionSym;
Devang Patel12563b32010-04-16 23:33:45 +0000426 MCSymbol *DwarfStrSectionSym, *TextSectionSym, *DwarfDebugRangeSectionSym;
Eric Christopher55863be2013-04-07 03:43:09 +0000427 MCSymbol *DwarfDebugLocSectionSym, *DwarfLineSectionSym, *DwarfAddrSectionSym;
Devang Patel9fc11702010-05-25 23:40:22 +0000428 MCSymbol *FunctionBeginSym, *FunctionEndSym;
Eric Christopherd8667202013-12-30 17:22:27 +0000429 MCSymbol *DwarfInfoDWOSectionSym, *DwarfAbbrevDWOSectionSym;
430 MCSymbol *DwarfStrDWOSectionSym;
Eric Christopher39eebfa2013-09-30 23:14:16 +0000431 MCSymbol *DwarfGnuPubNamesSectionSym, *DwarfGnuPubTypesSectionSym;
Devang Patel9c160e12010-07-08 20:10:35 +0000432
Nick Lewyckyd1ee7f82011-11-02 20:55:33 +0000433 // As an optimization, there is no need to emit an entry in the directory
Eric Christopher808fd7b2013-07-03 01:57:23 +0000434 // table for the same directory as DW_AT_comp_dir.
Nick Lewyckyd1ee7f82011-11-02 20:55:33 +0000435 StringRef CompilationDir;
436
Eric Christopher0f63d062013-12-03 00:45:45 +0000437 // Counter for assigning globally unique IDs for ranges.
438 unsigned GlobalRangeCount;
439
Eric Christopherc8a310e2012-12-10 23:34:43 +0000440 // Holder for the file specific debug information.
Eric Christopherf8194852013-12-05 18:06:10 +0000441 DwarfFile InfoHolder;
Eric Christopherc8a310e2012-12-10 23:34:43 +0000442
Eric Christopher0aa4a672012-12-10 22:25:41 +0000443 // Holders for the various debug information flags that we might need to
444 // have exposed. See accessor functions below for description.
445
Eric Christopher070bf162013-07-03 01:57:26 +0000446 // Holder for imported entities.
447 typedef SmallVector<std::pair<const MDNode *, const MDNode *>, 32>
Eric Christophera5a79422013-12-09 23:32:48 +0000448 ImportedEntityMap;
Eric Christopher070bf162013-07-03 01:57:26 +0000449 ImportedEntityMap ScopesWithImportedEntities;
450
David Blaikie47f615e2013-12-17 23:32:35 +0000451 // Map from MDNodes for user-defined types to the type units that describe
452 // them.
453 DenseMap<const MDNode *, const DwarfTypeUnit *> DwarfTypeUnits;
Eric Christopher67646432013-07-26 17:02:41 +0000454
Eric Christopher4d36ca02013-08-26 23:24:35 +0000455 // Whether to emit the pubnames/pubtypes sections.
456 bool HasDwarfPubSections;
457
Eric Christopher1ad84572014-01-15 00:04:29 +0000458 // Whether or not to use AT_ranges for compilation units.
459 bool HasCURanges;
460
Eric Christopher2037caf2014-01-28 00:49:26 +0000461 // Whether we emitted a function into a section other than the default
462 // text.
463 bool UsedNonDefaultText;
464
Eric Christopher4d36ca02013-08-26 23:24:35 +0000465 // Version of dwarf we're emitting.
466 unsigned DwarfVersion;
467
Eric Christopher0a13eb32013-11-21 22:56:11 +0000468 // Maps from a type identifier to the actual MDNode.
469 DITypeIdentifierMap TypeIdentifierMap;
470
Eric Christopher42e39942012-11-29 22:56:13 +0000471 // DWARF5 Experimental Options
Eric Christopher7b30f2e42012-11-21 00:34:35 +0000472 bool HasDwarfAccelTables;
Eric Christophercdf218d2012-12-10 19:51:21 +0000473 bool HasSplitDwarf;
Manman Renac8062b2013-07-02 23:40:10 +0000474
Eric Christopherd692c1d2012-12-11 19:42:09 +0000475 // Separated Dwarf Variables
Eric Christopherd79f5482012-12-10 19:51:13 +0000476 // In general these will all be for bits that are left in the
477 // original object file, rather than things that are meant
478 // to be in the .dwo sections.
479
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000480 // Holder for the skeleton information.
Eric Christopherf8194852013-12-05 18:06:10 +0000481 DwarfFile SkeletonHolder;
Eric Christopherd79f5482012-12-10 19:51:13 +0000482
David Blaikie47f4b822014-03-19 00:11:28 +0000483 /// Store file names for type units under fission in a line table header that
484 /// will be emitted into debug_line.dwo.
485 // FIXME: replace this with a map from comp_dir to table so that we can emit
486 // multiple tables during LTO each of which uses directory 0, referencing the
487 // comp_dir of all the type units that use it.
David Blaikie8287aff2014-03-18 02:13:23 +0000488 MCDwarfDwoLineTable SplitTypeUnitFileTable;
David Blaikie4a2f95f2014-03-18 01:17:26 +0000489
David Blaikie47f4b822014-03-19 00:11:28 +0000490 // True iff there are multiple CUs in this module.
491 bool SingleCU;
492
493 MCDwarfDwoLineTable *getDwoLineTable(const DwarfCompileUnit &);
494
Devang Patel7e623022011-08-10 20:55:27 +0000495 void addScopeVariable(LexicalScope *LS, DbgVariable *Var);
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000496
Eric Christophera5a79422013-12-09 23:32:48 +0000497 const SmallVectorImpl<DwarfUnit *> &getUnits() {
498 return InfoHolder.getUnits();
499 }
David Blaikiefd1eff52013-11-26 19:14:34 +0000500
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000501 /// \brief Find abstract variable associated with Var.
Devang Patele1c53f22010-05-20 16:36:41 +0000502 DbgVariable *findAbstractVariable(DIVariable &Var, DebugLoc Loc);
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000503
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000504 /// \brief Find DIE for the given subprogram and attach appropriate
505 /// DW_AT_low_pc and DW_AT_high_pc attributes. If there are global
506 /// variables in this scope then create and insert DIEs for these
507 /// variables.
Eric Christopher4287a492013-12-09 23:57:44 +0000508 DIE *updateSubprogramScopeDIE(DwarfCompileUnit *SPCU, DISubprogram SP);
Bill Wendling2f921f82009-05-15 09:23:25 +0000509
Eric Christopher44e66c12013-12-03 00:45:56 +0000510 /// \brief A helper function to check whether the DIE for a given Scope is
511 /// going to be null.
Manman Ren2312ed32013-09-10 18:40:41 +0000512 bool isLexicalScopeDIENull(LexicalScope *Scope);
Bill Wendling2f921f82009-05-15 09:23:25 +0000513
Eric Christopherbe2513e2013-12-03 00:45:59 +0000514 /// \brief A helper function to construct a RangeSpanList for a given
515 /// lexical scope.
Eric Christopher4287a492013-12-09 23:57:44 +0000516 void addScopeRangeList(DwarfCompileUnit *TheCU, DIE *ScopeDIE,
Eric Christopherbe2513e2013-12-03 00:45:59 +0000517 const SmallVectorImpl<InsnRange> &Range);
518
Eric Christopher77913e0392013-12-03 00:45:54 +0000519 /// \brief Construct new DW_TAG_lexical_block for this scope and
520 /// attach DW_AT_low_pc/DW_AT_high_pc labels.
Eric Christopher4287a492013-12-09 23:57:44 +0000521 DIE *constructLexicalScopeDIE(DwarfCompileUnit *TheCU, LexicalScope *Scope);
Eric Christopher77913e0392013-12-03 00:45:54 +0000522
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000523 /// \brief This scope represents inlined body of a function. Construct
524 /// DIE to represent this concrete inlined copy of the function.
Eric Christopher4287a492013-12-09 23:57:44 +0000525 DIE *constructInlinedScopeDIE(DwarfCompileUnit *TheCU, LexicalScope *Scope);
Devang Patel930143b2009-11-21 02:48:08 +0000526
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000527 /// \brief Construct a DIE for this scope.
Eric Christopher4287a492013-12-09 23:57:44 +0000528 DIE *constructScopeDIE(DwarfCompileUnit *TheCU, LexicalScope *Scope);
Manman Ren2312ed32013-09-10 18:40:41 +0000529 /// A helper function to create children of a Scope DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000530 DIE *createScopeChildrenDIE(DwarfCompileUnit *TheCU, LexicalScope *Scope,
Eric Christophera5a79422013-12-09 23:32:48 +0000531 SmallVectorImpl<DIE *> &Children);
Devang Patel930143b2009-11-21 02:48:08 +0000532
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000533 /// \brief Emit initial Dwarf sections with a label at the start of each one.
Eric Christopher7b30f2e42012-11-21 00:34:35 +0000534 void emitSectionLabels();
Bill Wendling2f921f82009-05-15 09:23:25 +0000535
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000536 /// \brief Compute the size and offset of a DIE given an incoming Offset.
Eric Christopher1f0cbb82012-11-20 22:14:13 +0000537 unsigned computeSizeAndOffset(DIE *Die, unsigned Offset);
Bill Wendling2f921f82009-05-15 09:23:25 +0000538
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000539 /// \brief Compute the size and offset of all the DIEs.
Devang Patel930143b2009-11-21 02:48:08 +0000540 void computeSizeAndOffsets();
Bill Wendling2f921f82009-05-15 09:23:25 +0000541
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000542 /// \brief Attach DW_AT_inline attribute with inlined subprogram DIEs.
Eric Christopher960ac372012-11-22 00:59:49 +0000543 void computeInlinedDIEs();
544
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000545 /// \brief Collect info for variables that were optimized out.
Eric Christopher960ac372012-11-22 00:59:49 +0000546 void collectDeadVariables();
547
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000548 /// \brief Finish off debug information after all functions have been
549 /// processed.
Eric Christopher960ac372012-11-22 00:59:49 +0000550 void finalizeModuleInfo();
551
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000552 /// \brief Emit labels to close any remaining sections that have been left
553 /// open.
Eric Christopher960ac372012-11-22 00:59:49 +0000554 void endSections();
555
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000556 /// \brief Emit the debug info section.
Devang Patel930143b2009-11-21 02:48:08 +0000557 void emitDebugInfo();
Bill Wendling2f921f82009-05-15 09:23:25 +0000558
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000559 /// \brief Emit the abbreviation section.
Eric Christopher38371952012-11-20 23:30:11 +0000560 void emitAbbreviations();
Bill Wendling2f921f82009-05-15 09:23:25 +0000561
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000562 /// \brief Emit the last address of the section and the end of
Bill Wendling2f921f82009-05-15 09:23:25 +0000563 /// the line matrix.
Devang Patel930143b2009-11-21 02:48:08 +0000564 void emitEndOfLineMatrix(unsigned SectionEnd);
Bill Wendling2f921f82009-05-15 09:23:25 +0000565
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000566 /// \brief Emit visible names into a hashed accelerator table section.
Eric Christopher4996c702011-11-07 09:24:32 +0000567 void emitAccelNames();
Eric Christopher27527b22012-11-21 00:03:28 +0000568
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000569 /// \brief Emit objective C classes and categories into a hashed
Eric Christopher4996c702011-11-07 09:24:32 +0000570 /// accelerator table section.
571 void emitAccelObjC();
572
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000573 /// \brief Emit namespace dies into a hashed accelerator table.
Eric Christopher4996c702011-11-07 09:24:32 +0000574 void emitAccelNamespaces();
575
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000576 /// \brief Emit type dies into a hashed accelerator table.
Eric Christopher4996c702011-11-07 09:24:32 +0000577 void emitAccelTypes();
Eric Christopher27527b22012-11-21 00:03:28 +0000578
Krzysztof Parzyszek228daa62013-02-12 18:00:14 +0000579 /// \brief Emit visible names into a debug pubnames section.
Eric Christopherdd1a0122013-09-13 00:35:05 +0000580 /// \param GnuStyle determines whether or not we want to emit
581 /// additional information into the table ala newer gcc for gdb
582 /// index.
583 void emitDebugPubNames(bool GnuStyle = false);
Krzysztof Parzyszek228daa62013-02-12 18:00:14 +0000584
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000585 /// \brief Emit visible types into a debug pubtypes section.
Eric Christopherdd1a0122013-09-13 00:35:05 +0000586 /// \param GnuStyle determines whether or not we want to emit
587 /// additional information into the table ala newer gcc for gdb
588 /// index.
589 void emitDebugPubTypes(bool GnuStyle = false);
Devang Patel04d2f2d2009-11-24 01:14:22 +0000590
David Blaikie0f55e832014-03-11 23:18:15 +0000591 void
592 emitDebugPubSection(bool GnuStyle, const MCSection *PSec, StringRef Name,
593 const StringMap<const DIE *> &(DwarfUnit::*Accessor)()
594 const);
595
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000596 /// \brief Emit visible names into a debug str section.
Devang Patel930143b2009-11-21 02:48:08 +0000597 void emitDebugStr();
Bill Wendling2f921f82009-05-15 09:23:25 +0000598
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000599 /// \brief Emit visible names into a debug loc section.
Devang Patel930143b2009-11-21 02:48:08 +0000600 void emitDebugLoc();
Bill Wendling2f921f82009-05-15 09:23:25 +0000601
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000602 /// \brief Emit visible names into a debug aranges section.
Eric Christopher7b30f2e42012-11-21 00:34:35 +0000603 void emitDebugARanges();
Bill Wendling2f921f82009-05-15 09:23:25 +0000604
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000605 /// \brief Emit visible names into a debug ranges section.
Devang Patel930143b2009-11-21 02:48:08 +0000606 void emitDebugRanges();
Bill Wendling2f921f82009-05-15 09:23:25 +0000607
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000608 /// \brief Emit inline info using custom format.
Devang Patel930143b2009-11-21 02:48:08 +0000609 void emitDebugInlineInfo();
Bill Wendling2b128d72009-05-20 23:19:06 +0000610
Eric Christophercdf218d2012-12-10 19:51:21 +0000611 /// DWARF 5 Experimental Split Dwarf Emitters
Eric Christopher9c2ecd92012-11-30 23:59:06 +0000612
David Blaikie38fe6342014-01-09 04:28:46 +0000613 /// \brief Initialize common features of skeleton units.
614 void initSkeletonUnit(const DwarfUnit *U, DIE *Die, DwarfUnit *NewU);
615
Eric Christophercdf218d2012-12-10 19:51:21 +0000616 /// \brief Construct the split debug info compile unit for the debug info
617 /// section.
Eric Christopher4287a492013-12-09 23:57:44 +0000618 DwarfCompileUnit *constructSkeletonCU(const DwarfCompileUnit *CU);
Eric Christopher9c2ecd92012-11-30 23:59:06 +0000619
David Blaikie15ed5eb2014-01-10 01:38:41 +0000620 /// \brief Construct the split debug info compile unit for the debug info
621 /// section.
David Blaikie15632ae2014-02-12 00:31:30 +0000622 DwarfTypeUnit *constructSkeletonTU(DwarfTypeUnit *TU);
David Blaikie15ed5eb2014-01-10 01:38:41 +0000623
Eric Christopher9c2ecd92012-11-30 23:59:06 +0000624 /// \brief Emit the debug info dwo section.
625 void emitDebugInfoDWO();
626
Eric Christopher3c5a1912012-12-19 22:02:53 +0000627 /// \brief Emit the debug abbrev dwo section.
628 void emitDebugAbbrevDWO();
629
David Blaikie4a2f95f2014-03-18 01:17:26 +0000630 /// \brief Emit the debug line dwo section.
631 void emitDebugLineDWO();
632
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000633 /// \brief Emit the debug str dwo section.
634 void emitDebugStrDWO();
635
David Blaikie3c842622013-12-04 21:31:26 +0000636 /// Flags to let the linker know we have emitted new style pubnames. Only
637 /// emit it here if we don't have a skeleton CU for split dwarf.
Eric Christophera5a79422013-12-09 23:32:48 +0000638 void addGnuPubAttributes(DwarfUnit *U, DIE *D) const;
David Blaikie3c842622013-12-04 21:31:26 +0000639
Eric Christopher4287a492013-12-09 23:57:44 +0000640 /// \brief Create new DwarfCompileUnit for the given metadata node with tag
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000641 /// DW_TAG_compile_unit.
David Blaikie47f4b822014-03-19 00:11:28 +0000642 DwarfCompileUnit *constructDwarfCompileUnit(DICompileUnit DIUnit);
Devang Patel1a0df9a2010-05-10 22:49:55 +0000643
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000644 /// \brief Construct subprogram DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000645 void constructSubprogramDIE(DwarfCompileUnit *TheCU, const MDNode *N);
Bill Wendling2b128d72009-05-20 23:19:06 +0000646
David Blaikie1fd43652013-05-07 21:35:53 +0000647 /// \brief Construct imported_module or imported_declaration DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000648 void constructImportedEntityDIE(DwarfCompileUnit *TheCU, const MDNode *N);
David Blaikief55abea2013-04-22 06:12:31 +0000649
David Blaikie684fc532013-05-06 23:33:07 +0000650 /// \brief Construct import_module DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000651 void constructImportedEntityDIE(DwarfCompileUnit *TheCU, const MDNode *N,
David Blaikie684fc532013-05-06 23:33:07 +0000652 DIE *Context);
653
654 /// \brief Construct import_module DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000655 void constructImportedEntityDIE(DwarfCompileUnit *TheCU,
Eric Christophera5a79422013-12-09 23:32:48 +0000656 const DIImportedEntity &Module, DIE *Context);
David Blaikie684fc532013-05-06 23:33:07 +0000657
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000658 /// \brief Register a source line with debug info. Returns the unique
659 /// label that was emitted and which provides correspondence to the
660 /// source line list.
Devang Patel34a66202011-05-11 19:22:19 +0000661 void recordSourceLine(unsigned Line, unsigned Col, const MDNode *Scope,
662 unsigned Flags);
Eric Christopher27527b22012-11-21 00:03:28 +0000663
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000664 /// \brief Indentify instructions that are marking the beginning of or
665 /// ending of a scope.
Devang Patel359b0132010-04-08 18:43:56 +0000666 void identifyScopeMarkers();
Devang Patelf1d5a1e2010-04-08 15:37:09 +0000667
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000668 /// \brief If Var is an current function argument that add it in
669 /// CurrentFnArguments list.
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000670 bool addCurrentFnArgument(DbgVariable *Var, LexicalScope *Scope);
Devang Patel6c622ef2011-03-01 22:58:55 +0000671
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000672 /// \brief Populate LexicalScope entries with variables' info.
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000673 void collectVariableInfo(SmallPtrSet<const MDNode *, 16> &ProcessedVars);
Eric Christopher27527b22012-11-21 00:03:28 +0000674
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000675 /// \brief Collect variable information from the side table maintained
676 /// by MMI.
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000677 void collectVariableInfoFromMMITable(SmallPtrSet<const MDNode *, 16> &P);
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000678
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000679 /// \brief Ensure that a label will be emitted before MI.
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000680 void requestLabelBeforeInsn(const MachineInstr *MI) {
Eric Christophera5a79422013-12-09 23:32:48 +0000681 LabelsBeforeInsn.insert(std::make_pair(MI, (MCSymbol *)0));
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000682 }
683
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000684 /// \brief Return Label preceding the instruction.
Eric Christopher962c9082013-01-15 23:56:56 +0000685 MCSymbol *getLabelBeforeInsn(const MachineInstr *MI);
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000686
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000687 /// \brief Ensure that a label will be emitted after MI.
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000688 void requestLabelAfterInsn(const MachineInstr *MI) {
Eric Christophera5a79422013-12-09 23:32:48 +0000689 LabelsAfterInsn.insert(std::make_pair(MI, (MCSymbol *)0));
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000690 }
691
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000692 /// \brief Return Label immediately following the instruction.
Eric Christopher962c9082013-01-15 23:56:56 +0000693 MCSymbol *getLabelAfterInsn(const MachineInstr *MI);
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000694
David Blaikie4bd13b72014-03-07 18:49:45 +0000695 void attachLowHighPC(DwarfCompileUnit *Unit, DIE *D, MCSymbol *Begin,
696 MCSymbol *End);
697
Bill Wendling2f921f82009-05-15 09:23:25 +0000698public:
699 //===--------------------------------------------------------------------===//
700 // Main entry points.
701 //
Chris Lattnerf0d6bd32010-04-05 05:11:15 +0000702 DwarfDebug(AsmPrinter *A, Module *M);
Bill Wendling2f921f82009-05-15 09:23:25 +0000703
Manman Ren4dbdc902013-10-31 17:54:35 +0000704 void insertDIE(const MDNode *TypeMD, DIE *Die) {
705 MDTypeNodeToDieMap.insert(std::make_pair(TypeMD, Die));
706 }
707 DIE *getDIE(const MDNode *TypeMD) {
708 return MDTypeNodeToDieMap.lookup(TypeMD);
709 }
710
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000711 /// \brief Emit all Dwarf sections that should come prior to the
Bill Wendling2f921f82009-05-15 09:23:25 +0000712 /// content.
Eric Christopher58f41952012-11-19 22:42:15 +0000713 void beginModule();
Bill Wendling2f921f82009-05-15 09:23:25 +0000714
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000715 /// \brief Emit all Dwarf sections that should come after the content.
Craig Topper7b883b32014-03-08 06:31:39 +0000716 void endModule() override;
Bill Wendling2f921f82009-05-15 09:23:25 +0000717
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000718 /// \brief Gather pre-function debug information.
Craig Topper7b883b32014-03-08 06:31:39 +0000719 void beginFunction(const MachineFunction *MF) override;
Bill Wendling2f921f82009-05-15 09:23:25 +0000720
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000721 /// \brief Gather and emit post-function debug information.
Craig Topper7b883b32014-03-08 06:31:39 +0000722 void endFunction(const MachineFunction *MF) override;
Bill Wendling2f921f82009-05-15 09:23:25 +0000723
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000724 /// \brief Process beginning of an instruction.
Craig Topper7b883b32014-03-08 06:31:39 +0000725 void beginInstruction(const MachineInstr *MI) override;
Bill Wendling2f921f82009-05-15 09:23:25 +0000726
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000727 /// \brief Process end of an instruction.
Craig Topper7b883b32014-03-08 06:31:39 +0000728 void endInstruction() override;
Devang Patelf20c4f72011-04-12 22:53:02 +0000729
Eric Christopher67646432013-07-26 17:02:41 +0000730 /// \brief Add a DIE to the set of types that we're going to pull into
731 /// type units.
David Blaikie15632ae2014-02-12 00:31:30 +0000732 void addDwarfTypeUnitType(DwarfCompileUnit &CU, StringRef Identifier,
David Blaikief645f962014-01-09 03:23:41 +0000733 DIE *Die, DICompositeType CTy);
Eric Christopher67646432013-07-26 17:02:41 +0000734
Richard Mitton21101b32013-09-19 23:21:01 +0000735 /// \brief Add a label so that arange data can be generated for it.
Alexey Samsonov4436bf02013-10-03 08:54:43 +0000736 void addArangeLabel(SymbolCU SCU) { ArangeLabels.push_back(SCU); }
Richard Mitton21101b32013-09-19 23:21:01 +0000737
Richard Mitton089ed892013-09-23 17:56:20 +0000738 /// \brief For symbols that have a size designated (e.g. common symbols),
739 /// this tracks that size.
Craig Topper7b883b32014-03-08 06:31:39 +0000740 void setSymbolSize(const MCSymbol *Sym, uint64_t Size) override {
Eric Christophera5a79422013-12-09 23:32:48 +0000741 SymSize[Sym] = Size;
742 }
Richard Mitton089ed892013-09-23 17:56:20 +0000743
Eric Christophera2de8262012-12-15 00:04:07 +0000744 /// \brief Recursively Emits a debug information entry.
David Blaikieff3ab2c2013-12-05 01:01:41 +0000745 void emitDIE(DIE *Die);
Eric Christophera2de8262012-12-15 00:04:07 +0000746
Eric Christopher55c51812012-11-21 00:03:31 +0000747 // Experimental DWARF5 features.
748
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000749 /// \brief Returns whether or not to emit tables that dwarf consumers can
750 /// use to accelerate lookup.
Eric Christopher411bd592014-03-06 00:00:53 +0000751 bool useDwarfAccelTables() const { return HasDwarfAccelTables; }
Eric Christopher55c51812012-11-21 00:03:31 +0000752
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000753 /// \brief Returns whether or not to change the current debug info for the
Eric Christophercdf218d2012-12-10 19:51:21 +0000754 /// split dwarf proposal support.
Eric Christopher411bd592014-03-06 00:00:53 +0000755 bool useSplitDwarf() const { return HasSplitDwarf; }
Manman Renac8062b2013-07-02 23:40:10 +0000756
757 /// Returns the Dwarf Version.
758 unsigned getDwarfVersion() const { return DwarfVersion; }
Manman Ren60352032013-09-05 18:48:31 +0000759
Eric Christophera27220f2014-03-05 22:41:20 +0000760 /// Returns the section symbol for the .debug_loc section.
761 MCSymbol *getDebugLocSym() const { return DwarfDebugLocSectionSym; }
762
Eric Christopher384f3fe2014-03-20 19:16:16 +0000763 /// Returns the previous section that was emitted into.
764 const MCSection *getPrevSection() const { return PrevSection; }
765
766 /// Returns the previous CU that was being updated
767 const DwarfCompileUnit *getPrevCU() const { return PrevCU; }
768
Eric Christopher4f17ee02014-03-08 00:29:41 +0000769 /// Returns the entries for the .debug_loc section.
Eric Christopher05135fb2014-03-18 02:18:24 +0000770 const SmallVectorImpl<DebugLocEntry> &getDebugLocEntries() const {
Eric Christopher4f17ee02014-03-08 00:29:41 +0000771 return DotDebugLocEntries;
772 }
773
774 /// \brief Emit an entry for the debug loc section. This can be used to
775 /// handle an entry that's going to be emitted into the debug loc section.
Eric Christopher05135fb2014-03-18 02:18:24 +0000776 void emitDebugLocEntry(ByteStreamer &Streamer, const DebugLocEntry &Entry);
Eric Christopher4f17ee02014-03-08 00:29:41 +0000777
Eric Christopher87b9c492013-10-05 00:32:34 +0000778 /// Find the MDNode for the given reference.
779 template <typename T> T resolve(DIRef<T> Ref) const {
Manman Ren34b3dcc2013-09-10 18:30:07 +0000780 return Ref.resolve(TypeIdentifierMap);
781 }
Manman Ren60352032013-09-05 18:48:31 +0000782
Adrian Prantl1a1647c2014-03-18 02:34:58 +0000783 /// \brief Return the TypeIdentifierMap.
Eric Christopherc0bd5f82014-03-18 20:39:54 +0000784 const DITypeIdentifierMap &getTypeIdentifierMap() const {
Adrian Prantl1a1647c2014-03-18 02:34:58 +0000785 return TypeIdentifierMap;
786 }
787
Eric Christopherdd508382014-03-06 00:00:56 +0000788 /// Find the DwarfCompileUnit for the given CU Die.
789 DwarfCompileUnit *lookupUnit(const DIE *CU) const {
790 return CUDieMap.lookup(CU);
791 }
Manman Ren3eb9dff2013-09-09 19:05:21 +0000792 /// isSubprogramContext - Return true if Context is either a subprogram
793 /// or another context nested inside a subprogram.
794 bool isSubprogramContext(const MDNode *Context);
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000795};
Bill Wendling2f921f82009-05-15 09:23:25 +0000796} // End of namespace llvm
797
798#endif