diff options
author | Devang Patel <dpatel@apple.com> | 2010-01-29 18:11:03 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2010-01-29 18:11:03 +0000 |
commit | 3dd96a1489498deb03208f7011f48b9f3d7901db (patch) | |
tree | 010d8a0a19281f109f33f1051b46419d7cae80c5 /lib/CodeGen/CGDebugInfo.cpp | |
parent | 3c9e03bda57d33097b19eef1dbb06bc5b2876551 (diff) |
Maintain a map of regions (lexical scopes) and use it to find context for a global variable.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@94817 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGDebugInfo.cpp')
-rw-r--r-- | lib/CodeGen/CGDebugInfo.cpp | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/lib/CodeGen/CGDebugInfo.cpp b/lib/CodeGen/CGDebugInfo.cpp index 3597098a60..ac3d5bd3b4 100644 --- a/lib/CodeGen/CGDebugInfo.cpp +++ b/lib/CodeGen/CGDebugInfo.cpp @@ -50,17 +50,13 @@ void CGDebugInfo::setLocation(SourceLocation Loc) { } /// getContextDescriptor - Get context info for the decl. -llvm::DIDescriptor CGDebugInfo::getContextDescriptor(const VarDecl *Decl, +llvm::DIDescriptor CGDebugInfo::getContextDescriptor(const Decl *D, llvm::DIDescriptor &CompileUnit) { - if (Decl->isFileVarDecl()) - return CompileUnit; - if (Decl->getDeclContext()->isFunctionOrMethod()) { - // Find the last subprogram in region stack. - for (unsigned RI = RegionStack.size(), RE = 0; RI != RE; --RI) { - llvm::DIDescriptor R(RegionStack[RI - 1]); - if (R.isSubprogram()) - return R; - } + if (const Decl *Parent = dyn_cast<Decl>(D->getDeclContext())) { + llvm::DenseMap<const Decl *, llvm::WeakVH>::iterator + I = RegionMap.find(Parent); + if (I != RegionMap.end()) + return llvm::DIDescriptor(dyn_cast_or_null<llvm::MDNode>(I->second)); } return CompileUnit; } @@ -1273,6 +1269,7 @@ void CGDebugInfo::EmitFunctionStart(GlobalDecl GD, QualType FnType, llvm::DISubprogram SP(dyn_cast_or_null<llvm::MDNode>(FI->second)); if (!SP.isNull() && SP.isSubprogram() && SP.isDefinition()) { RegionStack.push_back(SP.getNode()); + RegionMap[D] = llvm::WeakVH(SP.getNode()); return; } } @@ -1303,6 +1300,7 @@ void CGDebugInfo::EmitFunctionStart(GlobalDecl GD, QualType FnType, // Push function on region stack. RegionStack.push_back(SP.getNode()); + RegionMap[D] = llvm::WeakVH(SP.getNode()); } |