mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Add more comments... err debug statements to the fast allocator.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@129400 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2a2bc5ccee
commit
0b756349a7
@ -420,20 +420,25 @@ void RAFast::definePhysReg(MachineInstr *MI, unsigned PhysReg,
|
||||
// can be allocated directly.
|
||||
// Returns spillImpossible when PhysReg or an alias can't be spilled.
|
||||
unsigned RAFast::calcSpillCost(unsigned PhysReg) const {
|
||||
if (UsedInInstr.test(PhysReg))
|
||||
if (UsedInInstr.test(PhysReg)) {
|
||||
DEBUG(dbgs() << "PhysReg: " << PhysReg << " is already used in instr.\n");
|
||||
return spillImpossible;
|
||||
}
|
||||
switch (unsigned VirtReg = PhysRegState[PhysReg]) {
|
||||
case regDisabled:
|
||||
break;
|
||||
case regFree:
|
||||
return 0;
|
||||
case regReserved:
|
||||
DEBUG(dbgs() << "VirtReg: " << VirtReg << " corresponding to PhysReg: "
|
||||
<< PhysReg << " is reserved already.\n");
|
||||
return spillImpossible;
|
||||
default:
|
||||
return LiveVirtRegs.lookup(VirtReg).Dirty ? spillDirty : spillClean;
|
||||
}
|
||||
|
||||
// This is a disabled register, add up cost of aliases.
|
||||
DEBUG(dbgs() << "\tRegister: " << PhysReg << " is disabled.\n");
|
||||
unsigned Cost = 0;
|
||||
for (const unsigned *AS = TRI->getAliasSet(PhysReg);
|
||||
unsigned Alias = *AS; ++AS) {
|
||||
@ -511,9 +516,14 @@ void RAFast::allocVirtReg(MachineInstr *MI, LiveRegEntry &LRE, unsigned Hint) {
|
||||
|
||||
unsigned BestReg = 0, BestCost = spillImpossible;
|
||||
for (TargetRegisterClass::iterator I = AOB; I != AOE; ++I) {
|
||||
if (!Allocatable.test(*I))
|
||||
if (!Allocatable.test(*I)) {
|
||||
DEBUG(dbgs() << "\tRegister " << *I << " is not allocatable.\n");
|
||||
continue;
|
||||
}
|
||||
unsigned Cost = calcSpillCost(*I);
|
||||
DEBUG(dbgs() << "\tRegister: " << *I << "\n");
|
||||
DEBUG(dbgs() << "\tCost: " << Cost << "\n");
|
||||
DEBUG(dbgs() << "\tBestCost: " << BestCost << "\n");
|
||||
// Cost is 0 when all aliases are already disabled.
|
||||
if (Cost == 0)
|
||||
return assignVirtToPhysReg(LRE, *I);
|
||||
@ -722,10 +732,13 @@ void RAFast::handleThroughOperands(MachineInstr *MI,
|
||||
if (!MO.isReg() || (MO.isDef() && !MO.isEarlyClobber())) continue;
|
||||
unsigned Reg = MO.getReg();
|
||||
if (!Reg || !TargetRegisterInfo::isPhysicalRegister(Reg)) continue;
|
||||
DEBUG(dbgs() << "\tSetting reg " << Reg << " as used in instr\n");
|
||||
UsedInInstr.set(Reg);
|
||||
for (const unsigned *AS = TRI->getAliasSet(Reg); *AS; ++AS)
|
||||
for (const unsigned *AS = TRI->getAliasSet(Reg); *AS; ++AS) {
|
||||
DEBUG(dbgs() << "\tSetting alias reg " << *AS << " as used in instr\n");
|
||||
UsedInInstr.set(*AS);
|
||||
}
|
||||
}
|
||||
|
||||
// Also mark PartialDefs as used to avoid reallocation.
|
||||
for (unsigned i = 0, e = PartialDefs.size(); i != e; ++i)
|
||||
|
Loading…
x
Reference in New Issue
Block a user