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