mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-17 03:30:28 +00:00
41400da31e
2. Parsing .word directive in MBlaze asm parser 3. Fixing hack where memory instructions reversed order of last two parameters 4. Fixing many improperly encoded instructions 5. Support parsing special instructions (MFS,MTS,etc.) 6. Removing unused functions from inst printer git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@118941 91177308-0d34-0410-b5e6-96231b3b80d8
70 lines
2.2 KiB
C++
70 lines
2.2 KiB
C++
//===-- MBlazeInstPrinter.cpp - Convert MBlaze MCInst to assembly syntax --===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This class prints an MBlaze MCInst to a .s file.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#define DEBUG_TYPE "asm-printer"
|
|
#include "MBlaze.h"
|
|
#include "MBlazeInstPrinter.h"
|
|
#include "llvm/MC/MCInst.h"
|
|
#include "llvm/MC/MCAsmInfo.h"
|
|
#include "llvm/MC/MCExpr.h"
|
|
#include "llvm/Support/ErrorHandling.h"
|
|
#include "llvm/Support/FormattedStream.h"
|
|
using namespace llvm;
|
|
|
|
|
|
// Include the auto-generated portion of the assembly writer.
|
|
#include "MBlazeGenAsmWriter.inc"
|
|
|
|
void MBlazeInstPrinter::printInst(const MCInst *MI, raw_ostream &O) {
|
|
printInstruction(MI, O);
|
|
}
|
|
|
|
void MBlazeInstPrinter::printOperand(const MCInst *MI, unsigned OpNo,
|
|
raw_ostream &O, const char *Modifier) {
|
|
assert((Modifier == 0 || Modifier[0] == 0) && "No modifiers supported");
|
|
const MCOperand &Op = MI->getOperand(OpNo);
|
|
if (Op.isReg()) {
|
|
O << getRegisterName(Op.getReg());
|
|
} else if (Op.isImm()) {
|
|
O << (int32_t)Op.getImm();
|
|
} else {
|
|
assert(Op.isExpr() && "unknown operand kind in printOperand");
|
|
O << *Op.getExpr();
|
|
}
|
|
}
|
|
|
|
void MBlazeInstPrinter::printFSLImm(const MCInst *MI, int OpNo,
|
|
raw_ostream &O) {
|
|
const MCOperand &MO = MI->getOperand(OpNo);
|
|
if (MO.isImm())
|
|
O << "rfsl" << MO.getImm();
|
|
else
|
|
printOperand(MI, OpNo, O, NULL);
|
|
}
|
|
|
|
void MBlazeInstPrinter::printUnsignedImm(const MCInst *MI, int OpNo,
|
|
raw_ostream &O) {
|
|
const MCOperand &MO = MI->getOperand(OpNo);
|
|
if (MO.isImm())
|
|
O << MO.getImm();
|
|
else
|
|
printOperand(MI, OpNo, O, NULL);
|
|
}
|
|
|
|
void MBlazeInstPrinter::printMemOperand(const MCInst *MI, int OpNo,
|
|
raw_ostream &O, const char *Modifier) {
|
|
printOperand(MI, OpNo, O, NULL);
|
|
O << ", ";
|
|
printOperand(MI, OpNo+1, O, NULL);
|
|
}
|