mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-26 07:24:25 +00:00
DwarfDebug: Avoid an extra map lookup while constructing abstract scope DIEs and reduce nesting/conditionals.
One test case had to be updated as it still had the extra indirection for the variable list - removing the extra indirection got it back to passing. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@208608 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -576,7 +576,8 @@ void DwarfDebug::constructAbstractSubprogramScopeDIE(DwarfCompileUnit &TheCU,
|
||||
|
||||
DISubprogram Sub(Scope->getScopeNode());
|
||||
|
||||
ProcessedSPNodes.insert(Sub);
|
||||
if (!ProcessedSPNodes.insert(Sub))
|
||||
return;
|
||||
|
||||
if (DIE *ScopeDIE = TheCU.getDIE(Sub)) {
|
||||
AbstractSPDies.insert(std::make_pair(Sub, ScopeDIE));
|
||||
@ -1575,25 +1576,25 @@ void DwarfDebug::endFunction(const MachineFunction *MF) {
|
||||
// Construct abstract scopes.
|
||||
for (LexicalScope *AScope : LScopes.getAbstractScopesList()) {
|
||||
DISubprogram SP(AScope->getScopeNode());
|
||||
if (SP.isSubprogram()) {
|
||||
// Collect info for variables that were optimized out.
|
||||
DIArray Variables = SP.getVariables();
|
||||
for (unsigned i = 0, e = Variables.getNumElements(); i != e; ++i) {
|
||||
DIVariable DV(Variables.getElement(i));
|
||||
if (!DV || !DV.isVariable() || !ProcessedVars.insert(DV))
|
||||
continue;
|
||||
// Check that DbgVariable for DV wasn't created earlier, when
|
||||
// findAbstractVariable() was called for inlined instance of DV.
|
||||
LLVMContext &Ctx = DV->getContext();
|
||||
DIVariable CleanDV = cleanseInlinedVariable(DV, Ctx);
|
||||
if (AbstractVariables.lookup(CleanDV))
|
||||
continue;
|
||||
if (LexicalScope *Scope = LScopes.findAbstractScope(DV.getContext()))
|
||||
addScopeVariable(Scope, new DbgVariable(DV, nullptr, this));
|
||||
}
|
||||
if (!SP.isSubprogram())
|
||||
continue;
|
||||
// Collect info for variables that were optimized out.
|
||||
DIArray Variables = SP.getVariables();
|
||||
for (unsigned i = 0, e = Variables.getNumElements(); i != e; ++i) {
|
||||
DIVariable DV(Variables.getElement(i));
|
||||
assert(DV && DV.isVariable());
|
||||
if (!ProcessedVars.insert(DV))
|
||||
continue;
|
||||
// Check that DbgVariable for DV wasn't created earlier, when
|
||||
// findAbstractVariable() was called for inlined instance of DV.
|
||||
LLVMContext &Ctx = DV->getContext();
|
||||
DIVariable CleanDV = cleanseInlinedVariable(DV, Ctx);
|
||||
if (AbstractVariables.lookup(CleanDV))
|
||||
continue;
|
||||
if (LexicalScope *Scope = LScopes.findAbstractScope(DV.getContext()))
|
||||
addScopeVariable(Scope, new DbgVariable(DV, nullptr, this));
|
||||
}
|
||||
if (ProcessedSPNodes.count(AScope->getScopeNode()) == 0)
|
||||
constructAbstractSubprogramScopeDIE(TheCU, AScope);
|
||||
constructAbstractSubprogramScopeDIE(TheCU, AScope);
|
||||
}
|
||||
|
||||
DIE &CurFnDIE = constructSubprogramScopeDIE(TheCU, FnScope);
|
||||
|
Reference in New Issue
Block a user