mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-29 06:30:39 +00:00
Don't skip over instructions other than loads that might read memory
when trying to sink stores. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@52259 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e562b1725e
commit
6903a24f32
@ -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;
|
||||
}
|
||||
}
|
||||
|
19
test/Transforms/InstCombine/2008-06-13-ReadOnlyCallStore.ll
Normal file
19
test/Transforms/InstCombine/2008-06-13-ReadOnlyCallStore.ll
Normal file
@ -0,0 +1,19 @@
|
||||
; RUN: llvm-as < %s | opt -instcombine | llvm-dis | grep {store i8} | count 2
|
||||
|
||||
define i32 @a(i8* %s) nounwind {
|
||||
entry:
|
||||
store i8 0, i8* %s, align 1 ; This store cannot be eliminated!
|
||||
%tmp3 = call i32 @strlen( i8* %s ) nounwind readonly
|
||||
%tmp5 = icmp ne i32 %tmp3, 0
|
||||
br i1 %tmp5, label %bb, label %bb8
|
||||
|
||||
bb: ; preds = %entry
|
||||
store i8 0, i8* %s, align 1
|
||||
br label %bb8
|
||||
|
||||
bb8:
|
||||
ret i32 %tmp3
|
||||
}
|
||||
|
||||
declare i32 @strlen(i8*) nounwind readonly
|
||||
|
Loading…
Reference in New Issue
Block a user