Avoid moving iterators when the previous block was just visited.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@129081 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Jakob Stoklund Olesen 2011-04-07 17:27:50 +00:00
parent 0bd2bd9ecc
commit f34ae32a6b

View File

@ -99,6 +99,7 @@ void InterferenceCache::Entry::update(unsigned MBBNum) {
tie(Start, Stop) = Indexes->getMBBRange(MBBNum); tie(Start, Stop) = Indexes->getMBBRange(MBBNum);
// Use advanceTo only when possible. // Use advanceTo only when possible.
if (PrevPos != Start) {
if (!PrevPos.isValid() || Start < PrevPos) if (!PrevPos.isValid() || Start < PrevPos)
for (unsigned i = 0, e = Iters.size(); i != e; ++i) for (unsigned i = 0, e = Iters.size(); i != e; ++i)
Iters[i].find(Start); Iters[i].find(Start);
@ -106,6 +107,7 @@ void InterferenceCache::Entry::update(unsigned MBBNum) {
for (unsigned i = 0, e = Iters.size(); i != e; ++i) for (unsigned i = 0, e = Iters.size(); i != e; ++i)
Iters[i].advanceTo(Start); Iters[i].advanceTo(Start);
PrevPos = Start; PrevPos = Start;
}
// Check for first interference. // Check for first interference.
for (unsigned i = 0, e = Iters.size(); i != e; ++i) { for (unsigned i = 0, e = Iters.size(); i != e; ++i) {
@ -129,11 +131,14 @@ void InterferenceCache::Entry::update(unsigned MBBNum) {
if (!I.valid() || I.start() >= Stop) if (!I.valid() || I.start() >= Stop)
continue; continue;
I.advanceTo(Stop); I.advanceTo(Stop);
if (!I.valid() || I.start() >= Stop) bool Backup = !I.valid() || I.start() >= Stop;
if (Backup)
--I; --I;
SlotIndex StopI = I.stop(); SlotIndex StopI = I.stop();
if (!BI->Last.isValid() || StopI > BI->Last) if (!BI->Last.isValid() || StopI > BI->Last)
BI->Last = StopI; BI->Last = StopI;
if (Backup)
++I;
} }
PrevPos = Stop; PrevPos = Stop;
} }