From: Aaron Ballman Date: Mon, 9 Feb 2015 23:11:39 +0000 (+0000) Subject: On Windows, we now use RaiseException to generate the kind of trap we require (one... X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=b9df444409e3344b8505ada72929a463409eb7bc;p=oota-llvm.git On Windows, we now use RaiseException to generate the kind of trap we require (one which calls our vectored exception handler), and fall back to using a volatile write to simulate a trap elsewhere. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@228628 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/llvm/Support/Compiler.h b/include/llvm/Support/Compiler.h index 77e442b581d..69c74462cc4 100644 --- a/include/llvm/Support/Compiler.h +++ b/include/llvm/Support/Compiler.h @@ -287,6 +287,14 @@ /// which causes the program to exit abnormally. #if __has_builtin(__builtin_trap) || LLVM_GNUC_PREREQ(4, 3, 0) # define LLVM_BUILTIN_TRAP __builtin_trap() +#elif defined(LLVM_ON_WIN32) +extern "C" __declspec(dllimport) void __stdcall RaiseException( + unsigned long, unsigned long, unsigned long, const unsigned long *); +#define LLVM_BUILTIN_TRAP \ + do { \ + ::RaiseException(0xDEADD0D0, 0x1 /*EXCEPTION_NONCONTINUABLE*/, 0, nullptr);\ + __assume(false); \ + } while (0) #else # define LLVM_BUILTIN_TRAP *(volatile int*)0x11 = 0 #endif