2017-08-02 06:20:41 +08:00
|
|
|
; RUN: llc -verify-machineinstrs < %s -mtriple=ppc32-- -fp-contract=fast -mattr=-vsx -disable-ppc-vsx-fma-mutation=false | FileCheck %s
|
2016-08-04 02:17:35 +08:00
|
|
|
; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64-unknown-linux-gnu -fp-contract=fast -mattr=+vsx -mcpu=pwr7 -disable-ppc-vsx-fma-mutation=false | FileCheck -check-prefix=CHECK-VSX %s
|
|
|
|
; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64-unknown-linux-gnu -fp-contract=fast -mcpu=pwr8 -disable-ppc-vsx-fma-mutation=false | FileCheck -check-prefix=CHECK-P8 %s
|
|
|
|
; RUN: llc -verify-machineinstrs < %s -mtriple=powerpc64le-unknown-linux-gnu -fp-contract=fast -mcpu=pwr8 -disable-ppc-vsx-fma-mutation=false | FileCheck -check-prefix=CHECK-P8 %s
|
2005-04-09 12:01:32 +08:00
|
|
|
|
Optionally enable more-aggressive FMA formation in DAGCombine
The heuristic used by DAGCombine to form FMAs checks that the FMUL has only one
use, but this is overly-conservative on some systems. Specifically, if the FMA
and the FADD have the same latency (and the FMA does not compete for resources
with the FMUL any more than the FADD does), there is no need for the
restriction, and furthermore, forming the FMA leaving the FMUL can still allow
for higher overall throughput and decreased critical-path length.
Here we add a new TLI callback, enableAggressiveFMAFusion, false by default, to
elide the hasOneUse check. This is enabled for PowerPC by default, as most
PowerPC systems will benefit.
Patch by Olivier Sallenave, thanks!
llvm-svn: 218120
2014-09-19 19:42:56 +08:00
|
|
|
declare double @dummy1(double) #0
|
|
|
|
declare double @dummy2(double, double) #0
|
|
|
|
declare double @dummy3(double, double, double) #0
|
2015-05-30 01:13:25 +08:00
|
|
|
declare float @dummy4(float, float) #0
|
Optionally enable more-aggressive FMA formation in DAGCombine
The heuristic used by DAGCombine to form FMAs checks that the FMUL has only one
use, but this is overly-conservative on some systems. Specifically, if the FMA
and the FADD have the same latency (and the FMA does not compete for resources
with the FMUL any more than the FADD does), there is no need for the
restriction, and furthermore, forming the FMA leaving the FMUL can still allow
for higher overall throughput and decreased critical-path length.
Here we add a new TLI callback, enableAggressiveFMAFusion, false by default, to
elide the hasOneUse check. This is enabled for PowerPC by default, as most
PowerPC systems will benefit.
Patch by Olivier Sallenave, thanks!
llvm-svn: 218120
2014-09-19 19:42:56 +08:00
|
|
|
|
2008-02-19 16:07:33 +08:00
|
|
|
define double @test_FMADD1(double %A, double %B, double %C) {
|
2009-06-05 06:49:04 +08:00
|
|
|
%D = fmul double %A, %B ; <double> [#uses=1]
|
Optionally enable more-aggressive FMA formation in DAGCombine
The heuristic used by DAGCombine to form FMAs checks that the FMUL has only one
use, but this is overly-conservative on some systems. Specifically, if the FMA
and the FADD have the same latency (and the FMA does not compete for resources
with the FMUL any more than the FADD does), there is no need for the
restriction, and furthermore, forming the FMA leaving the FMUL can still allow
for higher overall throughput and decreased critical-path length.
Here we add a new TLI callback, enableAggressiveFMAFusion, false by default, to
elide the hasOneUse check. This is enabled for PowerPC by default, as most
PowerPC systems will benefit.
Patch by Olivier Sallenave, thanks!
llvm-svn: 218120
2014-09-19 19:42:56 +08:00
|
|
|
%E = fadd double %C, %D ; <double> [#uses=1]
|
2005-04-09 16:29:59 +08:00
|
|
|
ret double %E
|
2013-07-14 04:38:47 +08:00
|
|
|
; CHECK-LABEL: test_FMADD1:
|
2013-04-11 20:32:23 +08:00
|
|
|
; CHECK: fmadd
|
|
|
|
; CHECK-NEXT: blr
|
2014-10-18 05:02:44 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FMADD1:
|
|
|
|
; CHECK-VSX: xsmaddmdp
|
|
|
|
; CHECK-VSX-NEXT: blr
|
2005-04-09 16:29:59 +08:00
|
|
|
}
|
2008-02-19 16:07:33 +08:00
|
|
|
|
|
|
|
define double @test_FMADD2(double %A, double %B, double %C) {
|
2009-06-05 06:49:04 +08:00
|
|
|
%D = fmul double %A, %B ; <double> [#uses=1]
|
|
|
|
%E = fadd double %D, %C ; <double> [#uses=1]
|
2005-04-09 12:01:32 +08:00
|
|
|
ret double %E
|
2013-07-14 04:38:47 +08:00
|
|
|
; CHECK-LABEL: test_FMADD2:
|
2013-04-11 20:32:23 +08:00
|
|
|
; CHECK: fmadd
|
|
|
|
; CHECK-NEXT: blr
|
2014-10-18 05:02:44 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FMADD2:
|
|
|
|
; CHECK-VSX: xsmaddmdp
|
|
|
|
; CHECK-VSX-NEXT: blr
|
2005-04-09 12:01:32 +08:00
|
|
|
}
|
2008-02-19 16:07:33 +08:00
|
|
|
|
Optionally enable more-aggressive FMA formation in DAGCombine
The heuristic used by DAGCombine to form FMAs checks that the FMUL has only one
use, but this is overly-conservative on some systems. Specifically, if the FMA
and the FADD have the same latency (and the FMA does not compete for resources
with the FMUL any more than the FADD does), there is no need for the
restriction, and furthermore, forming the FMA leaving the FMUL can still allow
for higher overall throughput and decreased critical-path length.
Here we add a new TLI callback, enableAggressiveFMAFusion, false by default, to
elide the hasOneUse check. This is enabled for PowerPC by default, as most
PowerPC systems will benefit.
Patch by Olivier Sallenave, thanks!
llvm-svn: 218120
2014-09-19 19:42:56 +08:00
|
|
|
define double @test_FMSUB1(double %A, double %B, double %C) {
|
2009-06-05 06:49:04 +08:00
|
|
|
%D = fmul double %A, %B ; <double> [#uses=1]
|
|
|
|
%E = fsub double %D, %C ; <double> [#uses=1]
|
2005-04-09 12:01:32 +08:00
|
|
|
ret double %E
|
Optionally enable more-aggressive FMA formation in DAGCombine
The heuristic used by DAGCombine to form FMAs checks that the FMUL has only one
use, but this is overly-conservative on some systems. Specifically, if the FMA
and the FADD have the same latency (and the FMA does not compete for resources
with the FMUL any more than the FADD does), there is no need for the
restriction, and furthermore, forming the FMA leaving the FMUL can still allow
for higher overall throughput and decreased critical-path length.
Here we add a new TLI callback, enableAggressiveFMAFusion, false by default, to
elide the hasOneUse check. This is enabled for PowerPC by default, as most
PowerPC systems will benefit.
Patch by Olivier Sallenave, thanks!
llvm-svn: 218120
2014-09-19 19:42:56 +08:00
|
|
|
; CHECK-LABEL: test_FMSUB1:
|
2013-04-11 20:32:23 +08:00
|
|
|
; CHECK: fmsub
|
|
|
|
; CHECK-NEXT: blr
|
2014-10-18 05:02:44 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FMSUB1:
|
|
|
|
; CHECK-VSX: xsmsubmdp
|
|
|
|
; CHECK-VSX-NEXT: blr
|
2005-04-09 12:01:32 +08:00
|
|
|
}
|
2008-02-19 16:07:33 +08:00
|
|
|
|
Optionally enable more-aggressive FMA formation in DAGCombine
The heuristic used by DAGCombine to form FMAs checks that the FMUL has only one
use, but this is overly-conservative on some systems. Specifically, if the FMA
and the FADD have the same latency (and the FMA does not compete for resources
with the FMUL any more than the FADD does), there is no need for the
restriction, and furthermore, forming the FMA leaving the FMUL can still allow
for higher overall throughput and decreased critical-path length.
Here we add a new TLI callback, enableAggressiveFMAFusion, false by default, to
elide the hasOneUse check. This is enabled for PowerPC by default, as most
PowerPC systems will benefit.
Patch by Olivier Sallenave, thanks!
llvm-svn: 218120
2014-09-19 19:42:56 +08:00
|
|
|
define double @test_FMSUB2(double %A, double %B, double %C, double %D) {
|
|
|
|
%E = fmul double %A, %B ; <double> [#uses=2]
|
|
|
|
%F = fadd double %E, %C ; <double> [#uses=1]
|
|
|
|
%G = fsub double %E, %D ; <double> [#uses=1]
|
|
|
|
%H = call double @dummy2(double %F, double %G) ; <double> [#uses=1]
|
|
|
|
ret double %H
|
|
|
|
; CHECK-LABEL: test_FMSUB2:
|
|
|
|
; CHECK: fmadd
|
|
|
|
; CHECK-NEXT: fmsub
|
2014-10-18 05:02:44 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FMSUB2:
|
|
|
|
; CHECK-VSX: xsmaddadp
|
|
|
|
; CHECK-VSX-NEXT: xsmsubmdp
|
Optionally enable more-aggressive FMA formation in DAGCombine
The heuristic used by DAGCombine to form FMAs checks that the FMUL has only one
use, but this is overly-conservative on some systems. Specifically, if the FMA
and the FADD have the same latency (and the FMA does not compete for resources
with the FMUL any more than the FADD does), there is no need for the
restriction, and furthermore, forming the FMA leaving the FMUL can still allow
for higher overall throughput and decreased critical-path length.
Here we add a new TLI callback, enableAggressiveFMAFusion, false by default, to
elide the hasOneUse check. This is enabled for PowerPC by default, as most
PowerPC systems will benefit.
Patch by Olivier Sallenave, thanks!
llvm-svn: 218120
2014-09-19 19:42:56 +08:00
|
|
|
}
|
|
|
|
|
2008-02-19 16:07:33 +08:00
|
|
|
define double @test_FNMADD1(double %A, double %B, double %C) {
|
2009-06-05 06:49:04 +08:00
|
|
|
%D = fmul double %A, %B ; <double> [#uses=1]
|
|
|
|
%E = fadd double %D, %C ; <double> [#uses=1]
|
|
|
|
%F = fsub double -0.000000e+00, %E ; <double> [#uses=1]
|
2005-04-09 12:01:32 +08:00
|
|
|
ret double %F
|
2013-07-14 04:38:47 +08:00
|
|
|
; CHECK-LABEL: test_FNMADD1:
|
2013-04-11 20:32:23 +08:00
|
|
|
; CHECK: fnmadd
|
|
|
|
; CHECK-NEXT: blr
|
2014-10-18 05:02:44 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FNMADD1:
|
|
|
|
; CHECK-VSX: xsnmaddmdp
|
|
|
|
; CHECK-VSX-NEXT: blr
|
2005-04-09 12:01:32 +08:00
|
|
|
}
|
2008-02-19 16:07:33 +08:00
|
|
|
|
|
|
|
define double @test_FNMADD2(double %A, double %B, double %C) {
|
2009-06-05 06:49:04 +08:00
|
|
|
%D = fmul double %A, %B ; <double> [#uses=1]
|
|
|
|
%E = fadd double %C, %D ; <double> [#uses=1]
|
|
|
|
%F = fsub double -0.000000e+00, %E ; <double> [#uses=1]
|
2005-04-09 12:01:32 +08:00
|
|
|
ret double %F
|
2013-07-14 04:38:47 +08:00
|
|
|
; CHECK-LABEL: test_FNMADD2:
|
2013-04-11 20:32:23 +08:00
|
|
|
; CHECK: fnmadd
|
|
|
|
; CHECK-NEXT: blr
|
2014-10-18 05:02:44 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FNMADD2:
|
|
|
|
; CHECK-VSX: xsnmaddmdp
|
|
|
|
; CHECK-VSX-NEXT: blr
|
2005-04-09 12:01:32 +08:00
|
|
|
}
|
2008-02-19 16:07:33 +08:00
|
|
|
|
|
|
|
define double @test_FNMSUB1(double %A, double %B, double %C) {
|
2009-06-05 06:49:04 +08:00
|
|
|
%D = fmul double %A, %B ; <double> [#uses=1]
|
|
|
|
%E = fsub double %C, %D ; <double> [#uses=1]
|
2005-04-09 16:29:59 +08:00
|
|
|
ret double %E
|
2013-07-14 04:38:47 +08:00
|
|
|
; CHECK-LABEL: test_FNMSUB1:
|
2020-06-04 16:30:17 +08:00
|
|
|
; CHECK: fneg
|
|
|
|
; CHECK-NEXT: fmadd
|
2013-04-11 20:32:23 +08:00
|
|
|
; CHECK-NEXT: blr
|
2014-10-18 05:02:44 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FNMSUB1:
|
2020-06-04 16:30:17 +08:00
|
|
|
; CHECK-VSX: xsnegdp
|
|
|
|
; CHECK-VSX-NEXT: xsmaddmdp
|
|
|
|
}
|
|
|
|
|
|
|
|
; need nsz flag to generate fnmsub since it may affect sign of zero
|
|
|
|
define double @test_FNMSUB1_NSZ(double %A, double %B, double %C) {
|
|
|
|
%D = fmul nsz double %A, %B ; <double> [#uses=1]
|
|
|
|
%E = fsub nsz double %C, %D ; <double> [#uses=1]
|
|
|
|
ret double %E
|
|
|
|
; CHECK-LABEL: test_FNMSUB1_NSZ:
|
|
|
|
; CHECK: fnmsub
|
|
|
|
; CHECK-NEXT: blr
|
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FNMSUB1_NSZ:
|
2014-10-18 05:02:44 +08:00
|
|
|
; CHECK-VSX: xsnmsubmdp
|
2005-04-09 16:29:59 +08:00
|
|
|
}
|
2008-02-19 16:07:33 +08:00
|
|
|
|
|
|
|
define double @test_FNMSUB2(double %A, double %B, double %C) {
|
2009-06-05 06:49:04 +08:00
|
|
|
%D = fmul double %A, %B ; <double> [#uses=1]
|
|
|
|
%E = fsub double %D, %C ; <double> [#uses=1]
|
|
|
|
%F = fsub double -0.000000e+00, %E ; <double> [#uses=1]
|
2005-04-09 12:01:32 +08:00
|
|
|
ret double %F
|
2013-07-14 04:38:47 +08:00
|
|
|
; CHECK-LABEL: test_FNMSUB2:
|
2013-04-11 20:32:23 +08:00
|
|
|
; CHECK: fnmsub
|
|
|
|
; CHECK-NEXT: blr
|
2014-10-18 05:02:44 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FNMSUB2:
|
|
|
|
; CHECK-VSX: xsnmsubmdp
|
|
|
|
; CHECK-VSX-NEXT: blr
|
2005-04-09 12:01:32 +08:00
|
|
|
}
|
2008-02-19 16:07:33 +08:00
|
|
|
|
|
|
|
define float @test_FNMSUBS(float %A, float %B, float %C) {
|
2009-06-05 06:49:04 +08:00
|
|
|
%D = fmul float %A, %B ; <float> [#uses=1]
|
|
|
|
%E = fsub float %D, %C ; <float> [#uses=1]
|
|
|
|
%F = fsub float -0.000000e+00, %E ; <float> [#uses=1]
|
2005-12-15 06:51:13 +08:00
|
|
|
ret float %F
|
2013-07-14 04:38:47 +08:00
|
|
|
; CHECK-LABEL: test_FNMSUBS:
|
2013-04-11 20:32:23 +08:00
|
|
|
; CHECK: fnmsubs
|
|
|
|
; CHECK-NEXT: blr
|
2014-10-18 05:02:44 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_FNMSUBS:
|
|
|
|
; CHECK-VSX: fnmsubs
|
|
|
|
; CHECK-VSX-NEXT: blr
|
2005-12-15 06:51:13 +08:00
|
|
|
}
|
2015-05-30 01:13:25 +08:00
|
|
|
|
|
|
|
define float @test_XSMADDMSP(float %A, float %B, float %C) {
|
|
|
|
%D = fmul float %A, %B ; <float> [#uses=1]
|
|
|
|
%E = fadd float %C, %D ; <float> [#uses=1]
|
|
|
|
ret float %E
|
|
|
|
; CHECK-P8-LABEL: test_XSMADDMSP:
|
|
|
|
; CHECK-P8: xsmaddmsp
|
|
|
|
; CHECK-P8-NEXT: blr
|
|
|
|
}
|
|
|
|
|
|
|
|
define float @test_XSMSUBMSP(float %A, float %B, float %C) {
|
|
|
|
%D = fmul float %A, %B ; <float> [#uses=1]
|
|
|
|
%E = fsub float %D, %C ; <float> [#uses=1]
|
|
|
|
ret float %E
|
|
|
|
; CHECK-P8-LABEL: test_XSMSUBMSP:
|
|
|
|
; CHECK-P8: xsmsubmsp
|
|
|
|
; CHECK-P8-NEXT: blr
|
|
|
|
}
|
|
|
|
|
|
|
|
define float @test_XSMADDASP(float %A, float %B, float %C, float %D) {
|
|
|
|
%E = fmul float %A, %B ; <float> [#uses=2]
|
|
|
|
%F = fadd float %E, %C ; <float> [#uses=1]
|
|
|
|
%G = fsub float %E, %D ; <float> [#uses=1]
|
|
|
|
%H = call float @dummy4(float %F, float %G) ; <float> [#uses=1]
|
|
|
|
ret float %H
|
|
|
|
; CHECK-P8-LABEL: test_XSMADDASP:
|
|
|
|
; CHECK-P8: xsmaddasp
|
|
|
|
; CHECK-P8-NEXT: xsmsubmsp
|
|
|
|
}
|
|
|
|
|
|
|
|
define float @test_XSMSUBASP(float %A, float %B, float %C, float %D) {
|
|
|
|
%E = fmul float %A, %B ; <float> [#uses=2]
|
|
|
|
%F = fsub float %E, %C ; <float> [#uses=1]
|
|
|
|
%G = fsub float %E, %D ; <float> [#uses=1]
|
|
|
|
%H = call float @dummy4(float %F, float %G) ; <float> [#uses=1]
|
|
|
|
ret float %H
|
|
|
|
; CHECK-P8-LABEL: test_XSMSUBASP:
|
|
|
|
; CHECK-P8: xsmsubasp
|
|
|
|
; CHECK-P8-NEXT: xsmsubmsp
|
|
|
|
}
|
|
|
|
|
|
|
|
define float @test_XSNMADDMSP(float %A, float %B, float %C) {
|
|
|
|
%D = fmul float %A, %B ; <float> [#uses=1]
|
|
|
|
%E = fadd float %D, %C ; <float> [#uses=1]
|
|
|
|
%F = fsub float -0.000000e+00, %E ; <float> [#uses=1]
|
|
|
|
ret float %F
|
|
|
|
; CHECK-P8-LABEL: test_XSNMADDMSP:
|
|
|
|
; CHECK-P8: xsnmaddmsp
|
|
|
|
; CHECK-P8-NEXT: blr
|
|
|
|
}
|
|
|
|
|
|
|
|
define float @test_XSNMSUBMSP(float %A, float %B, float %C) {
|
|
|
|
%D = fmul float %A, %B ; <float> [#uses=1]
|
|
|
|
%E = fsub float %D, %C ; <float> [#uses=1]
|
|
|
|
%F = fsub float -0.000000e+00, %E ; <float> [#uses=1]
|
|
|
|
ret float %F
|
|
|
|
; CHECK-P8-LABEL: test_XSNMSUBMSP:
|
|
|
|
; CHECK-P8: xsnmsubmsp
|
|
|
|
; CHECK-P8-NEXT: blr
|
|
|
|
}
|
|
|
|
|
|
|
|
define float @test_XSNMADDASP(float %A, float %B, float %C) {
|
|
|
|
%D = fmul float %A, %B ; <float> [#uses=1]
|
|
|
|
%E = fadd float %D, %C ; <float> [#uses=1]
|
|
|
|
%F = fsub float -0.000000e+00, %E ; <float> [#uses=1]
|
|
|
|
%H = call float @dummy4(float %E, float %F) ; <float> [#uses=1]
|
|
|
|
ret float %F
|
|
|
|
; CHECK-P8-LABEL: test_XSNMADDASP:
|
|
|
|
; CHECK-P8: xsnmaddasp
|
2020-05-12 14:29:40 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_XSNMADDASP:
|
|
|
|
; CHECK-VSX: fnmadds
|
2015-05-30 01:13:25 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define float @test_XSNMSUBASP(float %A, float %B, float %C) {
|
|
|
|
%D = fmul float %A, %B ; <float> [#uses=1]
|
|
|
|
%E = fsub float %D, %C ; <float> [#uses=1]
|
|
|
|
%F = fsub float -0.000000e+00, %E ; <float> [#uses=1]
|
|
|
|
%H = call float @dummy4(float %E, float %F) ; <float> [#uses=1]
|
|
|
|
ret float %F
|
|
|
|
; CHECK-P8-LABEL: test_XSNMSUBASP:
|
|
|
|
; CHECK-P8: xsnmsubasp
|
2020-05-12 14:29:40 +08:00
|
|
|
|
|
|
|
; CHECK-VSX-LABEL: test_XSNMSUBASP:
|
|
|
|
; CHECK-VSX: fnmsubs
|
2015-05-30 01:13:25 +08:00
|
|
|
}
|