diff options
author | Devang Patel <dpatel@apple.com> | 2009-03-25 23:57:48 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2009-03-25 23:57:48 +0000 |
commit | 575ec806e0d6e10eaf1bbe4163379d51565f7fe4 (patch) | |
tree | 6adfb2dd1e8a83e6c858a6e10f13483a3d6f9fab /lib | |
parent | 54f302272c6bf98638d224949be8bd23a120ba48 (diff) | |
download | external_llvm-575ec806e0d6e10eaf1bbe4163379d51565f7fe4.tar.gz external_llvm-575ec806e0d6e10eaf1bbe4163379d51565f7fe4.tar.bz2 external_llvm-575ec806e0d6e10eaf1bbe4163379d51565f7fe4.zip |
Before deleting a basic block, give other loop passes a chance cleanup analysis values, related to the instructions in the basic block.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@67719 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Analysis/LoopPass.cpp | 7 | ||||
-rw-r--r-- | lib/Transforms/Scalar/LoopIndexSplit.cpp | 2 |
2 files changed, 8 insertions, 1 deletions
diff --git a/lib/Analysis/LoopPass.cpp b/lib/Analysis/LoopPass.cpp index c4ff988944..08c25f4cea 100644 --- a/lib/Analysis/LoopPass.cpp +++ b/lib/Analysis/LoopPass.cpp @@ -152,6 +152,13 @@ void LPPassManager::cloneBasicBlockSimpleAnalysis(BasicBlock *From, /// deleteSimpleAnalysisValue - Invoke deleteAnalysisValue hook for all passes. void LPPassManager::deleteSimpleAnalysisValue(Value *V, Loop *L) { + if (BasicBlock *BB = dyn_cast<BasicBlock>(V)) { + for (BasicBlock::iterator BI = BB->begin(), BE = BB->end(); BI != BE; + ++BI) { + Instruction &I = *BI; + deleteSimpleAnalysisValue(&I, L); + } + } for (unsigned Index = 0; Index < getNumContainedPasses(); ++Index) { Pass *P = getContainedPass(Index); LoopPass *LP = dynamic_cast<LoopPass *>(P); diff --git a/lib/Transforms/Scalar/LoopIndexSplit.cpp b/lib/Transforms/Scalar/LoopIndexSplit.cpp index e93d448cc1..98e5cc15d6 100644 --- a/lib/Transforms/Scalar/LoopIndexSplit.cpp +++ b/lib/Transforms/Scalar/LoopIndexSplit.cpp @@ -673,6 +673,7 @@ void LoopIndexSplit::removeBlocks(BasicBlock *DeadBB, Loop *LP, while (!WorkList.empty()) { BasicBlock *BB = WorkList.back(); WorkList.pop_back(); + LPM->deleteSimpleAnalysisValue(BB, LP); for(BasicBlock::iterator BBI = BB->begin(), BBE = BB->end(); BBI != BBE; ) { Instruction *I = BBI; @@ -680,7 +681,6 @@ void LoopIndexSplit::removeBlocks(BasicBlock *DeadBB, Loop *LP, I->replaceAllUsesWith(UndefValue::get(I->getType())); I->eraseFromParent(); } - LPM->deleteSimpleAnalysisValue(BB, LP); DT->eraseNode(BB); DF->removeBlock(BB); LI->removeBlock(BB); |