2012-02-17 09:23:50 +08:00
|
|
|
//=== MipsInstPrinter.h - Convert Mips MCInst to assembly syntax -*- C++ -*-==//
|
2011-07-08 07:56:50 +08:00
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This class prints a Mips MCInst to a .s file.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2014-08-14 00:26:38 +08:00
|
|
|
#ifndef LLVM_LIB_TARGET_MIPS_INSTPRINTER_MIPSINSTPRINTER_H
|
|
|
|
#define LLVM_LIB_TARGET_MIPS_INSTPRINTER_MIPSINSTPRINTER_H
|
2011-07-08 07:56:50 +08:00
|
|
|
#include "llvm/MC/MCInstPrinter.h"
|
|
|
|
|
|
|
|
namespace llvm {
|
2012-06-02 18:20:22 +08:00
|
|
|
// These enumeration declarations were originally in MipsInstrInfo.h but
|
2011-07-08 07:56:50 +08:00
|
|
|
// had to be moved here to avoid circular dependencies between
|
2012-02-28 15:46:26 +08:00
|
|
|
// LLVMMipsCodeGen and LLVMMipsAsmPrinter.
|
2011-07-08 07:56:50 +08:00
|
|
|
namespace Mips {
|
|
|
|
// Mips Branch Codes
|
|
|
|
enum FPBranchCode {
|
|
|
|
BRANCH_F,
|
|
|
|
BRANCH_T,
|
|
|
|
BRANCH_FL,
|
|
|
|
BRANCH_TL,
|
|
|
|
BRANCH_INVALID
|
|
|
|
};
|
|
|
|
|
|
|
|
// Mips Condition Codes
|
|
|
|
enum CondCode {
|
|
|
|
// To be used with float branch True
|
|
|
|
FCOND_F,
|
|
|
|
FCOND_UN,
|
|
|
|
FCOND_OEQ,
|
|
|
|
FCOND_UEQ,
|
|
|
|
FCOND_OLT,
|
|
|
|
FCOND_ULT,
|
|
|
|
FCOND_OLE,
|
|
|
|
FCOND_ULE,
|
|
|
|
FCOND_SF,
|
|
|
|
FCOND_NGLE,
|
|
|
|
FCOND_SEQ,
|
|
|
|
FCOND_NGL,
|
|
|
|
FCOND_LT,
|
|
|
|
FCOND_NGE,
|
|
|
|
FCOND_LE,
|
|
|
|
FCOND_NGT,
|
|
|
|
|
|
|
|
// To be used with float branch False
|
|
|
|
// This conditions have the same mnemonic as the
|
|
|
|
// above ones, but are used with a branch False;
|
|
|
|
FCOND_T,
|
|
|
|
FCOND_OR,
|
|
|
|
FCOND_UNE,
|
|
|
|
FCOND_ONE,
|
|
|
|
FCOND_UGE,
|
|
|
|
FCOND_OGE,
|
|
|
|
FCOND_UGT,
|
|
|
|
FCOND_OGT,
|
|
|
|
FCOND_ST,
|
|
|
|
FCOND_GLE,
|
|
|
|
FCOND_SNE,
|
|
|
|
FCOND_GL,
|
|
|
|
FCOND_NLT,
|
|
|
|
FCOND_GE,
|
|
|
|
FCOND_NLE,
|
|
|
|
FCOND_GT
|
|
|
|
};
|
|
|
|
|
|
|
|
const char *MipsFCCToString(Mips::CondCode CC);
|
|
|
|
} // end namespace Mips
|
|
|
|
|
|
|
|
class MipsInstPrinter : public MCInstPrinter {
|
|
|
|
public:
|
2012-04-02 14:09:36 +08:00
|
|
|
MipsInstPrinter(const MCAsmInfo &MAI, const MCInstrInfo &MII,
|
|
|
|
const MCRegisterInfo &MRI)
|
|
|
|
: MCInstPrinter(MAI, MII, MRI) {}
|
2012-02-28 15:46:26 +08:00
|
|
|
|
2011-07-08 07:56:50 +08:00
|
|
|
// Autogenerated by tblgen.
|
|
|
|
void printInstruction(const MCInst *MI, raw_ostream &O);
|
|
|
|
static const char *getRegisterName(unsigned RegNo);
|
2012-02-28 15:46:26 +08:00
|
|
|
|
2014-04-29 15:58:02 +08:00
|
|
|
void printRegName(raw_ostream &OS, unsigned RegNo) const override;
|
2015-03-28 04:36:02 +08:00
|
|
|
void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot,
|
|
|
|
const MCSubtargetInfo &STI) override;
|
2012-02-28 15:46:26 +08:00
|
|
|
|
2013-02-05 16:32:10 +08:00
|
|
|
bool printAliasInstr(const MCInst *MI, raw_ostream &OS);
|
2014-05-13 02:04:06 +08:00
|
|
|
void printCustomAliasOperand(const MCInst *MI, unsigned OpIdx,
|
|
|
|
unsigned PrintMethodIdx, raw_ostream &O);
|
2013-02-05 16:32:10 +08:00
|
|
|
|
2011-07-08 07:56:50 +08:00
|
|
|
private:
|
|
|
|
void printOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
|
2016-03-01 00:06:38 +08:00
|
|
|
template <unsigned Bits, unsigned Offset = 0>
|
|
|
|
void printUImm(const MCInst *MI, int opNum, raw_ostream &O);
|
2011-07-08 07:56:50 +08:00
|
|
|
void printMemOperand(const MCInst *MI, int opNum, raw_ostream &O);
|
|
|
|
void printMemOperandEA(const MCInst *MI, int opNum, raw_ostream &O);
|
2016-09-09 19:06:01 +08:00
|
|
|
void printFCCOperand(const MCInst *MI, int opNum, raw_ostream &O);
|
2014-12-16 22:59:10 +08:00
|
|
|
void printRegisterPair(const MCInst *MI, int opNum, raw_ostream &O);
|
2013-09-24 22:20:00 +08:00
|
|
|
void printSHFMask(const MCInst *MI, int opNum, raw_ostream &O);
|
[mips] Print instructions "beq", "bne" and "or" using assembler pseudo
instructions "beqz", "bnez" and "move", when possible.
beq $2, $zero, $L1 => beqz $2, $L1
bne $2, $zero, $L1 => bnez $2, $L1
or $2, $3, $zero => move $2, $3
llvm-svn: 187229
2013-07-27 02:34:25 +08:00
|
|
|
|
|
|
|
bool printAlias(const char *Str, const MCInst &MI, unsigned OpNo,
|
|
|
|
raw_ostream &OS);
|
|
|
|
bool printAlias(const char *Str, const MCInst &MI, unsigned OpNo0,
|
|
|
|
unsigned OpNo1, raw_ostream &OS);
|
|
|
|
bool printAlias(const MCInst &MI, raw_ostream &OS);
|
2013-12-09 00:51:52 +08:00
|
|
|
void printSaveRestore(const MCInst *MI, raw_ostream &O);
|
2014-11-20 00:44:02 +08:00
|
|
|
void printRegisterList(const MCInst *MI, int opNum, raw_ostream &O);
|
2011-07-08 07:56:50 +08:00
|
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
|
|
|
|
#endif
|