mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-18 13:34:04 +00:00
Revert "Fix stuff... again."
Accidental commit. This reverts commit r219693. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@219695 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2b0657e28f
commit
8730dc16e9
@ -137,8 +137,6 @@ LexicalScope *LexicalScopes::findLexicalScope(DebugLoc DL) {
|
|||||||
/// getOrCreateLexicalScope - Find lexical scope for the given DebugLoc. If
|
/// getOrCreateLexicalScope - Find lexical scope for the given DebugLoc. If
|
||||||
/// not available then create new lexical scope.
|
/// not available then create new lexical scope.
|
||||||
LexicalScope *LexicalScopes::getOrCreateLexicalScope(DebugLoc DL) {
|
LexicalScope *LexicalScopes::getOrCreateLexicalScope(DebugLoc DL) {
|
||||||
if (DL.isUnknown())
|
|
||||||
return nullptr;
|
|
||||||
MDNode *Scope = nullptr;
|
MDNode *Scope = nullptr;
|
||||||
MDNode *InlinedAt = nullptr;
|
MDNode *InlinedAt = nullptr;
|
||||||
DL.getScopeAndInlinedAt(Scope, InlinedAt, MF->getFunction()->getContext());
|
DL.getScopeAndInlinedAt(Scope, InlinedAt, MF->getFunction()->getContext());
|
||||||
@ -174,12 +172,9 @@ LexicalScope *LexicalScopes::getOrCreateRegularScope(MDNode *Scope) {
|
|||||||
std::make_tuple(Parent, DIDescriptor(Scope),
|
std::make_tuple(Parent, DIDescriptor(Scope),
|
||||||
nullptr, false)).first;
|
nullptr, false)).first;
|
||||||
|
|
||||||
if (!Parent) {
|
if (!Parent && DIDescriptor(Scope).isSubprogram() &&
|
||||||
assert(DIDescriptor(Scope).isSubprogram());
|
DISubprogram(Scope).describes(MF->getFunction()))
|
||||||
assert(DISubprogram(Scope).describes(MF->getFunction()));
|
|
||||||
assert(!CurrentFnLexicalScope);
|
|
||||||
CurrentFnLexicalScope = &I->second;
|
CurrentFnLexicalScope = &I->second;
|
||||||
}
|
|
||||||
|
|
||||||
return &I->second;
|
return &I->second;
|
||||||
}
|
}
|
||||||
|
@ -568,34 +568,6 @@ bool DISubprogram::Verify() const {
|
|||||||
if (isLValueReference() && isRValueReference())
|
if (isLValueReference() && isRValueReference())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
// If a DISubprogram has an llvm::Function*, then scope chains from all
|
|
||||||
// instructions within the function should lead to this DISubprogram.
|
|
||||||
if (auto *F = getFunction()) {
|
|
||||||
LLVMContext &Ctxt = F->getContext();
|
|
||||||
for (auto &BB : *F) {
|
|
||||||
for (auto &I : BB) {
|
|
||||||
DebugLoc DL = I.getDebugLoc();
|
|
||||||
if (DL.isUnknown())
|
|
||||||
continue;
|
|
||||||
|
|
||||||
MDNode *Scope = nullptr;
|
|
||||||
MDNode *IA = nullptr;
|
|
||||||
// walk the inlined-at scopes
|
|
||||||
while (DL.getScopeAndInlinedAt(Scope, IA, F->getContext()), IA)
|
|
||||||
DL = DebugLoc::getFromDILocation(IA);
|
|
||||||
DL.getScopeAndInlinedAt(Scope, IA, Ctxt);
|
|
||||||
assert(!IA);
|
|
||||||
while (!DIDescriptor(Scope).isSubprogram()) {
|
|
||||||
DILexicalBlockFile D(Scope);
|
|
||||||
Scope = D.isLexicalBlockFile()
|
|
||||||
? D.getScope()
|
|
||||||
: DebugLoc::getFromDILexicalBlock(Scope).getScope(Ctxt);
|
|
||||||
}
|
|
||||||
if (!DISubprogram(Scope).describes(F))
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return DbgNode->getNumOperands() == 9 && getNumHeaderFields() == 12;
|
return DbgNode->getNumOperands() == 9 && getNumHeaderFields() == 12;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user