diff options
| author | Dale Johannesen <dalej@apple.com> | 2010-01-27 22:11:16 +0000 |
|---|---|---|
| committer | Dale Johannesen <dalej@apple.com> | 2010-01-27 22:11:16 +0000 |
| commit | 77b108e17b450dcc08403ea740fe5c44fdc0fc13 (patch) | |
| tree | cf9e6f006420141e1418420a70709089e8cc1459 /llvm/lib | |
| parent | 7e15aefa15a2406c2ea2f1cd9fd4e8e3c451998a (diff) | |
| download | bcm5719-llvm-77b108e17b450dcc08403ea740fe5c44fdc0fc13.tar.gz bcm5719-llvm-77b108e17b450dcc08403ea740fe5c44fdc0fc13.zip | |
Treat MO_REG 0 location as undefined in DEBUG_VALUE,
per document.
llvm-svn: 94693
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp b/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp index b6a358133bb..9fb6ca4c460 100644 --- a/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp +++ b/llvm/lib/Target/X86/AsmPrinter/X86MCInstLower.cpp @@ -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); |

