Treat MO_REG 0 location as undefined in DEBUG_VALUE,
authorDale Johannesen <dalej@apple.com>
Wed, 27 Jan 2010 22:11:16 +0000 (22:11 +0000)
committerDale Johannesen <dalej@apple.com>
Wed, 27 Jan 2010 22:11:16 +0000 (22:11 +0000)
per document.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@94693 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/AsmPrinter/X86MCInstLower.cpp

index b6a358133bbc2d0a088cadd4a12cf70b742ee243..9fb6ca4c460852ab3707753f65c3b40629e5d687 100644 (file)
@@ -428,10 +428,16 @@ void X86AsmPrinter::printInstructionThroughMCStreamer(const MachineInstr *MI) {
     O << V.getName();
     O << " <- ";
     if (NOps==3) {
-      // Register or immediate value
+      // Register or immediate value. Register 0 means undef.
       assert(MI->getOperand(0).getType()==MachineOperand::MO_Register ||
              MI->getOperand(0).getType()==MachineOperand::MO_Immediate);
-      printOperand(MI, 0);
+      if (MI->getOperand(0).getType()==MachineOperand::MO_Register &&
+          MI->getOperand(0).getReg()==0) {
+        // Suppress offset in this case, it is not meaningful.
+        O << "undef";
+        return;
+      } else
+        printOperand(MI, 0);
     } else {
       // Frame address.  Currently handles register +- offset only.
       assert(MI->getOperand(0).getType()==MachineOperand::MO_Register);