summaryrefslogtreecommitdiff
path: root/lib/Transforms
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-04-07 16:28:01 +0000
committerChris Lattner <sabre@nondot.org>2005-04-07 16:28:01 +0000
commit08954a26e4b1f54a9552b34f81cf6e570fefa67d (patch)
tree8b292c67b2af2ae1e589f936658a215dab5bd07b /lib/Transforms
parent3d173b3638ddf269391b32366b54b413f96e3b78 (diff)
downloadllvm-08954a26e4b1f54a9552b34f81cf6e570fefa67d.tar.gz
llvm-08954a26e4b1f54a9552b34f81cf6e570fefa67d.tar.bz2
llvm-08954a26e4b1f54a9552b34f81cf6e570fefa67d.tar.xz
Implement InstCombine/add.ll:test28, transforming C1-(X+C2) --> (C1-C2)-X.
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
Diffstat (limited to 'lib/Transforms')
-rw-r--r--lib/Transforms/Scalar/InstructionCombining.cpp10
1 files changed, 8 insertions, 2 deletions
diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp
index 9e40dc3239..c1eb3ebe45 100644
--- a/lib/Transforms/Scalar/InstructionCombining.cpp
+++ b/lib/Transforms/Scalar/InstructionCombining.cpp
@@ -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()) {