xref: /aosp_15_r20/external/llvm/test/Verifier/2010-08-07-PointerIntrinsic.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: not llvm-as < %s 2>&1 | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; CHECK: assembly parsed, but does not verify as correct
3*9880d681SAndroid Build Coastguard Worker; PR7316
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Worker; XFAIL: *
6*9880d681SAndroid Build Coastguard Worker; The test case is buggy, it supposed to check that we reject memcpy with vector
7*9880d681SAndroid Build Coastguard Worker; pointer arguments. Now we don't reject such memcpy and the test case would
8*9880d681SAndroid Build Coastguard Worker; fail if it was correct. Because it used the wrong signature for memcpy (the
9*9880d681SAndroid Build Coastguard Worker; last isVolatile argument was missing) it was rejected by the verifier and
10*9880d681SAndroid Build Coastguard Worker; didn't fail. Fix the memcpy signature and mark it as an expected failure
11*9880d681SAndroid Build Coastguard Worker; for now.
12*9880d681SAndroid Build Coastguard Worker
13*9880d681SAndroid Build Coastguard Workertarget datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:32"
14*9880d681SAndroid Build Coastguard Workertarget triple = "x86-unknown-unknown"
15*9880d681SAndroid Build Coastguard Worker@aa = global [32 x i8] zeroinitializer, align 1
16*9880d681SAndroid Build Coastguard Worker@bb = global [16 x i8] zeroinitializer, align 1
17*9880d681SAndroid Build Coastguard Workerdefine void @x() nounwind {
18*9880d681SAndroid Build Coastguard WorkerL.0:
19*9880d681SAndroid Build Coastguard Worker	%0 = getelementptr [32 x i8], [32 x i8]* @aa, i32 0, i32 4
20*9880d681SAndroid Build Coastguard Worker	%1 = bitcast i8* %0 to [16 x i8]*
21*9880d681SAndroid Build Coastguard Worker	%2 = bitcast [16 x i8]* %1 to [0 x i8]*
22*9880d681SAndroid Build Coastguard Worker	%3 = getelementptr [16 x i8], [16 x i8]* @bb
23*9880d681SAndroid Build Coastguard Worker	%4 = bitcast [16 x i8]* %3 to [0 x i8]*
24*9880d681SAndroid Build Coastguard Worker	call void @llvm.memcpy.p0a0i8.p0a0i8.i32([0 x i8]* %2, [0 x i8]* %4, i32 16, i32 1, i1 false)
25*9880d681SAndroid Build Coastguard Worker	br label %return
26*9880d681SAndroid Build Coastguard Workerreturn:
27*9880d681SAndroid Build Coastguard Worker	ret void
28*9880d681SAndroid Build Coastguard Worker}
29*9880d681SAndroid Build Coastguard Workerdeclare void @llvm.memcpy.p0a0i8.p0a0i8.i32([0 x i8]* nocapture, [0 x i8]* nocapture readonly, i32, i32, i1) nounwind
30