diff options
| author | Devang Patel <dpatel@apple.com> | 2007-07-31 08:00:57 +0000 |
|---|---|---|
| committer | Devang Patel <dpatel@apple.com> | 2007-07-31 08:00:57 +0000 |
| commit | cc2b233b62f07e259979b4abc64a4bb5b82616a8 (patch) | |
| tree | c4be105e90ef83de3c39a93d07e4a9fe21036e12 /llvm/lib/Analysis/LoopPass.cpp | |
| parent | b08423b36ea113c5e8847705799c235bbc70ad1f (diff) | |
| download | bcm5719-llvm-cc2b233b62f07e259979b4abc64a4bb5b82616a8.tar.gz bcm5719-llvm-cc2b233b62f07e259979b4abc64a4bb5b82616a8.zip | |
Introduce Simple Analysis interface for loop passes.
Right now, this interface provides hooks for only to operations, 1) clone basic block 2) delete value.
llvm-svn: 40625
Diffstat (limited to 'llvm/lib/Analysis/LoopPass.cpp')
| -rw-r--r-- | llvm/lib/Analysis/LoopPass.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/LoopPass.cpp b/llvm/lib/Analysis/LoopPass.cpp index dc3e86844eb..21c14c6293e 100644 --- a/llvm/lib/Analysis/LoopPass.cpp +++ b/llvm/lib/Analysis/LoopPass.cpp @@ -140,6 +140,27 @@ void LPPassManager::redoLoop(Loop *L) { redoThisLoop = true; } +/// cloneBasicBlockSimpleAnalysis - Invoke cloneBasicBlockAnalysis hook for +/// all loop passes. +void LPPassManager::cloneBasicBlockSimpleAnalysis(BasicBlock *From, + BasicBlock *To, Loop *L) { + for (unsigned Index = 0; Index < getNumContainedPasses(); ++Index) { + Pass *P = getContainedPass(Index); + LoopPass *LP = dynamic_cast<LoopPass *>(P); + LP->cloneBasicBlockAnalysis(From, To, L); + } +} + +/// deleteSimpleAnalysisValue - Invoke deleteAnalysisValue hook for all passes. +void LPPassManager::deleteSimpleAnalysisValue(Value *V, Loop *L) { + for (unsigned Index = 0; Index < getNumContainedPasses(); ++Index) { + Pass *P = getContainedPass(Index); + LoopPass *LP = dynamic_cast<LoopPass *>(P); + LP->deleteAnalysisValue(V, L); + } +} + + // Recurse through all subloops and all loops into LQ. static void addLoopIntoQueue(Loop *L, std::deque<Loop *> &LQ) { LQ.push_back(L); |

