[LoopVectorizer] Add support for chaining partial reductions (#120272)
[llvm-project.git] / clang / test / CodeGen / RISCV / rvv-intrinsics-handcrafted / vfmsub-out-of-range.c
blob43ca863a0cdd3f58a2c09cdba97f8bbd256eb906
1 // REQUIRES: riscv-registered-target
2 // RUN: %clang_cc1 -triple riscv64 -target-feature +f -target-feature +d \
3 // RUN: -target-feature +v -target-feature +zfh -target-feature +zvfh \
4 // RUN: -fsyntax-only -verify %s
6 #include <riscv_vector.h>
9 vfloat32m1_t test_vfmsub_vv_f32m1_rm(vfloat32m1_t vd, vfloat32m1_t vs1, vfloat32m1_t vs2, size_t vl) {
10 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
11 return __riscv_vfmsub_vv_f32m1_rm(vd, vs1, vs2, 5, vl);
14 vfloat32m1_t test_vfmsub_vf_f32m1_rm(vfloat32m1_t vd, float rs1, vfloat32m1_t vs2, size_t vl) {
15 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
16 return __riscv_vfmsub_vf_f32m1_rm(vd, rs1, vs2, 5, vl);
19 vfloat32m1_t test_vfmsub_vv_f32m1_rm_m(vbool32_t mask, vfloat32m1_t vd, vfloat32m1_t vs1, vfloat32m1_t vs2, size_t vl) {
20 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
21 return __riscv_vfmsub_vv_f32m1_rm_m(mask, vd, vs1, vs2, 5, vl);
24 vfloat32m1_t test_vfmsub_vf_f32m1_rm_m(vbool32_t mask, vfloat32m1_t vd, float rs1, vfloat32m1_t vs2, size_t vl) {
25 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
26 return __riscv_vfmsub_vf_f32m1_rm_m(mask, vd, rs1, vs2, 5, vl);
29 vfloat32m1_t test_vfmsub_vv_f32m1_rm_tu(vfloat32m1_t vd, vfloat32m1_t vs1, vfloat32m1_t vs2, size_t vl) {
30 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
31 return __riscv_vfmsub_vv_f32m1_rm_tu(vd, vs1, vs2, 5, vl);
34 vfloat32m1_t test_vfmsub_vf_f32m1_rm_tu(vfloat32m1_t vd, float rs1, vfloat32m1_t vs2, size_t vl) {
35 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
36 return __riscv_vfmsub_vf_f32m1_rm_tu(vd, rs1, vs2, 5, vl);
39 vfloat32m1_t test_vfmsub_vv_f32m1_rm_tum(vbool32_t mask, vfloat32m1_t vd, vfloat32m1_t vs1, vfloat32m1_t vs2, size_t vl) {
40 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
41 return __riscv_vfmsub_vv_f32m1_rm_tum(mask, vd, vs1, vs2, 5, vl);
44 vfloat32m1_t test_vfmsub_vf_f32m1_rm_tum(vbool32_t mask, vfloat32m1_t vd, float rs1, vfloat32m1_t vs2, size_t vl) {
45 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
46 return __riscv_vfmsub_vf_f32m1_rm_tum(mask, vd, rs1, vs2, 5, vl);
49 vfloat32m1_t test_vfmsub_vv_f32m1_rm_tumu(vbool32_t mask, vfloat32m1_t vd, vfloat32m1_t vs1, vfloat32m1_t vs2, size_t vl) {
50 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
51 return __riscv_vfmsub_vv_f32m1_rm_tumu(mask, vd, vs1, vs2, 5, vl);
54 vfloat32m1_t test_vfmsub_vf_f32m1_rm_tumu(vbool32_t mask, vfloat32m1_t vd, float rs1, vfloat32m1_t vs2, size_t vl) {
55 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
56 return __riscv_vfmsub_vf_f32m1_rm_tumu(mask, vd, rs1, vs2, 5, vl);
59 vfloat32m1_t test_vfmsub_vv_f32m1_rm_mu(vbool32_t mask, vfloat32m1_t vd, vfloat32m1_t vs1, vfloat32m1_t vs2, size_t vl) {
60 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
61 return __riscv_vfmsub_vv_f32m1_rm_mu(mask, vd, vs1, vs2, 5, vl);
64 vfloat32m1_t test_vfmsub_vf_f32m1_rm_mu(vbool32_t mask, vfloat32m1_t vd, float rs1, vfloat32m1_t vs2, size_t vl) {
65 // expected-error@+1 {{argument value 5 is outside the valid range [0, 4]}}
66 return __riscv_vfmsub_vf_f32m1_rm_mu(mask, vd, rs1, vs2, 5, vl);