1//== XCoreInstPrinter.h - Convert XCore MCInst to assembly syntax -*- C++ -*-=//
2//
3//                     The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9///
10/// \file
11/// \brief This file contains the declaration of the XCoreInstPrinter class,
12/// which is used to print XCore MCInst to a .s file.
13///
14//===----------------------------------------------------------------------===//
15
16#ifndef XCOREINSTPRINTER_H
17#define XCOREINSTPRINTER_H
18#include "llvm/MC/MCInstPrinter.h"
19
20namespace llvm {
21
22class TargetMachine;
23
24class XCoreInstPrinter : public MCInstPrinter {
25public:
26  XCoreInstPrinter(const MCAsmInfo &MAI, const MCInstrInfo &MII,
27                  const MCRegisterInfo &MRI)
28    : MCInstPrinter(MAI, MII, MRI) {}
29
30  // Autogenerated by tblgen.
31  void printInstruction(const MCInst *MI, raw_ostream &O);
32  static const char *getRegisterName(unsigned RegNo);
33
34  void printRegName(raw_ostream &OS, unsigned RegNo) const override;
35  void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot) override;
36private:
37  void printInlineJT(const MCInst *MI, int opNum, raw_ostream &O);
38  void printInlineJT32(const MCInst *MI, int opNum, raw_ostream &O);
39  void printOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
40  void printMemOperand(const MCInst *MI, int opNum, raw_ostream &O);
41};
42} // end namespace llvm
43
44#endif
45