simplify (x+c)^signbit as (x+c+signbit), pointed out by PR1288. This implements
authorChris Lattner <sabre@nondot.org>
Mon, 2 Apr 2007 05:36:22 +0000 (05:36 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 2 Apr 2007 05:36:22 +0000 (05:36 +0000)
test/Transforms/InstCombine/xor.ll:test28

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

lib/Transforms/Scalar/InstructionCombining.cpp

index 87f96674285e3b20e28f79238d32f2672d00489b..3b81be3abfdba280c66653f030baa04dff9e4bfe 100644 (file)
@@ -4005,7 +4005,7 @@ Instruction *InstCombiner::visitXor(BinaryOperator &I) {
           return BinaryOperator::createOr(Op0NotVal, NotY);
         }
       }
-
+          
       if (ConstantInt *Op0CI = dyn_cast<ConstantInt>(Op0I->getOperand(1)))
         if (Op0I->getOpcode() == Instruction::Add) {
           // ~(X-c) --> (-c-1)-X
@@ -4015,6 +4015,12 @@ Instruction *InstCombiner::visitXor(BinaryOperator &I) {
                            ConstantExpr::getSub(NegOp0CI,
                                              ConstantInt::get(I.getType(), 1)),
                                           Op0I->getOperand(0));
+          } else if (RHS->getValue().isMinSignedValue()) {
+            // (X + C) ^ signbit -> (X + C + signbit)
+            Constant *C = ConstantInt::get(RHS->getValue() + Op0CI->getValue());
+            return BinaryOperator::createAdd(Op0I->getOperand(0), C);
+                                             
+                                                              
           }
         } else if (Op0I->getOpcode() == Instruction::Or) {
           // (X|C1)^C2 -> X^(C1|C2) iff X&~C1 == 0