aboutsummaryrefslogtreecommitdiff
path: root/lib/Transforms/Scalar/Reassociate.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-09-02 06:38:04 +0000
committerChris Lattner <sabre@nondot.org>2005-09-02 06:38:04 +0000
commit2cd85da3ed8e703729fb5adfe8cc2f9b1dd2f6a8 (patch)
tree0e176175a1c41d50979346daa672bb565ca8ade9 /lib/Transforms/Scalar/Reassociate.cpp
parentd6c69e9bba71d647e7bfe03de91242b57f618dde (diff)
Avoid creating garbage instructions, just move the old add instruction
to where we need it when converting -(A+B+C) -> -A + -B + -C. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23213 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Scalar/Reassociate.cpp')
-rw-r--r--lib/Transforms/Scalar/Reassociate.cpp20
1 files changed, 11 insertions, 9 deletions
diff --git a/lib/Transforms/Scalar/Reassociate.cpp b/lib/Transforms/Scalar/Reassociate.cpp
index a9b0ea6cbb..fb143c9827 100644
--- a/lib/Transforms/Scalar/Reassociate.cpp
+++ b/lib/Transforms/Scalar/Reassociate.cpp
@@ -318,16 +318,18 @@ static Value *NegateValue(Value *V, Instruction *BI) {
//
if (Instruction *I = dyn_cast<Instruction>(V))
if (I->getOpcode() == Instruction::Add && I->hasOneUse()) {
- Value *RHS = NegateValue(I->getOperand(1), BI);
- Value *LHS = NegateValue(I->getOperand(0), BI);
-
- // We must actually insert a new add instruction here, because the neg
- // instructions do not dominate the old add instruction in general. By
- // adding it now, we are assured that the neg instructions we just
- // inserted dominate the instruction we are about to insert after them.
+ // Push the negates through the add.
+ I->setOperand(0, NegateValue(I->getOperand(0), BI));
+ I->setOperand(1, NegateValue(I->getOperand(1), BI));
+
+ // We must move the add instruction here, because the neg instructions do
+ // not dominate the old add instruction in general. By moving it, we are
+ // assured that the neg instructions we just inserted dominate the
+ // instruction we are about to insert after them.
//
- return BinaryOperator::create(Instruction::Add, LHS, RHS,
- I->getName()+".neg", BI);
+ I->moveBefore(BI);
+ I->setName(I->getName()+".neg");
+ return I;
}
// Insert a 'neg' instruction that subtracts the value from zero to get the