Add DAG-combines for aggressive FMA formation.
authorLang Hames <lhames@gmail.com>
Tue, 19 Jun 2012 22:51:23 +0000 (22:51 +0000)
committerLang Hames <lhames@gmail.com>
Tue, 19 Jun 2012 22:51:23 +0000 (22:51 +0000)
commitd693cafcfb9e67ba7040cb810e4409a166421482
tree86a20682e48b7aaf402fc95f6497eae48e8fa89a
parentfa8becb6f9e8aa2cbe3bab79e1fc4cdf2ffbb8e5
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.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@158757 91177308-0d34-0410-b5e6-96231b3b80d8
include/llvm/Target/TargetOptions.h
lib/CodeGen/SelectionDAG/DAGCombiner.cpp
lib/Target/ARM/ARMInstrInfo.td
lib/Target/PowerPC/PPCInstrInfo.td
test/CodeGen/ARM/fusedMAC.ll
test/CodeGen/PowerPC/a2-fp-basic.ll
test/CodeGen/PowerPC/fma.ll
test/CodeGen/PowerPC/ppc440-fp-basic.ll
tools/llc/llc.cpp