blob: 56a6a0413c8a782b773ccf5ae50d15621fe7cc4b [file] [log] [blame]
Tom Stellard75aadc22012-12-11 21:25:42 +00001//===-- AMDGPUInstPrinter.cpp - AMDGPU MC Inst -> ASM ---------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8// \file
9//===----------------------------------------------------------------------===//
10
11#include "AMDGPUInstPrinter.h"
Chandler Carruthd9903882015-01-14 11:23:27 +000012#include "SIDefines.h"
Konstantin Zhuravlyov836cbff2016-09-30 17:01:40 +000013#include "MCTargetDesc/AMDGPUMCTargetDesc.h"
Artem Tamazov6edc1352016-05-26 17:00:33 +000014#include "Utils/AMDGPUAsmUtils.h"
Konstantin Zhuravlyov836cbff2016-09-30 17:01:40 +000015#include "Utils/AMDGPUBaseInfo.h"
Christian Konigbf114b42013-02-21 15:17:22 +000016#include "llvm/MC/MCExpr.h"
Benjamin Kramerd78bb462013-05-23 17:10:37 +000017#include "llvm/MC/MCInst.h"
Matt Arsenault303011a2014-12-17 21:04:08 +000018#include "llvm/MC/MCInstrInfo.h"
Matt Arsenault4d7d3832014-04-15 22:32:49 +000019#include "llvm/MC/MCRegisterInfo.h"
Konstantin Zhuravlyov836cbff2016-09-30 17:01:40 +000020#include "llvm/MC/MCSubtargetInfo.h"
Matt Arsenault4d7d3832014-04-15 22:32:49 +000021#include "llvm/Support/MathExtras.h"
Craig Topperdaf2e3f2015-12-25 22:10:01 +000022#include "llvm/Support/raw_ostream.h"
Tom Stellard75aadc22012-12-11 21:25:42 +000023
Artem Tamazoveb4d5a92016-04-13 16:18:41 +000024#include <string>
25
Tom Stellard75aadc22012-12-11 21:25:42 +000026using namespace llvm;
Konstantin Zhuravlyov836cbff2016-09-30 17:01:40 +000027using namespace llvm::AMDGPU;
Tom Stellard75aadc22012-12-11 21:25:42 +000028
29void AMDGPUInstPrinter::printInst(const MCInst *MI, raw_ostream &OS,
Akira Hatanakab46d0232015-03-27 20:36:02 +000030 StringRef Annot, const MCSubtargetInfo &STI) {
Vincent Lejeunef97af792013-05-02 21:52:30 +000031 OS.flush();
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +000032 printInstruction(MI, STI, OS);
Tom Stellard75aadc22012-12-11 21:25:42 +000033 printAnnotation(OS, Annot);
34}
35
Sam Koltondfa29f72016-03-09 12:29:31 +000036void AMDGPUInstPrinter::printU4ImmOperand(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +000037 raw_ostream &O) {
Sam Koltondfa29f72016-03-09 12:29:31 +000038 O << formatHex(MI->getOperand(OpNo).getImm() & 0xf);
39}
40
Matt Arsenault4d7d3832014-04-15 22:32:49 +000041void AMDGPUInstPrinter::printU8ImmOperand(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +000042 raw_ostream &O) {
Matt Arsenault4d7d3832014-04-15 22:32:49 +000043 O << formatHex(MI->getOperand(OpNo).getImm() & 0xff);
44}
45
46void AMDGPUInstPrinter::printU16ImmOperand(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +000047 const MCSubtargetInfo &STI,
Matt Arsenault4d7d3832014-04-15 22:32:49 +000048 raw_ostream &O) {
49 O << formatHex(MI->getOperand(OpNo).getImm() & 0xffff);
50}
51
Sam Koltondfa29f72016-03-09 12:29:31 +000052void AMDGPUInstPrinter::printU4ImmDecOperand(const MCInst *MI, unsigned OpNo,
53 raw_ostream &O) {
54 O << formatDec(MI->getOperand(OpNo).getImm() & 0xf);
55}
56
Matt Arsenault61cc9082014-10-10 22:16:07 +000057void AMDGPUInstPrinter::printU8ImmDecOperand(const MCInst *MI, unsigned OpNo,
58 raw_ostream &O) {
59 O << formatDec(MI->getOperand(OpNo).getImm() & 0xff);
60}
61
62void AMDGPUInstPrinter::printU16ImmDecOperand(const MCInst *MI, unsigned OpNo,
63 raw_ostream &O) {
64 O << formatDec(MI->getOperand(OpNo).getImm() & 0xffff);
65}
66
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +000067void AMDGPUInstPrinter::printU32ImmOperand(const MCInst *MI, unsigned OpNo,
68 const MCSubtargetInfo &STI,
69 raw_ostream &O) {
70 O << formatHex(MI->getOperand(OpNo).getImm() & 0xffffffff);
71}
72
73void AMDGPUInstPrinter::printNamedBit(const MCInst *MI, unsigned OpNo,
74 raw_ostream &O, StringRef BitName) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +000075 if (MI->getOperand(OpNo).getImm()) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +000076 O << ' ' << BitName;
Nikolay Haustov2f684f12016-02-26 09:51:05 +000077 }
78}
79
Tom Stellard229d5e62014-08-05 14:48:12 +000080void AMDGPUInstPrinter::printOffen(const MCInst *MI, unsigned OpNo,
81 raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +000082 printNamedBit(MI, OpNo, O, "offen");
Tom Stellard229d5e62014-08-05 14:48:12 +000083}
84
85void AMDGPUInstPrinter::printIdxen(const MCInst *MI, unsigned OpNo,
86 raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +000087 printNamedBit(MI, OpNo, O, "idxen");
Tom Stellard229d5e62014-08-05 14:48:12 +000088}
89
90void AMDGPUInstPrinter::printAddr64(const MCInst *MI, unsigned OpNo,
91 raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +000092 printNamedBit(MI, OpNo, O, "addr64");
Tom Stellard229d5e62014-08-05 14:48:12 +000093}
94
95void AMDGPUInstPrinter::printMBUFOffset(const MCInst *MI, unsigned OpNo,
96 raw_ostream &O) {
97 if (MI->getOperand(OpNo).getImm()) {
98 O << " offset:";
Matt Arsenaultfb13b222014-12-03 03:12:13 +000099 printU16ImmDecOperand(MI, OpNo, O);
Tom Stellard229d5e62014-08-05 14:48:12 +0000100 }
101}
102
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000103void AMDGPUInstPrinter::printOffset(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000104 const MCSubtargetInfo &STI,
105 raw_ostream &O) {
Matt Arsenault61cc9082014-10-10 22:16:07 +0000106 uint16_t Imm = MI->getOperand(OpNo).getImm();
107 if (Imm != 0) {
108 O << " offset:";
109 printU16ImmDecOperand(MI, OpNo, O);
110 }
111}
112
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000113void AMDGPUInstPrinter::printOffset0(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000114 const MCSubtargetInfo &STI,
115 raw_ostream &O) {
Tom Stellard1f3416a2015-04-08 01:09:19 +0000116 if (MI->getOperand(OpNo).getImm()) {
117 O << " offset0:";
118 printU8ImmDecOperand(MI, OpNo, O);
119 }
Matt Arsenault61cc9082014-10-10 22:16:07 +0000120}
121
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000122void AMDGPUInstPrinter::printOffset1(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000123 const MCSubtargetInfo &STI,
124 raw_ostream &O) {
Tom Stellard1f3416a2015-04-08 01:09:19 +0000125 if (MI->getOperand(OpNo).getImm()) {
126 O << " offset1:";
127 printU8ImmDecOperand(MI, OpNo, O);
128 }
Matt Arsenault61cc9082014-10-10 22:16:07 +0000129}
130
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000131void AMDGPUInstPrinter::printSMRDOffset(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000132 const MCSubtargetInfo &STI,
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000133 raw_ostream &O) {
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000134 printU32ImmOperand(MI, OpNo, STI, O);
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000135}
136
137void AMDGPUInstPrinter::printSMRDLiteralOffset(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000138 const MCSubtargetInfo &STI,
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000139 raw_ostream &O) {
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000140 printU32ImmOperand(MI, OpNo, STI, O);
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000141}
142
Tom Stellard065e3d42015-03-09 18:49:54 +0000143void AMDGPUInstPrinter::printGDS(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000144 const MCSubtargetInfo &STI, raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000145 printNamedBit(MI, OpNo, O, "gds");
Tom Stellard065e3d42015-03-09 18:49:54 +0000146}
147
Tom Stellard229d5e62014-08-05 14:48:12 +0000148void AMDGPUInstPrinter::printGLC(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000149 const MCSubtargetInfo &STI, raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000150 printNamedBit(MI, OpNo, O, "glc");
Tom Stellard229d5e62014-08-05 14:48:12 +0000151}
152
153void AMDGPUInstPrinter::printSLC(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000154 const MCSubtargetInfo &STI, raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000155 printNamedBit(MI, OpNo, O, "slc");
Tom Stellard229d5e62014-08-05 14:48:12 +0000156}
157
158void AMDGPUInstPrinter::printTFE(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000159 const MCSubtargetInfo &STI, raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000160 printNamedBit(MI, OpNo, O, "tfe");
161}
162
163void AMDGPUInstPrinter::printDMask(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000164 const MCSubtargetInfo &STI, raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000165 if (MI->getOperand(OpNo).getImm()) {
166 O << " dmask:";
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000167 printU16ImmOperand(MI, OpNo, STI, O);
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000168 }
169}
170
171void AMDGPUInstPrinter::printUNorm(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000172 const MCSubtargetInfo &STI, raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000173 printNamedBit(MI, OpNo, O, "unorm");
174}
175
176void AMDGPUInstPrinter::printDA(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000177 const MCSubtargetInfo &STI, raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000178 printNamedBit(MI, OpNo, O, "da");
179}
180
181void AMDGPUInstPrinter::printR128(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000182 const MCSubtargetInfo &STI, raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000183 printNamedBit(MI, OpNo, O, "r128");
184}
185
186void AMDGPUInstPrinter::printLWE(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000187 const MCSubtargetInfo &STI, raw_ostream &O) {
Nikolay Haustov2f684f12016-02-26 09:51:05 +0000188 printNamedBit(MI, OpNo, O, "lwe");
Tom Stellard229d5e62014-08-05 14:48:12 +0000189}
190
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000191void AMDGPUInstPrinter::printRegOperand(unsigned RegNo, raw_ostream &O,
Tom Stellardd7e6f132015-04-08 01:09:26 +0000192 const MCRegisterInfo &MRI) {
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000193 switch (RegNo) {
Matt Arsenault72b31ee2013-11-12 02:35:51 +0000194 case AMDGPU::VCC:
195 O << "vcc";
196 return;
197 case AMDGPU::SCC:
198 O << "scc";
199 return;
200 case AMDGPU::EXEC:
201 O << "exec";
202 return;
203 case AMDGPU::M0:
204 O << "m0";
205 return;
Matt Arsenault3f981402014-09-15 15:41:53 +0000206 case AMDGPU::FLAT_SCR:
207 O << "flat_scratch";
208 return;
209 case AMDGPU::VCC_LO:
210 O << "vcc_lo";
211 return;
212 case AMDGPU::VCC_HI:
213 O << "vcc_hi";
214 return;
Artem Tamazoveb4d5a92016-04-13 16:18:41 +0000215 case AMDGPU::TBA_LO:
216 O << "tba_lo";
217 return;
218 case AMDGPU::TBA_HI:
219 O << "tba_hi";
220 return;
221 case AMDGPU::TMA_LO:
222 O << "tma_lo";
223 return;
224 case AMDGPU::TMA_HI:
225 O << "tma_hi";
226 return;
Matt Arsenault3f981402014-09-15 15:41:53 +0000227 case AMDGPU::EXEC_LO:
228 O << "exec_lo";
229 return;
230 case AMDGPU::EXEC_HI:
231 O << "exec_hi";
232 return;
233 case AMDGPU::FLAT_SCR_LO:
234 O << "flat_scratch_lo";
235 return;
236 case AMDGPU::FLAT_SCR_HI:
237 O << "flat_scratch_hi";
238 return;
Matt Arsenault72b31ee2013-11-12 02:35:51 +0000239 default:
240 break;
241 }
242
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000243 // The low 8 bits of the encoding value is the register index, for both VGPRs
244 // and SGPRs.
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000245 unsigned RegIdx = MRI.getEncodingValue(RegNo) & ((1 << 8) - 1);
Matt Arsenault72b31ee2013-11-12 02:35:51 +0000246
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000247 unsigned NumRegs;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000248 if (MRI.getRegClass(AMDGPU::VGPR_32RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000249 O << 'v';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000250 NumRegs = 1;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000251 } else if (MRI.getRegClass(AMDGPU::SGPR_32RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000252 O << 's';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000253 NumRegs = 1;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000254 } else if (MRI.getRegClass(AMDGPU::VReg_64RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000255 O <<'v';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000256 NumRegs = 2;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000257 } else if (MRI.getRegClass(AMDGPU::SGPR_64RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000258 O << 's';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000259 NumRegs = 2;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000260 } else if (MRI.getRegClass(AMDGPU::VReg_128RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000261 O << 'v';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000262 NumRegs = 4;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000263 } else if (MRI.getRegClass(AMDGPU::SGPR_128RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000264 O << 's';
Artem Tamazov38e496b2016-04-29 17:04:50 +0000265 NumRegs = 4;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000266 } else if (MRI.getRegClass(AMDGPU::VReg_96RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000267 O << 'v';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000268 NumRegs = 3;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000269 } else if (MRI.getRegClass(AMDGPU::VReg_256RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000270 O << 'v';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000271 NumRegs = 8;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000272 } else if (MRI.getRegClass(AMDGPU::SReg_256RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000273 O << 's';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000274 NumRegs = 8;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000275 } else if (MRI.getRegClass(AMDGPU::VReg_512RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000276 O << 'v';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000277 NumRegs = 16;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000278 } else if (MRI.getRegClass(AMDGPU::SReg_512RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000279 O << 's';
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000280 NumRegs = 16;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000281 } else if (MRI.getRegClass(AMDGPU::TTMP_64RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000282 O << "ttmp";
283 NumRegs = 2;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000284 // Trap temps start at offset 112. TODO: Get this from tablegen.
285 RegIdx -= 112;
286 } else if (MRI.getRegClass(AMDGPU::TTMP_128RegClassID).contains(RegNo)) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000287 O << "ttmp";
288 NumRegs = 4;
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000289 // Trap temps start at offset 112. TODO: Get this from tablegen.
290 RegIdx -= 112;
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000291 } else {
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000292 O << getRegisterName(RegNo);
Matt Arsenault72b31ee2013-11-12 02:35:51 +0000293 return;
294 }
295
Matt Arsenaultfcf86c52014-04-15 22:32:42 +0000296 if (NumRegs == 1) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000297 O << RegIdx;
Matt Arsenault72b31ee2013-11-12 02:35:51 +0000298 return;
299 }
300
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000301 O << '[' << RegIdx << ':' << (RegIdx + NumRegs - 1) << ']';
Matt Arsenault72b31ee2013-11-12 02:35:51 +0000302}
303
Tom Stellardc0503922015-03-12 21:34:22 +0000304void AMDGPUInstPrinter::printVOPDst(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000305 const MCSubtargetInfo &STI, raw_ostream &O) {
Tom Stellardc0503922015-03-12 21:34:22 +0000306 if (MII.get(MI->getOpcode()).TSFlags & SIInstrFlags::VOP3)
307 O << "_e64 ";
Sam Koltondfa29f72016-03-09 12:29:31 +0000308 else if (MII.get(MI->getOpcode()).TSFlags & SIInstrFlags::DPP)
309 O << "_dpp ";
Sam Kolton3025e7f2016-04-26 13:33:56 +0000310 else if (MII.get(MI->getOpcode()).TSFlags & SIInstrFlags::SDWA)
311 O << "_sdwa ";
Tom Stellardc0503922015-03-12 21:34:22 +0000312 else
313 O << "_e32 ";
314
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000315 printOperand(MI, OpNo, STI, O);
Tom Stellardc0503922015-03-12 21:34:22 +0000316}
317
Matt Arsenault303011a2014-12-17 21:04:08 +0000318void AMDGPUInstPrinter::printImmediate32(uint32_t Imm, raw_ostream &O) {
Matt Arsenault4d7d3832014-04-15 22:32:49 +0000319 int32_t SImm = static_cast<int32_t>(Imm);
320 if (SImm >= -16 && SImm <= 64) {
321 O << SImm;
322 return;
323 }
324
Matt Arsenault02dc2652014-09-17 17:32:13 +0000325 if (Imm == FloatToBits(0.0f))
326 O << "0.0";
327 else if (Imm == FloatToBits(1.0f))
328 O << "1.0";
329 else if (Imm == FloatToBits(-1.0f))
330 O << "-1.0";
331 else if (Imm == FloatToBits(0.5f))
332 O << "0.5";
333 else if (Imm == FloatToBits(-0.5f))
334 O << "-0.5";
335 else if (Imm == FloatToBits(2.0f))
336 O << "2.0";
337 else if (Imm == FloatToBits(-2.0f))
338 O << "-2.0";
339 else if (Imm == FloatToBits(4.0f))
340 O << "4.0";
341 else if (Imm == FloatToBits(-4.0f))
342 O << "-4.0";
Matt Arsenault303011a2014-12-17 21:04:08 +0000343 else
Matt Arsenault02dc2652014-09-17 17:32:13 +0000344 O << formatHex(static_cast<uint64_t>(Imm));
Matt Arsenault303011a2014-12-17 21:04:08 +0000345}
346
347void AMDGPUInstPrinter::printImmediate64(uint64_t Imm, raw_ostream &O) {
348 int64_t SImm = static_cast<int64_t>(Imm);
349 if (SImm >= -16 && SImm <= 64) {
350 O << SImm;
351 return;
Matt Arsenault4d7d3832014-04-15 22:32:49 +0000352 }
Matt Arsenault303011a2014-12-17 21:04:08 +0000353
354 if (Imm == DoubleToBits(0.0))
355 O << "0.0";
356 else if (Imm == DoubleToBits(1.0))
357 O << "1.0";
358 else if (Imm == DoubleToBits(-1.0))
359 O << "-1.0";
360 else if (Imm == DoubleToBits(0.5))
361 O << "0.5";
362 else if (Imm == DoubleToBits(-0.5))
363 O << "-0.5";
364 else if (Imm == DoubleToBits(2.0))
365 O << "2.0";
366 else if (Imm == DoubleToBits(-2.0))
367 O << "-2.0";
368 else if (Imm == DoubleToBits(4.0))
369 O << "4.0";
370 else if (Imm == DoubleToBits(-4.0))
371 O << "-4.0";
Matt Arsenault382557e2015-10-23 18:07:58 +0000372 else {
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000373 assert(isUInt<32>(Imm) || Imm == 0x3fc45f306dc9c882);
Matt Arsenault382557e2015-10-23 18:07:58 +0000374
375 // In rare situations, we will have a 32-bit literal in a 64-bit
376 // operand. This is technically allowed for the encoding of s_mov_b64.
377 O << formatHex(static_cast<uint64_t>(Imm));
378 }
Matt Arsenault4d7d3832014-04-15 22:32:49 +0000379}
380
Tom Stellard75aadc22012-12-11 21:25:42 +0000381void AMDGPUInstPrinter::printOperand(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000382 const MCSubtargetInfo &STI,
Tom Stellard75aadc22012-12-11 21:25:42 +0000383 raw_ostream &O) {
384
Valery Pykhtinc7616752016-08-15 10:56:48 +0000385 if (OpNo >= MI->getNumOperands()) {
386 O << "/*Missing OP" << OpNo << "*/";
387 return;
388 }
389
Tom Stellard75aadc22012-12-11 21:25:42 +0000390 const MCOperand &Op = MI->getOperand(OpNo);
391 if (Op.isReg()) {
392 switch (Op.getReg()) {
393 // This is the default predicate state, so we don't need to print it.
Matt Arsenault72b31ee2013-11-12 02:35:51 +0000394 case AMDGPU::PRED_SEL_OFF:
395 break;
396
397 default:
Tom Stellardd7e6f132015-04-08 01:09:26 +0000398 printRegOperand(Op.getReg(), O, MRI);
Matt Arsenault72b31ee2013-11-12 02:35:51 +0000399 break;
Tom Stellard75aadc22012-12-11 21:25:42 +0000400 }
401 } else if (Op.isImm()) {
Matt Arsenault303011a2014-12-17 21:04:08 +0000402 const MCInstrDesc &Desc = MII.get(MI->getOpcode());
403 int RCID = Desc.OpInfo[OpNo].RegClass;
404 if (RCID != -1) {
405 const MCRegisterClass &ImmRC = MRI.getRegClass(RCID);
406 if (ImmRC.getSize() == 4)
407 printImmediate32(Op.getImm(), O);
408 else if (ImmRC.getSize() == 8)
409 printImmediate64(Op.getImm(), O);
410 else
411 llvm_unreachable("Invalid register class size");
Matt Arsenault70120fa2015-02-21 21:29:00 +0000412 } else if (Desc.OpInfo[OpNo].OperandType == MCOI::OPERAND_IMMEDIATE) {
413 printImmediate32(Op.getImm(), O);
Matt Arsenault303011a2014-12-17 21:04:08 +0000414 } else {
415 // We hit this for the immediate instruction bits that don't yet have a
416 // custom printer.
417 // TODO: Eventually this should be unnecessary.
418 O << formatDec(Op.getImm());
419 }
Tom Stellard75aadc22012-12-11 21:25:42 +0000420 } else if (Op.isFPImm()) {
Matt Arsenault02dc2652014-09-17 17:32:13 +0000421 // We special case 0.0 because otherwise it will be printed as an integer.
422 if (Op.getFPImm() == 0.0)
423 O << "0.0";
Matt Arsenault303011a2014-12-17 21:04:08 +0000424 else {
425 const MCInstrDesc &Desc = MII.get(MI->getOpcode());
426 const MCRegisterClass &ImmRC = MRI.getRegClass(Desc.OpInfo[OpNo].RegClass);
427
428 if (ImmRC.getSize() == 4)
429 printImmediate32(FloatToBits(Op.getFPImm()), O);
430 else if (ImmRC.getSize() == 8)
431 printImmediate64(DoubleToBits(Op.getFPImm()), O);
432 else
433 llvm_unreachable("Invalid register class size");
434 }
Christian Konigbf114b42013-02-21 15:17:22 +0000435 } else if (Op.isExpr()) {
436 const MCExpr *Exp = Op.getExpr();
Matt Arsenault8b643552015-06-09 00:31:39 +0000437 Exp->print(O, &MAI);
Tom Stellard75aadc22012-12-11 21:25:42 +0000438 } else {
Nikolay Haustovac106ad2016-03-01 13:57:29 +0000439 O << "/*INV_OP*/";
Tom Stellard75aadc22012-12-11 21:25:42 +0000440 }
441}
442
Sam Kolton945231a2016-06-10 09:57:59 +0000443void AMDGPUInstPrinter::printOperandAndFPInputMods(const MCInst *MI,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000444 unsigned OpNo,
445 const MCSubtargetInfo &STI,
446 raw_ostream &O) {
Vincent Lejeune94af31f2014-05-10 19:18:33 +0000447 unsigned InputModifiers = MI->getOperand(OpNo).getImm();
Matt Arsenault9783e002014-09-29 15:50:26 +0000448 if (InputModifiers & SISrcMods::NEG)
Matt Arsenault3673eba2014-09-21 17:27:28 +0000449 O << '-';
Matt Arsenault9783e002014-09-29 15:50:26 +0000450 if (InputModifiers & SISrcMods::ABS)
Matt Arsenault3673eba2014-09-21 17:27:28 +0000451 O << '|';
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000452 printOperand(MI, OpNo + 1, STI, O);
Matt Arsenault9783e002014-09-29 15:50:26 +0000453 if (InputModifiers & SISrcMods::ABS)
Matt Arsenault3673eba2014-09-21 17:27:28 +0000454 O << '|';
Vincent Lejeune94af31f2014-05-10 19:18:33 +0000455}
456
Sam Kolton945231a2016-06-10 09:57:59 +0000457void AMDGPUInstPrinter::printOperandAndIntInputMods(const MCInst *MI,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000458 unsigned OpNo,
459 const MCSubtargetInfo &STI,
460 raw_ostream &O) {
Sam Kolton945231a2016-06-10 09:57:59 +0000461 unsigned InputModifiers = MI->getOperand(OpNo).getImm();
462 if (InputModifiers & SISrcMods::SEXT)
463 O << "sext(";
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000464 printOperand(MI, OpNo + 1, STI, O);
Sam Kolton945231a2016-06-10 09:57:59 +0000465 if (InputModifiers & SISrcMods::SEXT)
466 O << ')';
467}
468
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000469void AMDGPUInstPrinter::printDPPCtrl(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000470 const MCSubtargetInfo &STI,
471 raw_ostream &O) {
Sam Koltondfa29f72016-03-09 12:29:31 +0000472 unsigned Imm = MI->getOperand(OpNo).getImm();
Teresa Johnsone50b23c2016-03-09 14:58:23 +0000473 if (Imm <= 0x0ff) {
Sam Koltona74cd522016-03-18 15:35:51 +0000474 O << " quad_perm:[";
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000475 O << formatDec(Imm & 0x3) << ',';
476 O << formatDec((Imm & 0xc) >> 2) << ',';
477 O << formatDec((Imm & 0x30) >> 4) << ',';
478 O << formatDec((Imm & 0xc0) >> 6) << ']';
Sam Koltondfa29f72016-03-09 12:29:31 +0000479 } else if ((Imm >= 0x101) && (Imm <= 0x10f)) {
480 O << " row_shl:";
481 printU4ImmDecOperand(MI, OpNo, O);
482 } else if ((Imm >= 0x111) && (Imm <= 0x11f)) {
483 O << " row_shr:";
484 printU4ImmDecOperand(MI, OpNo, O);
485 } else if ((Imm >= 0x121) && (Imm <= 0x12f)) {
486 O << " row_ror:";
487 printU4ImmDecOperand(MI, OpNo, O);
488 } else if (Imm == 0x130) {
489 O << " wave_shl:1";
490 } else if (Imm == 0x134) {
491 O << " wave_rol:1";
492 } else if (Imm == 0x138) {
493 O << " wave_shr:1";
494 } else if (Imm == 0x13c) {
495 O << " wave_ror:1";
496 } else if (Imm == 0x140) {
Sam Koltona74cd522016-03-18 15:35:51 +0000497 O << " row_mirror";
Sam Koltondfa29f72016-03-09 12:29:31 +0000498 } else if (Imm == 0x141) {
Sam Koltona74cd522016-03-18 15:35:51 +0000499 O << " row_half_mirror";
Sam Koltondfa29f72016-03-09 12:29:31 +0000500 } else if (Imm == 0x142) {
501 O << " row_bcast:15";
502 } else if (Imm == 0x143) {
503 O << " row_bcast:31";
504 } else {
505 llvm_unreachable("Invalid dpp_ctrl value");
506 }
507}
508
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000509void AMDGPUInstPrinter::printRowMask(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000510 const MCSubtargetInfo &STI,
511 raw_ostream &O) {
Sam Koltondfa29f72016-03-09 12:29:31 +0000512 O << " row_mask:";
513 printU4ImmOperand(MI, OpNo, O);
514}
515
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000516void AMDGPUInstPrinter::printBankMask(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000517 const MCSubtargetInfo &STI,
518 raw_ostream &O) {
Sam Koltondfa29f72016-03-09 12:29:31 +0000519 O << " bank_mask:";
520 printU4ImmOperand(MI, OpNo, O);
521}
522
Nikolay Haustov4f672a32016-04-29 09:02:30 +0000523void AMDGPUInstPrinter::printBoundCtrl(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000524 const MCSubtargetInfo &STI,
525 raw_ostream &O) {
Sam Koltondfa29f72016-03-09 12:29:31 +0000526 unsigned Imm = MI->getOperand(OpNo).getImm();
527 if (Imm) {
528 O << " bound_ctrl:0"; // XXX - this syntax is used in sp3
529 }
530}
531
Sam Kolton3025e7f2016-04-26 13:33:56 +0000532void AMDGPUInstPrinter::printSDWASel(const MCInst *MI, unsigned OpNo,
533 raw_ostream &O) {
Sam Koltona3ec5c12016-10-07 14:46:06 +0000534 using namespace llvm::AMDGPU::SDWA;
535
Sam Kolton3025e7f2016-04-26 13:33:56 +0000536 unsigned Imm = MI->getOperand(OpNo).getImm();
537 switch (Imm) {
Sam Koltona3ec5c12016-10-07 14:46:06 +0000538 case SdwaSel::BYTE_0: O << "BYTE_0"; break;
539 case SdwaSel::BYTE_1: O << "BYTE_1"; break;
540 case SdwaSel::BYTE_2: O << "BYTE_2"; break;
541 case SdwaSel::BYTE_3: O << "BYTE_3"; break;
542 case SdwaSel::WORD_0: O << "WORD_0"; break;
543 case SdwaSel::WORD_1: O << "WORD_1"; break;
544 case SdwaSel::DWORD: O << "DWORD"; break;
Sam Kolton3025e7f2016-04-26 13:33:56 +0000545 default: llvm_unreachable("Invalid SDWA data select operand");
546 }
547}
548
549void AMDGPUInstPrinter::printSDWADstSel(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000550 const MCSubtargetInfo &STI,
Sam Kolton3025e7f2016-04-26 13:33:56 +0000551 raw_ostream &O) {
552 O << "dst_sel:";
553 printSDWASel(MI, OpNo, O);
554}
555
556void AMDGPUInstPrinter::printSDWASrc0Sel(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000557 const MCSubtargetInfo &STI,
Sam Kolton3025e7f2016-04-26 13:33:56 +0000558 raw_ostream &O) {
559 O << "src0_sel:";
560 printSDWASel(MI, OpNo, O);
561}
562
563void AMDGPUInstPrinter::printSDWASrc1Sel(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000564 const MCSubtargetInfo &STI,
Sam Kolton3025e7f2016-04-26 13:33:56 +0000565 raw_ostream &O) {
566 O << "src1_sel:";
567 printSDWASel(MI, OpNo, O);
568}
569
570void AMDGPUInstPrinter::printSDWADstUnused(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000571 const MCSubtargetInfo &STI,
Sam Kolton3025e7f2016-04-26 13:33:56 +0000572 raw_ostream &O) {
Sam Koltona3ec5c12016-10-07 14:46:06 +0000573 using namespace llvm::AMDGPU::SDWA;
574
Sam Kolton3025e7f2016-04-26 13:33:56 +0000575 O << "dst_unused:";
576 unsigned Imm = MI->getOperand(OpNo).getImm();
577 switch (Imm) {
Sam Koltona3ec5c12016-10-07 14:46:06 +0000578 case DstUnused::UNUSED_PAD: O << "UNUSED_PAD"; break;
579 case DstUnused::UNUSED_SEXT: O << "UNUSED_SEXT"; break;
580 case DstUnused::UNUSED_PRESERVE: O << "UNUSED_PRESERVE"; break;
Sam Kolton3025e7f2016-04-26 13:33:56 +0000581 default: llvm_unreachable("Invalid SDWA dest_unused operand");
582 }
583}
584
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000585void AMDGPUInstPrinter::printInterpSlot(const MCInst *MI, unsigned OpNo,
586 const MCSubtargetInfo &STI,
Michel Danzere9bb18b2013-02-14 19:03:25 +0000587 raw_ostream &O) {
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000588 unsigned Imm = MI->getOperand(OpNo).getImm();
Michel Danzere9bb18b2013-02-14 19:03:25 +0000589
590 if (Imm == 2) {
591 O << "P0";
592 } else if (Imm == 1) {
593 O << "P20";
594 } else if (Imm == 0) {
595 O << "P10";
596 } else {
Matt Arsenault393366c2014-09-21 17:27:31 +0000597 llvm_unreachable("Invalid interpolation parameter slot");
Michel Danzere9bb18b2013-02-14 19:03:25 +0000598 }
599}
600
Tom Stellard75aadc22012-12-11 21:25:42 +0000601void AMDGPUInstPrinter::printMemOperand(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000602 const MCSubtargetInfo &STI,
Tom Stellard75aadc22012-12-11 21:25:42 +0000603 raw_ostream &O) {
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000604 printOperand(MI, OpNo, STI, O);
Tom Stellard75aadc22012-12-11 21:25:42 +0000605 O << ", ";
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000606 printOperand(MI, OpNo + 1, STI, O);
Tom Stellard75aadc22012-12-11 21:25:42 +0000607}
608
609void AMDGPUInstPrinter::printIfSet(const MCInst *MI, unsigned OpNo,
Vincent Lejeunef97af792013-05-02 21:52:30 +0000610 raw_ostream &O, StringRef Asm,
611 StringRef Default) {
Tom Stellard75aadc22012-12-11 21:25:42 +0000612 const MCOperand &Op = MI->getOperand(OpNo);
613 assert(Op.isImm());
614 if (Op.getImm() == 1) {
615 O << Asm;
Vincent Lejeunef97af792013-05-02 21:52:30 +0000616 } else {
617 O << Default;
Tom Stellard75aadc22012-12-11 21:25:42 +0000618 }
619}
620
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000621void AMDGPUInstPrinter::printIfSet(const MCInst *MI, unsigned OpNo,
622 raw_ostream &O, char Asm) {
623 const MCOperand &Op = MI->getOperand(OpNo);
624 assert(Op.isImm());
625 if (Op.getImm() == 1)
626 O << Asm;
627}
628
Tom Stellard75aadc22012-12-11 21:25:42 +0000629void AMDGPUInstPrinter::printAbs(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000630 const MCSubtargetInfo &STI, raw_ostream &O) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000631 printIfSet(MI, OpNo, O, '|');
Tom Stellard75aadc22012-12-11 21:25:42 +0000632}
633
634void AMDGPUInstPrinter::printClamp(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000635 const MCSubtargetInfo &STI, raw_ostream &O) {
Tom Stellard75aadc22012-12-11 21:25:42 +0000636 printIfSet(MI, OpNo, O, "_SAT");
637}
638
Matt Arsenault97069782014-09-30 19:49:48 +0000639void AMDGPUInstPrinter::printClampSI(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000640 const MCSubtargetInfo &STI,
Matt Arsenault97069782014-09-30 19:49:48 +0000641 raw_ostream &O) {
642 if (MI->getOperand(OpNo).getImm())
643 O << " clamp";
644}
645
646void AMDGPUInstPrinter::printOModSI(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000647 const MCSubtargetInfo &STI,
648 raw_ostream &O) {
Matt Arsenault97069782014-09-30 19:49:48 +0000649 int Imm = MI->getOperand(OpNo).getImm();
650 if (Imm == SIOutMods::MUL2)
651 O << " mul:2";
652 else if (Imm == SIOutMods::MUL4)
653 O << " mul:4";
654 else if (Imm == SIOutMods::DIV2)
655 O << " div:2";
656}
657
Tom Stellard75aadc22012-12-11 21:25:42 +0000658void AMDGPUInstPrinter::printLiteral(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000659 const MCSubtargetInfo &STI,
Tom Stellard75aadc22012-12-11 21:25:42 +0000660 raw_ostream &O) {
Jan Vesely79714642016-05-13 20:39:24 +0000661 const MCOperand &Op = MI->getOperand(OpNo);
662 assert(Op.isImm() || Op.isExpr());
663 if (Op.isImm()) {
664 int64_t Imm = Op.getImm();
665 O << Imm << '(' << BitsToFloat(Imm) << ')';
666 }
667 if (Op.isExpr()) {
668 Op.getExpr()->print(O << '@', &MAI);
669 }
Tom Stellard75aadc22012-12-11 21:25:42 +0000670}
671
672void AMDGPUInstPrinter::printLast(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000673 const MCSubtargetInfo &STI, raw_ostream &O) {
Rafael Espindola0b9319e2015-06-12 12:42:13 +0000674 printIfSet(MI, OpNo, O, "*", " ");
Tom Stellard75aadc22012-12-11 21:25:42 +0000675}
676
677void AMDGPUInstPrinter::printNeg(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000678 const MCSubtargetInfo &STI, raw_ostream &O) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000679 printIfSet(MI, OpNo, O, '-');
Tom Stellard75aadc22012-12-11 21:25:42 +0000680}
681
682void AMDGPUInstPrinter::printOMOD(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000683 const MCSubtargetInfo &STI, raw_ostream &O) {
Tom Stellard75aadc22012-12-11 21:25:42 +0000684 switch (MI->getOperand(OpNo).getImm()) {
685 default: break;
686 case 1:
687 O << " * 2.0";
688 break;
689 case 2:
690 O << " * 4.0";
691 break;
692 case 3:
693 O << " / 2.0";
694 break;
695 }
696}
697
698void AMDGPUInstPrinter::printRel(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000699 const MCSubtargetInfo &STI, raw_ostream &O) {
Matt Arsenaulte8dbf792016-07-05 22:06:56 +0000700 printIfSet(MI, OpNo, O, '+');
Tom Stellard75aadc22012-12-11 21:25:42 +0000701}
702
703void AMDGPUInstPrinter::printUpdateExecMask(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000704 const MCSubtargetInfo &STI,
Tom Stellard75aadc22012-12-11 21:25:42 +0000705 raw_ostream &O) {
706 printIfSet(MI, OpNo, O, "ExecMask,");
707}
708
709void AMDGPUInstPrinter::printUpdatePred(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000710 const MCSubtargetInfo &STI,
Tom Stellard75aadc22012-12-11 21:25:42 +0000711 raw_ostream &O) {
712 printIfSet(MI, OpNo, O, "Pred,");
713}
714
715void AMDGPUInstPrinter::printWrite(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000716 const MCSubtargetInfo &STI, raw_ostream &O) {
Tom Stellard75aadc22012-12-11 21:25:42 +0000717 const MCOperand &Op = MI->getOperand(OpNo);
718 if (Op.getImm() == 0) {
719 O << " (MASKED)";
720 }
721}
722
Tom Stellard365366f2013-01-23 02:09:06 +0000723void AMDGPUInstPrinter::printSel(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000724 raw_ostream &O) {
Tom Stellard365366f2013-01-23 02:09:06 +0000725 const char * chans = "XYZW";
726 int sel = MI->getOperand(OpNo).getImm();
727
728 int chan = sel & 3;
729 sel >>= 2;
730
731 if (sel >= 512) {
732 sel -= 512;
733 int cb = sel >> 12;
734 sel &= 4095;
Matt Arsenault3673eba2014-09-21 17:27:28 +0000735 O << cb << '[' << sel << ']';
Tom Stellard365366f2013-01-23 02:09:06 +0000736 } else if (sel >= 448) {
737 sel -= 448;
738 O << sel;
739 } else if (sel >= 0){
740 O << sel;
741 }
742
743 if (sel >= 0)
Matt Arsenault3673eba2014-09-21 17:27:28 +0000744 O << '.' << chans[chan];
Tom Stellard365366f2013-01-23 02:09:06 +0000745}
746
Vincent Lejeunef97af792013-05-02 21:52:30 +0000747void AMDGPUInstPrinter::printBankSwizzle(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000748 const MCSubtargetInfo &STI,
Vincent Lejeunef97af792013-05-02 21:52:30 +0000749 raw_ostream &O) {
750 int BankSwizzle = MI->getOperand(OpNo).getImm();
751 switch (BankSwizzle) {
752 case 1:
Vincent Lejeunebb8a87212013-06-29 19:32:29 +0000753 O << "BS:VEC_021/SCL_122";
Vincent Lejeunef97af792013-05-02 21:52:30 +0000754 break;
755 case 2:
Vincent Lejeunebb8a87212013-06-29 19:32:29 +0000756 O << "BS:VEC_120/SCL_212";
Vincent Lejeunef97af792013-05-02 21:52:30 +0000757 break;
758 case 3:
Vincent Lejeunebb8a87212013-06-29 19:32:29 +0000759 O << "BS:VEC_102/SCL_221";
Vincent Lejeunef97af792013-05-02 21:52:30 +0000760 break;
761 case 4:
762 O << "BS:VEC_201";
763 break;
764 case 5:
765 O << "BS:VEC_210";
766 break;
767 default:
768 break;
769 }
770 return;
771}
772
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000773void AMDGPUInstPrinter::printRSel(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000774 const MCSubtargetInfo &STI, raw_ostream &O) {
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000775 unsigned Sel = MI->getOperand(OpNo).getImm();
776 switch (Sel) {
777 case 0:
Matt Arsenault3673eba2014-09-21 17:27:28 +0000778 O << 'X';
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000779 break;
780 case 1:
Matt Arsenault3673eba2014-09-21 17:27:28 +0000781 O << 'Y';
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000782 break;
783 case 2:
Matt Arsenault3673eba2014-09-21 17:27:28 +0000784 O << 'Z';
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000785 break;
786 case 3:
Matt Arsenault3673eba2014-09-21 17:27:28 +0000787 O << 'W';
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000788 break;
789 case 4:
Matt Arsenault3673eba2014-09-21 17:27:28 +0000790 O << '0';
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000791 break;
792 case 5:
Matt Arsenault3673eba2014-09-21 17:27:28 +0000793 O << '1';
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000794 break;
795 case 7:
Matt Arsenault3673eba2014-09-21 17:27:28 +0000796 O << '_';
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000797 break;
798 default:
799 break;
800 }
801}
802
803void AMDGPUInstPrinter::printCT(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000804 const MCSubtargetInfo &STI, raw_ostream &O) {
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000805 unsigned CT = MI->getOperand(OpNo).getImm();
806 switch (CT) {
807 case 0:
Matt Arsenault3673eba2014-09-21 17:27:28 +0000808 O << 'U';
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000809 break;
810 case 1:
Matt Arsenault3673eba2014-09-21 17:27:28 +0000811 O << 'N';
Vincent Lejeuned3eed662013-05-17 16:50:20 +0000812 break;
813 default:
814 break;
815 }
816}
817
Vincent Lejeuneb0422e22013-05-02 21:52:40 +0000818void AMDGPUInstPrinter::printKCache(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000819 const MCSubtargetInfo &STI, raw_ostream &O) {
Vincent Lejeuneb0422e22013-05-02 21:52:40 +0000820 int KCacheMode = MI->getOperand(OpNo).getImm();
821 if (KCacheMode > 0) {
822 int KCacheBank = MI->getOperand(OpNo - 2).getImm();
Matt Arsenault3673eba2014-09-21 17:27:28 +0000823 O << "CB" << KCacheBank << ':';
Vincent Lejeuneb0422e22013-05-02 21:52:40 +0000824 int KCacheAddr = MI->getOperand(OpNo + 2).getImm();
Matt Arsenault3673eba2014-09-21 17:27:28 +0000825 int LineSize = (KCacheMode == 1) ? 16 : 32;
826 O << KCacheAddr * 16 << '-' << KCacheAddr * 16 + LineSize;
Vincent Lejeuneb0422e22013-05-02 21:52:40 +0000827 }
828}
829
Michel Danzer6064f572014-01-27 07:20:44 +0000830void AMDGPUInstPrinter::printSendMsg(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000831 const MCSubtargetInfo &STI,
Michel Danzer6064f572014-01-27 07:20:44 +0000832 raw_ostream &O) {
Artem Tamazovebe71ce2016-05-06 17:48:48 +0000833 using namespace llvm::AMDGPU::SendMsg;
834
835 const unsigned SImm16 = MI->getOperand(OpNo).getImm();
836 const unsigned Id = SImm16 & ID_MASK_;
837 do {
838 if (Id == ID_INTERRUPT) {
839 if ((SImm16 & ~ID_MASK_) != 0) // Unused/unknown bits must be 0.
840 break;
841 O << "sendmsg(" << IdSymbolic[Id] << ')';
842 return;
Michel Danzer6064f572014-01-27 07:20:44 +0000843 }
Artem Tamazovebe71ce2016-05-06 17:48:48 +0000844 if (Id == ID_GS || Id == ID_GS_DONE) {
845 if ((SImm16 & ~(ID_MASK_|OP_GS_MASK_|STREAM_ID_MASK_)) != 0) // Unused/unknown bits must be 0.
846 break;
847 const unsigned OpGs = (SImm16 & OP_GS_MASK_) >> OP_SHIFT_;
848 const unsigned StreamId = (SImm16 & STREAM_ID_MASK_) >> STREAM_ID_SHIFT_;
849 if (OpGs == OP_GS_NOP && Id != ID_GS_DONE) // NOP to be used for GS_DONE only.
850 break;
851 if (OpGs == OP_GS_NOP && StreamId != 0) // NOP does not use/define stream id bits.
852 break;
853 O << "sendmsg(" << IdSymbolic[Id] << ", " << OpGsSymbolic[OpGs];
854 if (OpGs != OP_GS_NOP) { O << ", " << StreamId; }
855 O << ')';
856 return;
857 }
858 if (Id == ID_SYSMSG) {
859 if ((SImm16 & ~(ID_MASK_|OP_SYS_MASK_)) != 0) // Unused/unknown bits must be 0.
860 break;
861 const unsigned OpSys = (SImm16 & OP_SYS_MASK_) >> OP_SHIFT_;
862 if (! (OP_SYS_FIRST_ <= OpSys && OpSys < OP_SYS_LAST_)) // Unused/unknown.
863 break;
864 O << "sendmsg(" << IdSymbolic[Id] << ", " << OpSysSymbolic[OpSys] << ')';
865 return;
866 }
867 } while (0);
868 O << SImm16; // Unknown simm16 code.
Michel Danzer6064f572014-01-27 07:20:44 +0000869}
870
Vincent Lejeuned6cbede2013-10-13 17:56:28 +0000871void AMDGPUInstPrinter::printWaitFlag(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000872 const MCSubtargetInfo &STI,
Vincent Lejeuned6cbede2013-10-13 17:56:28 +0000873 raw_ostream &O) {
Konstantin Zhuravlyov836cbff2016-09-30 17:01:40 +0000874 IsaVersion IV = getIsaVersion(STI.getFeatureBits());
875
Vincent Lejeuned6cbede2013-10-13 17:56:28 +0000876 unsigned SImm16 = MI->getOperand(OpNo).getImm();
Konstantin Zhuravlyovcdd45472016-10-11 18:58:22 +0000877 unsigned Vmcnt, Expcnt, Lgkmcnt;
878 decodeWaitcnt(IV, SImm16, Vmcnt, Expcnt, Lgkmcnt);
Matt Arsenault3a997592014-09-26 01:09:46 +0000879
880 bool NeedSpace = false;
881
Konstantin Zhuravlyovcdd45472016-10-11 18:58:22 +0000882 if (Vmcnt != getVmcntBitMask(IV)) {
Matt Arsenault3a997592014-09-26 01:09:46 +0000883 O << "vmcnt(" << Vmcnt << ')';
884 NeedSpace = true;
885 }
886
Konstantin Zhuravlyovcdd45472016-10-11 18:58:22 +0000887 if (Expcnt != getExpcntBitMask(IV)) {
Matt Arsenault3a997592014-09-26 01:09:46 +0000888 if (NeedSpace)
889 O << ' ';
890 O << "expcnt(" << Expcnt << ')';
891 NeedSpace = true;
892 }
893
Konstantin Zhuravlyovcdd45472016-10-11 18:58:22 +0000894 if (Lgkmcnt != getLgkmcntBitMask(IV)) {
Matt Arsenault3a997592014-09-26 01:09:46 +0000895 if (NeedSpace)
896 O << ' ';
Matt Arsenault3673eba2014-09-21 17:27:28 +0000897 O << "lgkmcnt(" << Lgkmcnt << ')';
Matt Arsenault3a997592014-09-26 01:09:46 +0000898 }
Vincent Lejeuned6cbede2013-10-13 17:56:28 +0000899}
900
Artem Tamazovd6468662016-04-25 14:13:51 +0000901void AMDGPUInstPrinter::printHwreg(const MCInst *MI, unsigned OpNo,
Konstantin Zhuravlyovda4687c2016-09-27 14:42:48 +0000902 const MCSubtargetInfo &STI, raw_ostream &O) {
Artem Tamazov6edc1352016-05-26 17:00:33 +0000903 using namespace llvm::AMDGPU::Hwreg;
904
Artem Tamazovd6468662016-04-25 14:13:51 +0000905 unsigned SImm16 = MI->getOperand(OpNo).getImm();
Artem Tamazov6edc1352016-05-26 17:00:33 +0000906 const unsigned Id = (SImm16 & ID_MASK_) >> ID_SHIFT_;
907 const unsigned Offset = (SImm16 & OFFSET_MASK_) >> OFFSET_SHIFT_;
908 const unsigned Width = ((SImm16 & WIDTH_M1_MASK_) >> WIDTH_M1_SHIFT_) + 1;
Artem Tamazovd6468662016-04-25 14:13:51 +0000909
Artem Tamazov5cd55b12016-04-27 15:17:03 +0000910 O << "hwreg(";
Artem Tamazov6edc1352016-05-26 17:00:33 +0000911 if (ID_SYMBOLIC_FIRST_ <= Id && Id < ID_SYMBOLIC_LAST_) {
912 O << IdSymbolic[Id];
913 } else {
914 O << Id;
Artem Tamazovd6468662016-04-25 14:13:51 +0000915 }
Artem Tamazov6edc1352016-05-26 17:00:33 +0000916 if (Width != WIDTH_M1_DEFAULT_ + 1 || Offset != OFFSET_DEFAULT_) {
Artem Tamazov5cd55b12016-04-27 15:17:03 +0000917 O << ", " << Offset << ", " << Width;
918 }
919 O << ')';
Artem Tamazovd6468662016-04-25 14:13:51 +0000920}
921
Tom Stellard75aadc22012-12-11 21:25:42 +0000922#include "AMDGPUGenAsmWriter.inc"