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
);