LLVM: llvm::SystemZInstPrinterCommon Class Reference (original) (raw)

#include "[Target/SystemZ/MCTargetDesc/SystemZInstPrinterCommon.h](SystemZInstPrinterCommon%5F8h%5Fsource.html)"

Public Member Functions
SystemZInstPrinterCommon (const MCAsmInfo &MAI, const MCInstrInfo &MII, const MCRegisterInfo &MRI)
void printAddress (const MCAsmInfo *MAI, MCRegister Base, const MCOperand &DispMO, MCRegister Index, raw_ostream &O)
void printOperand (const MCOperand &MO, const MCAsmInfo *MAI, raw_ostream &O)
virtual void printFormattedRegName (const MCAsmInfo *MAI, MCRegister Reg, raw_ostream &O)
void printRegName (raw_ostream &O, MCRegister Reg) override
Print the assembler register name.
Public Member Functions inherited from llvm::MCInstPrinter
MCInstPrinter (const MCAsmInfo &mai, const MCInstrInfo &mii, const MCRegisterInfo &mri)
virtual ~MCInstPrinter ()
virtual bool applyTargetSpecificCLOption (StringRef Opt)
Customize the printer according to a command line option.
void setCommentStream (raw_ostream &OS)
Specify a stream to emit comments to.
virtual std::pair< const char *, uint64_t > getMnemonic (const MCInst &MI) const =0
Returns a pair containing the mnemonic for MI and the number of bits left for further processing by printInstruction (generated by tablegen).
virtual void printInst (const MCInst *MI, uint64_t Address, StringRef Annot, const MCSubtargetInfo &STI, raw_ostream &OS)=0
Print the specified MCInst to the specified raw_ostream.
StringRef getOpcodeName (unsigned Opcode) const
Return the name of the specified opcode enum (e.g.
bool getUseMarkup () const
void setUseMarkup (bool Value)
bool getUseColor () const
void setUseColor (bool Value)
WithMarkup markup (raw_ostream &OS, Markup M)
bool getPrintImmHex () const
void setPrintImmHex (bool Value)
void setPrintHexStyle (HexStyle::Style Value)
void setPrintBranchImmAsAddress (bool Value)
void setSymbolizeOperands (bool Value)
void setMCInstrAnalysis (const MCInstrAnalysis *Value)
format_object< int64_t > formatImm (int64_t Value) const
Utility function to print immediates in decimal or hex.
format_object< int64_t > formatDec (int64_t Value) const
Utility functions to print decimal/hexadecimal values.
format_object< int64_t > formatHex (int64_t Value) const
format_object< uint64_t > formatHex (uint64_t Value) const
Protected Member Functions
template<unsigned N>
void printUImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
template<unsigned N>
void printSImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printOperand (const MCInst *MI, uint64_t, unsigned OpNum, raw_ostream &O)
void printBDAddrOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printBDXAddrOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printBDLAddrOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printBDRAddrOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printBDVAddrOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printLXAAddrOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printU1ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printU2ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printU3ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printU4ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printS8ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printU8ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printU12ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printS16ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printU16ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printS32ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printU32ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printU48ImmOperand (const MCInst *MI, int OpNum, raw_ostream &O)
void printPCRelOperand (const MCInst *MI, uint64_t Address, int OpNum, raw_ostream &O)
void printPCRelTLSOperand (const MCInst *MI, uint64_t Address, int OpNum, raw_ostream &O)
void printCond4Operand (const MCInst *MI, int OpNum, raw_ostream &O)
Protected Member Functions inherited from llvm::MCInstPrinter
void printAnnotation (raw_ostream &OS, StringRef Annot)
Utility function for printing annotations.
const char * matchAliasPatterns (const MCInst *MI, const MCSubtargetInfo *STI, const AliasMatchingData &M)
Helper for matching MCInsts to alias patterns when printing instructions.
Additional Inherited Members
Public Types inherited from llvm::MCInstPrinter
enum class Markup { Immediate, Register, Target, Memory }
Protected Attributes inherited from llvm::MCInstPrinter
raw_ostream * CommentStream = nullptr
A stream that comments can be emitted to if desired.
const MCAsmInfo & MAI
const MCInstrInfo & MII
const MCRegisterInfo & MRI
const MCInstrAnalysis * MIA = nullptr
bool UseMarkup = false
True if we are printing marked up assembly.
bool UseColor = false
True if we are printing colored assembly.
bool PrintAliases = true
True if we prefer aliases (e.g. nop) to raw mnemonics.
bool PrintImmHex = false
True if we are printing immediates as hex.
HexStyle::Style PrintHexStyle = HexStyle::C
Which style to use for printing hexadecimal values.
bool PrintBranchImmAsAddress = false
If true, a branch immediate (e.g.
bool SymbolizeOperands = false
If true, symbolize branch target and memory reference operands.
SmallVector< raw_ostream::Colors, 4 > ColorStack {raw_ostream::Colors::RESET}

Definition at line 25 of file SystemZInstPrinterCommon.h.

printAddress()

printBDAddrOperand()

printBDLAddrOperand()

void SystemZInstPrinterCommon::printBDLAddrOperand ( const MCInst * MI, int OpNum, raw_ostream & O ) protected

printBDRAddrOperand()

void SystemZInstPrinterCommon::printBDRAddrOperand ( const MCInst * MI, int OpNum, raw_ostream & O ) protected

printBDVAddrOperand()

void SystemZInstPrinterCommon::printBDVAddrOperand ( const MCInst * MI, int OpNum, raw_ostream & O ) protected

printBDXAddrOperand()

void SystemZInstPrinterCommon::printBDXAddrOperand ( const MCInst * MI, int OpNum, raw_ostream & O ) protected

printCond4Operand()

printFormattedRegName()

printLXAAddrOperand()

void SystemZInstPrinterCommon::printLXAAddrOperand ( const MCInst * MI, int OpNum, raw_ostream & O ) protected

printOperand() [1/3]

printOperand() [2/3]

printOperand() [3/3]

Definition at line 45 of file SystemZInstPrinterCommon.cpp.

References llvm::MCOperand::getExpr(), llvm::MCOperand::getImm(), llvm::MCOperand::getReg(), llvm::MCInstPrinter::Immediate, llvm::MCOperand::isExpr(), llvm::MCOperand::isImm(), llvm::MCOperand::isReg(), llvm_unreachable, llvm::MCInstPrinter::MAI, llvm::MCInstPrinter::markup(), and printRegName().

Referenced by printAddress(), printBDLAddrOperand(), printBDRAddrOperand(), printOperand(), and printOperand().

printPCRelOperand()

Definition at line 151 of file SystemZInstPrinterCommon.cpp.

References llvm::Address, llvm::dyn_cast(), llvm::MCInstPrinter::formatHex(), llvm::MCInstPrinter::formatImm(), llvm::MCOperand::getExpr(), llvm::MCOperand::getImm(), llvm::MCInstPrinter::Immediate, llvm::MCOperand::isImm(), llvm::MCInstPrinter::MAI, llvm::MCInstPrinter::markup(), MI, llvm::Offset, llvm::MCInstPrinter::PrintBranchImmAsAddress, and llvm::MCInstPrinter::Target.

Referenced by printPCRelTLSOperand().

printPCRelTLSOperand()

Definition at line 178 of file SystemZInstPrinterCommon.cpp.

References llvm::Address, llvm::cast(), llvm::MCOperand::getExpr(), llvm::MCSymbol::getName(), llvm::MCSymbolRefExpr::getSpecifier(), llvm::MCSymbolRefExpr::getSymbol(), llvm_unreachable, MI, printPCRelOperand(), llvm::SystemZ::S_TLSGD, and llvm::SystemZ::S_TLSLDM.

printRegName()

printS16ImmOperand()

printS32ImmOperand()

printS8ImmOperand()

printSImmOperand()

printU12ImmOperand()

printU16ImmOperand()

printU1ImmOperand()

printU2ImmOperand()

printU32ImmOperand()

printU3ImmOperand()

printU48ImmOperand()

printU4ImmOperand()

printU8ImmOperand()

printUImmOperand()

Definition at line 66 of file SystemZInstPrinterCommon.cpp.

References assert(), llvm::MCOperand::getExpr(), llvm::MCOperand::getImm(), llvm::MCInstPrinter::Immediate, llvm::MCOperand::isExpr(), llvm::isUInt(), llvm::MCInstPrinter::MAI, llvm::MCInstPrinter::markup(), and MI.

Referenced by printU12ImmOperand(), printU16ImmOperand(), printU1ImmOperand(), printU2ImmOperand(), printU32ImmOperand(), printU3ImmOperand(), printU48ImmOperand(), printU4ImmOperand(), and printU8ImmOperand().


The documentation for this class was generated from the following files: