From: Chris Lattner Date: Tue, 12 Aug 2003 21:45:24 +0000 (+0000) Subject: Fix bug: Reassociate/2003-08-12-InfiniteLoop.ll X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=e9608e37fcf78a3a63e2d8ec900520651486ff1d;p=oota-llvm.git Fix bug: Reassociate/2003-08-12-InfiniteLoop.ll git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7792 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/Reassociate.cpp b/lib/Transforms/Scalar/Reassociate.cpp index fe032116c55..580b4efac74 100644 --- a/lib/Transforms/Scalar/Reassociate.cpp +++ b/lib/Transforms/Scalar/Reassociate.cpp @@ -126,12 +126,13 @@ bool Reassociate::ReassociateExpr(BinaryOperator *I) { if (LHSI->getOpcode() == I->getOpcode() && LHSI->use_size() == 1) { // If the rank of our current RHS is less than the rank of the LHS's LHS, // then we reassociate the two instructions... - if (RHSRank < getRank(LHSI->getOperand(0))) { - unsigned TakeOp = 0; - if (BinaryOperator *IOp = dyn_cast(LHSI->getOperand(0))) - if (IOp->getOpcode() == LHSI->getOpcode()) - TakeOp = 1; // Hoist out non-tree portion + unsigned TakeOp = 0; + if (BinaryOperator *IOp = dyn_cast(LHSI->getOperand(0))) + if (IOp->getOpcode() == LHSI->getOpcode()) + TakeOp = 1; // Hoist out non-tree portion + + if (RHSRank < getRank(LHSI->getOperand(TakeOp))) { // Convert ((a + 12) + 10) into (a + (12 + 10)) I->setOperand(0, LHSI->getOperand(TakeOp)); LHSI->setOperand(TakeOp, RHS);