diff options
| author | Chris Lattner <sabre@nondot.org> | 2002-09-12 17:06:40 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2002-09-12 17:06:40 +0000 |
| commit | bae3c670505a410ddb91b83671b3b9bcf3ccf49f (patch) | |
| tree | 367c1a25bc82217985b95fc438e76f2c75255a02 /llvm/lib/VMCore/Pass.cpp | |
| parent | 500f06490d256b135fcd704b8845a627d97091d7 (diff) | |
| download | bcm5719-llvm-bae3c670505a410ddb91b83671b3b9bcf3ccf49f.tar.gz bcm5719-llvm-bae3c670505a410ddb91b83671b3b9bcf3ccf49f.zip | |
Add a new BasicBlockPass::doInitialization/Finalization(Function &) pair of
methods that may be useful for BasicBlockPasses.
llvm-svn: 3688
Diffstat (limited to 'llvm/lib/VMCore/Pass.cpp')
| -rw-r--r-- | llvm/lib/VMCore/Pass.cpp | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/llvm/lib/VMCore/Pass.cpp b/llvm/lib/VMCore/Pass.cpp index b673484f214..19b564e61f3 100644 --- a/llvm/lib/VMCore/Pass.cpp +++ b/llvm/lib/VMCore/Pass.cpp @@ -341,18 +341,20 @@ void FunctionPass::addToPassManager(PassManagerT<Function> *PM, // function. // bool BasicBlockPass::runOnFunction(Function &F) { - bool Changed = false; + bool Changed = doInitialization(F); for (Function::iterator I = F.begin(), E = F.end(); I != E; ++I) Changed |= runOnBasicBlock(*I); - return Changed; + return Changed | doFinalization(F); } // To run directly on the basic block, we initialize, runOnBasicBlock, then // finalize. // bool BasicBlockPass::run(BasicBlock &BB) { - Module &M = *BB.getParent()->getParent(); - return doInitialization(M) | runOnBasicBlock(BB) | doFinalization(M); + Function &F = *BB.getParent(); + Module &M = *F.getParent(); + return doInitialization(M) | doInitialization(F) | runOnBasicBlock(BB) | + doFinalization(F) | doFinalization(M); } void BasicBlockPass::addToPassManager(PassManagerT<Function> *PM, |

