mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-30 00:15:55 +00:00
Cosmetic changes, which were long overdue, in DwarfDebug.cpp.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@89537 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
bef8888a91
commit
2c4ceb177b
@ -105,9 +105,9 @@ DIE::~DIE() {
|
|||||||
delete Children[i];
|
delete Children[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
/// AddSiblingOffset - Add a sibling offset field to the front of the DIE.
|
/// addSiblingOffset - Add a sibling offset field to the front of the DIE.
|
||||||
///
|
///
|
||||||
void DIE::AddSiblingOffset() {
|
void DIE::addSiblingOffset() {
|
||||||
DIEInteger *DI = new DIEInteger(0);
|
DIEInteger *DI = new DIEInteger(0);
|
||||||
Values.insert(Values.begin(), DI);
|
Values.insert(Values.begin(), DI);
|
||||||
Abbrev.AddFirstAttribute(dwarf::DW_AT_sibling, dwarf::DW_FORM_ref4);
|
Abbrev.AddFirstAttribute(dwarf::DW_AT_sibling, dwarf::DW_FORM_ref4);
|
||||||
|
@ -161,34 +161,28 @@ namespace llvm {
|
|||||||
void setSize(unsigned S) { Size = S; }
|
void setSize(unsigned S) { Size = S; }
|
||||||
void setAbstractCompileUnit(CompileUnit *CU) { AbstractCU = CU; }
|
void setAbstractCompileUnit(CompileUnit *CU) { AbstractCU = CU; }
|
||||||
|
|
||||||
/// AddValue - Add a value and attributes to a DIE.
|
/// addValue - Add a value and attributes to a DIE.
|
||||||
///
|
///
|
||||||
void AddValue(unsigned Attribute, unsigned Form, DIEValue *Value) {
|
void addValue(unsigned Attribute, unsigned Form, DIEValue *Value) {
|
||||||
Abbrev.AddAttribute(Attribute, Form);
|
Abbrev.AddAttribute(Attribute, Form);
|
||||||
Values.push_back(Value);
|
Values.push_back(Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// SiblingOffset - Return the offset of the debug information entry's
|
/// SiblingOffset - Return the offset of the debug information entry's
|
||||||
/// sibling.
|
/// sibling.
|
||||||
unsigned SiblingOffset() const { return Offset + Size; }
|
unsigned getSiblingOffset() const { return Offset + Size; }
|
||||||
|
|
||||||
/// AddSiblingOffset - Add a sibling offset field to the front of the DIE.
|
/// addSiblingOffset - Add a sibling offset field to the front of the DIE.
|
||||||
///
|
///
|
||||||
void AddSiblingOffset();
|
void addSiblingOffset();
|
||||||
|
|
||||||
/// AddChild - Add a child to the DIE.
|
/// addChild - Add a child to the DIE.
|
||||||
///
|
///
|
||||||
void AddChild(DIE *Child) {
|
void addChild(DIE *Child) {
|
||||||
Abbrev.setChildrenFlag(dwarf::DW_CHILDREN_yes);
|
Abbrev.setChildrenFlag(dwarf::DW_CHILDREN_yes);
|
||||||
Children.push_back(Child);
|
Children.push_back(Child);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Detach - Detaches objects connected to it after copying.
|
|
||||||
///
|
|
||||||
void Detach() {
|
|
||||||
Children.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef NDEBUG
|
#ifndef NDEBUG
|
||||||
void print(raw_ostream &O, unsigned IncIndent = 0);
|
void print(raw_ostream &O, unsigned IncIndent = 0);
|
||||||
void dump();
|
void dump();
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -106,9 +106,9 @@ class DwarfDebug : public Dwarf {
|
|||||||
/// Lines - List of of source line correspondence.
|
/// Lines - List of of source line correspondence.
|
||||||
std::vector<SrcLineInfo> Lines;
|
std::vector<SrcLineInfo> Lines;
|
||||||
|
|
||||||
/// Values - A list of all the unique values in use.
|
/// DIEValues - A list of all the unique values in use.
|
||||||
///
|
///
|
||||||
std::vector<DIEValue *> Values;
|
std::vector<DIEValue *> DIEValues;
|
||||||
|
|
||||||
/// StringPool - A UniqueVector of strings used by indirect references.
|
/// StringPool - A UniqueVector of strings used by indirect references.
|
||||||
///
|
///
|
||||||
@ -225,137 +225,133 @@ class DwarfDebug : public Dwarf {
|
|||||||
return SourceIds.size();
|
return SourceIds.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// AssignAbbrevNumber - Define a unique number for the abbreviation.
|
/// assignAbbrevNumber - Define a unique number for the abbreviation.
|
||||||
///
|
///
|
||||||
void AssignAbbrevNumber(DIEAbbrev &Abbrev);
|
void assignAbbrevNumber(DIEAbbrev &Abbrev);
|
||||||
|
|
||||||
/// CreateDIEEntry - Creates a new DIEEntry to be a proxy for a debug
|
/// createDIEEntry - Creates a new DIEEntry to be a proxy for a debug
|
||||||
/// information entry.
|
/// information entry.
|
||||||
DIEEntry *CreateDIEEntry(DIE *Entry = NULL);
|
DIEEntry *createDIEEntry(DIE *Entry = NULL);
|
||||||
|
|
||||||
/// SetDIEEntry - Set a DIEEntry once the debug information entry is defined.
|
/// addUInt - Add an unsigned integer attribute data and value.
|
||||||
///
|
///
|
||||||
void SetDIEEntry(DIEEntry *Value, DIE *Entry);
|
void addUInt(DIE *Die, unsigned Attribute, unsigned Form, uint64_t Integer);
|
||||||
|
|
||||||
/// AddUInt - Add an unsigned integer attribute data and value.
|
/// addSInt - Add an signed integer attribute data and value.
|
||||||
///
|
///
|
||||||
void AddUInt(DIE *Die, unsigned Attribute, unsigned Form, uint64_t Integer);
|
void addSInt(DIE *Die, unsigned Attribute, unsigned Form, int64_t Integer);
|
||||||
|
|
||||||
/// AddSInt - Add an signed integer attribute data and value.
|
/// addString - Add a string attribute data and value.
|
||||||
///
|
///
|
||||||
void AddSInt(DIE *Die, unsigned Attribute, unsigned Form, int64_t Integer);
|
void addString(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
|
|
||||||
/// AddString - Add a string attribute data and value.
|
|
||||||
///
|
|
||||||
void AddString(DIE *Die, unsigned Attribute, unsigned Form,
|
|
||||||
const std::string &String);
|
const std::string &String);
|
||||||
|
|
||||||
/// AddLabel - Add a Dwarf label attribute data and value.
|
/// addLabel - Add a Dwarf label attribute data and value.
|
||||||
///
|
///
|
||||||
void AddLabel(DIE *Die, unsigned Attribute, unsigned Form,
|
void addLabel(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
const DWLabel &Label);
|
const DWLabel &Label);
|
||||||
|
|
||||||
/// AddObjectLabel - Add an non-Dwarf label attribute data and value.
|
/// addObjectLabel - Add an non-Dwarf label attribute data and value.
|
||||||
///
|
///
|
||||||
void AddObjectLabel(DIE *Die, unsigned Attribute, unsigned Form,
|
void addObjectLabel(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
const std::string &Label);
|
const std::string &Label);
|
||||||
|
|
||||||
/// AddSectionOffset - Add a section offset label attribute data and value.
|
/// addSectionOffset - Add a section offset label attribute data and value.
|
||||||
///
|
///
|
||||||
void AddSectionOffset(DIE *Die, unsigned Attribute, unsigned Form,
|
void addSectionOffset(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
const DWLabel &Label, const DWLabel &Section,
|
const DWLabel &Label, const DWLabel &Section,
|
||||||
bool isEH = false, bool useSet = true);
|
bool isEH = false, bool useSet = true);
|
||||||
|
|
||||||
/// AddDelta - Add a label delta attribute data and value.
|
/// addDelta - Add a label delta attribute data and value.
|
||||||
///
|
///
|
||||||
void AddDelta(DIE *Die, unsigned Attribute, unsigned Form,
|
void addDelta(DIE *Die, unsigned Attribute, unsigned Form,
|
||||||
const DWLabel &Hi, const DWLabel &Lo);
|
const DWLabel &Hi, const DWLabel &Lo);
|
||||||
|
|
||||||
/// AddDIEEntry - Add a DIE attribute data and value.
|
/// addDIEEntry - Add a DIE attribute data and value.
|
||||||
///
|
///
|
||||||
void AddDIEEntry(DIE *Die, unsigned Attribute, unsigned Form, DIE *Entry) {
|
void addDIEEntry(DIE *Die, unsigned Attribute, unsigned Form, DIE *Entry) {
|
||||||
Die->AddValue(Attribute, Form, CreateDIEEntry(Entry));
|
Die->addValue(Attribute, Form, createDIEEntry(Entry));
|
||||||
}
|
}
|
||||||
|
|
||||||
/// AddBlock - Add block data.
|
/// addBlock - Add block data.
|
||||||
///
|
///
|
||||||
void AddBlock(DIE *Die, unsigned Attribute, unsigned Form, DIEBlock *Block);
|
void addBlock(DIE *Die, unsigned Attribute, unsigned Form, DIEBlock *Block);
|
||||||
|
|
||||||
/// AddSourceLine - Add location information to specified debug information
|
/// addSourceLine - Add location information to specified debug information
|
||||||
/// entry.
|
/// entry.
|
||||||
void AddSourceLine(DIE *Die, const DIVariable *V);
|
void addSourceLine(DIE *Die, const DIVariable *V);
|
||||||
void AddSourceLine(DIE *Die, const DIGlobal *G);
|
void addSourceLine(DIE *Die, const DIGlobal *G);
|
||||||
void AddSourceLine(DIE *Die, const DISubprogram *SP);
|
void addSourceLine(DIE *Die, const DISubprogram *SP);
|
||||||
void AddSourceLine(DIE *Die, const DIType *Ty);
|
void addSourceLine(DIE *Die, const DIType *Ty);
|
||||||
|
|
||||||
/// AddAddress - Add an address attribute to a die based on the location
|
/// addAddress - Add an address attribute to a die based on the location
|
||||||
/// provided.
|
/// provided.
|
||||||
void AddAddress(DIE *Die, unsigned Attribute,
|
void addAddress(DIE *Die, unsigned Attribute,
|
||||||
const MachineLocation &Location);
|
const MachineLocation &Location);
|
||||||
|
|
||||||
/// AddComplexAddress - Start with the address based on the location provided,
|
/// addComplexAddress - Start with the address based on the location provided,
|
||||||
/// and generate the DWARF information necessary to find the actual variable
|
/// and generate the DWARF information necessary to find the actual variable
|
||||||
/// (navigating the extra location information encoded in the type) based on
|
/// (navigating the extra location information encoded in the type) based on
|
||||||
/// the starting location. Add the DWARF information to the die.
|
/// the starting location. Add the DWARF information to the die.
|
||||||
///
|
///
|
||||||
void AddComplexAddress(DbgVariable *&DV, DIE *Die, unsigned Attribute,
|
void addComplexAddress(DbgVariable *&DV, DIE *Die, unsigned Attribute,
|
||||||
const MachineLocation &Location);
|
const MachineLocation &Location);
|
||||||
|
|
||||||
// FIXME: Should be reformulated in terms of AddComplexAddress.
|
// FIXME: Should be reformulated in terms of addComplexAddress.
|
||||||
/// AddBlockByrefAddress - Start with the address based on the location
|
/// addBlockByrefAddress - Start with the address based on the location
|
||||||
/// provided, and generate the DWARF information necessary to find the
|
/// provided, and generate the DWARF information necessary to find the
|
||||||
/// actual Block variable (navigating the Block struct) based on the
|
/// actual Block variable (navigating the Block struct) based on the
|
||||||
/// starting location. Add the DWARF information to the die. Obsolete,
|
/// starting location. Add the DWARF information to the die. Obsolete,
|
||||||
/// please use AddComplexAddress instead.
|
/// please use addComplexAddress instead.
|
||||||
///
|
///
|
||||||
void AddBlockByrefAddress(DbgVariable *&DV, DIE *Die, unsigned Attribute,
|
void addBlockByrefAddress(DbgVariable *&DV, DIE *Die, unsigned Attribute,
|
||||||
const MachineLocation &Location);
|
const MachineLocation &Location);
|
||||||
|
|
||||||
/// AddType - Add a new type attribute to the specified entity.
|
/// addType - Add a new type attribute to the specified entity.
|
||||||
void AddType(CompileUnit *DW_Unit, DIE *Entity, DIType Ty);
|
void addType(CompileUnit *DW_Unit, DIE *Entity, DIType Ty);
|
||||||
|
|
||||||
/// ConstructTypeDIE - Construct basic type die from DIBasicType.
|
/// constructTypeDIE - Construct basic type die from DIBasicType.
|
||||||
void ConstructTypeDIE(CompileUnit *DW_Unit, DIE &Buffer,
|
void constructTypeDIE(CompileUnit *DW_Unit, DIE &Buffer,
|
||||||
DIBasicType BTy);
|
DIBasicType BTy);
|
||||||
|
|
||||||
/// ConstructTypeDIE - Construct derived type die from DIDerivedType.
|
/// constructTypeDIE - Construct derived type die from DIDerivedType.
|
||||||
void ConstructTypeDIE(CompileUnit *DW_Unit, DIE &Buffer,
|
void constructTypeDIE(CompileUnit *DW_Unit, DIE &Buffer,
|
||||||
DIDerivedType DTy);
|
DIDerivedType DTy);
|
||||||
|
|
||||||
/// ConstructTypeDIE - Construct type DIE from DICompositeType.
|
/// constructTypeDIE - Construct type DIE from DICompositeType.
|
||||||
void ConstructTypeDIE(CompileUnit *DW_Unit, DIE &Buffer,
|
void constructTypeDIE(CompileUnit *DW_Unit, DIE &Buffer,
|
||||||
DICompositeType CTy);
|
DICompositeType CTy);
|
||||||
|
|
||||||
/// ConstructSubrangeDIE - Construct subrange DIE from DISubrange.
|
/// constructSubrangeDIE - Construct subrange DIE from DISubrange.
|
||||||
void ConstructSubrangeDIE(DIE &Buffer, DISubrange SR, DIE *IndexTy);
|
void constructSubrangeDIE(DIE &Buffer, DISubrange SR, DIE *IndexTy);
|
||||||
|
|
||||||
/// ConstructArrayTypeDIE - Construct array type DIE from DICompositeType.
|
/// constructArrayTypeDIE - Construct array type DIE from DICompositeType.
|
||||||
void ConstructArrayTypeDIE(CompileUnit *DW_Unit, DIE &Buffer,
|
void constructArrayTypeDIE(CompileUnit *DW_Unit, DIE &Buffer,
|
||||||
DICompositeType *CTy);
|
DICompositeType *CTy);
|
||||||
|
|
||||||
/// ConstructEnumTypeDIE - Construct enum type DIE from DIEnumerator.
|
/// constructEnumTypeDIE - Construct enum type DIE from DIEnumerator.
|
||||||
DIE *ConstructEnumTypeDIE(CompileUnit *DW_Unit, DIEnumerator *ETy);
|
DIE *constructEnumTypeDIE(CompileUnit *DW_Unit, DIEnumerator *ETy);
|
||||||
|
|
||||||
/// CreateGlobalVariableDIE - Create new DIE using GV.
|
/// createGlobalVariableDIE - Create new DIE using GV.
|
||||||
DIE *CreateGlobalVariableDIE(CompileUnit *DW_Unit,
|
DIE *createGlobalVariableDIE(CompileUnit *DW_Unit,
|
||||||
const DIGlobalVariable &GV);
|
const DIGlobalVariable &GV);
|
||||||
|
|
||||||
/// CreateMemberDIE - Create new member DIE.
|
/// createMemberDIE - Create new member DIE.
|
||||||
DIE *CreateMemberDIE(CompileUnit *DW_Unit, const DIDerivedType &DT);
|
DIE *createMemberDIE(CompileUnit *DW_Unit, const DIDerivedType &DT);
|
||||||
|
|
||||||
/// CreateSubprogramDIE - Create new DIE using SP.
|
/// createSubprogramDIE - Create new DIE using SP.
|
||||||
DIE *CreateSubprogramDIE(CompileUnit *DW_Unit,
|
DIE *createSubprogramDIE(CompileUnit *DW_Unit,
|
||||||
const DISubprogram &SP,
|
const DISubprogram &SP,
|
||||||
bool IsConstructor = false,
|
bool IsConstructor = false,
|
||||||
bool IsInlined = false);
|
bool IsInlined = false);
|
||||||
|
|
||||||
/// FindCompileUnit - Get the compile unit for the given descriptor.
|
/// findCompileUnit - Get the compile unit for the given descriptor.
|
||||||
///
|
///
|
||||||
CompileUnit &FindCompileUnit(DICompileUnit Unit) const;
|
CompileUnit &findCompileUnit(DICompileUnit Unit) const;
|
||||||
|
|
||||||
/// CreateDbgScopeVariable - Create a new scope variable.
|
/// createDbgScopeVariable - Create a new scope variable.
|
||||||
///
|
///
|
||||||
DIE *CreateDbgScopeVariable(DbgVariable *DV, CompileUnit *Unit);
|
DIE *createDbgScopeVariable(DbgVariable *DV, CompileUnit *Unit);
|
||||||
|
|
||||||
/// getUpdatedDbgScope - Find or create DbgScope assicated with
|
/// getUpdatedDbgScope - Find or create DbgScope assicated with
|
||||||
/// the instruction. Initialize scope and update scope hierarchy.
|
/// the instruction. Initialize scope and update scope hierarchy.
|
||||||
@ -370,88 +366,97 @@ class DwarfDebug : public Dwarf {
|
|||||||
DbgVariable *findAbstractVariable(DIVariable &Var, unsigned FrameIdx,
|
DbgVariable *findAbstractVariable(DIVariable &Var, unsigned FrameIdx,
|
||||||
DILocation &Loc);
|
DILocation &Loc);
|
||||||
|
|
||||||
DIE *UpdateSubprogramScopeDIE(MDNode *SPNode);
|
/// updateSubprogramScopeDIE - Find DIE for the given subprogram and
|
||||||
DIE *ConstructLexicalScopeDIE(DbgScope *Scope);
|
/// attach appropriate DW_AT_low_pc and DW_AT_high_pc attributes.
|
||||||
DIE *ConstructScopeDIE(DbgScope *Scope);
|
/// If there are global variables in this scope then create and insert
|
||||||
DIE *ConstructInlinedScopeDIE(DbgScope *Scope);
|
/// DIEs for these variables.
|
||||||
DIE *ConstructVariableDIE(DbgVariable *DV, DbgScope *S, CompileUnit *Unit);
|
DIE *updateSubprogramScopeDIE(MDNode *SPNode);
|
||||||
|
|
||||||
/// ConstructDbgScope - Construct the components of a scope.
|
/// constructLexicalScope - Construct new DW_TAG_lexical_block
|
||||||
///
|
/// for this scope and attach DW_AT_low_pc/DW_AT_high_pc labels.
|
||||||
void ConstructDbgScope(DbgScope *ParentScope,
|
DIE *constructLexicalScopeDIE(DbgScope *Scope);
|
||||||
unsigned ParentStartID, unsigned ParentEndID,
|
|
||||||
DIE *ParentDie, CompileUnit *Unit);
|
|
||||||
|
|
||||||
/// EmitInitial - Emit initial Dwarf declarations. This is necessary for cc
|
/// constructInlinedScopeDIE - This scope represents inlined body of
|
||||||
|
/// a function. Construct DIE to represent this concrete inlined copy
|
||||||
|
/// of the function.
|
||||||
|
DIE *constructInlinedScopeDIE(DbgScope *Scope);
|
||||||
|
|
||||||
|
/// constructVariableDIE - Construct a DIE for the given DbgVariable.
|
||||||
|
DIE *constructVariableDIE(DbgVariable *DV, DbgScope *S, CompileUnit *Unit);
|
||||||
|
|
||||||
|
/// constructScopeDIE - Construct a DIE for this scope.
|
||||||
|
DIE *constructScopeDIE(DbgScope *Scope);
|
||||||
|
|
||||||
|
/// emitInitial - Emit initial Dwarf declarations. This is necessary for cc
|
||||||
/// tools to recognize the object file contains Dwarf information.
|
/// tools to recognize the object file contains Dwarf information.
|
||||||
void EmitInitial();
|
void emitInitial();
|
||||||
|
|
||||||
/// EmitDIE - Recusively Emits a debug information entry.
|
/// emitDIE - Recusively Emits a debug information entry.
|
||||||
///
|
///
|
||||||
void EmitDIE(DIE *Die);
|
void emitDIE(DIE *Die);
|
||||||
|
|
||||||
/// SizeAndOffsetDie - Compute the size and offset of a DIE.
|
/// computeSizeAndOffset - Compute the size and offset of a DIE.
|
||||||
///
|
///
|
||||||
unsigned SizeAndOffsetDie(DIE *Die, unsigned Offset, bool Last);
|
unsigned computeSizeAndOffset(DIE *Die, unsigned Offset, bool Last);
|
||||||
|
|
||||||
/// SizeAndOffsets - Compute the size and offset of all the DIEs.
|
/// computeSizeAndOffsets - Compute the size and offset of all the DIEs.
|
||||||
///
|
///
|
||||||
void SizeAndOffsets();
|
void computeSizeAndOffsets();
|
||||||
|
|
||||||
/// EmitDebugInfo / EmitDebugInfoPerCU - Emit the debug info section.
|
/// EmitDebugInfo / emitDebugInfoPerCU - Emit the debug info section.
|
||||||
///
|
///
|
||||||
void EmitDebugInfoPerCU(CompileUnit *Unit);
|
void emitDebugInfoPerCU(CompileUnit *Unit);
|
||||||
|
|
||||||
void EmitDebugInfo();
|
void emitDebugInfo();
|
||||||
|
|
||||||
/// EmitAbbreviations - Emit the abbreviation section.
|
/// emitAbbreviations - Emit the abbreviation section.
|
||||||
///
|
///
|
||||||
void EmitAbbreviations() const;
|
void emitAbbreviations() const;
|
||||||
|
|
||||||
/// EmitEndOfLineMatrix - Emit the last address of the section and the end of
|
/// emitEndOfLineMatrix - Emit the last address of the section and the end of
|
||||||
/// the line matrix.
|
/// the line matrix.
|
||||||
///
|
///
|
||||||
void EmitEndOfLineMatrix(unsigned SectionEnd);
|
void emitEndOfLineMatrix(unsigned SectionEnd);
|
||||||
|
|
||||||
/// EmitDebugLines - Emit source line information.
|
/// emitDebugLines - Emit source line information.
|
||||||
///
|
///
|
||||||
void EmitDebugLines();
|
void emitDebugLines();
|
||||||
|
|
||||||
/// EmitCommonDebugFrame - Emit common frame info into a debug frame section.
|
/// emitCommonDebugFrame - Emit common frame info into a debug frame section.
|
||||||
///
|
///
|
||||||
void EmitCommonDebugFrame();
|
void emitCommonDebugFrame();
|
||||||
|
|
||||||
/// EmitFunctionDebugFrame - Emit per function frame info into a debug frame
|
/// emitFunctionDebugFrame - Emit per function frame info into a debug frame
|
||||||
/// section.
|
/// section.
|
||||||
void EmitFunctionDebugFrame(const FunctionDebugFrameInfo &DebugFrameInfo);
|
void emitFunctionDebugFrame(const FunctionDebugFrameInfo &DebugFrameInfo);
|
||||||
|
|
||||||
void EmitDebugPubNamesPerCU(CompileUnit *Unit);
|
void emitDebugPubNamesPerCU(CompileUnit *Unit);
|
||||||
|
|
||||||
/// EmitDebugPubNames - Emit visible names into a debug pubnames section.
|
/// emitDebugPubNames - Emit visible names into a debug pubnames section.
|
||||||
///
|
///
|
||||||
void EmitDebugPubNames();
|
void emitDebugPubNames();
|
||||||
|
|
||||||
/// EmitDebugStr - Emit visible names into a debug str section.
|
/// emitDebugStr - Emit visible names into a debug str section.
|
||||||
///
|
///
|
||||||
void EmitDebugStr();
|
void emitDebugStr();
|
||||||
|
|
||||||
/// EmitDebugLoc - Emit visible names into a debug loc section.
|
/// emitDebugLoc - Emit visible names into a debug loc section.
|
||||||
///
|
///
|
||||||
void EmitDebugLoc();
|
void emitDebugLoc();
|
||||||
|
|
||||||
/// EmitDebugARanges - Emit visible names into a debug aranges section.
|
/// EmitDebugARanges - Emit visible names into a debug aranges section.
|
||||||
///
|
///
|
||||||
void EmitDebugARanges();
|
void EmitDebugARanges();
|
||||||
|
|
||||||
/// EmitDebugRanges - Emit visible names into a debug ranges section.
|
/// emitDebugRanges - Emit visible names into a debug ranges section.
|
||||||
///
|
///
|
||||||
void EmitDebugRanges();
|
void emitDebugRanges();
|
||||||
|
|
||||||
/// EmitDebugMacInfo - Emit visible names into a debug macinfo section.
|
/// emitDebugMacInfo - Emit visible names into a debug macinfo section.
|
||||||
///
|
///
|
||||||
void EmitDebugMacInfo();
|
void emitDebugMacInfo();
|
||||||
|
|
||||||
/// EmitDebugInlineInfo - Emit inline info using following format.
|
/// emitDebugInlineInfo - Emit inline info using following format.
|
||||||
/// Section Header:
|
/// Section Header:
|
||||||
/// 1. length of section
|
/// 1. length of section
|
||||||
/// 2. Dwarf version number
|
/// 2. Dwarf version number
|
||||||
@ -469,7 +474,7 @@ class DwarfDebug : public Dwarf {
|
|||||||
/// inlined instance; the die_offset points to the inlined_subroutine die in
|
/// inlined instance; the die_offset points to the inlined_subroutine die in
|
||||||
/// the __debug_info section, and the low_pc is the starting address for the
|
/// the __debug_info section, and the low_pc is the starting address for the
|
||||||
/// inlining instance.
|
/// inlining instance.
|
||||||
void EmitDebugInlineInfo();
|
void emitDebugInlineInfo();
|
||||||
|
|
||||||
/// GetOrCreateSourceID - Look up the source id with the given directory and
|
/// GetOrCreateSourceID - Look up the source id with the given directory and
|
||||||
/// source file names. If none currently exists, create a new id and insert it
|
/// source file names. If none currently exists, create a new id and insert it
|
||||||
@ -478,17 +483,17 @@ class DwarfDebug : public Dwarf {
|
|||||||
unsigned GetOrCreateSourceID(const char *DirName,
|
unsigned GetOrCreateSourceID(const char *DirName,
|
||||||
const char *FileName);
|
const char *FileName);
|
||||||
|
|
||||||
void ConstructCompileUnit(MDNode *N);
|
void constructCompileUnit(MDNode *N);
|
||||||
|
|
||||||
void ConstructGlobalVariableDIE(MDNode *N);
|
void constructGlobalVariableDIE(MDNode *N);
|
||||||
|
|
||||||
void ConstructSubprogram(MDNode *N);
|
void constructSubprogramDIE(MDNode *N);
|
||||||
|
|
||||||
// FIXME: This should go away in favor of complex addresses.
|
// FIXME: This should go away in favor of complex addresses.
|
||||||
/// Find the type the programmer originally declared the variable to be
|
/// Find the type the programmer originally declared the variable to be
|
||||||
/// and return that type. Obsolete, use GetComplexAddrType instead.
|
/// and return that type. Obsolete, use GetComplexAddrType instead.
|
||||||
///
|
///
|
||||||
DIType GetBlockByrefType(DIType Ty, std::string Name);
|
DIType getBlockByrefType(DIType Ty, std::string Name);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
//===--------------------------------------------------------------------===//
|
//===--------------------------------------------------------------------===//
|
||||||
@ -501,30 +506,30 @@ public:
|
|||||||
/// be emitted.
|
/// be emitted.
|
||||||
bool ShouldEmitDwarfDebug() const { return shouldEmit; }
|
bool ShouldEmitDwarfDebug() const { return shouldEmit; }
|
||||||
|
|
||||||
/// BeginModule - Emit all Dwarf sections that should come prior to the
|
/// beginModule - Emit all Dwarf sections that should come prior to the
|
||||||
/// content.
|
/// content.
|
||||||
void BeginModule(Module *M, MachineModuleInfo *MMI);
|
void beginModule(Module *M, MachineModuleInfo *MMI);
|
||||||
|
|
||||||
/// EndModule - Emit all Dwarf sections that should come after the content.
|
/// endModule - Emit all Dwarf sections that should come after the content.
|
||||||
///
|
///
|
||||||
void EndModule();
|
void endModule();
|
||||||
|
|
||||||
/// BeginFunction - Gather pre-function debug information. Assumes being
|
/// beginFunction - Gather pre-function debug information. Assumes being
|
||||||
/// emitted immediately after the function entry point.
|
/// emitted immediately after the function entry point.
|
||||||
void BeginFunction(MachineFunction *MF);
|
void beginFunction(MachineFunction *MF);
|
||||||
|
|
||||||
/// EndFunction - Gather and emit post-function debug information.
|
/// endFunction - Gather and emit post-function debug information.
|
||||||
///
|
///
|
||||||
void EndFunction(MachineFunction *MF);
|
void endFunction(MachineFunction *MF);
|
||||||
|
|
||||||
/// RecordSourceLine - Records location information and associates it with a
|
/// recordSourceLine - Records location information and associates it with a
|
||||||
/// label. Returns a unique label ID used to generate a label and provide
|
/// label. Returns a unique label ID used to generate a label and provide
|
||||||
/// correspondence to the source line list.
|
/// correspondence to the source line list.
|
||||||
unsigned RecordSourceLine(unsigned Line, unsigned Col, MDNode *Scope);
|
unsigned recordSourceLine(unsigned Line, unsigned Col, MDNode *Scope);
|
||||||
|
|
||||||
/// getRecordSourceLineCount - Return the number of source lines in the debug
|
/// getSourceLineCount - Return the number of source lines in the debug
|
||||||
/// info.
|
/// info.
|
||||||
unsigned getRecordSourceLineCount() const {
|
unsigned getSourceLineCount() const {
|
||||||
return Lines.size();
|
return Lines.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -536,22 +541,18 @@ public:
|
|||||||
unsigned getOrCreateSourceID(const std::string &DirName,
|
unsigned getOrCreateSourceID(const std::string &DirName,
|
||||||
const std::string &FileName);
|
const std::string &FileName);
|
||||||
|
|
||||||
/// ExtractScopeInformation - Scan machine instructions in this function
|
/// extractScopeInformation - Scan machine instructions in this function
|
||||||
/// and collect DbgScopes. Return true, if atleast one scope was found.
|
/// and collect DbgScopes. Return true, if atleast one scope was found.
|
||||||
bool ExtractScopeInformation(MachineFunction *MF);
|
bool extractScopeInformation(MachineFunction *MF);
|
||||||
|
|
||||||
/// CollectVariableInfo - Populate DbgScope entries with variables' info.
|
/// collectVariableInfo - Populate DbgScope entries with variables' info.
|
||||||
void CollectVariableInfo();
|
void collectVariableInfo();
|
||||||
|
|
||||||
/// SetDbgScopeEndLabels - Update DbgScope end labels for the scopes that
|
/// beginScope - Process beginning of a scope starting at Label.
|
||||||
/// end with this machine instruction.
|
void beginScope(const MachineInstr *MI, unsigned Label);
|
||||||
void SetDbgScopeEndLabels(const MachineInstr *MI, unsigned Label);
|
|
||||||
|
|
||||||
/// BeginScope - Process beginning of a scope starting at Label.
|
/// endScope - Prcess end of a scope.
|
||||||
void BeginScope(const MachineInstr *MI, unsigned Label);
|
void endScope(const MachineInstr *MI);
|
||||||
|
|
||||||
/// EndScope - Prcess end of a scope.
|
|
||||||
void EndScope(const MachineInstr *MI);
|
|
||||||
};
|
};
|
||||||
} // End of namespace llvm
|
} // End of namespace llvm
|
||||||
|
|
||||||
|
@ -43,14 +43,14 @@ void DwarfWriter::BeginModule(Module *M,
|
|||||||
DE = new DwarfException(OS, A, T);
|
DE = new DwarfException(OS, A, T);
|
||||||
DD = new DwarfDebug(OS, A, T);
|
DD = new DwarfDebug(OS, A, T);
|
||||||
DE->BeginModule(M, MMI);
|
DE->BeginModule(M, MMI);
|
||||||
DD->BeginModule(M, MMI);
|
DD->beginModule(M, MMI);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// EndModule - Emit all Dwarf sections that should come after the content.
|
/// EndModule - Emit all Dwarf sections that should come after the content.
|
||||||
///
|
///
|
||||||
void DwarfWriter::EndModule() {
|
void DwarfWriter::EndModule() {
|
||||||
DE->EndModule();
|
DE->EndModule();
|
||||||
DD->EndModule();
|
DD->endModule();
|
||||||
delete DD; DD = 0;
|
delete DD; DD = 0;
|
||||||
delete DE; DE = 0;
|
delete DE; DE = 0;
|
||||||
}
|
}
|
||||||
@ -59,13 +59,13 @@ void DwarfWriter::EndModule() {
|
|||||||
/// emitted immediately after the function entry point.
|
/// emitted immediately after the function entry point.
|
||||||
void DwarfWriter::BeginFunction(MachineFunction *MF) {
|
void DwarfWriter::BeginFunction(MachineFunction *MF) {
|
||||||
DE->BeginFunction(MF);
|
DE->BeginFunction(MF);
|
||||||
DD->BeginFunction(MF);
|
DD->beginFunction(MF);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// EndFunction - Gather and emit post-function debug information.
|
/// EndFunction - Gather and emit post-function debug information.
|
||||||
///
|
///
|
||||||
void DwarfWriter::EndFunction(MachineFunction *MF) {
|
void DwarfWriter::EndFunction(MachineFunction *MF) {
|
||||||
DD->EndFunction(MF);
|
DD->endFunction(MF);
|
||||||
DE->EndFunction();
|
DE->EndFunction();
|
||||||
|
|
||||||
if (MachineModuleInfo *MMI = DD->getMMI() ? DD->getMMI() : DE->getMMI())
|
if (MachineModuleInfo *MMI = DD->getMMI() ? DD->getMMI() : DE->getMMI())
|
||||||
@ -78,12 +78,12 @@ void DwarfWriter::EndFunction(MachineFunction *MF) {
|
|||||||
/// correspondence to the source line list.
|
/// correspondence to the source line list.
|
||||||
unsigned DwarfWriter::RecordSourceLine(unsigned Line, unsigned Col,
|
unsigned DwarfWriter::RecordSourceLine(unsigned Line, unsigned Col,
|
||||||
MDNode *Scope) {
|
MDNode *Scope) {
|
||||||
return DD->RecordSourceLine(Line, Col, Scope);
|
return DD->recordSourceLine(Line, Col, Scope);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// getRecordSourceLineCount - Count source lines.
|
/// getRecordSourceLineCount - Count source lines.
|
||||||
unsigned DwarfWriter::getRecordSourceLineCount() {
|
unsigned DwarfWriter::getRecordSourceLineCount() {
|
||||||
return DD->getRecordSourceLineCount();
|
return DD->getSourceLineCount();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// ShouldEmitDwarfDebug - Returns true if Dwarf debugging declarations should
|
/// ShouldEmitDwarfDebug - Returns true if Dwarf debugging declarations should
|
||||||
@ -93,8 +93,8 @@ bool DwarfWriter::ShouldEmitDwarfDebug() const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void DwarfWriter::BeginScope(const MachineInstr *MI, unsigned L) {
|
void DwarfWriter::BeginScope(const MachineInstr *MI, unsigned L) {
|
||||||
DD->BeginScope(MI, L);
|
DD->beginScope(MI, L);
|
||||||
}
|
}
|
||||||
void DwarfWriter::EndScope(const MachineInstr *MI) {
|
void DwarfWriter::EndScope(const MachineInstr *MI) {
|
||||||
DD->EndScope(MI);
|
DD->endScope(MI);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user