summaryrefslogtreecommitdiffstats
path: root/llvm/test/Verifier
diff options
context:
space:
mode:
authorNuno Lopes <nunoplopes@sapo.pt>2012-06-28 22:57:00 +0000
committerNuno Lopes <nunoplopes@sapo.pt>2012-06-28 22:57:00 +0000
commit2f49284f12aef1f8e3d0564cfed37b742b84b7ff (patch)
treec9ea60d33c11d4e34b7e81a63d5ca917d2618657 /llvm/test/Verifier
parentd162c91b1aa48e1482fb8fc983c9fc8451927a16 (diff)
downloadbcm5719-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.ll10
-rw-r--r--llvm/test/Verifier/invoke-2.ll14
-rw-r--r--llvm/test/Verifier/invoke.ll65
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
+}
OpenPOWER on IntegriCloud