diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2008-06-13 22:02:12 +0000 |
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2008-06-13 22:02:12 +0000 |
| commit | 5de0a77a9bbd06d0b1ecb71429cb83822e93eabe (patch) | |
| tree | eba073a4d1ab2e35f8389204318e2d512b28f55c /llvm/lib | |
| parent | 9ad8c54aab51afec95ae4989e36850cddf40b606 (diff) | |
| download | bcm5719-llvm-5de0a77a9bbd06d0b1ecb71429cb83822e93eabe.tar.gz bcm5719-llvm-5de0a77a9bbd06d0b1ecb71429cb83822e93eabe.zip | |
Don't skip over instructions other than loads that might read memory
when trying to sink stores.
llvm-svn: 52259
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 8dbca0f2e8b..8a7128bf65c 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -10417,18 +10417,19 @@ bool InstCombiner::SimplifyStoreAtEndOfBlock(StoreInst &SI) { return false; break; } - // If we find something that may be using the stored value, or if we run - // out of instructions, we can't do the xform. - if (isa<LoadInst>(BBI) || BBI->mayWriteToMemory() || + // If we find something that may be using or overwriting the stored + // value, or if we run out of instructions, we can't do the xform. + if (BBI->mayReadFromMemory() || BBI->mayWriteToMemory() || BBI == OtherBB->begin()) return false; } // In order to eliminate the store in OtherBr, we have to - // make sure nothing reads the stored value in StoreBB. + // make sure nothing reads or overwrites the stored value in + // StoreBB. for (BasicBlock::iterator I = StoreBB->begin(); &*I != &SI; ++I) { // FIXME: This should really be AA driven. - if (isa<LoadInst>(I) || I->mayWriteToMemory()) + if (I->mayReadFromMemory() || I->mayWriteToMemory()) return false; } } |

