mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-01 08:28:19 +00:00
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:
parent
cea934f803
commit
31c7141542
@ -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 {
|
||||||
|
@ -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();
|
||||||
|
@ -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);
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user