SparcInstPrinter.h revision 36b56886974eae4f9c5ebc96befd3e7bfe5de338
1//===-- SparcInstPrinter.h - Convert Sparc MCInst to assembly syntax ------===//
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 an Sparc MCInst to a .s file.
11//
12//===----------------------------------------------------------------------===//
13
14#ifndef SparcINSTPRINTER_H
15#define SparcINSTPRINTER_H
16
17#include "llvm/MC/MCInstPrinter.h"
18#include "llvm/MC/MCSubtargetInfo.h"
19
20namespace llvm {
21
22class MCOperand;
23
24class SparcInstPrinter : public MCInstPrinter {
25  const MCSubtargetInfo &STI;
26public:
27 SparcInstPrinter(const MCAsmInfo &MAI,
28                  const MCInstrInfo &MII,
29                  const MCRegisterInfo &MRI,
30                  const MCSubtargetInfo &sti)
31   : MCInstPrinter(MAI, MII, MRI), STI(sti) {}
32
33  virtual void printRegName(raw_ostream &OS, unsigned RegNo) const;
34  virtual void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot);
35  bool printSparcAliasInstr(const MCInst *MI, raw_ostream &OS);
36  bool isV9() const;
37
38  // Autogenerated by tblgen.
39  void printInstruction(const MCInst *MI, raw_ostream &O);
40  bool printAliasInstr(const MCInst *MI, raw_ostream &O);
41  static const char *getRegisterName(unsigned RegNo);
42
43  void printOperand(const MCInst *MI, int opNum, raw_ostream &OS);
44  void printMemOperand(const MCInst *MI, int opNum, raw_ostream &OS,
45                       const char *Modifier = 0);
46  void printCCOperand(const MCInst *MI, int opNum, raw_ostream &OS);
47  bool printGetPCX(const MCInst *MI, unsigned OpNo, raw_ostream &OS);
48
49};
50} // end namespace llvm
51
52#endif
53