Implement InstCombine/add.ll:test28, transforming C1-(X+C2) --> (C1-C2)-X.
authorChris Lattner <sabre@nondot.org>
Thu, 7 Apr 2005 16:28:01 +0000 (16:28 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 7 Apr 2005 16:28:01 +0000 (16:28 +0000)
This occurs several dozen times in specint2k, particularly in crafty and gcc
apparently.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21136 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Scalar/InstructionCombining.cpp

index 9e40dc3239f4ad9f23a8fc4673e78e6b0db7e4a2..c1eb3ebe45f49e54a3c66f8542bc7e18aac65294 100644 (file)
@@ -795,10 +795,16 @@ Instruction *InstCombiner::visitSub(BinaryOperator &I) {
   if (BinaryOperator *Op1I = dyn_cast<BinaryOperator>(Op1)) {
     if (Op1I->getOpcode() == Instruction::Add &&
         !Op0->getType()->isFloatingPoint()) {
-      if (Op1I->getOperand(0) == Op0)             // X-(X+Y) == -Y
+      if (Op1I->getOperand(0) == Op0)              // X-(X+Y) == -Y
         return BinaryOperator::createNeg(Op1I->getOperand(1), I.getName());
-      else if (Op1I->getOperand(1) == Op0)        // X-(Y+X) == -Y
+      else if (Op1I->getOperand(1) == Op0)         // X-(Y+X) == -Y
         return BinaryOperator::createNeg(Op1I->getOperand(0), I.getName());
+      else if (ConstantInt *CI1 = dyn_cast<ConstantInt>(I.getOperand(0))) {
+        if (ConstantInt *CI2 = dyn_cast<ConstantInt>(Op1I->getOperand(1)))
+          // C1-(X+C2) --> (C1-C2)-X
+          return BinaryOperator::createSub(ConstantExpr::getSub(CI1, CI2),
+                                           Op1I->getOperand(0));
+      }
     }
 
     if (Op1I->hasOneUse()) {