aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Analysis
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2010-08-11 22:36:04 +0000
committerOwen Anderson <resistor@mac.com>2010-08-11 22:36:04 +0000
commitf5e94ec0d24c92dce4f37a30173d9ff0efe55767 (patch)
tree19607ac88f6dac913bcb44bc69635244df6f36fb /lib/Analysis
parenta1bccc58b83479dc744127a4a2c79f2f7d4f8862 (diff)
downloadexternal_llvm-f5e94ec0d24c92dce4f37a30173d9ff0efe55767.zip
external_llvm-f5e94ec0d24c92dce4f37a30173d9ff0efe55767.tar.gz
external_llvm-f5e94ec0d24c92dce4f37a30173d9ff0efe55767.tar.bz2
Fix a subtle use-after-free issue.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110863 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis')
-rw-r--r--lib/Analysis/LazyValueInfo.cpp5
1 files changed, 4 insertions, 1 deletions
diff --git a/lib/Analysis/LazyValueInfo.cpp b/lib/Analysis/LazyValueInfo.cpp
index c932e81..d3a437f 100644
--- a/lib/Analysis/LazyValueInfo.cpp
+++ b/lib/Analysis/LazyValueInfo.cpp
@@ -384,7 +384,6 @@ namespace {
} // end anonymous namespace
void LazyValueInfoCache::LVIValueHandle::deleted() {
- Parent->ValueCache.erase(*this);
for (std::set<std::pair<BasicBlock*, Value*> >::iterator
I = Parent->OverDefinedCache.begin(),
E = Parent->OverDefinedCache.end();
@@ -394,6 +393,10 @@ void LazyValueInfoCache::LVIValueHandle::deleted() {
if (tmp->second == getValPtr())
Parent->OverDefinedCache.erase(tmp);
}
+
+ // This erasure deallocates *this, so it MUST happen after we're done
+ // using any and all members of *this.
+ Parent->ValueCache.erase(*this);
}