[ARM] Split large truncating MVE stores
[llvm-complete.git] / test / CodeGen / AArch64 / arm64-reserved-arg-reg-call-error.ll
blobb98b11e180e20c24cf482a0f51ba7a7a4a41e1d8
1 ; RUN: not llc < %s -mtriple=arm64-linux-gnu -mattr=+reserve-x1 2>&1 | FileCheck %s
2 ; RUN: not llc < %s -mtriple=arm64-linux-gnu -mattr=+reserve-x1 -fast-isel 2>&1 | FileCheck %s
3 ; RUN: not llc < %s -mtriple=arm64-linux-gnu -mattr=+reserve-x1 -global-isel 2>&1 | FileCheck %s
5 ; CHECK: error:
6 ; CHECK-SAME: AArch64 doesn't support function calls if any of the argument registers is reserved.
7 define void @call_function() {
8   call void @foo()
9   ret void
11 declare void @foo()
13 ; CHECK: error:
14 ; CHECK-SAME: AArch64 doesn't support function calls if any of the argument registers is reserved.
15 define void @call_memcpy(i8* %out, i8* %in) {
16   call void @llvm.memcpy.p0i8.p0i8.i64(i8* %out, i8* %in, i64 800, i1 false)
17   ret void
19 declare void @llvm.memcpy.p0i8.p0i8.i64(i8*, i8*, i64, i1)