Update the tests to the new EH scheme.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@138891 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Bill Wendling
2011-08-31 20:55:40 +00:00
parent 4f8aaa0928
commit b072dd9ba4
5 changed files with 26 additions and 5 deletions

View File

@@ -8,11 +8,16 @@ Entry:
br i1 %cond, label %Inv, label %Cont br i1 %cond, label %Inv, label %Cont
Inv: ; preds = %Entry Inv: ; preds = %Entry
invoke void @foo( ) invoke void @foo( )
to label %Ok unwind label %Cont to label %Ok unwind label %LPad
Ok: ; preds = %Inv Ok: ; preds = %Inv
br label %Cont br label %Cont
LPad:
%val = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
catch i8* null
br label %Cont
Cont: ; preds = %Ok, %Inv, %Entry Cont: ; preds = %Ok, %Inv, %Entry
%X = phi i32 [ 0, %Entry ], [ 1, %Ok ], [ 0, %Inv ] ; <i32> [#uses=1] %X = phi i32 [ 0, %Entry ], [ 1, %Ok ], [ 0, %LPad ] ; <i32> [#uses=1]
ret i32 %X ret i32 %X
} }
declare i32 @__gxx_personality_v0(...)

View File

@@ -6,8 +6,13 @@ define void @caller() {
br i1 true, label %T, label %F br i1 true, label %T, label %F
F: ; preds = %0 F: ; preds = %0
%X = invoke i32 @foo( ) %X = invoke i32 @foo( )
to label %T unwind label %T ; <i32> [#uses=0] to label %T unwind label %LP ; <i32> [#uses=0]
T: ; preds = %F, %F, %0 LP:
%val = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
catch i8* null
br label %T
T:
ret void ret void
} }
declare i32 @__gxx_personality_v0(...)

View File

@@ -31,7 +31,9 @@ bb149: ; preds = %bb114
bb177: ; preds = %bb149 bb177: ; preds = %bb149
unreachable unreachable
cleanup: ; preds = %bb149, %bb114, %bb67 cleanup: ; preds = %bb149, %bb114, %bb67
unwind %val = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
cleanup
resume { i8*, i32 } %val
} }
declare double @sin(double) declare double @sin(double)
@@ -39,3 +41,5 @@ declare double @sin(double)
declare double @log(double) declare double @log(double)
declare double @sqrt(double) declare double @sqrt(double)
declare i32 @__gxx_personality_v0(...)

View File

@@ -7,6 +7,8 @@ define i32 @main() {
to label %UnifiedReturnBlock unwind label %lpad to label %UnifiedReturnBlock unwind label %lpad
lpad: lpad:
%val = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
cleanup
unreachable unreachable
UnifiedReturnBlock: UnifiedReturnBlock:

View File

@@ -90,6 +90,8 @@ A:
%c = call i64 @test4c(i64 %b) %c = call i64 @test4c(i64 %b)
ret i64 %c ret i64 %c
B: B:
%val = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
catch i8* null
ret i64 0 ret i64 0
} }
; CHECK: define i64 @test4b() ; CHECK: define i64 @test4b()
@@ -121,6 +123,8 @@ A:
%c = call i64 @test5c({i64,i64} %a) %c = call i64 @test5c({i64,i64} %a)
ret i64 %c ret i64 %c
B: B:
%val = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
catch i8* null
ret i64 0 ret i64 0
} }
@@ -204,3 +208,4 @@ entry:
ret void ret void
} }
declare i32 @__gxx_personality_v0(...)