Added Pass::createPass(ID) to handle pass configuration by ID
authorAndrew Trick <atrick@apple.com>
Wed, 8 Feb 2012 21:22:34 +0000 (21:22 +0000)
committerAndrew Trick <atrick@apple.com>
Wed, 8 Feb 2012 21:22:34 +0000 (21:22 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@150092 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/CodeGen/Passes.h
include/llvm/Pass.h
lib/CodeGen/Passes.cpp
lib/VMCore/Pass.cpp

index 2585aebc1c01bca5055593b1e15c10294930492e..884957173172af64d6ca22bf7125ef9faa0932b5 100644 (file)
@@ -135,7 +135,7 @@ protected:
   ///
 
   /// Add a target-independent CodeGen pass at this point in the pipeline.
-  void addCommonPass(char &ID);
+  void addPass(char &ID);
 
   /// printNoVerify - Add a pass to dump the machine function, if debugging is
   /// enabled.
index 104b272d095de4e1e960d30484ce2f824dad2108..a0cbca121d5e2ec1b727cb1c8feddd0de13098a5 100644 (file)
@@ -175,6 +175,10 @@ public:
   // argument string, or null if it is not known.
   static const PassInfo *lookupPassInfo(StringRef Arg);
 
+  // createPass - Create a object for the specified pass class,
+  // or null if it is not known.
+  static Pass *createPass(char &TI);
+
   /// getAnalysisIfAvailable<AnalysisType>() - Subclasses use this function to
   /// get analysis information that might be around, for example to update it.
   /// This is different than getAnalysis in that it can fail (if the analysis
index eb5673498302859ebc3a0196b74322aafd7185a1..2877cf165b6bd4e257be3c8bd274abf58647f2d5 100644 (file)
@@ -103,8 +103,12 @@ TargetPassConfig::TargetPassConfig()
   llvm_unreachable("TargetPassConfig should not be constructed on-the-fly");
 }
 
-void TargetPassConfig::addCommonPass(char &ID) {
-  // FIXME: about to be implemented.
+void TargetPassConfig::addPass(char &ID) {
+  // FIXME: check user overrides
+  Pass *P = Pass::createPass(ID);
+  if (!P)
+    llvm_unreachable("Pass ID not registered");
+  PM.add(P);
 }
 
 void TargetPassConfig::printNoVerify(const char *Banner) const {
index 05d2efa850aa7409c935810b9260f695e9738e05..07ac3c35c1aae71e071ffaebd56eb2155d234ec3 100644 (file)
@@ -189,6 +189,13 @@ const PassInfo *Pass::lookupPassInfo(StringRef Arg) {
   return PassRegistry::getPassRegistry()->getPassInfo(Arg);
 }
 
+Pass *Pass::createPass(char &TI) {
+  const PassInfo *PI = PassRegistry::getPassRegistry()->getPassInfo(&TI);
+  if (!PI)
+    return NULL;
+  return PI->createPass();
+}
+
 Pass *PassInfo::createPass() const {
   assert((!isAnalysisGroup() || NormalCtor) &&
          "No default implementation found for analysis group!");