diff options
Diffstat (limited to 'test/Verifier/2010-08-07-PointerIntrinsic.ll')
-rw-r--r-- | test/Verifier/2010-08-07-PointerIntrinsic.ll | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/test/Verifier/2010-08-07-PointerIntrinsic.ll b/test/Verifier/2010-08-07-PointerIntrinsic.ll index 0c0121ddbc81e..a502fab1223d6 100644 --- a/test/Verifier/2010-08-07-PointerIntrinsic.ll +++ b/test/Verifier/2010-08-07-PointerIntrinsic.ll @@ -2,6 +2,14 @@ ; CHECK: assembly parsed, but does not verify as correct ; PR7316 +; XFAIL: * +; The test case is buggy, it supposed to check that we reject memcpy with vector +; pointer arguments. Now we don't reject such memcpy and the test case would +; fail if it was correct. Because it used the wrong signature for memcpy (the +; last isVolatile argument was missing) it was rejected by the verifier and +; didn't fail. Fix the memcpy signature and mark it as an expected failure +; for now. + target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:32" target triple = "x86-unknown-unknown" @aa = global [32 x i8] zeroinitializer, align 1 @@ -13,9 +21,9 @@ L.0: %2 = bitcast [16 x i8]* %1 to [0 x i8]* %3 = getelementptr [16 x i8], [16 x i8]* @bb %4 = bitcast [16 x i8]* %3 to [0 x i8]* - call void @llvm.memcpy.i32([0 x i8]* %2, [0 x i8]* %4, i32 16, i32 1) + call void @llvm.memcpy.p0a0i8.p0a0i8.i32([0 x i8]* %2, [0 x i8]* %4, i32 16, i32 1, i1 false) br label %return return: ret void } -declare void @llvm.memcpy.i32([0 x i8]*, [0 x i8]*, i32, i32) nounwind +declare void @llvm.memcpy.p0a0i8.p0a0i8.i32([0 x i8]* nocapture, [0 x i8]* nocapture readonly, i32, i32, i1) nounwind |