From a10df5028211fc897751d23e91d035db47d23fac Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 20 Apr 2004 21:30:06 +0000 Subject: [PATCH] Add the ability for SCC passes to initialize and finalize themselves git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@13084 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/CallGraphSCCPass.h | 13 +++++++++++++ lib/Analysis/IPA/CallGraphSCCPass.cpp | 9 +++------ 2 files changed, 16 insertions(+), 6 deletions(-) diff --git a/include/llvm/CallGraphSCCPass.h b/include/llvm/CallGraphSCCPass.h index 86cdc29f571..73c9323074f 100644 --- a/include/llvm/CallGraphSCCPass.h +++ b/include/llvm/CallGraphSCCPass.h @@ -26,9 +26,16 @@ namespace llvm { class CallGraphNode; +class Module; struct CallGraphSCCPass : public Pass { + /// doInitialization - This method is called before the SCC's of the program + /// has been processed, allowing the pass to do initialization as necessary. + virtual bool doInitialization(Module &M) { + return false; + } + /// runOnSCC - This method should be implemented by the subclass to perform /// whatever action is necessary for the specified SCC. Note that /// non-recursive (or only self-recursive) functions will have an SCC size of @@ -36,6 +43,12 @@ struct CallGraphSCCPass : public Pass { /// virtual bool runOnSCC(const std::vector &SCC) = 0; + /// doFinalization - This method is called after the SCC's of the program has + /// been processed, allowing the pass to do final cleanup as necessary. + virtual bool doFinalization(Module &M) { + return false; + } + /// run - Run this pass, returning true if a modification was made to the /// module argument. This is implemented in terms of the runOnSCC method. /// diff --git a/lib/Analysis/IPA/CallGraphSCCPass.cpp b/lib/Analysis/IPA/CallGraphSCCPass.cpp index e9ab6500c8d..23aedb0731f 100644 --- a/lib/Analysis/IPA/CallGraphSCCPass.cpp +++ b/lib/Analysis/IPA/CallGraphSCCPass.cpp @@ -18,8 +18,7 @@ #include "llvm/CallGraphSCCPass.h" #include "llvm/Analysis/CallGraph.h" #include "Support/SCCIterator.h" - -namespace llvm { +using namespace llvm; /// getAnalysisUsage - For this class, we declare that we require and preserve /// the call graph. If the derived class implements this method, it should @@ -31,11 +30,9 @@ void CallGraphSCCPass::getAnalysisUsage(AnalysisUsage &AU) const { bool CallGraphSCCPass::run(Module &M) { CallGraph &CG = getAnalysis(); - bool Changed = false; + bool Changed = doInitialization(M); for (scc_iterator I = scc_begin(&CG), E = scc_end(&CG); I != E; ++I) Changed = runOnSCC(*I); - return Changed; + return Changed | doFinalization(M); } - -} // End llvm namespace