diff options
| author | Michael J. Spencer <bigcheesegs@gmail.com> | 2017-02-09 21:46:49 +0000 | 
|---|---|---|
| committer | Michael J. Spencer <bigcheesegs@gmail.com> | 2017-02-09 21:46:49 +0000 | 
| commit | 714d9d22ad7bd19679a042239b9e384d38303610 (patch) | |
| tree | de174277a5036118fbc2fd14edc7d0b8d6676bb4 /llvm/lib/Transforms/Scalar | |
| parent | 857aba44106ac543cbd8210cff56db46e7287c84 (diff) | |
| download | bcm5719-llvm-714d9d22ad7bd19679a042239b9e384d38303610.tar.gz bcm5719-llvm-714d9d22ad7bd19679a042239b9e384d38303610.zip  | |
[LoadCombine] Fix combining of loads which span an aliasing store.
Fixes PR31517
Differential Revision: https://reviews.llvm.org/D28922
llvm-svn: 294632
Diffstat (limited to 'llvm/lib/Transforms/Scalar')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LoadCombine.cpp | 6 | 
1 files changed, 5 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Scalar/LoadCombine.cpp b/llvm/lib/Transforms/Scalar/LoadCombine.cpp index 389f1c595aa..61b7804b59b 100644 --- a/llvm/lib/Transforms/Scalar/LoadCombine.cpp +++ b/llvm/lib/Transforms/Scalar/LoadCombine.cpp @@ -245,13 +245,17 @@ bool LoadCombine::runOnBasicBlock(BasicBlock &BB) {    bool Combined = false;    unsigned Index = 0;    for (auto &I : BB) { -    if (I.mayThrow() || (I.mayWriteToMemory() && AST.containsUnknown(&I))) { +    if (I.mayThrow() || AST.containsUnknown(&I)) {        if (combineLoads(LoadMap))          Combined = true;        LoadMap.clear();        AST.clear();        continue;      } +    if (I.mayWriteToMemory()) { +      AST.add(&I); +      continue; +    }      LoadInst *LI = dyn_cast<LoadInst>(&I);      if (!LI)        continue;  | 

