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