mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-25 03:30:37 +00:00
Sink DwarfDebug::constructInlinedScopeDIE into DwarfCompileUnit
This introduces access to the AbstractSPDies map from DwarfDebug so DwarfCompileUnit can access it. Eventually this'll sink down to DwarfFile, but it'll still be generically accessible - not much encapsulation to provide it. (constructInlinedScopeDIE could stay further up, in DwarfFile to avoid exposing this - but I don't think that's particularly better) git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@219411 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c53401ee91
commit
3fcb9f3ea5
@ -348,7 +348,7 @@ void DwarfCompileUnit::constructScopeDIE(
|
|||||||
// the scope DIE is null.
|
// the scope DIE is null.
|
||||||
std::unique_ptr<DIE> ScopeDIE;
|
std::unique_ptr<DIE> ScopeDIE;
|
||||||
if (Scope->getParent() && DS.isSubprogram()) {
|
if (Scope->getParent() && DS.isSubprogram()) {
|
||||||
ScopeDIE = DD->constructInlinedScopeDIE(*this, Scope);
|
ScopeDIE = constructInlinedScopeDIE(Scope);
|
||||||
if (!ScopeDIE)
|
if (!ScopeDIE)
|
||||||
return;
|
return;
|
||||||
// We create children when the scope DIE is not null.
|
// We create children when the scope DIE is not null.
|
||||||
@ -431,4 +431,34 @@ void DwarfCompileUnit::attachRangesOrLowHighPC(
|
|||||||
addScopeRangeList(Die, Ranges);
|
addScopeRangeList(Die, Ranges);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This scope represents inlined body of a function. Construct DIE to
|
||||||
|
// represent this concrete inlined copy of the function.
|
||||||
|
std::unique_ptr<DIE>
|
||||||
|
DwarfCompileUnit::constructInlinedScopeDIE(LexicalScope *Scope) {
|
||||||
|
assert(Scope->getScopeNode());
|
||||||
|
DIScope DS(Scope->getScopeNode());
|
||||||
|
DISubprogram InlinedSP = getDISubprogram(DS);
|
||||||
|
// Find the subprogram's DwarfCompileUnit in the SPMap in case the subprogram
|
||||||
|
// was inlined from another compile unit.
|
||||||
|
DIE *OriginDIE = DD->getAbstractSPDies()[InlinedSP];
|
||||||
|
assert(OriginDIE && "Unable to find original DIE for an inlined subprogram.");
|
||||||
|
|
||||||
|
auto ScopeDIE = make_unique<DIE>(dwarf::DW_TAG_inlined_subroutine);
|
||||||
|
addDIEEntry(*ScopeDIE, dwarf::DW_AT_abstract_origin, *OriginDIE);
|
||||||
|
|
||||||
|
attachRangesOrLowHighPC(*ScopeDIE, Scope->getRanges());
|
||||||
|
|
||||||
|
// Add the call site information to the DIE.
|
||||||
|
DILocation DL(Scope->getInlinedAt());
|
||||||
|
addUInt(*ScopeDIE, dwarf::DW_AT_call_file, None,
|
||||||
|
getOrCreateSourceID(DL.getFilename(), DL.getDirectory()));
|
||||||
|
addUInt(*ScopeDIE, dwarf::DW_AT_call_line, None, DL.getLineNumber());
|
||||||
|
|
||||||
|
// Add name to the name table, we do this here because we're guaranteed
|
||||||
|
// to have concrete versions of our DW_TAG_inlined_subprogram nodes.
|
||||||
|
DD->addSubprogramNames(InlinedSP, *ScopeDIE);
|
||||||
|
|
||||||
|
return ScopeDIE;
|
||||||
|
}
|
||||||
|
|
||||||
} // end llvm namespace
|
} // end llvm namespace
|
||||||
|
@ -89,6 +89,10 @@ public:
|
|||||||
|
|
||||||
void attachRangesOrLowHighPC(DIE &D,
|
void attachRangesOrLowHighPC(DIE &D,
|
||||||
const SmallVectorImpl<InsnRange> &Ranges);
|
const SmallVectorImpl<InsnRange> &Ranges);
|
||||||
|
|
||||||
|
/// \brief This scope represents inlined body of a function. Construct
|
||||||
|
/// DIE to represent this concrete inlined copy of the function.
|
||||||
|
std::unique_ptr<DIE> constructInlinedScopeDIE(LexicalScope *Scope);
|
||||||
};
|
};
|
||||||
|
|
||||||
} // end llvm namespace
|
} // end llvm namespace
|
||||||
|
@ -347,37 +347,6 @@ DwarfDebug::constructLexicalScopeDIE(DwarfCompileUnit &TheCU,
|
|||||||
return ScopeDIE;
|
return ScopeDIE;
|
||||||
}
|
}
|
||||||
|
|
||||||
// This scope represents inlined body of a function. Construct DIE to
|
|
||||||
// represent this concrete inlined copy of the function.
|
|
||||||
std::unique_ptr<DIE>
|
|
||||||
DwarfDebug::constructInlinedScopeDIE(DwarfCompileUnit &TheCU,
|
|
||||||
LexicalScope *Scope) {
|
|
||||||
assert(Scope->getScopeNode());
|
|
||||||
DIScope DS(Scope->getScopeNode());
|
|
||||||
DISubprogram InlinedSP = getDISubprogram(DS);
|
|
||||||
// Find the subprogram's DwarfCompileUnit in the SPMap in case the subprogram
|
|
||||||
// was inlined from another compile unit.
|
|
||||||
DIE *OriginDIE = AbstractSPDies[InlinedSP];
|
|
||||||
assert(OriginDIE && "Unable to find original DIE for an inlined subprogram.");
|
|
||||||
|
|
||||||
auto ScopeDIE = make_unique<DIE>(dwarf::DW_TAG_inlined_subroutine);
|
|
||||||
TheCU.addDIEEntry(*ScopeDIE, dwarf::DW_AT_abstract_origin, *OriginDIE);
|
|
||||||
|
|
||||||
TheCU.attachRangesOrLowHighPC(*ScopeDIE, Scope->getRanges());
|
|
||||||
|
|
||||||
// Add the call site information to the DIE.
|
|
||||||
DILocation DL(Scope->getInlinedAt());
|
|
||||||
TheCU.addUInt(*ScopeDIE, dwarf::DW_AT_call_file, None,
|
|
||||||
TheCU.getOrCreateSourceID(DL.getFilename(), DL.getDirectory()));
|
|
||||||
TheCU.addUInt(*ScopeDIE, dwarf::DW_AT_call_line, None, DL.getLineNumber());
|
|
||||||
|
|
||||||
// Add name to the name table, we do this here because we're guaranteed
|
|
||||||
// to have concrete versions of our DW_TAG_inlined_subprogram nodes.
|
|
||||||
addSubprogramNames(InlinedSP, *ScopeDIE);
|
|
||||||
|
|
||||||
return ScopeDIE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static std::unique_ptr<DIE> constructVariableDIE(DwarfCompileUnit &TheCU,
|
static std::unique_ptr<DIE> constructVariableDIE(DwarfCompileUnit &TheCU,
|
||||||
DbgVariable &DV,
|
DbgVariable &DV,
|
||||||
const LexicalScope &Scope,
|
const LexicalScope &Scope,
|
||||||
|
@ -661,6 +661,18 @@ public:
|
|||||||
/// going to be null.
|
/// going to be null.
|
||||||
bool isLexicalScopeDIENull(LexicalScope *Scope);
|
bool isLexicalScopeDIENull(LexicalScope *Scope);
|
||||||
|
|
||||||
|
/// \brief Return Label preceding the instruction.
|
||||||
|
MCSymbol *getLabelBeforeInsn(const MachineInstr *MI);
|
||||||
|
|
||||||
|
/// \brief Return Label immediately following the instruction.
|
||||||
|
MCSymbol *getLabelAfterInsn(const MachineInstr *MI);
|
||||||
|
|
||||||
|
// FIXME: Consider rolling ranges up into DwarfDebug since we use a single
|
||||||
|
// range_base anyway, so there's no need to keep them as separate per-CU range
|
||||||
|
// lists. (though one day we might end up with a range.dwo section, in which
|
||||||
|
// case it'd go to DwarfFile)
|
||||||
|
unsigned getNextRangeNumber() { return GlobalRangeCount++; }
|
||||||
|
|
||||||
// FIXME: Sink these functions down into DwarfFile/Dwarf*Unit.
|
// FIXME: Sink these functions down into DwarfFile/Dwarf*Unit.
|
||||||
|
|
||||||
/// \brief Construct new DW_TAG_lexical_block for this scope and
|
/// \brief Construct new DW_TAG_lexical_block for this scope and
|
||||||
@ -668,23 +680,14 @@ public:
|
|||||||
std::unique_ptr<DIE> constructLexicalScopeDIE(DwarfCompileUnit &TheCU,
|
std::unique_ptr<DIE> constructLexicalScopeDIE(DwarfCompileUnit &TheCU,
|
||||||
LexicalScope *Scope);
|
LexicalScope *Scope);
|
||||||
|
|
||||||
/// \brief This scope represents inlined body of a function. Construct
|
|
||||||
/// DIE to represent this concrete inlined copy of the function.
|
|
||||||
std::unique_ptr<DIE> constructInlinedScopeDIE(DwarfCompileUnit &TheCU,
|
|
||||||
LexicalScope *Scope);
|
|
||||||
|
|
||||||
/// A helper function to create children of a Scope DIE.
|
/// A helper function to create children of a Scope DIE.
|
||||||
DIE *createScopeChildrenDIE(DwarfCompileUnit &TheCU, LexicalScope *Scope,
|
DIE *createScopeChildrenDIE(DwarfCompileUnit &TheCU, LexicalScope *Scope,
|
||||||
SmallVectorImpl<std::unique_ptr<DIE>> &Children,
|
SmallVectorImpl<std::unique_ptr<DIE>> &Children,
|
||||||
unsigned *ChildScopeCount = nullptr);
|
unsigned *ChildScopeCount = nullptr);
|
||||||
|
|
||||||
/// \brief Return Label preceding the instruction.
|
DenseMap<const MDNode *, DIE *> &getAbstractSPDies() {
|
||||||
MCSymbol *getLabelBeforeInsn(const MachineInstr *MI);
|
return AbstractSPDies;
|
||||||
|
}
|
||||||
/// \brief Return Label immediately following the instruction.
|
|
||||||
MCSymbol *getLabelAfterInsn(const MachineInstr *MI);
|
|
||||||
|
|
||||||
unsigned getNextRangeNumber() { return GlobalRangeCount++; }
|
|
||||||
};
|
};
|
||||||
} // End of namespace llvm
|
} // End of namespace llvm
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user