forked from OSchip/llvm-project
If the only use of something is a DEBUG_VALUE, don't
let that stop it from being deleted, and change the DEBUG_VALUE value to undef. llvm-svn: 94694
This commit is contained in:
parent
77b108e17b
commit
6eb8e13236
|
@ -107,6 +107,20 @@ bool DeadMachineInstructionElim::runOnMachineFunction(MachineFunction &MF) {
|
||||||
MIE = MBB->rend(); MII != MIE; ) {
|
MIE = MBB->rend(); MII != MIE; ) {
|
||||||
MachineInstr *MI = &*MII;
|
MachineInstr *MI = &*MII;
|
||||||
|
|
||||||
|
if (MI->getOpcode()==TargetInstrInfo::DEBUG_VALUE) {
|
||||||
|
// Don't delete the DEBUG_VALUE itself, but if its Value operand is
|
||||||
|
// a vreg and this is the only use, substitute an undef operand;
|
||||||
|
// the former operand will then be deleted normally.
|
||||||
|
if (MI->getNumOperands()==3 && MI->getOperand(0).isReg()) {
|
||||||
|
unsigned Reg = MI->getOperand(0).getReg();
|
||||||
|
MachineRegisterInfo::use_iterator I = MRI->use_begin(Reg);
|
||||||
|
assert(I != MRI->use_end());
|
||||||
|
if (++I == MRI->use_end())
|
||||||
|
// only one use, which must be this DEBUG_VALUE.
|
||||||
|
MI->getOperand(0).setReg(0U);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// If the instruction is dead, delete it!
|
// If the instruction is dead, delete it!
|
||||||
if (isDead(MI)) {
|
if (isDead(MI)) {
|
||||||
DEBUG(dbgs() << "DeadMachineInstructionElim: DELETING: " << *MI);
|
DEBUG(dbgs() << "DeadMachineInstructionElim: DELETING: " << *MI);
|
||||||
|
|
Loading…
Reference in New Issue