forked from OSchip/llvm-project
Make MCRegisterInfo available to the the MCInstPrinter.
Used to allow context sensitive printing of super-register or sub-register references. llvm-svn: 152043
This commit is contained in:
parent
7cf6db7e3c
commit
fd93a59557
|
@ -14,6 +14,7 @@ namespace llvm {
|
|||
class MCInst;
|
||||
class raw_ostream;
|
||||
class MCAsmInfo;
|
||||
class MCRegisterInfo;
|
||||
class StringRef;
|
||||
|
||||
/// MCInstPrinter - This is an instance of a target assembly language printer
|
||||
|
@ -25,6 +26,7 @@ protected:
|
|||
/// assembly emission is disable.
|
||||
raw_ostream *CommentStream;
|
||||
const MCAsmInfo &MAI;
|
||||
const MCRegisterInfo &MRI;
|
||||
|
||||
/// The current set of available features.
|
||||
unsigned AvailableFeatures;
|
||||
|
@ -32,8 +34,8 @@ protected:
|
|||
/// Utility function for printing annotations.
|
||||
void printAnnotation(raw_ostream &OS, StringRef Annot);
|
||||
public:
|
||||
MCInstPrinter(const MCAsmInfo &mai)
|
||||
: CommentStream(0), MAI(mai), AvailableFeatures(0) {}
|
||||
MCInstPrinter(const MCAsmInfo &mai, const MCRegisterInfo &mri)
|
||||
: CommentStream(0), MAI(mai), MRI(mri), AvailableFeatures(0) {}
|
||||
|
||||
virtual ~MCInstPrinter();
|
||||
|
||||
|
|
|
@ -104,6 +104,7 @@ namespace llvm {
|
|||
typedef MCInstPrinter *(*MCInstPrinterCtorTy)(const Target &T,
|
||||
unsigned SyntaxVariant,
|
||||
const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI);
|
||||
typedef MCCodeEmitter *(*MCCodeEmitterCtorTy)(const MCInstrInfo &II,
|
||||
const MCSubtargetInfo &STI,
|
||||
|
@ -392,10 +393,11 @@ namespace llvm {
|
|||
|
||||
MCInstPrinter *createMCInstPrinter(unsigned SyntaxVariant,
|
||||
const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) const {
|
||||
if (!MCInstPrinterCtorFn)
|
||||
return 0;
|
||||
return MCInstPrinterCtorFn(*this, SyntaxVariant, MAI, STI);
|
||||
return MCInstPrinterCtorFn(*this, SyntaxVariant, MAI, MRI, STI);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -171,7 +171,8 @@ bool LLVMTargetMachine::addPassesToEmitFile(PassManagerBase &PM,
|
|||
switch (FileType) {
|
||||
case CGFT_AssemblyFile: {
|
||||
MCInstPrinter *InstPrinter =
|
||||
getTarget().createMCInstPrinter(MAI.getAssemblerDialect(), MAI, STI);
|
||||
getTarget().createMCInstPrinter(MAI.getAssemblerDialect(), MAI,
|
||||
Context->getRegisterInfo(), STI);
|
||||
|
||||
// Create a code emitter if asked to show the encoding.
|
||||
MCCodeEmitter *MCE = 0;
|
||||
|
|
|
@ -80,7 +80,7 @@ LLVMDisasmContextRef LLVMCreateDisasm(const char *TripleName, void *DisInfo,
|
|||
// Set up the instruction printer.
|
||||
int AsmPrinterVariant = MAI->getAssemblerDialect();
|
||||
MCInstPrinter *IP = TheTarget->createMCInstPrinter(AsmPrinterVariant,
|
||||
*MAI, *STI);
|
||||
*MAI, *MRI, *STI);
|
||||
assert(IP && "Unable to create instruction printer!");
|
||||
|
||||
LLVMDisasmContext *DC = new LLVMDisasmContext(TripleName, DisInfo, TagType,
|
||||
|
|
|
@ -168,7 +168,8 @@ EDDisassembler::EDDisassembler(CPUKey &key) :
|
|||
|
||||
InstString.reset(new std::string);
|
||||
InstStream.reset(new raw_string_ostream(*InstString));
|
||||
InstPrinter.reset(Tgt->createMCInstPrinter(LLVMSyntaxVariant, *AsmInfo, *STI));
|
||||
InstPrinter.reset(Tgt->createMCInstPrinter(LLVMSyntaxVariant, *AsmInfo,
|
||||
*MRI, *STI));
|
||||
|
||||
if (!InstPrinter)
|
||||
return;
|
||||
|
|
|
@ -35,8 +35,9 @@ static unsigned translateShiftImm(unsigned imm) {
|
|||
|
||||
|
||||
ARMInstPrinter::ARMInstPrinter(const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) :
|
||||
MCInstPrinter(MAI) {
|
||||
MCInstPrinter(MAI, MRI) {
|
||||
// Initialize the set of available features.
|
||||
setAvailableFeatures(STI.getFeatureBits());
|
||||
}
|
||||
|
|
|
@ -23,7 +23,8 @@ class MCOperand;
|
|||
|
||||
class ARMInstPrinter : public MCInstPrinter {
|
||||
public:
|
||||
ARMInstPrinter(const MCAsmInfo &MAI, const MCSubtargetInfo &STI);
|
||||
ARMInstPrinter(const MCAsmInfo &MAI, const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI);
|
||||
|
||||
virtual void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot);
|
||||
virtual StringRef getOpcodeName(unsigned Opcode) const;
|
||||
|
|
|
@ -163,9 +163,10 @@ static MCStreamer *createMCStreamer(const Target &T, StringRef TT,
|
|||
static MCInstPrinter *createARMMCInstPrinter(const Target &T,
|
||||
unsigned SyntaxVariant,
|
||||
const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) {
|
||||
if (SyntaxVariant == 0)
|
||||
return new ARMInstPrinter(MAI, STI);
|
||||
return new ARMInstPrinter(MAI, MRI, STI);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -21,8 +21,8 @@ namespace llvm {
|
|||
|
||||
class MBlazeInstPrinter : public MCInstPrinter {
|
||||
public:
|
||||
MBlazeInstPrinter(const MCAsmInfo &MAI)
|
||||
: MCInstPrinter(MAI) {}
|
||||
MBlazeInstPrinter(const MCAsmInfo &MAI, const MCRegisterInfo &MRI)
|
||||
: MCInstPrinter(MAI, MRI) {}
|
||||
|
||||
virtual void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot);
|
||||
|
||||
|
|
|
@ -95,9 +95,10 @@ static MCStreamer *createMCStreamer(const Target &T, StringRef TT,
|
|||
static MCInstPrinter *createMBlazeMCInstPrinter(const Target &T,
|
||||
unsigned SyntaxVariant,
|
||||
const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) {
|
||||
if (SyntaxVariant == 0)
|
||||
return new MBlazeInstPrinter(MAI);
|
||||
return new MBlazeInstPrinter(MAI, MRI);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -21,8 +21,8 @@ namespace llvm {
|
|||
|
||||
class MSP430InstPrinter : public MCInstPrinter {
|
||||
public:
|
||||
MSP430InstPrinter(const MCAsmInfo &MAI)
|
||||
: MCInstPrinter(MAI) {}
|
||||
MSP430InstPrinter(const MCAsmInfo &MAI, const MCRegisterInfo &MRI)
|
||||
: MCInstPrinter(MAI, MRI) {}
|
||||
|
||||
virtual void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot);
|
||||
|
||||
|
|
|
@ -61,9 +61,10 @@ static MCCodeGenInfo *createMSP430MCCodeGenInfo(StringRef TT, Reloc::Model RM,
|
|||
static MCInstPrinter *createMSP430MCInstPrinter(const Target &T,
|
||||
unsigned SyntaxVariant,
|
||||
const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) {
|
||||
if (SyntaxVariant == 0)
|
||||
return new MSP430InstPrinter(MAI);
|
||||
return new MSP430InstPrinter(MAI, MRI);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -77,7 +77,8 @@ class TargetMachine;
|
|||
|
||||
class MipsInstPrinter : public MCInstPrinter {
|
||||
public:
|
||||
MipsInstPrinter(const MCAsmInfo &MAI) : MCInstPrinter(MAI) {}
|
||||
MipsInstPrinter(const MCAsmInfo &MAI, const MCRegisterInfo &MRI) :
|
||||
MCInstPrinter(MAI, MRI) {}
|
||||
|
||||
// Autogenerated by tblgen.
|
||||
void printInstruction(const MCInst *MI, raw_ostream &O);
|
||||
|
|
|
@ -76,8 +76,9 @@ static MCCodeGenInfo *createMipsMCCodeGenInfo(StringRef TT, Reloc::Model RM,
|
|||
static MCInstPrinter *createMipsMCInstPrinter(const Target &T,
|
||||
unsigned SyntaxVariant,
|
||||
const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) {
|
||||
return new MipsInstPrinter(MAI);
|
||||
return new MipsInstPrinter(MAI, MRI);
|
||||
}
|
||||
|
||||
static MCStreamer *createMCStreamer(const Target &T, StringRef TT,
|
||||
|
|
|
@ -27,8 +27,9 @@ using namespace llvm;
|
|||
#include "PTXGenAsmWriter.inc"
|
||||
|
||||
PTXInstPrinter::PTXInstPrinter(const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) :
|
||||
MCInstPrinter(MAI) {
|
||||
MCInstPrinter(MAI, MRI) {
|
||||
// Initialize the set of available features.
|
||||
setAvailableFeatures(STI.getFeatureBits());
|
||||
}
|
||||
|
|
|
@ -23,7 +23,8 @@ class MCOperand;
|
|||
|
||||
class PTXInstPrinter : public MCInstPrinter {
|
||||
public:
|
||||
PTXInstPrinter(const MCAsmInfo &MAI, const MCSubtargetInfo &STI);
|
||||
PTXInstPrinter(const MCAsmInfo &MAI, const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI);
|
||||
|
||||
virtual void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot);
|
||||
virtual StringRef getOpcodeName(unsigned Opcode) const;
|
||||
|
|
|
@ -62,9 +62,10 @@ static MCCodeGenInfo *createPTXMCCodeGenInfo(StringRef TT, Reloc::Model RM,
|
|||
static MCInstPrinter *createPTXMCInstPrinter(const Target &T,
|
||||
unsigned SyntaxVariant,
|
||||
const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) {
|
||||
assert(SyntaxVariant == 0 && "We only have one syntax variant");
|
||||
return new PTXInstPrinter(MAI, STI);
|
||||
return new PTXInstPrinter(MAI, MRI, STI);
|
||||
}
|
||||
|
||||
extern "C" void LLVMInitializePTXTargetMC() {
|
||||
|
|
|
@ -24,8 +24,9 @@ class PPCInstPrinter : public MCInstPrinter {
|
|||
// 0 -> AIX, 1 -> Darwin.
|
||||
unsigned SyntaxVariant;
|
||||
public:
|
||||
PPCInstPrinter(const MCAsmInfo &MAI, unsigned syntaxVariant)
|
||||
: MCInstPrinter(MAI), SyntaxVariant(syntaxVariant) {}
|
||||
PPCInstPrinter(const MCAsmInfo &MAI, const MCRegisterInfo &MRI,
|
||||
unsigned syntaxVariant)
|
||||
: MCInstPrinter(MAI, MRI), SyntaxVariant(syntaxVariant) {}
|
||||
|
||||
bool isDarwinSyntax() const {
|
||||
return SyntaxVariant == 1;
|
||||
|
|
|
@ -108,8 +108,9 @@ static MCStreamer *createMCStreamer(const Target &T, StringRef TT,
|
|||
static MCInstPrinter *createPPCMCInstPrinter(const Target &T,
|
||||
unsigned SyntaxVariant,
|
||||
const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) {
|
||||
return new PPCInstPrinter(MAI, SyntaxVariant);
|
||||
return new PPCInstPrinter(MAI, MRI, SyntaxVariant);
|
||||
}
|
||||
|
||||
extern "C" void LLVMInitializePowerPCTargetMC() {
|
||||
|
|
|
@ -30,10 +30,6 @@ using namespace llvm;
|
|||
#define PRINT_ALIAS_INSTR
|
||||
#include "X86GenAsmWriter.inc"
|
||||
|
||||
X86ATTInstPrinter::X86ATTInstPrinter(const MCAsmInfo &MAI)
|
||||
: MCInstPrinter(MAI) {
|
||||
}
|
||||
|
||||
void X86ATTInstPrinter::printRegName(raw_ostream &OS,
|
||||
unsigned RegNo) const {
|
||||
OS << '%' << getRegisterName(RegNo);
|
||||
|
|
|
@ -22,8 +22,9 @@ class MCOperand;
|
|||
|
||||
class X86ATTInstPrinter : public MCInstPrinter {
|
||||
public:
|
||||
X86ATTInstPrinter(const MCAsmInfo &MAI);
|
||||
|
||||
X86ATTInstPrinter(const MCAsmInfo &MAI, const MCRegisterInfo &MRI)
|
||||
: MCInstPrinter(MAI, MRI) {}
|
||||
|
||||
virtual void printRegName(raw_ostream &OS, unsigned RegNo) const;
|
||||
virtual void printInst(const MCInst *MI, raw_ostream &OS, StringRef Annot);
|
||||
virtual StringRef getOpcodeName(unsigned Opcode) const;
|
||||
|
|
|
@ -23,8 +23,8 @@ class MCOperand;
|
|||
|
||||
class X86IntelInstPrinter : public MCInstPrinter {
|
||||
public:
|
||||
X86IntelInstPrinter(const MCAsmInfo &MAI)
|
||||
: MCInstPrinter(MAI) {}
|
||||
X86IntelInstPrinter(const MCAsmInfo &MAI, const MCRegisterInfo &MRI)
|
||||
: MCInstPrinter(MAI, MRI) {}
|
||||
|
||||
virtual void printRegName(raw_ostream &OS, unsigned RegNo) const;
|
||||
virtual void printInst(const MCInst *MI, raw_ostream &OS, StringRef Annot);
|
||||
|
|
|
@ -474,11 +474,12 @@ static MCStreamer *createMCStreamer(const Target &T, StringRef TT,
|
|||
static MCInstPrinter *createX86MCInstPrinter(const Target &T,
|
||||
unsigned SyntaxVariant,
|
||||
const MCAsmInfo &MAI,
|
||||
const MCRegisterInfo &MRI,
|
||||
const MCSubtargetInfo &STI) {
|
||||
if (SyntaxVariant == 0)
|
||||
return new X86ATTInstPrinter(MAI);
|
||||
return new X86ATTInstPrinter(MAI, MRI);
|
||||
if (SyntaxVariant == 1)
|
||||
return new X86IntelInstPrinter(MAI);
|
||||
return new X86IntelInstPrinter(MAI, MRI);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
|
|
@ -21,6 +21,7 @@
|
|||
#include "llvm/MC/MCDisassembler.h"
|
||||
#include "llvm/MC/MCInst.h"
|
||||
#include "llvm/MC/MCInstPrinter.h"
|
||||
#include "llvm/MC/MCRegisterInfo.h"
|
||||
#include "llvm/MC/MCSubtargetInfo.h"
|
||||
#include "llvm/ADT/OwningPtr.h"
|
||||
#include "llvm/ADT/Triple.h"
|
||||
|
@ -160,16 +161,22 @@ int Disassembler::disassemble(const Target &T,
|
|||
errs() << "error: no subtarget info for target " << Triple << "\n";
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
OwningPtr<const MCDisassembler> DisAsm(T.createMCDisassembler(*STI));
|
||||
if (!DisAsm) {
|
||||
errs() << "error: no disassembler for target " << Triple << "\n";
|
||||
return -1;
|
||||
}
|
||||
|
||||
OwningPtr<const MCRegisterInfo> MRI(T.createMCRegInfo(Triple));
|
||||
if (!MRI) {
|
||||
errs() << "error: no register info for target " << Triple << "\n";
|
||||
return -1;
|
||||
}
|
||||
|
||||
int AsmPrinterVariant = AsmInfo->getAssemblerDialect();
|
||||
OwningPtr<MCInstPrinter> IP(T.createMCInstPrinter(AsmPrinterVariant,
|
||||
*AsmInfo, *STI));
|
||||
*AsmInfo, *MRI, *STI));
|
||||
if (!IP) {
|
||||
errs() << "error: no instruction printer for target " << Triple << '\n';
|
||||
return -1;
|
||||
|
|
|
@ -416,7 +416,7 @@ static int AssembleInput(const char *ProgName) {
|
|||
// FIXME: There is a bit of code duplication with addPassesToEmitFile.
|
||||
if (FileType == OFT_AssemblyFile) {
|
||||
MCInstPrinter *IP =
|
||||
TheTarget->createMCInstPrinter(OutputAsmVariant, *MAI, *STI);
|
||||
TheTarget->createMCInstPrinter(OutputAsmVariant, *MAI, *MRI, *STI);
|
||||
MCCodeEmitter *CE = 0;
|
||||
MCAsmBackend *MAB = 0;
|
||||
if (ShowEncoding) {
|
||||
|
|
|
@ -26,6 +26,7 @@
|
|||
#include "llvm/MC/MCInstrAnalysis.h"
|
||||
#include "llvm/MC/MCInstrDesc.h"
|
||||
#include "llvm/MC/MCInstrInfo.h"
|
||||
#include "llvm/MC/MCRegisterInfo.h"
|
||||
#include "llvm/MC/MCSubtargetInfo.h"
|
||||
#include "llvm/Support/CommandLine.h"
|
||||
#include "llvm/Support/Debug.h"
|
||||
|
@ -257,9 +258,10 @@ void llvm::DisassembleInputMachO(StringRef Filename) {
|
|||
OwningPtr<const MCSubtargetInfo>
|
||||
STI(TheTarget->createMCSubtargetInfo(TripleName, "", ""));
|
||||
OwningPtr<const MCDisassembler> DisAsm(TheTarget->createMCDisassembler(*STI));
|
||||
OwningPtr<const MCRegisterInfo> MRI(TheTarget->createMCRegInfo(TripleName));
|
||||
int AsmPrinterVariant = AsmInfo->getAssemblerDialect();
|
||||
OwningPtr<MCInstPrinter> IP(TheTarget->createMCInstPrinter(
|
||||
AsmPrinterVariant, *AsmInfo, *STI));
|
||||
AsmPrinterVariant, *AsmInfo, *MRI, *STI));
|
||||
|
||||
if (!InstrAnalysis || !AsmInfo || !STI || !DisAsm || !IP) {
|
||||
errs() << "error: couldn't initialize disassembler for target "
|
||||
|
|
|
@ -26,6 +26,7 @@
|
|||
#include "llvm/MC/MCDisassembler.h"
|
||||
#include "llvm/MC/MCInst.h"
|
||||
#include "llvm/MC/MCInstPrinter.h"
|
||||
#include "llvm/MC/MCRegisterInfo.h"
|
||||
#include "llvm/MC/MCSubtargetInfo.h"
|
||||
#include "llvm/Support/Casting.h"
|
||||
#include "llvm/Support/CommandLine.h"
|
||||
|
@ -246,9 +247,15 @@ static void DisassembleObject(const ObjectFile *Obj, bool InlineRelocs) {
|
|||
return;
|
||||
}
|
||||
|
||||
OwningPtr<const MCRegisterInfo> MRI(TheTarget->createMCRegInfo(TripleName));
|
||||
if (!MRI) {
|
||||
errs() << "error: no register info for target " << TripleName << "\n";
|
||||
return;
|
||||
}
|
||||
|
||||
int AsmPrinterVariant = AsmInfo->getAssemblerDialect();
|
||||
OwningPtr<MCInstPrinter> IP(TheTarget->createMCInstPrinter(
|
||||
AsmPrinterVariant, *AsmInfo, *STI));
|
||||
AsmPrinterVariant, *AsmInfo, *MRI, *STI));
|
||||
if (!IP) {
|
||||
errs() << "error: no instruction printer for target " << TripleName
|
||||
<< '\n';
|
||||
|
|
Loading…
Reference in New Issue