blob: fcac25d52072f12787a77d9d919a8c0005f5b223 [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"
David Blaikie1275e4f2014-04-01 21:49:04 +000019#include "DebugLocEntry.h"
Devang Patel018b29b2010-01-19 06:19:05 +000020#include "llvm/ADT/DenseMap.h"
Eric Christopheracbe42b2014-03-18 20:58:35 +000021#include "llvm/ADT/MapVector.h"
22#include "llvm/ADT/SmallPtrSet.h"
23#include "llvm/ADT/StringMap.h"
Bill Wendling2f921f82009-05-15 09:23:25 +000024#include "llvm/ADT/FoldingSet.h"
Chandler Carruth802d7552012-12-04 07:12:27 +000025#include "llvm/CodeGen/LexicalScopes.h"
Chandler Carruth9a4c9e52014-03-06 00:46:21 +000026#include "llvm/IR/DebugInfo.h"
Eric Christopheracbe42b2014-03-18 20:58:35 +000027#include "llvm/IR/DebugLoc.h"
Chandler Carruth802d7552012-12-04 07:12:27 +000028#include "llvm/MC/MachineLocation.h"
David Blaikie4a2f95f2014-03-18 01:17:26 +000029#include "llvm/MC/MCDwarf.h"
Chris Lattner3f3fb972010-04-05 05:24:55 +000030#include "llvm/Support/Allocator.h"
Bill Wendling2f921f82009-05-15 09:23:25 +000031
32namespace llvm {
33
Adrian Prantl702bf5a2014-03-18 02:34:52 +000034class AsmPrinter;
Eric Christopher29e874d2014-03-07 22:40:37 +000035class ByteStreamer;
Chris Lattner88fce102012-01-26 20:44:57 +000036class ConstantInt;
37class ConstantFP;
Eric Christopherce4a9442014-03-18 20:37:10 +000038class DwarfCompileUnit;
39class DwarfDebug;
40class DwarfTypeUnit;
41class DwarfUnit;
Bill Wendling2f921f82009-05-15 09:23:25 +000042class MachineModuleInfo;
Bill Wendling2f921f82009-05-15 09:23:25 +000043
44//===----------------------------------------------------------------------===//
Eric Christopheracdcbdb2012-11-27 22:43:45 +000045/// \brief This class is used to record source line correspondence.
Benjamin Kramer079b96e2013-09-11 18:05:11 +000046class SrcLineInfo {
Eric Christophera5a79422013-12-09 23:32:48 +000047 unsigned Line; // Source line number.
48 unsigned Column; // Source column.
49 unsigned SourceID; // Source ID number.
50 MCSymbol *Label; // Label in code ID number.
Bill Wendling2f921f82009-05-15 09:23:25 +000051public:
Chris Lattnerb4666f42010-03-14 08:15:55 +000052 SrcLineInfo(unsigned L, unsigned C, unsigned S, MCSymbol *label)
Eric Christophera5a79422013-12-09 23:32:48 +000053 : Line(L), Column(C), SourceID(S), Label(label) {}
Bill Wendling2f921f82009-05-15 09:23:25 +000054
55 // Accessors
56 unsigned getLine() const { return Line; }
57 unsigned getColumn() const { return Column; }
58 unsigned getSourceID() const { return SourceID; }
Chris Lattnerb4666f42010-03-14 08:15:55 +000059 MCSymbol *getLabel() const { return Label; }
Bill Wendling2f921f82009-05-15 09:23:25 +000060};
61
Devang Patelf20c4f72011-04-12 22:53:02 +000062//===----------------------------------------------------------------------===//
Eric Christopheracdcbdb2012-11-27 22:43:45 +000063/// \brief This class is used to track local variable information.
Benjamin Kramer079b96e2013-09-11 18:05:11 +000064class DbgVariable {
Eric Christophera5a79422013-12-09 23:32:48 +000065 DIVariable Var; // Variable Descriptor.
66 DIE *TheDIE; // Variable DIE.
67 unsigned DotDebugLocOffset; // Offset in DotDebugLocEntries.
68 DbgVariable *AbsVar; // Corresponding Abstract variable, if any.
69 const MachineInstr *MInsn; // DBG_VALUE instruction of the variable.
Devang Patel3e4a9652011-08-15 21:24:36 +000070 int FrameIndex;
Manman Renb3388602013-10-05 01:43:03 +000071 DwarfDebug *DD;
Eric Christophera5a79422013-12-09 23:32:48 +000072
Devang Patelf20c4f72011-04-12 22:53:02 +000073public:
74 // AbsVar may be NULL.
Manman Renb3388602013-10-05 01:43:03 +000075 DbgVariable(DIVariable V, DbgVariable *AV, DwarfDebug *DD)
Eric Christophera5a79422013-12-09 23:32:48 +000076 : Var(V), TheDIE(0), DotDebugLocOffset(~0U), AbsVar(AV), MInsn(0),
77 FrameIndex(~0), DD(DD) {}
Devang Patelf20c4f72011-04-12 22:53:02 +000078
79 // Accessors.
Eric Christophera5a79422013-12-09 23:32:48 +000080 DIVariable getVariable() const { return Var; }
81 void setDIE(DIE *D) { TheDIE = D; }
82 DIE *getDIE() const { return TheDIE; }
83 void setDotDebugLocOffset(unsigned O) { DotDebugLocOffset = O; }
84 unsigned getDotDebugLocOffset() const { return DotDebugLocOffset; }
85 StringRef getName() const { return Var.getName(); }
Devang Patel99819b52011-08-15 19:01:20 +000086 DbgVariable *getAbstractVariable() const { return AbsVar; }
Eric Christophera5a79422013-12-09 23:32:48 +000087 const MachineInstr *getMInsn() const { return MInsn; }
88 void setMInsn(const MachineInstr *M) { MInsn = M; }
89 int getFrameIndex() const { return FrameIndex; }
90 void setFrameIndex(int FI) { FrameIndex = FI; }
Eric Christopher27527b22012-11-21 00:03:28 +000091 // Translate tag to proper Dwarf tag.
Eric Christophera5a79422013-12-09 23:32:48 +000092 uint16_t getTag() const {
Devang Patel6e4d2c92011-08-15 18:35:42 +000093 if (Var.getTag() == dwarf::DW_TAG_arg_variable)
94 return dwarf::DW_TAG_formal_parameter;
Eric Christopher27527b22012-11-21 00:03:28 +000095
Devang Patel6e4d2c92011-08-15 18:35:42 +000096 return dwarf::DW_TAG_variable;
97 }
Eric Christopheracdcbdb2012-11-27 22:43:45 +000098 /// \brief Return true if DbgVariable is artificial.
Eric Christophera5a79422013-12-09 23:32:48 +000099 bool isArtificial() const {
Devang Pateld7d80aa2011-08-15 18:40:16 +0000100 if (Var.isArtificial())
101 return true;
Eric Christopherc1c8a1b2012-09-21 22:18:52 +0000102 if (getType().isArtificial())
Devang Pateld7d80aa2011-08-15 18:40:16 +0000103 return true;
104 return false;
105 }
Eric Christophere3417762012-09-12 23:36:19 +0000106
Eric Christophera5a79422013-12-09 23:32:48 +0000107 bool isObjectPointer() const {
Eric Christophere3417762012-09-12 23:36:19 +0000108 if (Var.isObjectPointer())
109 return true;
Eric Christopherc1c8a1b2012-09-21 22:18:52 +0000110 if (getType().isObjectPointer())
Eric Christophere3417762012-09-12 23:36:19 +0000111 return true;
112 return false;
113 }
Eric Christopher27527b22012-11-21 00:03:28 +0000114
Eric Christophera5a79422013-12-09 23:32:48 +0000115 bool variableHasComplexAddress() const {
Manman Ren7504ed42013-07-08 18:33:29 +0000116 assert(Var.isVariable() && "Invalid complex DbgVariable!");
Devang Patelf20c4f72011-04-12 22:53:02 +0000117 return Var.hasComplexAddress();
118 }
Adrian Prantl1a1647c2014-03-18 02:34:58 +0000119 bool isBlockByrefVariable() const;
Eric Christophera5a79422013-12-09 23:32:48 +0000120 unsigned getNumAddrElements() const {
Manman Ren7504ed42013-07-08 18:33:29 +0000121 assert(Var.isVariable() && "Invalid complex DbgVariable!");
Devang Patelf20c4f72011-04-12 22:53:02 +0000122 return Var.getNumAddrElements();
123 }
Eric Christophera5a79422013-12-09 23:32:48 +0000124 uint64_t getAddrElement(unsigned i) const { return Var.getAddrElement(i); }
Devang Patelf20c4f72011-04-12 22:53:02 +0000125 DIType getType() const;
Manman Renbe5576f2013-10-08 19:07:44 +0000126
127private:
128 /// resolve - Look in the DwarfDebug map for the MDNode that
129 /// corresponds to the reference.
130 template <typename T> T resolve(DIRef<T> Ref) const;
Devang Patelf20c4f72011-04-12 22:53:02 +0000131};
132
Eric Christopherc8a310e2012-12-10 23:34:43 +0000133/// \brief Collects and handles information specific to a particular
Eric Christopherf8194852013-12-05 18:06:10 +0000134/// collection of units. This collection represents all of the units
135/// that will be ultimately output into a single object file.
136class DwarfFile {
Eric Christopherc8a310e2012-12-10 23:34:43 +0000137 // Target of Dwarf emission, used for sizing of abbreviations.
138 AsmPrinter *Asm;
139
140 // Used to uniquely define abbreviations.
David Blaikie0504cda2013-12-05 07:43:55 +0000141 FoldingSet<DIEAbbrev> AbbreviationsSet;
Eric Christopherc8a310e2012-12-10 23:34:43 +0000142
143 // A list of all the unique abbreviations in use.
David Blaikie0504cda2013-12-05 07:43:55 +0000144 std::vector<DIEAbbrev *> Abbreviations;
Eric Christopherc8a310e2012-12-10 23:34:43 +0000145
146 // A pointer to all units in the section.
Eric Christophera5a79422013-12-09 23:32:48 +0000147 SmallVector<DwarfUnit *, 1> CUs;
Eric Christopherc8a310e2012-12-10 23:34:43 +0000148
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000149 // Collection of strings for this unit and assorted symbols.
Eric Christopher18cf0612013-07-03 20:36:36 +0000150 // A String->Symbol mapping of strings used by indirect
151 // references.
Eric Christophera5a79422013-12-09 23:32:48 +0000152 typedef StringMap<std::pair<MCSymbol *, unsigned>, BumpPtrAllocator &>
153 StrPool;
Eric Christopher27614582013-01-08 22:22:06 +0000154 StrPool StringPool;
Eric Christophere698f532012-12-20 21:58:36 +0000155 unsigned NextStringPoolNumber;
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000156 std::string StringPref;
Eric Christophere698f532012-12-20 21:58:36 +0000157
David Blaikief1a6dea2014-02-15 19:34:03 +0000158 struct AddressPoolEntry {
159 unsigned Number;
160 bool TLS;
161 AddressPoolEntry(unsigned Number, bool TLS) : Number(Number), TLS(TLS) {}
162 };
Eric Christopher962c9082013-01-15 23:56:56 +0000163 // Collection of addresses for this unit and assorted labels.
Eric Christopher18cf0612013-07-03 20:36:36 +0000164 // A Symbol->unsigned mapping of addresses used by indirect
165 // references.
David Blaikief1a6dea2014-02-15 19:34:03 +0000166 typedef DenseMap<const MCSymbol *, AddressPoolEntry> AddrPool;
Eric Christopher962c9082013-01-15 23:56:56 +0000167 AddrPool AddressPool;
168 unsigned NextAddrPoolNumber;
169
Eric Christopherc8a310e2012-12-10 23:34:43 +0000170public:
Eric Christopherf8194852013-12-05 18:06:10 +0000171 DwarfFile(AsmPrinter *AP, const char *Pref, BumpPtrAllocator &DA)
David Blaikie0504cda2013-12-05 07:43:55 +0000172 : Asm(AP), StringPool(DA), NextStringPoolNumber(0), StringPref(Pref),
173 AddressPool(), NextAddrPoolNumber(0) {}
Eric Christopherc8a310e2012-12-10 23:34:43 +0000174
Eric Christopherf8194852013-12-05 18:06:10 +0000175 ~DwarfFile();
David Blaikie72f1a3e2013-11-23 01:17:34 +0000176
Eric Christophera5a79422013-12-09 23:32:48 +0000177 const SmallVectorImpl<DwarfUnit *> &getUnits() { return CUs; }
David Blaikiefd1eff52013-11-26 19:14:34 +0000178
Eric Christopherc8a310e2012-12-10 23:34:43 +0000179 /// \brief Compute the size and offset of a DIE given an incoming Offset.
180 unsigned computeSizeAndOffset(DIE *Die, unsigned Offset);
181
182 /// \brief Compute the size and offset of all the DIEs.
183 void computeSizeAndOffsets();
184
185 /// \brief Define a unique number for the abbreviation.
186 void assignAbbrevNumber(DIEAbbrev &Abbrev);
187
188 /// \brief Add a unit to the list of CUs.
Eric Christophera5a79422013-12-09 23:32:48 +0000189 void addUnit(DwarfUnit *CU) { CUs.push_back(CU); }
Eric Christophera2de8262012-12-15 00:04:07 +0000190
191 /// \brief Emit all of the units to the section listed with the given
192 /// abbreviation section.
David Blaikief72ed5f2014-03-24 20:31:01 +0000193 void emitUnits(DwarfDebug *DD, const MCSymbol *ASectionSym);
Eric Christophere698f532012-12-20 21:58:36 +0000194
David Blaikie0504cda2013-12-05 07:43:55 +0000195 /// \brief Emit a set of abbreviations to the specific section.
196 void emitAbbrevs(const MCSection *);
197
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000198 /// \brief Emit all of the strings to the section given.
Eric Christopherdd7b4612013-07-03 21:23:59 +0000199 void emitStrings(const MCSection *StrSection, const MCSection *OffsetSection,
200 const MCSymbol *StrSecSym);
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000201
Eric Christopher962c9082013-01-15 23:56:56 +0000202 /// \brief Emit all of the addresses to the section given.
Eric Christopherdd7b4612013-07-03 21:23:59 +0000203 void emitAddresses(const MCSection *AddrSection);
Eric Christopher962c9082013-01-15 23:56:56 +0000204
Eric Christophere698f532012-12-20 21:58:36 +0000205 /// \brief Returns the entry into the start of the pool.
206 MCSymbol *getStringPoolSym();
207
208 /// \brief Returns an entry into the string pool with the given
209 /// string text.
210 MCSymbol *getStringPoolEntry(StringRef Str);
211
Eric Christopher2cbd5762013-01-07 19:32:41 +0000212 /// \brief Returns the index into the string pool with the given
213 /// string text.
214 unsigned getStringPoolIndex(StringRef Str);
215
Eric Christophere698f532012-12-20 21:58:36 +0000216 /// \brief Returns the string pool.
Eric Christopher27614582013-01-08 22:22:06 +0000217 StrPool *getStringPool() { return &StringPool; }
Eric Christopher962c9082013-01-15 23:56:56 +0000218
219 /// \brief Returns the index into the address pool with the given
220 /// label/symbol.
David Blaikief1a6dea2014-02-15 19:34:03 +0000221 unsigned getAddrPoolIndex(const MCSymbol *Sym, bool TLS = false);
Eric Christopher962c9082013-01-15 23:56:56 +0000222
223 /// \brief Returns the address pool.
224 AddrPool *getAddrPool() { return &AddressPool; }
Eric Christopherc8a310e2012-12-10 23:34:43 +0000225};
226
Eric Christopher670ee0e2013-10-24 21:20:23 +0000227/// \brief Helper used to pair up a symbol and its DWARF compile unit.
Richard Mitton21101b32013-09-19 23:21:01 +0000228struct SymbolCU {
Eric Christopher4287a492013-12-09 23:57:44 +0000229 SymbolCU(DwarfCompileUnit *CU, const MCSymbol *Sym) : Sym(Sym), CU(CU) {}
Richard Mitton21101b32013-09-19 23:21:01 +0000230 const MCSymbol *Sym;
Eric Christopher4287a492013-12-09 23:57:44 +0000231 DwarfCompileUnit *CU;
Richard Mitton21101b32013-09-19 23:21:01 +0000232};
233
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000234/// \brief Collects and handles dwarf debug information.
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000235class DwarfDebug : public AsmPrinterHandler {
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000236 // Target of Dwarf emission.
Chris Lattner3a383cb2010-04-05 00:13:49 +0000237 AsmPrinter *Asm;
Chris Lattneracda87b2010-04-05 05:31:04 +0000238
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000239 // Collected machine module information.
Chris Lattner3a383cb2010-04-05 00:13:49 +0000240 MachineModuleInfo *MMI;
241
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000242 // All DIEValues are allocated through this allocator.
Benjamin Kramer07480082012-06-09 10:34:15 +0000243 BumpPtrAllocator DIEValueAllocator;
244
Eric Christopherbfe7d292013-12-03 22:05:55 +0000245 // Handle to the compile unit used for the inline extension handling,
246 // this is just so that the DIEValue allocator has a place to store
247 // the particular elements.
248 // FIXME: Store these off of DwarfDebug instead?
Eric Christopher4287a492013-12-09 23:57:44 +0000249 DwarfCompileUnit *FirstCU;
Devang Pateleb1bb4e2011-08-16 22:09:43 +0000250
Eric Christopher4287a492013-12-09 23:57:44 +0000251 // Maps MDNode with its corresponding DwarfCompileUnit.
Eric Christopher179fba12014-01-29 22:06:23 +0000252 MapVector<const MDNode *, DwarfCompileUnit *> CUMap;
Bill Wendling2f921f82009-05-15 09:23:25 +0000253
Eric Christopher4287a492013-12-09 23:57:44 +0000254 // Maps subprogram MDNode with its corresponding DwarfCompileUnit.
255 DenseMap<const MDNode *, DwarfCompileUnit *> SPMap;
Devang Pateleb1bb4e2011-08-16 22:09:43 +0000256
Eric Christopher4287a492013-12-09 23:57:44 +0000257 // Maps a CU DIE with its corresponding DwarfCompileUnit.
258 DenseMap<const DIE *, DwarfCompileUnit *> CUDieMap;
Manman Rence20d462013-10-29 22:57:10 +0000259
Eric Christopher47f2be82014-03-20 19:16:20 +0000260 /// Maps MDNodes for type system with the corresponding DIEs. These DIEs can
Manman Ren4dbdc902013-10-31 17:54:35 +0000261 /// be shared across CUs, that is why we keep the map here instead
Eric Christopher4287a492013-12-09 23:57:44 +0000262 /// of in DwarfCompileUnit.
Manman Ren4dbdc902013-10-31 17:54:35 +0000263 DenseMap<const MDNode *, DIE *> MDTypeNodeToDieMap;
264
Alexey Samsonov4436bf02013-10-03 08:54:43 +0000265 // List of all labels used in aranges generation.
266 std::vector<SymbolCU> ArangeLabels;
Richard Mitton21101b32013-09-19 23:21:01 +0000267
Richard Mitton089ed892013-09-23 17:56:20 +0000268 // Size of each symbol emitted (for those symbols that have a specific size).
Eric Christophera5a79422013-12-09 23:32:48 +0000269 DenseMap<const MCSymbol *, uint64_t> SymSize;
Richard Mitton089ed892013-09-23 17:56:20 +0000270
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000271 // Provides a unique id per text section.
Richard Mitton21101b32013-09-19 23:21:01 +0000272 typedef DenseMap<const MCSection *, SmallVector<SymbolCU, 8> > SectionMapType;
273 SectionMapType SectionMap;
Bill Wendling2f921f82009-05-15 09:23:25 +0000274
Eric Christopheraba20dd2013-07-08 21:16:18 +0000275 // List of arguments for current function.
Devang Patel6c622ef2011-03-01 22:58:55 +0000276 SmallVector<DbgVariable *, 8> CurrentFnArguments;
277
Devang Patel7e623022011-08-10 20:55:27 +0000278 LexicalScopes LScopes;
Devang Patel95cd4b92010-03-25 15:09:44 +0000279
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000280 // Collection of abstract subprogram DIEs.
Devang Patela37a95e2010-07-07 22:20:57 +0000281 DenseMap<const MDNode *, DIE *> AbstractSPDies;
282
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000283 // Collection of dbg variables of a scope.
Eric Christophera5a79422013-12-09 23:32:48 +0000284 typedef DenseMap<LexicalScope *, SmallVector<DbgVariable *, 8> >
285 ScopeVariablesMap;
Craig Topper2b4a2012013-07-03 04:40:27 +0000286 ScopeVariablesMap ScopeVariables;
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000287
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000288 // Collection of abstract variables.
Devang Patel32cc43c2010-05-07 20:54:48 +0000289 DenseMap<const MDNode *, DbgVariable *> AbstractVariables;
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000290
Eric Christopher05135fb2014-03-18 02:18:24 +0000291 // Collection of DebugLocEntry.
David Blaikie84d8e182014-03-24 22:38:38 +0000292 SmallVector<SmallVector<DebugLocEntry, 4>, 4> DotDebugLocEntries;
Devang Patel9fc11702010-05-25 23:40:22 +0000293
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000294 // Collection of subprogram DIEs that are marked (at the end of the module)
295 // as DW_AT_inline.
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000296 SmallPtrSet<DIE *, 4> InlinedSubprogramDIEs;
297
Eric Christopher48fef592012-12-20 21:58:40 +0000298 // This is a collection of subprogram MDNodes that are processed to
299 // create DIEs.
Devang Patelf3b2db62010-06-28 18:25:03 +0000300 SmallPtrSet<const MDNode *, 16> ProcessedSPNodes;
301
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000302 // Maps instruction with label emitted before instruction.
Devang Patel6c74a872010-04-27 19:46:33 +0000303 DenseMap<const MachineInstr *, MCSymbol *> LabelsBeforeInsn;
Devang Patel3ebd8932010-04-08 16:50:29 +0000304
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000305 // Maps instruction with label emitted after instruction.
Devang Patel6c74a872010-04-27 19:46:33 +0000306 DenseMap<const MachineInstr *, MCSymbol *> LabelsAfterInsn;
Devang Patel3ebd8932010-04-08 16:50:29 +0000307
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000308 // Every user variable mentioned by a DBG_VALUE instruction in order of
309 // appearance.
Eric Christophera5a79422013-12-09 23:32:48 +0000310 SmallVector<const MDNode *, 8> UserVariables;
Devang Patel002d54d2010-05-26 19:37:24 +0000311
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000312 // For each user variable, keep a list of DBG_VALUE instructions in order.
313 // The list can also contain normal instructions that clobber the previous
314 // DBG_VALUE.
Eric Christophera5a79422013-12-09 23:32:48 +0000315 typedef DenseMap<const MDNode *, SmallVector<const MachineInstr *, 4> >
316 DbgValueHistoryMap;
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000317 DbgValueHistoryMap DbgValues;
Jakob Stoklund Olesenec0ac3c2011-03-22 22:33:08 +0000318
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000319 // Previous instruction's location information. This is used to determine
320 // label location to indicate scope boundries in dwarf debug info.
Chris Lattner915c5f92010-04-02 19:42:39 +0000321 DebugLoc PrevInstLoc;
Devang Patel12563b32010-04-16 23:33:45 +0000322 MCSymbol *PrevLabel;
Devang Patelbd477be2010-03-29 17:20:31 +0000323
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000324 // This location indicates end of function prologue and beginning of function
325 // body.
Devang Patel34a66202011-05-11 19:22:19 +0000326 DebugLoc PrologEndLoc;
327
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000328 // If nonnull, stores the current machine function we're processing.
329 const MachineFunction *CurFn;
330
331 // If nonnull, stores the current machine instruction we're processing.
332 const MachineInstr *CurMI;
333
Eric Christopher384f3fe2014-03-20 19:16:16 +0000334 // If nonnull, stores the section that the previous function was allocated to
335 // emitting.
336 const MCSection *PrevSection;
337
338 // If nonnull, stores the CU in which the previous subprogram was contained.
339 const DwarfCompileUnit *PrevCU;
340
Chris Lattner6629ca92010-04-04 22:59:04 +0000341 // Section Symbols: these are assembler temporary labels that are emitted at
342 // the beginning of each supported dwarf section. These are used to form
343 // section offsets and are created by EmitSectionLabels.
Rafael Espindolaa7160962011-05-06 14:56:22 +0000344 MCSymbol *DwarfInfoSectionSym, *DwarfAbbrevSectionSym;
Devang Patel12563b32010-04-16 23:33:45 +0000345 MCSymbol *DwarfStrSectionSym, *TextSectionSym, *DwarfDebugRangeSectionSym;
Eric Christopher55863be2013-04-07 03:43:09 +0000346 MCSymbol *DwarfDebugLocSectionSym, *DwarfLineSectionSym, *DwarfAddrSectionSym;
Devang Patel9fc11702010-05-25 23:40:22 +0000347 MCSymbol *FunctionBeginSym, *FunctionEndSym;
Eric Christopherd8667202013-12-30 17:22:27 +0000348 MCSymbol *DwarfInfoDWOSectionSym, *DwarfAbbrevDWOSectionSym;
David Blaikiee12ab122014-04-01 16:09:49 +0000349 MCSymbol *DwarfStrDWOSectionSym;
Eric Christopher39eebfa2013-09-30 23:14:16 +0000350 MCSymbol *DwarfGnuPubNamesSectionSym, *DwarfGnuPubTypesSectionSym;
Devang Patel9c160e12010-07-08 20:10:35 +0000351
Nick Lewyckyd1ee7f82011-11-02 20:55:33 +0000352 // As an optimization, there is no need to emit an entry in the directory
Eric Christopher808fd7b2013-07-03 01:57:23 +0000353 // table for the same directory as DW_AT_comp_dir.
Nick Lewyckyd1ee7f82011-11-02 20:55:33 +0000354 StringRef CompilationDir;
355
Eric Christopher0f63d062013-12-03 00:45:45 +0000356 // Counter for assigning globally unique IDs for ranges.
357 unsigned GlobalRangeCount;
358
Eric Christopherc8a310e2012-12-10 23:34:43 +0000359 // Holder for the file specific debug information.
Eric Christopherf8194852013-12-05 18:06:10 +0000360 DwarfFile InfoHolder;
Eric Christopherc8a310e2012-12-10 23:34:43 +0000361
Eric Christopher0aa4a672012-12-10 22:25:41 +0000362 // Holders for the various debug information flags that we might need to
363 // have exposed. See accessor functions below for description.
364
Eric Christopher070bf162013-07-03 01:57:26 +0000365 // Holder for imported entities.
366 typedef SmallVector<std::pair<const MDNode *, const MDNode *>, 32>
Eric Christophera5a79422013-12-09 23:32:48 +0000367 ImportedEntityMap;
Eric Christopher070bf162013-07-03 01:57:26 +0000368 ImportedEntityMap ScopesWithImportedEntities;
369
David Blaikie47f615e2013-12-17 23:32:35 +0000370 // Map from MDNodes for user-defined types to the type units that describe
371 // them.
372 DenseMap<const MDNode *, const DwarfTypeUnit *> DwarfTypeUnits;
Eric Christopher67646432013-07-26 17:02:41 +0000373
Eric Christopher4d36ca02013-08-26 23:24:35 +0000374 // Whether to emit the pubnames/pubtypes sections.
375 bool HasDwarfPubSections;
376
Eric Christopher1ad84572014-01-15 00:04:29 +0000377 // Whether or not to use AT_ranges for compilation units.
378 bool HasCURanges;
379
Eric Christopher2037caf2014-01-28 00:49:26 +0000380 // Whether we emitted a function into a section other than the default
381 // text.
382 bool UsedNonDefaultText;
383
Eric Christopher4d36ca02013-08-26 23:24:35 +0000384 // Version of dwarf we're emitting.
385 unsigned DwarfVersion;
386
Eric Christopher0a13eb32013-11-21 22:56:11 +0000387 // Maps from a type identifier to the actual MDNode.
388 DITypeIdentifierMap TypeIdentifierMap;
389
Eric Christopher42e39942012-11-29 22:56:13 +0000390 // DWARF5 Experimental Options
Eric Christopher7b30f2e42012-11-21 00:34:35 +0000391 bool HasDwarfAccelTables;
Eric Christophercdf218d2012-12-10 19:51:21 +0000392 bool HasSplitDwarf;
Manman Renac8062b2013-07-02 23:40:10 +0000393
Eric Christopherd692c1d2012-12-11 19:42:09 +0000394 // Separated Dwarf Variables
Eric Christopherd79f5482012-12-10 19:51:13 +0000395 // In general these will all be for bits that are left in the
396 // original object file, rather than things that are meant
397 // to be in the .dwo sections.
398
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000399 // Holder for the skeleton information.
Eric Christopherf8194852013-12-05 18:06:10 +0000400 DwarfFile SkeletonHolder;
Eric Christopherd79f5482012-12-10 19:51:13 +0000401
David Blaikie47f4b822014-03-19 00:11:28 +0000402 /// Store file names for type units under fission in a line table header that
403 /// will be emitted into debug_line.dwo.
404 // FIXME: replace this with a map from comp_dir to table so that we can emit
405 // multiple tables during LTO each of which uses directory 0, referencing the
406 // comp_dir of all the type units that use it.
David Blaikie8287aff2014-03-18 02:13:23 +0000407 MCDwarfDwoLineTable SplitTypeUnitFileTable;
David Blaikie4a2f95f2014-03-18 01:17:26 +0000408
David Blaikie47f4b822014-03-19 00:11:28 +0000409 // True iff there are multiple CUs in this module.
410 bool SingleCU;
411
412 MCDwarfDwoLineTable *getDwoLineTable(const DwarfCompileUnit &);
413
Devang Patel7e623022011-08-10 20:55:27 +0000414 void addScopeVariable(LexicalScope *LS, DbgVariable *Var);
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000415
Eric Christophera5a79422013-12-09 23:32:48 +0000416 const SmallVectorImpl<DwarfUnit *> &getUnits() {
417 return InfoHolder.getUnits();
418 }
David Blaikiefd1eff52013-11-26 19:14:34 +0000419
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000420 /// \brief Find abstract variable associated with Var.
Devang Patele1c53f22010-05-20 16:36:41 +0000421 DbgVariable *findAbstractVariable(DIVariable &Var, DebugLoc Loc);
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000422
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000423 /// \brief Find DIE for the given subprogram and attach appropriate
424 /// DW_AT_low_pc and DW_AT_high_pc attributes. If there are global
425 /// variables in this scope then create and insert DIEs for these
426 /// variables.
Eric Christopher4287a492013-12-09 23:57:44 +0000427 DIE *updateSubprogramScopeDIE(DwarfCompileUnit *SPCU, DISubprogram SP);
Bill Wendling2f921f82009-05-15 09:23:25 +0000428
Eric Christopher44e66c12013-12-03 00:45:56 +0000429 /// \brief A helper function to check whether the DIE for a given Scope is
430 /// going to be null.
Manman Ren2312ed32013-09-10 18:40:41 +0000431 bool isLexicalScopeDIENull(LexicalScope *Scope);
Bill Wendling2f921f82009-05-15 09:23:25 +0000432
Eric Christopherbe2513e2013-12-03 00:45:59 +0000433 /// \brief A helper function to construct a RangeSpanList for a given
434 /// lexical scope.
Eric Christopher4287a492013-12-09 23:57:44 +0000435 void addScopeRangeList(DwarfCompileUnit *TheCU, DIE *ScopeDIE,
Eric Christopherbe2513e2013-12-03 00:45:59 +0000436 const SmallVectorImpl<InsnRange> &Range);
437
Eric Christopher77913e0392013-12-03 00:45:54 +0000438 /// \brief Construct new DW_TAG_lexical_block for this scope and
439 /// attach DW_AT_low_pc/DW_AT_high_pc labels.
Eric Christopher4287a492013-12-09 23:57:44 +0000440 DIE *constructLexicalScopeDIE(DwarfCompileUnit *TheCU, LexicalScope *Scope);
Eric Christopher77913e0392013-12-03 00:45:54 +0000441
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000442 /// \brief This scope represents inlined body of a function. Construct
443 /// DIE to represent this concrete inlined copy of the function.
Eric Christopher4287a492013-12-09 23:57:44 +0000444 DIE *constructInlinedScopeDIE(DwarfCompileUnit *TheCU, LexicalScope *Scope);
Devang Patel930143b2009-11-21 02:48:08 +0000445
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000446 /// \brief Construct a DIE for this scope.
Eric Christopher4287a492013-12-09 23:57:44 +0000447 DIE *constructScopeDIE(DwarfCompileUnit *TheCU, LexicalScope *Scope);
Manman Ren2312ed32013-09-10 18:40:41 +0000448 /// A helper function to create children of a Scope DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000449 DIE *createScopeChildrenDIE(DwarfCompileUnit *TheCU, LexicalScope *Scope,
Eric Christophera5a79422013-12-09 23:32:48 +0000450 SmallVectorImpl<DIE *> &Children);
Devang Patel930143b2009-11-21 02:48:08 +0000451
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000452 /// \brief Emit initial Dwarf sections with a label at the start of each one.
Eric Christopher7b30f2e42012-11-21 00:34:35 +0000453 void emitSectionLabels();
Bill Wendling2f921f82009-05-15 09:23:25 +0000454
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000455 /// \brief Compute the size and offset of a DIE given an incoming Offset.
Eric Christopher1f0cbb82012-11-20 22:14:13 +0000456 unsigned computeSizeAndOffset(DIE *Die, unsigned Offset);
Bill Wendling2f921f82009-05-15 09:23:25 +0000457
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000458 /// \brief Compute the size and offset of all the DIEs.
Devang Patel930143b2009-11-21 02:48:08 +0000459 void computeSizeAndOffsets();
Bill Wendling2f921f82009-05-15 09:23:25 +0000460
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000461 /// \brief Attach DW_AT_inline attribute with inlined subprogram DIEs.
Eric Christopher960ac372012-11-22 00:59:49 +0000462 void computeInlinedDIEs();
463
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000464 /// \brief Collect info for variables that were optimized out.
Eric Christopher960ac372012-11-22 00:59:49 +0000465 void collectDeadVariables();
466
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000467 /// \brief Finish off debug information after all functions have been
468 /// processed.
Eric Christopher960ac372012-11-22 00:59:49 +0000469 void finalizeModuleInfo();
470
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000471 /// \brief Emit labels to close any remaining sections that have been left
472 /// open.
Eric Christopher960ac372012-11-22 00:59:49 +0000473 void endSections();
474
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000475 /// \brief Emit the debug info section.
Devang Patel930143b2009-11-21 02:48:08 +0000476 void emitDebugInfo();
Bill Wendling2f921f82009-05-15 09:23:25 +0000477
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000478 /// \brief Emit the abbreviation section.
Eric Christopher38371952012-11-20 23:30:11 +0000479 void emitAbbreviations();
Bill Wendling2f921f82009-05-15 09:23:25 +0000480
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000481 /// \brief Emit the last address of the section and the end of
Bill Wendling2f921f82009-05-15 09:23:25 +0000482 /// the line matrix.
Devang Patel930143b2009-11-21 02:48:08 +0000483 void emitEndOfLineMatrix(unsigned SectionEnd);
Bill Wendling2f921f82009-05-15 09:23:25 +0000484
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000485 /// \brief Emit visible names into a hashed accelerator table section.
Eric Christopher4996c702011-11-07 09:24:32 +0000486 void emitAccelNames();
Eric Christopher27527b22012-11-21 00:03:28 +0000487
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000488 /// \brief Emit objective C classes and categories into a hashed
Eric Christopher4996c702011-11-07 09:24:32 +0000489 /// accelerator table section.
490 void emitAccelObjC();
491
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000492 /// \brief Emit namespace dies into a hashed accelerator table.
Eric Christopher4996c702011-11-07 09:24:32 +0000493 void emitAccelNamespaces();
494
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000495 /// \brief Emit type dies into a hashed accelerator table.
Eric Christopher4996c702011-11-07 09:24:32 +0000496 void emitAccelTypes();
Eric Christopher27527b22012-11-21 00:03:28 +0000497
Krzysztof Parzyszek228daa62013-02-12 18:00:14 +0000498 /// \brief Emit visible names into a debug pubnames section.
Eric Christopherdd1a0122013-09-13 00:35:05 +0000499 /// \param GnuStyle determines whether or not we want to emit
500 /// additional information into the table ala newer gcc for gdb
501 /// index.
502 void emitDebugPubNames(bool GnuStyle = false);
Krzysztof Parzyszek228daa62013-02-12 18:00:14 +0000503
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000504 /// \brief Emit visible types into a debug pubtypes section.
Eric Christopherdd1a0122013-09-13 00:35:05 +0000505 /// \param GnuStyle determines whether or not we want to emit
506 /// additional information into the table ala newer gcc for gdb
507 /// index.
508 void emitDebugPubTypes(bool GnuStyle = false);
Devang Patel04d2f2d2009-11-24 01:14:22 +0000509
David Blaikie0f55e832014-03-11 23:18:15 +0000510 void
511 emitDebugPubSection(bool GnuStyle, const MCSection *PSec, StringRef Name,
512 const StringMap<const DIE *> &(DwarfUnit::*Accessor)()
513 const);
514
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000515 /// \brief Emit visible names into a debug str section.
Devang Patel930143b2009-11-21 02:48:08 +0000516 void emitDebugStr();
Bill Wendling2f921f82009-05-15 09:23:25 +0000517
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000518 /// \brief Emit visible names into a debug loc section.
Devang Patel930143b2009-11-21 02:48:08 +0000519 void emitDebugLoc();
Bill Wendling2f921f82009-05-15 09:23:25 +0000520
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000521 /// \brief Emit visible names into a debug aranges section.
Eric Christopher7b30f2e42012-11-21 00:34:35 +0000522 void emitDebugARanges();
Bill Wendling2f921f82009-05-15 09:23:25 +0000523
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000524 /// \brief Emit visible names into a debug ranges section.
Devang Patel930143b2009-11-21 02:48:08 +0000525 void emitDebugRanges();
Bill Wendling2f921f82009-05-15 09:23:25 +0000526
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000527 /// \brief Emit inline info using custom format.
Devang Patel930143b2009-11-21 02:48:08 +0000528 void emitDebugInlineInfo();
Bill Wendling2b128d72009-05-20 23:19:06 +0000529
Eric Christophercdf218d2012-12-10 19:51:21 +0000530 /// DWARF 5 Experimental Split Dwarf Emitters
Eric Christopher9c2ecd92012-11-30 23:59:06 +0000531
David Blaikie38fe6342014-01-09 04:28:46 +0000532 /// \brief Initialize common features of skeleton units.
533 void initSkeletonUnit(const DwarfUnit *U, DIE *Die, DwarfUnit *NewU);
534
Eric Christophercdf218d2012-12-10 19:51:21 +0000535 /// \brief Construct the split debug info compile unit for the debug info
536 /// section.
Eric Christopher4287a492013-12-09 23:57:44 +0000537 DwarfCompileUnit *constructSkeletonCU(const DwarfCompileUnit *CU);
Eric Christopher9c2ecd92012-11-30 23:59:06 +0000538
David Blaikie15ed5eb2014-01-10 01:38:41 +0000539 /// \brief Construct the split debug info compile unit for the debug info
540 /// section.
David Blaikie15632ae2014-02-12 00:31:30 +0000541 DwarfTypeUnit *constructSkeletonTU(DwarfTypeUnit *TU);
David Blaikie15ed5eb2014-01-10 01:38:41 +0000542
Eric Christopher9c2ecd92012-11-30 23:59:06 +0000543 /// \brief Emit the debug info dwo section.
544 void emitDebugInfoDWO();
545
Eric Christopher3c5a1912012-12-19 22:02:53 +0000546 /// \brief Emit the debug abbrev dwo section.
547 void emitDebugAbbrevDWO();
548
David Blaikie4a2f95f2014-03-18 01:17:26 +0000549 /// \brief Emit the debug line dwo section.
550 void emitDebugLineDWO();
551
Eric Christopher3bf29fd2012-12-27 02:14:01 +0000552 /// \brief Emit the debug str dwo section.
553 void emitDebugStrDWO();
554
David Blaikie3c842622013-12-04 21:31:26 +0000555 /// Flags to let the linker know we have emitted new style pubnames. Only
556 /// emit it here if we don't have a skeleton CU for split dwarf.
Eric Christophera5a79422013-12-09 23:32:48 +0000557 void addGnuPubAttributes(DwarfUnit *U, DIE *D) const;
David Blaikie3c842622013-12-04 21:31:26 +0000558
Eric Christopher4287a492013-12-09 23:57:44 +0000559 /// \brief Create new DwarfCompileUnit for the given metadata node with tag
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000560 /// DW_TAG_compile_unit.
David Blaikie47f4b822014-03-19 00:11:28 +0000561 DwarfCompileUnit *constructDwarfCompileUnit(DICompileUnit DIUnit);
Devang Patel1a0df9a2010-05-10 22:49:55 +0000562
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000563 /// \brief Construct subprogram DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000564 void constructSubprogramDIE(DwarfCompileUnit *TheCU, const MDNode *N);
Bill Wendling2b128d72009-05-20 23:19:06 +0000565
David Blaikie1fd43652013-05-07 21:35:53 +0000566 /// \brief Construct imported_module or imported_declaration DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000567 void constructImportedEntityDIE(DwarfCompileUnit *TheCU, const MDNode *N);
David Blaikief55abea2013-04-22 06:12:31 +0000568
David Blaikie684fc532013-05-06 23:33:07 +0000569 /// \brief Construct import_module DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000570 void constructImportedEntityDIE(DwarfCompileUnit *TheCU, const MDNode *N,
David Blaikie684fc532013-05-06 23:33:07 +0000571 DIE *Context);
572
573 /// \brief Construct import_module DIE.
Eric Christopher4287a492013-12-09 23:57:44 +0000574 void constructImportedEntityDIE(DwarfCompileUnit *TheCU,
Eric Christophera5a79422013-12-09 23:32:48 +0000575 const DIImportedEntity &Module, DIE *Context);
David Blaikie684fc532013-05-06 23:33:07 +0000576
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000577 /// \brief Register a source line with debug info. Returns the unique
578 /// label that was emitted and which provides correspondence to the
579 /// source line list.
Devang Patel34a66202011-05-11 19:22:19 +0000580 void recordSourceLine(unsigned Line, unsigned Col, const MDNode *Scope,
581 unsigned Flags);
Eric Christopher27527b22012-11-21 00:03:28 +0000582
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000583 /// \brief Indentify instructions that are marking the beginning of or
584 /// ending of a scope.
Devang Patel359b0132010-04-08 18:43:56 +0000585 void identifyScopeMarkers();
Devang Patelf1d5a1e2010-04-08 15:37:09 +0000586
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000587 /// \brief If Var is an current function argument that add it in
588 /// CurrentFnArguments list.
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000589 bool addCurrentFnArgument(DbgVariable *Var, LexicalScope *Scope);
Devang Patel6c622ef2011-03-01 22:58:55 +0000590
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000591 /// \brief Populate LexicalScope entries with variables' info.
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000592 void collectVariableInfo(SmallPtrSet<const MDNode *, 16> &ProcessedVars);
Eric Christopher27527b22012-11-21 00:03:28 +0000593
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000594 /// \brief Collect variable information from the side table maintained
595 /// by MMI.
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000596 void collectVariableInfoFromMMITable(SmallPtrSet<const MDNode *, 16> &P);
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000597
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000598 /// \brief Ensure that a label will be emitted before MI.
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000599 void requestLabelBeforeInsn(const MachineInstr *MI) {
Eric Christophera5a79422013-12-09 23:32:48 +0000600 LabelsBeforeInsn.insert(std::make_pair(MI, (MCSymbol *)0));
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000601 }
602
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000603 /// \brief Return Label preceding the instruction.
Eric Christopher962c9082013-01-15 23:56:56 +0000604 MCSymbol *getLabelBeforeInsn(const MachineInstr *MI);
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000605
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000606 /// \brief Ensure that a label will be emitted after MI.
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000607 void requestLabelAfterInsn(const MachineInstr *MI) {
Eric Christophera5a79422013-12-09 23:32:48 +0000608 LabelsAfterInsn.insert(std::make_pair(MI, (MCSymbol *)0));
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000609 }
610
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000611 /// \brief Return Label immediately following the instruction.
Eric Christopher962c9082013-01-15 23:56:56 +0000612 MCSymbol *getLabelAfterInsn(const MachineInstr *MI);
Jakob Stoklund Olesen9a624fa2011-03-26 02:19:36 +0000613
David Blaikie4bd13b72014-03-07 18:49:45 +0000614 void attachLowHighPC(DwarfCompileUnit *Unit, DIE *D, MCSymbol *Begin,
615 MCSymbol *End);
616
Bill Wendling2f921f82009-05-15 09:23:25 +0000617public:
618 //===--------------------------------------------------------------------===//
619 // Main entry points.
620 //
Chris Lattnerf0d6bd32010-04-05 05:11:15 +0000621 DwarfDebug(AsmPrinter *A, Module *M);
Bill Wendling2f921f82009-05-15 09:23:25 +0000622
Manman Ren4dbdc902013-10-31 17:54:35 +0000623 void insertDIE(const MDNode *TypeMD, DIE *Die) {
624 MDTypeNodeToDieMap.insert(std::make_pair(TypeMD, Die));
625 }
626 DIE *getDIE(const MDNode *TypeMD) {
627 return MDTypeNodeToDieMap.lookup(TypeMD);
628 }
629
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000630 /// \brief Emit all Dwarf sections that should come prior to the
Bill Wendling2f921f82009-05-15 09:23:25 +0000631 /// content.
Eric Christopher58f41952012-11-19 22:42:15 +0000632 void beginModule();
Bill Wendling2f921f82009-05-15 09:23:25 +0000633
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000634 /// \brief Emit all Dwarf sections that should come after the content.
Craig Topper7b883b32014-03-08 06:31:39 +0000635 void endModule() override;
Bill Wendling2f921f82009-05-15 09:23:25 +0000636
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000637 /// \brief Gather pre-function debug information.
Craig Topper7b883b32014-03-08 06:31:39 +0000638 void beginFunction(const MachineFunction *MF) override;
Bill Wendling2f921f82009-05-15 09:23:25 +0000639
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000640 /// \brief Gather and emit post-function debug information.
Craig Topper7b883b32014-03-08 06:31:39 +0000641 void endFunction(const MachineFunction *MF) override;
Bill Wendling2f921f82009-05-15 09:23:25 +0000642
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000643 /// \brief Process beginning of an instruction.
Craig Topper7b883b32014-03-08 06:31:39 +0000644 void beginInstruction(const MachineInstr *MI) override;
Bill Wendling2f921f82009-05-15 09:23:25 +0000645
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000646 /// \brief Process end of an instruction.
Craig Topper7b883b32014-03-08 06:31:39 +0000647 void endInstruction() override;
Devang Patelf20c4f72011-04-12 22:53:02 +0000648
Eric Christopher67646432013-07-26 17:02:41 +0000649 /// \brief Add a DIE to the set of types that we're going to pull into
650 /// type units.
David Blaikie15632ae2014-02-12 00:31:30 +0000651 void addDwarfTypeUnitType(DwarfCompileUnit &CU, StringRef Identifier,
David Blaikief645f962014-01-09 03:23:41 +0000652 DIE *Die, DICompositeType CTy);
Eric Christopher67646432013-07-26 17:02:41 +0000653
Richard Mitton21101b32013-09-19 23:21:01 +0000654 /// \brief Add a label so that arange data can be generated for it.
Alexey Samsonov4436bf02013-10-03 08:54:43 +0000655 void addArangeLabel(SymbolCU SCU) { ArangeLabels.push_back(SCU); }
Richard Mitton21101b32013-09-19 23:21:01 +0000656
Richard Mitton089ed892013-09-23 17:56:20 +0000657 /// \brief For symbols that have a size designated (e.g. common symbols),
658 /// this tracks that size.
Craig Topper7b883b32014-03-08 06:31:39 +0000659 void setSymbolSize(const MCSymbol *Sym, uint64_t Size) override {
Eric Christophera5a79422013-12-09 23:32:48 +0000660 SymSize[Sym] = Size;
661 }
Richard Mitton089ed892013-09-23 17:56:20 +0000662
Eric Christophera2de8262012-12-15 00:04:07 +0000663 /// \brief Recursively Emits a debug information entry.
David Blaikieff3ab2c2013-12-05 01:01:41 +0000664 void emitDIE(DIE *Die);
Eric Christophera2de8262012-12-15 00:04:07 +0000665
Eric Christopher55c51812012-11-21 00:03:31 +0000666 // Experimental DWARF5 features.
667
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000668 /// \brief Returns whether or not to emit tables that dwarf consumers can
669 /// use to accelerate lookup.
Eric Christopher411bd592014-03-06 00:00:53 +0000670 bool useDwarfAccelTables() const { return HasDwarfAccelTables; }
Eric Christopher55c51812012-11-21 00:03:31 +0000671
Eric Christopheracdcbdb2012-11-27 22:43:45 +0000672 /// \brief Returns whether or not to change the current debug info for the
Eric Christophercdf218d2012-12-10 19:51:21 +0000673 /// split dwarf proposal support.
Eric Christopher411bd592014-03-06 00:00:53 +0000674 bool useSplitDwarf() const { return HasSplitDwarf; }
Manman Renac8062b2013-07-02 23:40:10 +0000675
676 /// Returns the Dwarf Version.
677 unsigned getDwarfVersion() const { return DwarfVersion; }
Manman Ren60352032013-09-05 18:48:31 +0000678
Eric Christophera27220f2014-03-05 22:41:20 +0000679 /// Returns the section symbol for the .debug_loc section.
680 MCSymbol *getDebugLocSym() const { return DwarfDebugLocSectionSym; }
681
Eric Christopher384f3fe2014-03-20 19:16:16 +0000682 /// Returns the previous section that was emitted into.
683 const MCSection *getPrevSection() const { return PrevSection; }
684
685 /// Returns the previous CU that was being updated
686 const DwarfCompileUnit *getPrevCU() const { return PrevCU; }
687
Eric Christopher4f17ee02014-03-08 00:29:41 +0000688 /// Returns the entries for the .debug_loc section.
David Blaikie84d8e182014-03-24 22:38:38 +0000689 const SmallVectorImpl<SmallVector<DebugLocEntry, 4>> &
690 getDebugLocEntries() const {
Eric Christopher4f17ee02014-03-08 00:29:41 +0000691 return DotDebugLocEntries;
692 }
693
694 /// \brief Emit an entry for the debug loc section. This can be used to
695 /// handle an entry that's going to be emitted into the debug loc section.
Eric Christopher05135fb2014-03-18 02:18:24 +0000696 void emitDebugLocEntry(ByteStreamer &Streamer, const DebugLocEntry &Entry);
Eric Christopher4f17ee02014-03-08 00:29:41 +0000697
David Blaikie0e84adc2014-04-01 16:17:41 +0000698 /// Emit the location for a debug loc entry, including the size header.
699 void emitDebugLocEntryLocation(const DebugLocEntry &Entry);
700
Eric Christopher87b9c492013-10-05 00:32:34 +0000701 /// Find the MDNode for the given reference.
702 template <typename T> T resolve(DIRef<T> Ref) const {
Manman Ren34b3dcc2013-09-10 18:30:07 +0000703 return Ref.resolve(TypeIdentifierMap);
704 }
Manman Ren60352032013-09-05 18:48:31 +0000705
Adrian Prantl1a1647c2014-03-18 02:34:58 +0000706 /// \brief Return the TypeIdentifierMap.
Eric Christopherc0bd5f82014-03-18 20:39:54 +0000707 const DITypeIdentifierMap &getTypeIdentifierMap() const {
Adrian Prantl1a1647c2014-03-18 02:34:58 +0000708 return TypeIdentifierMap;
709 }
710
Eric Christopherdd508382014-03-06 00:00:56 +0000711 /// Find the DwarfCompileUnit for the given CU Die.
712 DwarfCompileUnit *lookupUnit(const DIE *CU) const {
713 return CUDieMap.lookup(CU);
714 }
Manman Ren3eb9dff2013-09-09 19:05:21 +0000715 /// isSubprogramContext - Return true if Context is either a subprogram
716 /// or another context nested inside a subprogram.
717 bool isSubprogramContext(const MDNode *Context);
Devang Patelf6eeaeb2009-11-10 23:06:00 +0000718};
Bill Wendling2f921f82009-05-15 09:23:25 +0000719} // End of namespace llvm
720
721#endif