diff options
| author | Craig Topper <craig.topper@gmail.com> | 2012-04-09 05:16:56 +0000 | 
|---|---|---|
| committer | Craig Topper <craig.topper@gmail.com> | 2012-04-09 05:16:56 +0000 | 
| commit | 5894fe430aa6195ea6e26b57ab817588349efcd0 (patch) | |
| tree | 257e565bd048a56236e3fd14e7d85a26ac1260f5 /llvm/lib | |
| parent | 3779ac10b4651afadedc89b0acc667c0ce7d06e8 (diff) | |
| download | bcm5719-llvm-5894fe430aa6195ea6e26b57ab817588349efcd0.tar.gz bcm5719-llvm-5894fe430aa6195ea6e26b57ab817588349efcd0.zip | |
Replace some explicit checks with asserts for conditions that should never happen.
llvm-svn: 154305
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp | 21 | 
1 files changed, 7 insertions, 14 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp index a8822953caf..036f0392a03 100644 --- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp @@ -7698,8 +7698,7 @@ SDValue DAGCombiner::visitVECTOR_SHUFFLE(SDNode *N) {    SDValue N0 = N->getOperand(0);    SDValue N1 = N->getOperand(1); -  assert(N0.getValueType().getVectorNumElements() == NumElts && -        "Vector shuffle must be normalized in DAG"); +  assert(N0.getValueType() == VT && "Vector shuffle must be normalized in DAG");    // Canonicalize shuffle undef, undef -> undef    if (N0.getOpcode() == ISD::UNDEF && N1.getOpcode() == ISD::UNDEF) @@ -7804,27 +7803,21 @@ SDValue DAGCombiner::visitVECTOR_SHUFFLE(SDNode *N) {      if (N0.getOperand(1).getOpcode() != ISD::UNDEF)        return SDValue(); -    // The incoming shuffle must be of the same type as the result of the current -    // shuffle. -    if (OtherSV->getOperand(0).getValueType() != VT) -      return SDValue(); - -    EVT InVT = N0.getValueType(); -    int InNumElts = InVT.getVectorNumElements(); +    // The incoming shuffle must be of the same type as the result of the +    // current shuffle. +    assert(OtherSV->getOperand(0).getValueType() == VT && +           "Shuffle types don't match");      for (unsigned i = 0; i != NumElts; ++i) {        int Idx = SVN->getMaskElt(i); -      // If we access the second (undef) operand then this index can be -      // canonicalized to undef as well. -      if (Idx >= InNumElts) -        Idx = -1; +      assert(Idx < (int)NumElts && "Index references undef operand");        // Next, this index comes from the first value, which is the incoming        // shuffle. Adopt the incoming index.        if (Idx >= 0)          Idx = OtherSV->getMaskElt(Idx);        // The combined shuffle must map each index to itself. -      if ((unsigned)Idx != i && Idx != -1) +      if (Idx >= 0 && (unsigned)Idx != i)          return SDValue();      } | 

