mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
[Win32] Catch exceptions (eg. segfault) on waiting for invoked clang from the driver.
clang/lib/Driver/Driver.cpp: Don't pass through negative exit status, or parent would be confused. llvm::sys::Program::Wait(): Suppose 0x8000XXXX and 0xC000XXXX as abnormal exit code and pass it as negative value. Win32 Exception Handler: Exit with ExceptionCode on an unhandle exception. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@145389 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
ebb57cc44a
commit
5d2f8c3155
@ -367,7 +367,17 @@ Program::Wait(const Path &path,
|
||||
return -2;
|
||||
}
|
||||
|
||||
return status & 0377;
|
||||
if (!status)
|
||||
return 0;
|
||||
|
||||
// Pass 10(Warning) and 11(Error) to the callee as negative value.
|
||||
if ((status & 0xBFFF0000U) == 0x80000000U)
|
||||
return (int)status;
|
||||
|
||||
if (status & 0xFF)
|
||||
return status & 0x7FFFFFFF;
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
bool
|
||||
|
@ -446,7 +446,7 @@ static LONG WINAPI LLVMUnhandledExceptionFilter(LPEXCEPTION_POINTERS ep) {
|
||||
}
|
||||
|
||||
if (ExitOnUnhandledExceptions)
|
||||
_exit(-3);
|
||||
_exit(ep->ExceptionRecord->ExceptionCode);
|
||||
|
||||
// Allow dialog box to pop up allowing choice to start debugger.
|
||||
if (OldFilter)
|
||||
|
Loading…
Reference in New Issue
Block a user