diff options
| author | Chris Lattner <sabre@nondot.org> | 2011-05-22 07:15:13 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2011-05-22 07:15:13 +0000 |
| commit | 1a1acc21914555e4ffbd9fb6194749e3780fd1c2 (patch) | |
| tree | 44b25529de6ca49a8ba5e720b6835aafe89e94df /llvm/lib/Transforms/IPO | |
| parent | 93e0f19f1d64feea12bb51f96fdf47a7ab7557d9 (diff) | |
| download | bcm5719-llvm-1a1acc21914555e4ffbd9fb6194749e3780fd1c2.tar.gz bcm5719-llvm-1a1acc21914555e4ffbd9fb6194749e3780fd1c2.zip | |
fix PR9856, an incorrectly conservative assertion: a global can be
"stored once" even if its address is compared.
llvm-svn: 131849
Diffstat (limited to 'llvm/lib/Transforms/IPO')
| -rw-r--r-- | llvm/lib/Transforms/IPO/GlobalOpt.cpp | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/llvm/lib/Transforms/IPO/GlobalOpt.cpp b/llvm/lib/Transforms/IPO/GlobalOpt.cpp index ded58aca75f..9d98bb156b4 100644 --- a/llvm/lib/Transforms/IPO/GlobalOpt.cpp +++ b/llvm/lib/Transforms/IPO/GlobalOpt.cpp @@ -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)) |

