mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-26 04:32:44 +01:00
6ea2cff39a
Summary: This change enables the sin(x) cos(x) -> sincos(x) optimization on GNU target triples. This optimization was being inhibited when -ffast-math wasn't set because sincos in GLibC does not set errno, while sin and cos do. However, this optimization will only run if the attributes on the sin/cos calls include readnone, which is how clang represents the fact that it doesn't care about the errno values set by these functions (via the -fno-math-errno flag). Reviewers: hfinkel, bogner Subscribers: mcrosier, javed.absar, llvm-commits, paul.redmond Differential Revision: https://reviews.llvm.org/D32921 llvm-svn: 305204
80 lines
2.1 KiB
LLVM
80 lines
2.1 KiB
LLVM
; Test that combined sin/cos library call is emitted when appropriate
|
|
|
|
; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s --check-prefix=CHECK-OPT
|
|
; RUN: llc < %s -mtriple=s390x-linux-gnu -enable-unsafe-fp-math | FileCheck %s --check-prefix=CHECK-OPT
|
|
|
|
define float @f1(float %x) {
|
|
; CHECK-OPT-LABEL: f1:
|
|
; CHECK-OPT: brasl %r14, sincosf@PLT
|
|
; CHECK-OPT: le %f0, 164(%r15)
|
|
; CHECK-OPT: aeb %f0, 160(%r15)
|
|
%tmp1 = call float @sinf(float %x) readnone
|
|
%tmp2 = call float @cosf(float %x) readnone
|
|
%add = fadd float %tmp1, %tmp2
|
|
ret float %add
|
|
}
|
|
|
|
define float @f1_errno(float %x) {
|
|
; CHECK-OPT-LABEL: f1_errno:
|
|
; CHECK-OPT: brasl %r14, sinf@PLT
|
|
; CHECK-OPT: ler %f9, %f0
|
|
; CHECK-OPT: brasl %r14, cosf@PLT
|
|
; CHECK-OPT: aebr %f0, %f9
|
|
%tmp1 = call float @sinf(float %x)
|
|
%tmp2 = call float @cosf(float %x)
|
|
%add = fadd float %tmp1, %tmp2
|
|
ret float %add
|
|
}
|
|
|
|
define double @f2(double %x) {
|
|
; CHECK-OPT-LABEL: f2:
|
|
; CHECK-OPT: brasl %r14, sincos@PLT
|
|
; CHECK-OPT: ld %f0, 168(%r15)
|
|
; CHECK-OPT: adb %f0, 160(%r15)
|
|
%tmp1 = call double @sin(double %x) readnone
|
|
%tmp2 = call double @cos(double %x) readnone
|
|
%add = fadd double %tmp1, %tmp2
|
|
ret double %add
|
|
}
|
|
|
|
define double @f2_errno(double %x) {
|
|
; CHECK-OPT-LABEL: f2_errno:
|
|
; CHECK-OPT: brasl %r14, sin@PLT
|
|
; CHECK-OPT: ldr %f9, %f0
|
|
; CHECK-OPT: brasl %r14, cos@PLT
|
|
; CHECK-OPT: adbr %f0, %f9
|
|
%tmp1 = call double @sin(double %x)
|
|
%tmp2 = call double @cos(double %x)
|
|
%add = fadd double %tmp1, %tmp2
|
|
ret double %add
|
|
}
|
|
|
|
define fp128 @f3(fp128 %x) {
|
|
; CHECK-OPT-LABEL: f3:
|
|
; CHECK-OPT: brasl %r14, sincosl@PLT
|
|
; CHECK-OPT: axbr
|
|
%tmp1 = call fp128 @sinl(fp128 %x) readnone
|
|
%tmp2 = call fp128 @cosl(fp128 %x) readnone
|
|
%add = fadd fp128 %tmp1, %tmp2
|
|
ret fp128 %add
|
|
}
|
|
|
|
define fp128 @f3_errno(fp128 %x) {
|
|
; CHECK-OPT-LABEL: f3_errno:
|
|
; CHECK-OPT: brasl %r14, sinl@PLT
|
|
; CHECK-OPT: brasl %r14, cosl@PLT
|
|
; CHECK-OPT: axbr
|
|
%tmp1 = call fp128 @sinl(fp128 %x)
|
|
%tmp2 = call fp128 @cosl(fp128 %x)
|
|
%add = fadd fp128 %tmp1, %tmp2
|
|
ret fp128 %add
|
|
}
|
|
|
|
declare float @sinf(float)
|
|
declare double @sin(double)
|
|
declare fp128 @sinl(fp128)
|
|
declare float @cosf(float)
|
|
declare double @cos(double)
|
|
declare fp128 @cosl(fp128)
|
|
|