If we encounter a fatal error, exit with status 70. For BSD systems this is
defined as an internal software error. This notifies the driver to report
diagnostics information.
rdar://11951540
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@167754 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/tools/driver/cc1_main.cpp b/tools/driver/cc1_main.cpp
index 674f2ad..9da6723 100644
--- a/tools/driver/cc1_main.cpp
+++ b/tools/driver/cc1_main.cpp
@@ -48,8 +48,10 @@
// particular that we remove files registered with RemoveFileOnSignal.
llvm::sys::RunInterruptHandlers();
- // We cannot recover from llvm errors.
- exit(1);
+ // We cannot recover from llvm errors. When reporting a fatal error, exit
+ // with status 70. For BSD systems this is defined as an internal software
+ // error. This notifies the driver to report diagnostics information.
+ exit(70);
}
int cc1_main(const char **ArgBegin, const char **ArgEnd,
diff --git a/tools/driver/driver.cpp b/tools/driver/driver.cpp
index 81979ec..8233247 100644
--- a/tools/driver/driver.cpp
+++ b/tools/driver/driver.cpp
@@ -480,8 +480,9 @@
Res = -1;
// If result status is < 0, then the driver command signalled an error.
- // In this case, generate additional diagnostic information if possible.
- if (Res < 0)
+ // If result status is 70, then the driver command reported a fatal error.
+ // In these cases, generate additional diagnostic information if possible.
+ if (Res < 0 || Res == 70)
TheDriver.generateCompilationDiagnostics(*C, FailingCommand);
// If any timers were active but haven't been destroyed yet, print their