summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorDale Johannesen <dalej@apple.com>2010-01-27 22:11:16 +0000
committerDale Johannesen <dalej@apple.com>2010-01-27 22:11:16 +0000
commit77b108e17b450dcc08403ea740fe5c44fdc0fc13 (patch)
treecf9e6f006420141e1418420a70709089e8cc1459 /llvm/lib
parent7e15aefa15a2406c2ea2f1cd9fd4e8e3c451998a (diff)
downloadbcm5719-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.cpp10
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);
OpenPOWER on IntegriCloud