mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-12 13:30:51 +00:00
Don't assume that only Uses can be kills. Defs are marked as kills initially
when there are no uses. This fixes a dangling-pointer bug, where pointers to deleted instructions were not removed from kills lists. More info here: http://lists.cs.uiuc.edu/pipermail/llvmdev/2007-July/009749.html git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@40131 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b1d1f7a035
commit
c674a924d4
@ -229,7 +229,7 @@ public:
|
||||
bool Removed = false;
|
||||
for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) {
|
||||
MachineOperand &MO = MI->getOperand(i);
|
||||
if (MO.isReg() && MO.isUse() && MO.getReg() == reg) {
|
||||
if (MO.isReg() && MO.isKill() && MO.getReg() == reg) {
|
||||
MO.unsetIsKill();
|
||||
Removed = true;
|
||||
break;
|
||||
|
@ -582,15 +582,13 @@ void LiveVariables::instructionChanged(MachineInstr *OldMI,
|
||||
if (VI.DefInst == OldMI)
|
||||
VI.DefInst = NewMI;
|
||||
}
|
||||
if (MO.isUse()) {
|
||||
if (MO.isKill()) {
|
||||
MO.unsetIsKill();
|
||||
addVirtualRegisterKilled(Reg, NewMI);
|
||||
}
|
||||
// If this is a kill of the value, update the VI kills list.
|
||||
if (VI.removeKill(OldMI))
|
||||
VI.Kills.push_back(NewMI); // Yes, there was a kill of it
|
||||
if (MO.isKill()) {
|
||||
MO.unsetIsKill();
|
||||
addVirtualRegisterKilled(Reg, NewMI);
|
||||
}
|
||||
// If this is a kill of the value, update the VI kills list.
|
||||
if (VI.removeKill(OldMI))
|
||||
VI.Kills.push_back(NewMI); // Yes, there was a kill of it
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -955,7 +955,7 @@ MachineOperand *SimpleRegisterCoalescing::findDefOperand(MachineInstr *MI, unsig
|
||||
void SimpleRegisterCoalescing::unsetRegisterKill(MachineInstr *MI, unsigned Reg) {
|
||||
for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) {
|
||||
MachineOperand &MO = MI->getOperand(i);
|
||||
if (MO.isReg() && MO.isUse() && MO.isKill() && MO.getReg() &&
|
||||
if (MO.isReg() && MO.isKill() && MO.getReg() &&
|
||||
mri_->regsOverlap(rep(MO.getReg()), Reg))
|
||||
MO.unsetIsKill();
|
||||
}
|
||||
@ -979,7 +979,7 @@ void SimpleRegisterCoalescing::unsetRegisterKills(unsigned Start, unsigned End,
|
||||
|
||||
for (unsigned i = 0, NumOps = MI->getNumOperands(); i != NumOps; ++i) {
|
||||
MachineOperand &MO = MI->getOperand(i);
|
||||
if (MO.isReg() && MO.isUse() && MO.isKill() && MO.getReg() &&
|
||||
if (MO.isReg() && MO.isKill() && MO.getReg() &&
|
||||
mri_->regsOverlap(rep(MO.getReg()), Reg)) {
|
||||
MO.unsetIsKill();
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user