1 //===- AsmWriterInst.h - Classes encapsulating a printable inst -*- C++ -*-===//
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 // These classes implement a parser for assembly strings. The parser splits
10 // the string into operands, which can be literal strings (the constant bits of
11 // the string), actual operands (i.e., operands from the MachineInstr), and
12 // dynamically-generated text, specified by raw C++ code.
14 //===----------------------------------------------------------------------===//
16 #ifndef LLVM_UTILS_TABLEGEN_ASMWRITERINST_H
17 #define LLVM_UTILS_TABLEGEN_ASMWRITERINST_H
23 class CodeGenInstruction
;
25 struct AsmWriterOperand
{
27 // Output this text surrounded by quotes to the asm.
29 // This is the name of a routine to call to print the operand.
30 isMachineInstrOperand
,
31 // Output this text verbatim to the asm writer. It is code that
32 // will output some text to the asm.
33 isLiteralStatementOperand
36 /// MiOpNo - For isMachineInstrOperand, this is the operand number of the
37 /// machine instruction.
40 /// Str - For isLiteralTextOperand, this IS the literal text. For
41 /// isMachineInstrOperand, this is the PrinterMethodName for the operand..
42 /// For isLiteralStatementOperand, this is the code to insert verbatim
43 /// into the asm writer.
46 /// MiModifier - For isMachineInstrOperand, this is the modifier string for
47 /// an operand, specified with syntax like ${opname:modifier}.
48 std::string MiModifier
;
52 // To make VS STL happy
53 AsmWriterOperand(OpType op
= isLiteralTextOperand
):OperandType(op
) {}
55 AsmWriterOperand(const std::string
&LitStr
,
56 OpType op
= isLiteralTextOperand
)
57 : OperandType(op
), Str(LitStr
) {}
59 AsmWriterOperand(const std::string
&Printer
, unsigned _MIOpNo
,
60 const std::string
&Modifier
,
61 OpType op
= isMachineInstrOperand
, bool PCRel
= false)
62 : OperandType(op
), MIOpNo(_MIOpNo
), Str(Printer
), MiModifier(Modifier
),
65 bool operator!=(const AsmWriterOperand
&Other
) const {
66 if (OperandType
!= Other
.OperandType
|| Str
!= Other
.Str
) return true;
67 if (OperandType
== isMachineInstrOperand
)
68 return MIOpNo
!= Other
.MIOpNo
|| MiModifier
!= Other
.MiModifier
||
72 bool operator==(const AsmWriterOperand
&Other
) const {
73 return !operator!=(Other
);
76 /// getCode - Return the code that prints this operand.
77 std::string
getCode(bool PassSubtarget
) const;
82 std::vector
<AsmWriterOperand
> Operands
;
83 const CodeGenInstruction
*CGI
;
86 AsmWriterInst(const CodeGenInstruction
&CGI
, unsigned CGIIndex
,
89 /// MatchesAllButOneOp - If this instruction is exactly identical to the
90 /// specified instruction except for one differing operand, return the
91 /// differing operand number. Otherwise return ~0.
92 unsigned MatchesAllButOneOp(const AsmWriterInst
&Other
) const;
95 void AddLiteralString(const std::string
&Str
) {
96 // If the last operand was already a literal text string, append this to
97 // it, otherwise add a new operand.
98 if (!Operands
.empty() &&
99 Operands
.back().OperandType
== AsmWriterOperand::isLiteralTextOperand
)
100 Operands
.back().Str
.append(Str
);
102 Operands
.push_back(AsmWriterOperand(Str
));