diff options
author | David Blaikie <dblaikie@gmail.com> | 2013-06-15 15:52:58 +0000 |
---|---|---|
committer | David Blaikie <dblaikie@gmail.com> | 2013-06-15 15:52:58 +0000 |
commit | c9380db4ba52dbe0bae316867c0dd314b78c290a (patch) | |
tree | a18bf5a32d357011773ca9a7bfd1b32407510cb9 /llvm/lib/CodeGen/AsmPrinter | |
parent | 4898e62ac09c045c9342c231b73e6150f0d2cd4f (diff) | |
download | bcm5719-llvm-c9380db4ba52dbe0bae316867c0dd314b78c290a.tar.gz bcm5719-llvm-c9380db4ba52dbe0bae316867c0dd314b78c290a.zip |
DebugInfo: print DBG_VALUE MachineInstrs with [] for deref and drop the offset when it's zero
llvm-svn: 184045
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter')
-rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index 7f4ba7a0d93..9b392649283 100644 --- a/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -569,6 +569,8 @@ static bool emitDebugValueComment(const MachineInstr *MI, AsmPrinter &AP) { } OS << V.getName() << " <- "; + int64_t Offset = MI->getOperand(1).getImm(); + bool Deref = false; // Register or immediate value. Register 0 means undef. if (MI->getOperand(0).isFPImm()) { APFloat APF = APFloat(MI->getOperand(0).getFPImm()->getValueAPF()); @@ -590,17 +592,25 @@ static bool emitDebugValueComment(const MachineInstr *MI, AsmPrinter &AP) { MI->getOperand(0).getCImm()->getValue().print(OS, false /*isSigned*/); } else { assert(MI->getOperand(0).isReg() && "Unknown operand type"); - if (MI->getOperand(0).getReg() == 0) { + unsigned Reg = MI->getOperand(0).getReg(); + if (Reg == 0) { // Suppress offset, it is not meaningful here. OS << "undef"; // NOTE: Want this comment at start of line, don't emit with AddComment. AP.OutStreamer.EmitRawText(OS.str()); return true; } - OS << AP.TM.getRegisterInfo()->getName(MI->getOperand(0).getReg()); + Deref = Offset != 0; // FIXME: use a better sentinel value so that deref of + // a reg with a zero offset is valid + if (Deref) + OS << '['; + OS << AP.TM.getRegisterInfo()->getName(Reg); } - OS << '+' << MI->getOperand(1).getImm(); + if (Offset) + OS << '+' << Offset; + if (Deref) + OS << ']'; // NOTE: Want this comment at start of line, don't emit with AddComment. AP.OutStreamer.EmitRawText(OS.str()); return true; |