mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-25 13:24:46 +00:00
Switch invars away from using isTrapping when it really shouldn't be
using it. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@75852 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -544,7 +544,13 @@ void IndVarSimplify::SinkUnusedInvariants(Loop *L) {
|
||||
// New instructions were inserted at the end of the preheader.
|
||||
if (isa<PHINode>(I))
|
||||
break;
|
||||
if (I->isTrapping())
|
||||
// Don't move instructions which might have side effects, since the side
|
||||
// effects need to complete before instructions inside the loop. Also
|
||||
// don't move instructions which might read memory, since the loop may
|
||||
// modify memory. Note that it's okay if the instruction might have
|
||||
// undefined behavior: LoopSimplify guarantees that the preheader
|
||||
// dominates the exit block.
|
||||
if (I->mayHaveSideEffects() || I->mayReadFromMemory())
|
||||
continue;
|
||||
// Determine if there is a use in or before the loop (direct or
|
||||
// otherwise).
|
||||
|
Reference in New Issue
Block a user