diff options
author | Nuno Lopes <nunoplopes@sapo.pt> | 2012-06-28 22:57:00 +0000 |
---|---|---|
committer | Nuno Lopes <nunoplopes@sapo.pt> | 2012-06-28 22:57:00 +0000 |
commit | 2f49284f12aef1f8e3d0564cfed37b742b84b7ff (patch) | |
tree | c9ea60d33c11d4e34b7e81a63d5ca917d2618657 /llvm/test/Verifier | |
parent | d162c91b1aa48e1482fb8fc983c9fc8451927a16 (diff) | |
download | bcm5719-llvm-2f49284f12aef1f8e3d0564cfed37b742b84b7ff.tar.gz bcm5719-llvm-2f49284f12aef1f8e3d0564cfed37b742b84b7ff.zip |
make the verifier accept @llvm.donothing as the only intrinsic that can be invoked
While at it, merge 2 tests and FileCheckize them
llvm-svn: 159388
Diffstat (limited to 'llvm/test/Verifier')
-rw-r--r-- | llvm/test/Verifier/invoke-1.ll | 10 | ||||
-rw-r--r-- | llvm/test/Verifier/invoke-2.ll | 14 | ||||
-rw-r--r-- | llvm/test/Verifier/invoke.ll | 65 |
3 files changed, 65 insertions, 24 deletions
diff --git a/llvm/test/Verifier/invoke-1.ll b/llvm/test/Verifier/invoke-1.ll deleted file mode 100644 index 427abe02cef..00000000000 --- a/llvm/test/Verifier/invoke-1.ll +++ /dev/null @@ -1,10 +0,0 @@ -; RUN: not llvm-as < %s |& grep {not verify as correct} -; PR1042 - -define i32 @foo() { - %A = invoke i32 @foo( ) - to label %L unwind label %L ; <i32> [#uses=1] -L: ; preds = %0, %0 - ret i32 %A -} - diff --git a/llvm/test/Verifier/invoke-2.ll b/llvm/test/Verifier/invoke-2.ll deleted file mode 100644 index 0145935a1a7..00000000000 --- a/llvm/test/Verifier/invoke-2.ll +++ /dev/null @@ -1,14 +0,0 @@ -; RUN: not llvm-as %s |& grep {not verify as correct} -; PR1042 - -define i32 @foo() { - br i1 false, label %L1, label %L2 -L1: ; preds = %0 - %A = invoke i32 @foo( ) - to label %L unwind label %L ; <i32> [#uses=1] -L2: ; preds = %0 - br label %L -L: ; preds = %L2, %L1, %L1 - ret i32 %A -} - diff --git a/llvm/test/Verifier/invoke.ll b/llvm/test/Verifier/invoke.ll new file mode 100644 index 00000000000..2a0336b03f3 --- /dev/null +++ b/llvm/test/Verifier/invoke.ll @@ -0,0 +1,65 @@ +; RUN: not llvm-as < %s -o /dev/null |& FileCheck %s + +; PR1042 +define i32 @foo() { +; CHECK: The unwind destination does not have a landingpad instruction + %A = invoke i32 @foo( ) + to label %L unwind label %L ; <i32> [#uses=1] +L: ; preds = %0, %0 + ret i32 %A +} + +; PR1042 +define i32 @bar() { + br i1 false, label %L1, label %L2 +L1: ; preds = %0 + %A = invoke i32 @bar( ) + to label %L unwind label %L ; <i32> [#uses=1] +L2: ; preds = %0 + br label %L +L: ; preds = %L2, %L1, %L1 +; CHECK: The unwind destination does not have a landingpad instruction +; CHECK: Instruction does not dominate all uses + ret i32 %A +} + + +declare i32 @__gxx_personality_v0(...) +declare void @llvm.donothing() +declare void @llvm.trap() +declare i8 @llvm.expect.i8(i8,i8) +declare i32 @fn(i8 (i8, i8)*) + +define void @f1() { +entry: +; OK + invoke void @llvm.donothing() + to label %cont unwind label %cont + +cont: + %0 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) + filter [0 x i8*] zeroinitializer + ret void +} + +define i8 @f2() { +entry: +; CHECK: Cannot invoke an intrinsinc other than donothing + invoke void @llvm.trap() + to label %cont unwind label %lpad + +cont: + ret i8 3 + +lpad: + %0 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) + filter [0 x i8*] zeroinitializer + ret i8 2 +} + +define i32 @f3() { +entry: +; CHECK: Cannot take the address of an intrinsic + %call = call i32 @fn(i8 (i8, i8)* @llvm.expect.i8) + ret i32 %call +} |