mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-06 09:44:39 +00:00
Preserve physreg kills in MachineBasicBlock::SplitCriticalEdge.
Failure to preserve kills was causing LiveIntervals to miss some EFLAGS live ranges. Unfortunately I've been unable to reduce a good test case yet. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@150152 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c1b18e7549
commit
72a043f9d6
@ -602,10 +602,11 @@ MachineBasicBlock::SplitCriticalEdge(MachineBasicBlock *Succ, Pass *P) {
|
||||
MachineInstr *MI = I;
|
||||
for (MachineInstr::mop_iterator OI = MI->operands_begin(),
|
||||
OE = MI->operands_end(); OI != OE; ++OI) {
|
||||
if (!OI->isReg() || !OI->isUse() || !OI->isKill() || OI->isUndef())
|
||||
if (!OI->isReg() || OI->getReg() == 0 ||
|
||||
!OI->isUse() || !OI->isKill() || OI->isUndef())
|
||||
continue;
|
||||
unsigned Reg = OI->getReg();
|
||||
if (TargetRegisterInfo::isVirtualRegister(Reg) &&
|
||||
if (TargetRegisterInfo::isPhysicalRegister(Reg) ||
|
||||
LV->getVarInfo(Reg).removeKill(MI)) {
|
||||
KilledRegs.push_back(Reg);
|
||||
DEBUG(dbgs() << "Removing terminator kill: " << *MI);
|
||||
@ -638,14 +639,16 @@ MachineBasicBlock::SplitCriticalEdge(MachineBasicBlock *Succ, Pass *P) {
|
||||
NMBB->addLiveIn(*I);
|
||||
|
||||
// Update LiveVariables.
|
||||
const TargetRegisterInfo *TRI = MF->getTarget().getRegisterInfo();
|
||||
if (LV) {
|
||||
// Restore kills of virtual registers that were killed by the terminators.
|
||||
while (!KilledRegs.empty()) {
|
||||
unsigned Reg = KilledRegs.pop_back_val();
|
||||
for (instr_iterator I = instr_end(), E = instr_begin(); I != E;) {
|
||||
if (!(--I)->addRegisterKilled(Reg, NULL, /* addIfNotFound= */ false))
|
||||
if (!(--I)->addRegisterKilled(Reg, TRI, /* addIfNotFound= */ false))
|
||||
continue;
|
||||
LV->getVarInfo(Reg).Kills.push_back(I);
|
||||
if (TargetRegisterInfo::isVirtualRegister(Reg))
|
||||
LV->getVarInfo(Reg).Kills.push_back(I);
|
||||
DEBUG(dbgs() << "Restored terminator kill: " << *I);
|
||||
break;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user