blob: 49e4bf07c8187e16ab00b34d9256722d8a81eca0 [file] [log] [blame]
Valery Pykhtina34fb492016-08-30 15:20:31 +00001//===-- SOPInstructions.td - SOP Instruction Defintions -------------------===//
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//===----------------------------------------------------------------------===//
9
Matt Arsenaultcc88ce32016-10-12 18:00:51 +000010def GPRIdxModeMatchClass : AsmOperandClass {
11 let Name = "GPRIdxMode";
12 let PredicateMethod = "isGPRIdxMode";
13 let RenderMethod = "addImmOperands";
14}
15
16def GPRIdxMode : Operand<i32> {
17 let PrintMethod = "printVGPRIndexMode";
18 let ParserMatchClass = GPRIdxModeMatchClass;
19 let OperandType = "OPERAND_IMMEDIATE";
20}
21
Valery Pykhtina34fb492016-08-30 15:20:31 +000022//===----------------------------------------------------------------------===//
23// SOP1 Instructions
24//===----------------------------------------------------------------------===//
25
26class SOP1_Pseudo <string opName, dag outs, dag ins,
27 string asmOps, list<dag> pattern=[]> :
28 InstSI <outs, ins, "", pattern>,
29 SIMCInstr<opName, SIEncodingFamily.NONE> {
30 let isPseudo = 1;
31 let isCodeGenOnly = 1;
32 let SubtargetPredicate = isGCN;
33
34 let mayLoad = 0;
35 let mayStore = 0;
36 let hasSideEffects = 0;
37 let SALU = 1;
38 let SOP1 = 1;
39 let SchedRW = [WriteSALU];
Matt Arsenault6bc43d82016-10-06 16:20:41 +000040 let Size = 4;
Tom Stellard2add8a12016-09-06 20:00:26 +000041 let UseNamedOperandTable = 1;
Valery Pykhtina34fb492016-08-30 15:20:31 +000042
43 string Mnemonic = opName;
44 string AsmOperands = asmOps;
45
46 bits<1> has_src0 = 1;
47 bits<1> has_sdst = 1;
48}
49
50class SOP1_Real<bits<8> op, SOP1_Pseudo ps> :
51 InstSI <ps.OutOperandList, ps.InOperandList,
52 ps.Mnemonic # " " # ps.AsmOperands, []>,
53 Enc32 {
54
55 let isPseudo = 0;
56 let isCodeGenOnly = 0;
Matt Arsenault6bc43d82016-10-06 16:20:41 +000057 let Size = 4;
Valery Pykhtina34fb492016-08-30 15:20:31 +000058
59 // copy relevant pseudo op flags
60 let SubtargetPredicate = ps.SubtargetPredicate;
61 let AsmMatchConverter = ps.AsmMatchConverter;
62
63 // encoding
64 bits<7> sdst;
65 bits<8> src0;
66
67 let Inst{7-0} = !if(ps.has_src0, src0, ?);
68 let Inst{15-8} = op;
69 let Inst{22-16} = !if(ps.has_sdst, sdst, ?);
70 let Inst{31-23} = 0x17d; //encoding;
71}
72
73class SOP1_32 <string opName, list<dag> pattern=[]> : SOP1_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +000074 opName, (outs SReg_32:$sdst), (ins SSrc_b32:$src0),
Valery Pykhtina34fb492016-08-30 15:20:31 +000075 "$sdst, $src0", pattern
76>;
77
Matt Arsenaultcc88ce32016-10-12 18:00:51 +000078// 32-bit input, no output.
79class SOP1_0_32 <string opName, list<dag> pattern = []> : SOP1_Pseudo <
80 opName, (outs), (ins SSrc_b32:$src0),
81 "$src0", pattern> {
82 let has_sdst = 0;
83}
84
Dmitry Preobrazhensky12194e92017-04-12 12:40:19 +000085class SOP1_0_32R <string opName, list<dag> pattern = []> : SOP1_Pseudo <
86 opName, (outs), (ins SReg_32:$src0),
87 "$src0", pattern> {
88 let has_sdst = 0;
89}
90
Valery Pykhtina34fb492016-08-30 15:20:31 +000091class SOP1_64 <string opName, list<dag> pattern=[]> : SOP1_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +000092 opName, (outs SReg_64:$sdst), (ins SSrc_b64:$src0),
Valery Pykhtina34fb492016-08-30 15:20:31 +000093 "$sdst, $src0", pattern
94>;
95
96// 64-bit input, 32-bit output.
97class SOP1_32_64 <string opName, list<dag> pattern=[]> : SOP1_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +000098 opName, (outs SReg_32:$sdst), (ins SSrc_b64:$src0),
Valery Pykhtina34fb492016-08-30 15:20:31 +000099 "$sdst, $src0", pattern
100>;
101
102// 32-bit input, 64-bit output.
103class SOP1_64_32 <string opName, list<dag> pattern=[]> : SOP1_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000104 opName, (outs SReg_64:$sdst), (ins SSrc_b32:$src0),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000105 "$sdst, $src0", pattern
106>;
107
108// no input, 64-bit output.
109class SOP1_64_0 <string opName, list<dag> pattern=[]> : SOP1_Pseudo <
110 opName, (outs SReg_64:$sdst), (ins), "$sdst", pattern> {
111 let has_src0 = 0;
112}
113
114// 64-bit input, no output
115class SOP1_1 <string opName, list<dag> pattern=[]> : SOP1_Pseudo <
116 opName, (outs), (ins SReg_64:$src0), "$src0", pattern> {
117 let has_sdst = 0;
118}
119
120
121let isMoveImm = 1 in {
122 let isReMaterializable = 1, isAsCheapAsAMove = 1 in {
123 def S_MOV_B32 : SOP1_32 <"s_mov_b32">;
124 def S_MOV_B64 : SOP1_64 <"s_mov_b64">;
125 } // End isRematerializeable = 1
126
127 let Uses = [SCC] in {
128 def S_CMOV_B32 : SOP1_32 <"s_cmov_b32">;
129 def S_CMOV_B64 : SOP1_64 <"s_cmov_b64">;
130 } // End Uses = [SCC]
131} // End isMoveImm = 1
132
133let Defs = [SCC] in {
134 def S_NOT_B32 : SOP1_32 <"s_not_b32",
135 [(set i32:$sdst, (not i32:$src0))]
136 >;
137
138 def S_NOT_B64 : SOP1_64 <"s_not_b64",
139 [(set i64:$sdst, (not i64:$src0))]
140 >;
141 def S_WQM_B32 : SOP1_32 <"s_wqm_b32">;
142 def S_WQM_B64 : SOP1_64 <"s_wqm_b64">;
143} // End Defs = [SCC]
144
145
146def S_BREV_B32 : SOP1_32 <"s_brev_b32",
147 [(set i32:$sdst, (bitreverse i32:$src0))]
148>;
149def S_BREV_B64 : SOP1_64 <"s_brev_b64">;
150
151let Defs = [SCC] in {
152def S_BCNT0_I32_B32 : SOP1_32 <"s_bcnt0_i32_b32">;
153def S_BCNT0_I32_B64 : SOP1_32_64 <"s_bcnt0_i32_b64">;
154def S_BCNT1_I32_B32 : SOP1_32 <"s_bcnt1_i32_b32",
155 [(set i32:$sdst, (ctpop i32:$src0))]
156>;
157def S_BCNT1_I32_B64 : SOP1_32_64 <"s_bcnt1_i32_b64">;
158} // End Defs = [SCC]
159
160def S_FF0_I32_B32 : SOP1_32 <"s_ff0_i32_b32">;
161def S_FF0_I32_B64 : SOP1_32_64 <"s_ff0_i32_b64">;
162def S_FF1_I32_B32 : SOP1_32 <"s_ff1_i32_b32",
163 [(set i32:$sdst, (cttz_zero_undef i32:$src0))]
164>;
165def S_FF1_I32_B64 : SOP1_32_64 <"s_ff1_i32_b64">;
166
167def S_FLBIT_I32_B32 : SOP1_32 <"s_flbit_i32_b32",
168 [(set i32:$sdst, (AMDGPUffbh_u32 i32:$src0))]
169>;
170
171def S_FLBIT_I32_B64 : SOP1_32_64 <"s_flbit_i32_b64">;
172def S_FLBIT_I32 : SOP1_32 <"s_flbit_i32",
173 [(set i32:$sdst, (AMDGPUffbh_i32 i32:$src0))]
174>;
175def S_FLBIT_I32_I64 : SOP1_32_64 <"s_flbit_i32_i64">;
176def S_SEXT_I32_I8 : SOP1_32 <"s_sext_i32_i8",
177 [(set i32:$sdst, (sext_inreg i32:$src0, i8))]
178>;
179def S_SEXT_I32_I16 : SOP1_32 <"s_sext_i32_i16",
180 [(set i32:$sdst, (sext_inreg i32:$src0, i16))]
181>;
182
183def S_BITSET0_B32 : SOP1_32 <"s_bitset0_b32">;
184def S_BITSET0_B64 : SOP1_64_32 <"s_bitset0_b64">;
185def S_BITSET1_B32 : SOP1_32 <"s_bitset1_b32">;
186def S_BITSET1_B64 : SOP1_64_32 <"s_bitset1_b64">;
Konstantin Zhuravlyovb2ff8df2017-05-26 20:38:26 +0000187def S_GETPC_B64 : SOP1_64_0 <"s_getpc_b64",
188 [(set i64:$sdst, (int_amdgcn_s_getpc))]
189>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000190
Matt Arsenault2b1f9aa2017-05-17 21:56:25 +0000191let isTerminator = 1, isBarrier = 1, SchedRW = [WriteBranch] in {
192
193let isBranch = 1, isIndirectBranch = 1 in {
Valery Pykhtina34fb492016-08-30 15:20:31 +0000194def S_SETPC_B64 : SOP1_1 <"s_setpc_b64">;
Matt Arsenault2b1f9aa2017-05-17 21:56:25 +0000195} // End isBranch = 1, isIndirectBranch = 1
196
197let isReturn = 1 in {
198// Define variant marked as return rather than branch.
199def S_SETPC_B64_return : SOP1_1<"", [(AMDGPUret_flag i64:$src0)]>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000200}
Matt Arsenault2b1f9aa2017-05-17 21:56:25 +0000201} // End isTerminator = 1, isBarrier = 1
202
203let isCall = 1 in {
204def S_SWAPPC_B64 : SOP1_64 <"s_swappc_b64"
205>;
206}
207
Valery Pykhtina34fb492016-08-30 15:20:31 +0000208def S_RFE_B64 : SOP1_1 <"s_rfe_b64">;
209
210let hasSideEffects = 1, Uses = [EXEC], Defs = [EXEC, SCC] in {
211
212def S_AND_SAVEEXEC_B64 : SOP1_64 <"s_and_saveexec_b64">;
213def S_OR_SAVEEXEC_B64 : SOP1_64 <"s_or_saveexec_b64">;
214def S_XOR_SAVEEXEC_B64 : SOP1_64 <"s_xor_saveexec_b64">;
215def S_ANDN2_SAVEEXEC_B64 : SOP1_64 <"s_andn2_saveexec_b64">;
216def S_ORN2_SAVEEXEC_B64 : SOP1_64 <"s_orn2_saveexec_b64">;
217def S_NAND_SAVEEXEC_B64 : SOP1_64 <"s_nand_saveexec_b64">;
218def S_NOR_SAVEEXEC_B64 : SOP1_64 <"s_nor_saveexec_b64">;
219def S_XNOR_SAVEEXEC_B64 : SOP1_64 <"s_xnor_saveexec_b64">;
220
221} // End hasSideEffects = 1, Uses = [EXEC], Defs = [EXEC, SCC]
222
223def S_QUADMASK_B32 : SOP1_32 <"s_quadmask_b32">;
224def S_QUADMASK_B64 : SOP1_64 <"s_quadmask_b64">;
225
226let Uses = [M0] in {
227def S_MOVRELS_B32 : SOP1_32 <"s_movrels_b32">;
228def S_MOVRELS_B64 : SOP1_64 <"s_movrels_b64">;
229def S_MOVRELD_B32 : SOP1_32 <"s_movreld_b32">;
230def S_MOVRELD_B64 : SOP1_64 <"s_movreld_b64">;
231} // End Uses = [M0]
232
Dmitry Preobrazhensky12194e92017-04-12 12:40:19 +0000233def S_CBRANCH_JOIN : SOP1_0_32R <"s_cbranch_join">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000234def S_MOV_REGRD_B32 : SOP1_32 <"s_mov_regrd_b32">;
235let Defs = [SCC] in {
236def S_ABS_I32 : SOP1_32 <"s_abs_i32">;
237} // End Defs = [SCC]
238def S_MOV_FED_B32 : SOP1_32 <"s_mov_fed_b32">;
239
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000240let SubtargetPredicate = HasVGPRIndexMode in {
241def S_SET_GPR_IDX_IDX : SOP1_0_32<"s_set_gpr_idx_idx"> {
242 let Uses = [M0];
243 let Defs = [M0];
244}
245}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000246
247//===----------------------------------------------------------------------===//
248// SOP2 Instructions
249//===----------------------------------------------------------------------===//
250
251class SOP2_Pseudo<string opName, dag outs, dag ins,
252 string asmOps, list<dag> pattern=[]> :
253 InstSI<outs, ins, "", pattern>,
254 SIMCInstr<opName, SIEncodingFamily.NONE> {
255 let isPseudo = 1;
256 let isCodeGenOnly = 1;
257 let SubtargetPredicate = isGCN;
258 let mayLoad = 0;
259 let mayStore = 0;
260 let hasSideEffects = 0;
261 let SALU = 1;
262 let SOP2 = 1;
263 let SchedRW = [WriteSALU];
264 let UseNamedOperandTable = 1;
265
266 string Mnemonic = opName;
267 string AsmOperands = asmOps;
268
269 bits<1> has_sdst = 1;
270
271 // Pseudo instructions have no encodings, but adding this field here allows
272 // us to do:
273 // let sdst = xxx in {
274 // for multiclasses that include both real and pseudo instructions.
275 // field bits<7> sdst = 0;
276 // let Size = 4; // Do we need size here?
277}
278
279class SOP2_Real<bits<7> op, SOP2_Pseudo ps> :
280 InstSI <ps.OutOperandList, ps.InOperandList,
281 ps.Mnemonic # " " # ps.AsmOperands, []>,
282 Enc32 {
283 let isPseudo = 0;
284 let isCodeGenOnly = 0;
285
286 // copy relevant pseudo op flags
287 let SubtargetPredicate = ps.SubtargetPredicate;
288 let AsmMatchConverter = ps.AsmMatchConverter;
289
290 // encoding
291 bits<7> sdst;
292 bits<8> src0;
293 bits<8> src1;
294
295 let Inst{7-0} = src0;
296 let Inst{15-8} = src1;
297 let Inst{22-16} = !if(ps.has_sdst, sdst, ?);
298 let Inst{29-23} = op;
299 let Inst{31-30} = 0x2; // encoding
300}
301
302
303class SOP2_32 <string opName, list<dag> pattern=[]> : SOP2_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000304 opName, (outs SReg_32:$sdst), (ins SSrc_b32:$src0, SSrc_b32:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000305 "$sdst, $src0, $src1", pattern
306>;
307
308class SOP2_64 <string opName, list<dag> pattern=[]> : SOP2_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000309 opName, (outs SReg_64:$sdst), (ins SSrc_b64:$src0, SSrc_b64:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000310 "$sdst, $src0, $src1", pattern
311>;
312
313class SOP2_64_32 <string opName, list<dag> pattern=[]> : SOP2_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000314 opName, (outs SReg_64:$sdst), (ins SSrc_b64:$src0, SSrc_b32:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000315 "$sdst, $src0, $src1", pattern
316>;
317
318class SOP2_64_32_32 <string opName, list<dag> pattern=[]> : SOP2_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000319 opName, (outs SReg_64:$sdst), (ins SSrc_b32:$src0, SSrc_b32:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000320 "$sdst, $src0, $src1", pattern
321>;
322
323let Defs = [SCC] in { // Carry out goes to SCC
324let isCommutable = 1 in {
325def S_ADD_U32 : SOP2_32 <"s_add_u32">;
326def S_ADD_I32 : SOP2_32 <"s_add_i32",
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000327 [(set i32:$sdst, (add SSrc_b32:$src0, SSrc_b32:$src1))]
Valery Pykhtina34fb492016-08-30 15:20:31 +0000328>;
329} // End isCommutable = 1
330
331def S_SUB_U32 : SOP2_32 <"s_sub_u32">;
332def S_SUB_I32 : SOP2_32 <"s_sub_i32",
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000333 [(set i32:$sdst, (sub SSrc_b32:$src0, SSrc_b32:$src1))]
Valery Pykhtina34fb492016-08-30 15:20:31 +0000334>;
335
336let Uses = [SCC] in { // Carry in comes from SCC
337let isCommutable = 1 in {
338def S_ADDC_U32 : SOP2_32 <"s_addc_u32",
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000339 [(set i32:$sdst, (adde (i32 SSrc_b32:$src0), (i32 SSrc_b32:$src1)))]>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000340} // End isCommutable = 1
341
342def S_SUBB_U32 : SOP2_32 <"s_subb_u32",
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000343 [(set i32:$sdst, (sube (i32 SSrc_b32:$src0), (i32 SSrc_b32:$src1)))]>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000344} // End Uses = [SCC]
345
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000346
347let isCommutable = 1 in {
Valery Pykhtina34fb492016-08-30 15:20:31 +0000348def S_MIN_I32 : SOP2_32 <"s_min_i32",
349 [(set i32:$sdst, (smin i32:$src0, i32:$src1))]
350>;
351def S_MIN_U32 : SOP2_32 <"s_min_u32",
352 [(set i32:$sdst, (umin i32:$src0, i32:$src1))]
353>;
354def S_MAX_I32 : SOP2_32 <"s_max_i32",
355 [(set i32:$sdst, (smax i32:$src0, i32:$src1))]
356>;
357def S_MAX_U32 : SOP2_32 <"s_max_u32",
358 [(set i32:$sdst, (umax i32:$src0, i32:$src1))]
359>;
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000360} // End isCommutable = 1
Valery Pykhtina34fb492016-08-30 15:20:31 +0000361} // End Defs = [SCC]
362
363
364let Uses = [SCC] in {
365 def S_CSELECT_B32 : SOP2_32 <"s_cselect_b32">;
366 def S_CSELECT_B64 : SOP2_64 <"s_cselect_b64">;
367} // End Uses = [SCC]
368
369let Defs = [SCC] in {
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000370let isCommutable = 1 in {
Valery Pykhtina34fb492016-08-30 15:20:31 +0000371def S_AND_B32 : SOP2_32 <"s_and_b32",
372 [(set i32:$sdst, (and i32:$src0, i32:$src1))]
373>;
374
375def S_AND_B64 : SOP2_64 <"s_and_b64",
376 [(set i64:$sdst, (and i64:$src0, i64:$src1))]
377>;
378
379def S_OR_B32 : SOP2_32 <"s_or_b32",
380 [(set i32:$sdst, (or i32:$src0, i32:$src1))]
381>;
382
383def S_OR_B64 : SOP2_64 <"s_or_b64",
384 [(set i64:$sdst, (or i64:$src0, i64:$src1))]
385>;
386
387def S_XOR_B32 : SOP2_32 <"s_xor_b32",
388 [(set i32:$sdst, (xor i32:$src0, i32:$src1))]
389>;
390
391def S_XOR_B64 : SOP2_64 <"s_xor_b64",
392 [(set i64:$sdst, (xor i64:$src0, i64:$src1))]
393>;
Konstantin Zhuravlyovca8946a2017-09-18 21:22:45 +0000394
395def S_XNOR_B32 : SOP2_32 <"s_xnor_b32",
396 [(set i32:$sdst, (not (xor_oneuse i32:$src0, i32:$src1)))]
397>;
398
399def S_XNOR_B64 : SOP2_64 <"s_xnor_b64",
400 [(set i64:$sdst, (not (xor_oneuse i64:$src0, i64:$src1)))]
401>;
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000402} // End isCommutable = 1
403
Valery Pykhtina34fb492016-08-30 15:20:31 +0000404def S_ANDN2_B32 : SOP2_32 <"s_andn2_b32">;
405def S_ANDN2_B64 : SOP2_64 <"s_andn2_b64">;
406def S_ORN2_B32 : SOP2_32 <"s_orn2_b32">;
407def S_ORN2_B64 : SOP2_64 <"s_orn2_b64">;
408def S_NAND_B32 : SOP2_32 <"s_nand_b32">;
409def S_NAND_B64 : SOP2_64 <"s_nand_b64">;
410def S_NOR_B32 : SOP2_32 <"s_nor_b32">;
411def S_NOR_B64 : SOP2_64 <"s_nor_b64">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000412} // End Defs = [SCC]
413
414// Use added complexity so these patterns are preferred to the VALU patterns.
415let AddedComplexity = 1 in {
416
417let Defs = [SCC] in {
418def S_LSHL_B32 : SOP2_32 <"s_lshl_b32",
419 [(set i32:$sdst, (shl i32:$src0, i32:$src1))]
420>;
421def S_LSHL_B64 : SOP2_64_32 <"s_lshl_b64",
422 [(set i64:$sdst, (shl i64:$src0, i32:$src1))]
423>;
424def S_LSHR_B32 : SOP2_32 <"s_lshr_b32",
425 [(set i32:$sdst, (srl i32:$src0, i32:$src1))]
426>;
427def S_LSHR_B64 : SOP2_64_32 <"s_lshr_b64",
428 [(set i64:$sdst, (srl i64:$src0, i32:$src1))]
429>;
430def S_ASHR_I32 : SOP2_32 <"s_ashr_i32",
431 [(set i32:$sdst, (sra i32:$src0, i32:$src1))]
432>;
433def S_ASHR_I64 : SOP2_64_32 <"s_ashr_i64",
434 [(set i64:$sdst, (sra i64:$src0, i32:$src1))]
435>;
436} // End Defs = [SCC]
437
438def S_BFM_B32 : SOP2_32 <"s_bfm_b32",
439 [(set i32:$sdst, (AMDGPUbfm i32:$src0, i32:$src1))]>;
440def S_BFM_B64 : SOP2_64_32_32 <"s_bfm_b64">;
441def S_MUL_I32 : SOP2_32 <"s_mul_i32",
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000442 [(set i32:$sdst, (mul i32:$src0, i32:$src1))]> {
443 let isCommutable = 1;
444}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000445
446} // End AddedComplexity = 1
447
448let Defs = [SCC] in {
449def S_BFE_U32 : SOP2_32 <"s_bfe_u32">;
450def S_BFE_I32 : SOP2_32 <"s_bfe_i32">;
451def S_BFE_U64 : SOP2_64_32 <"s_bfe_u64">;
452def S_BFE_I64 : SOP2_64_32 <"s_bfe_i64">;
453} // End Defs = [SCC]
454
455def S_CBRANCH_G_FORK : SOP2_Pseudo <
456 "s_cbranch_g_fork", (outs),
Dmitry Preobrazhensky57148602017-04-14 11:52:26 +0000457 (ins SCSrc_b64:$src0, SCSrc_b64:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000458 "$src0, $src1"
459> {
460 let has_sdst = 0;
461}
462
463let Defs = [SCC] in {
464def S_ABSDIFF_I32 : SOP2_32 <"s_absdiff_i32">;
465} // End Defs = [SCC]
466
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000467let SubtargetPredicate = isVI in {
468 def S_RFE_RESTORE_B64 : SOP2_Pseudo <
469 "s_rfe_restore_b64", (outs),
470 (ins SSrc_b64:$src0, SSrc_b32:$src1),
471 "$src0, $src1"
472 > {
473 let hasSideEffects = 1;
474 let has_sdst = 0;
475 }
476}
477
Matt Arsenault9be7b0d2017-02-27 18:49:11 +0000478let SubtargetPredicate = isGFX9 in {
479 def S_PACK_LL_B32_B16 : SOP2_32<"s_pack_ll_b32_b16">;
480 def S_PACK_LH_B32_B16 : SOP2_32<"s_pack_lh_b32_b16">;
481 def S_PACK_HH_B32_B16 : SOP2_32<"s_pack_hh_b32_b16">;
482}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000483
484//===----------------------------------------------------------------------===//
485// SOPK Instructions
486//===----------------------------------------------------------------------===//
487
488class SOPK_Pseudo <string opName, dag outs, dag ins,
489 string asmOps, list<dag> pattern=[]> :
490 InstSI <outs, ins, "", pattern>,
491 SIMCInstr<opName, SIEncodingFamily.NONE> {
492 let isPseudo = 1;
493 let isCodeGenOnly = 1;
494 let SubtargetPredicate = isGCN;
495 let mayLoad = 0;
496 let mayStore = 0;
497 let hasSideEffects = 0;
498 let SALU = 1;
499 let SOPK = 1;
500 let SchedRW = [WriteSALU];
501 let UseNamedOperandTable = 1;
502 string Mnemonic = opName;
503 string AsmOperands = asmOps;
504
505 bits<1> has_sdst = 1;
506}
507
508class SOPK_Real<bits<5> op, SOPK_Pseudo ps> :
509 InstSI <ps.OutOperandList, ps.InOperandList,
510 ps.Mnemonic # " " # ps.AsmOperands, []> {
511 let isPseudo = 0;
512 let isCodeGenOnly = 0;
513
514 // copy relevant pseudo op flags
515 let SubtargetPredicate = ps.SubtargetPredicate;
516 let AsmMatchConverter = ps.AsmMatchConverter;
517 let DisableEncoding = ps.DisableEncoding;
518 let Constraints = ps.Constraints;
519
520 // encoding
521 bits<7> sdst;
522 bits<16> simm16;
523 bits<32> imm;
524}
525
526class SOPK_Real32<bits<5> op, SOPK_Pseudo ps> :
527 SOPK_Real <op, ps>,
528 Enc32 {
529 let Inst{15-0} = simm16;
530 let Inst{22-16} = !if(ps.has_sdst, sdst, ?);
531 let Inst{27-23} = op;
532 let Inst{31-28} = 0xb; //encoding
533}
534
535class SOPK_Real64<bits<5> op, SOPK_Pseudo ps> :
536 SOPK_Real<op, ps>,
537 Enc64 {
538 let Inst{15-0} = simm16;
539 let Inst{22-16} = !if(ps.has_sdst, sdst, ?);
540 let Inst{27-23} = op;
541 let Inst{31-28} = 0xb; //encoding
542 let Inst{63-32} = imm;
543}
544
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000545class SOPKInstTable <bit is_sopk, string cmpOp = ""> {
546 bit IsSOPK = is_sopk;
547 string BaseCmpOp = cmpOp;
548}
549
Valery Pykhtina34fb492016-08-30 15:20:31 +0000550class SOPK_32 <string opName, list<dag> pattern=[]> : SOPK_Pseudo <
551 opName,
552 (outs SReg_32:$sdst),
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000553 (ins s16imm:$simm16),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000554 "$sdst, $simm16",
555 pattern>;
556
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000557class SOPK_SCC <string opName, string base_op, bit isSignExt> : SOPK_Pseudo <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000558 opName,
559 (outs),
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000560 !if(isSignExt,
561 (ins SReg_32:$sdst, s16imm:$simm16),
562 (ins SReg_32:$sdst, u16imm:$simm16)),
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000563 "$sdst, $simm16", []>,
564 SOPKInstTable<1, base_op>{
Valery Pykhtina34fb492016-08-30 15:20:31 +0000565 let Defs = [SCC];
566}
567
568class SOPK_32TIE <string opName, list<dag> pattern=[]> : SOPK_Pseudo <
569 opName,
570 (outs SReg_32:$sdst),
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000571 (ins SReg_32:$src0, s16imm:$simm16),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000572 "$sdst, $simm16",
573 pattern
574>;
575
576let isReMaterializable = 1, isMoveImm = 1 in {
577def S_MOVK_I32 : SOPK_32 <"s_movk_i32">;
578} // End isReMaterializable = 1
579let Uses = [SCC] in {
580def S_CMOVK_I32 : SOPK_32 <"s_cmovk_i32">;
581}
582
583let isCompare = 1 in {
584
585// This instruction is disabled for now until we can figure out how to teach
586// the instruction selector to correctly use the S_CMP* vs V_CMP*
587// instructions.
588//
589// When this instruction is enabled the code generator sometimes produces this
590// invalid sequence:
591//
592// SCC = S_CMPK_EQ_I32 SGPR0, imm
593// VCC = COPY SCC
594// VGPR0 = V_CNDMASK VCC, VGPR0, VGPR1
595//
596// def S_CMPK_EQ_I32 : SOPK_SCC <"s_cmpk_eq_i32",
597// [(set i1:$dst, (setcc i32:$src0, imm:$src1, SETEQ))]
598// >;
599
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000600def S_CMPK_EQ_I32 : SOPK_SCC <"s_cmpk_eq_i32", "s_cmp_eq_i32", 1>;
601def S_CMPK_LG_I32 : SOPK_SCC <"s_cmpk_lg_i32", "s_cmp_lg_i32", 1>;
602def S_CMPK_GT_I32 : SOPK_SCC <"s_cmpk_gt_i32", "s_cmp_gt_i32", 1>;
603def S_CMPK_GE_I32 : SOPK_SCC <"s_cmpk_ge_i32", "s_cmp_ge_i32", 1>;
604def S_CMPK_LT_I32 : SOPK_SCC <"s_cmpk_lt_i32", "s_cmp_lt_i32", 1>;
605def S_CMPK_LE_I32 : SOPK_SCC <"s_cmpk_le_i32", "s_cmp_le_i32", 1>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000606
607let SOPKZext = 1 in {
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000608def S_CMPK_EQ_U32 : SOPK_SCC <"s_cmpk_eq_u32", "s_cmp_eq_u32", 0>;
609def S_CMPK_LG_U32 : SOPK_SCC <"s_cmpk_lg_u32", "s_cmp_lg_u32", 0>;
610def S_CMPK_GT_U32 : SOPK_SCC <"s_cmpk_gt_u32", "s_cmp_gt_u32", 0>;
611def S_CMPK_GE_U32 : SOPK_SCC <"s_cmpk_ge_u32", "s_cmp_ge_u32", 0>;
612def S_CMPK_LT_U32 : SOPK_SCC <"s_cmpk_lt_u32", "s_cmp_lt_u32", 0>;
613def S_CMPK_LE_U32 : SOPK_SCC <"s_cmpk_le_u32", "s_cmp_le_u32", 0>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000614} // End SOPKZext = 1
Valery Pykhtina34fb492016-08-30 15:20:31 +0000615} // End isCompare = 1
616
617let Defs = [SCC], isCommutable = 1, DisableEncoding = "$src0",
618 Constraints = "$sdst = $src0" in {
619 def S_ADDK_I32 : SOPK_32TIE <"s_addk_i32">;
620 def S_MULK_I32 : SOPK_32TIE <"s_mulk_i32">;
621}
622
623def S_CBRANCH_I_FORK : SOPK_Pseudo <
624 "s_cbranch_i_fork",
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000625 (outs), (ins SReg_64:$sdst, s16imm:$simm16),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000626 "$sdst, $simm16"
627>;
628
629let mayLoad = 1 in {
630def S_GETREG_B32 : SOPK_Pseudo <
631 "s_getreg_b32",
632 (outs SReg_32:$sdst), (ins hwreg:$simm16),
633 "$sdst, $simm16"
634>;
635}
636
Tom Stellard8485fa02016-12-07 02:42:15 +0000637let hasSideEffects = 1 in {
638
Valery Pykhtina34fb492016-08-30 15:20:31 +0000639def S_SETREG_B32 : SOPK_Pseudo <
640 "s_setreg_b32",
641 (outs), (ins SReg_32:$sdst, hwreg:$simm16),
Tom Stellard8485fa02016-12-07 02:42:15 +0000642 "$simm16, $sdst",
643 [(AMDGPUsetreg i32:$sdst, (i16 timm:$simm16))]
Valery Pykhtina34fb492016-08-30 15:20:31 +0000644>;
645
646// FIXME: Not on SI?
647//def S_GETREG_REGRD_B32 : SOPK_32 <sopk<0x14, 0x13>, "s_getreg_regrd_b32">;
648
649def S_SETREG_IMM32_B32 : SOPK_Pseudo <
650 "s_setreg_imm32_b32",
651 (outs), (ins i32imm:$imm, hwreg:$simm16),
Matt Arsenault10c17ca2016-10-06 10:13:23 +0000652 "$simm16, $imm"> {
653 let Size = 8; // Unlike every other SOPK instruction.
Valery Pykhtina34fb492016-08-30 15:20:31 +0000654 let has_sdst = 0;
655}
656
Tom Stellard8485fa02016-12-07 02:42:15 +0000657} // End hasSideEffects = 1
Valery Pykhtina34fb492016-08-30 15:20:31 +0000658
659//===----------------------------------------------------------------------===//
660// SOPC Instructions
661//===----------------------------------------------------------------------===//
662
663class SOPCe <bits<7> op> : Enc32 {
664 bits<8> src0;
665 bits<8> src1;
666
667 let Inst{7-0} = src0;
668 let Inst{15-8} = src1;
669 let Inst{22-16} = op;
670 let Inst{31-23} = 0x17e;
671}
672
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000673class SOPC <bits<7> op, dag outs, dag ins, string asm,
674 list<dag> pattern = []> :
Valery Pykhtina34fb492016-08-30 15:20:31 +0000675 InstSI<outs, ins, asm, pattern>, SOPCe <op> {
676 let mayLoad = 0;
677 let mayStore = 0;
678 let hasSideEffects = 0;
679 let SALU = 1;
680 let SOPC = 1;
681 let isCodeGenOnly = 0;
682 let Defs = [SCC];
683 let SchedRW = [WriteSALU];
684 let UseNamedOperandTable = 1;
685 let SubtargetPredicate = isGCN;
686}
687
688class SOPC_Base <bits<7> op, RegisterOperand rc0, RegisterOperand rc1,
689 string opName, list<dag> pattern = []> : SOPC <
690 op, (outs), (ins rc0:$src0, rc1:$src1),
691 opName#" $src0, $src1", pattern > {
692 let Defs = [SCC];
693}
694class SOPC_Helper <bits<7> op, RegisterOperand rc, ValueType vt,
695 string opName, PatLeaf cond> : SOPC_Base <
696 op, rc, rc, opName,
697 [(set SCC, (si_setcc_uniform vt:$src0, vt:$src1, cond))] > {
698}
699
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000700class SOPC_CMP_32<bits<7> op, string opName,
701 PatLeaf cond = COND_NULL, string revOp = opName>
702 : SOPC_Helper<op, SSrc_b32, i32, opName, cond>,
703 Commutable_REV<revOp, !eq(revOp, opName)>,
704 SOPKInstTable<0, opName> {
705 let isCompare = 1;
706 let isCommutable = 1;
707}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000708
Matt Arsenault7b1dc2c2016-09-17 02:02:19 +0000709class SOPC_CMP_64<bits<7> op, string opName,
710 PatLeaf cond = COND_NULL, string revOp = opName>
711 : SOPC_Helper<op, SSrc_b64, i64, opName, cond>,
712 Commutable_REV<revOp, !eq(revOp, opName)> {
713 let isCompare = 1;
714 let isCommutable = 1;
715}
716
Valery Pykhtina34fb492016-08-30 15:20:31 +0000717class SOPC_32<bits<7> op, string opName, list<dag> pattern = []>
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000718 : SOPC_Base<op, SSrc_b32, SSrc_b32, opName, pattern>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000719
720class SOPC_64_32<bits<7> op, string opName, list<dag> pattern = []>
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000721 : SOPC_Base<op, SSrc_b64, SSrc_b32, opName, pattern>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000722
Matt Arsenault5d8eb252016-09-30 01:50:20 +0000723def S_CMP_EQ_I32 : SOPC_CMP_32 <0x00, "s_cmp_eq_i32">;
724def S_CMP_LG_I32 : SOPC_CMP_32 <0x01, "s_cmp_lg_i32">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000725def S_CMP_GT_I32 : SOPC_CMP_32 <0x02, "s_cmp_gt_i32", COND_SGT>;
726def S_CMP_GE_I32 : SOPC_CMP_32 <0x03, "s_cmp_ge_i32", COND_SGE>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000727def S_CMP_LT_I32 : SOPC_CMP_32 <0x04, "s_cmp_lt_i32", COND_SLT, "s_cmp_gt_i32">;
728def S_CMP_LE_I32 : SOPC_CMP_32 <0x05, "s_cmp_le_i32", COND_SLE, "s_cmp_ge_i32">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000729def S_CMP_EQ_U32 : SOPC_CMP_32 <0x06, "s_cmp_eq_u32", COND_EQ>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000730def S_CMP_LG_U32 : SOPC_CMP_32 <0x07, "s_cmp_lg_u32", COND_NE>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000731def S_CMP_GT_U32 : SOPC_CMP_32 <0x08, "s_cmp_gt_u32", COND_UGT>;
732def S_CMP_GE_U32 : SOPC_CMP_32 <0x09, "s_cmp_ge_u32", COND_UGE>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000733def S_CMP_LT_U32 : SOPC_CMP_32 <0x0a, "s_cmp_lt_u32", COND_ULT, "s_cmp_gt_u32">;
734def S_CMP_LE_U32 : SOPC_CMP_32 <0x0b, "s_cmp_le_u32", COND_ULE, "s_cmp_ge_u32">;
735
Valery Pykhtina34fb492016-08-30 15:20:31 +0000736def S_BITCMP0_B32 : SOPC_32 <0x0c, "s_bitcmp0_b32">;
737def S_BITCMP1_B32 : SOPC_32 <0x0d, "s_bitcmp1_b32">;
738def S_BITCMP0_B64 : SOPC_64_32 <0x0e, "s_bitcmp0_b64">;
739def S_BITCMP1_B64 : SOPC_64_32 <0x0f, "s_bitcmp1_b64">;
740def S_SETVSKIP : SOPC_32 <0x10, "s_setvskip">;
741
Matt Arsenault7b1dc2c2016-09-17 02:02:19 +0000742let SubtargetPredicate = isVI in {
743def S_CMP_EQ_U64 : SOPC_CMP_64 <0x12, "s_cmp_eq_u64", COND_EQ>;
744def S_CMP_LG_U64 : SOPC_CMP_64 <0x13, "s_cmp_lg_u64", COND_NE>;
745}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000746
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000747let SubtargetPredicate = HasVGPRIndexMode in {
748def S_SET_GPR_IDX_ON : SOPC <0x11,
749 (outs),
750 (ins SSrc_b32:$src0, GPRIdxMode:$src1),
751 "s_set_gpr_idx_on $src0,$src1"> {
752 let Defs = [M0]; // No scc def
753 let Uses = [M0]; // Other bits of m0 unmodified.
754 let hasSideEffects = 1; // Sets mode.gpr_idx_en
Matt Arsenault2d8c2892016-11-01 20:42:24 +0000755 let FixedSize = 1;
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000756}
757}
758
Valery Pykhtina34fb492016-08-30 15:20:31 +0000759//===----------------------------------------------------------------------===//
760// SOPP Instructions
761//===----------------------------------------------------------------------===//
762
763class SOPPe <bits<7> op> : Enc32 {
764 bits <16> simm16;
765
766 let Inst{15-0} = simm16;
767 let Inst{22-16} = op;
768 let Inst{31-23} = 0x17f; // encoding
769}
770
771class SOPP <bits<7> op, dag ins, string asm, list<dag> pattern = []> :
772 InstSI <(outs), ins, asm, pattern >, SOPPe <op> {
773
774 let mayLoad = 0;
775 let mayStore = 0;
776 let hasSideEffects = 0;
777 let SALU = 1;
778 let SOPP = 1;
Matt Arsenault10c17ca2016-10-06 10:13:23 +0000779 let Size = 4;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000780 let SchedRW = [WriteSALU];
781
782 let UseNamedOperandTable = 1;
783 let SubtargetPredicate = isGCN;
784}
785
786
787def S_NOP : SOPP <0x00000000, (ins i16imm:$simm16), "s_nop $simm16">;
788
789let isTerminator = 1 in {
790
791def S_ENDPGM : SOPP <0x00000001, (ins), "s_endpgm",
792 [(AMDGPUendpgm)]> {
793 let simm16 = 0;
794 let isBarrier = 1;
Matt Arsenault4e9c1e32016-10-28 23:00:38 +0000795 let isReturn = 1;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000796}
797
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000798let SubtargetPredicate = isVI in {
799def S_ENDPGM_SAVED : SOPP <0x0000001B, (ins), "s_endpgm_saved"> {
800 let simm16 = 0;
801 let isBarrier = 1;
802 let isReturn = 1;
803}
804}
805
Valery Pykhtina34fb492016-08-30 15:20:31 +0000806let isBranch = 1, SchedRW = [WriteBranch] in {
807def S_BRANCH : SOPP <
808 0x00000002, (ins sopp_brtarget:$simm16), "s_branch $simm16",
809 [(br bb:$simm16)]> {
810 let isBarrier = 1;
811}
812
813let Uses = [SCC] in {
814def S_CBRANCH_SCC0 : SOPP <
815 0x00000004, (ins sopp_brtarget:$simm16),
816 "s_cbranch_scc0 $simm16"
817>;
818def S_CBRANCH_SCC1 : SOPP <
819 0x00000005, (ins sopp_brtarget:$simm16),
Matt Arsenaultd674e0a2017-10-10 20:34:49 +0000820 "s_cbranch_scc1 $simm16"
Valery Pykhtina34fb492016-08-30 15:20:31 +0000821>;
822} // End Uses = [SCC]
823
824let Uses = [VCC] in {
825def S_CBRANCH_VCCZ : SOPP <
826 0x00000006, (ins sopp_brtarget:$simm16),
827 "s_cbranch_vccz $simm16"
828>;
829def S_CBRANCH_VCCNZ : SOPP <
830 0x00000007, (ins sopp_brtarget:$simm16),
831 "s_cbranch_vccnz $simm16"
832>;
833} // End Uses = [VCC]
834
835let Uses = [EXEC] in {
836def S_CBRANCH_EXECZ : SOPP <
837 0x00000008, (ins sopp_brtarget:$simm16),
838 "s_cbranch_execz $simm16"
839>;
840def S_CBRANCH_EXECNZ : SOPP <
841 0x00000009, (ins sopp_brtarget:$simm16),
842 "s_cbranch_execnz $simm16"
843>;
844} // End Uses = [EXEC]
845
Dmitry Preobrazhensky3ac63112017-04-05 17:26:45 +0000846def S_CBRANCH_CDBGSYS : SOPP <
847 0x00000017, (ins sopp_brtarget:$simm16),
848 "s_cbranch_cdbgsys $simm16"
849>;
850
851def S_CBRANCH_CDBGSYS_AND_USER : SOPP <
852 0x0000001A, (ins sopp_brtarget:$simm16),
853 "s_cbranch_cdbgsys_and_user $simm16"
854>;
855
856def S_CBRANCH_CDBGSYS_OR_USER : SOPP <
857 0x00000019, (ins sopp_brtarget:$simm16),
858 "s_cbranch_cdbgsys_or_user $simm16"
859>;
860
861def S_CBRANCH_CDBGUSER : SOPP <
862 0x00000018, (ins sopp_brtarget:$simm16),
863 "s_cbranch_cdbguser $simm16"
864>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000865
866} // End isBranch = 1
867} // End isTerminator = 1
868
869let hasSideEffects = 1 in {
870def S_BARRIER : SOPP <0x0000000a, (ins), "s_barrier",
871 [(int_amdgcn_s_barrier)]> {
872 let SchedRW = [WriteBarrier];
873 let simm16 = 0;
874 let mayLoad = 1;
875 let mayStore = 1;
876 let isConvergent = 1;
877}
878
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000879let SubtargetPredicate = isVI in {
880def S_WAKEUP : SOPP <0x00000003, (ins), "s_wakeup"> {
881 let simm16 = 0;
882 let mayLoad = 1;
883 let mayStore = 1;
884}
885}
886
Valery Pykhtina34fb492016-08-30 15:20:31 +0000887let mayLoad = 1, mayStore = 1, hasSideEffects = 1 in
888def S_WAITCNT : SOPP <0x0000000c, (ins WAIT_FLAG:$simm16), "s_waitcnt $simm16">;
889def S_SETHALT : SOPP <0x0000000d, (ins i16imm:$simm16), "s_sethalt $simm16">;
Dmitry Preobrazhensky3ac63112017-04-05 17:26:45 +0000890def S_SETKILL : SOPP <0x0000000b, (ins i16imm:$simm16), "s_setkill $simm16">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000891
892// On SI the documentation says sleep for approximately 64 * low 2
893// bits, consistent with the reported maximum of 448. On VI the
894// maximum reported is 960 cycles, so 960 / 64 = 15 max, so is the
895// maximum really 15 on VI?
896def S_SLEEP : SOPP <0x0000000e, (ins i32imm:$simm16),
897 "s_sleep $simm16", [(int_amdgcn_s_sleep SIMM16bit:$simm16)]> {
898 let hasSideEffects = 1;
899 let mayLoad = 1;
900 let mayStore = 1;
901}
902
903def S_SETPRIO : SOPP <0x0000000f, (ins i16imm:$simm16), "s_setprio $simm16">;
904
905let Uses = [EXEC, M0] in {
906// FIXME: Should this be mayLoad+mayStore?
907def S_SENDMSG : SOPP <0x00000010, (ins SendMsgImm:$simm16), "s_sendmsg $simm16",
908 [(AMDGPUsendmsg (i32 imm:$simm16))]
909>;
Jan Veselyd48445d2017-01-04 18:06:55 +0000910
911def S_SENDMSGHALT : SOPP <0x00000011, (ins SendMsgImm:$simm16), "s_sendmsghalt $simm16",
912 [(AMDGPUsendmsghalt (i32 imm:$simm16))]
913>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000914} // End Uses = [EXEC, M0]
915
Valery Pykhtina34fb492016-08-30 15:20:31 +0000916def S_TRAP : SOPP <0x00000012, (ins i16imm:$simm16), "s_trap $simm16">;
917def S_ICACHE_INV : SOPP <0x00000013, (ins), "s_icache_inv"> {
918 let simm16 = 0;
919}
920def S_INCPERFLEVEL : SOPP <0x00000014, (ins i32imm:$simm16), "s_incperflevel $simm16",
921 [(int_amdgcn_s_incperflevel SIMM16bit:$simm16)]> {
922 let hasSideEffects = 1;
923 let mayLoad = 1;
924 let mayStore = 1;
925}
926def S_DECPERFLEVEL : SOPP <0x00000015, (ins i32imm:$simm16), "s_decperflevel $simm16",
927 [(int_amdgcn_s_decperflevel SIMM16bit:$simm16)]> {
928 let hasSideEffects = 1;
929 let mayLoad = 1;
930 let mayStore = 1;
931}
932def S_TTRACEDATA : SOPP <0x00000016, (ins), "s_ttracedata"> {
933 let simm16 = 0;
934}
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000935
936let SubtargetPredicate = HasVGPRIndexMode in {
937def S_SET_GPR_IDX_OFF : SOPP<0x1c, (ins), "s_set_gpr_idx_off"> {
938 let simm16 = 0;
939}
940}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000941} // End hasSideEffects
942
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000943let SubtargetPredicate = HasVGPRIndexMode in {
944def S_SET_GPR_IDX_MODE : SOPP<0x1d, (ins GPRIdxMode:$simm16),
945 "s_set_gpr_idx_mode$simm16"> {
946 let Defs = [M0];
947}
948}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000949
Valery Pykhtina34fb492016-08-30 15:20:31 +0000950//===----------------------------------------------------------------------===//
951// S_GETREG_B32 Intrinsic Pattern.
952//===----------------------------------------------------------------------===//
Matt Arsenault90c75932017-10-03 00:06:41 +0000953def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000954 (int_amdgcn_s_getreg imm:$simm16),
955 (S_GETREG_B32 (as_i16imm $simm16))
956>;
957
958//===----------------------------------------------------------------------===//
959// SOP1 Patterns
960//===----------------------------------------------------------------------===//
961
Matt Arsenault90c75932017-10-03 00:06:41 +0000962def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000963 (i64 (ctpop i64:$src)),
964 (i64 (REG_SEQUENCE SReg_64,
965 (i32 (COPY_TO_REGCLASS (S_BCNT1_I32_B64 $src), SReg_32)), sub0,
Tom Stellard115a6152016-11-10 16:02:37 +0000966 (S_MOV_B32 (i32 0)), sub1))
Valery Pykhtina34fb492016-08-30 15:20:31 +0000967>;
968
Matt Arsenault90c75932017-10-03 00:06:41 +0000969def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000970 (i32 (smax i32:$x, (i32 (ineg i32:$x)))),
971 (S_ABS_I32 $x)
972>;
973
Matt Arsenault90c75932017-10-03 00:06:41 +0000974def : GCNPat <
Tom Stellard115a6152016-11-10 16:02:37 +0000975 (i16 imm:$imm),
976 (S_MOV_B32 imm:$imm)
977>;
978
979// Same as a 32-bit inreg
Matt Arsenault90c75932017-10-03 00:06:41 +0000980def : GCNPat<
Tom Stellard115a6152016-11-10 16:02:37 +0000981 (i32 (sext i16:$src)),
982 (S_SEXT_I32_I16 $src)
983>;
984
985
Valery Pykhtina34fb492016-08-30 15:20:31 +0000986//===----------------------------------------------------------------------===//
987// SOP2 Patterns
988//===----------------------------------------------------------------------===//
989
990// V_ADD_I32_e32/S_ADD_U32 produces carry in VCC/SCC. For the vector
991// case, the sgpr-copies pass will fix this to use the vector version.
Matt Arsenault90c75932017-10-03 00:06:41 +0000992def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000993 (i32 (addc i32:$src0, i32:$src1)),
994 (S_ADD_U32 $src0, $src1)
995>;
996
Tom Stellard115a6152016-11-10 16:02:37 +0000997// FIXME: We need to use COPY_TO_REGCLASS to work-around the fact that
998// REG_SEQUENCE patterns don't support instructions with multiple
999// outputs.
Matt Arsenault90c75932017-10-03 00:06:41 +00001000def : GCNPat<
Tom Stellard115a6152016-11-10 16:02:37 +00001001 (i64 (zext i16:$src)),
1002 (REG_SEQUENCE SReg_64,
1003 (i32 (COPY_TO_REGCLASS (S_AND_B32 $src, (S_MOV_B32 (i32 0xffff))), SGPR_32)), sub0,
1004 (S_MOV_B32 (i32 0)), sub1)
1005>;
1006
Matt Arsenault90c75932017-10-03 00:06:41 +00001007def : GCNPat <
Tom Stellard115a6152016-11-10 16:02:37 +00001008 (i64 (sext i16:$src)),
1009 (REG_SEQUENCE SReg_64, (i32 (S_SEXT_I32_I16 $src)), sub0,
1010 (i32 (COPY_TO_REGCLASS (S_ASHR_I32 (i32 (S_SEXT_I32_I16 $src)), (S_MOV_B32 (i32 31))), SGPR_32)), sub1)
1011>;
1012
Matt Arsenault90c75932017-10-03 00:06:41 +00001013def : GCNPat<
Tom Stellard115a6152016-11-10 16:02:37 +00001014 (i32 (zext i16:$src)),
1015 (S_AND_B32 (S_MOV_B32 (i32 0xffff)), $src)
1016>;
1017
1018
1019
Valery Pykhtina34fb492016-08-30 15:20:31 +00001020//===----------------------------------------------------------------------===//
1021// SOPP Patterns
1022//===----------------------------------------------------------------------===//
1023
Matt Arsenault90c75932017-10-03 00:06:41 +00001024def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +00001025 (int_amdgcn_s_waitcnt i32:$simm16),
1026 (S_WAITCNT (as_i16imm $simm16))
1027>;
1028
Valery Pykhtina34fb492016-08-30 15:20:31 +00001029
1030//===----------------------------------------------------------------------===//
1031// Real target instructions, move this to the appropriate subtarget TD file
1032//===----------------------------------------------------------------------===//
1033
1034class Select_si<string opName> :
1035 SIMCInstr<opName, SIEncodingFamily.SI> {
1036 list<Predicate> AssemblerPredicates = [isSICI];
1037 string DecoderNamespace = "SICI";
1038}
1039
1040class SOP1_Real_si<bits<8> op, SOP1_Pseudo ps> :
1041 SOP1_Real<op, ps>,
1042 Select_si<ps.Mnemonic>;
1043
1044class SOP2_Real_si<bits<7> op, SOP2_Pseudo ps> :
1045 SOP2_Real<op, ps>,
1046 Select_si<ps.Mnemonic>;
1047
1048class SOPK_Real_si<bits<5> op, SOPK_Pseudo ps> :
1049 SOPK_Real32<op, ps>,
1050 Select_si<ps.Mnemonic>;
1051
1052def S_MOV_B32_si : SOP1_Real_si <0x03, S_MOV_B32>;
1053def S_MOV_B64_si : SOP1_Real_si <0x04, S_MOV_B64>;
1054def S_CMOV_B32_si : SOP1_Real_si <0x05, S_CMOV_B32>;
1055def S_CMOV_B64_si : SOP1_Real_si <0x06, S_CMOV_B64>;
1056def S_NOT_B32_si : SOP1_Real_si <0x07, S_NOT_B32>;
1057def S_NOT_B64_si : SOP1_Real_si <0x08, S_NOT_B64>;
1058def S_WQM_B32_si : SOP1_Real_si <0x09, S_WQM_B32>;
1059def S_WQM_B64_si : SOP1_Real_si <0x0a, S_WQM_B64>;
1060def S_BREV_B32_si : SOP1_Real_si <0x0b, S_BREV_B32>;
1061def S_BREV_B64_si : SOP1_Real_si <0x0c, S_BREV_B64>;
1062def S_BCNT0_I32_B32_si : SOP1_Real_si <0x0d, S_BCNT0_I32_B32>;
1063def S_BCNT0_I32_B64_si : SOP1_Real_si <0x0e, S_BCNT0_I32_B64>;
1064def S_BCNT1_I32_B32_si : SOP1_Real_si <0x0f, S_BCNT1_I32_B32>;
1065def S_BCNT1_I32_B64_si : SOP1_Real_si <0x10, S_BCNT1_I32_B64>;
1066def S_FF0_I32_B32_si : SOP1_Real_si <0x11, S_FF0_I32_B32>;
1067def S_FF0_I32_B64_si : SOP1_Real_si <0x12, S_FF0_I32_B64>;
1068def S_FF1_I32_B32_si : SOP1_Real_si <0x13, S_FF1_I32_B32>;
1069def S_FF1_I32_B64_si : SOP1_Real_si <0x14, S_FF1_I32_B64>;
1070def S_FLBIT_I32_B32_si : SOP1_Real_si <0x15, S_FLBIT_I32_B32>;
1071def S_FLBIT_I32_B64_si : SOP1_Real_si <0x16, S_FLBIT_I32_B64>;
1072def S_FLBIT_I32_si : SOP1_Real_si <0x17, S_FLBIT_I32>;
1073def S_FLBIT_I32_I64_si : SOP1_Real_si <0x18, S_FLBIT_I32_I64>;
1074def S_SEXT_I32_I8_si : SOP1_Real_si <0x19, S_SEXT_I32_I8>;
1075def S_SEXT_I32_I16_si : SOP1_Real_si <0x1a, S_SEXT_I32_I16>;
1076def S_BITSET0_B32_si : SOP1_Real_si <0x1b, S_BITSET0_B32>;
1077def S_BITSET0_B64_si : SOP1_Real_si <0x1c, S_BITSET0_B64>;
1078def S_BITSET1_B32_si : SOP1_Real_si <0x1d, S_BITSET1_B32>;
1079def S_BITSET1_B64_si : SOP1_Real_si <0x1e, S_BITSET1_B64>;
1080def S_GETPC_B64_si : SOP1_Real_si <0x1f, S_GETPC_B64>;
1081def S_SETPC_B64_si : SOP1_Real_si <0x20, S_SETPC_B64>;
1082def S_SWAPPC_B64_si : SOP1_Real_si <0x21, S_SWAPPC_B64>;
1083def S_RFE_B64_si : SOP1_Real_si <0x22, S_RFE_B64>;
1084def S_AND_SAVEEXEC_B64_si : SOP1_Real_si <0x24, S_AND_SAVEEXEC_B64>;
1085def S_OR_SAVEEXEC_B64_si : SOP1_Real_si <0x25, S_OR_SAVEEXEC_B64>;
1086def S_XOR_SAVEEXEC_B64_si : SOP1_Real_si <0x26, S_XOR_SAVEEXEC_B64>;
1087def S_ANDN2_SAVEEXEC_B64_si: SOP1_Real_si <0x27, S_ANDN2_SAVEEXEC_B64>;
1088def S_ORN2_SAVEEXEC_B64_si : SOP1_Real_si <0x28, S_ORN2_SAVEEXEC_B64>;
1089def S_NAND_SAVEEXEC_B64_si : SOP1_Real_si <0x29, S_NAND_SAVEEXEC_B64>;
1090def S_NOR_SAVEEXEC_B64_si : SOP1_Real_si <0x2a, S_NOR_SAVEEXEC_B64>;
1091def S_XNOR_SAVEEXEC_B64_si : SOP1_Real_si <0x2b, S_XNOR_SAVEEXEC_B64>;
1092def S_QUADMASK_B32_si : SOP1_Real_si <0x2c, S_QUADMASK_B32>;
1093def S_QUADMASK_B64_si : SOP1_Real_si <0x2d, S_QUADMASK_B64>;
1094def S_MOVRELS_B32_si : SOP1_Real_si <0x2e, S_MOVRELS_B32>;
1095def S_MOVRELS_B64_si : SOP1_Real_si <0x2f, S_MOVRELS_B64>;
1096def S_MOVRELD_B32_si : SOP1_Real_si <0x30, S_MOVRELD_B32>;
1097def S_MOVRELD_B64_si : SOP1_Real_si <0x31, S_MOVRELD_B64>;
1098def S_CBRANCH_JOIN_si : SOP1_Real_si <0x32, S_CBRANCH_JOIN>;
1099def S_MOV_REGRD_B32_si : SOP1_Real_si <0x33, S_MOV_REGRD_B32>;
1100def S_ABS_I32_si : SOP1_Real_si <0x34, S_ABS_I32>;
1101def S_MOV_FED_B32_si : SOP1_Real_si <0x35, S_MOV_FED_B32>;
1102
1103def S_ADD_U32_si : SOP2_Real_si <0x00, S_ADD_U32>;
1104def S_ADD_I32_si : SOP2_Real_si <0x02, S_ADD_I32>;
1105def S_SUB_U32_si : SOP2_Real_si <0x01, S_SUB_U32>;
1106def S_SUB_I32_si : SOP2_Real_si <0x03, S_SUB_I32>;
1107def S_ADDC_U32_si : SOP2_Real_si <0x04, S_ADDC_U32>;
1108def S_SUBB_U32_si : SOP2_Real_si <0x05, S_SUBB_U32>;
1109def S_MIN_I32_si : SOP2_Real_si <0x06, S_MIN_I32>;
1110def S_MIN_U32_si : SOP2_Real_si <0x07, S_MIN_U32>;
1111def S_MAX_I32_si : SOP2_Real_si <0x08, S_MAX_I32>;
1112def S_MAX_U32_si : SOP2_Real_si <0x09, S_MAX_U32>;
1113def S_CSELECT_B32_si : SOP2_Real_si <0x0a, S_CSELECT_B32>;
1114def S_CSELECT_B64_si : SOP2_Real_si <0x0b, S_CSELECT_B64>;
1115def S_AND_B32_si : SOP2_Real_si <0x0e, S_AND_B32>;
1116def S_AND_B64_si : SOP2_Real_si <0x0f, S_AND_B64>;
1117def S_OR_B32_si : SOP2_Real_si <0x10, S_OR_B32>;
1118def S_OR_B64_si : SOP2_Real_si <0x11, S_OR_B64>;
1119def S_XOR_B32_si : SOP2_Real_si <0x12, S_XOR_B32>;
1120def S_XOR_B64_si : SOP2_Real_si <0x13, S_XOR_B64>;
1121def S_ANDN2_B32_si : SOP2_Real_si <0x14, S_ANDN2_B32>;
1122def S_ANDN2_B64_si : SOP2_Real_si <0x15, S_ANDN2_B64>;
1123def S_ORN2_B32_si : SOP2_Real_si <0x16, S_ORN2_B32>;
1124def S_ORN2_B64_si : SOP2_Real_si <0x17, S_ORN2_B64>;
1125def S_NAND_B32_si : SOP2_Real_si <0x18, S_NAND_B32>;
1126def S_NAND_B64_si : SOP2_Real_si <0x19, S_NAND_B64>;
1127def S_NOR_B32_si : SOP2_Real_si <0x1a, S_NOR_B32>;
1128def S_NOR_B64_si : SOP2_Real_si <0x1b, S_NOR_B64>;
1129def S_XNOR_B32_si : SOP2_Real_si <0x1c, S_XNOR_B32>;
1130def S_XNOR_B64_si : SOP2_Real_si <0x1d, S_XNOR_B64>;
1131def S_LSHL_B32_si : SOP2_Real_si <0x1e, S_LSHL_B32>;
1132def S_LSHL_B64_si : SOP2_Real_si <0x1f, S_LSHL_B64>;
1133def S_LSHR_B32_si : SOP2_Real_si <0x20, S_LSHR_B32>;
1134def S_LSHR_B64_si : SOP2_Real_si <0x21, S_LSHR_B64>;
1135def S_ASHR_I32_si : SOP2_Real_si <0x22, S_ASHR_I32>;
1136def S_ASHR_I64_si : SOP2_Real_si <0x23, S_ASHR_I64>;
1137def S_BFM_B32_si : SOP2_Real_si <0x24, S_BFM_B32>;
1138def S_BFM_B64_si : SOP2_Real_si <0x25, S_BFM_B64>;
1139def S_MUL_I32_si : SOP2_Real_si <0x26, S_MUL_I32>;
1140def S_BFE_U32_si : SOP2_Real_si <0x27, S_BFE_U32>;
1141def S_BFE_I32_si : SOP2_Real_si <0x28, S_BFE_I32>;
1142def S_BFE_U64_si : SOP2_Real_si <0x29, S_BFE_U64>;
1143def S_BFE_I64_si : SOP2_Real_si <0x2a, S_BFE_I64>;
1144def S_CBRANCH_G_FORK_si : SOP2_Real_si <0x2b, S_CBRANCH_G_FORK>;
1145def S_ABSDIFF_I32_si : SOP2_Real_si <0x2c, S_ABSDIFF_I32>;
1146
1147def S_MOVK_I32_si : SOPK_Real_si <0x00, S_MOVK_I32>;
1148def S_CMOVK_I32_si : SOPK_Real_si <0x02, S_CMOVK_I32>;
1149def S_CMPK_EQ_I32_si : SOPK_Real_si <0x03, S_CMPK_EQ_I32>;
1150def S_CMPK_LG_I32_si : SOPK_Real_si <0x04, S_CMPK_LG_I32>;
1151def S_CMPK_GT_I32_si : SOPK_Real_si <0x05, S_CMPK_GT_I32>;
1152def S_CMPK_GE_I32_si : SOPK_Real_si <0x06, S_CMPK_GE_I32>;
1153def S_CMPK_LT_I32_si : SOPK_Real_si <0x07, S_CMPK_LT_I32>;
1154def S_CMPK_LE_I32_si : SOPK_Real_si <0x08, S_CMPK_LE_I32>;
1155def S_CMPK_EQ_U32_si : SOPK_Real_si <0x09, S_CMPK_EQ_U32>;
1156def S_CMPK_LG_U32_si : SOPK_Real_si <0x0a, S_CMPK_LG_U32>;
1157def S_CMPK_GT_U32_si : SOPK_Real_si <0x0b, S_CMPK_GT_U32>;
1158def S_CMPK_GE_U32_si : SOPK_Real_si <0x0c, S_CMPK_GE_U32>;
1159def S_CMPK_LT_U32_si : SOPK_Real_si <0x0d, S_CMPK_LT_U32>;
1160def S_CMPK_LE_U32_si : SOPK_Real_si <0x0e, S_CMPK_LE_U32>;
1161def S_ADDK_I32_si : SOPK_Real_si <0x0f, S_ADDK_I32>;
1162def S_MULK_I32_si : SOPK_Real_si <0x10, S_MULK_I32>;
1163def S_CBRANCH_I_FORK_si : SOPK_Real_si <0x11, S_CBRANCH_I_FORK>;
1164def S_GETREG_B32_si : SOPK_Real_si <0x12, S_GETREG_B32>;
1165def S_SETREG_B32_si : SOPK_Real_si <0x13, S_SETREG_B32>;
1166//def S_GETREG_REGRD_B32_si : SOPK_Real_si <0x14, S_GETREG_REGRD_B32>; // see pseudo for comments
1167def S_SETREG_IMM32_B32_si : SOPK_Real64<0x15, S_SETREG_IMM32_B32>,
1168 Select_si<S_SETREG_IMM32_B32.Mnemonic>;
1169
1170
1171class Select_vi<string opName> :
1172 SIMCInstr<opName, SIEncodingFamily.VI> {
1173 list<Predicate> AssemblerPredicates = [isVI];
1174 string DecoderNamespace = "VI";
1175}
1176
1177class SOP1_Real_vi<bits<8> op, SOP1_Pseudo ps> :
1178 SOP1_Real<op, ps>,
1179 Select_vi<ps.Mnemonic>;
1180
1181
1182class SOP2_Real_vi<bits<7> op, SOP2_Pseudo ps> :
1183 SOP2_Real<op, ps>,
1184 Select_vi<ps.Mnemonic>;
1185
1186class SOPK_Real_vi<bits<5> op, SOPK_Pseudo ps> :
1187 SOPK_Real32<op, ps>,
1188 Select_vi<ps.Mnemonic>;
1189
1190def S_MOV_B32_vi : SOP1_Real_vi <0x00, S_MOV_B32>;
1191def S_MOV_B64_vi : SOP1_Real_vi <0x01, S_MOV_B64>;
1192def S_CMOV_B32_vi : SOP1_Real_vi <0x02, S_CMOV_B32>;
1193def S_CMOV_B64_vi : SOP1_Real_vi <0x03, S_CMOV_B64>;
1194def S_NOT_B32_vi : SOP1_Real_vi <0x04, S_NOT_B32>;
1195def S_NOT_B64_vi : SOP1_Real_vi <0x05, S_NOT_B64>;
1196def S_WQM_B32_vi : SOP1_Real_vi <0x06, S_WQM_B32>;
1197def S_WQM_B64_vi : SOP1_Real_vi <0x07, S_WQM_B64>;
1198def S_BREV_B32_vi : SOP1_Real_vi <0x08, S_BREV_B32>;
1199def S_BREV_B64_vi : SOP1_Real_vi <0x09, S_BREV_B64>;
1200def S_BCNT0_I32_B32_vi : SOP1_Real_vi <0x0a, S_BCNT0_I32_B32>;
1201def S_BCNT0_I32_B64_vi : SOP1_Real_vi <0x0b, S_BCNT0_I32_B64>;
1202def S_BCNT1_I32_B32_vi : SOP1_Real_vi <0x0c, S_BCNT1_I32_B32>;
1203def S_BCNT1_I32_B64_vi : SOP1_Real_vi <0x0d, S_BCNT1_I32_B64>;
1204def S_FF0_I32_B32_vi : SOP1_Real_vi <0x0e, S_FF0_I32_B32>;
1205def S_FF0_I32_B64_vi : SOP1_Real_vi <0x0f, S_FF0_I32_B64>;
1206def S_FF1_I32_B32_vi : SOP1_Real_vi <0x10, S_FF1_I32_B32>;
1207def S_FF1_I32_B64_vi : SOP1_Real_vi <0x11, S_FF1_I32_B64>;
1208def S_FLBIT_I32_B32_vi : SOP1_Real_vi <0x12, S_FLBIT_I32_B32>;
1209def S_FLBIT_I32_B64_vi : SOP1_Real_vi <0x13, S_FLBIT_I32_B64>;
1210def S_FLBIT_I32_vi : SOP1_Real_vi <0x14, S_FLBIT_I32>;
1211def S_FLBIT_I32_I64_vi : SOP1_Real_vi <0x15, S_FLBIT_I32_I64>;
1212def S_SEXT_I32_I8_vi : SOP1_Real_vi <0x16, S_SEXT_I32_I8>;
1213def S_SEXT_I32_I16_vi : SOP1_Real_vi <0x17, S_SEXT_I32_I16>;
1214def S_BITSET0_B32_vi : SOP1_Real_vi <0x18, S_BITSET0_B32>;
1215def S_BITSET0_B64_vi : SOP1_Real_vi <0x19, S_BITSET0_B64>;
1216def S_BITSET1_B32_vi : SOP1_Real_vi <0x1a, S_BITSET1_B32>;
1217def S_BITSET1_B64_vi : SOP1_Real_vi <0x1b, S_BITSET1_B64>;
1218def S_GETPC_B64_vi : SOP1_Real_vi <0x1c, S_GETPC_B64>;
1219def S_SETPC_B64_vi : SOP1_Real_vi <0x1d, S_SETPC_B64>;
1220def S_SWAPPC_B64_vi : SOP1_Real_vi <0x1e, S_SWAPPC_B64>;
1221def S_RFE_B64_vi : SOP1_Real_vi <0x1f, S_RFE_B64>;
1222def S_AND_SAVEEXEC_B64_vi : SOP1_Real_vi <0x20, S_AND_SAVEEXEC_B64>;
1223def S_OR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x21, S_OR_SAVEEXEC_B64>;
1224def S_XOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x22, S_XOR_SAVEEXEC_B64>;
1225def S_ANDN2_SAVEEXEC_B64_vi: SOP1_Real_vi <0x23, S_ANDN2_SAVEEXEC_B64>;
1226def S_ORN2_SAVEEXEC_B64_vi : SOP1_Real_vi <0x24, S_ORN2_SAVEEXEC_B64>;
1227def S_NAND_SAVEEXEC_B64_vi : SOP1_Real_vi <0x25, S_NAND_SAVEEXEC_B64>;
1228def S_NOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x26, S_NOR_SAVEEXEC_B64>;
1229def S_XNOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x27, S_XNOR_SAVEEXEC_B64>;
1230def S_QUADMASK_B32_vi : SOP1_Real_vi <0x28, S_QUADMASK_B32>;
1231def S_QUADMASK_B64_vi : SOP1_Real_vi <0x29, S_QUADMASK_B64>;
1232def S_MOVRELS_B32_vi : SOP1_Real_vi <0x2a, S_MOVRELS_B32>;
1233def S_MOVRELS_B64_vi : SOP1_Real_vi <0x2b, S_MOVRELS_B64>;
1234def S_MOVRELD_B32_vi : SOP1_Real_vi <0x2c, S_MOVRELD_B32>;
1235def S_MOVRELD_B64_vi : SOP1_Real_vi <0x2d, S_MOVRELD_B64>;
1236def S_CBRANCH_JOIN_vi : SOP1_Real_vi <0x2e, S_CBRANCH_JOIN>;
1237def S_MOV_REGRD_B32_vi : SOP1_Real_vi <0x2f, S_MOV_REGRD_B32>;
1238def S_ABS_I32_vi : SOP1_Real_vi <0x30, S_ABS_I32>;
1239def S_MOV_FED_B32_vi : SOP1_Real_vi <0x31, S_MOV_FED_B32>;
Matt Arsenaultcc88ce32016-10-12 18:00:51 +00001240def S_SET_GPR_IDX_IDX_vi : SOP1_Real_vi <0x32, S_SET_GPR_IDX_IDX>;
Valery Pykhtina34fb492016-08-30 15:20:31 +00001241
1242def S_ADD_U32_vi : SOP2_Real_vi <0x00, S_ADD_U32>;
1243def S_ADD_I32_vi : SOP2_Real_vi <0x02, S_ADD_I32>;
1244def S_SUB_U32_vi : SOP2_Real_vi <0x01, S_SUB_U32>;
1245def S_SUB_I32_vi : SOP2_Real_vi <0x03, S_SUB_I32>;
1246def S_ADDC_U32_vi : SOP2_Real_vi <0x04, S_ADDC_U32>;
1247def S_SUBB_U32_vi : SOP2_Real_vi <0x05, S_SUBB_U32>;
1248def S_MIN_I32_vi : SOP2_Real_vi <0x06, S_MIN_I32>;
1249def S_MIN_U32_vi : SOP2_Real_vi <0x07, S_MIN_U32>;
1250def S_MAX_I32_vi : SOP2_Real_vi <0x08, S_MAX_I32>;
1251def S_MAX_U32_vi : SOP2_Real_vi <0x09, S_MAX_U32>;
1252def S_CSELECT_B32_vi : SOP2_Real_vi <0x0a, S_CSELECT_B32>;
1253def S_CSELECT_B64_vi : SOP2_Real_vi <0x0b, S_CSELECT_B64>;
1254def S_AND_B32_vi : SOP2_Real_vi <0x0c, S_AND_B32>;
1255def S_AND_B64_vi : SOP2_Real_vi <0x0d, S_AND_B64>;
1256def S_OR_B32_vi : SOP2_Real_vi <0x0e, S_OR_B32>;
1257def S_OR_B64_vi : SOP2_Real_vi <0x0f, S_OR_B64>;
1258def S_XOR_B32_vi : SOP2_Real_vi <0x10, S_XOR_B32>;
1259def S_XOR_B64_vi : SOP2_Real_vi <0x11, S_XOR_B64>;
1260def S_ANDN2_B32_vi : SOP2_Real_vi <0x12, S_ANDN2_B32>;
1261def S_ANDN2_B64_vi : SOP2_Real_vi <0x13, S_ANDN2_B64>;
1262def S_ORN2_B32_vi : SOP2_Real_vi <0x14, S_ORN2_B32>;
1263def S_ORN2_B64_vi : SOP2_Real_vi <0x15, S_ORN2_B64>;
1264def S_NAND_B32_vi : SOP2_Real_vi <0x16, S_NAND_B32>;
1265def S_NAND_B64_vi : SOP2_Real_vi <0x17, S_NAND_B64>;
1266def S_NOR_B32_vi : SOP2_Real_vi <0x18, S_NOR_B32>;
1267def S_NOR_B64_vi : SOP2_Real_vi <0x19, S_NOR_B64>;
1268def S_XNOR_B32_vi : SOP2_Real_vi <0x1a, S_XNOR_B32>;
1269def S_XNOR_B64_vi : SOP2_Real_vi <0x1b, S_XNOR_B64>;
1270def S_LSHL_B32_vi : SOP2_Real_vi <0x1c, S_LSHL_B32>;
1271def S_LSHL_B64_vi : SOP2_Real_vi <0x1d, S_LSHL_B64>;
1272def S_LSHR_B32_vi : SOP2_Real_vi <0x1e, S_LSHR_B32>;
1273def S_LSHR_B64_vi : SOP2_Real_vi <0x1f, S_LSHR_B64>;
1274def S_ASHR_I32_vi : SOP2_Real_vi <0x20, S_ASHR_I32>;
1275def S_ASHR_I64_vi : SOP2_Real_vi <0x21, S_ASHR_I64>;
1276def S_BFM_B32_vi : SOP2_Real_vi <0x22, S_BFM_B32>;
1277def S_BFM_B64_vi : SOP2_Real_vi <0x23, S_BFM_B64>;
1278def S_MUL_I32_vi : SOP2_Real_vi <0x24, S_MUL_I32>;
1279def S_BFE_U32_vi : SOP2_Real_vi <0x25, S_BFE_U32>;
1280def S_BFE_I32_vi : SOP2_Real_vi <0x26, S_BFE_I32>;
1281def S_BFE_U64_vi : SOP2_Real_vi <0x27, S_BFE_U64>;
1282def S_BFE_I64_vi : SOP2_Real_vi <0x28, S_BFE_I64>;
1283def S_CBRANCH_G_FORK_vi : SOP2_Real_vi <0x29, S_CBRANCH_G_FORK>;
1284def S_ABSDIFF_I32_vi : SOP2_Real_vi <0x2a, S_ABSDIFF_I32>;
Matt Arsenault9be7b0d2017-02-27 18:49:11 +00001285def S_PACK_LL_B32_B16_vi : SOP2_Real_vi <0x32, S_PACK_LL_B32_B16>;
1286def S_PACK_LH_B32_B16_vi : SOP2_Real_vi <0x33, S_PACK_LH_B32_B16>;
1287def S_PACK_HH_B32_B16_vi : SOP2_Real_vi <0x34, S_PACK_HH_B32_B16>;
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +00001288def S_RFE_RESTORE_B64_vi : SOP2_Real_vi <0x2b, S_RFE_RESTORE_B64>;
Valery Pykhtina34fb492016-08-30 15:20:31 +00001289
1290def S_MOVK_I32_vi : SOPK_Real_vi <0x00, S_MOVK_I32>;
1291def S_CMOVK_I32_vi : SOPK_Real_vi <0x01, S_CMOVK_I32>;
1292def S_CMPK_EQ_I32_vi : SOPK_Real_vi <0x02, S_CMPK_EQ_I32>;
1293def S_CMPK_LG_I32_vi : SOPK_Real_vi <0x03, S_CMPK_LG_I32>;
1294def S_CMPK_GT_I32_vi : SOPK_Real_vi <0x04, S_CMPK_GT_I32>;
1295def S_CMPK_GE_I32_vi : SOPK_Real_vi <0x05, S_CMPK_GE_I32>;
1296def S_CMPK_LT_I32_vi : SOPK_Real_vi <0x06, S_CMPK_LT_I32>;
1297def S_CMPK_LE_I32_vi : SOPK_Real_vi <0x07, S_CMPK_LE_I32>;
1298def S_CMPK_EQ_U32_vi : SOPK_Real_vi <0x08, S_CMPK_EQ_U32>;
1299def S_CMPK_LG_U32_vi : SOPK_Real_vi <0x09, S_CMPK_LG_U32>;
1300def S_CMPK_GT_U32_vi : SOPK_Real_vi <0x0A, S_CMPK_GT_U32>;
1301def S_CMPK_GE_U32_vi : SOPK_Real_vi <0x0B, S_CMPK_GE_U32>;
1302def S_CMPK_LT_U32_vi : SOPK_Real_vi <0x0C, S_CMPK_LT_U32>;
1303def S_CMPK_LE_U32_vi : SOPK_Real_vi <0x0D, S_CMPK_LE_U32>;
1304def S_ADDK_I32_vi : SOPK_Real_vi <0x0E, S_ADDK_I32>;
1305def S_MULK_I32_vi : SOPK_Real_vi <0x0F, S_MULK_I32>;
1306def S_CBRANCH_I_FORK_vi : SOPK_Real_vi <0x10, S_CBRANCH_I_FORK>;
1307def S_GETREG_B32_vi : SOPK_Real_vi <0x11, S_GETREG_B32>;
1308def S_SETREG_B32_vi : SOPK_Real_vi <0x12, S_SETREG_B32>;
1309//def S_GETREG_REGRD_B32_vi : SOPK_Real_vi <0x13, S_GETREG_REGRD_B32>; // see pseudo for comments
1310def S_SETREG_IMM32_B32_vi : SOPK_Real64<0x14, S_SETREG_IMM32_B32>,
Tom Stellard2add8a12016-09-06 20:00:26 +00001311 Select_vi<S_SETREG_IMM32_B32.Mnemonic>;