mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2026-04-26 12:20:42 +00:00
Local register allocator shouldn't assume only the entry and landing pad basic blocks have live-ins.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@63323 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -710,24 +710,21 @@ void RALocal::AllocateBasicBlock(MachineBasicBlock &MBB) {
|
||||
DEBUG(const BasicBlock *LBB = MBB.getBasicBlock();
|
||||
if (LBB) DOUT << "\nStarting RegAlloc of BB: " << LBB->getName());
|
||||
|
||||
// If this is the first basic block in the machine function, add live-in
|
||||
// registers as active.
|
||||
if (&MBB == &*MF->begin() || MBB.isLandingPad()) {
|
||||
for (MachineBasicBlock::livein_iterator I = MBB.livein_begin(),
|
||||
// Add live-in registers as active.
|
||||
for (MachineBasicBlock::livein_iterator I = MBB.livein_begin(),
|
||||
E = MBB.livein_end(); I != E; ++I) {
|
||||
unsigned Reg = *I;
|
||||
MF->getRegInfo().setPhysRegUsed(Reg);
|
||||
PhysRegsUsed[Reg] = 0; // It is free and reserved now
|
||||
AddToPhysRegsUseOrder(Reg);
|
||||
for (const unsigned *SubRegs = TRI->getSubRegisters(Reg);
|
||||
*SubRegs; ++SubRegs) {
|
||||
if (PhysRegsUsed[*SubRegs] != -2) {
|
||||
AddToPhysRegsUseOrder(*SubRegs);
|
||||
PhysRegsUsed[*SubRegs] = 0; // It is free and reserved now
|
||||
MF->getRegInfo().setPhysRegUsed(*SubRegs);
|
||||
}
|
||||
unsigned Reg = *I;
|
||||
MF->getRegInfo().setPhysRegUsed(Reg);
|
||||
PhysRegsUsed[Reg] = 0; // It is free and reserved now
|
||||
AddToPhysRegsUseOrder(Reg);
|
||||
for (const unsigned *SubRegs = TRI->getSubRegisters(Reg);
|
||||
*SubRegs; ++SubRegs) {
|
||||
if (PhysRegsUsed[*SubRegs] != -2) {
|
||||
AddToPhysRegsUseOrder(*SubRegs);
|
||||
PhysRegsUsed[*SubRegs] = 0; // It is free and reserved now
|
||||
MF->getRegInfo().setPhysRegUsed(*SubRegs);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
ComputeLocalLiveness(MBB);
|
||||
|
||||
Reference in New Issue
Block a user