mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-20 14:29:27 +00:00
Fix another case where LSR was affected by debug info.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@97865 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
6cc1aeaad2
commit
621e06f9df
@ -1267,8 +1267,19 @@ Value *SCEVExpander::expand(const SCEV *S) {
|
||||
L = L->getParentLoop())
|
||||
if (S->isLoopInvariant(L)) {
|
||||
if (!L) break;
|
||||
if (BasicBlock *Preheader = L->getLoopPreheader())
|
||||
if (BasicBlock *Preheader = L->getLoopPreheader()) {
|
||||
InsertPt = Preheader->getTerminator();
|
||||
BasicBlock::iterator IP = InsertPt;
|
||||
// Back past any debug info instructions. Sometimes we inserted
|
||||
// something earlier before debug info but after any real instructions.
|
||||
// This should behave the same as if debug info was not present.
|
||||
while (IP != Preheader->begin()) {
|
||||
--IP;
|
||||
if (!isa<DbgInfoIntrinsic>(IP))
|
||||
break;
|
||||
InsertPt = IP;
|
||||
}
|
||||
}
|
||||
} else {
|
||||
// If the SCEV is computable at this level, insert it into the header
|
||||
// after the PHIs (and after any other instructions that we've inserted
|
||||
|
Loading…
x
Reference in New Issue
Block a user