remove some dead code
authorChris Lattner <sabre@nondot.org>
Sat, 3 Feb 2007 23:28:07 +0000 (23:28 +0000)
committerChris Lattner <sabre@nondot.org>
Sat, 3 Feb 2007 23:28:07 +0000 (23:28 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33845 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Scalar/InstructionCombining.cpp

index 8f3675299c750b44fde294ee76cc8d4497386c46..49a17750478f2bc841522e359945d1714bda8f1a 100644 (file)
@@ -5624,25 +5624,14 @@ Instruction *InstCombiner::FoldShiftByConstant(Value *Op0, ConstantInt *Op1,
     unsigned ShiftAmt2 = (unsigned)Op1->getZExtValue();
     
     // Check for (A << c1) << c2   and   (A >> c1) >> c2.
-    if (isLeftShift == isShiftOfLeftShift) {
-      // Do not fold these shifts if the first one is signed and the second one
-      // is unsigned and this is a right shift.  Further, don't do any folding
-      // on them.
-      if (isShiftOfSignedShift && isUnsignedShift && !isLeftShift)
-        return 0;
-      
+    if (I.getOpcode() == ShiftOp->getOpcode()) {
       unsigned Amt = ShiftAmt1+ShiftAmt2;   // Fold into one big shift.
       if (Amt > Op0->getType()->getPrimitiveSizeInBits())
         Amt = Op0->getType()->getPrimitiveSizeInBits();
       
       Value *Op = ShiftOp->getOperand(0);
-      BinaryOperator *ShiftResult = 
-        BinaryOperator::create(I.getOpcode(), Op, 
-                               ConstantInt::get(Op->getType(), Amt));
-      if (I.getType() == ShiftResult->getType())
-        return ShiftResult;
-      InsertNewInstBefore(ShiftResult, I);
-      return CastInst::create(Instruction::BitCast, ShiftResult, I.getType());
+      return BinaryOperator::create(I.getOpcode(), Op, 
+                                    ConstantInt::get(Op->getType(), Amt));
     }
     
     // Check for (A << c1) >> c2 or (A >> c1) << c2.  If we are dealing with