diff options
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp | 9 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp | 26 | 
2 files changed, 21 insertions, 14 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp index 7730db1dfce..6ff288c8976 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorOps.cpp @@ -141,6 +141,7 @@ class VectorLegalizer {    SDValue ExpandROT(SDValue Op);    SDValue ExpandFMINNUM_FMAXNUM(SDValue Op);    SDValue ExpandAddSubSat(SDValue Op); +  SDValue ExpandFixedPointMul(SDValue Op);    SDValue ExpandStrictFPOp(SDValue Op);    /// Implements vector promotion. @@ -782,6 +783,8 @@ SDValue VectorLegalizer::Expand(SDValue Op) {    case ISD::UADDSAT:    case ISD::SADDSAT:      return ExpandAddSubSat(Op); +  case ISD::SMULFIX: +    return ExpandFixedPointMul(Op);    case ISD::STRICT_FADD:    case ISD::STRICT_FSUB:    case ISD::STRICT_FMUL: @@ -1217,6 +1220,12 @@ SDValue VectorLegalizer::ExpandAddSubSat(SDValue Op) {    return DAG.UnrollVectorOp(Op.getNode());  } +SDValue VectorLegalizer::ExpandFixedPointMul(SDValue Op) { +  if (SDValue Expanded = TLI.expandFixedPointMul(Op.getNode(), DAG)) +    return Expanded; +  return DAG.UnrollVectorOp(Op.getNode()); +} +  SDValue VectorLegalizer::ExpandStrictFPOp(SDValue Op) {    EVT VT = Op.getValueType();    EVT EltVT = VT.getVectorElementType(); diff --git a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp index c910a845ac2..e759089aa43 100644 --- a/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/TargetLowering.cpp @@ -5362,29 +5362,25 @@ SDValue TargetLowering::expandAddSubSat(SDNode *Node, SelectionDAG &DAG) const {  SDValue  TargetLowering::expandFixedPointMul(SDNode *Node, SelectionDAG &DAG) const {    assert(Node->getOpcode() == ISD::SMULFIX && "Expected opcode to be SMULFIX."); -  assert(Node->getNumOperands() == 3 && -         "Expected signed fixed point multiplication to have 3 operands.");    SDLoc dl(Node);    SDValue LHS = Node->getOperand(0);    SDValue RHS = Node->getOperand(1); -  assert(LHS.getValueType().isScalarInteger() && -         "Expected operands to be integers. Vector of int arguments should " -         "already be unrolled."); -  assert(RHS.getValueType().isScalarInteger() && -         "Expected operands to be integers. Vector of int arguments should " -         "already be unrolled."); +  EVT VT = LHS.getValueType(); +  unsigned Scale = Node->getConstantOperandVal(2); + +  // [us]mul.fix(a, b, 0) -> mul(a, b) +  if (!Scale) { +    if (VT.isVector() && !isOperationLegalOrCustom(ISD::MUL, VT)) +      return SDValue(); +    return DAG.getNode(ISD::MUL, dl, VT, LHS, RHS); +  } +    assert(LHS.getValueType() == RHS.getValueType() &&           "Expected both operands to be the same type"); - -  unsigned Scale = Node->getConstantOperandVal(2); -  EVT VT = LHS.getValueType();    assert(Scale < VT.getScalarSizeInBits() &&           "Expected scale to be less than the number of bits."); -  if (!Scale) -    return DAG.getNode(ISD::MUL, dl, VT, LHS, RHS); -    // Get the upper and lower bits of the result.    SDValue Lo, Hi;    if (isOperationLegalOrCustom(ISD::SMUL_LOHI, VT)) { @@ -5395,6 +5391,8 @@ TargetLowering::expandFixedPointMul(SDNode *Node, SelectionDAG &DAG) const {    } else if (isOperationLegalOrCustom(ISD::MULHS, VT)) {      Lo = DAG.getNode(ISD::MUL, dl, VT, LHS, RHS);      Hi = DAG.getNode(ISD::MULHS, dl, VT, LHS, RHS); +  } else if (VT.isVector()) { +    return SDValue();    } else {      report_fatal_error("Unable to expand signed fixed point multiplication.");    } | 

