summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2011-12-12 04:36:02 +0000
committerChandler Carruth <chandlerc@gmail.com>2011-12-12 04:36:02 +0000
commitc4eab904c95549106f628b6fdd8ccf62527aa398 (patch)
tree28ef32166df30f4204b473bcb9717b327dfe4365 /test
parentccbf1e36d34c2d66600748bdd8767dc122629a58 (diff)
downloadllvm-c4eab904c95549106f628b6fdd8ccf62527aa398.tar.gz
llvm-c4eab904c95549106f628b6fdd8ccf62527aa398.tar.bz2
llvm-c4eab904c95549106f628b6fdd8ccf62527aa398.tar.xz
Teach the verifier to reject all non-constant arguments to the second
argument of the cttz and ctlz intrinsics. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@146360 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test')
-rw-r--r--test/Verifier/cttz-undef-arg.ll16
1 files changed, 16 insertions, 0 deletions
diff --git a/test/Verifier/cttz-undef-arg.ll b/test/Verifier/cttz-undef-arg.ll
new file mode 100644
index 0000000000..48cd061d32
--- /dev/null
+++ b/test/Verifier/cttz-undef-arg.ll
@@ -0,0 +1,16 @@
+; RUN: not llvm-as < %s -o /dev/null |& FileCheck %s
+
+declare i32 @llvm.ctlz.i32(i32, i1)
+declare i32 @llvm.cttz.i32(i32, i1)
+
+define void @f(i32 %x, i1 %is_not_zero) {
+entry:
+; CHECK: is_zero_undef argument of bit counting intrinsics must be a constant int
+; CHECK-NEXT: @llvm.ctlz.i32
+ call i32 @llvm.ctlz.i32(i32 %x, i1 %is_not_zero)
+
+; CHECK: is_zero_undef argument of bit counting intrinsics must be a constant int
+; CHECK-NEXT: @llvm.cttz.i32
+ call i32 @llvm.cttz.i32(i32 %x, i1 %is_not_zero)
+ ret void
+}