//===- llvm/CodeGen/DwarfFile.h - Dwarf Debug Framework ---------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_CODEGEN_ASMPRINTER_DWARFFILE_H #define LLVM_LIB_CODEGEN_ASMPRINTER_DWARFFILE_H #include "DwarfStringPool.h" #include "llvm/ADT/DenseMap.h" #include "llvm/ADT/SmallVector.h" #include "llvm/ADT/StringRef.h" #include "llvm/CodeGen/DIE.h" #include "llvm/Support/Allocator.h" #include #include namespace llvm { class AsmPrinter; class DbgVariable; class DwarfCompileUnit; class DwarfUnit; class LexicalScope; class MCSection; class MDNode; class DwarfFile { // Target of Dwarf emission, used for sizing of abbreviations. AsmPrinter *Asm; BumpPtrAllocator AbbrevAllocator; // Used to uniquely define abbreviations. DIEAbbrevSet Abbrevs; // A pointer to all units in the section. SmallVector, 1> CUs; DwarfStringPool StrPool; // Collection of dbg variables of a scope. DenseMap> ScopeVariables; // Collection of abstract subprogram DIEs. DenseMap AbstractSPDies; DenseMap> AbstractVariables; /// Maps MDNodes for type system with the corresponding DIEs. These DIEs can /// be shared across CUs, that is why we keep the map here instead /// of in DwarfCompileUnit. DenseMap DITypeNodeToDieMap; public: DwarfFile(AsmPrinter *AP, StringRef Pref, BumpPtrAllocator &DA); const SmallVectorImpl> &getUnits() { return CUs; } /// \brief Compute the size and offset of a DIE given an incoming Offset. unsigned computeSizeAndOffset(DIE &Die, unsigned Offset); /// \brief Compute the size and offset of all the DIEs. void computeSizeAndOffsets(); /// \brief Compute the size and offset of all the DIEs in the given unit. /// \returns The size of the root DIE. unsigned computeSizeAndOffsetsForUnit(DwarfUnit *TheU); /// \brief Add a unit to the list of CUs. void addUnit(std::unique_ptr U); /// \brief Emit all of the units to the section listed with the given /// abbreviation section. void emitUnits(bool UseOffsets); /// \brief Emit the given unit to its section. void emitUnit(DwarfUnit *U, bool UseOffsets); /// \brief Emit a set of abbreviations to the specific section. void emitAbbrevs(MCSection *); /// \brief Emit all of the strings to the section given. void emitStrings(MCSection *StrSection, MCSection *OffsetSection = nullptr); /// \brief Returns the string pool. DwarfStringPool &getStringPool() { return StrPool; } /// \returns false if the variable was merged with a previous one. bool addScopeVariable(LexicalScope *LS, DbgVariable *Var); DenseMap> &getScopeVariables() { return ScopeVariables; } DenseMap &getAbstractSPDies() { return AbstractSPDies; } DenseMap> &getAbstractVariables() { return AbstractVariables; } void insertDIE(const MDNode *TypeMD, DIE *Die) { DITypeNodeToDieMap.insert(std::make_pair(TypeMD, Die)); } DIE *getDIE(const MDNode *TypeMD) { return DITypeNodeToDieMap.lookup(TypeMD); } }; } // end namespace llvm #endif // LLVM_LIB_CODEGEN_ASMPRINTER_DWARFFILE_H