diff options
author | Devang Patel <dpatel@apple.com> | 2006-11-07 21:49:50 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2006-11-07 21:49:50 +0000 |
commit | 448d27cd795dc273249f123444509403f4fa4fac (patch) | |
tree | 1c5e13b933d0d8e232c1abb23f0e3eea49b6aade /lib/VMCore/PassManager.cpp | |
parent | 5e213ea69796f695d5c33f18c25c82dad4c87a24 (diff) |
Add FunctionPassManager_New.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31515 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore/PassManager.cpp')
-rw-r--r-- | lib/VMCore/PassManager.cpp | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/lib/VMCore/PassManager.cpp b/lib/VMCore/PassManager.cpp index bd8faac60a..450a515c40 100644 --- a/lib/VMCore/PassManager.cpp +++ b/lib/VMCore/PassManager.cpp @@ -54,3 +54,59 @@ BasicBlockPassManager_New::runOnFunction(Function &F) { return Changed; } +// FunctionPassManager_New implementation + +/////////////////////////////////////////////////////////////////////////////// +// FunctionPassManager + +/// Add pass P into the pass manager queue. If P is a BasicBlockPass then +/// either use it into active basic block pass manager or create new basic +/// block pass manager to handle pass P. +bool +FunctionPassManager_New::addPass (Pass *P) { + + // If P is a BasicBlockPass then use BasicBlockPassManager_New. + if (BasicBlockPass *BP = dynamic_cast<BasicBlockPass*>(P)) { + + if (!activeBBPassManager + || !activeBBPassManager->addPass(BP)) { + + activeBBPassManager = new BasicBlockPassManager_New(); + + PassVector.push_back(activeBBPassManager); + assert (!activeBBPassManager->addPass(BP) && + "Unable to add Pass"); + } + return true; + } + + FunctionPass *FP = dynamic_cast<FunctionPass *>(P); + if (!FP) + return false; + + // TODO: Check if it suitable to manage P using this FunctionPassManager + // or we need another instance of BasicBlockPassManager + + PassVector.push_back(FP); + activeBBPassManager = NULL; + return true; +} + +/// Execute all of the passes scheduled for execution by invoking +/// runOnFunction method. Keep track of whether any of the passes modifies +/// the function, and if so, return true. +bool +FunctionPassManager_New::runOnModule(Module &M) { + + bool Changed = false; + for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I) + for (std::vector<Pass *>::iterator itr = PassVector.begin(), + e = PassVector.end(); itr != e; ++itr) { + Pass *P = *itr; + FunctionPass *FP = dynamic_cast<FunctionPass*>(P); + Changed |= FP->runOnFunction(*I); + } + return Changed; +} + + |