| ; Make sure this testcase codegens to the sin and cos instructions, not calls |
| ; RUN: llvm-as < %s | \ |
| ; RUN: llc -march=x86 -mattr=-sse,-sse2,-sse3 -enable-unsafe-fp-math | \ |
| ; RUN: grep sin\$ | count 3 |
| ; RUN: llvm-as < %s | \ |
| ; RUN: llc -march=x86 -mattr=-sse,-sse2,-sse3 -enable-unsafe-fp-math | \ |
| ; RUN: grep cos\$ | count 3 |
| |
| declare float @sinf(float) |
| |
| declare double @sin(double) |
| |
| declare x86_fp80 @sinl(x86_fp80) |
| |
| define float @test1(float %X) { |
| %Y = call float @sinf(float %X) |
| ret float %Y |
| } |
| |
| define double @test2(double %X) { |
| %Y = call double @sin(double %X) |
| ret double %Y |
| } |
| |
| define x86_fp80 @test3(x86_fp80 %X) { |
| %Y = call x86_fp80 @sinl(x86_fp80 %X) |
| ret x86_fp80 %Y |
| } |
| |
| declare float @cosf(float) |
| |
| declare double @cos(double) |
| |
| declare x86_fp80 @cosl(x86_fp80) |
| |
| define float @test4(float %X) { |
| %Y = call float @cosf(float %X) |
| ret float %Y |
| } |
| |
| define double @test5(double %X) { |
| %Y = call double @cos(double %X) |
| ret double %Y |
| } |
| |
| define x86_fp80 @test6(x86_fp80 %X) { |
| %Y = call x86_fp80 @cosl(x86_fp80 %X) |
| ret x86_fp80 %Y |
| } |
| |