//===-- M68kInstPrinter.h - Convert M68k MCInst to asm ----------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
///
/// \file
/// This file contains declarations for an M68k MCInst printer.
///
//===----------------------------------------------------------------------===//
#ifndef LLVM_LIB_TARGET_M68K_INSTPRINTER_M68KINSTPRINTER_H
#define LLVM_LIB_TARGET_M68K_INSTPRINTER_M68KINSTPRINTER_H
#include "M68kMemOperandPrinter.h"
#include "llvm/MC/MCInstPrinter.h"
namespace llvm {
class TargetMachine;
class M68kInstPrinter : public MCInstPrinter,
public M68kMemOperandPrinter<M68kInstPrinter, MCInst> {
friend class M68kMemOperandPrinter;
public:
M68kInstPrinter(const MCAsmInfo &MAI, const MCInstrInfo &MII,
const MCRegisterInfo &MRI)
: MCInstPrinter(MAI, MII, MRI) {}
// Autogenerated by tblgen.
void printInstruction(const MCInst *MI, uint64_t Address, raw_ostream &O);
static const char *getRegisterName(MCRegister Reg);
void printRegName(raw_ostream &OS, MCRegister Reg) const override;
void printInst(const MCInst *MI, uint64_t Address, StringRef Annot,
const MCSubtargetInfo &STI, raw_ostream &O) override;
bool printAliasInstr(const MCInst *MI, uint64_t Address, raw_ostream &OS);
void printCustomAliasOperand(const MCInst *MI, unsigned OpIdx,
unsigned PrintMethodIdx, raw_ostream &O);
std::pair<const char *, uint64_t> getMnemonic(const MCInst *MI) override;
private:
void printOperand(const MCInst *MI, unsigned opNum, raw_ostream &O);
void printImmediate(const MCInst *MI, unsigned opNum, raw_ostream &O);
/// Print register mask for MOVEM instruction in order D0-D7,A0-A7
void printMoveMask(const MCInst *MI, unsigned opNum, raw_ostream &O);
/// Print register mask for MOVEM instruction in order A7-A0,D7-D0
void printMoveMaskR(const MCInst *MI, unsigned opNum, raw_ostream &O);
void printDisp(const MCInst *MI, unsigned opNum, raw_ostream &O);
void printAbsMem(const MCInst *MI, unsigned opNum, raw_ostream &O);
//===----------------------------------------------------------------------===//
// Specializations
//===----------------------------------------------------------------------===//
//
void printPCRelImm(const MCInst *MI, uint64_t Address, unsigned opNum,
raw_ostream &O) {
printAbsMem(MI, opNum, O);
}
void printARI8Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIMem(MI, opNum, O);
}
void printARI16Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIMem(MI, opNum, O);
}
void printARI32Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIMem(MI, opNum, O);
}
void printARIPI8Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIPIMem(MI, opNum, O);
}
void printARIPI16Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIPIMem(MI, opNum, O);
}
void printARIPI32Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIPIMem(MI, opNum, O);
}
void printARIPD8Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIPDMem(MI, opNum, O);
}
void printARIPD16Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIPDMem(MI, opNum, O);
}
void printARIPD32Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIPDMem(MI, opNum, O);
}
void printARID8Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIDMem(MI, opNum, O);
}
void printARID16Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIDMem(MI, opNum, O);
}
void printARID32Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIDMem(MI, opNum, O);
}
void printARII8Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIIMem(MI, opNum, O);
}
void printARII16Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIIMem(MI, opNum, O);
}
void printARII32Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printARIIMem(MI, opNum, O);
}
void printAS8Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printAbsMem(MI, opNum, O);
}
void printAS16Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printAbsMem(MI, opNum, O);
}
void printAS32Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printAbsMem(MI, opNum, O);
}
void printAL8Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printAbsMem(MI, opNum, O);
}
void printAL16Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printAbsMem(MI, opNum, O);
}
void printAL32Mem(const MCInst *MI, unsigned opNum, raw_ostream &O) {
printAbsMem(MI, opNum, O);
}
void printPCD8Mem(const MCInst *MI, uint64_t Address, unsigned opNum,
raw_ostream &O) {
printPCDMem(MI, Address, opNum, O);
}
void printPCD16Mem(const MCInst *MI, uint64_t Address, unsigned opNum,
raw_ostream &O) {
printPCDMem(MI, Address, opNum, O);
}
void printPCD32Mem(const MCInst *MI, uint64_t Address, unsigned opNum,
raw_ostream &O) {
printPCDMem(MI, Address, opNum, O);
}
void printPCI8Mem(const MCInst *MI, uint64_t Address, unsigned opNum,
raw_ostream &O) {
printPCIMem(MI, Address, opNum, O);
}
void printPCI16Mem(const MCInst *MI, uint64_t Address, unsigned opNum,
raw_ostream &O) {
printPCIMem(MI, Address, opNum, O);
}
void printPCI32Mem(const MCInst *MI, uint64_t Address, unsigned opNum,
raw_ostream &O) {
printPCIMem(MI, Address, opNum, O);
}
};
} // end namespace llvm
#endif // LLVM_LIB_TARGET_M68K_INSTPRINTER_M68KINSTPRINTER_H