summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2007-09-06 01:07:24 +0000
committerEvan Cheng <evan.cheng@apple.com>2007-09-06 01:07:24 +0000
commitd059eed1c14db51c4910d2468a01f84c33f188b1 (patch)
treef8ad0c950dd62ad8c9217efa900633af2edb2002 /llvm/lib/CodeGen
parentb56a9909556aee1670e88adcf8b0a56dc25c5c9e (diff)
downloadbcm5719-llvm-d059eed1c14db51c4910d2468a01f84c33f188b1.tar.gz
bcm5719-llvm-d059eed1c14db51c4910d2468a01f84c33f188b1.zip
Fix a memory leak.
llvm-svn: 41739
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r--llvm/lib/CodeGen/LiveInterval.cpp2
-rw-r--r--llvm/lib/CodeGen/LiveIntervalAnalysis.cpp3
2 files changed, 4 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/LiveInterval.cpp b/llvm/lib/CodeGen/LiveInterval.cpp
index 4d38f0adcfa..9b4872d8308 100644
--- a/llvm/lib/CodeGen/LiveInterval.cpp
+++ b/llvm/lib/CodeGen/LiveInterval.cpp
@@ -476,7 +476,9 @@ void LiveInterval::MergeValueNumberInto(VNInfo *V1, VNInfo *V2) {
// ~1U so it can be nuked later.
if (V1->id == getNumValNums()-1) {
do {
+ VNInfo *VNI = valnos.back();
valnos.pop_back();
+ VNI->~VNInfo();
} while (valnos.back()->def == ~1U);
} else {
V1->def = ~1U;
diff --git a/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp b/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp
index 2f93b769485..3d324b7bfc6 100644
--- a/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp
+++ b/llvm/lib/CodeGen/LiveIntervalAnalysis.cpp
@@ -62,10 +62,11 @@ void LiveIntervals::getAnalysisUsage(AnalysisUsage &AU) const {
}
void LiveIntervals::releaseMemory() {
- VNInfoAllocator.Reset();
mi2iMap_.clear();
i2miMap_.clear();
r2iMap_.clear();
+ // Release VNInfo memroy regions after all VNInfo objects are dtor'd.
+ VNInfoAllocator.Reset();
for (unsigned i = 0, e = ClonedMIs.size(); i != e; ++i)
delete ClonedMIs[i];
}
OpenPOWER on IntegriCloud