mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-10 06:00:30 +00:00
3b0d377ef8
Without a diagnostic handler installed, llc's behaviour is to exit on the first error that it encounters. This is very different from the behaviour of clang and other front ends, which try to gather as many errors as possible before exiting. This commit adds a diagnostic handler to llc, allowing it to find and report more than one error. The old behaviour is preserved under a flag (-exit-on-error). Some of the tests fail with the new diagnostic handler, so they have to use the new flag in order to run under the previous behaviour. Some of these are known bugs, others need further investigation. Ideally, we should fix the tests and remove the flag at some point in the future. Reapplied after fixing the LLDB build that was broken due to the new DiagnosticSeverity in LLVMContext.h, and fixed an UB in the new change. Patch by Diana Picus. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@269655 91177308-0d34-0410-b5e6-96231b3b80d8
23 lines
694 B
LLVM
23 lines
694 B
LLVM
; RUN: not llc -march=amdgcn -exit-on-error < %s 2>&1 | FileCheck %s
|
|
|
|
; Make sure that AMDGPUPromoteAlloca doesn't crash if the called
|
|
; function is a constantexpr cast of a function.
|
|
|
|
declare void @foo(float*) #0
|
|
declare void @foo.varargs(...) #0
|
|
|
|
; CHECK: in function crash_call_constexpr_cast{{.*}}: unsupported call to function foo
|
|
define void @crash_call_constexpr_cast() #0 {
|
|
%alloca = alloca i32
|
|
call void bitcast (void (float*)* @foo to void (i32*)*)(i32* %alloca) #0
|
|
ret void
|
|
}
|
|
|
|
define void @crash_call_constexpr_cast_varargs() #0 {
|
|
%alloca = alloca i32
|
|
call void bitcast (void (...)* @foo.varargs to void (i32*)*)(i32* %alloca) #0
|
|
ret void
|
|
}
|
|
|
|
attributes #0 = { nounwind }
|