mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-30 16:17:05 +00:00 
			
		
		
		
	git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@170320 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //== XCoreInstPrinter.h - Convert XCore MCInst to assembly syntax -*- C++ -*-=//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is distributed under the University of Illinois Open Source
 | |
| // License. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| ///
 | |
| /// \file
 | |
| /// \brief This file contains the declaration of the XCoreInstPrinter class,
 | |
| /// which is used to print XCore MCInst to a .s file.
 | |
| ///
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| #ifndef XCOREINSTPRINTER_H
 | |
| #define XCOREINSTPRINTER_H
 | |
| #include "llvm/MC/MCInstPrinter.h"
 | |
| 
 | |
| namespace llvm {
 | |
| 
 | |
| class TargetMachine;
 | |
| 
 | |
| class XCoreInstPrinter : public MCInstPrinter {
 | |
| public:
 | |
|   XCoreInstPrinter(const MCAsmInfo &MAI, const MCInstrInfo &MII,
 | |
|                   const MCRegisterInfo &MRI)
 | |
|     : MCInstPrinter(MAI, MII, MRI) {}
 | |
| 
 | |
|   // Autogenerated by tblgen.
 | |
|   void printInstruction(const MCInst *MI, raw_ostream &O);
 | |
|   static const char *getRegisterName(unsigned RegNo);
 | |
| 
 | |
|   virtual void printRegName(raw_ostream &OS, unsigned RegNo) const;
 | |
|   virtual void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot);
 | |
| private:
 | |
|   void printInlineJT(const MCInst *MI, int opNum, raw_ostream &O);
 | |
|   void printInlineJT32(const MCInst *MI, int opNum, raw_ostream &O);
 | |
|   void printOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
 | |
|   void printMemOperand(const MCInst *MI, int opNum, raw_ostream &O);
 | |
| };
 | |
| } // end namespace llvm
 | |
| 
 | |
| #endif
 |