diff options
Diffstat (limited to 'lib/Transforms')
| -rw-r--r-- | lib/Transforms/Scalar/LoopUnswitch.cpp | 18 | 
1 files changed, 9 insertions, 9 deletions
| diff --git a/lib/Transforms/Scalar/LoopUnswitch.cpp b/lib/Transforms/Scalar/LoopUnswitch.cpp index 00ecc74..04b825b 100644 --- a/lib/Transforms/Scalar/LoopUnswitch.cpp +++ b/lib/Transforms/Scalar/LoopUnswitch.cpp @@ -409,15 +409,6 @@ bool LoopUnswitch::processCurrentLoop() {    if (!currentLoop->isSafeToClone())      return false; -  // Loops with invokes, whose unwind edge escapes the loop, cannot be -  // unswitched because splitting their edges are non-trivial and don't preserve -  // loop simplify information. -  for (Loop::block_iterator I = currentLoop->block_begin(), -         E = currentLoop->block_end(); I != E; ++I) -    if (const InvokeInst *II = dyn_cast<InvokeInst>((*I)->getTerminator())) -      if (!currentLoop->contains(II->getUnwindDest())) -        return false; -    // Without dedicated exits, splitting the exit edge may fail.    if (!currentLoop->hasDedicatedExits())      return false; @@ -429,6 +420,15 @@ bool LoopUnswitch::processCurrentLoop() {    if (!BranchesInfo.countLoop(currentLoop))      return false; +  // Loops with invokes, whose unwind edge escapes the loop, cannot be +  // unswitched because splitting their edges are non-trivial and don't preserve +  // loop simplify information. +  for (Loop::block_iterator I = currentLoop->block_begin(), +         E = currentLoop->block_end(); I != E; ++I) +    if (const InvokeInst *II = dyn_cast<InvokeInst>((*I)->getTerminator())) +      if (!currentLoop->contains(II->getUnwindDest())) +        return false; +    // Loop over all of the basic blocks in the loop.  If we find an interior    // block that is branching on a loop-invariant condition, we can unswitch this    // loop. | 
