blob: f378c6f18dac21cc00058d85ea4c0f63714c99c0 [file] [log] [blame]
Alex Bradbury2fee9ea2017-08-15 13:08:29 +00001//===-- RISCVInstPrinter.h - Convert RISCV MCInst to asm 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// This class prints a RISCV MCInst to a .s file.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef LLVM_LIB_TARGET_RISCV_INSTPRINTER_RISCVINSTPRINTER_H
15#define LLVM_LIB_TARGET_RISCV_INSTPRINTER_RISCVINSTPRINTER_H
16
17#include "MCTargetDesc/RISCVMCTargetDesc.h"
18#include "llvm/MC/MCInstPrinter.h"
19
20namespace llvm {
21class MCOperand;
22
23class RISCVInstPrinter : public MCInstPrinter {
24public:
25 RISCVInstPrinter(const MCAsmInfo &MAI, const MCInstrInfo &MII,
26 const MCRegisterInfo &MRI)
27 : MCInstPrinter(MAI, MII, MRI) {}
28
29 void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot,
30 const MCSubtargetInfo &STI) override;
31 void printRegName(raw_ostream &O, unsigned RegNo) const override;
32
33 void printOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O,
34 const char *Modifier = nullptr);
35
36 // Autogenerated by tblgen.
37 void printInstruction(const MCInst *MI, raw_ostream &O);
38 static const char *getRegisterName(unsigned RegNo,
39 unsigned AltIdx = RISCV::ABIRegAltName);
40};
41}
42
43#endif