mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-22 10:16:43 +00:00
fix PR9856, an incorrectly conservative assertion: a global can be
"stored once" even if its address is compared. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@131849 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
9e7bc05ad7
commit
98a42b2fc3
@ -799,7 +799,8 @@ static bool OptimizeAwayTrappingUsesOfLoads(GlobalVariable *GV, Constant *LV) {
|
||||
// If we get here we could have other crazy uses that are transitively
|
||||
// loaded.
|
||||
assert((isa<PHINode>(GlobalUser) || isa<SelectInst>(GlobalUser) ||
|
||||
isa<ConstantExpr>(GlobalUser)) && "Only expect load and stores!");
|
||||
isa<ConstantExpr>(GlobalUser) || isa<CmpInst>(GlobalUser)) &&
|
||||
"Only expect load and stores!");
|
||||
}
|
||||
}
|
||||
|
||||
@ -1589,8 +1590,7 @@ static bool OptimizeOnceStoredGlobal(GlobalVariable *GV, Value *StoredOnceVal,
|
||||
GV->getInitializer()->isNullValue()) {
|
||||
if (Constant *SOVC = dyn_cast<Constant>(StoredOnceVal)) {
|
||||
if (GV->getInitializer()->getType() != SOVC->getType())
|
||||
SOVC =
|
||||
ConstantExpr::getBitCast(SOVC, GV->getInitializer()->getType());
|
||||
SOVC = ConstantExpr::getBitCast(SOVC, GV->getInitializer()->getType());
|
||||
|
||||
// Optimize away any trapping uses of the loaded value.
|
||||
if (OptimizeAwayTrappingUsesOfLoads(GV, SOVC))
|
||||
|
@ -64,3 +64,17 @@ define void @memset_with_strange_user() ssp {
|
||||
ret void
|
||||
}
|
||||
declare void @llvm.memset.p0i8.i64(i8* nocapture, i8, i64, i32, i1) nounwind
|
||||
|
||||
|
||||
; PR9856
|
||||
@g_52 = internal global i32** null, align 8
|
||||
@g_90 = external global i32*, align 8
|
||||
|
||||
define void @icmp_user_of_stored_once() nounwind ssp {
|
||||
entry:
|
||||
%tmp4 = load i32*** @g_52, align 8
|
||||
store i32** @g_90, i32*** @g_52
|
||||
%cmp17 = icmp ne i32*** undef, @g_52
|
||||
ret void
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user