diff options
| author | Mon P Wang <wangmp@apple.com> | 2009-01-15 22:43:38 +0000 | 
|---|---|---|
| committer | Mon P Wang <wangmp@apple.com> | 2009-01-15 22:43:38 +0000 | 
| commit | e248edff1befc92c46912ec04c1b459a8cd5ad63 (patch) | |
| tree | d579484432c65c18613207ffa1732990adad63d4 /llvm/lib/CodeGen | |
| parent | 7e105f0b12988cbdcb7d48db193d0efd67051ff7 (diff) | |
| download | bcm5719-llvm-e248edff1befc92c46912ec04c1b459a8cd5ad63.tar.gz bcm5719-llvm-e248edff1befc92c46912ec04c1b459a8cd5ad63.zip | |
Added missing support to widen an operand from a bit convert.
llvm-svn: 62285
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.h | 1 | ||||
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp | 31 | 
2 files changed, 32 insertions, 0 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.h b/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.h index c6fbf70a342..949ee349ce2 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.h +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeTypes.h @@ -606,6 +606,7 @@ private:    // Widen Vector Operand.    bool WidenVectorOperand(SDNode *N, unsigned ResNo); +  SDValue WidenVecOp_BIT_CONVERT(SDNode *N);    SDValue WidenVecOp_CONCAT_VECTORS(SDNode *N);    SDValue WidenVecOp_EXTRACT_VECTOR_ELT(SDNode *N);    SDValue WidenVecOp_STORE(SDNode* N); diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp index 0c2639a467e..3823f65263a 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeVectorTypes.cpp @@ -1735,6 +1735,7 @@ bool DAGTypeLegalizer::WidenVectorOperand(SDNode *N, unsigned ResNo) {      assert(0 && "Do not know how to widen this operator's operand!");      abort(); +  case ISD::BIT_CONVERT:        Res = WidenVecOp_BIT_CONVERT(N); break;    case ISD::CONCAT_VECTORS:     Res = WidenVecOp_CONCAT_VECTORS(N); break;    case ISD::EXTRACT_VECTOR_ELT: Res = WidenVecOp_EXTRACT_VECTOR_ELT(N); break;    case ISD::STORE:              Res = WidenVecOp_STORE(N); break; @@ -1786,6 +1787,36 @@ SDValue DAGTypeLegalizer::WidenVecOp_Convert(SDNode *N) {    return DAG.getNode(ISD::BUILD_VECTOR, VT, &Ops[0], NumElts);  } +SDValue DAGTypeLegalizer::WidenVecOp_BIT_CONVERT(SDNode *N) { +  MVT VT = N->getValueType(0); +  SDValue InOp = GetWidenedVector(N->getOperand(0)); +  MVT InWidenVT = InOp.getValueType(); + +  // Check if we can convert between two legal vector types and extract. +  unsigned InWidenSize = InWidenVT.getSizeInBits(); +  unsigned Size = VT.getSizeInBits(); +  if (InWidenSize % Size == 0 && !VT.isVector()) { +    unsigned NewNumElts = InWidenSize / Size; +    MVT NewVT = MVT::getVectorVT(VT, NewNumElts); +    if (TLI.isTypeLegal(NewVT)) { +      SDValue BitOp = DAG.getNode(ISD::BIT_CONVERT, NewVT, InOp); +      return DAG.getNode(ISD::EXTRACT_VECTOR_ELT, VT, BitOp, +                         DAG.getIntPtrConstant(0)); +    } +  } + +  // Lower the bit-convert to a store/load from the stack. Create the stack +  // frame object.  Make sure it is aligned for both the source and destination +  // types. +  SDValue FIPtr = DAG.CreateStackTemporary(InWidenVT, VT); + +  // Emit a store to the stack slot. +  SDValue Store = DAG.getStore(DAG.getEntryNode(), InOp, FIPtr, NULL, 0); + +  // Result is a load from the stack slot. +  return DAG.getLoad(VT, Store, FIPtr, NULL, 0); +} +  SDValue DAGTypeLegalizer::WidenVecOp_CONCAT_VECTORS(SDNode *N) {    // If the input vector is not legal, it is likely that we will not find a    // legal vector of the same size. Replace the concatenate vector with a | 

