switch the x86 asmprinters to use getRegisterName instead

of getting it from TRI, inst printing now is codegen context
free!

llvm-svn: 81710
This commit is contained in:
Chris Lattner 2009-09-13 20:15:16 +00:00
parent cea934f803
commit 31c7141542
5 changed files with 11 additions and 18 deletions

View File

@ -48,7 +48,7 @@ STATISTIC(EmittedInsts, "Number of machine instrs printed");
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
void X86ATTAsmPrinter::printMCInst(const MCInst *MI) { void X86ATTAsmPrinter::printMCInst(const MCInst *MI) {
X86ATTInstPrinter(O, MAI, TRI).printInstruction(MI); X86ATTInstPrinter(O, MAI).printInstruction(MI);
} }
void X86ATTAsmPrinter::PrintPICBaseSymbol() const { void X86ATTAsmPrinter::PrintPICBaseSymbol() const {

View File

@ -19,7 +19,6 @@
#include "llvm/MC/MCExpr.h" #include "llvm/MC/MCExpr.h"
#include "llvm/Support/ErrorHandling.h" #include "llvm/Support/ErrorHandling.h"
#include "llvm/Support/FormattedStream.h" #include "llvm/Support/FormattedStream.h"
#include "llvm/Target/TargetRegisterInfo.h" // FIXME: REMOVE.
using namespace llvm; using namespace llvm;
// Include the auto-generated portion of the assembly writer. // Include the auto-generated portion of the assembly writer.
@ -70,7 +69,7 @@ void X86ATTInstPrinter::printOperand(const MCInst *MI, unsigned OpNo,
const MCOperand &Op = MI->getOperand(OpNo); const MCOperand &Op = MI->getOperand(OpNo);
if (Op.isReg()) { if (Op.isReg()) {
O << '%' << TRI->getAsmName(Op.getReg()); O << '%' << getRegisterName(Op.getReg());
return; return;
} else if (Op.isImm()) { } else if (Op.isImm()) {
O << '$' << Op.getImm(); O << '$' << Op.getImm();

View File

@ -24,10 +24,8 @@ namespace llvm {
class X86ATTInstPrinter { class X86ATTInstPrinter {
raw_ostream &O; raw_ostream &O;
const MCAsmInfo *MAI; const MCAsmInfo *MAI;
const TargetRegisterInfo *TRI; // FIXME: Elim.
public: public:
X86ATTInstPrinter(raw_ostream &o, const MCAsmInfo *mai, X86ATTInstPrinter(raw_ostream &o, const MCAsmInfo *mai) : O(o), MAI(mai) {}
const TargetRegisterInfo *tri) : O(o), MAI(mai), TRI(tri) {}
// Autogenerated by tblgen. // Autogenerated by tblgen.
void printInstruction(const MCInst *MI); void printInstruction(const MCInst *MI);

View File

@ -214,6 +214,11 @@ static void PrintRegName(raw_ostream &O, StringRef RegName) {
O << (char)toupper(RegName[i]); O << (char)toupper(RegName[i]);
} }
void X86IntelAsmPrinter::printOperand(const MachineInstr *MI, unsigned OpNo,
const char *Modifier) {
printOp(MI->getOperand(OpNo), Modifier);
}
void X86IntelAsmPrinter::printOp(const MachineOperand &MO, void X86IntelAsmPrinter::printOp(const MachineOperand &MO,
const char *Modifier) { const char *Modifier) {
switch (MO.getType()) { switch (MO.getType()) {
@ -226,7 +231,7 @@ void X86IntelAsmPrinter::printOp(const MachineOperand &MO,
((strcmp(Modifier,"subreg16") == 0) ? MVT::i16 :MVT::i8)); ((strcmp(Modifier,"subreg16") == 0) ? MVT::i16 :MVT::i8));
Reg = getX86SubSuperRegister(Reg, VT); Reg = getX86SubSuperRegister(Reg, VT);
} }
PrintRegName(O, TRI->getAsmName(Reg)); PrintRegName(O, getRegisterName(Reg));
return; return;
} }
case MachineOperand::MO_Immediate: case MachineOperand::MO_Immediate:
@ -399,7 +404,7 @@ bool X86IntelAsmPrinter::printAsmMRegister(const MachineOperand &MO,
break; break;
} }
PrintRegName(O, TRI->getAsmName(Reg)); PrintRegName(O, getRegisterName(Reg));
return false; return false;
} }

View File

@ -43,16 +43,7 @@ struct VISIBILITY_HIDDEN X86IntelAsmPrinter : public AsmPrinter {
// This method is used by the tablegen'erated instruction printer. // This method is used by the tablegen'erated instruction printer.
void printOperand(const MachineInstr *MI, unsigned OpNo, void printOperand(const MachineInstr *MI, unsigned OpNo,
const char *Modifier = 0) { const char *Modifier = 0);
const MachineOperand &MO = MI->getOperand(OpNo);
if (MO.isReg()) {
assert(TargetRegisterInfo::isPhysicalRegister(MO.getReg()) &&
"Not physreg??");
O << TM.getRegisterInfo()->get(MO.getReg()).Name; // Capitalized names
} else {
printOp(MO, Modifier);
}
}
void print_pcrel_imm(const MachineInstr *MI, unsigned OpNo); void print_pcrel_imm(const MachineInstr *MI, unsigned OpNo);