summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDale Johannesen <dalej@apple.com>2010-01-27 22:12:36 +0000
committerDale Johannesen <dalej@apple.com>2010-01-27 22:12:36 +0000
commit6eb8e132362db35fab25ba396cecc099a88dd58b (patch)
tree34859705809e08c5886ceb33b97d7f6ee59fec20
parent77b108e17b450dcc08403ea740fe5c44fdc0fc13 (diff)
downloadbcm5719-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.cpp14
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);
OpenPOWER on IntegriCloud