Add a opt-args option that can be used to pass arguments to every opt
authorRafael Espindola <rafael.espindola@gmail.com>
Sun, 8 Aug 2010 22:14:20 +0000 (22:14 +0000)
committerRafael Espindola <rafael.espindola@gmail.com>
Sun, 8 Aug 2010 22:14:20 +0000 (22:14 +0000)
invocation. Fixes PR7793:

bugpoint -debug test.ll --opt-args -unroll-count=4

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@110555 91177308-0d34-0410-b5e6-96231b3b80d8

docs/CommandGuide/bugpoint.pod
tools/bugpoint/OptimizerDriver.cpp

index 7afeea1aba5aff4030e1ff08af8f6b7b62a37970..1870a0d84b60408b884f80270103bb1f796ce187 100644 (file)
@@ -67,6 +67,10 @@ tool.
 Pass all arguments specified after B<--gcc-tool-args> to the invocation of
 B<gcc>.
 
+=item B<--opt-args> I<opt args>
+
+Pass all arguments specified after B<--opt-args> to the invocation of B<opt>.
+
 =item B<--disable-{dce,simplifycfg}>
 
 Do not run the specified passes to clean up and reduce the size of the test
index 7abcece3a84453f448218688ea5d28346236c14c..ffd40997fc54e21a9428f054cd0577abafa2d45a 100644 (file)
@@ -88,6 +88,10 @@ void BugDriver::EmitProgressBitcode(const Module *M,
 
 cl::opt<bool> SilencePasses("silence-passes", cl::desc("Suppress output of running passes (both stdout and stderr)"));
 
+static cl::list<std::string> OptArgs("opt-args", cl::Positional,
+                                     cl::desc("<opt arguments>..."),
+                                     cl::ZeroOrMore, cl::PositionalEatsArgs);
+
 /// runPasses - Run the specified passes on Program, outputting a bitcode file
 /// and writing the filename into OutputFile if successful.  If the
 /// optimizations fail for some reason (optimizer crashes), return true,
@@ -154,6 +158,8 @@ bool BugDriver::runPasses(Module *Program,
 
   Args.push_back("-o");
   Args.push_back(OutputFilename.c_str());
+  for (unsigned i = 0, e = OptArgs.size(); i != e; ++i)
+    Args.push_back(OptArgs[i].c_str());
   std::vector<std::string> pass_args;
   for (unsigned i = 0, e = PluginLoader::getNumPlugins(); i != e; ++i) {
     pass_args.push_back( std::string("-load"));