| /* { dg-do compile } */ |
| /* { dg-require-effective-target cv_simd } */ |
| /* { dg-options "-march=rv32i_xcvsimd -mabi=ilp32" } */ |
| |
| int |
| foo1 (int a, int b) |
| { |
| return __builtin_riscv_cv_simd_sub_sc_h(a, b); |
| } |
| |
| int |
| foo2 (int a) |
| { |
| return __builtin_riscv_cv_simd_sub_sc_h(a, -32); |
| } |
| |
| int |
| foo3 (int a) |
| { |
| return __builtin_riscv_cv_simd_sub_sc_h(a, 0); |
| } |
| |
| int |
| foo4 (int a) |
| { |
| return __builtin_riscv_cv_simd_sub_sc_h(a, 31); |
| } |
| |
| /* { dg-final { scan-assembler-times "cv\\.sub\\.sc\\.h" 1 } } */ |
| /* { dg-final { scan-assembler-times "cv\\.sub\\.sci\\.h" 3 } } */ |