xref: /aosp_15_r20/external/llvm/lib/MC/MCInst.cpp (revision 9880d6810fe72a1726cb53787c6711e909410d58)
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 Worker void 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 Worker LLVM_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 Worker void 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 Worker void 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 Worker LLVM_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