/* Test SB-1 v2sf extensions.  */
/* { dg-do compile } */ 
/* { dg-options "-march=sb1 -mpaired-single -mgp64 -ffast-math" } */
/* { dg-skip-if "rsqrt code quality test" { *-*-* } { "-O0" } { "" } } */
/* { dg-final { scan-assembler "\tdiv.ps\t" } } */
/* { dg-final { scan-assembler "\trecip.ps\t" } } */
/* { dg-final { scan-assembler "\tsqrt.ps\t" } } */
/* { dg-final { scan-assembler "\trsqrt.ps\t" } } */

typedef float v2sf __attribute__ ((vector_size (8)));

NOMIPS16 v2sf divide (v2sf a, v2sf b)
{
  return a / b;
}

NOMIPS16 v2sf recip (v2sf a)
{
  return ((v2sf) {1.0, 1.0}) / a;
}

NOMIPS16 v2sf squareroot (v2sf a)
{
  return __builtin_mips_sqrt_ps (a);
}

NOMIPS16 v2sf rsqrt (v2sf a)
{
  return ((v2sf) {1.0, 1.0}) / __builtin_mips_sqrt_ps (a);
}