diff options
author | Dale Johannesen <dalej@apple.com> | 2010-01-27 22:12:36 +0000 |
---|---|---|
committer | Dale Johannesen <dalej@apple.com> | 2010-01-27 22:12:36 +0000 |
commit | 6eb8e132362db35fab25ba396cecc099a88dd58b (patch) | |
tree | 34859705809e08c5886ceb33b97d7f6ee59fec20 | |
parent | 77b108e17b450dcc08403ea740fe5c44fdc0fc13 (diff) | |
download | bcm5719-llvm-6eb8e132362db35fab25ba396cecc099a88dd58b.tar.gz bcm5719-llvm-6eb8e132362db35fab25ba396cecc099a88dd58b.zip |
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
-rw-r--r-- | llvm/lib/CodeGen/DeadMachineInstructionElim.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/DeadMachineInstructionElim.cpp b/llvm/lib/CodeGen/DeadMachineInstructionElim.cpp index 0982eabff12..9d7ec06ac97 100644 --- a/llvm/lib/CodeGen/DeadMachineInstructionElim.cpp +++ b/llvm/lib/CodeGen/DeadMachineInstructionElim.cpp @@ -107,6 +107,20 @@ bool DeadMachineInstructionElim::runOnMachineFunction(MachineFunction &MF) { MIE = MBB->rend(); MII != MIE; ) { 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 (isDead(MI)) { DEBUG(dbgs() << "DeadMachineInstructionElim: DELETING: " << *MI); |