From 9c28314a68b3abcf12698f0b68ebbd8adcef5d54 Mon Sep 17 00:00:00 2001 From: Reid Kleckner Date: Tue, 3 Mar 2015 17:41:09 +0000 Subject: [PATCH] Make llvm.eh.begincatch use an outparam Ultimately, __CxxFrameHandler3 needs us to put a stack offset in a table, and it will take responsibility for copying the exception object into that slot. Modelling the exception object as an SSA value returned by begincatch isn't going to work in general, so make it use an output parameter. Reviewers: andrew.w.kaylor Differential Revision: http://reviews.llvm.org/D7920 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@231086 91177308-0d34-0410-b5e6-96231b3b80d8 --- docs/ExceptionHandling.rst | 12 ++-- include/llvm/IR/Intrinsics.td | 6 +- .../Lint/cppeh-catch-intrinsics-clean.ll | 6 +- test/Analysis/Lint/cppeh-catch-intrinsics.ll | 28 ++++----- test/CodeGen/X86/cppeh-catch-all.ll | 4 +- test/CodeGen/X86/cppeh-catch-scalar.ll | 11 +--- test/CodeGen/X86/cppeh-frame-vars.ll | 11 +--- test/CodeGen/X86/cppeh-inalloca.ll | 31 ++++------ .../X86/cppeh-nonalloca-frame-values.ll | 62 ++++++++++--------- 9 files changed, 80 insertions(+), 91 deletions(-) diff --git a/docs/ExceptionHandling.rst b/docs/ExceptionHandling.rst index 696b50f7e0c..bf93fdaaaf4 100644 --- a/docs/ExceptionHandling.rst +++ b/docs/ExceptionHandling.rst @@ -442,7 +442,7 @@ Uses of this intrinsic are generated by the C++ front-end. .. code-block:: llvm - i8* @llvm.eh.begincatch(i8* %exn) + void @llvm.eh.begincatch(i8* %ehptr, i8* %ehobj) This intrinsic marks the beginning of catch handling code within the blocks @@ -450,11 +450,11 @@ following a ``landingpad`` instruction. The exact behavior of this function depends on the compilation target and the personality function associated with the ``landingpad`` instruction. -The argument to this intrinsic is a pointer that was previously extracted from -the aggregate return value of the ``landingpad`` instruction. The return -value of the intrinsic is a pointer to the exception object to be used by the -catch code. This pointer is returned as an ``i8*`` value, but the actual type -of the object will depend on the exception that was thrown. +The first argument to this intrinsic is a pointer that was previously extracted +from the aggregate return value of the ``landingpad`` instruction. The second +argument to the intrinsic is a pointer to stack space where the exception object +should be stored. The runtime handles the details of copying the exception +object into the slot. If the second parameter is null, no copy occurs. Uses of this intrinsic are generated by the C++ front-end. Many targets will use implementation-specific functions (such as ``__cxa_begin_catch``) instead diff --git a/include/llvm/IR/Intrinsics.td b/include/llvm/IR/Intrinsics.td index e89e65db7a8..af65b1a6a4a 100644 --- a/include/llvm/IR/Intrinsics.td +++ b/include/llvm/IR/Intrinsics.td @@ -412,8 +412,10 @@ def int_eh_return_i32 : Intrinsic<[], [llvm_i32_ty, llvm_ptr_ty]>; def int_eh_return_i64 : Intrinsic<[], [llvm_i64_ty, llvm_ptr_ty]>; // eh.begincatch takes a pointer returned by a landingpad instruction and -// returns the exception object pointer for the exception to be handled. -def int_eh_begincatch : Intrinsic<[llvm_ptr_ty], [llvm_ptr_ty]>; +// copies the exception object into the memory pointed to by the second +// parameter. If the second parameter is null, no copy occurs. +def int_eh_begincatch : Intrinsic<[], [llvm_ptr_ty, llvm_ptr_ty], + [NoCapture<0>, NoCapture<1>]>; def int_eh_endcatch : Intrinsic<[], []>; // __builtin_unwind_init is an undocumented GCC intrinsic that causes all diff --git a/test/Analysis/Lint/cppeh-catch-intrinsics-clean.ll b/test/Analysis/Lint/cppeh-catch-intrinsics-clean.ll index e398d718f86..8cd44c86a72 100644 --- a/test/Analysis/Lint/cppeh-catch-intrinsics-clean.ll +++ b/test/Analysis/Lint/cppeh-catch-intrinsics-clean.ll @@ -5,7 +5,7 @@ target triple = "x86_64-pc-windows-msvc" -declare i8* @llvm.eh.begincatch(i8*) +declare void @llvm.eh.begincatch(i8*, i8*) declare void @llvm.eh.endcatch() @@ -27,7 +27,7 @@ lpad: ; preds = %entry br i1 %matches, label %catch, label %eh.resume catch: ; preds = %lpad - %2 = call i8* @llvm.eh.begincatch(i8* %exn) + call void @llvm.eh.begincatch(i8* %exn, i8* null) call void @_Z10handle_intv() br label %invoke.cont2 @@ -77,7 +77,7 @@ lpad1: ; preds = %entry catch: ; preds = %lpad, %lpad1 %exn2 = phi i8* [%exn, %lpad], [%exn1, %lpad1] %sel2 = phi i32 [%sel, %lpad], [%sel1, %lpad1] - %3 = call i8* @llvm.eh.begincatch(i8* %exn2) + call void @llvm.eh.begincatch(i8* %exn2, i8* null) call void @_Z10handle_intv() %matches1 = icmp eq i32 %sel2, 0 br i1 %matches1, label %invoke.cont2, label %invoke.cont3 diff --git a/test/Analysis/Lint/cppeh-catch-intrinsics.ll b/test/Analysis/Lint/cppeh-catch-intrinsics.ll index 5ab73e35a81..3a0c487c290 100644 --- a/test/Analysis/Lint/cppeh-catch-intrinsics.ll +++ b/test/Analysis/Lint/cppeh-catch-intrinsics.ll @@ -6,7 +6,7 @@ target triple = "x86_64-pc-windows-msvc" -declare i8* @llvm.eh.begincatch(i8*) +declare void @llvm.eh.begincatch(i8*, i8*) declare void @llvm.eh.endcatch() @@ -15,7 +15,7 @@ declare void @llvm.eh.endcatch() ; Function Attrs: uwtable define void @test_missing_endcatch() { ; CHECK: Some paths from llvm.eh.begincatch may not reach llvm.eh.endcatch -; CHECK-NEXT: %2 = call i8* @llvm.eh.begincatch(i8* %exn) +; CHECK-NEXT: call void @llvm.eh.begincatch(i8* %exn, i8* null) entry: invoke void @_Z9may_throwv() to label %try.cont unwind label %lpad @@ -30,7 +30,7 @@ lpad: ; preds = %entry br i1 %matches, label %catch, label %eh.resume catch: ; preds = %lpad - %2 = call i8* @llvm.eh.begincatch(i8* %exn) + call void @llvm.eh.begincatch(i8* %exn, i8* null) call void @_Z10handle_intv() br label %invoke.cont2 @@ -79,8 +79,8 @@ eh.resume: ; preds = %catch.dispatch ; Function Attrs: uwtable define void @test_multiple_begin() { ; CHECK: llvm.eh.begincatch may be called a second time before llvm.eh.endcatch -; CHECK-NEXT: %2 = call i8* @llvm.eh.begincatch(i8* %exn) -; CHECK-NEXT: %3 = call i8* @llvm.eh.begincatch(i8* %exn) +; CHECK-NEXT: call void @llvm.eh.begincatch(i8* %exn, i8* null) +; CHECK-NEXT: call void @llvm.eh.begincatch(i8* %exn, i8* null) entry: invoke void @_Z9may_throwv() to label %try.cont unwind label %lpad @@ -95,12 +95,12 @@ lpad: ; preds = %entry br i1 %matches, label %catch, label %eh.resume catch: ; preds = %lpad - %2 = call i8* @llvm.eh.begincatch(i8* %exn) + call void @llvm.eh.begincatch(i8* %exn, i8* null) call void @_Z10handle_intv() br label %invoke.cont2 invoke.cont2: ; preds = %catch - %3 = call i8* @llvm.eh.begincatch(i8* %exn) + call void @llvm.eh.begincatch(i8* %exn, i8* null) call void @llvm.eh.endcatch() br label %try.cont @@ -130,7 +130,7 @@ lpad: ; preds = %entry br i1 %matches, label %catch, label %eh.resume catch: ; preds = %lpad - %2 = call i8* @llvm.eh.begincatch(i8* %exn) + call void @llvm.eh.begincatch(i8* %exn, i8* null) call void @_Z10handle_intv() call void @llvm.eh.endcatch() br label %invoke.cont2 @@ -150,10 +150,10 @@ eh.resume: ; preds = %catch.dispatch ; Function Attrs: uwtable define void @test_begincatch_without_lpad() { ; CHECK: llvm.eh.begincatch may be reachable without passing a landingpad -; CHECK-NEXT: %0 = call i8* @llvm.eh.begincatch(i8* %exn) +; CHECK-NEXT: call void @llvm.eh.begincatch(i8* %exn, i8* null) entry: %exn = alloca i8 - %0 = call i8* @llvm.eh.begincatch(i8* %exn) + call void @llvm.eh.begincatch(i8* %exn, i8* null) call void @_Z10handle_intv() br label %invoke.cont2 @@ -168,7 +168,7 @@ try.cont: ; preds = %invoke.cont2, %entr ; Function Attrs: uwtable define void @test_branch_to_begincatch_with_no_lpad(i32 %fake.sel) { ; CHECK: llvm.eh.begincatch may be reachable without passing a landingpad -; CHECK-NEXT: %3 = call i8* @llvm.eh.begincatch(i8* %exn2) +; CHECK-NEXT: call void @llvm.eh.begincatch(i8* %exn2, i8* null) entry: %fake.exn = alloca i8 invoke void @_Z9may_throwv() @@ -189,7 +189,7 @@ lpad: ; preds = %entry catch: ; preds = %lpad, %entry %exn2 = phi i8* [%exn, %lpad], [%fake.exn, %entry] %sel2 = phi i32 [%sel, %lpad], [%fake.sel, %entry] - %3 = call i8* @llvm.eh.begincatch(i8* %exn2) + call void @llvm.eh.begincatch(i8* %exn2, i8* null) call void @_Z10handle_intv() %matches1 = icmp eq i32 %sel2, 0 br i1 %matches1, label %invoke.cont2, label %invoke.cont3 @@ -213,7 +213,7 @@ eh.resume: ; preds = %catch.dispatch ; Function Attrs: uwtable define void @test_branch_missing_endcatch() { ; CHECK: Some paths from llvm.eh.begincatch may not reach llvm.eh.endcatch -; CHECK-NEXT: %3 = call i8* @llvm.eh.begincatch(i8* %exn2) +; CHECK-NEXT: call void @llvm.eh.begincatch(i8* %exn2, i8* null) entry: invoke void @_Z9may_throwv() to label %invoke.cont unwind label %lpad @@ -247,7 +247,7 @@ lpad1: ; preds = %entry catch: ; preds = %lpad, %lpad1 %exn2 = phi i8* [%exn, %lpad], [%exn1, %lpad1] %sel2 = phi i32 [%sel, %lpad], [%sel1, %lpad1] - %3 = call i8* @llvm.eh.begincatch(i8* %exn2) + call void @llvm.eh.begincatch(i8* %exn2, i8* null) call void @_Z10handle_intv() %matches1 = icmp eq i32 %sel2, 0 br i1 %matches1, label %invoke.cont2, label %invoke.cont3 diff --git a/test/CodeGen/X86/cppeh-catch-all.ll b/test/CodeGen/X86/cppeh-catch-all.ll index ff0cea662c3..814e97d2edf 100644 --- a/test/CodeGen/X86/cppeh-catch-all.ll +++ b/test/CodeGen/X86/cppeh-catch-all.ll @@ -40,7 +40,7 @@ lpad: ; preds = %entry catch: ; preds = %lpad %exn = load i8*, i8** %exn.slot - %tmp3 = call i8* @llvm.eh.begincatch(i8* %exn) #2 + call void @llvm.eh.begincatch(i8* %exn, i8* null) #2 call void @_Z16handle_exceptionv() br label %invoke.cont2 @@ -66,7 +66,7 @@ declare void @_Z9may_throwv() #1 declare i32 @__CxxFrameHandler3(...) -declare i8* @llvm.eh.begincatch(i8*) +declare void @llvm.eh.begincatch(i8*, i8*) declare void @_Z16handle_exceptionv() #1 diff --git a/test/CodeGen/X86/cppeh-catch-scalar.ll b/test/CodeGen/X86/cppeh-catch-scalar.ll index 25cd801758c..9c16a9b09ef 100644 --- a/test/CodeGen/X86/cppeh-catch-scalar.ll +++ b/test/CodeGen/X86/cppeh-catch-scalar.ll @@ -62,10 +62,8 @@ catch.dispatch: ; preds = %lpad catch: ; preds = %catch.dispatch %exn11 = load i8*, i8** %exn.slot - %tmp4 = call i8* @llvm.eh.begincatch(i8* %exn11) #3 - %tmp5 = bitcast i8* %tmp4 to i32* - %tmp6 = load i32, i32* %tmp5, align 4 - store i32 %tmp6, i32* %i, align 4 + %i.i8 = bitcast i32* %i to i8* + call void @llvm.eh.begincatch(i8* %exn11, i8* %i.i8) #3 %tmp7 = load i32, i32* %i, align 4 call void @_Z10handle_inti(i32 %tmp7) br label %invoke.cont2 @@ -92,9 +90,6 @@ eh.resume: ; preds = %catch.dispatch ; CHECK: %eh.obj.ptr = getelementptr inbounds %struct._Z4testv.ehdata, %struct._Z4testv.ehdata* %eh.data, i32 0, i32 1 ; CHECK: %eh.obj = load i8*, i8** %eh.obj.ptr ; CHECK: %i = getelementptr inbounds %struct._Z4testv.ehdata, %struct._Z4testv.ehdata* %eh.data, i32 0, i32 2 -; CHECK: %tmp5 = bitcast i8* %eh.obj to i32* -; CHECK: %tmp6 = load i32, i32* %tmp5, align 4 -; CHECK: store i32 %tmp6, i32* %i, align 4 ; CHECK: %tmp7 = load i32, i32* %i, align 4 ; CHECK: call void @_Z10handle_inti(i32 %tmp7) ; CHECK: ret i8* blockaddress(@_Z4testv, %try.cont) @@ -107,7 +102,7 @@ declare i32 @__CxxFrameHandler3(...) ; Function Attrs: nounwind readnone declare i32 @llvm.eh.typeid.for(i8*) #2 -declare i8* @llvm.eh.begincatch(i8*) +declare void @llvm.eh.begincatch(i8*, i8*) declare void @llvm.eh.endcatch() diff --git a/test/CodeGen/X86/cppeh-frame-vars.ll b/test/CodeGen/X86/cppeh-frame-vars.ll index 3a611c30151..471aeed8f73 100644 --- a/test/CodeGen/X86/cppeh-frame-vars.ll +++ b/test/CodeGen/X86/cppeh-frame-vars.ll @@ -116,10 +116,8 @@ catch.dispatch: ; preds = %lpad catch: ; preds = %catch.dispatch %exn = load i8*, i8** %exn.slot - %tmp8 = call i8* @llvm.eh.begincatch(i8* %exn) #1 - %tmp9 = bitcast i8* %tmp8 to i32* - %tmp10 = load i32, i32* %tmp9, align 4 - store i32 %tmp10, i32* %e, align 4 + %e.i8 = bitcast i32* %e to i8* + call void @llvm.eh.begincatch(i8* %exn, i8* %e.i8) #1 %tmp11 = load i32, i32* %e, align 4 %tmp12 = load i32, i32* %NumExceptions, align 4 %idxprom = sext i32 %tmp12 to i64 @@ -190,9 +188,6 @@ eh.resume: ; preds = %catch.dispatch ; CHECK: %ExceptionVal = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 4 ; CHECK: %i = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 5 ; CHECK: %Data = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 6 -; CHECK: %tmp9 = bitcast i8* %eh.obj to i32* -; CHECK: %tmp10 = load i32, i32* %tmp9, align 4 -; CHECK: store i32 %tmp10, i32* %e, align 4 ; CHECK: %tmp11 = load i32, i32* %e, align 4 ; CHECK: %tmp12 = load i32, i32* %NumExceptions, align 4 ; CHECK: %idxprom = sext i32 %tmp12 to i64 @@ -241,7 +236,7 @@ declare i32 @__CxxFrameHandler3(...) ; Function Attrs: nounwind readnone declare i32 @llvm.eh.typeid.for(i8*) #3 -declare i8* @llvm.eh.begincatch(i8*) +declare void @llvm.eh.begincatch(i8*, i8*) declare void @llvm.eh.endcatch() diff --git a/test/CodeGen/X86/cppeh-inalloca.ll b/test/CodeGen/X86/cppeh-inalloca.ll index d7b7d561655..61f5a0c0ec6 100644 --- a/test/CodeGen/X86/cppeh-inalloca.ll +++ b/test/CodeGen/X86/cppeh-inalloca.ll @@ -84,15 +84,13 @@ catch.dispatch: ; preds = %lpad catch: ; preds = %catch.dispatch %exn = load i8*, i8** %exn.slot - %5 = call i8* @llvm.eh.begincatch(i8* %exn) #3 - %6 = bitcast i8* %5 to i32* - %7 = load i32, i32* %6, align 4 - store i32 %7, i32* %e, align 4 + %e.i8 = bitcast i32* %e to i8* + call void @llvm.eh.begincatch(i8* %exn, i8* %e.i8) #3 %a = getelementptr inbounds <{ %struct.A }>, <{ %struct.A }>* %0, i32 0, i32 0 %a1 = getelementptr inbounds %struct.A, %struct.A* %a, i32 0, i32 0 - %8 = load i32, i32* %a1, align 4 - %9 = load i32, i32* %e, align 4 - %add = add nsw i32 %8, %9 + %tmp8 = load i32, i32* %a1, align 4 + %tmp9 = load i32, i32* %e, align 4 + %add = add nsw i32 %tmp8, %tmp9 store i32 %add, i32* %retval store i32 1, i32* %cleanup.dest.slot call void @llvm.eh.endcatch() #3 @@ -109,14 +107,14 @@ try.cont: ; preds = %invoke.cont ; CHECK: %.tmp.reload1 = load volatile <{ %struct.A }>*, <{ %struct.A }>** %.tmp.reg2mem ; CHECK: %a2 = getelementptr inbounds <{ %struct.A }>, <{ %struct.A }>* %.tmp.reload1, i32 0, i32 0 ; CHECK: call x86_thiscallcc void @"\01??1A@@QAE@XZ"(%struct.A* %a2) #2 -; CHECK: %10 = load i32, i32* %retval -; CHECK: ret i32 %10 +; CHECK: %tmp10 = load i32, i32* %retval +; CHECK: ret i32 %tmp10 cleanup: ; preds = %try.cont, %catch %a2 = getelementptr inbounds <{ %struct.A }>, <{ %struct.A }>* %0, i32 0, i32 0 call x86_thiscallcc void @"\01??1A@@QAE@XZ"(%struct.A* %a2) #3 - %10 = load i32, i32* %retval - ret i32 %10 + %tmp10 = load i32, i32* %retval + ret i32 %tmp10 ehcleanup: ; preds = %catch.dispatch %a3 = getelementptr inbounds <{ %struct.A }>, <{ %struct.A }>* %0, i32 0, i32 0 @@ -143,14 +141,11 @@ eh.resume: ; preds = %ehcleanup ; CHECK: %.reload = load <{ %struct.A }>*, <{ %struct.A }>** %eh.temp.alloca ; CHECK: %retval = getelementptr inbounds %"struct.\01?test@@YAHUA@@@Z.ehdata", %"struct.\01?test@@YAHUA@@@Z.ehdata"* %eh.data, i32 0, i32 4 ; CHECK: %cleanup.dest.slot = getelementptr inbounds %"struct.\01?test@@YAHUA@@@Z.ehdata", %"struct.\01?test@@YAHUA@@@Z.ehdata"* %eh.data, i32 0, i32 5 -; CHECK: %2 = bitcast i8* %eh.obj to i32* -; CHECK: %3 = load i32, i32* %2, align 4 -; CHECK: store i32 %3, i32* %e, align 4 ; CHECK: %a = getelementptr inbounds <{ %struct.A }>, <{ %struct.A }>* %.reload, i32 0, i32 0 ; CHECK: %a1 = getelementptr inbounds %struct.A, %struct.A* %a, i32 0, i32 0 -; CHECK: %4 = load i32, i32* %a1, align 4 -; CHECK: %5 = load i32, i32* %e, align 4 -; CHECK: %add = add nsw i32 %4, %5 +; CHECK: %tmp8 = load i32, i32* %a1, align 4 +; CHECK: %tmp9 = load i32, i32* %e, align 4 +; CHECK: %add = add nsw i32 %tmp8, %tmp9 ; CHECK: store i32 %add, i32* %retval ; CHECK: store i32 1, i32* %cleanup.dest.slot ; CHECK: ret i8* blockaddress(@"\01?test@@YAHUA@@@Z", %cleanup) @@ -164,7 +159,7 @@ declare i32 @__CxxFrameHandler3(...) ; Function Attrs: nounwind readnone declare i32 @llvm.eh.typeid.for(i8*) #1 -declare i8* @llvm.eh.begincatch(i8*) +declare void @llvm.eh.begincatch(i8*, i8*) declare void @llvm.eh.endcatch() diff --git a/test/CodeGen/X86/cppeh-nonalloca-frame-values.ll b/test/CodeGen/X86/cppeh-nonalloca-frame-values.ll index ebc540d66fe..987b264699d 100644 --- a/test/CodeGen/X86/cppeh-nonalloca-frame-values.ll +++ b/test/CodeGen/X86/cppeh-nonalloca-frame-values.ll @@ -51,26 +51,26 @@ $"\01??_R0H@8" = comdat any @"\01??_R0H@8" = linkonce_odr global %rtti.TypeDescriptor2 { i8** @"\01??_7type_info@@6B@", i8* null, [3 x i8] c".H\00" }, comdat ; This structure should be declared for the frame allocation block. -; CHECK: %"struct.\01?test@@YAXXZ.ehdata" = type { i32, i8*, i32, [10 x i32], i32, i32*, i32* } +; CHECK: %"struct.\01?test@@YAXXZ.ehdata" = type { i32, i8*, i32, i32, [10 x i32], i32, i32*, i32* } ; The function entry should be rewritten like this. ; CHECK: define void @"\01?test@@YAXXZ"() #0 { ; CHECK: entry: -; CHECK: %frame.alloc = call i8* @llvm.frameallocate(i32 80) +; CHECK: %frame.alloc = call i8* @llvm.frameallocate(i32 88) ; CHECK: %eh.data = bitcast i8* %frame.alloc to %"struct.\01?test@@YAXXZ.ehdata"* ; CHECK-NOT: %ExceptionVal = alloca [10 x i32], align 16 -; CHECK: %NumExceptions.020.reg2mem = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 2 -; CHECK: %i.019.reg2mem = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 4 -; CHECK: %ExceptionVal = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 3 +; CHECK: %NumExceptions.020.reg2mem = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 3 +; CHECK: %i.019.reg2mem = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 5 +; CHECK: %ExceptionVal = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 4 ; CHECK: %Data = alloca i64, align 8 ; CHECK: %tmpcast = bitcast i64* %Data to %struct.SomeData* ; CHECK: %0 = bitcast [10 x i32]* %ExceptionVal to i8* ; CHECK: call void @llvm.lifetime.start(i64 40, i8* %0) #1 ; CHECK: store i64 0, i64* %Data, align 8 -; CHECK: %a.reg2mem = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 5 +; CHECK: %a.reg2mem = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 6 ; CHECK: %a = bitcast i64* %Data to i32* ; CHECK: store i32* %a, i32** %a.reg2mem -; CHECK: %b.reg2mem = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 6 +; CHECK: %b.reg2mem = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 7 ; CHECK: %b = getelementptr inbounds %struct.SomeData, %struct.SomeData* %tmpcast, i64 0, i32 1 ; CHECK: store i32* %b, i32** %b.reg2mem ; CHECK: store i32 0, i32* %NumExceptions.020.reg2mem @@ -80,6 +80,7 @@ $"\01??_R0H@8" = comdat any ; Function Attrs: uwtable define void @"\01?test@@YAXXZ"() #0 { entry: + %e = alloca i32, align 4 %ExceptionVal = alloca [10 x i32], align 16 %Data = alloca i64, align 8 %tmpcast = bitcast i64* %Data to %struct.SomeData* @@ -127,25 +128,25 @@ lpad: ; preds = %for.body catch: ; preds = %lpad %5 = extractvalue { i8*, i32 } %2, 0 - %6 = tail call i8* @llvm.eh.begincatch(i8* %5) #1 - %7 = bitcast i8* %6 to i32* - %8 = load i32, i32* %7, align 4, !tbaa !7 + %e.i8 = bitcast i32* %e to i8* + call void @llvm.eh.begincatch(i8* %5, i8* %e.i8) #1 + %tmp8 = load i32, i32* %e, align 4, !tbaa !7 %idxprom = sext i32 %NumExceptions.020 to i64 %arrayidx = getelementptr inbounds [10 x i32], [10 x i32]* %ExceptionVal, i64 0, i64 %idxprom - store i32 %8, i32* %arrayidx, align 4, !tbaa !7 + store i32 %tmp8, i32* %arrayidx, align 4, !tbaa !7 %inc = add nsw i32 %NumExceptions.020, 1 - %cmp1 = icmp eq i32 %8, %i.019 + %cmp1 = icmp eq i32 %tmp8, %i.019 br i1 %cmp1, label %if.then, label %if.else if.then: ; preds = %catch - %9 = load i32, i32* %b, align 4, !tbaa !8 - %add2 = add nsw i32 %9, %i.019 + %tmp9 = load i32, i32* %b, align 4, !tbaa !8 + %add2 = add nsw i32 %tmp9, %i.019 store i32 %add2, i32* %b, align 4, !tbaa !8 br label %if.end if.else: ; preds = %catch - %10 = load i32, i32* %a, align 8, !tbaa !2 - %add4 = add nsw i32 %10, %8 + %tmp10 = load i32, i32* %a, align 8, !tbaa !2 + %add4 = add nsw i32 %tmp10, %tmp8 store i32 %add4, i32* %a, align 8, !tbaa !2 br label %if.end @@ -190,33 +191,34 @@ eh.resume: ; preds = %lpad ; CHECK: %eh.data = bitcast i8* %eh.alloc to %"struct.\01?test@@YAXXZ.ehdata"* ; CHECK: %eh.obj.ptr = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 1 ; CHECK: %eh.obj = load i8*, i8** %eh.obj.ptr -; CHECK: %eh.temp.alloca = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 2 +; CHECK: %e = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 2 +; CHECK: %eh.temp.alloca = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 3 ; CHECK: %NumExceptions.020.reload = load i32, i32* %eh.temp.alloca -; CHECK: %ExceptionVal = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 3 -; CHECK: %eh.temp.alloca1 = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 4 +; CHECK: %ExceptionVal = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 4 +; CHECK: %eh.temp.alloca1 = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 5 ; CHECK: %i.019.reload = load i32, i32* %eh.temp.alloca1 -; CHECK: %eh.temp.alloca2 = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 5 +; CHECK: %eh.temp.alloca2 = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 6 ; CHECK: %a.reload = load i32*, i32** %eh.temp.alloca2 -; CHECK: %eh.temp.alloca3 = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 6 +; CHECK: %eh.temp.alloca3 = getelementptr inbounds %"struct.\01?test@@YAXXZ.ehdata", %"struct.\01?test@@YAXXZ.ehdata"* %eh.data, i32 0, i32 7 ; CHECK: %b.reload = load i32*, i32** %eh.temp.alloca3 -; CHECK: %2 = bitcast i8* %eh.obj to i32* -; CHECK: %3 = load i32, i32* %2, align 4, !tbaa !7 +; CHECK: %e.i8 = bitcast i32* %e to i8* +; CHECK: %tmp8 = load i32, i32* %e, align 4, !tbaa !7 ; CHECK: %idxprom = sext i32 %NumExceptions.020.reload to i64 ; CHECK: %arrayidx = getelementptr inbounds [10 x i32], [10 x i32]* %ExceptionVal, i64 0, i64 %idxprom -; CHECK: store i32 %3, i32* %arrayidx, align 4, !tbaa !7 +; CHECK: store i32 %tmp8, i32* %arrayidx, align 4, !tbaa !7 ; CHECK: %inc = add nsw i32 %NumExceptions.020.reload, 1 -; CHECK: %cmp1 = icmp eq i32 %3, %i.019.reload +; CHECK: %cmp1 = icmp eq i32 %tmp8, %i.019.reload ; CHECK: br i1 %cmp1, label %if.then, label %if.else ; ; CHECK: if.then: ; preds = %catch.entry -; CHECK: %4 = load i32, i32* %b.reload, align 4, !tbaa !8 -; CHECK: %add2 = add nsw i32 %4, %i.019.reload +; CHECK: %tmp9 = load i32, i32* %b.reload, align 4, !tbaa !8 +; CHECK: %add2 = add nsw i32 %tmp9, %i.019.reload ; CHECK: store i32 %add2, i32* %b.reload, align 4, !tbaa !8 ; CHECK: br label %if.end ; ; CHECK: if.else: ; preds = %catch.entry -; CHECK: %5 = load i32, i32* %a.reload, align 8, !tbaa !2 -; CHECK: %add4 = add nsw i32 %5, %3 +; CHECK: %tmp10 = load i32, i32* %a.reload, align 8, !tbaa !2 +; CHECK: %add4 = add nsw i32 %tmp10, %tmp8 ; CHECK: store i32 %add4, i32* %a.reload, align 8, !tbaa !2 ; CHECK: br label %if.end ; @@ -234,7 +236,7 @@ declare i32 @__CxxFrameHandler3(...) ; Function Attrs: nounwind readnone declare i32 @llvm.eh.typeid.for(i8*) #3 -declare i8* @llvm.eh.begincatch(i8*) +declare void @llvm.eh.begincatch(i8*, i8*) declare void @llvm.eh.endcatch()