xref: /llvm-project/clang/test/CodeGen/AArch64/sme-intrinsics/acle_sme_str.c (revision 207e5ccceec8d3cc3f32723e78f2a142bc61b07d)
1*207e5cccSFangrui Song // NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --version 3
2*207e5cccSFangrui Song // REQUIRES: aarch64-registered-target
3*207e5cccSFangrui Song // RUN: %clang_cc1 -triple aarch64 -target-feature +sme -O1 -Werror -emit-llvm -o - %s | FileCheck %s -check-prefixes=CHECK,CHECK-C
4*207e5cccSFangrui Song // RUN: %clang_cc1 -triple aarch64 -target-feature +sme -O1 -Werror -emit-llvm -o - -x c++ %s | FileCheck %s -check-prefixes=CHECK,CHECK-CXX
5*207e5cccSFangrui Song // RUN: %clang_cc1 -triple aarch64 -target-feature +sme -S -O1 -Werror -o /dev/null %s
6*207e5cccSFangrui Song 
7*207e5cccSFangrui Song #include <arm_sme.h>
8*207e5cccSFangrui Song 
9*207e5cccSFangrui Song // CHECK-C-LABEL: @test_svstr_vnum_za(
10*207e5cccSFangrui Song // CHECK-CXX-LABEL: @_Z18test_svstr_vnum_zajPv(
11*207e5cccSFangrui Song // CHECK-NEXT:  entry:
12*207e5cccSFangrui Song // CHECK-NEXT:    tail call void @llvm.aarch64.sme.str(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 0)
13*207e5cccSFangrui Song // CHECK-NEXT:    ret void
14*207e5cccSFangrui Song //
15*207e5cccSFangrui Song void test_svstr_vnum_za(uint32_t slice_base, void *ptr) __arm_in("za") {
16*207e5cccSFangrui Song   svstr_vnum_za(slice_base, ptr, 0);
17*207e5cccSFangrui Song }
18*207e5cccSFangrui Song 
19*207e5cccSFangrui Song // CHECK-C-LABEL: @test_svstr_vnum_za_1(
20*207e5cccSFangrui Song // CHECK-CXX-LABEL: @_Z20test_svstr_vnum_za_1jPv(
21*207e5cccSFangrui Song // CHECK-NEXT:  entry:
22*207e5cccSFangrui Song // CHECK-NEXT:    tail call void @llvm.aarch64.sme.str(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 15)
23*207e5cccSFangrui Song // CHECK-NEXT:    ret void
24*207e5cccSFangrui Song //
25*207e5cccSFangrui Song void test_svstr_vnum_za_1(uint32_t slice_base, void *ptr) __arm_in("za") {
26*207e5cccSFangrui Song   svstr_vnum_za(slice_base, ptr, 15);
27*207e5cccSFangrui Song }
28*207e5cccSFangrui Song 
29*207e5cccSFangrui Song // CHECK-C-LABEL: @test_svstr_za(
30*207e5cccSFangrui Song // CHECK-CXX-LABEL: @_Z13test_svstr_zajPv(
31*207e5cccSFangrui Song // CHECK-NEXT:  entry:
32*207e5cccSFangrui Song // CHECK-NEXT:    tail call void @llvm.aarch64.sme.str(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 0)
33*207e5cccSFangrui Song // CHECK-NEXT:    ret void
34*207e5cccSFangrui Song //
35*207e5cccSFangrui Song void test_svstr_za(uint32_t slice_base, void *ptr) __arm_in("za") {
36*207e5cccSFangrui Song   svstr_za(slice_base, ptr);
37*207e5cccSFangrui Song }
38*207e5cccSFangrui Song 
39*207e5cccSFangrui Song // CHECK-C-LABEL: @test_svstr_vnum_za_var(
40*207e5cccSFangrui Song // CHECK-CXX-LABEL: @_Z22test_svstr_vnum_za_varjPvl(
41*207e5cccSFangrui Song // CHECK-NEXT:  entry:
42*207e5cccSFangrui Song // CHECK-NEXT:    [[TMP0:%.*]] = trunc i64 [[VNUM:%.*]] to i32
43*207e5cccSFangrui Song // CHECK-NEXT:    tail call void @llvm.aarch64.sme.str(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 [[TMP0:%.*]])
44*207e5cccSFangrui Song // CHECK-NEXT:    ret void
45*207e5cccSFangrui Song //
46*207e5cccSFangrui Song void test_svstr_vnum_za_var(uint32_t slice_base, void *ptr, int64_t vnum) __arm_in("za") {
47*207e5cccSFangrui Song   svstr_vnum_za(slice_base, ptr, vnum);
48*207e5cccSFangrui Song }
49*207e5cccSFangrui Song 
50*207e5cccSFangrui Song // CHECK-C-LABEL: @test_svstr_vnum_za_2(
51*207e5cccSFangrui Song // CHECK-CXX-LABEL: @_Z20test_svstr_vnum_za_2jPv(
52*207e5cccSFangrui Song // CHECK-NEXT:  entry:
53*207e5cccSFangrui Song // CHECK-NEXT:    tail call void @llvm.aarch64.sme.str(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 16)
54*207e5cccSFangrui Song // CHECK-NEXT:    ret void
55*207e5cccSFangrui Song //
56*207e5cccSFangrui Song void test_svstr_vnum_za_2(uint32_t slice_base, void *ptr) __arm_in("za") {
57*207e5cccSFangrui Song   svstr_vnum_za(slice_base, ptr, 16);
58*207e5cccSFangrui Song }
59