1*9880d681SAndroid Build Coastguard Worker //===- lib/MC/MCInst.cpp - MCInst implementation --------------------------===// 2*9880d681SAndroid Build Coastguard Worker // 3*9880d681SAndroid Build Coastguard Worker // The LLVM Compiler Infrastructure 4*9880d681SAndroid Build Coastguard Worker // 5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source 6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details. 7*9880d681SAndroid Build Coastguard Worker // 8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 9*9880d681SAndroid Build Coastguard Worker 10*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCInst.h" 11*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCExpr.h" 12*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCInstPrinter.h" 13*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/Debug.h" 14*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/raw_ostream.h" 15*9880d681SAndroid Build Coastguard Worker 16*9880d681SAndroid Build Coastguard Worker using namespace llvm; 17*9880d681SAndroid Build Coastguard Worker print(raw_ostream & OS) const18*9880d681SAndroid Build Coastguard Workervoid MCOperand::print(raw_ostream &OS) const { 19*9880d681SAndroid Build Coastguard Worker OS << "<MCOperand "; 20*9880d681SAndroid Build Coastguard Worker if (!isValid()) 21*9880d681SAndroid Build Coastguard Worker OS << "INVALID"; 22*9880d681SAndroid Build Coastguard Worker else if (isReg()) 23*9880d681SAndroid Build Coastguard Worker OS << "Reg:" << getReg(); 24*9880d681SAndroid Build Coastguard Worker else if (isImm()) 25*9880d681SAndroid Build Coastguard Worker OS << "Imm:" << getImm(); 26*9880d681SAndroid Build Coastguard Worker else if (isFPImm()) 27*9880d681SAndroid Build Coastguard Worker OS << "FPImm:" << getFPImm(); 28*9880d681SAndroid Build Coastguard Worker else if (isExpr()) { 29*9880d681SAndroid Build Coastguard Worker OS << "Expr:(" << *getExpr() << ")"; 30*9880d681SAndroid Build Coastguard Worker } else if (isInst()) { 31*9880d681SAndroid Build Coastguard Worker OS << "Inst:(" << *getInst() << ")"; 32*9880d681SAndroid Build Coastguard Worker } else 33*9880d681SAndroid Build Coastguard Worker OS << "UNDEFINED"; 34*9880d681SAndroid Build Coastguard Worker OS << ">"; 35*9880d681SAndroid Build Coastguard Worker } 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Worker #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) dump() const38*9880d681SAndroid Build Coastguard WorkerLLVM_DUMP_METHOD void MCOperand::dump() const { 39*9880d681SAndroid Build Coastguard Worker print(dbgs()); 40*9880d681SAndroid Build Coastguard Worker dbgs() << "\n"; 41*9880d681SAndroid Build Coastguard Worker } 42*9880d681SAndroid Build Coastguard Worker #endif 43*9880d681SAndroid Build Coastguard Worker print(raw_ostream & OS) const44*9880d681SAndroid Build Coastguard Workervoid MCInst::print(raw_ostream &OS) const { 45*9880d681SAndroid Build Coastguard Worker OS << "<MCInst " << getOpcode(); 46*9880d681SAndroid Build Coastguard Worker for (unsigned i = 0, e = getNumOperands(); i != e; ++i) { 47*9880d681SAndroid Build Coastguard Worker OS << " "; 48*9880d681SAndroid Build Coastguard Worker getOperand(i).print(OS); 49*9880d681SAndroid Build Coastguard Worker } 50*9880d681SAndroid Build Coastguard Worker OS << ">"; 51*9880d681SAndroid Build Coastguard Worker } 52*9880d681SAndroid Build Coastguard Worker dump_pretty(raw_ostream & OS,const MCInstPrinter * Printer,StringRef Separator) const53*9880d681SAndroid Build Coastguard Workervoid MCInst::dump_pretty(raw_ostream &OS, const MCInstPrinter *Printer, 54*9880d681SAndroid Build Coastguard Worker StringRef Separator) const { 55*9880d681SAndroid Build Coastguard Worker OS << "<MCInst #" << getOpcode(); 56*9880d681SAndroid Build Coastguard Worker 57*9880d681SAndroid Build Coastguard Worker // Show the instruction opcode name if we have access to a printer. 58*9880d681SAndroid Build Coastguard Worker if (Printer) 59*9880d681SAndroid Build Coastguard Worker OS << ' ' << Printer->getOpcodeName(getOpcode()); 60*9880d681SAndroid Build Coastguard Worker 61*9880d681SAndroid Build Coastguard Worker for (unsigned i = 0, e = getNumOperands(); i != e; ++i) { 62*9880d681SAndroid Build Coastguard Worker OS << Separator; 63*9880d681SAndroid Build Coastguard Worker getOperand(i).print(OS); 64*9880d681SAndroid Build Coastguard Worker } 65*9880d681SAndroid Build Coastguard Worker OS << ">"; 66*9880d681SAndroid Build Coastguard Worker } 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Worker #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) dump() const69*9880d681SAndroid Build Coastguard WorkerLLVM_DUMP_METHOD void MCInst::dump() const { 70*9880d681SAndroid Build Coastguard Worker print(dbgs()); 71*9880d681SAndroid Build Coastguard Worker dbgs() << "\n"; 72*9880d681SAndroid Build Coastguard Worker } 73*9880d681SAndroid Build Coastguard Worker #endif 74