diff options
| author | Chris Lattner <sabre@nondot.org> | 2002-02-26 21:46:54 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2002-02-26 21:46:54 +0000 | 
| commit | bd0ef77cde9c9e82f2b4ad33e4982c46274d6540 (patch) | |
| tree | 0903b61112c9e6d336c8b623e235ede2f937f13c /lib/Transforms/Scalar/ADCE.cpp | |
| parent | 3b2541424f771ae11c30675ce06da7b380780028 (diff) | |
Change over to use new style pass mechanism, now passes only expose small
creation functions in their public header file, unless they can help it.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1816 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Scalar/ADCE.cpp')
| -rw-r--r-- | lib/Transforms/Scalar/ADCE.cpp | 33 | 
1 files changed, 18 insertions, 15 deletions
| diff --git a/lib/Transforms/Scalar/ADCE.cpp b/lib/Transforms/Scalar/ADCE.cpp index 91bed41f6c..14c68f410e 100644 --- a/lib/Transforms/Scalar/ADCE.cpp +++ b/lib/Transforms/Scalar/ADCE.cpp @@ -288,21 +288,24 @@ BasicBlock *ADCE::fixupCFG(BasicBlock *BB, std::set<BasicBlock*> &VisitedBlocks,    }  } - - -// doADCE - Execute the Agressive Dead Code Elimination Algorithm -// -bool AgressiveDCE::runOnMethod(Method *M) { -  return ADCE(M).doADCE( -       getAnalysis<cfg::DominanceFrontier>(cfg::DominanceFrontier::PostDomID)); +namespace { +  struct AgressiveDCE : public MethodPass { +    // doADCE - Execute the Agressive Dead Code Elimination Algorithm +    // +    virtual bool runOnMethod(Method *M) { +      return ADCE(M).doADCE( +   getAnalysis<cfg::DominanceFrontier>(cfg::DominanceFrontier::PostDomID)); +    } +    // getAnalysisUsageInfo - We require post dominance frontiers (aka Control +    // Dependence Graph) +    virtual void getAnalysisUsageInfo(Pass::AnalysisSet &Requires, +                                      Pass::AnalysisSet &Destroyed, +                                      Pass::AnalysisSet &Provided) { +      Requires.push_back(cfg::DominanceFrontier::PostDomID); +    } +  };  } - -// getAnalysisUsageInfo - We require post dominance frontiers (aka Control -// Dependence Graph) -// -void AgressiveDCE::getAnalysisUsageInfo(Pass::AnalysisSet &Requires, -                                        Pass::AnalysisSet &Destroyed, -                                        Pass::AnalysisSet &Provided) { -  Requires.push_back(cfg::DominanceFrontier::PostDomID); +Pass *createAgressiveDCEPass() { +  return new AgressiveDCE();  } | 
