1 //===-- AMDGPUInstPrinter.h - AMDGPU MC Inst -> ASM interface ---*- 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 //===----------------------------------------------------------------------===//
10 //===----------------------------------------------------------------------===//
12 #ifndef LLVM_LIB_TARGET_AMDGPU_MCTARGETDESC_AMDGPUINSTPRINTER_H
13 #define LLVM_LIB_TARGET_AMDGPU_MCTARGETDESC_AMDGPUINSTPRINTER_H
15 #include "AMDGPUMCTargetDesc.h"
16 #include "llvm/MC/MCInstPrinter.h"
20 class AMDGPUInstPrinter : public MCInstPrinter {
22 AMDGPUInstPrinter(const MCAsmInfo &MAI,
23 const MCInstrInfo &MII, const MCRegisterInfo &MRI)
24 : MCInstPrinter(MAI, MII, MRI) {}
26 //Autogenerated by tblgen
27 void printInstruction(const MCInst *MI, const MCSubtargetInfo &STI,
29 static const char *getRegisterName(unsigned RegNo,
30 unsigned AltIdx = AMDGPU::NoRegAltName);
32 void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot,
33 const MCSubtargetInfo &STI) override;
34 static void printRegOperand(unsigned RegNo, raw_ostream &O,
35 const MCRegisterInfo &MRI);
38 void printU4ImmOperand(const MCInst *MI, unsigned OpNo,
39 const MCSubtargetInfo &STI, raw_ostream &O);
40 void printU8ImmOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
41 void printU16ImmOperand(const MCInst *MI, unsigned OpNo,
42 const MCSubtargetInfo &STI, raw_ostream &O);
43 void printU4ImmDecOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
44 void printU8ImmDecOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
45 void printU16ImmDecOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
46 void printU32ImmOperand(const MCInst *MI, unsigned OpNo,
47 const MCSubtargetInfo &STI, raw_ostream &O);
48 void printNamedBit(const MCInst *MI, unsigned OpNo, raw_ostream &O,
50 void printOffen(const MCInst *MI, unsigned OpNo, raw_ostream &O);
51 void printIdxen(const MCInst *MI, unsigned OpNo, raw_ostream &O);
52 void printAddr64(const MCInst *MI, unsigned OpNo, raw_ostream &O);
53 void printMBUFOffset(const MCInst *MI, unsigned OpNo, raw_ostream &O);
54 void printOffset(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
56 void printFlatOffset(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
59 void printOffset0(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
61 void printOffset1(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
63 void printSMRDOffset8(const MCInst *MI, unsigned OpNo,
64 const MCSubtargetInfo &STI, raw_ostream &O);
65 void printSMRDOffset20(const MCInst *MI, unsigned OpNo,
66 const MCSubtargetInfo &STI, raw_ostream &O);
67 void printSMRDLiteralOffset(const MCInst *MI, unsigned OpNo,
68 const MCSubtargetInfo &STI, raw_ostream &O);
69 void printGDS(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
71 void printDLC(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
73 void printGLC(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
75 void printSLC(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
77 void printTFE(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
79 void printDMask(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
81 void printDim(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
83 void printUNorm(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
85 void printDA(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
87 void printR128A16(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
89 void printLWE(const MCInst *MI, unsigned OpNo,
90 const MCSubtargetInfo &STI, raw_ostream &O);
91 void printD16(const MCInst *MI, unsigned OpNo,
92 const MCSubtargetInfo &STI, raw_ostream &O);
93 void printExpCompr(const MCInst *MI, unsigned OpNo,
94 const MCSubtargetInfo &STI, raw_ostream &O);
95 void printExpVM(const MCInst *MI, unsigned OpNo,
96 const MCSubtargetInfo &STI, raw_ostream &O);
97 void printFORMAT(const MCInst *MI, unsigned OpNo,
98 const MCSubtargetInfo &STI, raw_ostream &O);
100 void printRegOperand(unsigned RegNo, raw_ostream &O);
101 void printVOPDst(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
103 void printVINTRPDst(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
105 void printImmediate16(uint32_t Imm, const MCSubtargetInfo &STI,
107 void printImmediateV216(uint32_t Imm, const MCSubtargetInfo &STI,
109 void printImmediate32(uint32_t Imm, const MCSubtargetInfo &STI,
111 void printImmediate64(uint64_t Imm, const MCSubtargetInfo &STI,
113 void printOperand(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
115 void printOperandAndFPInputMods(const MCInst *MI, unsigned OpNo,
116 const MCSubtargetInfo &STI, raw_ostream &O);
117 void printOperandAndIntInputMods(const MCInst *MI, unsigned OpNo,
118 const MCSubtargetInfo &STI, raw_ostream &O);
119 void printDPP8(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
121 void printDPPCtrl(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
123 void printRowMask(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
125 void printBankMask(const MCInst *MI, unsigned OpNo,
126 const MCSubtargetInfo &STI, raw_ostream &O);
127 void printBoundCtrl(const MCInst *MI, unsigned OpNo,
128 const MCSubtargetInfo &STI, raw_ostream &O);
129 void printFI(const MCInst *MI, unsigned OpNo,
130 const MCSubtargetInfo &STI, raw_ostream &O);
131 void printSDWASel(const MCInst *MI, unsigned OpNo, raw_ostream &O);
132 void printSDWADstSel(const MCInst *MI, unsigned OpNo,
133 const MCSubtargetInfo &STI, raw_ostream &O);
134 void printSDWASrc0Sel(const MCInst *MI, unsigned OpNo,
135 const MCSubtargetInfo &STI, raw_ostream &O);
136 void printSDWASrc1Sel(const MCInst *MI, unsigned OpNo,
137 const MCSubtargetInfo &STI, raw_ostream &O);
138 void printSDWADstUnused(const MCInst *MI, unsigned OpNo,
139 const MCSubtargetInfo &STI, raw_ostream &O);
140 void printPackedModifier(const MCInst *MI, StringRef Name, unsigned Mod,
142 void printOpSel(const MCInst *MI, unsigned OpNo,
143 const MCSubtargetInfo &STI, raw_ostream &O);
144 void printOpSelHi(const MCInst *MI, unsigned OpNo,
145 const MCSubtargetInfo &STI, raw_ostream &O);
146 void printNegLo(const MCInst *MI, unsigned OpNo,
147 const MCSubtargetInfo &STI, raw_ostream &O);
148 void printNegHi(const MCInst *MI, unsigned OpNo,
149 const MCSubtargetInfo &STI, raw_ostream &O);
150 void printInterpSlot(const MCInst *MI, unsigned OpNo,
151 const MCSubtargetInfo &STI, raw_ostream &O);
152 void printInterpAttr(const MCInst *MI, unsigned OpNo,
153 const MCSubtargetInfo &STI, raw_ostream &O);
154 void printInterpAttrChan(const MCInst *MI, unsigned OpNo,
155 const MCSubtargetInfo &STI, raw_ostream &O);
157 void printVGPRIndexMode(const MCInst *MI, unsigned OpNo,
158 const MCSubtargetInfo &STI, raw_ostream &O);
159 void printMemOperand(const MCInst *MI, unsigned OpNo,
160 const MCSubtargetInfo &STI, raw_ostream &O);
161 void printBLGP(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
163 void printCBSZ(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
165 void printABID(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
167 void printDefaultVccOperand(unsigned OpNo, const MCSubtargetInfo &STI,
171 template <unsigned N>
172 void printExpSrcN(const MCInst *MI, unsigned OpNo,
173 const MCSubtargetInfo &STI, raw_ostream &O);
174 void printExpSrc0(const MCInst *MI, unsigned OpNo,
175 const MCSubtargetInfo &STI, raw_ostream &O);
176 void printExpSrc1(const MCInst *MI, unsigned OpNo,
177 const MCSubtargetInfo &STI, raw_ostream &O);
178 void printExpSrc2(const MCInst *MI, unsigned OpNo,
179 const MCSubtargetInfo &STI, raw_ostream &O);
180 void printExpSrc3(const MCInst *MI, unsigned OpNo,
181 const MCSubtargetInfo &STI, raw_ostream &O);
182 void printExpTgt(const MCInst *MI, unsigned OpNo,
183 const MCSubtargetInfo &STI, raw_ostream &O);
186 static void printIfSet(const MCInst *MI, unsigned OpNo, raw_ostream &O,
187 StringRef Asm, StringRef Default = "");
188 static void printIfSet(const MCInst *MI, unsigned OpNo, raw_ostream &O,
191 void printAbs(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
193 void printHigh(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
195 void printClamp(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
197 void printClampSI(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
199 void printOModSI(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
201 void printLiteral(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
203 void printLast(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
205 void printNeg(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
207 void printOMOD(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
209 void printRel(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
211 void printUpdateExecMask(const MCInst *MI, unsigned OpNo,
212 const MCSubtargetInfo &STI, raw_ostream &O);
213 void printUpdatePred(const MCInst *MI, unsigned OpNo,
214 const MCSubtargetInfo &STI, raw_ostream &O);
215 void printWrite(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
217 void printBankSwizzle(const MCInst *MI, unsigned OpNo,
218 const MCSubtargetInfo &STI, raw_ostream &O);
219 void printRSel(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
221 void printCT(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
223 void printKCache(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
225 void printSendMsg(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
227 void printSwizzle(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
229 void printWaitFlag(const MCInst *MI, unsigned OpNo,
230 const MCSubtargetInfo &STI, raw_ostream &O);
231 void printHwreg(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
233 void printEndpgm(const MCInst *MI, unsigned OpNo, const MCSubtargetInfo &STI,
237 class R600InstPrinter : public MCInstPrinter {
239 R600InstPrinter(const MCAsmInfo &MAI, const MCInstrInfo &MII,
240 const MCRegisterInfo &MRI)
241 : MCInstPrinter(MAI, MII, MRI) {}
243 void printInst(const MCInst *MI, raw_ostream &O, StringRef Annot,
244 const MCSubtargetInfo &STI) override;
245 void printInstruction(const MCInst *MI, raw_ostream &O);
246 static const char *getRegisterName(unsigned RegNo);
248 void printAbs(const MCInst *MI, unsigned OpNo, raw_ostream &O);
249 void printBankSwizzle(const MCInst *MI, unsigned OpNo, raw_ostream &O);
250 void printClamp(const MCInst *MI, unsigned OpNo, raw_ostream &O);
251 void printCT(const MCInst *MI, unsigned OpNo, raw_ostream &O);
252 void printKCache(const MCInst *MI, unsigned OpNo, raw_ostream &O);
253 void printLast(const MCInst *MI, unsigned OpNo, raw_ostream &O);
254 void printLiteral(const MCInst *MI, unsigned OpNo, raw_ostream &O);
255 void printMemOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
256 void printNeg(const MCInst *MI, unsigned OpNo, raw_ostream &O);
257 void printOMOD(const MCInst *MI, unsigned OpNo, raw_ostream &O);
258 void printOperand(const MCInst *MI, unsigned OpNo, raw_ostream &O);
259 void printRel(const MCInst *MI, unsigned OpNo, raw_ostream &O);
260 void printRSel(const MCInst *MI, unsigned OpNo, raw_ostream &O);
261 void printUpdateExecMask(const MCInst *MI, unsigned OpNo, raw_ostream &O);
262 void printUpdatePred(const MCInst *MI, unsigned OpNo, raw_ostream &O);
263 void printWrite(const MCInst *MI, unsigned OpNo, raw_ostream &O);
266 } // End namespace llvm