Allow creating of passes like levelraise which use a targetdata ctor
authorChris Lattner <sabre@nondot.org>
Wed, 22 Jan 2003 23:24:11 +0000 (23:24 +0000)
committerChris Lattner <sabre@nondot.org>
Wed, 22 Jan 2003 23:24:11 +0000 (23:24 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5403 91177308-0d34-0410-b5e6-96231b3b80d8

tools/bugpoint/OptimizerDriver.cpp

index aae5791935ce483aa99b38b1c23234a6960382b4..300ba950697ac3e99a01a374546a13421301bc8f 100644 (file)
@@ -13,6 +13,7 @@
 #include "llvm/PassManager.h"
 #include "llvm/Analysis/Verifier.h"
 #include "llvm/Bytecode/WriteBytecodePass.h"
+#include "llvm/Target/TargetData.h"
 #include <sys/types.h>
 #include <sys/wait.h>
 #include <unistd.h>
@@ -60,6 +61,8 @@ void BugDriver::EmitProgressBytecode(const PassInfo *Pass,
   std::cout << " " << Filename << " -" << Pass->getPassArgument() << "\n";
 }
 
+/// FIXME: This should be parameterizable!!
+static TargetData TD("bugpoint target");
 
 static void RunChild(Module *Program,const std::vector<const PassInfo*> &Passes,
                      const std::string &OutFilename) {
@@ -73,6 +76,8 @@ static void RunChild(Module *Program,const std::vector<const PassInfo*> &Passes,
   for (unsigned i = 0, e = Passes.size(); i != e; ++i) {
     if (Passes[i]->getNormalCtor())
       PM.add(Passes[i]->getNormalCtor()());
+    else if (Passes[i]->getDataCtor())
+      PM.add(Passes[i]->getDataCtor()(TD));    // Provide dummy target data...
     else
       std::cerr << "Cannot create pass yet: " << Passes[i]->getPassName()
                 << "\n";