Add a new "AutoDebugCrashes" option
authorChris Lattner <sabre@nondot.org>
Sun, 14 Mar 2004 21:21:57 +0000 (21:21 +0000)
committerChris Lattner <sabre@nondot.org>
Sun, 14 Mar 2004 21:21:57 +0000 (21:21 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@12396 91177308-0d34-0410-b5e6-96231b3b80d8

tools/bugpoint/BugDriver.h
tools/bugpoint/OptimizerDriver.cpp

index b1cc3e830ba155f59e975f61e35316bd4b691c8c..f5ef51763e3e72120e22cd6262f22ca84ea7316b 100644 (file)
@@ -192,8 +192,11 @@ public:
 
   /// runPassesOn - Carefully run the specified set of pass on the specified
   /// module, returning the transformed module on success, or a null pointer on
-  /// failure.
-  Module *runPassesOn(Module *M, const std::vector<const PassInfo*> &Passes);
+  /// failure.  If AutoDebugCrashes is set to true, then bugpoint will
+  /// automatically attempt to track down a crashing pass if one exists, and
+  /// this method will never return null.
+  Module *runPassesOn(Module *M, const std::vector<const PassInfo*> &Passes,
+                      bool AutoDebugCrashes = false);
 
   /// runPasses - Run the specified passes on Program, outputting a bytecode
   /// file and writting the filename into OutputFile if successful.  If the
index d741265606adad7edec25c1ee1d9c35bad1c3f70..14ca7c832c32d65de36103dfc8bf33eb4d11df80 100644 (file)
@@ -16,6 +16,7 @@
 //===----------------------------------------------------------------------===//
 
 #include "BugDriver.h"
+#include "llvm/Module.h"
 #include "llvm/PassManager.h"
 #include "llvm/Analysis/Verifier.h"
 #include "llvm/Bytecode/WriteBytecodePass.h"
@@ -166,11 +167,20 @@ bool BugDriver::runPasses(const std::vector<const PassInfo*> &Passes,
 /// module, returning the transformed module on success, or a null pointer on
 /// failure.
 Module *BugDriver::runPassesOn(Module *M,
-                               const std::vector<const PassInfo*> &Passes) {
+                               const std::vector<const PassInfo*> &Passes,
+                               bool AutoDebugCrashes) {
   Module *OldProgram = swapProgramIn(M);
   std::string BytecodeResult;
-  if (runPasses(Passes, BytecodeResult, false/*delete*/, true/*quiet*/))
+  if (runPasses(Passes, BytecodeResult, false/*delete*/, true/*quiet*/)) {
+    if (AutoDebugCrashes) {
+      std::cerr << " Error running this sequence of passes" 
+                << " on the input program!\n";
+      delete OldProgram;
+      EmitProgressBytecode("pass-error",  false);
+      exit(debugOptimizerCrash());
+    }
     return 0;
+  }
 
   // Restore the current program.
   swapProgramIn(OldProgram);