| // NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --version 3 |
| // REQUIRES: aarch64-registered-target |
| // RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sme -S -O1 -Werror -emit-llvm -o - %s | FileCheck %s -check-prefixes=CHECK,CHECK-C |
| // RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sme -S -O1 -Werror -emit-llvm -o - -x c++ %s | FileCheck %s -check-prefixes=CHECK,CHECK-CXX |
| // RUN: %clang_cc1 -triple aarch64-none-linux-gnu -target-feature +sme -S -O1 -Werror -o /dev/null %s |
| |
| #include <arm_sme.h> |
| |
| // CHECK-C-LABEL: @test_svldr_vnum_za( |
| // CHECK-CXX-LABEL: @_Z18test_svldr_vnum_zajPKv( |
| // CHECK-NEXT: entry: |
| // CHECK-NEXT: tail call void @llvm.aarch64.sme.ldr(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 0) |
| // CHECK-NEXT: ret void |
| // |
| void test_svldr_vnum_za(uint32_t slice_base, const void *ptr) __arm_out("za") { |
| svldr_vnum_za(slice_base, ptr, 0); |
| } |
| |
| // CHECK-C-LABEL: @test_svldr_vnum_za_1( |
| // CHECK-CXX-LABEL: @_Z20test_svldr_vnum_za_1jPKv( |
| // CHECK-NEXT: entry: |
| // CHECK-NEXT: tail call void @llvm.aarch64.sme.ldr(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 15) |
| // CHECK-NEXT: ret void |
| // |
| void test_svldr_vnum_za_1(uint32_t slice_base, const void *ptr) __arm_out("za") { |
| svldr_vnum_za(slice_base, ptr, 15); |
| } |
| |
| // CHECK-C-LABEL: @test_svldr_za( |
| // CHECK-CXX-LABEL: @_Z13test_svldr_zajPKv( |
| // CHECK-NEXT: entry: |
| // CHECK-NEXT: tail call void @llvm.aarch64.sme.ldr(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 0) |
| // CHECK-NEXT: ret void |
| // |
| void test_svldr_za(uint32_t slice_base, const void *ptr) __arm_out("za") { |
| svldr_za(slice_base, ptr); |
| } |
| |
| // CHECK-C-LABEL: @test_svldr_vnum_za_var( |
| // CHECK-CXX-LABEL: @_Z22test_svldr_vnum_za_varjPKvl( |
| // CHECK-NEXT: entry: |
| // CHECK-NEXT: [[TMP0:%.*]] = trunc i64 [[VNUM:%.*]] to i32 |
| // CHECK-NEXT: tail call void @llvm.aarch64.sme.ldr(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 [[TMP0:%.*]]) |
| // CHECK-NEXT: ret void |
| // |
| void test_svldr_vnum_za_var(uint32_t slice_base, const void *ptr, int64_t vnum) __arm_out("za") { |
| svldr_vnum_za(slice_base, ptr, vnum); |
| } |
| |
| // CHECK-C-LABEL: @test_svldr_vnum_za_2( |
| // CHECK-CXX-LABEL: @_Z20test_svldr_vnum_za_2jPKv( |
| // CHECK-NEXT: entry: |
| // CHECK-NEXT: tail call void @llvm.aarch64.sme.ldr(i32 [[SLICE_BASE:%.*]], ptr [[PTR:%.*]], i32 16) |
| // CHECK-NEXT: ret void |
| // |
| void test_svldr_vnum_za_2(uint32_t slice_base, const void *ptr) __arm_out("za") { |
| svldr_vnum_za(slice_base, ptr, 16); |
| } |