diff options
| author | Craig Topper <craig.topper@gmail.com> | 2012-04-09 07:19:09 +0000 | 
|---|---|---|
| committer | Craig Topper <craig.topper@gmail.com> | 2012-04-09 07:19:09 +0000 | 
| commit | 9c3da316ec6483f5358eeae8683f14b467a3acd1 (patch) | |
| tree | fcd6c31516a096089671d439bc7171694b6e172c /llvm/lib | |
| parent | e5893f64e8e3819804731f92b467349f4813932c (diff) | |
| download | bcm5719-llvm-9c3da316ec6483f5358eeae8683f14b467a3acd1.tar.gz bcm5719-llvm-9c3da316ec6483f5358eeae8683f14b467a3acd1.zip | |
Remove unnecessary type check when combining and/or/xor of swizzles. Move some checks to allow better early out.
llvm-svn: 154309
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp | 25 | 
1 files changed, 12 insertions, 13 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp index 3a06868de53..1d135ef7bdd 100644 --- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp @@ -2361,18 +2361,16 @@ SDValue DAGCombiner::SimplifyBinOpWithSameOpcodeHands(SDNode *N) {    // The type-legalizer generates this pattern when loading illegal    // vector types from memory. In many cases this allows additional shuffle    // optimizations. -  if (N0.getOpcode() == ISD::VECTOR_SHUFFLE && Level < AfterLegalizeDAG) { +  if (N0.getOpcode() == ISD::VECTOR_SHUFFLE && Level < AfterLegalizeDAG && +      N0.getOperand(1).getOpcode() == ISD::UNDEF && +      N1.getOperand(1).getOpcode() == ISD::UNDEF) {      ShuffleVectorSDNode *SVN0 = cast<ShuffleVectorSDNode>(N0);      ShuffleVectorSDNode *SVN1 = cast<ShuffleVectorSDNode>(N1); -    SDValue In0 = SVN0->getOperand(0); -    SDValue In1 = SVN1->getOperand(0); -    EVT In0Ty = In0.getValueType(); -    EVT In1Ty = In1.getValueType(); + +    assert(N0.getOperand(0).getValueType() == N1.getOperand(1).getValueType() && +           "Inputs to shuffles are not the same type");      unsigned NumElts = VT.getVectorNumElements(); -    // Check that both shuffles are swizzles. -    bool SingleVecShuff = (N0.getOperand(1).getOpcode() == ISD::UNDEF && -                           N1.getOperand(1).getOpcode() == ISD::UNDEF);      // Check that both shuffles use the same mask. The masks are known to be of      // the same length because the result vector type is the same. @@ -2386,14 +2384,15 @@ SDValue DAGCombiner::SimplifyBinOpWithSameOpcodeHands(SDNode *N) {        }      } -    if (SameMask && SingleVecShuff && In0Ty == In1Ty) { -      SDValue Op = DAG.getNode(N->getOpcode(), N->getDebugLoc(), VT, In0, In1); -      SDValue Shuff = DAG.getVectorShuffle(VT, N->getDebugLoc(), Op, -                                          DAG.getUNDEF(VT), &SVN0->getMask()[0]); +    if (SameMask) { +      SDValue Op = DAG.getNode(N->getOpcode(), N->getDebugLoc(), VT, +                               N0.getOperand(0), N1.getOperand(0));        AddToWorkList(Op.getNode()); -      return Shuff; +      return DAG.getVectorShuffle(VT, N->getDebugLoc(), Op, +                                  DAG.getUNDEF(VT), &SVN0->getMask()[0]);      }    } +    return SDValue();  } | 

