/* { dg-do compile } */
/* { dg-require-effective-target cv_simd } */
/* { dg-options "-march=rv32i_xcvsimd -mabi=ilp32" } */

int
foo1 (int a, int b, int c)
{
	return __builtin_riscv_cv_simd_sdotsp_sc_h(a, b, c);
}

int
foo2 (int a, int b)
{
	return __builtin_riscv_cv_simd_sdotsp_sc_h(a, -32, b);
}

int
foo3 (int a, int b)
{
	return __builtin_riscv_cv_simd_sdotsp_sc_h(a, 0, b);
}

int
foo4 (int a, int b)
{
	return __builtin_riscv_cv_simd_sdotsp_sc_h(a, 31, b);
}

/* { dg-final { scan-assembler-times "cv\\.sdotsp\\.sc\\.h" 1 } } */
/* { dg-final { scan-assembler-times "cv\\.sdotsp\\.sci\\.h" 3 } } */