Index: llvm/lib/Target/X86/MCTargetDesc/X86ATTInstPrinter.cpp =================================================================== --- llvm/lib/Target/X86/MCTargetDesc/X86ATTInstPrinter.cpp +++ llvm/lib/Target/X86/MCTargetDesc/X86ATTInstPrinter.cpp @@ -36,7 +36,7 @@ #include "X86GenAsmWriter.inc" void X86ATTInstPrinter::printRegName(raw_ostream &OS, MCRegister Reg) const { - OS << markup(""); + markup(OS, Markup::Register) << '%' << getRegisterName(Reg); } void X86ATTInstPrinter::printInst(const MCInst *MI, uint64_t Address, @@ -386,7 +386,7 @@ } else if (Op.isImm()) { // Print immediates as signed values. int64_t Imm = Op.getImm(); - O << markup(""); + markup(O, Markup::Immediate) << '$' << formatImm(Imm); // TODO: This should be in a helper function in the base class, so it can // be used by other printers. @@ -405,9 +405,9 @@ } } else { assert(Op.isExpr() && "unknown operand kind in printOperand"); - O << markup("print(O, &MAI); - O << markup(">"); } } @@ -451,8 +451,8 @@ printOperand(MI, Op + X86::AddrIndexReg, O); unsigned ScaleVal = MI->getOperand(Op + X86::AddrScaleAmt).getImm(); if (ScaleVal != 1) { - O << ',' << markup(""); + O << ','; + markup(O, Markup::Immediate) << ScaleVal; // never printed in hex. } } O << ')'; @@ -510,8 +510,7 @@ if (MI->getOperand(Op).isExpr()) return printOperand(MI, Op, O); - O << markup("getOperand(Op).getImm() & 0xff) - << markup(">"); + markup(O, Markup::Immediate) << '$' << formatImm(MI->getOperand(Op).getImm() & 0xff); } void X86ATTInstPrinter::printSTiRegOperand(const MCInst *MI, unsigned OpNo, @@ -520,7 +519,7 @@ unsigned Reg = Op.getReg(); // Override the default printing to print st(0) instead st. if (Reg == X86::ST0) - OS << markup(""); + markup(OS, Markup::Register) << "%st(0)"; else printRegName(OS, Reg); } Index: llvm/lib/Target/X86/MCTargetDesc/X86InstPrinterCommon.cpp =================================================================== --- llvm/lib/Target/X86/MCTargetDesc/X86InstPrinterCommon.cpp +++ llvm/lib/Target/X86/MCTargetDesc/X86InstPrinterCommon.cpp @@ -322,15 +322,13 @@ const MCOperand &Op = MI->getOperand(OpNo); if (Op.isImm()) { - O << markup(""); + markup(O, Markup::Immediate) << formatImm(Op.getImm()); } else { assert(Op.isExpr() && "unknown pcrel immediate operand"); // If a symbolic branch target was added as a constant expression then print @@ -338,7 +336,7 @@ const MCConstantExpr *BranchTarget = dyn_cast(Op.getExpr()); int64_t Address; if (BranchTarget && BranchTarget->evaluateAsAbsolute(Address)) { - O << markup(""); + markup(O, Markup::Immediate) << formatHex((uint64_t)Address); } else { // Otherwise, just print the expression. Op.getExpr()->print(O, &MAI); Index: llvm/lib/Target/X86/MCTargetDesc/X86IntelInstPrinter.cpp =================================================================== --- llvm/lib/Target/X86/MCTargetDesc/X86IntelInstPrinter.cpp +++ llvm/lib/Target/X86/MCTargetDesc/X86IntelInstPrinter.cpp @@ -34,7 +34,7 @@ #include "X86GenAsmWriter1.inc" void X86IntelInstPrinter::printRegName(raw_ostream &OS, MCRegister Reg) const { - OS << markup(""); + markup(OS, Markup::Register) << getRegisterName(Reg); } void X86IntelInstPrinter::printInst(const MCInst *MI, uint64_t Address, @@ -361,7 +361,7 @@ if (Op.isReg()) { printRegName(O, Op.getReg()); } else if (Op.isImm()) { - O << markup(""); + markup(O, Markup::Immediate) << formatImm((int64_t)Op.getImm()); } else { assert(Op.isExpr() && "unknown operand kind in printOperand"); O << "offset "; @@ -419,7 +419,7 @@ DispVal = -DispVal; } } - O << markup(""); + markup(O, Markup::Immediate) << formatImm(DispVal); } } @@ -453,7 +453,7 @@ O << markup(""); + markup(O, Markup::Immediate) << formatImm(DispSpec.getImm()); } else { assert(DispSpec.isExpr() && "non-immediate displacement?"); DispSpec.getExpr()->print(O, &MAI); @@ -467,8 +467,7 @@ if (MI->getOperand(Op).isExpr()) return MI->getOperand(Op).getExpr()->print(O, &MAI); - O << markup("getOperand(Op).getImm() & 0xff) - << markup(">"); + markup(O, Markup::Immediate) << formatImm(MI->getOperand(Op).getImm() & 0xff); } void X86IntelInstPrinter::printSTiRegOperand(const MCInst *MI, unsigned OpNo,