diff options
| author | Sanjay Patel <spatel@rotateright.com> | 2018-10-15 15:56:39 +0000 | 
|---|---|---|
| committer | Sanjay Patel <spatel@rotateright.com> | 2018-10-15 15:56:39 +0000 | 
| commit | 9e7e0fd828fd977c20d41e611d614bdff1a8748a (patch) | |
| tree | 2e201f003b431ad1898d293d86a9d040b44245ae /llvm/lib | |
| parent | 475a53649e9bd1027721cb05a8eed31f71df78db (diff) | |
| download | bcm5719-llvm-9e7e0fd828fd977c20d41e611d614bdff1a8748a.tar.gz bcm5719-llvm-9e7e0fd828fd977c20d41e611d614bdff1a8748a.zip | |
[DAGCombiner] allow undef elts in vector fma matching
llvm-svn: 344528
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp | 43 | 
1 files changed, 22 insertions, 21 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp index f2779a3475e..846830b3b28 100644 --- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp @@ -10815,29 +10815,30 @@ SDValue DAGCombiner::visitFMULForFMADistributiveCombine(SDNode *N) {    if (SDValue FMA = FuseFADD(N1, N0, Flags))      return FMA; -  // fold (fmul (fsub +1.0, x), y) -> (fma (fneg x), y, y) -  // fold (fmul (fsub -1.0, x), y) -> (fma (fneg x), y, (fneg y)) -  // fold (fmul (fsub x, +1.0), y) -> (fma x, y, (fneg y)) -  // fold (fmul (fsub x, -1.0), y) -> (fma x, y, y) +  // fold (fmul (fsub +1.0, x1), y) -> (fma (fneg x1), y, y) +  // fold (fmul (fsub -1.0, x1), y) -> (fma (fneg x1), y, (fneg y)) +  // fold (fmul (fsub x0, +1.0), y) -> (fma x0, y, (fneg y)) +  // fold (fmul (fsub x0, -1.0), y) -> (fma x0, y, y)    auto FuseFSUB = [&](SDValue X, SDValue Y, const SDNodeFlags Flags) {      if (X.getOpcode() == ISD::FSUB && (Aggressive || X->hasOneUse())) { -      auto XC0 = isConstOrConstSplatFP(X.getOperand(0)); -      if (XC0 && XC0->isExactlyValue(+1.0)) -        return DAG.getNode(PreferredFusedOpcode, SL, VT, -                           DAG.getNode(ISD::FNEG, SL, VT, X.getOperand(1)), Y, -                           Y, Flags); -      if (XC0 && XC0->isExactlyValue(-1.0)) -        return DAG.getNode(PreferredFusedOpcode, SL, VT, -                           DAG.getNode(ISD::FNEG, SL, VT, X.getOperand(1)), Y, -                           DAG.getNode(ISD::FNEG, SL, VT, Y), Flags); - -      auto XC1 = isConstOrConstSplatFP(X.getOperand(1)); -      if (XC1 && XC1->isExactlyValue(+1.0)) -        return DAG.getNode(PreferredFusedOpcode, SL, VT, X.getOperand(0), Y, -                           DAG.getNode(ISD::FNEG, SL, VT, Y), Flags); -      if (XC1 && XC1->isExactlyValue(-1.0)) -        return DAG.getNode(PreferredFusedOpcode, SL, VT, X.getOperand(0), Y, -                           Y, Flags); +      if (auto *C0 = isConstOrConstSplatFP(X.getOperand(0), true)) { +        if (C0->isExactlyValue(+1.0)) +          return DAG.getNode(PreferredFusedOpcode, SL, VT, +                             DAG.getNode(ISD::FNEG, SL, VT, X.getOperand(1)), Y, +                             Y, Flags); +        if (C0->isExactlyValue(-1.0)) +          return DAG.getNode(PreferredFusedOpcode, SL, VT, +                             DAG.getNode(ISD::FNEG, SL, VT, X.getOperand(1)), Y, +                             DAG.getNode(ISD::FNEG, SL, VT, Y), Flags); +      } +      if (auto *C1 = isConstOrConstSplatFP(X.getOperand(1), true)) { +        if (C1->isExactlyValue(+1.0)) +          return DAG.getNode(PreferredFusedOpcode, SL, VT, X.getOperand(0), Y, +                             DAG.getNode(ISD::FNEG, SL, VT, Y), Flags); +        if (C1->isExactlyValue(-1.0)) +          return DAG.getNode(PreferredFusedOpcode, SL, VT, X.getOperand(0), Y, +                             Y, Flags); +      }      }      return SDValue();    }; | 

