mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
Back out some of recent register scavenger change by John Mosby. It broke a number of ARM tests.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@78421 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7116b7bb0c
commit
c40f613034
@ -99,13 +99,12 @@ void RegScavenger::initRegState() {
|
||||
RegsAvailable ^= ReservedRegs;
|
||||
|
||||
// Live-in registers are in use.
|
||||
if (MBB) {
|
||||
if (!MBB->livein_empty())
|
||||
if (!MBB || MBB->livein_empty())
|
||||
return;
|
||||
for (MachineBasicBlock::const_livein_iterator I = MBB->livein_begin(),
|
||||
E = MBB->livein_end(); I != E; ++I)
|
||||
setUsed(*I);
|
||||
}
|
||||
}
|
||||
|
||||
void RegScavenger::enterBasicBlock(MachineBasicBlock *mbb) {
|
||||
MachineFunction &MF = *mbb->getParent();
|
||||
@ -128,16 +127,9 @@ void RegScavenger::enterBasicBlock(MachineBasicBlock *mbb) {
|
||||
// Create callee-saved registers bitvector.
|
||||
CalleeSavedRegs.resize(NumPhysRegs);
|
||||
const unsigned *CSRegs = TRI->getCalleeSavedRegs();
|
||||
if (CSRegs != NULL) {
|
||||
// At this point we know which CSRs are used by the current function,
|
||||
// so allow those that are _not_ already used to be available to RS.
|
||||
MachineFrameInfo *FFI = MF.getFrameInfo();
|
||||
const std::vector<CalleeSavedInfo> &CSI = FFI->getCalleeSavedInfo();
|
||||
|
||||
for (unsigned i = 0, e = CSI.size(); i != e; ++i) {
|
||||
CalleeSavedRegs.set(CSI[i].getReg());
|
||||
}
|
||||
}
|
||||
if (CSRegs != NULL)
|
||||
for (unsigned i = 0; CSRegs[i]; ++i)
|
||||
CalleeSavedRegs.set(CSRegs[i]);
|
||||
}
|
||||
|
||||
// RS used within emit{Pro,Epi}logue()
|
||||
@ -217,11 +209,6 @@ void RegScavenger::forward() {
|
||||
ScavengeRestore = NULL;
|
||||
}
|
||||
|
||||
#if 0
|
||||
if (MI->getOpcode() == TargetInstrInfo::IMPLICIT_DEF)
|
||||
return;
|
||||
#endif
|
||||
|
||||
// Separate register operands into 3 classes: uses, defs, earlyclobbers.
|
||||
SmallVector<std::pair<const MachineOperand*,unsigned>, 4> UseMOs;
|
||||
SmallVector<std::pair<const MachineOperand*,unsigned>, 4> DefMOs;
|
||||
@ -234,9 +221,11 @@ void RegScavenger::forward() {
|
||||
UseMOs.push_back(std::make_pair(&MO,i));
|
||||
else if (MO.isEarlyClobber())
|
||||
EarlyClobberMOs.push_back(std::make_pair(&MO,i));
|
||||
else if (MO.isDef())
|
||||
else {
|
||||
assert(MO.isDef());
|
||||
DefMOs.push_back(std::make_pair(&MO,i));
|
||||
}
|
||||
}
|
||||
|
||||
// Process uses first.
|
||||
BitVector KillRegs(NumPhysRegs);
|
||||
@ -245,9 +234,7 @@ void RegScavenger::forward() {
|
||||
unsigned Idx = UseMOs[i].second;
|
||||
unsigned Reg = MO.getReg();
|
||||
|
||||
// Allow free CSRs to be processed as uses.
|
||||
assert((isUsed(Reg) || !CalleeSavedRegs[Reg]) &&
|
||||
"Using an undefined register!");
|
||||
assert(isUsed(Reg) && "Using an undefined register!");
|
||||
|
||||
// Two-address operands implicitly kill.
|
||||
if ((MO.isKill() || MI->isRegTiedToDefOperand(Idx)) && !isReserved(Reg)) {
|
||||
@ -440,7 +427,7 @@ unsigned RegScavenger::scavengeRegister(const TargetRegisterClass *RC,
|
||||
? MachineBasicBlock::iterator(MaxUseMI) : MBB->getFirstTerminator();
|
||||
TII->loadRegFromStackSlot(*MBB, II, SReg, ScavengingFrameIndex, RC);
|
||||
ScavengeRestore = prior(II);
|
||||
// Doing this here leads to infinite regress
|
||||
// Doing this here leads to infinite regress.
|
||||
// ScavengedReg = SReg;
|
||||
ScavengedRC = RC;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user