summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2007-04-16 18:51:25 +0000
committerDevang Patel <dpatel@apple.com>2007-04-16 18:51:25 +0000
commit254c9eb7c8261e10c77c5e3e5bb32bcb0f2bb4f2 (patch)
treeff9ddb79a52e37e81676c45161690f6623de5388
parent475eb0f4edabd8ac1b8bc8297fdd8a5680c020f4 (diff)
downloadbcm5719-llvm-254c9eb7c8261e10c77c5e3e5bb32bcb0f2bb4f2.tar.gz
bcm5719-llvm-254c9eb7c8261e10c77c5e3e5bb32bcb0f2bb4f2.zip
Add getPotentialPassManagerType(). No functionality change, yet.
llvm-svn: 36149
-rw-r--r--llvm/include/llvm/Analysis/LoopPass.h4
-rw-r--r--llvm/include/llvm/CallGraphSCCPass.h5
-rw-r--r--llvm/include/llvm/Pass.h23
3 files changed, 31 insertions, 1 deletions
diff --git a/llvm/include/llvm/Analysis/LoopPass.h b/llvm/include/llvm/Analysis/LoopPass.h
index dd9480f0aa8..4163a09d333 100644
--- a/llvm/include/llvm/Analysis/LoopPass.h
+++ b/llvm/include/llvm/Analysis/LoopPass.h
@@ -57,6 +57,10 @@ class LoopPass : public Pass {
virtual void assignPassManager(PMStack &PMS,
PassManagerType PMT = PMT_LoopPassManager);
+ /// Return what kind of Pass Manager can manage this pass.
+ virtual PassManagerType getPotentialPassManagerType() const {
+ return PMT_LoopPassManager;
+ }
};
class LPPassManager : public FunctionPass, public PMDataManager {
diff --git a/llvm/include/llvm/CallGraphSCCPass.h b/llvm/include/llvm/CallGraphSCCPass.h
index f68e44774bc..af5cb849a38 100644
--- a/llvm/include/llvm/CallGraphSCCPass.h
+++ b/llvm/include/llvm/CallGraphSCCPass.h
@@ -54,6 +54,11 @@ struct CallGraphSCCPass : public Pass {
virtual void assignPassManager(PMStack &PMS,
PassManagerType PMT = PMT_CallGraphPassManager);
+ /// Return what kind of Pass Manager can manage this pass.
+ virtual PassManagerType getPotentialPassManagerType() const {
+ return PMT_CallGraphPassManager;
+ }
+
/// getAnalysisUsage - For this class, we declare that we require and preserve
/// the call graph. If the derived class implements this method, it should
/// always explicitly call the implementation here.
diff --git a/llvm/include/llvm/Pass.h b/llvm/include/llvm/Pass.h
index 30ddede85fb..cef45011cec 100644
--- a/llvm/include/llvm/Pass.h
+++ b/llvm/include/llvm/Pass.h
@@ -126,6 +126,11 @@ public:
PassManagerType T = PMT_Unknown) {}
/// Check if available pass managers are suitable for this pass or not.
virtual void preparePassManager(PMStack &PMS) {}
+
+ /// Return what kind of Pass Manager can manage this pass.
+ virtual PassManagerType getPotentialPassManagerType() const {
+ return PMT_Unknown;
+ }
// Access AnalysisResolver
inline void setResolver(AnalysisResolver *AR) { Resolver = AR; }
@@ -193,7 +198,7 @@ public:
template<typename AnalysisType>
AnalysisType &getAnalysisID(const PassInfo *PI) const;
-
+
};
inline std::ostream &operator<<(std::ostream &OS, const Pass &P) {
@@ -216,6 +221,12 @@ public:
virtual void assignPassManager(PMStack &PMS,
PassManagerType T = PMT_ModulePassManager);
+
+ /// Return what kind of Pass Manager can manage this pass.
+ virtual PassManagerType getPotentialPassManagerType() const {
+ return PMT_ModulePassManager;
+ }
+
// Force out-of-line virtual method.
virtual ~ModulePass();
};
@@ -283,6 +294,11 @@ public:
virtual void assignPassManager(PMStack &PMS,
PassManagerType T = PMT_FunctionPassManager);
+
+ /// Return what kind of Pass Manager can manage this pass.
+ virtual PassManagerType getPotentialPassManagerType() const {
+ return PMT_FunctionPassManager;
+ }
};
@@ -338,6 +354,11 @@ public:
virtual void assignPassManager(PMStack &PMS,
PassManagerType T = PMT_BasicBlockPassManager);
+
+ /// Return what kind of Pass Manager can manage this pass.
+ virtual PassManagerType getPotentialPassManagerType() const {
+ return PMT_BasicBlockPassManager;
+ }
};
/// PMStack
OpenPOWER on IntegriCloud