diff options
| author | Duncan Sands <baldrick@free.fr> | 2008-07-08 20:03:24 +0000 | 
|---|---|---|
| committer | Duncan Sands <baldrick@free.fr> | 2008-07-08 20:03:24 +0000 | 
| commit | 0797e5bf059dc2030caa8dabab33e230cf9efab0 (patch) | |
| tree | 4958d7eb0efa5543109067871d77046db2c49b24 /llvm/lib/CodeGen/SelectionDAG | |
| parent | 360d689db34dd0a5372d864ec3bc9320cc4df4b5 (diff) | |
| download | bcm5719-llvm-0797e5bf059dc2030caa8dabab33e230cf9efab0.tar.gz bcm5719-llvm-0797e5bf059dc2030caa8dabab33e230cf9efab0.zip | |
Remove custom expansion from LegalizeTypes when doing
soft float: experiments show that targets aren't
expecting this for results or for operands.  Add
support select/select_cc result soft float and
correct operand soft float for these.
llvm-svn: 53245
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG')
4 files changed, 40 insertions, 42 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp index 1d46bf30334..520924d14e7 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeFloatTypes.cpp @@ -48,18 +48,6 @@ void DAGTypeLegalizer::SoftenFloatResult(SDNode *N, unsigned ResNo) {          cerr << "\n");    SDOperand R = SDOperand(); -  // See if the target wants to custom expand this node. -  if (TLI.getOperationAction(N->getOpcode(), N->getValueType(ResNo)) == -      TargetLowering::Custom) { -    // If the target wants to, allow it to lower this itself. -    if (SDNode *P = TLI.ReplaceNodeResults(N, DAG)) { -      // Everything that once used N now uses P.  We are guaranteed that the -      // result value types of N and the result value types of P match. -      ReplaceNodeWith(N, P); -      return; -    } -  } -    switch (N->getOpcode()) {    default:  #ifndef NDEBUG @@ -78,6 +66,8 @@ void DAGTypeLegalizer::SoftenFloatResult(SDNode *N, unsigned ResNo) {      case ISD::FP_EXTEND:   R = SoftenFloatRes_FP_EXTEND(N); break;      case ISD::FP_ROUND:    R = SoftenFloatRes_FP_ROUND(N); break;      case ISD::LOAD:        R = SoftenFloatRes_LOAD(N); break; +    case ISD::SELECT:      R = SoftenFloatRes_SELECT(N); break; +    case ISD::SELECT_CC:   R = SoftenFloatRes_SELECT_CC(N); break;      case ISD::SINT_TO_FP:      case ISD::UINT_TO_FP:  R = SoftenFloatRes_XINT_TO_FP(N); break; @@ -244,6 +234,19 @@ SDOperand DAGTypeLegalizer::SoftenFloatRes_LOAD(SDNode *N) {    return BitConvertToInteger(DAG.getNode(ISD::FP_EXTEND, VT, NL));  } +SDOperand DAGTypeLegalizer::SoftenFloatRes_SELECT(SDNode *N) { +  SDOperand LHS = GetSoftenedFloat(N->getOperand(1)); +  SDOperand RHS = GetSoftenedFloat(N->getOperand(2)); +  return DAG.getNode(ISD::SELECT, LHS.getValueType(), N->getOperand(0),LHS,RHS); +} + +SDOperand DAGTypeLegalizer::SoftenFloatRes_SELECT_CC(SDNode *N) { +  SDOperand LHS = GetSoftenedFloat(N->getOperand(2)); +  SDOperand RHS = GetSoftenedFloat(N->getOperand(3)); +  return DAG.getNode(ISD::SELECT_CC, LHS.getValueType(), N->getOperand(0), +                     N->getOperand(1), LHS, RHS, N->getOperand(4)); +} +  SDOperand DAGTypeLegalizer::SoftenFloatRes_XINT_TO_FP(SDNode *N) {    bool isSigned = N->getOpcode() == ISD::SINT_TO_FP;    MVT DestVT = N->getValueType(0); @@ -352,29 +355,23 @@ SDOperand DAGTypeLegalizer::SoftenFloatRes_XINT_TO_FP(SDNode *N) {  bool DAGTypeLegalizer::SoftenFloatOperand(SDNode *N, unsigned OpNo) {    DEBUG(cerr << "Soften float operand " << OpNo << ": "; N->dump(&DAG);          cerr << "\n"); -  SDOperand Res(0, 0); +  SDOperand Res = SDOperand(); -  if (TLI.getOperationAction(N->getOpcode(), N->getOperand(OpNo).getValueType()) -      == TargetLowering::Custom) -    Res = TLI.LowerOperation(SDOperand(N, OpNo), DAG); - -  if (Res.Val == 0) { -    switch (N->getOpcode()) { -    default: +  switch (N->getOpcode()) { +  default:  #ifndef NDEBUG -      cerr << "SoftenFloatOperand Op #" << OpNo << ": "; -      N->dump(&DAG); cerr << "\n"; +    cerr << "SoftenFloatOperand Op #" << OpNo << ": "; +    N->dump(&DAG); cerr << "\n";  #endif -      assert(0 && "Do not know how to soften this operator's operand!"); -      abort(); +    assert(0 && "Do not know how to soften this operator's operand!"); +    abort(); -    case ISD::BIT_CONVERT: Res = SoftenFloatOp_BIT_CONVERT(N); break; +  case ISD::BIT_CONVERT: Res = SoftenFloatOp_BIT_CONVERT(N); break; -    case ISD::BR_CC:     Res = SoftenFloatOp_BR_CC(N); break; -    case ISD::SELECT_CC: Res = SoftenFloatOp_SELECT_CC(N); break; -    case ISD::SETCC:     Res = SoftenFloatOp_SETCC(N); break; -    case ISD::STORE:     Res = SoftenFloatOp_STORE(N, OpNo); break; -    } +  case ISD::BR_CC:     Res = SoftenFloatOp_BR_CC(N); break; +  case ISD::SELECT_CC: Res = SoftenFloatOp_SELECT_CC(N); break; +  case ISD::SETCC:     Res = SoftenFloatOp_SETCC(N); break; +  case ISD::STORE:     Res = SoftenFloatOp_STORE(N, OpNo); break;    }    // If the result is null, the sub-method took care of registering results etc. @@ -403,8 +400,7 @@ void DAGTypeLegalizer::SoftenSetCCOperands(SDOperand &NewLHS, SDOperand &NewRHS,                                             ISD::CondCode &CCCode) {    SDOperand LHSInt = GetSoftenedFloat(NewLHS);    SDOperand RHSInt = GetSoftenedFloat(NewRHS); -  MVT VT  = NewLHS.getValueType(); -  MVT NVT = LHSInt.getValueType(); +  MVT VT = NewLHS.getValueType();    assert((VT == MVT::f32 || VT == MVT::f64) && "Unsupported setcc type!"); @@ -468,13 +464,13 @@ void DAGTypeLegalizer::SoftenSetCCOperands(SDOperand &NewLHS, SDOperand &NewRHS,    }    SDOperand Ops[2] = { LHSInt, RHSInt }; -  NewLHS = MakeLibCall(LC1, NVT, Ops, 2, false/*sign irrelevant*/); -  NewRHS = DAG.getConstant(0, NVT); +  NewLHS = MakeLibCall(LC1, MVT::i32, Ops, 2, false/*sign irrelevant*/); +  NewRHS = DAG.getConstant(0, MVT::i32); +  CCCode = TLI.getCmpLibcallCC(LC1);    if (LC2 != RTLIB::UNKNOWN_LIBCALL) {      SDOperand Tmp = DAG.getNode(ISD::SETCC, TLI.getSetCCResultType(NewLHS), -                                NewLHS, NewRHS, -                                DAG.getCondCode(TLI.getCmpLibcallCC(LC1))); -    NewLHS = MakeLibCall(LC2, NVT, Ops, 2, false/*sign irrelevant*/); +                                NewLHS, NewRHS, DAG.getCondCode(CCCode)); +    NewLHS = MakeLibCall(LC2, MVT::i32, Ops, 2, false/*sign irrelevant*/);      NewLHS = DAG.getNode(ISD::SETCC, TLI.getSetCCResultType(NewLHS), NewLHS,                           NewRHS, DAG.getCondCode(TLI.getCmpLibcallCC(LC2)));      NewLHS = DAG.getNode(ISD::OR, Tmp.getValueType(), Tmp, NewLHS); @@ -794,7 +790,7 @@ void DAGTypeLegalizer::ExpandFloatRes_XINT_TO_FP(SDNode *N, SDOperand &Lo,  /// need promotion or expansion as well as the specified one.  bool DAGTypeLegalizer::ExpandFloatOperand(SDNode *N, unsigned OpNo) {    DEBUG(cerr << "Expand float operand: "; N->dump(&DAG); cerr << "\n"); -  SDOperand Res(0, 0); +  SDOperand Res = SDOperand();    if (TLI.getOperationAction(N->getOpcode(), N->getOperand(OpNo).getValueType())        == TargetLowering::Custom) diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp index d877b0a093c..19874e30a95 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeIntegerTypes.cpp @@ -465,7 +465,7 @@ SDOperand DAGTypeLegalizer::PromoteIntRes_VAARG(SDNode *N) {  /// node may need promotion or expansion as well as the specified one.  bool DAGTypeLegalizer::PromoteIntegerOperand(SDNode *N, unsigned OpNo) {    DEBUG(cerr << "Promote integer operand: "; N->dump(&DAG); cerr << "\n"); -  SDOperand Res(0, 0); +  SDOperand Res = SDOperand();    if (TLI.getOperationAction(N->getOpcode(), N->getOperand(OpNo).getValueType())        == TargetLowering::Custom) @@ -1641,7 +1641,7 @@ ExpandShiftWithKnownAmountBit(SDNode *N, SDOperand &Lo, SDOperand &Hi) {  /// node may need promotion or expansion as well as the specified one.  bool DAGTypeLegalizer::ExpandIntegerOperand(SDNode *N, unsigned OpNo) {    DEBUG(cerr << "Expand integer operand: "; N->dump(&DAG); cerr << "\n"); -  SDOperand Res(0, 0); +  SDOperand Res = SDOperand();    if (TLI.getOperationAction(N->getOpcode(), N->getOperand(OpNo).getValueType())        == TargetLowering::Custom) diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.h b/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.h index 22c4f63e3a8..eb65e8d7858 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.h +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.h @@ -338,6 +338,8 @@ private:    SDOperand SoftenFloatRes_FP_ROUND(SDNode *N);    SDOperand SoftenFloatRes_FSUB(SDNode *N);    SDOperand SoftenFloatRes_LOAD(SDNode *N); +  SDOperand SoftenFloatRes_SELECT(SDNode *N); +  SDOperand SoftenFloatRes_SELECT_CC(SDNode *N);    SDOperand SoftenFloatRes_XINT_TO_FP(SDNode *N);    // Operand Float to Integer Conversion. diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp index 44ee8ad706d..fadb938984a 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp @@ -150,7 +150,7 @@ SDOperand DAGTypeLegalizer::ScalarizeVecRes_SELECT(SDNode *N) {  bool DAGTypeLegalizer::ScalarizeOperand(SDNode *N, unsigned OpNo) {    DEBUG(cerr << "Scalarize node operand " << OpNo << ": "; N->dump(&DAG);          cerr << "\n"); -  SDOperand Res(0, 0); +  SDOperand Res = SDOperand();    if (Res.Val == 0) {      switch (N->getOpcode()) { @@ -535,7 +535,7 @@ void DAGTypeLegalizer::SplitVecRes_FPOWI(SDNode *N, SDOperand &Lo,  /// node may need legalization as well as the specified one.  bool DAGTypeLegalizer::SplitOperand(SDNode *N, unsigned OpNo) {    DEBUG(cerr << "Split node operand: "; N->dump(&DAG); cerr << "\n"); -  SDOperand Res(0, 0); +  SDOperand Res = SDOperand();    if (Res.Val == 0) {      switch (N->getOpcode()) { | 

