mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-16 14:31:59 +00:00
Stop computing physreg live ranges.
Everyone is using on-demand regunit ranges now. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@159018 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
a6d98b8b6c
commit
27b7669a60
@ -352,8 +352,7 @@ namespace llvm {
|
||||
void computeIntervals();
|
||||
|
||||
/// handleRegisterDef - update intervals for a register def
|
||||
/// (calls handlePhysicalRegisterDef and
|
||||
/// handleVirtualRegisterDef)
|
||||
/// (calls handleVirtualRegisterDef)
|
||||
void handleRegisterDef(MachineBasicBlock *MBB,
|
||||
MachineBasicBlock::iterator MI,
|
||||
SlotIndex MIIdx,
|
||||
@ -373,18 +372,6 @@ namespace llvm {
|
||||
unsigned MOIdx,
|
||||
LiveInterval& interval);
|
||||
|
||||
/// handlePhysicalRegisterDef - update intervals for a physical register
|
||||
/// def.
|
||||
void handlePhysicalRegisterDef(MachineBasicBlock* mbb,
|
||||
MachineBasicBlock::iterator mi,
|
||||
SlotIndex MIIdx, MachineOperand& MO,
|
||||
LiveInterval &interval);
|
||||
|
||||
/// handleLiveInRegister - Create interval for a livein register.
|
||||
void handleLiveInRegister(MachineBasicBlock* mbb,
|
||||
SlotIndex MIIdx,
|
||||
LiveInterval &interval);
|
||||
|
||||
static LiveInterval* createInterval(unsigned Reg);
|
||||
|
||||
void printInstrs(raw_ostream &O) const;
|
||||
|
@ -362,101 +362,6 @@ void LiveIntervals::handleVirtualRegisterDef(MachineBasicBlock *mbb,
|
||||
DEBUG(dbgs() << '\n');
|
||||
}
|
||||
|
||||
static bool isRegLiveIntoSuccessor(const MachineBasicBlock *MBB, unsigned Reg) {
|
||||
for (MachineBasicBlock::const_succ_iterator SI = MBB->succ_begin(),
|
||||
SE = MBB->succ_end();
|
||||
SI != SE; ++SI) {
|
||||
const MachineBasicBlock* succ = *SI;
|
||||
if (succ->isLiveIn(Reg))
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void LiveIntervals::handlePhysicalRegisterDef(MachineBasicBlock *MBB,
|
||||
MachineBasicBlock::iterator mi,
|
||||
SlotIndex MIIdx,
|
||||
MachineOperand& MO,
|
||||
LiveInterval &interval) {
|
||||
DEBUG(dbgs() << "\t\tregister: " << PrintReg(interval.reg, TRI));
|
||||
|
||||
SlotIndex baseIndex = MIIdx;
|
||||
SlotIndex start = baseIndex.getRegSlot(MO.isEarlyClobber());
|
||||
SlotIndex end = start;
|
||||
|
||||
// If it is not used after definition, it is considered dead at
|
||||
// the instruction defining it. Hence its interval is:
|
||||
// [defSlot(def), defSlot(def)+1)
|
||||
// For earlyclobbers, the defSlot was pushed back one; the extra
|
||||
// advance below compensates.
|
||||
if (MO.isDead()) {
|
||||
DEBUG(dbgs() << " dead");
|
||||
end = start.getDeadSlot();
|
||||
goto exit;
|
||||
}
|
||||
|
||||
// If it is not dead on definition, it must be killed by a
|
||||
// subsequent instruction. Hence its interval is:
|
||||
// [defSlot(def), useSlot(kill)+1)
|
||||
baseIndex = baseIndex.getNextIndex();
|
||||
while (++mi != MBB->end()) {
|
||||
|
||||
if (mi->isDebugValue())
|
||||
continue;
|
||||
if (getInstructionFromIndex(baseIndex) == 0)
|
||||
baseIndex = Indexes->getNextNonNullIndex(baseIndex);
|
||||
|
||||
if (mi->killsRegister(interval.reg, TRI)) {
|
||||
DEBUG(dbgs() << " killed");
|
||||
end = baseIndex.getRegSlot();
|
||||
goto exit;
|
||||
} else {
|
||||
int DefIdx = mi->findRegisterDefOperandIdx(interval.reg,false,false,TRI);
|
||||
if (DefIdx != -1) {
|
||||
if (mi->isRegTiedToUseOperand(DefIdx)) {
|
||||
// Two-address instruction.
|
||||
end = baseIndex.getRegSlot(mi->getOperand(DefIdx).isEarlyClobber());
|
||||
} else {
|
||||
// Another instruction redefines the register before it is ever read.
|
||||
// Then the register is essentially dead at the instruction that
|
||||
// defines it. Hence its interval is:
|
||||
// [defSlot(def), defSlot(def)+1)
|
||||
DEBUG(dbgs() << " dead");
|
||||
end = start.getDeadSlot();
|
||||
}
|
||||
goto exit;
|
||||
}
|
||||
}
|
||||
|
||||
baseIndex = baseIndex.getNextIndex();
|
||||
}
|
||||
|
||||
// If we get here the register *should* be live out.
|
||||
assert(!isAllocatable(interval.reg) && "Physregs shouldn't be live out!");
|
||||
|
||||
// FIXME: We need saner rules for reserved regs.
|
||||
if (isReserved(interval.reg)) {
|
||||
end = start.getDeadSlot();
|
||||
} else {
|
||||
// Unreserved, unallocable registers like EFLAGS can be live across basic
|
||||
// block boundaries.
|
||||
assert(isRegLiveIntoSuccessor(MBB, interval.reg) &&
|
||||
"Unreserved reg not live-out?");
|
||||
end = getMBBEndIdx(MBB);
|
||||
}
|
||||
exit:
|
||||
assert(start < end && "did not find end of interval?");
|
||||
|
||||
// Already exists? Extend old live interval.
|
||||
VNInfo *ValNo = interval.getVNInfoAt(start);
|
||||
bool Extend = ValNo != 0;
|
||||
if (!Extend)
|
||||
ValNo = interval.getNextValue(start, VNInfoAllocator);
|
||||
LiveRange LR(start, end, ValNo);
|
||||
interval.addRange(LR);
|
||||
DEBUG(dbgs() << " +" << LR << '\n');
|
||||
}
|
||||
|
||||
void LiveIntervals::handleRegisterDef(MachineBasicBlock *MBB,
|
||||
MachineBasicBlock::iterator MI,
|
||||
SlotIndex MIIdx,
|
||||
@ -465,93 +370,6 @@ void LiveIntervals::handleRegisterDef(MachineBasicBlock *MBB,
|
||||
if (TargetRegisterInfo::isVirtualRegister(MO.getReg()))
|
||||
handleVirtualRegisterDef(MBB, MI, MIIdx, MO, MOIdx,
|
||||
getOrCreateInterval(MO.getReg()));
|
||||
else
|
||||
handlePhysicalRegisterDef(MBB, MI, MIIdx, MO,
|
||||
getOrCreateInterval(MO.getReg()));
|
||||
}
|
||||
|
||||
void LiveIntervals::handleLiveInRegister(MachineBasicBlock *MBB,
|
||||
SlotIndex MIIdx,
|
||||
LiveInterval &interval) {
|
||||
assert(TargetRegisterInfo::isPhysicalRegister(interval.reg) &&
|
||||
"Only physical registers can be live in.");
|
||||
assert((!isAllocatable(interval.reg) || MBB->getParent()->begin() ||
|
||||
MBB->isLandingPad()) &&
|
||||
"Allocatable live-ins only valid for entry blocks and landing pads.");
|
||||
|
||||
DEBUG(dbgs() << "\t\tlivein register: " << PrintReg(interval.reg, TRI));
|
||||
|
||||
// Look for kills, if it reaches a def before it's killed, then it shouldn't
|
||||
// be considered a livein.
|
||||
MachineBasicBlock::iterator mi = MBB->begin();
|
||||
MachineBasicBlock::iterator E = MBB->end();
|
||||
// Skip over DBG_VALUE at the start of the MBB.
|
||||
if (mi != E && mi->isDebugValue()) {
|
||||
while (++mi != E && mi->isDebugValue())
|
||||
;
|
||||
if (mi == E)
|
||||
// MBB is empty except for DBG_VALUE's.
|
||||
return;
|
||||
}
|
||||
|
||||
SlotIndex baseIndex = MIIdx;
|
||||
SlotIndex start = baseIndex;
|
||||
if (getInstructionFromIndex(baseIndex) == 0)
|
||||
baseIndex = Indexes->getNextNonNullIndex(baseIndex);
|
||||
|
||||
SlotIndex end = baseIndex;
|
||||
bool SeenDefUse = false;
|
||||
|
||||
while (mi != E) {
|
||||
if (mi->killsRegister(interval.reg, TRI)) {
|
||||
DEBUG(dbgs() << " killed");
|
||||
end = baseIndex.getRegSlot();
|
||||
SeenDefUse = true;
|
||||
break;
|
||||
} else if (mi->modifiesRegister(interval.reg, TRI)) {
|
||||
// Another instruction redefines the register before it is ever read.
|
||||
// Then the register is essentially dead at the instruction that defines
|
||||
// it. Hence its interval is:
|
||||
// [defSlot(def), defSlot(def)+1)
|
||||
DEBUG(dbgs() << " dead");
|
||||
end = start.getDeadSlot();
|
||||
SeenDefUse = true;
|
||||
break;
|
||||
}
|
||||
|
||||
while (++mi != E && mi->isDebugValue())
|
||||
// Skip over DBG_VALUE.
|
||||
;
|
||||
if (mi != E)
|
||||
baseIndex = Indexes->getNextNonNullIndex(baseIndex);
|
||||
}
|
||||
|
||||
// Live-in register might not be used at all.
|
||||
if (!SeenDefUse) {
|
||||
if (isAllocatable(interval.reg) ||
|
||||
!isRegLiveIntoSuccessor(MBB, interval.reg)) {
|
||||
// Allocatable registers are never live through.
|
||||
// Non-allocatable registers that aren't live into any successors also
|
||||
// aren't live through.
|
||||
DEBUG(dbgs() << " dead");
|
||||
return;
|
||||
} else {
|
||||
// If we get here the register is non-allocatable and live into some
|
||||
// successor. We'll conservatively assume it's live-through.
|
||||
DEBUG(dbgs() << " live through");
|
||||
end = getMBBEndIdx(MBB);
|
||||
}
|
||||
}
|
||||
|
||||
SlotIndex defIdx = getMBBStartIdx(MBB);
|
||||
assert(getInstructionFromIndex(defIdx) == 0 &&
|
||||
"PHI def index points at actual instruction.");
|
||||
VNInfo *vni = interval.getNextValue(defIdx, VNInfoAllocator);
|
||||
vni->setIsPHIDef(true);
|
||||
LiveRange LR(start, end, vni);
|
||||
|
||||
interval.addRange(LR);
|
||||
DEBUG(dbgs() << " +" << LR << '\n');
|
||||
}
|
||||
|
||||
/// computeIntervals - computes the live intervals for virtual
|
||||
@ -579,12 +397,6 @@ void LiveIntervals::computeIntervals() {
|
||||
DEBUG(dbgs() << "BB#" << MBB->getNumber()
|
||||
<< ":\t\t# derived from " << MBB->getName() << "\n");
|
||||
|
||||
// Create intervals for live-ins to this BB first.
|
||||
for (MachineBasicBlock::livein_iterator LI = MBB->livein_begin(),
|
||||
LE = MBB->livein_end(); LI != LE; ++LI) {
|
||||
handleLiveInRegister(MBB, MIIndex, getOrCreateInterval(*LI));
|
||||
}
|
||||
|
||||
// Skip over empty initial indices.
|
||||
if (getInstructionFromIndex(MIIndex) == 0)
|
||||
MIIndex = Indexes->getNextNonNullIndex(MIIndex);
|
||||
@ -608,7 +420,7 @@ void LiveIntervals::computeIntervals() {
|
||||
continue;
|
||||
}
|
||||
|
||||
if (!MO.isReg() || !MO.getReg())
|
||||
if (!MO.isReg() || !TargetRegisterInfo::isVirtualRegister(MO.getReg()))
|
||||
continue;
|
||||
|
||||
// handle register defs - build intervals
|
||||
|
Loading…
x
Reference in New Issue
Block a user