// REQUIRES: riscv-registered-target // RUN: %clang_cc1 -std=c++11 -triple riscv64 -target-feature +v \ // RUN: -emit-llvm %s -o - | FileCheck -check-prefix=CHECK-LLVM %s // RUN: %clang_cc1 -std=c++11 -triple riscv64 -target-feature +zve32x \ // RUN: -emit-llvm %s -o - | FileCheck -check-prefix=CHECK-LLVM-ZVE32X %s #include // CHECK-LLVM: call riscv_vector_cc @_Z3baru15__rvv_int32m1_t vint32m1_t __attribute__((riscv_vector_cc)) bar(vint32m1_t input); vint32m1_t test_vector_cc_attr(vint32m1_t input, int32_t *base, size_t vl) { vint32m1_t val = __riscv_vle32_v_i32m1(base, vl); vint32m1_t ret = bar(input); __riscv_vse32_v_i32m1(base, val, vl); return ret; } // CHECK-LLVM: call riscv_vector_cc @_Z3baru15__rvv_int32m1_t [[riscv::vector_cc]] vint32m1_t bar(vint32m1_t input); vint32m1_t test_vector_cc_attr2(vint32m1_t input, int32_t *base, size_t vl) { vint32m1_t val = __riscv_vle32_v_i32m1(base, vl); vint32m1_t ret = bar(input); __riscv_vse32_v_i32m1(base, val, vl); return ret; } // CHECK-LLVM: call @_Z3bazu15__rvv_int32m1_t vint32m1_t baz(vint32m1_t input); vint32m1_t test_no_vector_cc_attr(vint32m1_t input, int32_t *base, size_t vl) { vint32m1_t val = __riscv_vle32_v_i32m1(base, vl); vint32m1_t ret = baz(input); __riscv_vse32_v_i32m1(base, val, vl); return ret; } // CHECK-LLVM: define dso_local void @_Z14test_vls_no_ccDv4_i(i128 noundef %arg.coerce) void test_vls_no_cc(__attribute__((vector_size(16))) int arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z25test_vls_default_abi_vlenDv4_i( noundef %arg.coerce) [[riscv::vls_cc]] void test_vls_default_abi_vlen(__attribute__((vector_size(16))) int arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z45test_vls_default_abi_vlen_unsupported_featureDv8_DF16_( noundef %arg.coerce) [[riscv::vls_cc]] void test_vls_default_abi_vlen_unsupported_feature(__attribute__((vector_size(16))) _Float16 arg) {} // CHECK-LLVM-ZVE32X: define dso_local riscv_vls_cc(128) void @_Z52test_vls_default_abi_vlen_unsupported_feature_zve32xDv4_f( noundef %arg.coerce) [[riscv::vls_cc]] void test_vls_default_abi_vlen_unsupported_feature_zve32x(__attribute__((vector_size(16))) float arg) {} // CHECK-LLVM-ZVE32X: define dso_local riscv_vls_cc(128) void @_Z55test_vls_default_abi_vlen_unsupported_feature_no_zve64xDv2_m( noundef %arg.coerce) [[riscv::vls_cc]] void test_vls_default_abi_vlen_unsupported_feature_no_zve64x(__attribute__((vector_size(16))) uint64_t arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z21test_vls_256_abi_vlenDv4_i( noundef %arg.coerce) [[riscv::vls_cc(256)]] void test_vls_256_abi_vlen(__attribute__((vector_size(16))) int arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(1024) void @_Z22test_vls_least_elementDv2_i( noundef %arg.coerce) [[riscv::vls_cc(1024)]] void test_vls_least_element(__attribute__((vector_size(8))) int arg) {} struct st_i32x4 { __attribute__((vector_size(16))) int i32; }; struct st_i32x4_arr1 { __attribute__((vector_size(16))) int i32[1]; }; struct st_i32x4_arr4 { __attribute__((vector_size(16))) int i32[4]; }; struct st_i32x4_arr8 { __attribute__((vector_size(16))) int i32[8]; }; struct st_i32x4x2 { __attribute__((vector_size(16))) int i32_1; __attribute__((vector_size(16))) int i32_2; }; struct st_i32x8x2 { __attribute__((vector_size(32))) int i32_1; __attribute__((vector_size(32))) int i32_2; }; struct st_i32x64x2 { __attribute__((vector_size(256))) int i32_1; __attribute__((vector_size(256))) int i32_2; }; struct st_i32x4x3 { __attribute__((vector_size(16))) int i32_1; __attribute__((vector_size(16))) int i32_2; __attribute__((vector_size(16))) int i32_3; }; struct st_i32x4x8 { __attribute__((vector_size(16))) int i32_1; __attribute__((vector_size(16))) int i32_2; __attribute__((vector_size(16))) int i32_3; __attribute__((vector_size(16))) int i32_4; __attribute__((vector_size(16))) int i32_5; __attribute__((vector_size(16))) int i32_6; __attribute__((vector_size(16))) int i32_7; __attribute__((vector_size(16))) int i32_8; }; struct st_i32x4x9 { __attribute__((vector_size(16))) int i32_1; __attribute__((vector_size(16))) int i32_2; __attribute__((vector_size(16))) int i32_3; __attribute__((vector_size(16))) int i32_4; __attribute__((vector_size(16))) int i32_5; __attribute__((vector_size(16))) int i32_6; __attribute__((vector_size(16))) int i32_7; __attribute__((vector_size(16))) int i32_8; __attribute__((vector_size(16))) int i32_9; }; typedef int __attribute__((vector_size(256))) int32x64_t; // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z14test_too_largeDv64_i(ptr dead_on_return noundef %0) [[riscv::vls_cc]] void test_too_large(int32x64_t arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z18test_too_large_256Dv64_i( noundef %arg.coerce) [[riscv::vls_cc(256)]] void test_too_large_256(int32x64_t arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z13test_st_i32x48st_i32x4( %arg) [[riscv::vls_cc]] void test_st_i32x4(struct st_i32x4 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z17test_st_i32x4_2568st_i32x4( %arg) [[riscv::vls_cc(256)]] void test_st_i32x4_256(struct st_i32x4 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z18test_st_i32x4_arr113st_i32x4_arr1( %arg) [[riscv::vls_cc]] void test_st_i32x4_arr1(struct st_i32x4_arr1 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z22test_st_i32x4_arr1_25613st_i32x4_arr1( %arg) [[riscv::vls_cc(256)]] void test_st_i32x4_arr1_256(struct st_i32x4_arr1 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z18test_st_i32x4_arr413st_i32x4_arr4(target("riscv.vector.tuple", , 4) %arg) [[riscv::vls_cc]] void test_st_i32x4_arr4(struct st_i32x4_arr4 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z22test_st_i32x4_arr4_25613st_i32x4_arr4(target("riscv.vector.tuple", , 4) %arg) [[riscv::vls_cc(256)]] void test_st_i32x4_arr4_256(struct st_i32x4_arr4 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z18test_st_i32x4_arr813st_i32x4_arr8(target("riscv.vector.tuple", , 8) %arg) [[riscv::vls_cc]] void test_st_i32x4_arr8(struct st_i32x4_arr8 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z22test_st_i32x4_arr8_25613st_i32x4_arr8(target("riscv.vector.tuple", , 8) %arg) [[riscv::vls_cc(256)]] void test_st_i32x4_arr8_256(struct st_i32x4_arr8 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z15test_st_i32x4x210st_i32x4x2(target("riscv.vector.tuple", , 2) %arg) [[riscv::vls_cc]] void test_st_i32x4x2(struct st_i32x4x2 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z19test_st_i32x4x2_25610st_i32x4x2(target("riscv.vector.tuple", , 2) %arg) [[riscv::vls_cc(256)]] void test_st_i32x4x2_256(struct st_i32x4x2 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z15test_st_i32x8x210st_i32x8x2(target("riscv.vector.tuple", , 2) %arg) [[riscv::vls_cc]] void test_st_i32x8x2(struct st_i32x8x2 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z19test_st_i32x8x2_25610st_i32x8x2(target("riscv.vector.tuple", , 2) %arg) [[riscv::vls_cc(256)]] void test_st_i32x8x2_256(struct st_i32x8x2 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z16test_st_i32x64x211st_i32x64x2(ptr dead_on_return noundef %arg) [[riscv::vls_cc]] void test_st_i32x64x2(struct st_i32x64x2 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z20test_st_i32x64x2_25611st_i32x64x2(ptr dead_on_return noundef %arg) [[riscv::vls_cc(256)]] void test_st_i32x64x2_256(struct st_i32x64x2 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z15test_st_i32x4x310st_i32x4x3(target("riscv.vector.tuple", , 3) %arg) [[riscv::vls_cc]] void test_st_i32x4x3(struct st_i32x4x3 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z19test_st_i32x4x3_25610st_i32x4x3(target("riscv.vector.tuple", , 3) %arg) [[riscv::vls_cc(256)]] void test_st_i32x4x3_256(struct st_i32x4x3 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z15test_st_i32x4x810st_i32x4x8(target("riscv.vector.tuple", , 8) %arg) [[riscv::vls_cc]] void test_st_i32x4x8(struct st_i32x4x8 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z19test_st_i32x4x8_25610st_i32x4x8(target("riscv.vector.tuple", , 8) %arg) [[riscv::vls_cc(256)]] void test_st_i32x4x8_256(struct st_i32x4x8 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(128) void @_Z15test_st_i32x4x910st_i32x4x9(ptr dead_on_return noundef %arg) [[riscv::vls_cc]] void test_st_i32x4x9(struct st_i32x4x9 arg) {} // CHECK-LLVM: define dso_local riscv_vls_cc(256) void @_Z19test_st_i32x4x9_25610st_i32x4x9(ptr dead_on_return noundef %arg) [[riscv::vls_cc(256)]] void test_st_i32x4x9_256(struct st_i32x4x9 arg) {}