mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-16 14:31:59 +00:00
Drop RAGreedy::trySpillInterferences().
This is a waste of time since we already know how to evict all interferences which is a better approach anyway. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@126798 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
9bf9aa5106
commit
1841d14eff
@ -145,7 +145,6 @@ private:
|
||||
bool checkUncachedInterference(LiveInterval&, unsigned);
|
||||
LiveInterval *getSingleInterference(LiveInterval&, unsigned);
|
||||
bool reassignVReg(LiveInterval &InterferingVReg, unsigned OldPhysReg);
|
||||
float calcInterferenceWeight(LiveInterval&, unsigned);
|
||||
float calcInterferenceInfo(LiveInterval&, unsigned);
|
||||
float calcGlobalSplitCost(const BitVector&);
|
||||
void splitAroundRegion(LiveInterval&, unsigned, const BitVector&,
|
||||
@ -166,8 +165,6 @@ private:
|
||||
SmallVectorImpl<LiveInterval*>&);
|
||||
unsigned trySplit(LiveInterval&, AllocationOrder&,
|
||||
SmallVectorImpl<LiveInterval*>&);
|
||||
unsigned trySpillInterferences(LiveInterval&, AllocationOrder&,
|
||||
SmallVectorImpl<LiveInterval*>&);
|
||||
};
|
||||
} // end anonymous namespace
|
||||
|
||||
@ -1283,68 +1280,6 @@ unsigned RAGreedy::trySplit(LiveInterval &VirtReg, AllocationOrder &Order,
|
||||
}
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// Spilling
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
/// calcInterferenceWeight - Calculate the combined spill weight of
|
||||
/// interferences when assigning VirtReg to PhysReg.
|
||||
float RAGreedy::calcInterferenceWeight(LiveInterval &VirtReg, unsigned PhysReg){
|
||||
float Sum = 0;
|
||||
for (const unsigned *AI = TRI->getOverlaps(PhysReg); *AI; ++AI) {
|
||||
LiveIntervalUnion::Query &Q = query(VirtReg, *AI);
|
||||
Q.collectInterferingVRegs();
|
||||
if (Q.seenUnspillableVReg())
|
||||
return HUGE_VALF;
|
||||
for (unsigned i = 0, e = Q.interferingVRegs().size(); i != e; ++i)
|
||||
Sum += Q.interferingVRegs()[i]->weight;
|
||||
}
|
||||
return Sum;
|
||||
}
|
||||
|
||||
/// trySpillInterferences - Try to spill interfering registers instead of the
|
||||
/// current one. Only do it if the accumulated spill weight is smaller than the
|
||||
/// current spill weight.
|
||||
unsigned RAGreedy::trySpillInterferences(LiveInterval &VirtReg,
|
||||
AllocationOrder &Order,
|
||||
SmallVectorImpl<LiveInterval*> &NewVRegs) {
|
||||
NamedRegionTimer T("Spill Interference", TimerGroupName, TimePassesIsEnabled);
|
||||
unsigned BestPhys = 0;
|
||||
float BestWeight = 0;
|
||||
|
||||
Order.rewind();
|
||||
while (unsigned PhysReg = Order.next()) {
|
||||
float Weight = calcInterferenceWeight(VirtReg, PhysReg);
|
||||
if (Weight == HUGE_VALF || Weight >= VirtReg.weight)
|
||||
continue;
|
||||
if (!BestPhys || Weight < BestWeight)
|
||||
BestPhys = PhysReg, BestWeight = Weight;
|
||||
}
|
||||
|
||||
// No candidates found.
|
||||
if (!BestPhys)
|
||||
return 0;
|
||||
|
||||
// Collect all interfering registers.
|
||||
SmallVector<LiveInterval*, 8> Spills;
|
||||
for (const unsigned *AI = TRI->getOverlaps(BestPhys); *AI; ++AI) {
|
||||
LiveIntervalUnion::Query &Q = query(VirtReg, *AI);
|
||||
Spills.append(Q.interferingVRegs().begin(), Q.interferingVRegs().end());
|
||||
for (unsigned i = 0, e = Q.interferingVRegs().size(); i != e; ++i) {
|
||||
LiveInterval *VReg = Q.interferingVRegs()[i];
|
||||
unassign(*VReg, *AI);
|
||||
}
|
||||
}
|
||||
|
||||
// Spill them all.
|
||||
DEBUG(dbgs() << "spilling " << Spills.size() << " interferences with weight "
|
||||
<< BestWeight << '\n');
|
||||
for (unsigned i = 0, e = Spills.size(); i != e; ++i)
|
||||
spiller().spill(Spills[i], NewVRegs, Spills);
|
||||
return BestPhys;
|
||||
}
|
||||
|
||||
|
||||
//===----------------------------------------------------------------------===//
|
||||
// Main Entry Point
|
||||
//===----------------------------------------------------------------------===//
|
||||
@ -1385,11 +1320,6 @@ unsigned RAGreedy::selectOrSplit(LiveInterval &VirtReg,
|
||||
if (PhysReg || !NewVRegs.empty())
|
||||
return PhysReg;
|
||||
|
||||
// Try to spill another interfering reg with less spill weight.
|
||||
PhysReg = trySpillInterferences(VirtReg, Order, NewVRegs);
|
||||
if (PhysReg)
|
||||
return PhysReg;
|
||||
|
||||
// Finally spill VirtReg itself.
|
||||
NamedRegionTimer T("Spiller", TimerGroupName, TimePassesIsEnabled);
|
||||
SmallVector<LiveInterval*, 1> pendingSpills;
|
||||
|
Loading…
x
Reference in New Issue
Block a user