Index: include/llvm/Analysis/LoopPass.h =================================================================== --- include/llvm/Analysis/LoopPass.h (revision 169026) +++ include/llvm/Analysis/LoopPass.h (working copy) @@ -39,6 +39,9 @@ // whatever action is necessary for the specified Loop. virtual bool runOnLoop(Loop *L, LPPassManager &LPM) = 0; + using llvm::Pass::doInitialization; + using llvm::Pass::doFinalization; + // Initialization and finalization hooks. virtual bool doInitialization(Loop *L, LPPassManager &LPM) { return false; Index: include/llvm/Analysis/RegionPass.h =================================================================== --- include/llvm/Analysis/RegionPass.h (revision 169026) +++ include/llvm/Analysis/RegionPass.h (working copy) @@ -59,6 +59,9 @@ /// @return The pass to print the LLVM IR in the region. Pass *createPrinterPass(raw_ostream &O, const std::string &Banner) const; + using llvm::Pass::doInitialization; + using llvm::Pass::doFinalization; + virtual bool doInitialization(Region *R, RGPassManager &RGM) { return false; } virtual bool doFinalization() { return false; } //@} Index: include/llvm/CallGraphSCCPass.h =================================================================== --- include/llvm/CallGraphSCCPass.h (revision 169026) +++ include/llvm/CallGraphSCCPass.h (working copy) @@ -39,6 +39,9 @@ /// corresponding to a CallGraph. Pass *createPrinterPass(raw_ostream &O, const std::string &Banner) const; + using llvm::Pass::doInitialization; + using llvm::Pass::doFinalization; + /// 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(CallGraph &CG) { Index: include/llvm/Pass.h =================================================================== --- include/llvm/Pass.h (revision 169026) +++ include/llvm/Pass.h (working copy) @@ -104,6 +104,16 @@ return PassID; } + /// doInitialization - Virtual method overridden by subclasses to do + /// any necessary initialization before any pass is run. + /// + virtual bool doInitialization(Module &) { return false; } + + /// doFinalization - Virtual method overriden by subclasses to do any + /// necessary clean up after all passes have run. + /// + virtual bool doFinalization(Module &) { return false; } + /// print - Print out the internal state of the pass. This is called by /// Analyze to print out the contents of an analysis. Otherwise it is not /// necessary to implement this method. Beware that the module pointer MAY be @@ -227,20 +237,10 @@ /// createPrinterPass - Get a module printer pass. Pass *createPrinterPass(raw_ostream &O, const std::string &Banner) const; - /// doInitialization - Virtual method overridden by subclasses to do - /// any necessary initialization before any pass is run. - /// - virtual bool doInitialization(Module &) { return false; } - /// runOnModule - Virtual method overriden by subclasses to process the module /// being operated on. virtual bool runOnModule(Module &M) = 0; - /// doFinalization - Virtual method overriden by subclasses to do any - /// necessary clean up after all passes have run. - /// - virtual bool doFinalization(Module &) { return false; } - virtual void assignPassManager(PMStack &PMS, PassManagerType T); @@ -297,21 +297,11 @@ /// createPrinterPass - Get a function printer pass. Pass *createPrinterPass(raw_ostream &O, const std::string &Banner) const; - /// doInitialization - Virtual method overridden by subclasses to do - /// any necessary per-module initialization. - /// - virtual bool doInitialization(Module &); - /// runOnFunction - Virtual method overriden by subclasses to do the /// per-function processing of the pass. /// virtual bool runOnFunction(Function &F) = 0; - /// doFinalization - Virtual method overriden by subclasses to do any post - /// processing needed after all passes have run. - /// - virtual bool doFinalization(Module &); - virtual void assignPassManager(PMStack &PMS, PassManagerType T); @@ -338,10 +328,8 @@ /// createPrinterPass - Get a basic block printer pass. Pass *createPrinterPass(raw_ostream &O, const std::string &Banner) const; - /// doInitialization - Virtual method overridden by subclasses to do - /// any necessary per-module initialization. - /// - virtual bool doInitialization(Module &); + using llvm::Pass::doInitialization; + using llvm::Pass::doFinalization; /// doInitialization - Virtual method overridden by BasicBlockPass subclasses /// to do any necessary per-function initialization. @@ -358,11 +346,6 @@ /// virtual bool doFinalization(Function &); - /// doFinalization - Virtual method overriden by subclasses to do any post - /// processing needed after all passes have run. - /// - virtual bool doFinalization(Module &); - virtual void assignPassManager(PMStack &PMS, PassManagerType T); Index: include/llvm/CodeGen/MachineModuleInfo.h =================================================================== --- include/llvm/CodeGen/MachineModuleInfo.h (revision 169026) +++ include/llvm/CodeGen/MachineModuleInfo.h (working copy) @@ -180,12 +180,6 @@ const MCObjectFileInfo *MOFI); ~MachineModuleInfo(); - using ModulePass::doInitialization; - bool doInitialization(); - - using ModulePass::doFinalization; - bool doFinalization(); - /// EndFunction - Discard function meta information. /// void EndFunction(); Index: lib/VMCore/Pass.cpp =================================================================== --- lib/VMCore/Pass.cpp (revision 169026) +++ lib/VMCore/Pass.cpp (working copy) @@ -133,16 +133,6 @@ return createPrintFunctionPass(Banner, &O); } -bool FunctionPass::doInitialization(Module &) { - // By default, don't do anything. - return false; -} - -bool FunctionPass::doFinalization(Module &) { - // By default, don't do anything. - return false; -} - PassManagerType FunctionPass::getPotentialPassManagerType() const { return PMT_FunctionPassManager; } @@ -157,11 +147,6 @@ llvm_unreachable("BasicBlockPass printing unsupported."); } -bool BasicBlockPass::doInitialization(Module &) { - // By default, don't do anything. - return false; -} - bool BasicBlockPass::doInitialization(Function &) { // By default, don't do anything. return false; @@ -172,11 +157,6 @@ return false; } -bool BasicBlockPass::doFinalization(Module &) { - // By default, don't do anything. - return false; -} - PassManagerType BasicBlockPass::getPotentialPassManagerType() const { return PMT_BasicBlockPassManager; } Index: lib/CodeGen/MachineModuleInfo.cpp =================================================================== --- lib/CodeGen/MachineModuleInfo.cpp (revision 169027) +++ lib/CodeGen/MachineModuleInfo.cpp (working copy) @@ -282,21 +282,6 @@ AddrLabelSymbols = 0; } -/// doInitialization - Initialize the state for a new module. -/// -bool MachineModuleInfo::doInitialization() { - assert(AddrLabelSymbols == 0 && "Improperly initialized"); - return false; -} - -/// doFinalization - Tear down the state after completion of a module. -/// -bool MachineModuleInfo::doFinalization() { - delete AddrLabelSymbols; - AddrLabelSymbols = 0; - return false; -} - /// EndFunction - Discard function meta information. /// void MachineModuleInfo::EndFunction() {