DBG_VALUE does not have any side effects; it also makes no sense to mark it cheap...
authorEvan Cheng <evan.cheng@apple.com>
Fri, 7 Jan 2011 21:08:26 +0000 (21:08 +0000)
committerEvan Cheng <evan.cheng@apple.com>
Fri, 7 Jan 2011 21:08:26 +0000 (21:08 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@123031 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Target/Target.td
lib/CodeGen/MachineInstr.cpp
lib/CodeGen/PeepholeOptimizer.cpp
lib/CodeGen/VirtRegRewriter.cpp

index f7a029bd611039e7c5abcdde4f71a5044871d968..e88a09eecc6ffca8507484fa313a05929756c46e 100644 (file)
@@ -484,7 +484,7 @@ def DBG_VALUE : Instruction {
   let OutOperandList = (outs);
   let InOperandList = (ins variable_ops);
   let AsmString = "DBG_VALUE";
-  let isAsCheapAsAMove = 1;
+  let neverHasSideEffects = 1;
 }
 def REG_SEQUENCE : Instruction {
   let OutOperandList = (outs unknown:$dst);
index bc2a545a5f279d6e6ba1a16be648bc99593c11ea..ccb2ffbab1d4c24e132500d4bb16ae0613898b45 100644 (file)
@@ -1115,7 +1115,9 @@ bool MachineInstr::isSafeToMove(const TargetInstrInfo *TII,
     SawStore = true;
     return false;
   }
-  if (TID->isTerminator() || TID->hasUnmodeledSideEffects())
+
+  if (isLabel() || isDebugValue() ||
+      TID->isTerminator() || TID->hasUnmodeledSideEffects())
     return false;
 
   // See if this instruction does a load.  If so, we have to guarantee that the
index 07c2b80dcb06f4f7a9813a81307254e3254873b9..1ddfe8b7c230c8b20dc39a7d74e250c96807a6fe 100644 (file)
@@ -336,7 +336,9 @@ bool PeepholeOptimizer::runOnMachineFunction(MachineFunction &MF) {
       MachineInstr *MI = &*MII++;
       LocalMIs.insert(MI);
 
-      if (MI->getDesc().hasUnmodeledSideEffects())
+      if (MI->isLabel() || MI->isPHI() || MI->isImplicitDef() ||
+          MI->isKill() || MI->isInlineAsm() || MI->isDebugValue() ||
+          MI->getDesc().hasUnmodeledSideEffects())
         continue;
 
       if (MI->getDesc().isCompare()) {
index 14ee69da4c2a871f107d7b83158dedd9c9d2c0f0..d04b9285bab967fab1d6b90219a3e7b8c3838d52 100644 (file)
@@ -1620,7 +1620,8 @@ static bool isSafeToDelete(MachineInstr &MI) {
   const TargetInstrDesc &TID = MI.getDesc();
   if (TID.mayLoad() || TID.mayStore() || TID.isCall() || TID.isTerminator() ||
       TID.isCall() || TID.isBarrier() || TID.isReturn() ||
-      TID.hasUnmodeledSideEffects())
+      TID.hasUnmodeledSideEffects() ||
+      MI.isLabel() || MI.isDebugValue())
     return false;
   for (unsigned i = 0, e = MI.getNumOperands(); i != e; ++i) {
     MachineOperand &MO = MI.getOperand(i);