mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
608538dccc
SimplifyCFG allows tail merging with code which terminates in unreachable which, in turn, makes it possible for an invoke to end up in a funclet which it was not originally part of. Using operand bundles on invokes allows us to determine whether or not an invoke was part of a funclet in the source program. Furthermore, it allows us to unambiguously answer questions about the legality of inlining into call sites which the personality may have trouble with. Differential Revision: http://reviews.llvm.org/D15517 llvm-svn: 255674
27 lines
898 B
LLVM
27 lines
898 B
LLVM
; RUN: llc -mtriple=x86_64-pc-windows-coreclr < %s | FileCheck %s
|
|
|
|
declare void @ProcessCLRException()
|
|
declare i8 addrspace(1)* @llvm.eh.exceptionpointer.p1i8(token)
|
|
declare void @f()
|
|
declare void @g(i32 addrspace(1)*)
|
|
|
|
; CHECK-LABEL: test1: # @test1
|
|
define void @test1() personality i8* bitcast (void ()* @ProcessCLRException to i8*) {
|
|
entry:
|
|
invoke void @f()
|
|
to label %exit unwind label %catch.pad
|
|
catch.pad:
|
|
%cs1 = catchswitch within none [label %catch.body] unwind to caller
|
|
catch.body:
|
|
; CHECK: {{^[^: ]+}}: # %catch.body
|
|
; CHECK: movq %rdx, %rcx
|
|
; CHECK-NEXT: callq g
|
|
%catch = catchpad within %cs1 [i32 5]
|
|
%exn = call i8 addrspace(1)* @llvm.eh.exceptionpointer.p1i8(token %catch)
|
|
%cast_exn = bitcast i8 addrspace(1)* %exn to i32 addrspace(1)*
|
|
call void @g(i32 addrspace(1)* %cast_exn) [ "funclet"(token %catch) ]
|
|
catchret from %catch to label %exit
|
|
exit:
|
|
ret void
|
|
}
|