| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 1 | //===-- 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 |  | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 17 | #include "llvm/CodeGen/AsmPrinter.h" | 
| Devang Patel | 9fc1170 | 2010-05-25 23:40:22 +0000 | [diff] [blame] | 18 | #include "llvm/CodeGen/MachineLocation.h" | 
| Chris Lattner | 28f2fda | 2010-04-05 06:12:01 +0000 | [diff] [blame] | 19 | #include "DIE.h" | 
| Devang Patel | 018b29b | 2010-01-19 06:19:05 +0000 | [diff] [blame] | 20 | #include "llvm/ADT/DenseMap.h" | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 21 | #include "llvm/ADT/FoldingSet.h" | 
| Chris Lattner | 3f3fb97 | 2010-04-05 05:24:55 +0000 | [diff] [blame] | 22 | #include "llvm/ADT/SmallPtrSet.h" | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 23 | #include "llvm/ADT/StringMap.h" | 
|  | 24 | #include "llvm/ADT/UniqueVector.h" | 
| Chris Lattner | 3f3fb97 | 2010-04-05 05:24:55 +0000 | [diff] [blame] | 25 | #include "llvm/Support/Allocator.h" | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 26 |  | 
|  | 27 | namespace llvm { | 
|  | 28 |  | 
|  | 29 | class CompileUnit; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 30 | class DbgConcreteScope; | 
| Nick Lewycky | a1c09d6 | 2009-11-17 09:17:08 +0000 | [diff] [blame] | 31 | class DbgScope; | 
|  | 32 | class DbgVariable; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 33 | class MachineFrameInfo; | 
|  | 34 | class MachineModuleInfo; | 
| Devang Patel | 173b2b9 | 2010-04-28 01:03:09 +0000 | [diff] [blame] | 35 | class MachineOperand; | 
| Chris Lattner | 7b26fce | 2009-08-22 20:48:53 +0000 | [diff] [blame] | 36 | class MCAsmInfo; | 
| Chris Lattner | 3f3fb97 | 2010-04-05 05:24:55 +0000 | [diff] [blame] | 37 | class DIEAbbrev; | 
|  | 38 | class DIE; | 
|  | 39 | class DIEBlock; | 
|  | 40 | class DIEEntry; | 
|  | 41 |  | 
|  | 42 | class DIEnumerator; | 
|  | 43 | class DIDescriptor; | 
|  | 44 | class DIVariable; | 
|  | 45 | class DIGlobal; | 
|  | 46 | class DIGlobalVariable; | 
|  | 47 | class DISubprogram; | 
|  | 48 | class DIBasicType; | 
|  | 49 | class DIDerivedType; | 
|  | 50 | class DIType; | 
|  | 51 | class DINameSpace; | 
|  | 52 | class DISubrange; | 
|  | 53 | class DICompositeType; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 54 |  | 
|  | 55 | //===----------------------------------------------------------------------===// | 
|  | 56 | /// SrcLineInfo - This class is used to record source line correspondence. | 
|  | 57 | /// | 
| Nick Lewycky | a1c09d6 | 2009-11-17 09:17:08 +0000 | [diff] [blame] | 58 | class SrcLineInfo { | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 59 | unsigned Line;                     // Source line number. | 
|  | 60 | unsigned Column;                   // Source column. | 
|  | 61 | unsigned SourceID;                 // Source ID number. | 
| Chris Lattner | b4666f4 | 2010-03-14 08:15:55 +0000 | [diff] [blame] | 62 | MCSymbol *Label;                   // Label in code ID number. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 63 | public: | 
| Chris Lattner | b4666f4 | 2010-03-14 08:15:55 +0000 | [diff] [blame] | 64 | SrcLineInfo(unsigned L, unsigned C, unsigned S, MCSymbol *label) | 
|  | 65 | : Line(L), Column(C), SourceID(S), Label(label) {} | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 66 |  | 
|  | 67 | // Accessors | 
|  | 68 | unsigned getLine() const { return Line; } | 
|  | 69 | unsigned getColumn() const { return Column; } | 
|  | 70 | unsigned getSourceID() const { return SourceID; } | 
| Chris Lattner | b4666f4 | 2010-03-14 08:15:55 +0000 | [diff] [blame] | 71 | MCSymbol *getLabel() const { return Label; } | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 72 | }; | 
|  | 73 |  | 
| Chris Lattner | 3a383cb | 2010-04-05 00:13:49 +0000 | [diff] [blame] | 74 | class DwarfDebug { | 
|  | 75 | /// Asm - Target of Dwarf emission. | 
|  | 76 | AsmPrinter *Asm; | 
| Chris Lattner | acda87b | 2010-04-05 05:31:04 +0000 | [diff] [blame] | 77 |  | 
| Chris Lattner | 3a383cb | 2010-04-05 00:13:49 +0000 | [diff] [blame] | 78 | /// MMI - Collected machine module information. | 
|  | 79 | MachineModuleInfo *MMI; | 
|  | 80 |  | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 81 | //===--------------------------------------------------------------------===// | 
|  | 82 | // Attributes used to construct specific Dwarf sections. | 
|  | 83 | // | 
|  | 84 |  | 
| Devang Patel | 1a0df9a | 2010-05-10 22:49:55 +0000 | [diff] [blame] | 85 | CompileUnit *FirstCU; | 
|  | 86 | DenseMap <const MDNode *, CompileUnit *> CUMap; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 87 |  | 
|  | 88 | /// AbbreviationsSet - Used to uniquely define abbreviations. | 
|  | 89 | /// | 
|  | 90 | FoldingSet<DIEAbbrev> AbbreviationsSet; | 
|  | 91 |  | 
|  | 92 | /// Abbreviations - A list of all the unique abbreviations in use. | 
|  | 93 | /// | 
|  | 94 | std::vector<DIEAbbrev *> Abbreviations; | 
|  | 95 |  | 
|  | 96 | /// DirectoryIdMap - Directory name to directory id map. | 
|  | 97 | /// | 
|  | 98 | StringMap<unsigned> DirectoryIdMap; | 
|  | 99 |  | 
|  | 100 | /// DirectoryNames - A list of directory names. | 
|  | 101 | SmallVector<std::string, 8> DirectoryNames; | 
|  | 102 |  | 
|  | 103 | /// SourceFileIdMap - Source file name to source file id map. | 
|  | 104 | /// | 
|  | 105 | StringMap<unsigned> SourceFileIdMap; | 
|  | 106 |  | 
|  | 107 | /// SourceFileNames - A list of source file names. | 
|  | 108 | SmallVector<std::string, 8> SourceFileNames; | 
|  | 109 |  | 
|  | 110 | /// SourceIdMap - Source id map, i.e. pair of directory id and source file | 
|  | 111 | /// id mapped to a unique id. | 
|  | 112 | DenseMap<std::pair<unsigned, unsigned>, unsigned> SourceIdMap; | 
|  | 113 |  | 
|  | 114 | /// SourceIds - Reverse map from source id to directory id + file id pair. | 
|  | 115 | /// | 
|  | 116 | SmallVector<std::pair<unsigned, unsigned>, 8> SourceIds; | 
|  | 117 |  | 
| Dan Gohman | 4a61882 | 2010-02-10 16:03:48 +0000 | [diff] [blame] | 118 | /// Lines - List of source line correspondence. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 119 | std::vector<SrcLineInfo> Lines; | 
|  | 120 |  | 
| Benjamin Kramer | 74729ae | 2010-03-31 19:34:01 +0000 | [diff] [blame] | 121 | /// DIEBlocks - A list of all the DIEBlocks in use. | 
|  | 122 | std::vector<DIEBlock *> DIEBlocks; | 
|  | 123 |  | 
|  | 124 | // DIEValueAllocator - All DIEValues are allocated through this allocator. | 
|  | 125 | BumpPtrAllocator DIEValueAllocator; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 126 |  | 
| Chris Lattner | b7aa952 | 2010-03-13 02:17:42 +0000 | [diff] [blame] | 127 | /// StringPool - A String->Symbol mapping of strings used by indirect | 
|  | 128 | /// references. | 
|  | 129 | StringMap<std::pair<MCSymbol*, unsigned> > StringPool; | 
|  | 130 | unsigned NextStringPoolNumber; | 
|  | 131 |  | 
|  | 132 | MCSymbol *getStringPoolEntry(StringRef Str); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 133 |  | 
|  | 134 | /// SectionMap - Provides a unique id per text section. | 
|  | 135 | /// | 
| Chris Lattner | 4d2c0f9 | 2009-07-31 18:48:30 +0000 | [diff] [blame] | 136 | UniqueVector<const MCSection*> SectionMap; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 137 |  | 
|  | 138 | /// SectionSourceLines - Tracks line numbers per text section. | 
|  | 139 | /// | 
|  | 140 | std::vector<std::vector<SrcLineInfo> > SectionSourceLines; | 
|  | 141 |  | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 142 | // CurrentFnDbgScope - Top level scope for the current function. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 143 | // | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 144 | DbgScope *CurrentFnDbgScope; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 145 |  | 
| Jeffrey Yasskin | 35b4e4f | 2010-03-12 17:45:06 +0000 | [diff] [blame] | 146 | /// DbgScopeMap - Tracks the scopes in the current function.  Owns the | 
|  | 147 | /// contained DbgScope*s. | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 148 | /// | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 149 | DenseMap<const MDNode *, DbgScope *> DbgScopeMap; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 150 |  | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 151 | /// ConcreteScopes - Tracks the concrete scopees in the current function. | 
|  | 152 | /// These scopes are also included in DbgScopeMap. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 153 | DenseMap<const MDNode *, DbgScope *> ConcreteScopes; | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 154 |  | 
|  | 155 | /// AbstractScopes - Tracks the abstract scopes a module. These scopes are | 
| Jeffrey Yasskin | 35b4e4f | 2010-03-12 17:45:06 +0000 | [diff] [blame] | 156 | /// not included DbgScopeMap.  AbstractScopes owns its DbgScope*s. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 157 | DenseMap<const MDNode *, DbgScope *> AbstractScopes; | 
| Devang Patel | 95cd4b9 | 2010-03-25 15:09:44 +0000 | [diff] [blame] | 158 |  | 
| Devang Patel | a37a95e | 2010-07-07 22:20:57 +0000 | [diff] [blame] | 159 | /// AbstractSPDies - Collection of abstract subprogram DIEs. | 
|  | 160 | DenseMap<const MDNode *, DIE *> AbstractSPDies; | 
|  | 161 |  | 
| Devang Patel | 95cd4b9 | 2010-03-25 15:09:44 +0000 | [diff] [blame] | 162 | /// AbstractScopesList - Tracks abstract scopes constructed while processing | 
|  | 163 | /// a function. This list is cleared during endFunction(). | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 164 | SmallVector<DbgScope *, 4>AbstractScopesList; | 
|  | 165 |  | 
| Jeffrey Yasskin | 35b4e4f | 2010-03-12 17:45:06 +0000 | [diff] [blame] | 166 | /// AbstractVariables - Collection on abstract variables.  Owned by the | 
|  | 167 | /// DbgScopes in AbstractScopes. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 168 | DenseMap<const MDNode *, DbgVariable *> AbstractVariables; | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 169 |  | 
| Devang Patel | e1c53f2 | 2010-05-20 16:36:41 +0000 | [diff] [blame] | 170 | /// DbgVariableToFrameIndexMap - Tracks frame index used to find | 
|  | 171 | /// variable's value. | 
|  | 172 | DenseMap<const DbgVariable *, int> DbgVariableToFrameIndexMap; | 
|  | 173 |  | 
|  | 174 | /// DbgVariableToDbgInstMap - Maps DbgVariable to corresponding DBG_VALUE | 
|  | 175 | /// machine instruction. | 
|  | 176 | DenseMap<const DbgVariable *, const MachineInstr *> DbgVariableToDbgInstMap; | 
|  | 177 |  | 
|  | 178 | /// DbgVariableLabelsMap - Maps DbgVariable to corresponding MCSymbol. | 
|  | 179 | DenseMap<const DbgVariable *, const MCSymbol *> DbgVariableLabelsMap; | 
|  | 180 |  | 
| Devang Patel | 9fc1170 | 2010-05-25 23:40:22 +0000 | [diff] [blame] | 181 | /// DotDebugLocEntry - This struct describes location entries emitted in | 
|  | 182 | /// .debug_loc section. | 
|  | 183 | typedef struct DotDebugLocEntry { | 
|  | 184 | const MCSymbol *Begin; | 
|  | 185 | const MCSymbol *End; | 
|  | 186 | MachineLocation Loc; | 
|  | 187 | DotDebugLocEntry() : Begin(0), End(0) {} | 
|  | 188 | DotDebugLocEntry(const MCSymbol *B, const MCSymbol *E, | 
|  | 189 | MachineLocation &L) : Begin(B), End(E), Loc(L) {} | 
|  | 190 | /// Empty entries are also used as a trigger to emit temp label. Such | 
|  | 191 | /// labels are referenced is used to find debug_loc offset for a given DIE. | 
|  | 192 | bool isEmpty() { return Begin == 0 && End == 0; } | 
|  | 193 | } DotDebugLocEntry; | 
|  | 194 |  | 
|  | 195 | /// DotDebugLocEntries - Collection of DotDebugLocEntry. | 
|  | 196 | SmallVector<DotDebugLocEntry, 4> DotDebugLocEntries; | 
|  | 197 |  | 
|  | 198 | /// UseDotDebugLocEntry - DW_AT_location attributes for the DIEs in this set | 
|  | 199 | /// idetifies corresponding .debug_loc entry offset. | 
|  | 200 | SmallPtrSet<const DIE *, 4> UseDotDebugLocEntry; | 
|  | 201 |  | 
| Devang Patel | e1c53f2 | 2010-05-20 16:36:41 +0000 | [diff] [blame] | 202 | /// VarToAbstractVarMap - Maps DbgVariable with corresponding Abstract | 
|  | 203 | /// DbgVariable, if any. | 
|  | 204 | DenseMap<const DbgVariable *, const DbgVariable *> VarToAbstractVarMap; | 
|  | 205 |  | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 206 | /// InliendSubprogramDIEs - Collection of subprgram DIEs that are marked | 
|  | 207 | /// (at the end of the module) as DW_AT_inline. | 
|  | 208 | SmallPtrSet<DIE *, 4> InlinedSubprogramDIEs; | 
|  | 209 |  | 
| Devang Patel | 3d6c40c | 2010-04-15 00:02:49 +0000 | [diff] [blame] | 210 | /// ContainingTypeMap - This map is used to keep track of subprogram DIEs that | 
|  | 211 | /// need DW_AT_containing_type attribute. This attribute points to a DIE that | 
|  | 212 | /// corresponds to the MDNode mapped with the subprogram DIE. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 213 | DenseMap<DIE *, const MDNode *> ContainingTypeMap; | 
| Devang Patel | eb57c59 | 2009-12-03 19:11:07 +0000 | [diff] [blame] | 214 |  | 
| Devang Patel | a081308 | 2010-05-19 21:58:28 +0000 | [diff] [blame] | 215 | typedef SmallVector<DbgScope *, 2> ScopeVector; | 
| Devang Patel | fb6f22f | 2010-06-28 05:59:13 +0000 | [diff] [blame] | 216 |  | 
| Devang Patel | 3ebd893 | 2010-04-08 16:50:29 +0000 | [diff] [blame] | 217 | SmallPtrSet<const MachineInstr *, 8> InsnsEndScopeSet; | 
| Devang Patel | 75cc16c | 2009-10-01 20:31:14 +0000 | [diff] [blame] | 218 |  | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 219 | /// InlineInfo - Keep track of inlined functions and their location.  This | 
|  | 220 | /// information is used to populate debug_inlined section. | 
| Devang Patel | 9fc1170 | 2010-05-25 23:40:22 +0000 | [diff] [blame] | 221 | typedef std::pair<const MCSymbol *, DIE *> InlineInfoLabels; | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 222 | DenseMap<const MDNode *, SmallVector<InlineInfoLabels, 4> > InlineInfo; | 
|  | 223 | SmallVector<const MDNode *, 4> InlinedSPNodes; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 224 |  | 
| Devang Patel | f3b2db6 | 2010-06-28 18:25:03 +0000 | [diff] [blame] | 225 | // ProcessedSPNodes - This is a collection of subprogram MDNodes that | 
|  | 226 | // are processed to create DIEs. | 
|  | 227 | SmallPtrSet<const MDNode *, 16> ProcessedSPNodes; | 
|  | 228 |  | 
| Devang Patel | 6c74a87 | 2010-04-27 19:46:33 +0000 | [diff] [blame] | 229 | /// LabelsBeforeInsn - Maps instruction with label emitted before | 
| Devang Patel | 3ebd893 | 2010-04-08 16:50:29 +0000 | [diff] [blame] | 230 | /// instruction. | 
| Devang Patel | 6c74a87 | 2010-04-27 19:46:33 +0000 | [diff] [blame] | 231 | DenseMap<const MachineInstr *, MCSymbol *> LabelsBeforeInsn; | 
| Devang Patel | 3ebd893 | 2010-04-08 16:50:29 +0000 | [diff] [blame] | 232 |  | 
| Devang Patel | 6c74a87 | 2010-04-27 19:46:33 +0000 | [diff] [blame] | 233 | /// LabelsAfterInsn - Maps instruction with label emitted after | 
| Devang Patel | 3ebd893 | 2010-04-08 16:50:29 +0000 | [diff] [blame] | 234 | /// instruction. | 
| Devang Patel | 6c74a87 | 2010-04-27 19:46:33 +0000 | [diff] [blame] | 235 | DenseMap<const MachineInstr *, MCSymbol *> LabelsAfterInsn; | 
| Devang Patel | 3ebd893 | 2010-04-08 16:50:29 +0000 | [diff] [blame] | 236 |  | 
| Devang Patel | 002d54d | 2010-05-26 19:37:24 +0000 | [diff] [blame] | 237 | /// insnNeedsLabel - Collection of instructions that need a label to mark | 
|  | 238 | /// a debuggging information entity. | 
|  | 239 | SmallPtrSet<const MachineInstr *, 8> InsnNeedsLabel; | 
|  | 240 |  | 
| Devang Patel | 12563b3 | 2010-04-16 23:33:45 +0000 | [diff] [blame] | 241 | SmallVector<const MCSymbol *, 8> DebugRangeSymbols; | 
| Devang Patel | 6adc562 | 2010-04-22 20:56:35 +0000 | [diff] [blame] | 242 |  | 
| Devang Patel | bd477be | 2010-03-29 17:20:31 +0000 | [diff] [blame] | 243 | /// Previous instruction's location information. This is used to determine | 
|  | 244 | /// label location to indicate scope boundries in dwarf debug info. | 
| Chris Lattner | 915c5f9 | 2010-04-02 19:42:39 +0000 | [diff] [blame] | 245 | DebugLoc PrevInstLoc; | 
| Devang Patel | 12563b3 | 2010-04-16 23:33:45 +0000 | [diff] [blame] | 246 | MCSymbol *PrevLabel; | 
| Devang Patel | bd477be | 2010-03-29 17:20:31 +0000 | [diff] [blame] | 247 |  | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 248 | struct FunctionDebugFrameInfo { | 
|  | 249 | unsigned Number; | 
|  | 250 | std::vector<MachineMove> Moves; | 
|  | 251 |  | 
|  | 252 | FunctionDebugFrameInfo(unsigned Num, const std::vector<MachineMove> &M) | 
|  | 253 | : Number(Num), Moves(M) {} | 
|  | 254 | }; | 
|  | 255 |  | 
|  | 256 | std::vector<FunctionDebugFrameInfo> DebugFrames; | 
|  | 257 |  | 
| Chris Lattner | 6629ca9 | 2010-04-04 22:59:04 +0000 | [diff] [blame] | 258 | // Section Symbols: these are assembler temporary labels that are emitted at | 
|  | 259 | // the beginning of each supported dwarf section.  These are used to form | 
|  | 260 | // section offsets and are created by EmitSectionLabels. | 
|  | 261 | MCSymbol *DwarfFrameSectionSym, *DwarfInfoSectionSym, *DwarfAbbrevSectionSym; | 
| Devang Patel | 12563b3 | 2010-04-16 23:33:45 +0000 | [diff] [blame] | 262 | MCSymbol *DwarfStrSectionSym, *TextSectionSym, *DwarfDebugRangeSectionSym; | 
| Devang Patel | 9fc1170 | 2010-05-25 23:40:22 +0000 | [diff] [blame] | 263 | MCSymbol *DwarfDebugLocSectionSym; | 
| Devang Patel | 24bc1b5 | 2010-06-29 20:17:53 +0000 | [diff] [blame] | 264 | MCSymbol *DwarfDebugLineSectionSym, *CurrentLineSectionSym; | 
| Devang Patel | 9fc1170 | 2010-05-25 23:40:22 +0000 | [diff] [blame] | 265 | MCSymbol *FunctionBeginSym, *FunctionEndSym; | 
| Devang Patel | 9c160e1 | 2010-07-08 20:10:35 +0000 | [diff] [blame] | 266 |  | 
|  | 267 | DIEInteger *DIEIntegerOne; | 
| Chris Lattner | 6629ca9 | 2010-04-04 22:59:04 +0000 | [diff] [blame] | 268 | private: | 
|  | 269 |  | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 270 | /// getSourceDirectoryAndFileIds - Return the directory and file ids that | 
|  | 271 | /// maps to the source id. Source id starts at 1. | 
|  | 272 | std::pair<unsigned, unsigned> | 
|  | 273 | getSourceDirectoryAndFileIds(unsigned SId) const { | 
|  | 274 | return SourceIds[SId-1]; | 
|  | 275 | } | 
|  | 276 |  | 
|  | 277 | /// getNumSourceDirectories - Return the number of source directories in the | 
|  | 278 | /// debug info. | 
|  | 279 | unsigned getNumSourceDirectories() const { | 
|  | 280 | return DirectoryNames.size(); | 
|  | 281 | } | 
|  | 282 |  | 
|  | 283 | /// getSourceDirectoryName - Return the name of the directory corresponding | 
|  | 284 | /// to the id. | 
|  | 285 | const std::string &getSourceDirectoryName(unsigned Id) const { | 
|  | 286 | return DirectoryNames[Id - 1]; | 
|  | 287 | } | 
|  | 288 |  | 
|  | 289 | /// getSourceFileName - Return the name of the source file corresponding | 
|  | 290 | /// to the id. | 
|  | 291 | const std::string &getSourceFileName(unsigned Id) const { | 
|  | 292 | return SourceFileNames[Id - 1]; | 
|  | 293 | } | 
|  | 294 |  | 
|  | 295 | /// getNumSourceIds - Return the number of unique source ids. | 
|  | 296 | unsigned getNumSourceIds() const { | 
|  | 297 | return SourceIds.size(); | 
|  | 298 | } | 
|  | 299 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 300 | /// assignAbbrevNumber - Define a unique number for the abbreviation. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 301 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 302 | void assignAbbrevNumber(DIEAbbrev &Abbrev); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 303 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 304 | /// createDIEEntry - Creates a new DIEEntry to be a proxy for a debug | 
| Bill Wendling | bcad77a | 2009-05-20 23:24:48 +0000 | [diff] [blame] | 305 | /// information entry. | 
| Jeffrey Yasskin | 35b4e4f | 2010-03-12 17:45:06 +0000 | [diff] [blame] | 306 | DIEEntry *createDIEEntry(DIE *Entry); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 307 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 308 | /// addUInt - Add an unsigned integer attribute data and value. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 309 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 310 | void addUInt(DIE *Die, unsigned Attribute, unsigned Form, uint64_t Integer); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 311 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 312 | /// addSInt - Add an signed integer attribute data and value. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 313 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 314 | void addSInt(DIE *Die, unsigned Attribute, unsigned Form, int64_t Integer); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 315 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 316 | /// addString - Add a string attribute data and value. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 317 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 318 | void addString(DIE *Die, unsigned Attribute, unsigned Form, | 
| Devang Patel | b3e0168 | 2009-11-24 19:42:17 +0000 | [diff] [blame] | 319 | const StringRef Str); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 320 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 321 | /// addLabel - Add a Dwarf label attribute data and value. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 322 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 323 | void addLabel(DIE *Die, unsigned Attribute, unsigned Form, | 
| Chris Lattner | bc9210c | 2010-03-08 22:23:36 +0000 | [diff] [blame] | 324 | const MCSymbol *Label); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 325 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 326 | /// addDelta - Add a label delta attribute data and value. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 327 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 328 | void addDelta(DIE *Die, unsigned Attribute, unsigned Form, | 
| Chris Lattner | bc9210c | 2010-03-08 22:23:36 +0000 | [diff] [blame] | 329 | const MCSymbol *Hi, const MCSymbol *Lo); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 330 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 331 | /// addDIEEntry - Add a DIE attribute data and value. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 332 | /// | 
| Chris Lattner | 3f3fb97 | 2010-04-05 05:24:55 +0000 | [diff] [blame] | 333 | void addDIEEntry(DIE *Die, unsigned Attribute, unsigned Form, DIE *Entry); | 
|  | 334 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 335 | /// addBlock - Add block data. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 336 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 337 | void addBlock(DIE *Die, unsigned Attribute, unsigned Form, DIEBlock *Block); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 338 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 339 | /// addSourceLine - Add location information to specified debug information | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 340 | /// entry. | 
| Devang Patel | b6511a3 | 2010-08-09 20:20:05 +0000 | [diff] [blame] | 341 | void addSourceLine(DIE *Die, const DIVariable V); | 
|  | 342 | void addSourceLine(DIE *Die, const DIGlobalVariable G); | 
|  | 343 | void addSourceLine(DIE *Die, const DISubprogram SP); | 
|  | 344 | void addSourceLine(DIE *Die, const DIType Ty); | 
|  | 345 | void addSourceLine(DIE *Die, const DINameSpace NS); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 346 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 347 | /// addAddress - Add an address attribute to a die based on the location | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 348 | /// provided. | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 349 | void addAddress(DIE *Die, unsigned Attribute, | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 350 | const MachineLocation &Location); | 
|  | 351 |  | 
| Devang Patel | 173b2b9 | 2010-04-28 01:03:09 +0000 | [diff] [blame] | 352 | /// addRegisterAddress - Add register location entry in variable DIE. | 
| Devang Patel | e1c53f2 | 2010-05-20 16:36:41 +0000 | [diff] [blame] | 353 | bool addRegisterAddress(DIE *Die, const MCSymbol *VS, const MachineOperand &MO); | 
| Devang Patel | 173b2b9 | 2010-04-28 01:03:09 +0000 | [diff] [blame] | 354 |  | 
|  | 355 | /// addConstantValue - Add constant value entry in variable DIE. | 
| Devang Patel | e1c53f2 | 2010-05-20 16:36:41 +0000 | [diff] [blame] | 356 | bool addConstantValue(DIE *Die, const MCSymbol *VS, const MachineOperand &MO); | 
| Devang Patel | 173b2b9 | 2010-04-28 01:03:09 +0000 | [diff] [blame] | 357 |  | 
|  | 358 | /// addConstantFPValue - Add constant value entry in variable DIE. | 
| Devang Patel | e1c53f2 | 2010-05-20 16:36:41 +0000 | [diff] [blame] | 359 | bool addConstantFPValue(DIE *Die, const MCSymbol *VS, const MachineOperand &MO); | 
| Devang Patel | 173b2b9 | 2010-04-28 01:03:09 +0000 | [diff] [blame] | 360 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 361 | /// addComplexAddress - Start with the address based on the location provided, | 
| Mike Stump | 14cf8ec | 2009-09-30 00:08:22 +0000 | [diff] [blame] | 362 | /// and generate the DWARF information necessary to find the actual variable | 
|  | 363 | /// (navigating the extra location information encoded in the type) based on | 
|  | 364 | /// the starting location.  Add the DWARF information to the die. | 
|  | 365 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 366 | void addComplexAddress(DbgVariable *&DV, DIE *Die, unsigned Attribute, | 
| Mike Stump | 14cf8ec | 2009-09-30 00:08:22 +0000 | [diff] [blame] | 367 | const MachineLocation &Location); | 
|  | 368 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 369 | // FIXME: Should be reformulated in terms of addComplexAddress. | 
|  | 370 | /// addBlockByrefAddress - Start with the address based on the location | 
| Caroline Tice | c87c1e2 | 2009-08-31 21:19:37 +0000 | [diff] [blame] | 371 | /// provided, and generate the DWARF information necessary to find the | 
|  | 372 | /// actual Block variable (navigating the Block struct) based on the | 
| Mike Stump | 14cf8ec | 2009-09-30 00:08:22 +0000 | [diff] [blame] | 373 | /// starting location.  Add the DWARF information to the die.  Obsolete, | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 374 | /// please use addComplexAddress instead. | 
| Caroline Tice | c87c1e2 | 2009-08-31 21:19:37 +0000 | [diff] [blame] | 375 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 376 | void addBlockByrefAddress(DbgVariable *&DV, DIE *Die, unsigned Attribute, | 
| Caroline Tice | c87c1e2 | 2009-08-31 21:19:37 +0000 | [diff] [blame] | 377 | const MachineLocation &Location); | 
|  | 378 |  | 
| Devang Patel | 6d9f9fe | 2010-08-09 21:01:39 +0000 | [diff] [blame] | 379 | /// addVariableAddress - Add DW_AT_location attribute for a DbgVariable. | 
|  | 380 | void addVariableAddress(DbgVariable *&DV, DIE *Die, unsigned Attribute, | 
|  | 381 | const MachineLocation &Location); | 
|  | 382 |  | 
| Devang Patel | 2b75ed2 | 2009-12-10 19:14:49 +0000 | [diff] [blame] | 383 | /// addToContextOwner - Add Die into the list of its context owner's children. | 
|  | 384 | void addToContextOwner(DIE *Die, DIDescriptor Context); | 
|  | 385 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 386 | /// addType - Add a new type attribute to the specified entity. | 
| Devang Patel | 9ccfb64 | 2009-12-09 18:24:21 +0000 | [diff] [blame] | 387 | void addType(DIE *Entity, DIType Ty); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 388 |  | 
| Devang Patel | 1f4690c | 2009-12-15 19:16:48 +0000 | [diff] [blame] | 389 |  | 
|  | 390 | /// getOrCreateNameSpace - Create a DIE for DINameSpace. | 
|  | 391 | DIE *getOrCreateNameSpace(DINameSpace NS); | 
|  | 392 |  | 
| Devang Patel | b5b60ea | 2009-12-10 18:05:33 +0000 | [diff] [blame] | 393 | /// getOrCreateTypeDIE - Find existing DIE or create new DIE for the | 
|  | 394 | /// given DIType. | 
|  | 395 | DIE *getOrCreateTypeDIE(DIType Ty); | 
|  | 396 |  | 
| Devang Patel | 04d2f2d | 2009-11-24 01:14:22 +0000 | [diff] [blame] | 397 | void addPubTypes(DISubprogram SP); | 
|  | 398 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 399 | /// constructTypeDIE - Construct basic type die from DIBasicType. | 
| Devang Patel | 9ccfb64 | 2009-12-09 18:24:21 +0000 | [diff] [blame] | 400 | void constructTypeDIE(DIE &Buffer, | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 401 | DIBasicType BTy); | 
|  | 402 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 403 | /// constructTypeDIE - Construct derived type die from DIDerivedType. | 
| Devang Patel | 9ccfb64 | 2009-12-09 18:24:21 +0000 | [diff] [blame] | 404 | void constructTypeDIE(DIE &Buffer, | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 405 | DIDerivedType DTy); | 
|  | 406 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 407 | /// constructTypeDIE - Construct type DIE from DICompositeType. | 
| Devang Patel | 9ccfb64 | 2009-12-09 18:24:21 +0000 | [diff] [blame] | 408 | void constructTypeDIE(DIE &Buffer, | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 409 | DICompositeType CTy); | 
|  | 410 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 411 | /// constructSubrangeDIE - Construct subrange DIE from DISubrange. | 
|  | 412 | void constructSubrangeDIE(DIE &Buffer, DISubrange SR, DIE *IndexTy); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 413 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 414 | /// constructArrayTypeDIE - Construct array type DIE from DICompositeType. | 
| Devang Patel | 9ccfb64 | 2009-12-09 18:24:21 +0000 | [diff] [blame] | 415 | void constructArrayTypeDIE(DIE &Buffer, | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 416 | DICompositeType *CTy); | 
|  | 417 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 418 | /// constructEnumTypeDIE - Construct enum type DIE from DIEnumerator. | 
| Devang Patel | 3b548aa | 2010-03-08 20:52:55 +0000 | [diff] [blame] | 419 | DIE *constructEnumTypeDIE(DIEnumerator ETy); | 
| Devang Patel | b074d17 | 2009-12-07 21:41:32 +0000 | [diff] [blame] | 420 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 421 | /// createMemberDIE - Create new member DIE. | 
| Devang Patel | 9ccfb64 | 2009-12-09 18:24:21 +0000 | [diff] [blame] | 422 | DIE *createMemberDIE(const DIDerivedType &DT); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 423 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 424 | /// createSubprogramDIE - Create new DIE using SP. | 
| Devang Patel | 525dda0 | 2009-12-14 16:18:45 +0000 | [diff] [blame] | 425 | DIE *createSubprogramDIE(const DISubprogram &SP, bool MakeDecl = false); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 426 |  | 
| Devang Patel | 6c74a87 | 2010-04-27 19:46:33 +0000 | [diff] [blame] | 427 | /// getOrCreateDbgScope - Create DbgScope for the scope. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 428 | DbgScope *getOrCreateDbgScope(const MDNode *Scope, const MDNode *InlinedAt); | 
| Devang Patel | 2904aa9 | 2009-11-12 19:02:56 +0000 | [diff] [blame] | 429 |  | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 430 | DbgScope *getOrCreateAbstractScope(const MDNode *N); | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 431 |  | 
|  | 432 | /// findAbstractVariable - Find abstract variable associated with Var. | 
| Devang Patel | e1c53f2 | 2010-05-20 16:36:41 +0000 | [diff] [blame] | 433 | DbgVariable *findAbstractVariable(DIVariable &Var, DebugLoc Loc); | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 434 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 435 | /// updateSubprogramScopeDIE - Find DIE for the given subprogram and | 
|  | 436 | /// attach appropriate DW_AT_low_pc and DW_AT_high_pc attributes. | 
|  | 437 | /// If there are global variables in this scope then create and insert | 
|  | 438 | /// DIEs for these variables. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 439 | DIE *updateSubprogramScopeDIE(const MDNode *SPNode); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 440 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 441 | /// constructLexicalScope - Construct new DW_TAG_lexical_block | 
|  | 442 | /// for this scope and attach DW_AT_low_pc/DW_AT_high_pc labels. | 
|  | 443 | DIE *constructLexicalScopeDIE(DbgScope *Scope); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 444 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 445 | /// constructInlinedScopeDIE - This scope represents inlined body of | 
|  | 446 | /// a function. Construct DIE to represent this concrete inlined copy | 
|  | 447 | /// of the function. | 
|  | 448 | DIE *constructInlinedScopeDIE(DbgScope *Scope); | 
|  | 449 |  | 
|  | 450 | /// constructVariableDIE - Construct a DIE for the given DbgVariable. | 
| Devang Patel | 9ccfb64 | 2009-12-09 18:24:21 +0000 | [diff] [blame] | 451 | DIE *constructVariableDIE(DbgVariable *DV, DbgScope *S); | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 452 |  | 
|  | 453 | /// constructScopeDIE - Construct a DIE for this scope. | 
|  | 454 | DIE *constructScopeDIE(DbgScope *Scope); | 
|  | 455 |  | 
| Chris Lattner | 46355d8 | 2010-04-04 22:33:59 +0000 | [diff] [blame] | 456 | /// EmitSectionLabels - Emit initial Dwarf sections with a label at | 
|  | 457 | /// the start of each one. | 
|  | 458 | void EmitSectionLabels(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 459 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 460 | /// emitDIE - Recusively Emits a debug information entry. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 461 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 462 | void emitDIE(DIE *Die); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 463 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 464 | /// computeSizeAndOffset - Compute the size and offset of a DIE. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 465 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 466 | unsigned computeSizeAndOffset(DIE *Die, unsigned Offset, bool Last); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 467 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 468 | /// computeSizeAndOffsets - Compute the size and offset of all the DIEs. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 469 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 470 | void computeSizeAndOffsets(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 471 |  | 
| Devang Patel | 9ccfb64 | 2009-12-09 18:24:21 +0000 | [diff] [blame] | 472 | /// EmitDebugInfo - Emit the debug info section. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 473 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 474 | void emitDebugInfo(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 475 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 476 | /// emitAbbreviations - Emit the abbreviation section. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 477 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 478 | void emitAbbreviations() const; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 479 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 480 | /// emitEndOfLineMatrix - Emit the last address of the section and the end of | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 481 | /// the line matrix. | 
|  | 482 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 483 | void emitEndOfLineMatrix(unsigned SectionEnd); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 484 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 485 | /// emitDebugLines - Emit source line information. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 486 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 487 | void emitDebugLines(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 488 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 489 | /// emitCommonDebugFrame - Emit common frame info into a debug frame section. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 490 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 491 | void emitCommonDebugFrame(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 492 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 493 | /// emitFunctionDebugFrame - Emit per function frame info into a debug frame | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 494 | /// section. | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 495 | void emitFunctionDebugFrame(const FunctionDebugFrameInfo &DebugFrameInfo); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 496 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 497 | /// emitDebugPubNames - Emit visible names into a debug pubnames section. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 498 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 499 | void emitDebugPubNames(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 500 |  | 
| Devang Patel | 04d2f2d | 2009-11-24 01:14:22 +0000 | [diff] [blame] | 501 | /// emitDebugPubTypes - Emit visible types into a debug pubtypes section. | 
|  | 502 | /// | 
|  | 503 | void emitDebugPubTypes(); | 
|  | 504 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 505 | /// emitDebugStr - Emit visible names into a debug str section. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 506 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 507 | void emitDebugStr(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 508 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 509 | /// emitDebugLoc - Emit visible names into a debug loc section. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 510 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 511 | void emitDebugLoc(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 512 |  | 
|  | 513 | /// EmitDebugARanges - Emit visible names into a debug aranges section. | 
|  | 514 | /// | 
|  | 515 | void EmitDebugARanges(); | 
|  | 516 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 517 | /// emitDebugRanges - Emit visible names into a debug ranges section. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 518 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 519 | void emitDebugRanges(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 520 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 521 | /// emitDebugMacInfo - Emit visible names into a debug macinfo section. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 522 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 523 | void emitDebugMacInfo(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 524 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 525 | /// emitDebugInlineInfo - Emit inline info using following format. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 526 | /// Section Header: | 
|  | 527 | /// 1. length of section | 
|  | 528 | /// 2. Dwarf version number | 
|  | 529 | /// 3. address size. | 
|  | 530 | /// | 
|  | 531 | /// Entries (one "entry" for each function that was inlined): | 
|  | 532 | /// | 
|  | 533 | /// 1. offset into __debug_str section for MIPS linkage name, if exists; | 
|  | 534 | ///   otherwise offset into __debug_str for regular function name. | 
|  | 535 | /// 2. offset into __debug_str section for regular function name. | 
|  | 536 | /// 3. an unsigned LEB128 number indicating the number of distinct inlining | 
|  | 537 | /// instances for the function. | 
|  | 538 | /// | 
|  | 539 | /// The rest of the entry consists of a {die_offset, low_pc}  pair for each | 
|  | 540 | /// inlined instance; the die_offset points to the inlined_subroutine die in | 
|  | 541 | /// the __debug_info section, and the low_pc is the starting address  for the | 
|  | 542 | ///  inlining instance. | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 543 | void emitDebugInlineInfo(); | 
| Bill Wendling | 2b128d7 | 2009-05-20 23:19:06 +0000 | [diff] [blame] | 544 |  | 
|  | 545 | /// GetOrCreateSourceID - Look up the source id with the given directory and | 
|  | 546 | /// source file names. If none currently exists, create a new id and insert it | 
| Chris Lattner | 1198002 | 2010-04-04 07:48:20 +0000 | [diff] [blame] | 547 | /// in the SourceIds map. This can update DirectoryNames and SourceFileNames | 
|  | 548 | /// maps as well. | 
| Devang Patel | 2d9caf9 | 2009-11-25 17:36:49 +0000 | [diff] [blame] | 549 | unsigned GetOrCreateSourceID(StringRef DirName, StringRef FileName); | 
| Bill Wendling | 2b128d7 | 2009-05-20 23:19:06 +0000 | [diff] [blame] | 550 |  | 
| Devang Patel | 1a0df9a | 2010-05-10 22:49:55 +0000 | [diff] [blame] | 551 | /// constructCompileUnit - Create new CompileUnit for the given | 
|  | 552 | /// metadata node with tag DW_TAG_compile_unit. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 553 | void constructCompileUnit(const MDNode *N); | 
| Bill Wendling | 2b128d7 | 2009-05-20 23:19:06 +0000 | [diff] [blame] | 554 |  | 
| Devang Patel | 1a0df9a | 2010-05-10 22:49:55 +0000 | [diff] [blame] | 555 | /// getCompielUnit - Get CompileUnit DIE. | 
|  | 556 | CompileUnit *getCompileUnit(const MDNode *N) const; | 
|  | 557 |  | 
|  | 558 | /// constructGlobalVariableDIE - Construct global variable DIE. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 559 | void constructGlobalVariableDIE(const MDNode *N); | 
| Bill Wendling | 2b128d7 | 2009-05-20 23:19:06 +0000 | [diff] [blame] | 560 |  | 
| Devang Patel | 1a0df9a | 2010-05-10 22:49:55 +0000 | [diff] [blame] | 561 | /// construct SubprogramDIE - Construct subprogram DIE. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 562 | void constructSubprogramDIE(const MDNode *N); | 
| Bill Wendling | 2b128d7 | 2009-05-20 23:19:06 +0000 | [diff] [blame] | 563 |  | 
| Chris Lattner | 64a168e | 2010-04-05 05:32:45 +0000 | [diff] [blame] | 564 | /// recordSourceLine - Register a source line with debug info. Returns the | 
|  | 565 | /// unique label that was emitted and which provides correspondence to | 
|  | 566 | /// the source line list. | 
| Devang Patel | 32cc43c | 2010-05-07 20:54:48 +0000 | [diff] [blame] | 567 | MCSymbol *recordSourceLine(unsigned Line, unsigned Col, const MDNode *Scope); | 
| Chris Lattner | 64a168e | 2010-04-05 05:32:45 +0000 | [diff] [blame] | 568 |  | 
|  | 569 | /// getSourceLineCount - Return the number of source lines in the debug | 
|  | 570 | /// info. | 
|  | 571 | unsigned getSourceLineCount() const { | 
|  | 572 | return Lines.size(); | 
|  | 573 | } | 
|  | 574 |  | 
| Devang Patel | e1c53f2 | 2010-05-20 16:36:41 +0000 | [diff] [blame] | 575 | /// recordVariableFrameIndex - Record a variable's index. | 
|  | 576 | void recordVariableFrameIndex(const DbgVariable *V, int Index); | 
|  | 577 |  | 
|  | 578 | /// findVariableFrameIndex - Return true if frame index for the variable | 
|  | 579 | /// is found. Update FI to hold value of the index. | 
|  | 580 | bool findVariableFrameIndex(const DbgVariable *V, int *FI); | 
|  | 581 |  | 
|  | 582 | /// findVariableLabel - Find MCSymbol for the variable. | 
|  | 583 | const MCSymbol *findVariableLabel(const DbgVariable *V); | 
|  | 584 |  | 
| Devang Patel | 490c8ab | 2010-05-20 19:57:06 +0000 | [diff] [blame] | 585 | /// findDbgScope - Find DbgScope for the debug loc attached with an | 
|  | 586 | /// instruction. | 
|  | 587 | DbgScope *findDbgScope(const MachineInstr *MI); | 
|  | 588 |  | 
| Devang Patel | 359b013 | 2010-04-08 18:43:56 +0000 | [diff] [blame] | 589 | /// identifyScopeMarkers() - Indentify instructions that are marking | 
|  | 590 | /// beginning of or end of a scope. | 
|  | 591 | void identifyScopeMarkers(); | 
| Devang Patel | f1d5a1e | 2010-04-08 15:37:09 +0000 | [diff] [blame] | 592 |  | 
| Chris Lattner | 64a168e | 2010-04-05 05:32:45 +0000 | [diff] [blame] | 593 | /// extractScopeInformation - Scan machine instructions in this function | 
|  | 594 | /// and collect DbgScopes. Return true, if atleast one scope was found. | 
|  | 595 | bool extractScopeInformation(); | 
|  | 596 |  | 
|  | 597 | /// collectVariableInfo - Populate DbgScope entries with variables' info. | 
| Devang Patel | 5c0f85c | 2010-06-25 22:07:34 +0000 | [diff] [blame] | 598 | void collectVariableInfo(const MachineFunction *, | 
|  | 599 | SmallPtrSet<const MDNode *, 16> &ProcessedVars); | 
| Chris Lattner | 64a168e | 2010-04-05 05:32:45 +0000 | [diff] [blame] | 600 |  | 
| Devang Patel | 490c8ab | 2010-05-20 19:57:06 +0000 | [diff] [blame] | 601 | /// collectVariableInfoFromMMITable - Collect variable information from | 
|  | 602 | /// side table maintained by MMI. | 
|  | 603 | void collectVariableInfoFromMMITable(const MachineFunction * MF, | 
|  | 604 | SmallPtrSet<const MDNode *, 16> &P); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 605 | public: | 
|  | 606 | //===--------------------------------------------------------------------===// | 
|  | 607 | // Main entry points. | 
|  | 608 | // | 
| Chris Lattner | f0d6bd3 | 2010-04-05 05:11:15 +0000 | [diff] [blame] | 609 | DwarfDebug(AsmPrinter *A, Module *M); | 
| Chris Lattner | 64a168e | 2010-04-05 05:32:45 +0000 | [diff] [blame] | 610 | ~DwarfDebug(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 611 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 612 | /// beginModule - Emit all Dwarf sections that should come prior to the | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 613 | /// content. | 
| Chris Lattner | 1198002 | 2010-04-04 07:48:20 +0000 | [diff] [blame] | 614 | void beginModule(Module *M); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 615 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 616 | /// endModule - Emit all Dwarf sections that should come after the content. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 617 | /// | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 618 | void endModule(); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 619 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 620 | /// beginFunction - Gather pre-function debug information.  Assumes being | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 621 | /// emitted immediately after the function entry point. | 
| Chris Lattner | 76555b5 | 2010-01-26 23:18:02 +0000 | [diff] [blame] | 622 | void beginFunction(const MachineFunction *MF); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 623 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 624 | /// endFunction - Gather and emit post-function debug information. | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 625 | /// | 
| Chris Lattner | 76555b5 | 2010-01-26 23:18:02 +0000 | [diff] [blame] | 626 | void endFunction(const MachineFunction *MF); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 627 |  | 
| Devang Patel | 9fc1170 | 2010-05-25 23:40:22 +0000 | [diff] [blame] | 628 | /// getLabelBeforeInsn - Return Label preceding the instruction. | 
|  | 629 | const MCSymbol *getLabelBeforeInsn(const MachineInstr *MI); | 
|  | 630 |  | 
|  | 631 | /// getLabelAfterInsn - Return Label immediately following the instruction. | 
|  | 632 | const MCSymbol *getLabelAfterInsn(const MachineInstr *MI); | 
|  | 633 |  | 
| Devang Patel | bd477be | 2010-03-29 17:20:31 +0000 | [diff] [blame] | 634 | /// beginScope - Process beginning of a scope. | 
|  | 635 | void beginScope(const MachineInstr *MI); | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 636 |  | 
| Devang Patel | 930143b | 2009-11-21 02:48:08 +0000 | [diff] [blame] | 637 | /// endScope - Prcess end of a scope. | 
|  | 638 | void endScope(const MachineInstr *MI); | 
| Devang Patel | f6eeaeb | 2009-11-10 23:06:00 +0000 | [diff] [blame] | 639 | }; | 
| Bill Wendling | 2f921f8 | 2009-05-15 09:23:25 +0000 | [diff] [blame] | 640 | } // End of namespace llvm | 
|  | 641 |  | 
|  | 642 | #endif |