[InstCombine] remove redundant fold for insertelement; NFC
authorSanjay Patel <spatel@rotateright.com>
Thu, 23 May 2019 23:33:34 +0000 (23:33 +0000)
committerSanjay Patel <spatel@rotateright.com>
Thu, 23 May 2019 23:33:34 +0000 (23:33 +0000)
The out-of-bounds index pattern is handled by InstSimplify.

llvm-svn: 361569

llvm/lib/Transforms/InstCombine/InstCombineVectorOps.cpp

index 44130d3..063175b 100644 (file)
@@ -884,14 +884,10 @@ Instruction *InstCombiner::visitInsertElementInst(InsertElementInst &IE) {
   if (match(IdxOp, m_ConstantInt(InsertedIdx)) &&
       match(ScalarOp, m_ExtractElement(m_Value(ExtVecOp),
                                        m_ConstantInt(ExtractedIdx)))) {
-    unsigned NumInsertVectorElts = IE.getType()->getNumElements();
     unsigned NumExtractVectorElts = ExtVecOp->getType()->getVectorNumElements();
     if (ExtractedIdx >= NumExtractVectorElts) // Out of range extract.
       return replaceInstUsesWith(IE, VecOp);
 
-    if (InsertedIdx >= NumInsertVectorElts)  // Out of range insert.
-      return replaceInstUsesWith(IE, UndefValue::get(IE.getType()));
-
     // If we are extracting a value from a vector, then inserting it right
     // back into the same place, just use the input vector.
     if (ExtVecOp == VecOp && ExtractedIdx == InsertedIdx)