1 //===- lib/MC/MCInst.cpp - MCInst implementation --------------------------===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 #include "llvm/MC/MCInst.h"
10 #include "llvm/Config/llvm-config.h"
11 #include "llvm/MC/MCExpr.h"
12 #include "llvm/MC/MCInstPrinter.h"
13 #include "llvm/MC/MCRegisterInfo.h"
14 #include "llvm/Support/Casting.h"
15 #include "llvm/Support/Compiler.h"
16 #include "llvm/Support/Debug.h"
17 #include "llvm/Support/raw_ostream.h"
21 void MCOperand::print(raw_ostream
&OS
, const MCRegisterInfo
*RegInfo
) const {
28 OS
<< RegInfo
->getName(getReg());
32 OS
<< "Imm:" << getImm();
34 OS
<< "SFPImm:" << bit_cast
<float>(getSFPImm());
36 OS
<< "DFPImm:" << bit_cast
<double>(getDFPImm());
38 OS
<< "Expr:(" << *getExpr() << ")";
39 } else if (isInst()) {
41 getInst()->print(OS
, RegInfo
);
48 bool MCOperand::evaluateAsConstantImm(int64_t &Imm
) const {
56 bool MCOperand::isBareSymbolRef() const {
58 "isBareSymbolRef expects only expressions");
59 const MCExpr
*Expr
= getExpr();
60 MCExpr::ExprKind Kind
= getExpr()->getKind();
61 return Kind
== MCExpr::SymbolRef
&&
62 cast
<MCSymbolRefExpr
>(Expr
)->getKind() == MCSymbolRefExpr::VK_None
;
65 #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
66 LLVM_DUMP_METHOD
void MCOperand::dump() const {
72 void MCInst::print(raw_ostream
&OS
, const MCRegisterInfo
*RegInfo
) const {
73 OS
<< "<MCInst " << getOpcode();
74 for (unsigned i
= 0, e
= getNumOperands(); i
!= e
; ++i
) {
76 getOperand(i
).print(OS
, RegInfo
);
81 void MCInst::dump_pretty(raw_ostream
&OS
, const MCInstPrinter
*Printer
,
83 const MCRegisterInfo
*RegInfo
) const {
84 StringRef InstName
= Printer
? Printer
->getOpcodeName(getOpcode()) : "";
85 dump_pretty(OS
, InstName
, Separator
, RegInfo
);
88 void MCInst::dump_pretty(raw_ostream
&OS
, StringRef Name
, StringRef Separator
,
89 const MCRegisterInfo
*RegInfo
) const {
90 OS
<< "<MCInst #" << getOpcode();
92 // Show the instruction opcode name if we have it.
96 for (unsigned i
= 0, e
= getNumOperands(); i
!= e
; ++i
) {
98 getOperand(i
).print(OS
, RegInfo
);
103 #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
104 LLVM_DUMP_METHOD
void MCInst::dump() const {