diff options
| author | James Molloy <james.molloy@arm.com> | 2017-04-05 09:24:26 +0000 |
|---|---|---|
| committer | James Molloy <james.molloy@arm.com> | 2017-04-05 09:24:26 +0000 |
| commit | 37dd4d7aaab4df34b732d4238627049948a0fef6 (patch) | |
| tree | 2f30597a9b47f2509768006e5588d28ea2c1a082 /llvm/lib/Analysis/LoopAccessAnalysis.cpp | |
| parent | 07d7c42c5d4ce7bedf23fe805931e633d554d206 (diff) | |
| download | bcm5719-llvm-37dd4d7aaab4df34b732d4238627049948a0fef6.tar.gz bcm5719-llvm-37dd4d7aaab4df34b732d4238627049948a0fef6.zip | |
[LAA] Correctly return a half-open range in expandBounds
This is a latent bug that's been hanging around for a while. For a loop-invariant
pointer, expandBounds would return the range {Ptr, Ptr}, but this was interpreted
as a half-open range, not a closed range. So we ended up planting incorrect
bounds checks. Even worse, they were tautological, so we ended up incorrectly
executing the optimized loop.
llvm-svn: 299526
Diffstat (limited to 'llvm/lib/Analysis/LoopAccessAnalysis.cpp')
| -rw-r--r-- | llvm/lib/Analysis/LoopAccessAnalysis.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/llvm/lib/Analysis/LoopAccessAnalysis.cpp b/llvm/lib/Analysis/LoopAccessAnalysis.cpp index 72488f1f080..4ba12583ff8 100644 --- a/llvm/lib/Analysis/LoopAccessAnalysis.cpp +++ b/llvm/lib/Analysis/LoopAccessAnalysis.cpp @@ -1939,7 +1939,10 @@ expandBounds(const RuntimePointerChecking::CheckingPtrGroup *CG, Loop *TheLoop, Value *NewPtr = (Inst && TheLoop->contains(Inst)) ? Exp.expandCodeFor(Sc, PtrArithTy, Loc) : Ptr; - return {NewPtr, NewPtr}; + // We must return a half-open range, which means incrementing Sc. + const SCEV *ScPlusOne = SE->getAddExpr(Sc, SE->getOne(PtrArithTy)); + Value *NewPtrPlusOne = Exp.expandCodeFor(ScPlusOne, PtrArithTy, Loc); + return {NewPtr, NewPtrPlusOne}; } else { Value *Start = nullptr, *End = nullptr; DEBUG(dbgs() << "LAA: Adding RT check for range:\n"); |

