From eded4916d6679a8c42e5f16d022afe0252c2df8e Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 26 Feb 2002 20:04:59 +0000 Subject: [PATCH] Move ProfilePaths class into ProfilePaths library, only expose a creation function git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1812 91177308-0d34-0410-b5e6-96231b3b80d8 --- .../Transforms/Instrumentation/ProfilePaths.h | 14 ++----- .../ProfilePaths/ProfilePaths.cpp | 37 +++++++++++-------- tools/opt/opt.cpp | 4 +- 3 files changed, 29 insertions(+), 26 deletions(-) diff --git a/include/llvm/Transforms/Instrumentation/ProfilePaths.h b/include/llvm/Transforms/Instrumentation/ProfilePaths.h index de9d37c4e88..4004c7fd95f 100644 --- a/include/llvm/Transforms/Instrumentation/ProfilePaths.h +++ b/include/llvm/Transforms/Instrumentation/ProfilePaths.h @@ -27,17 +27,11 @@ #ifndef LLVM_TRANSFORMS_INSTRUMENTATION_PROFILE_PATHS_H #define LLVM_TRANSFORMS_INSTRUMENTATION_PROFILE_PATHS_H -#include "llvm/Pass.h" +class Pass; -class ProfilePaths: public MethodPass { - public: - bool runOnMethod(Method *M); - - // getAnalysisUsageInfo - transform cfg to have just one exit node - virtual void getAnalysisUsageInfo(Pass::AnalysisSet &Requires, - Pass::AnalysisSet &Destroyed, - Pass::AnalysisSet &Provided); -}; +// createProfilePathsPass - Create a new pass to add path profiling +// +Pass *createProfilePathsPass(); #endif diff --git a/lib/Transforms/Instrumentation/ProfilePaths/ProfilePaths.cpp b/lib/Transforms/Instrumentation/ProfilePaths/ProfilePaths.cpp index 03a3e4bcca7..1be6458fea2 100644 --- a/lib/Transforms/Instrumentation/ProfilePaths/ProfilePaths.cpp +++ b/lib/Transforms/Instrumentation/ProfilePaths/ProfilePaths.cpp @@ -32,10 +32,32 @@ #include "llvm/ConstantVals.h" #include "llvm/DerivedTypes.h" #include "llvm/iMemory.h" +#include "llvm/Pass.h" #include "Graph.h" using std::vector; +class ProfilePaths: public MethodPass { + public: + bool runOnMethod(Method *M); + + // Before this pass, make sure that there is only one + // entry and only one exit node for the method in the CFG of the method + // + void ProfilePaths::getAnalysisUsageInfo(Pass::AnalysisSet &Requires, + Pass::AnalysisSet &Destroyed, + Pass::AnalysisSet &Provided) { + Requires.push_back(UnifyMethodExitNodes::ID); + } +}; + +// createProfilePathsPass - Create a new pass to add path profiling +// +Pass *createProfilePathsPass() { + return new ProfilePaths(); +} + + static Node *findBB(std::set &st, BasicBlock *BB){ for(std::set::iterator si=st.begin(); si!=st.end(); ++si){ if(((*si)->getElement())==BB){ @@ -145,18 +167,3 @@ bool ProfilePaths::runOnMethod(Method *M){ return true; // Always modifies method } - -//Before this pass, make sure that there is only one -//entry and only one exit node for the method in the CFG of the method -void ProfilePaths::getAnalysisUsageInfo(Pass::AnalysisSet &Requires, - Pass::AnalysisSet &Destroyed, - Pass::AnalysisSet &Provided) { - Requires.push_back(UnifyMethodExitNodes::ID); -} - - - - - - - diff --git a/tools/opt/opt.cpp b/tools/opt/opt.cpp index 34eff8f2ff4..2b2447b155b 100644 --- a/tools/opt/opt.cpp +++ b/tools/opt/opt.cpp @@ -100,9 +100,11 @@ struct { { trace , New }, { tracem , New }, - { paths , New }, + { paths , createProfilePathsPass }, + { print , NewPrintMethodPass }, { verify , createVerifierPass }, + { raiseallocs, New }, { cleangcc , New }, { globaldce , New }, -- 2.34.1