diff options
| author | Bob Wilson <bob.wilson@apple.com> | 2009-08-03 20:36:38 +0000 | 
|---|---|---|
| committer | Bob Wilson <bob.wilson@apple.com> | 2009-08-03 20:36:38 +0000 | 
| commit | f307e0bd6d1d620c2b2b56cebd731f02e582c67c (patch) | |
| tree | 2f147ef6808068e9d631634a79a1c6e4aac48a5a /llvm/lib/Target/ARM | |
| parent | 18c062361d6322e2fcfb2c234c527083264b8c5f (diff) | |
| download | bcm5719-llvm-f307e0bd6d1d620c2b2b56cebd731f02e582c67c.tar.gz bcm5719-llvm-f307e0bd6d1d620c2b2b56cebd731f02e582c67c.zip | |
Lower CONCAT_VECTOR during legalization instead of matching it during isel.
Add a testcase.
llvm-svn: 77992
Diffstat (limited to 'llvm/lib/Target/ARM')
| -rw-r--r-- | llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp | 21 | ||||
| -rw-r--r-- | llvm/lib/Target/ARM/ARMISelLowering.cpp | 24 | 
2 files changed, 19 insertions, 26 deletions
| diff --git a/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp b/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp index bcef059fa3c..8ef541f621d 100644 --- a/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp +++ b/llvm/lib/Target/ARM/ARMISelDAGToDAG.cpp @@ -1267,27 +1267,6 @@ SDNode *ARMDAGToDAGISel::Select(SDValue Op) {                                   MVT::Other, Ops, 3);    } -  case ISD::CONCAT_VECTORS: { -    MVT VT = Op.getValueType(); -    assert(VT.is128BitVector() && Op.getNumOperands() == 2 && -           "unexpected CONCAT_VECTORS"); -    SDValue N0 = Op.getOperand(0); -    SDValue N1 = Op.getOperand(1); -    SDNode *Result = -      CurDAG->getTargetNode(TargetInstrInfo::IMPLICIT_DEF, dl, VT); -    if (N0.getOpcode() != ISD::UNDEF) -      Result = CurDAG->getTargetNode(TargetInstrInfo::INSERT_SUBREG, dl, VT, -                                     SDValue(Result, 0), N0, -                                     CurDAG->getTargetConstant(arm_dsubreg_0, -                                                               MVT::i32)); -    if (N1.getOpcode() != ISD::UNDEF) -      Result = CurDAG->getTargetNode(TargetInstrInfo::INSERT_SUBREG, dl, VT, -                                     SDValue(Result, 0), N1, -                                     CurDAG->getTargetConstant(arm_dsubreg_1, -                                                               MVT::i32)); -    return Result; -  } -    case ISD::VECTOR_SHUFFLE: {      MVT VT = Op.getValueType(); diff --git a/llvm/lib/Target/ARM/ARMISelLowering.cpp b/llvm/lib/Target/ARM/ARMISelLowering.cpp index f0cf9434889..f819af5c0fc 100644 --- a/llvm/lib/Target/ARM/ARMISelLowering.cpp +++ b/llvm/lib/Target/ARM/ARMISelLowering.cpp @@ -2312,10 +2312,24 @@ static SDValue LowerEXTRACT_VECTOR_ELT(SDValue Op, SelectionDAG &DAG) {    return DAG.getNode(ISD::TRUNCATE, dl, VT, Op);  } -static SDValue LowerCONCAT_VECTORS(SDValue Op) { -  if (Op.getValueType().is128BitVector() && Op.getNumOperands() == 2) -    return Op; -  return SDValue(); +static SDValue LowerCONCAT_VECTORS(SDValue Op, SelectionDAG &DAG) { +  // The only time a CONCAT_VECTORS operation can have legal types is when +  // two 64-bit vectors are concatenated to a 128-bit vector. +  assert(Op.getValueType().is128BitVector() && Op.getNumOperands() == 2 && +         "unexpected CONCAT_VECTORS"); +  DebugLoc dl = Op.getDebugLoc(); +  SDValue Val = DAG.getUNDEF(MVT::v2f64); +  SDValue Op0 = Op.getOperand(0); +  SDValue Op1 = Op.getOperand(1); +  if (Op0.getOpcode() != ISD::UNDEF) +    Val = DAG.getNode(ISD::INSERT_VECTOR_ELT, dl, MVT::v2f64, Val, +                      DAG.getNode(ISD::BIT_CONVERT, dl, MVT::f64, Op0), +                      DAG.getIntPtrConstant(0)); +  if (Op1.getOpcode() != ISD::UNDEF) +    Val = DAG.getNode(ISD::INSERT_VECTOR_ELT, dl, MVT::v2f64, Val, +                      DAG.getNode(ISD::BIT_CONVERT, dl, MVT::f64, Op1), +                      DAG.getIntPtrConstant(1)); +  return DAG.getNode(ISD::BIT_CONVERT, dl, Op.getValueType(), Val);  }  SDValue ARMTargetLowering::LowerOperation(SDValue Op, SelectionDAG &DAG) { @@ -2351,7 +2365,7 @@ SDValue ARMTargetLowering::LowerOperation(SDValue Op, SelectionDAG &DAG) {    case ISD::VECTOR_SHUFFLE: return LowerVECTOR_SHUFFLE(Op, DAG);    case ISD::SCALAR_TO_VECTOR: return LowerSCALAR_TO_VECTOR(Op, DAG);    case ISD::EXTRACT_VECTOR_ELT: return LowerEXTRACT_VECTOR_ELT(Op, DAG); -  case ISD::CONCAT_VECTORS: return LowerCONCAT_VECTORS(Op); +  case ISD::CONCAT_VECTORS: return LowerCONCAT_VECTORS(Op, DAG);    }    return SDValue();  } | 

