| /* 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); |
| } |