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 | 4555618854c409cb804cd454b97771fa9f2d4b20 (patch) | |
tree | bd8802bea680b73fedafaa837c08a0d77a07ee7f /llvm/lib/Analysis/LoopPass.cpp | |
parent | a28908d575ed0180eddfd4fa7f25ac267a1f0ca3 (diff) | |
download | bcm5719-llvm-4555618854c409cb804cd454b97771fa9f2d4b20.tar.gz bcm5719-llvm-4555618854c409cb804cd454b97771fa9f2d4b20.zip |
Before deleting a basic block, give other loop passes a chance cleanup analysis values, related to the instructions in the basic block.
llvm-svn: 67719
Diffstat (limited to 'llvm/lib/Analysis/LoopPass.cpp')
-rw-r--r-- | llvm/lib/Analysis/LoopPass.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/LoopPass.cpp b/llvm/lib/Analysis/LoopPass.cpp index c4ff9889446..08c25f4ceae 100644 --- a/llvm/lib/Analysis/LoopPass.cpp +++ b/llvm/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); |