diff options
| author | Lang Hames <lhames@gmail.com> | 2012-06-19 22:51:23 +0000 | 
|---|---|---|
| committer | Lang Hames <lhames@gmail.com> | 2012-06-19 22:51:23 +0000 | 
| commit | 39fb1d08dce7b7c78a9633ce32c5610d72d1996a (patch) | |
| tree | 5ce060817ee61c35a865fce016bc1d7fa2020fe4 /llvm/lib/Target/PowerPC | |
| parent | 63d40202fb478b331abeddcf2b12517f42db0f86 (diff) | |
| download | bcm5719-llvm-39fb1d08dce7b7c78a9633ce32c5610d72d1996a.tar.gz bcm5719-llvm-39fb1d08dce7b7c78a9633ce32c5610d72d1996a.zip | |
Add DAG-combines for aggressive FMA formation.
This patch adds DAG combines to form FMAs from pairs of FADD + FMUL or
FSUB + FMUL. The combines are performed when:
(a) Either
      AllowExcessFPPrecision option (-enable-excess-fp-precision for llc)
        OR
      UnsafeFPMath option (-enable-unsafe-fp-math)
    are set, and
(b) TargetLoweringInfo::isFMAFasterThanMulAndAdd(VT) is true for the type of
    the FADD/FSUB, and
(c) The FMUL only has one user (the FADD/FSUB).
If your target has fast FMA instructions you can make use of these combines by
overriding TargetLoweringInfo::isFMAFasterThanMulAndAdd(VT) to return true for
types supported by your FMA instruction, and adding patterns to match ISD::FMA
to your FMA instructions.
llvm-svn: 158757
Diffstat (limited to 'llvm/lib/Target/PowerPC')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCInstrInfo.td | 2 | 
1 files changed, 1 insertions, 1 deletions
| diff --git a/llvm/lib/Target/PowerPC/PPCInstrInfo.td b/llvm/lib/Target/PowerPC/PPCInstrInfo.td index c9cdd5c1920..25b6dc733ea 100644 --- a/llvm/lib/Target/PowerPC/PPCInstrInfo.td +++ b/llvm/lib/Target/PowerPC/PPCInstrInfo.td @@ -353,7 +353,7 @@ def xaddroff : ComplexPattern<iPTR, 1, "SelectAddrIdxOffs", [], []>;  //===----------------------------------------------------------------------===//  // PowerPC Instruction Predicate Definitions. -def FPContractions : Predicate<"!TM.Options.NoExcessFPPrecision">; +def FPContractions : Predicate<"TM.Options.AllowExcessFPPrecision">;  def In32BitMode  : Predicate<"!PPCSubTarget.isPPC64()">;  def In64BitMode  : Predicate<"PPCSubTarget.isPPC64()">;  def IsBookE  : Predicate<"PPCSubTarget.isBookE()">; | 

