mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-03 13:31:05 +00:00
Move the InterferenceCache cursor into the GlobalSplitCand struct.
This is in preparation of supporting multiple global split candidates in a single live range split operation. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@135074 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
37023b05c8
commit
1337e2b75a
@ -127,10 +127,14 @@ public:
|
||||
Entry *CacheEntry;
|
||||
BlockInterference *Current;
|
||||
public:
|
||||
/// Cursor - Create a cursor for the interference allocated to PhysReg and
|
||||
/// all its aliases.
|
||||
Cursor(InterferenceCache &Cache, unsigned PhysReg)
|
||||
: CacheEntry(Cache.get(PhysReg)), Current(0) {}
|
||||
/// Cursor - Create a dangling cursor.
|
||||
Cursor() : CacheEntry(0), Current(0) {}
|
||||
|
||||
/// setPhysReg - Point this cursor to PhysReg's interference.
|
||||
void setPhysReg(InterferenceCache &Cache, unsigned PhysReg) {
|
||||
CacheEntry = Cache.get(PhysReg);
|
||||
Current = 0;
|
||||
}
|
||||
|
||||
/// moveTo - Move cursor to basic block MBBNum.
|
||||
void moveToBlock(unsigned MBBNum) {
|
||||
|
@ -160,11 +160,13 @@ class RAGreedy : public MachineFunctionPass,
|
||||
/// Global live range splitting candidate info.
|
||||
struct GlobalSplitCandidate {
|
||||
unsigned PhysReg;
|
||||
InterferenceCache::Cursor Intf;
|
||||
BitVector LiveBundles;
|
||||
SmallVector<unsigned, 8> ActiveBlocks;
|
||||
|
||||
void reset(unsigned Reg) {
|
||||
void reset(InterferenceCache &Cache, unsigned Reg) {
|
||||
PhysReg = Reg;
|
||||
Intf.setPhysReg(Cache, Reg);
|
||||
LiveBundles.clear();
|
||||
ActiveBlocks.clear();
|
||||
}
|
||||
@ -206,8 +208,8 @@ private:
|
||||
float calcSpillCost();
|
||||
bool addSplitConstraints(InterferenceCache::Cursor, float&);
|
||||
void addThroughConstraints(InterferenceCache::Cursor, ArrayRef<unsigned>);
|
||||
void growRegion(GlobalSplitCandidate &Cand, InterferenceCache::Cursor);
|
||||
float calcGlobalSplitCost(GlobalSplitCandidate&, InterferenceCache::Cursor);
|
||||
void growRegion(GlobalSplitCandidate &Cand);
|
||||
float calcGlobalSplitCost(GlobalSplitCandidate&);
|
||||
void splitAroundRegion(LiveInterval&, GlobalSplitCandidate&,
|
||||
SmallVectorImpl<LiveInterval*>&);
|
||||
void calcGapWeights(unsigned, SmallVectorImpl<float>&);
|
||||
@ -720,8 +722,7 @@ void RAGreedy::addThroughConstraints(InterferenceCache::Cursor Intf,
|
||||
SpillPlacer->addLinks(ArrayRef<unsigned>(TBS, T));
|
||||
}
|
||||
|
||||
void RAGreedy::growRegion(GlobalSplitCandidate &Cand,
|
||||
InterferenceCache::Cursor Intf) {
|
||||
void RAGreedy::growRegion(GlobalSplitCandidate &Cand) {
|
||||
// Keep track of through blocks that have not been added to SpillPlacer.
|
||||
BitVector Todo = SA->getThroughBlocks();
|
||||
SmallVectorImpl<unsigned> &ActiveBlocks = Cand.ActiveBlocks;
|
||||
@ -753,7 +754,7 @@ void RAGreedy::growRegion(GlobalSplitCandidate &Cand,
|
||||
// Any new blocks to add?
|
||||
if (ActiveBlocks.size() == AddedTo)
|
||||
break;
|
||||
addThroughConstraints(Intf,
|
||||
addThroughConstraints(Cand.Intf,
|
||||
ArrayRef<unsigned>(ActiveBlocks).slice(AddedTo));
|
||||
AddedTo = ActiveBlocks.size();
|
||||
|
||||
@ -794,8 +795,7 @@ float RAGreedy::calcSpillCost() {
|
||||
/// pattern in LiveBundles. This cost should be added to the local cost of the
|
||||
/// interference pattern in SplitConstraints.
|
||||
///
|
||||
float RAGreedy::calcGlobalSplitCost(GlobalSplitCandidate &Cand,
|
||||
InterferenceCache::Cursor Intf) {
|
||||
float RAGreedy::calcGlobalSplitCost(GlobalSplitCandidate &Cand) {
|
||||
float GlobalCost = 0;
|
||||
const BitVector &LiveBundles = Cand.LiveBundles;
|
||||
ArrayRef<SplitAnalysis::BlockInfo> UseBlocks = SA->getUseBlocks();
|
||||
@ -822,8 +822,8 @@ float RAGreedy::calcGlobalSplitCost(GlobalSplitCandidate &Cand,
|
||||
continue;
|
||||
if (RegIn && RegOut) {
|
||||
// We need double spill code if this block has interference.
|
||||
Intf.moveToBlock(Number);
|
||||
if (Intf.hasInterference())
|
||||
Cand.Intf.moveToBlock(Number);
|
||||
if (Cand.Intf.hasInterference())
|
||||
GlobalCost += 2*SpillPlacer->getBlockFrequency(Number);
|
||||
continue;
|
||||
}
|
||||
@ -853,7 +853,7 @@ void RAGreedy::splitAroundRegion(LiveInterval &VirtReg,
|
||||
dbgs() << ".\n";
|
||||
});
|
||||
|
||||
InterferenceCache::Cursor Intf(IntfCache, Cand.PhysReg);
|
||||
InterferenceCache::Cursor &Intf = Cand.Intf;
|
||||
LiveRangeEdit LREdit(VirtReg, NewVRegs, this);
|
||||
SE->reset(LREdit);
|
||||
|
||||
@ -1248,12 +1248,11 @@ unsigned RAGreedy::tryRegionSplit(LiveInterval &VirtReg, AllocationOrder &Order,
|
||||
for (unsigned Cand = 0; unsigned PhysReg = Order.next(); ++Cand) {
|
||||
if (GlobalCand.size() <= Cand)
|
||||
GlobalCand.resize(Cand+1);
|
||||
GlobalCand[Cand].reset(PhysReg);
|
||||
GlobalCand[Cand].reset(IntfCache, PhysReg);
|
||||
|
||||
SpillPlacer->prepare(GlobalCand[Cand].LiveBundles);
|
||||
float Cost;
|
||||
InterferenceCache::Cursor Intf(IntfCache, PhysReg);
|
||||
if (!addSplitConstraints(Intf, Cost)) {
|
||||
if (!addSplitConstraints(GlobalCand[Cand].Intf, Cost)) {
|
||||
DEBUG(dbgs() << PrintReg(PhysReg, TRI) << "\tno positive bundles\n");
|
||||
continue;
|
||||
}
|
||||
@ -1268,7 +1267,7 @@ unsigned RAGreedy::tryRegionSplit(LiveInterval &VirtReg, AllocationOrder &Order,
|
||||
});
|
||||
continue;
|
||||
}
|
||||
growRegion(GlobalCand[Cand], Intf);
|
||||
growRegion(GlobalCand[Cand]);
|
||||
|
||||
SpillPlacer->finish();
|
||||
|
||||
@ -1278,7 +1277,7 @@ unsigned RAGreedy::tryRegionSplit(LiveInterval &VirtReg, AllocationOrder &Order,
|
||||
continue;
|
||||
}
|
||||
|
||||
Cost += calcGlobalSplitCost(GlobalCand[Cand], Intf);
|
||||
Cost += calcGlobalSplitCost(GlobalCand[Cand]);
|
||||
DEBUG({
|
||||
dbgs() << ", total = " << Cost << " with bundles";
|
||||
for (int i = GlobalCand[Cand].LiveBundles.find_first(); i>=0;
|
||||
|
Loading…
Reference in New Issue
Block a user