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