blob: ec29a66c8bbbe6bfaf9dd12ce625875be911272d [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>;
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000394} // End isCommutable = 1
395
Valery Pykhtina34fb492016-08-30 15:20:31 +0000396def S_ANDN2_B32 : SOP2_32 <"s_andn2_b32">;
397def S_ANDN2_B64 : SOP2_64 <"s_andn2_b64">;
398def S_ORN2_B32 : SOP2_32 <"s_orn2_b32">;
399def S_ORN2_B64 : SOP2_64 <"s_orn2_b64">;
400def S_NAND_B32 : SOP2_32 <"s_nand_b32">;
401def S_NAND_B64 : SOP2_64 <"s_nand_b64">;
402def S_NOR_B32 : SOP2_32 <"s_nor_b32">;
403def S_NOR_B64 : SOP2_64 <"s_nor_b64">;
404def S_XNOR_B32 : SOP2_32 <"s_xnor_b32">;
405def S_XNOR_B64 : SOP2_64 <"s_xnor_b64">;
406} // End Defs = [SCC]
407
408// Use added complexity so these patterns are preferred to the VALU patterns.
409let AddedComplexity = 1 in {
410
411let Defs = [SCC] in {
412def S_LSHL_B32 : SOP2_32 <"s_lshl_b32",
413 [(set i32:$sdst, (shl i32:$src0, i32:$src1))]
414>;
415def S_LSHL_B64 : SOP2_64_32 <"s_lshl_b64",
416 [(set i64:$sdst, (shl i64:$src0, i32:$src1))]
417>;
418def S_LSHR_B32 : SOP2_32 <"s_lshr_b32",
419 [(set i32:$sdst, (srl i32:$src0, i32:$src1))]
420>;
421def S_LSHR_B64 : SOP2_64_32 <"s_lshr_b64",
422 [(set i64:$sdst, (srl i64:$src0, i32:$src1))]
423>;
424def S_ASHR_I32 : SOP2_32 <"s_ashr_i32",
425 [(set i32:$sdst, (sra i32:$src0, i32:$src1))]
426>;
427def S_ASHR_I64 : SOP2_64_32 <"s_ashr_i64",
428 [(set i64:$sdst, (sra i64:$src0, i32:$src1))]
429>;
430} // End Defs = [SCC]
431
432def S_BFM_B32 : SOP2_32 <"s_bfm_b32",
433 [(set i32:$sdst, (AMDGPUbfm i32:$src0, i32:$src1))]>;
434def S_BFM_B64 : SOP2_64_32_32 <"s_bfm_b64">;
435def S_MUL_I32 : SOP2_32 <"s_mul_i32",
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000436 [(set i32:$sdst, (mul i32:$src0, i32:$src1))]> {
437 let isCommutable = 1;
438}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000439
440} // End AddedComplexity = 1
441
442let Defs = [SCC] in {
443def S_BFE_U32 : SOP2_32 <"s_bfe_u32">;
444def S_BFE_I32 : SOP2_32 <"s_bfe_i32">;
445def S_BFE_U64 : SOP2_64_32 <"s_bfe_u64">;
446def S_BFE_I64 : SOP2_64_32 <"s_bfe_i64">;
447} // End Defs = [SCC]
448
449def S_CBRANCH_G_FORK : SOP2_Pseudo <
450 "s_cbranch_g_fork", (outs),
Dmitry Preobrazhensky57148602017-04-14 11:52:26 +0000451 (ins SCSrc_b64:$src0, SCSrc_b64:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000452 "$src0, $src1"
453> {
454 let has_sdst = 0;
455}
456
457let Defs = [SCC] in {
458def S_ABSDIFF_I32 : SOP2_32 <"s_absdiff_i32">;
459} // End Defs = [SCC]
460
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000461let SubtargetPredicate = isVI in {
462 def S_RFE_RESTORE_B64 : SOP2_Pseudo <
463 "s_rfe_restore_b64", (outs),
464 (ins SSrc_b64:$src0, SSrc_b32:$src1),
465 "$src0, $src1"
466 > {
467 let hasSideEffects = 1;
468 let has_sdst = 0;
469 }
470}
471
Matt Arsenault9be7b0d2017-02-27 18:49:11 +0000472let SubtargetPredicate = isGFX9 in {
473 def S_PACK_LL_B32_B16 : SOP2_32<"s_pack_ll_b32_b16">;
474 def S_PACK_LH_B32_B16 : SOP2_32<"s_pack_lh_b32_b16">;
475 def S_PACK_HH_B32_B16 : SOP2_32<"s_pack_hh_b32_b16">;
476}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000477
478//===----------------------------------------------------------------------===//
479// SOPK Instructions
480//===----------------------------------------------------------------------===//
481
482class SOPK_Pseudo <string opName, dag outs, dag ins,
483 string asmOps, list<dag> pattern=[]> :
484 InstSI <outs, ins, "", pattern>,
485 SIMCInstr<opName, SIEncodingFamily.NONE> {
486 let isPseudo = 1;
487 let isCodeGenOnly = 1;
488 let SubtargetPredicate = isGCN;
489 let mayLoad = 0;
490 let mayStore = 0;
491 let hasSideEffects = 0;
492 let SALU = 1;
493 let SOPK = 1;
494 let SchedRW = [WriteSALU];
495 let UseNamedOperandTable = 1;
496 string Mnemonic = opName;
497 string AsmOperands = asmOps;
498
499 bits<1> has_sdst = 1;
500}
501
502class SOPK_Real<bits<5> op, SOPK_Pseudo ps> :
503 InstSI <ps.OutOperandList, ps.InOperandList,
504 ps.Mnemonic # " " # ps.AsmOperands, []> {
505 let isPseudo = 0;
506 let isCodeGenOnly = 0;
507
508 // copy relevant pseudo op flags
509 let SubtargetPredicate = ps.SubtargetPredicate;
510 let AsmMatchConverter = ps.AsmMatchConverter;
511 let DisableEncoding = ps.DisableEncoding;
512 let Constraints = ps.Constraints;
513
514 // encoding
515 bits<7> sdst;
516 bits<16> simm16;
517 bits<32> imm;
518}
519
520class SOPK_Real32<bits<5> op, SOPK_Pseudo ps> :
521 SOPK_Real <op, ps>,
522 Enc32 {
523 let Inst{15-0} = simm16;
524 let Inst{22-16} = !if(ps.has_sdst, sdst, ?);
525 let Inst{27-23} = op;
526 let Inst{31-28} = 0xb; //encoding
527}
528
529class SOPK_Real64<bits<5> op, SOPK_Pseudo ps> :
530 SOPK_Real<op, ps>,
531 Enc64 {
532 let Inst{15-0} = simm16;
533 let Inst{22-16} = !if(ps.has_sdst, sdst, ?);
534 let Inst{27-23} = op;
535 let Inst{31-28} = 0xb; //encoding
536 let Inst{63-32} = imm;
537}
538
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000539class SOPKInstTable <bit is_sopk, string cmpOp = ""> {
540 bit IsSOPK = is_sopk;
541 string BaseCmpOp = cmpOp;
542}
543
Valery Pykhtina34fb492016-08-30 15:20:31 +0000544class SOPK_32 <string opName, list<dag> pattern=[]> : SOPK_Pseudo <
545 opName,
546 (outs SReg_32:$sdst),
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000547 (ins s16imm:$simm16),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000548 "$sdst, $simm16",
549 pattern>;
550
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000551class SOPK_SCC <string opName, string base_op, bit isSignExt> : SOPK_Pseudo <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000552 opName,
553 (outs),
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000554 !if(isSignExt,
555 (ins SReg_32:$sdst, s16imm:$simm16),
556 (ins SReg_32:$sdst, u16imm:$simm16)),
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000557 "$sdst, $simm16", []>,
558 SOPKInstTable<1, base_op>{
Valery Pykhtina34fb492016-08-30 15:20:31 +0000559 let Defs = [SCC];
560}
561
562class SOPK_32TIE <string opName, list<dag> pattern=[]> : SOPK_Pseudo <
563 opName,
564 (outs SReg_32:$sdst),
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000565 (ins SReg_32:$src0, s16imm:$simm16),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000566 "$sdst, $simm16",
567 pattern
568>;
569
570let isReMaterializable = 1, isMoveImm = 1 in {
571def S_MOVK_I32 : SOPK_32 <"s_movk_i32">;
572} // End isReMaterializable = 1
573let Uses = [SCC] in {
574def S_CMOVK_I32 : SOPK_32 <"s_cmovk_i32">;
575}
576
577let isCompare = 1 in {
578
579// This instruction is disabled for now until we can figure out how to teach
580// the instruction selector to correctly use the S_CMP* vs V_CMP*
581// instructions.
582//
583// When this instruction is enabled the code generator sometimes produces this
584// invalid sequence:
585//
586// SCC = S_CMPK_EQ_I32 SGPR0, imm
587// VCC = COPY SCC
588// VGPR0 = V_CNDMASK VCC, VGPR0, VGPR1
589//
590// def S_CMPK_EQ_I32 : SOPK_SCC <"s_cmpk_eq_i32",
591// [(set i1:$dst, (setcc i32:$src0, imm:$src1, SETEQ))]
592// >;
593
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000594def S_CMPK_EQ_I32 : SOPK_SCC <"s_cmpk_eq_i32", "s_cmp_eq_i32", 1>;
595def S_CMPK_LG_I32 : SOPK_SCC <"s_cmpk_lg_i32", "s_cmp_lg_i32", 1>;
596def S_CMPK_GT_I32 : SOPK_SCC <"s_cmpk_gt_i32", "s_cmp_gt_i32", 1>;
597def S_CMPK_GE_I32 : SOPK_SCC <"s_cmpk_ge_i32", "s_cmp_ge_i32", 1>;
598def S_CMPK_LT_I32 : SOPK_SCC <"s_cmpk_lt_i32", "s_cmp_lt_i32", 1>;
599def S_CMPK_LE_I32 : SOPK_SCC <"s_cmpk_le_i32", "s_cmp_le_i32", 1>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000600
601let SOPKZext = 1 in {
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000602def S_CMPK_EQ_U32 : SOPK_SCC <"s_cmpk_eq_u32", "s_cmp_eq_u32", 0>;
603def S_CMPK_LG_U32 : SOPK_SCC <"s_cmpk_lg_u32", "s_cmp_lg_u32", 0>;
604def S_CMPK_GT_U32 : SOPK_SCC <"s_cmpk_gt_u32", "s_cmp_gt_u32", 0>;
605def S_CMPK_GE_U32 : SOPK_SCC <"s_cmpk_ge_u32", "s_cmp_ge_u32", 0>;
606def S_CMPK_LT_U32 : SOPK_SCC <"s_cmpk_lt_u32", "s_cmp_lt_u32", 0>;
607def S_CMPK_LE_U32 : SOPK_SCC <"s_cmpk_le_u32", "s_cmp_le_u32", 0>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000608} // End SOPKZext = 1
Valery Pykhtina34fb492016-08-30 15:20:31 +0000609} // End isCompare = 1
610
611let Defs = [SCC], isCommutable = 1, DisableEncoding = "$src0",
612 Constraints = "$sdst = $src0" in {
613 def S_ADDK_I32 : SOPK_32TIE <"s_addk_i32">;
614 def S_MULK_I32 : SOPK_32TIE <"s_mulk_i32">;
615}
616
617def S_CBRANCH_I_FORK : SOPK_Pseudo <
618 "s_cbranch_i_fork",
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000619 (outs), (ins SReg_64:$sdst, s16imm:$simm16),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000620 "$sdst, $simm16"
621>;
622
623let mayLoad = 1 in {
624def S_GETREG_B32 : SOPK_Pseudo <
625 "s_getreg_b32",
626 (outs SReg_32:$sdst), (ins hwreg:$simm16),
627 "$sdst, $simm16"
628>;
629}
630
Tom Stellard8485fa02016-12-07 02:42:15 +0000631let hasSideEffects = 1 in {
632
Valery Pykhtina34fb492016-08-30 15:20:31 +0000633def S_SETREG_B32 : SOPK_Pseudo <
634 "s_setreg_b32",
635 (outs), (ins SReg_32:$sdst, hwreg:$simm16),
Tom Stellard8485fa02016-12-07 02:42:15 +0000636 "$simm16, $sdst",
637 [(AMDGPUsetreg i32:$sdst, (i16 timm:$simm16))]
Valery Pykhtina34fb492016-08-30 15:20:31 +0000638>;
639
640// FIXME: Not on SI?
641//def S_GETREG_REGRD_B32 : SOPK_32 <sopk<0x14, 0x13>, "s_getreg_regrd_b32">;
642
643def S_SETREG_IMM32_B32 : SOPK_Pseudo <
644 "s_setreg_imm32_b32",
645 (outs), (ins i32imm:$imm, hwreg:$simm16),
Matt Arsenault10c17ca2016-10-06 10:13:23 +0000646 "$simm16, $imm"> {
647 let Size = 8; // Unlike every other SOPK instruction.
Valery Pykhtina34fb492016-08-30 15:20:31 +0000648 let has_sdst = 0;
649}
650
Tom Stellard8485fa02016-12-07 02:42:15 +0000651} // End hasSideEffects = 1
Valery Pykhtina34fb492016-08-30 15:20:31 +0000652
653//===----------------------------------------------------------------------===//
654// SOPC Instructions
655//===----------------------------------------------------------------------===//
656
657class SOPCe <bits<7> op> : Enc32 {
658 bits<8> src0;
659 bits<8> src1;
660
661 let Inst{7-0} = src0;
662 let Inst{15-8} = src1;
663 let Inst{22-16} = op;
664 let Inst{31-23} = 0x17e;
665}
666
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000667class SOPC <bits<7> op, dag outs, dag ins, string asm,
668 list<dag> pattern = []> :
Valery Pykhtina34fb492016-08-30 15:20:31 +0000669 InstSI<outs, ins, asm, pattern>, SOPCe <op> {
670 let mayLoad = 0;
671 let mayStore = 0;
672 let hasSideEffects = 0;
673 let SALU = 1;
674 let SOPC = 1;
675 let isCodeGenOnly = 0;
676 let Defs = [SCC];
677 let SchedRW = [WriteSALU];
678 let UseNamedOperandTable = 1;
679 let SubtargetPredicate = isGCN;
680}
681
682class SOPC_Base <bits<7> op, RegisterOperand rc0, RegisterOperand rc1,
683 string opName, list<dag> pattern = []> : SOPC <
684 op, (outs), (ins rc0:$src0, rc1:$src1),
685 opName#" $src0, $src1", pattern > {
686 let Defs = [SCC];
687}
688class SOPC_Helper <bits<7> op, RegisterOperand rc, ValueType vt,
689 string opName, PatLeaf cond> : SOPC_Base <
690 op, rc, rc, opName,
691 [(set SCC, (si_setcc_uniform vt:$src0, vt:$src1, cond))] > {
692}
693
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000694class SOPC_CMP_32<bits<7> op, string opName,
695 PatLeaf cond = COND_NULL, string revOp = opName>
696 : SOPC_Helper<op, SSrc_b32, i32, opName, cond>,
697 Commutable_REV<revOp, !eq(revOp, opName)>,
698 SOPKInstTable<0, opName> {
699 let isCompare = 1;
700 let isCommutable = 1;
701}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000702
Matt Arsenault7b1dc2c2016-09-17 02:02:19 +0000703class SOPC_CMP_64<bits<7> op, string opName,
704 PatLeaf cond = COND_NULL, string revOp = opName>
705 : SOPC_Helper<op, SSrc_b64, i64, opName, cond>,
706 Commutable_REV<revOp, !eq(revOp, opName)> {
707 let isCompare = 1;
708 let isCommutable = 1;
709}
710
Valery Pykhtina34fb492016-08-30 15:20:31 +0000711class SOPC_32<bits<7> op, string opName, list<dag> pattern = []>
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000712 : SOPC_Base<op, SSrc_b32, SSrc_b32, opName, pattern>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000713
714class SOPC_64_32<bits<7> op, string opName, list<dag> pattern = []>
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000715 : SOPC_Base<op, SSrc_b64, SSrc_b32, opName, pattern>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000716
Matt Arsenault5d8eb252016-09-30 01:50:20 +0000717def S_CMP_EQ_I32 : SOPC_CMP_32 <0x00, "s_cmp_eq_i32">;
718def S_CMP_LG_I32 : SOPC_CMP_32 <0x01, "s_cmp_lg_i32">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000719def S_CMP_GT_I32 : SOPC_CMP_32 <0x02, "s_cmp_gt_i32", COND_SGT>;
720def S_CMP_GE_I32 : SOPC_CMP_32 <0x03, "s_cmp_ge_i32", COND_SGE>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000721def S_CMP_LT_I32 : SOPC_CMP_32 <0x04, "s_cmp_lt_i32", COND_SLT, "s_cmp_gt_i32">;
722def 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 +0000723def S_CMP_EQ_U32 : SOPC_CMP_32 <0x06, "s_cmp_eq_u32", COND_EQ>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000724def S_CMP_LG_U32 : SOPC_CMP_32 <0x07, "s_cmp_lg_u32", COND_NE>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000725def S_CMP_GT_U32 : SOPC_CMP_32 <0x08, "s_cmp_gt_u32", COND_UGT>;
726def S_CMP_GE_U32 : SOPC_CMP_32 <0x09, "s_cmp_ge_u32", COND_UGE>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000727def S_CMP_LT_U32 : SOPC_CMP_32 <0x0a, "s_cmp_lt_u32", COND_ULT, "s_cmp_gt_u32">;
728def S_CMP_LE_U32 : SOPC_CMP_32 <0x0b, "s_cmp_le_u32", COND_ULE, "s_cmp_ge_u32">;
729
Valery Pykhtina34fb492016-08-30 15:20:31 +0000730def S_BITCMP0_B32 : SOPC_32 <0x0c, "s_bitcmp0_b32">;
731def S_BITCMP1_B32 : SOPC_32 <0x0d, "s_bitcmp1_b32">;
732def S_BITCMP0_B64 : SOPC_64_32 <0x0e, "s_bitcmp0_b64">;
733def S_BITCMP1_B64 : SOPC_64_32 <0x0f, "s_bitcmp1_b64">;
734def S_SETVSKIP : SOPC_32 <0x10, "s_setvskip">;
735
Matt Arsenault7b1dc2c2016-09-17 02:02:19 +0000736let SubtargetPredicate = isVI in {
737def S_CMP_EQ_U64 : SOPC_CMP_64 <0x12, "s_cmp_eq_u64", COND_EQ>;
738def S_CMP_LG_U64 : SOPC_CMP_64 <0x13, "s_cmp_lg_u64", COND_NE>;
739}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000740
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000741let SubtargetPredicate = HasVGPRIndexMode in {
742def S_SET_GPR_IDX_ON : SOPC <0x11,
743 (outs),
744 (ins SSrc_b32:$src0, GPRIdxMode:$src1),
745 "s_set_gpr_idx_on $src0,$src1"> {
746 let Defs = [M0]; // No scc def
747 let Uses = [M0]; // Other bits of m0 unmodified.
748 let hasSideEffects = 1; // Sets mode.gpr_idx_en
Matt Arsenault2d8c2892016-11-01 20:42:24 +0000749 let FixedSize = 1;
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000750}
751}
752
Valery Pykhtina34fb492016-08-30 15:20:31 +0000753//===----------------------------------------------------------------------===//
754// SOPP Instructions
755//===----------------------------------------------------------------------===//
756
757class SOPPe <bits<7> op> : Enc32 {
758 bits <16> simm16;
759
760 let Inst{15-0} = simm16;
761 let Inst{22-16} = op;
762 let Inst{31-23} = 0x17f; // encoding
763}
764
765class SOPP <bits<7> op, dag ins, string asm, list<dag> pattern = []> :
766 InstSI <(outs), ins, asm, pattern >, SOPPe <op> {
767
768 let mayLoad = 0;
769 let mayStore = 0;
770 let hasSideEffects = 0;
771 let SALU = 1;
772 let SOPP = 1;
Matt Arsenault10c17ca2016-10-06 10:13:23 +0000773 let Size = 4;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000774 let SchedRW = [WriteSALU];
775
776 let UseNamedOperandTable = 1;
777 let SubtargetPredicate = isGCN;
778}
779
780
781def S_NOP : SOPP <0x00000000, (ins i16imm:$simm16), "s_nop $simm16">;
782
783let isTerminator = 1 in {
784
785def S_ENDPGM : SOPP <0x00000001, (ins), "s_endpgm",
786 [(AMDGPUendpgm)]> {
787 let simm16 = 0;
788 let isBarrier = 1;
Matt Arsenault4e9c1e32016-10-28 23:00:38 +0000789 let isReturn = 1;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000790}
791
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000792let SubtargetPredicate = isVI in {
793def S_ENDPGM_SAVED : SOPP <0x0000001B, (ins), "s_endpgm_saved"> {
794 let simm16 = 0;
795 let isBarrier = 1;
796 let isReturn = 1;
797}
798}
799
Valery Pykhtina34fb492016-08-30 15:20:31 +0000800let isBranch = 1, SchedRW = [WriteBranch] in {
801def S_BRANCH : SOPP <
802 0x00000002, (ins sopp_brtarget:$simm16), "s_branch $simm16",
803 [(br bb:$simm16)]> {
804 let isBarrier = 1;
805}
806
807let Uses = [SCC] in {
808def S_CBRANCH_SCC0 : SOPP <
809 0x00000004, (ins sopp_brtarget:$simm16),
810 "s_cbranch_scc0 $simm16"
811>;
812def S_CBRANCH_SCC1 : SOPP <
813 0x00000005, (ins sopp_brtarget:$simm16),
814 "s_cbranch_scc1 $simm16",
815 [(si_uniform_br_scc SCC, bb:$simm16)]
816>;
817} // End Uses = [SCC]
818
819let Uses = [VCC] in {
820def S_CBRANCH_VCCZ : SOPP <
821 0x00000006, (ins sopp_brtarget:$simm16),
822 "s_cbranch_vccz $simm16"
823>;
824def S_CBRANCH_VCCNZ : SOPP <
825 0x00000007, (ins sopp_brtarget:$simm16),
826 "s_cbranch_vccnz $simm16"
827>;
828} // End Uses = [VCC]
829
830let Uses = [EXEC] in {
831def S_CBRANCH_EXECZ : SOPP <
832 0x00000008, (ins sopp_brtarget:$simm16),
833 "s_cbranch_execz $simm16"
834>;
835def S_CBRANCH_EXECNZ : SOPP <
836 0x00000009, (ins sopp_brtarget:$simm16),
837 "s_cbranch_execnz $simm16"
838>;
839} // End Uses = [EXEC]
840
Dmitry Preobrazhensky3ac63112017-04-05 17:26:45 +0000841def S_CBRANCH_CDBGSYS : SOPP <
842 0x00000017, (ins sopp_brtarget:$simm16),
843 "s_cbranch_cdbgsys $simm16"
844>;
845
846def S_CBRANCH_CDBGSYS_AND_USER : SOPP <
847 0x0000001A, (ins sopp_brtarget:$simm16),
848 "s_cbranch_cdbgsys_and_user $simm16"
849>;
850
851def S_CBRANCH_CDBGSYS_OR_USER : SOPP <
852 0x00000019, (ins sopp_brtarget:$simm16),
853 "s_cbranch_cdbgsys_or_user $simm16"
854>;
855
856def S_CBRANCH_CDBGUSER : SOPP <
857 0x00000018, (ins sopp_brtarget:$simm16),
858 "s_cbranch_cdbguser $simm16"
859>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000860
861} // End isBranch = 1
862} // End isTerminator = 1
863
864let hasSideEffects = 1 in {
865def S_BARRIER : SOPP <0x0000000a, (ins), "s_barrier",
866 [(int_amdgcn_s_barrier)]> {
867 let SchedRW = [WriteBarrier];
868 let simm16 = 0;
869 let mayLoad = 1;
870 let mayStore = 1;
871 let isConvergent = 1;
872}
873
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000874let SubtargetPredicate = isVI in {
875def S_WAKEUP : SOPP <0x00000003, (ins), "s_wakeup"> {
876 let simm16 = 0;
877 let mayLoad = 1;
878 let mayStore = 1;
879}
880}
881
Valery Pykhtina34fb492016-08-30 15:20:31 +0000882let mayLoad = 1, mayStore = 1, hasSideEffects = 1 in
883def S_WAITCNT : SOPP <0x0000000c, (ins WAIT_FLAG:$simm16), "s_waitcnt $simm16">;
884def S_SETHALT : SOPP <0x0000000d, (ins i16imm:$simm16), "s_sethalt $simm16">;
Dmitry Preobrazhensky3ac63112017-04-05 17:26:45 +0000885def S_SETKILL : SOPP <0x0000000b, (ins i16imm:$simm16), "s_setkill $simm16">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000886
887// On SI the documentation says sleep for approximately 64 * low 2
888// bits, consistent with the reported maximum of 448. On VI the
889// maximum reported is 960 cycles, so 960 / 64 = 15 max, so is the
890// maximum really 15 on VI?
891def S_SLEEP : SOPP <0x0000000e, (ins i32imm:$simm16),
892 "s_sleep $simm16", [(int_amdgcn_s_sleep SIMM16bit:$simm16)]> {
893 let hasSideEffects = 1;
894 let mayLoad = 1;
895 let mayStore = 1;
896}
897
898def S_SETPRIO : SOPP <0x0000000f, (ins i16imm:$simm16), "s_setprio $simm16">;
899
900let Uses = [EXEC, M0] in {
901// FIXME: Should this be mayLoad+mayStore?
902def S_SENDMSG : SOPP <0x00000010, (ins SendMsgImm:$simm16), "s_sendmsg $simm16",
903 [(AMDGPUsendmsg (i32 imm:$simm16))]
904>;
Jan Veselyd48445d2017-01-04 18:06:55 +0000905
906def S_SENDMSGHALT : SOPP <0x00000011, (ins SendMsgImm:$simm16), "s_sendmsghalt $simm16",
907 [(AMDGPUsendmsghalt (i32 imm:$simm16))]
908>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000909} // End Uses = [EXEC, M0]
910
Valery Pykhtina34fb492016-08-30 15:20:31 +0000911def S_TRAP : SOPP <0x00000012, (ins i16imm:$simm16), "s_trap $simm16">;
912def S_ICACHE_INV : SOPP <0x00000013, (ins), "s_icache_inv"> {
913 let simm16 = 0;
914}
915def S_INCPERFLEVEL : SOPP <0x00000014, (ins i32imm:$simm16), "s_incperflevel $simm16",
916 [(int_amdgcn_s_incperflevel SIMM16bit:$simm16)]> {
917 let hasSideEffects = 1;
918 let mayLoad = 1;
919 let mayStore = 1;
920}
921def S_DECPERFLEVEL : SOPP <0x00000015, (ins i32imm:$simm16), "s_decperflevel $simm16",
922 [(int_amdgcn_s_decperflevel SIMM16bit:$simm16)]> {
923 let hasSideEffects = 1;
924 let mayLoad = 1;
925 let mayStore = 1;
926}
927def S_TTRACEDATA : SOPP <0x00000016, (ins), "s_ttracedata"> {
928 let simm16 = 0;
929}
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000930
931let SubtargetPredicate = HasVGPRIndexMode in {
932def S_SET_GPR_IDX_OFF : SOPP<0x1c, (ins), "s_set_gpr_idx_off"> {
933 let simm16 = 0;
934}
935}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000936} // End hasSideEffects
937
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000938let SubtargetPredicate = HasVGPRIndexMode in {
939def S_SET_GPR_IDX_MODE : SOPP<0x1d, (ins GPRIdxMode:$simm16),
940 "s_set_gpr_idx_mode$simm16"> {
941 let Defs = [M0];
942}
943}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000944
945let Predicates = [isGCN] in {
946
947//===----------------------------------------------------------------------===//
948// S_GETREG_B32 Intrinsic Pattern.
949//===----------------------------------------------------------------------===//
950def : Pat <
951 (int_amdgcn_s_getreg imm:$simm16),
952 (S_GETREG_B32 (as_i16imm $simm16))
953>;
954
955//===----------------------------------------------------------------------===//
956// SOP1 Patterns
957//===----------------------------------------------------------------------===//
958
959def : Pat <
960 (i64 (ctpop i64:$src)),
961 (i64 (REG_SEQUENCE SReg_64,
962 (i32 (COPY_TO_REGCLASS (S_BCNT1_I32_B64 $src), SReg_32)), sub0,
Tom Stellard115a6152016-11-10 16:02:37 +0000963 (S_MOV_B32 (i32 0)), sub1))
Valery Pykhtina34fb492016-08-30 15:20:31 +0000964>;
965
966def : Pat <
967 (i32 (smax i32:$x, (i32 (ineg i32:$x)))),
968 (S_ABS_I32 $x)
969>;
970
Tom Stellard115a6152016-11-10 16:02:37 +0000971def : Pat <
972 (i16 imm:$imm),
973 (S_MOV_B32 imm:$imm)
974>;
975
976// Same as a 32-bit inreg
977def : Pat<
978 (i32 (sext i16:$src)),
979 (S_SEXT_I32_I16 $src)
980>;
981
982
Valery Pykhtina34fb492016-08-30 15:20:31 +0000983//===----------------------------------------------------------------------===//
984// SOP2 Patterns
985//===----------------------------------------------------------------------===//
986
987// V_ADD_I32_e32/S_ADD_U32 produces carry in VCC/SCC. For the vector
988// case, the sgpr-copies pass will fix this to use the vector version.
989def : Pat <
990 (i32 (addc i32:$src0, i32:$src1)),
991 (S_ADD_U32 $src0, $src1)
992>;
993
Tom Stellard115a6152016-11-10 16:02:37 +0000994// FIXME: We need to use COPY_TO_REGCLASS to work-around the fact that
995// REG_SEQUENCE patterns don't support instructions with multiple
996// outputs.
997def : Pat<
998 (i64 (zext i16:$src)),
999 (REG_SEQUENCE SReg_64,
1000 (i32 (COPY_TO_REGCLASS (S_AND_B32 $src, (S_MOV_B32 (i32 0xffff))), SGPR_32)), sub0,
1001 (S_MOV_B32 (i32 0)), sub1)
1002>;
1003
1004def : Pat <
1005 (i64 (sext i16:$src)),
1006 (REG_SEQUENCE SReg_64, (i32 (S_SEXT_I32_I16 $src)), sub0,
1007 (i32 (COPY_TO_REGCLASS (S_ASHR_I32 (i32 (S_SEXT_I32_I16 $src)), (S_MOV_B32 (i32 31))), SGPR_32)), sub1)
1008>;
1009
1010def : Pat<
1011 (i32 (zext i16:$src)),
1012 (S_AND_B32 (S_MOV_B32 (i32 0xffff)), $src)
1013>;
1014
1015
1016
Valery Pykhtina34fb492016-08-30 15:20:31 +00001017//===----------------------------------------------------------------------===//
1018// SOPP Patterns
1019//===----------------------------------------------------------------------===//
1020
1021def : Pat <
1022 (int_amdgcn_s_waitcnt i32:$simm16),
1023 (S_WAITCNT (as_i16imm $simm16))
1024>;
1025
1026} // End isGCN predicate
1027
1028
1029//===----------------------------------------------------------------------===//
1030// Real target instructions, move this to the appropriate subtarget TD file
1031//===----------------------------------------------------------------------===//
1032
1033class Select_si<string opName> :
1034 SIMCInstr<opName, SIEncodingFamily.SI> {
1035 list<Predicate> AssemblerPredicates = [isSICI];
1036 string DecoderNamespace = "SICI";
1037}
1038
1039class SOP1_Real_si<bits<8> op, SOP1_Pseudo ps> :
1040 SOP1_Real<op, ps>,
1041 Select_si<ps.Mnemonic>;
1042
1043class SOP2_Real_si<bits<7> op, SOP2_Pseudo ps> :
1044 SOP2_Real<op, ps>,
1045 Select_si<ps.Mnemonic>;
1046
1047class SOPK_Real_si<bits<5> op, SOPK_Pseudo ps> :
1048 SOPK_Real32<op, ps>,
1049 Select_si<ps.Mnemonic>;
1050
1051def S_MOV_B32_si : SOP1_Real_si <0x03, S_MOV_B32>;
1052def S_MOV_B64_si : SOP1_Real_si <0x04, S_MOV_B64>;
1053def S_CMOV_B32_si : SOP1_Real_si <0x05, S_CMOV_B32>;
1054def S_CMOV_B64_si : SOP1_Real_si <0x06, S_CMOV_B64>;
1055def S_NOT_B32_si : SOP1_Real_si <0x07, S_NOT_B32>;
1056def S_NOT_B64_si : SOP1_Real_si <0x08, S_NOT_B64>;
1057def S_WQM_B32_si : SOP1_Real_si <0x09, S_WQM_B32>;
1058def S_WQM_B64_si : SOP1_Real_si <0x0a, S_WQM_B64>;
1059def S_BREV_B32_si : SOP1_Real_si <0x0b, S_BREV_B32>;
1060def S_BREV_B64_si : SOP1_Real_si <0x0c, S_BREV_B64>;
1061def S_BCNT0_I32_B32_si : SOP1_Real_si <0x0d, S_BCNT0_I32_B32>;
1062def S_BCNT0_I32_B64_si : SOP1_Real_si <0x0e, S_BCNT0_I32_B64>;
1063def S_BCNT1_I32_B32_si : SOP1_Real_si <0x0f, S_BCNT1_I32_B32>;
1064def S_BCNT1_I32_B64_si : SOP1_Real_si <0x10, S_BCNT1_I32_B64>;
1065def S_FF0_I32_B32_si : SOP1_Real_si <0x11, S_FF0_I32_B32>;
1066def S_FF0_I32_B64_si : SOP1_Real_si <0x12, S_FF0_I32_B64>;
1067def S_FF1_I32_B32_si : SOP1_Real_si <0x13, S_FF1_I32_B32>;
1068def S_FF1_I32_B64_si : SOP1_Real_si <0x14, S_FF1_I32_B64>;
1069def S_FLBIT_I32_B32_si : SOP1_Real_si <0x15, S_FLBIT_I32_B32>;
1070def S_FLBIT_I32_B64_si : SOP1_Real_si <0x16, S_FLBIT_I32_B64>;
1071def S_FLBIT_I32_si : SOP1_Real_si <0x17, S_FLBIT_I32>;
1072def S_FLBIT_I32_I64_si : SOP1_Real_si <0x18, S_FLBIT_I32_I64>;
1073def S_SEXT_I32_I8_si : SOP1_Real_si <0x19, S_SEXT_I32_I8>;
1074def S_SEXT_I32_I16_si : SOP1_Real_si <0x1a, S_SEXT_I32_I16>;
1075def S_BITSET0_B32_si : SOP1_Real_si <0x1b, S_BITSET0_B32>;
1076def S_BITSET0_B64_si : SOP1_Real_si <0x1c, S_BITSET0_B64>;
1077def S_BITSET1_B32_si : SOP1_Real_si <0x1d, S_BITSET1_B32>;
1078def S_BITSET1_B64_si : SOP1_Real_si <0x1e, S_BITSET1_B64>;
1079def S_GETPC_B64_si : SOP1_Real_si <0x1f, S_GETPC_B64>;
1080def S_SETPC_B64_si : SOP1_Real_si <0x20, S_SETPC_B64>;
1081def S_SWAPPC_B64_si : SOP1_Real_si <0x21, S_SWAPPC_B64>;
1082def S_RFE_B64_si : SOP1_Real_si <0x22, S_RFE_B64>;
1083def S_AND_SAVEEXEC_B64_si : SOP1_Real_si <0x24, S_AND_SAVEEXEC_B64>;
1084def S_OR_SAVEEXEC_B64_si : SOP1_Real_si <0x25, S_OR_SAVEEXEC_B64>;
1085def S_XOR_SAVEEXEC_B64_si : SOP1_Real_si <0x26, S_XOR_SAVEEXEC_B64>;
1086def S_ANDN2_SAVEEXEC_B64_si: SOP1_Real_si <0x27, S_ANDN2_SAVEEXEC_B64>;
1087def S_ORN2_SAVEEXEC_B64_si : SOP1_Real_si <0x28, S_ORN2_SAVEEXEC_B64>;
1088def S_NAND_SAVEEXEC_B64_si : SOP1_Real_si <0x29, S_NAND_SAVEEXEC_B64>;
1089def S_NOR_SAVEEXEC_B64_si : SOP1_Real_si <0x2a, S_NOR_SAVEEXEC_B64>;
1090def S_XNOR_SAVEEXEC_B64_si : SOP1_Real_si <0x2b, S_XNOR_SAVEEXEC_B64>;
1091def S_QUADMASK_B32_si : SOP1_Real_si <0x2c, S_QUADMASK_B32>;
1092def S_QUADMASK_B64_si : SOP1_Real_si <0x2d, S_QUADMASK_B64>;
1093def S_MOVRELS_B32_si : SOP1_Real_si <0x2e, S_MOVRELS_B32>;
1094def S_MOVRELS_B64_si : SOP1_Real_si <0x2f, S_MOVRELS_B64>;
1095def S_MOVRELD_B32_si : SOP1_Real_si <0x30, S_MOVRELD_B32>;
1096def S_MOVRELD_B64_si : SOP1_Real_si <0x31, S_MOVRELD_B64>;
1097def S_CBRANCH_JOIN_si : SOP1_Real_si <0x32, S_CBRANCH_JOIN>;
1098def S_MOV_REGRD_B32_si : SOP1_Real_si <0x33, S_MOV_REGRD_B32>;
1099def S_ABS_I32_si : SOP1_Real_si <0x34, S_ABS_I32>;
1100def S_MOV_FED_B32_si : SOP1_Real_si <0x35, S_MOV_FED_B32>;
1101
1102def S_ADD_U32_si : SOP2_Real_si <0x00, S_ADD_U32>;
1103def S_ADD_I32_si : SOP2_Real_si <0x02, S_ADD_I32>;
1104def S_SUB_U32_si : SOP2_Real_si <0x01, S_SUB_U32>;
1105def S_SUB_I32_si : SOP2_Real_si <0x03, S_SUB_I32>;
1106def S_ADDC_U32_si : SOP2_Real_si <0x04, S_ADDC_U32>;
1107def S_SUBB_U32_si : SOP2_Real_si <0x05, S_SUBB_U32>;
1108def S_MIN_I32_si : SOP2_Real_si <0x06, S_MIN_I32>;
1109def S_MIN_U32_si : SOP2_Real_si <0x07, S_MIN_U32>;
1110def S_MAX_I32_si : SOP2_Real_si <0x08, S_MAX_I32>;
1111def S_MAX_U32_si : SOP2_Real_si <0x09, S_MAX_U32>;
1112def S_CSELECT_B32_si : SOP2_Real_si <0x0a, S_CSELECT_B32>;
1113def S_CSELECT_B64_si : SOP2_Real_si <0x0b, S_CSELECT_B64>;
1114def S_AND_B32_si : SOP2_Real_si <0x0e, S_AND_B32>;
1115def S_AND_B64_si : SOP2_Real_si <0x0f, S_AND_B64>;
1116def S_OR_B32_si : SOP2_Real_si <0x10, S_OR_B32>;
1117def S_OR_B64_si : SOP2_Real_si <0x11, S_OR_B64>;
1118def S_XOR_B32_si : SOP2_Real_si <0x12, S_XOR_B32>;
1119def S_XOR_B64_si : SOP2_Real_si <0x13, S_XOR_B64>;
1120def S_ANDN2_B32_si : SOP2_Real_si <0x14, S_ANDN2_B32>;
1121def S_ANDN2_B64_si : SOP2_Real_si <0x15, S_ANDN2_B64>;
1122def S_ORN2_B32_si : SOP2_Real_si <0x16, S_ORN2_B32>;
1123def S_ORN2_B64_si : SOP2_Real_si <0x17, S_ORN2_B64>;
1124def S_NAND_B32_si : SOP2_Real_si <0x18, S_NAND_B32>;
1125def S_NAND_B64_si : SOP2_Real_si <0x19, S_NAND_B64>;
1126def S_NOR_B32_si : SOP2_Real_si <0x1a, S_NOR_B32>;
1127def S_NOR_B64_si : SOP2_Real_si <0x1b, S_NOR_B64>;
1128def S_XNOR_B32_si : SOP2_Real_si <0x1c, S_XNOR_B32>;
1129def S_XNOR_B64_si : SOP2_Real_si <0x1d, S_XNOR_B64>;
1130def S_LSHL_B32_si : SOP2_Real_si <0x1e, S_LSHL_B32>;
1131def S_LSHL_B64_si : SOP2_Real_si <0x1f, S_LSHL_B64>;
1132def S_LSHR_B32_si : SOP2_Real_si <0x20, S_LSHR_B32>;
1133def S_LSHR_B64_si : SOP2_Real_si <0x21, S_LSHR_B64>;
1134def S_ASHR_I32_si : SOP2_Real_si <0x22, S_ASHR_I32>;
1135def S_ASHR_I64_si : SOP2_Real_si <0x23, S_ASHR_I64>;
1136def S_BFM_B32_si : SOP2_Real_si <0x24, S_BFM_B32>;
1137def S_BFM_B64_si : SOP2_Real_si <0x25, S_BFM_B64>;
1138def S_MUL_I32_si : SOP2_Real_si <0x26, S_MUL_I32>;
1139def S_BFE_U32_si : SOP2_Real_si <0x27, S_BFE_U32>;
1140def S_BFE_I32_si : SOP2_Real_si <0x28, S_BFE_I32>;
1141def S_BFE_U64_si : SOP2_Real_si <0x29, S_BFE_U64>;
1142def S_BFE_I64_si : SOP2_Real_si <0x2a, S_BFE_I64>;
1143def S_CBRANCH_G_FORK_si : SOP2_Real_si <0x2b, S_CBRANCH_G_FORK>;
1144def S_ABSDIFF_I32_si : SOP2_Real_si <0x2c, S_ABSDIFF_I32>;
1145
1146def S_MOVK_I32_si : SOPK_Real_si <0x00, S_MOVK_I32>;
1147def S_CMOVK_I32_si : SOPK_Real_si <0x02, S_CMOVK_I32>;
1148def S_CMPK_EQ_I32_si : SOPK_Real_si <0x03, S_CMPK_EQ_I32>;
1149def S_CMPK_LG_I32_si : SOPK_Real_si <0x04, S_CMPK_LG_I32>;
1150def S_CMPK_GT_I32_si : SOPK_Real_si <0x05, S_CMPK_GT_I32>;
1151def S_CMPK_GE_I32_si : SOPK_Real_si <0x06, S_CMPK_GE_I32>;
1152def S_CMPK_LT_I32_si : SOPK_Real_si <0x07, S_CMPK_LT_I32>;
1153def S_CMPK_LE_I32_si : SOPK_Real_si <0x08, S_CMPK_LE_I32>;
1154def S_CMPK_EQ_U32_si : SOPK_Real_si <0x09, S_CMPK_EQ_U32>;
1155def S_CMPK_LG_U32_si : SOPK_Real_si <0x0a, S_CMPK_LG_U32>;
1156def S_CMPK_GT_U32_si : SOPK_Real_si <0x0b, S_CMPK_GT_U32>;
1157def S_CMPK_GE_U32_si : SOPK_Real_si <0x0c, S_CMPK_GE_U32>;
1158def S_CMPK_LT_U32_si : SOPK_Real_si <0x0d, S_CMPK_LT_U32>;
1159def S_CMPK_LE_U32_si : SOPK_Real_si <0x0e, S_CMPK_LE_U32>;
1160def S_ADDK_I32_si : SOPK_Real_si <0x0f, S_ADDK_I32>;
1161def S_MULK_I32_si : SOPK_Real_si <0x10, S_MULK_I32>;
1162def S_CBRANCH_I_FORK_si : SOPK_Real_si <0x11, S_CBRANCH_I_FORK>;
1163def S_GETREG_B32_si : SOPK_Real_si <0x12, S_GETREG_B32>;
1164def S_SETREG_B32_si : SOPK_Real_si <0x13, S_SETREG_B32>;
1165//def S_GETREG_REGRD_B32_si : SOPK_Real_si <0x14, S_GETREG_REGRD_B32>; // see pseudo for comments
1166def S_SETREG_IMM32_B32_si : SOPK_Real64<0x15, S_SETREG_IMM32_B32>,
1167 Select_si<S_SETREG_IMM32_B32.Mnemonic>;
1168
1169
1170class Select_vi<string opName> :
1171 SIMCInstr<opName, SIEncodingFamily.VI> {
1172 list<Predicate> AssemblerPredicates = [isVI];
1173 string DecoderNamespace = "VI";
1174}
1175
1176class SOP1_Real_vi<bits<8> op, SOP1_Pseudo ps> :
1177 SOP1_Real<op, ps>,
1178 Select_vi<ps.Mnemonic>;
1179
1180
1181class SOP2_Real_vi<bits<7> op, SOP2_Pseudo ps> :
1182 SOP2_Real<op, ps>,
1183 Select_vi<ps.Mnemonic>;
1184
1185class SOPK_Real_vi<bits<5> op, SOPK_Pseudo ps> :
1186 SOPK_Real32<op, ps>,
1187 Select_vi<ps.Mnemonic>;
1188
1189def S_MOV_B32_vi : SOP1_Real_vi <0x00, S_MOV_B32>;
1190def S_MOV_B64_vi : SOP1_Real_vi <0x01, S_MOV_B64>;
1191def S_CMOV_B32_vi : SOP1_Real_vi <0x02, S_CMOV_B32>;
1192def S_CMOV_B64_vi : SOP1_Real_vi <0x03, S_CMOV_B64>;
1193def S_NOT_B32_vi : SOP1_Real_vi <0x04, S_NOT_B32>;
1194def S_NOT_B64_vi : SOP1_Real_vi <0x05, S_NOT_B64>;
1195def S_WQM_B32_vi : SOP1_Real_vi <0x06, S_WQM_B32>;
1196def S_WQM_B64_vi : SOP1_Real_vi <0x07, S_WQM_B64>;
1197def S_BREV_B32_vi : SOP1_Real_vi <0x08, S_BREV_B32>;
1198def S_BREV_B64_vi : SOP1_Real_vi <0x09, S_BREV_B64>;
1199def S_BCNT0_I32_B32_vi : SOP1_Real_vi <0x0a, S_BCNT0_I32_B32>;
1200def S_BCNT0_I32_B64_vi : SOP1_Real_vi <0x0b, S_BCNT0_I32_B64>;
1201def S_BCNT1_I32_B32_vi : SOP1_Real_vi <0x0c, S_BCNT1_I32_B32>;
1202def S_BCNT1_I32_B64_vi : SOP1_Real_vi <0x0d, S_BCNT1_I32_B64>;
1203def S_FF0_I32_B32_vi : SOP1_Real_vi <0x0e, S_FF0_I32_B32>;
1204def S_FF0_I32_B64_vi : SOP1_Real_vi <0x0f, S_FF0_I32_B64>;
1205def S_FF1_I32_B32_vi : SOP1_Real_vi <0x10, S_FF1_I32_B32>;
1206def S_FF1_I32_B64_vi : SOP1_Real_vi <0x11, S_FF1_I32_B64>;
1207def S_FLBIT_I32_B32_vi : SOP1_Real_vi <0x12, S_FLBIT_I32_B32>;
1208def S_FLBIT_I32_B64_vi : SOP1_Real_vi <0x13, S_FLBIT_I32_B64>;
1209def S_FLBIT_I32_vi : SOP1_Real_vi <0x14, S_FLBIT_I32>;
1210def S_FLBIT_I32_I64_vi : SOP1_Real_vi <0x15, S_FLBIT_I32_I64>;
1211def S_SEXT_I32_I8_vi : SOP1_Real_vi <0x16, S_SEXT_I32_I8>;
1212def S_SEXT_I32_I16_vi : SOP1_Real_vi <0x17, S_SEXT_I32_I16>;
1213def S_BITSET0_B32_vi : SOP1_Real_vi <0x18, S_BITSET0_B32>;
1214def S_BITSET0_B64_vi : SOP1_Real_vi <0x19, S_BITSET0_B64>;
1215def S_BITSET1_B32_vi : SOP1_Real_vi <0x1a, S_BITSET1_B32>;
1216def S_BITSET1_B64_vi : SOP1_Real_vi <0x1b, S_BITSET1_B64>;
1217def S_GETPC_B64_vi : SOP1_Real_vi <0x1c, S_GETPC_B64>;
1218def S_SETPC_B64_vi : SOP1_Real_vi <0x1d, S_SETPC_B64>;
1219def S_SWAPPC_B64_vi : SOP1_Real_vi <0x1e, S_SWAPPC_B64>;
1220def S_RFE_B64_vi : SOP1_Real_vi <0x1f, S_RFE_B64>;
1221def S_AND_SAVEEXEC_B64_vi : SOP1_Real_vi <0x20, S_AND_SAVEEXEC_B64>;
1222def S_OR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x21, S_OR_SAVEEXEC_B64>;
1223def S_XOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x22, S_XOR_SAVEEXEC_B64>;
1224def S_ANDN2_SAVEEXEC_B64_vi: SOP1_Real_vi <0x23, S_ANDN2_SAVEEXEC_B64>;
1225def S_ORN2_SAVEEXEC_B64_vi : SOP1_Real_vi <0x24, S_ORN2_SAVEEXEC_B64>;
1226def S_NAND_SAVEEXEC_B64_vi : SOP1_Real_vi <0x25, S_NAND_SAVEEXEC_B64>;
1227def S_NOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x26, S_NOR_SAVEEXEC_B64>;
1228def S_XNOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x27, S_XNOR_SAVEEXEC_B64>;
1229def S_QUADMASK_B32_vi : SOP1_Real_vi <0x28, S_QUADMASK_B32>;
1230def S_QUADMASK_B64_vi : SOP1_Real_vi <0x29, S_QUADMASK_B64>;
1231def S_MOVRELS_B32_vi : SOP1_Real_vi <0x2a, S_MOVRELS_B32>;
1232def S_MOVRELS_B64_vi : SOP1_Real_vi <0x2b, S_MOVRELS_B64>;
1233def S_MOVRELD_B32_vi : SOP1_Real_vi <0x2c, S_MOVRELD_B32>;
1234def S_MOVRELD_B64_vi : SOP1_Real_vi <0x2d, S_MOVRELD_B64>;
1235def S_CBRANCH_JOIN_vi : SOP1_Real_vi <0x2e, S_CBRANCH_JOIN>;
1236def S_MOV_REGRD_B32_vi : SOP1_Real_vi <0x2f, S_MOV_REGRD_B32>;
1237def S_ABS_I32_vi : SOP1_Real_vi <0x30, S_ABS_I32>;
1238def S_MOV_FED_B32_vi : SOP1_Real_vi <0x31, S_MOV_FED_B32>;
Matt Arsenaultcc88ce32016-10-12 18:00:51 +00001239def S_SET_GPR_IDX_IDX_vi : SOP1_Real_vi <0x32, S_SET_GPR_IDX_IDX>;
Valery Pykhtina34fb492016-08-30 15:20:31 +00001240
1241def S_ADD_U32_vi : SOP2_Real_vi <0x00, S_ADD_U32>;
1242def S_ADD_I32_vi : SOP2_Real_vi <0x02, S_ADD_I32>;
1243def S_SUB_U32_vi : SOP2_Real_vi <0x01, S_SUB_U32>;
1244def S_SUB_I32_vi : SOP2_Real_vi <0x03, S_SUB_I32>;
1245def S_ADDC_U32_vi : SOP2_Real_vi <0x04, S_ADDC_U32>;
1246def S_SUBB_U32_vi : SOP2_Real_vi <0x05, S_SUBB_U32>;
1247def S_MIN_I32_vi : SOP2_Real_vi <0x06, S_MIN_I32>;
1248def S_MIN_U32_vi : SOP2_Real_vi <0x07, S_MIN_U32>;
1249def S_MAX_I32_vi : SOP2_Real_vi <0x08, S_MAX_I32>;
1250def S_MAX_U32_vi : SOP2_Real_vi <0x09, S_MAX_U32>;
1251def S_CSELECT_B32_vi : SOP2_Real_vi <0x0a, S_CSELECT_B32>;
1252def S_CSELECT_B64_vi : SOP2_Real_vi <0x0b, S_CSELECT_B64>;
1253def S_AND_B32_vi : SOP2_Real_vi <0x0c, S_AND_B32>;
1254def S_AND_B64_vi : SOP2_Real_vi <0x0d, S_AND_B64>;
1255def S_OR_B32_vi : SOP2_Real_vi <0x0e, S_OR_B32>;
1256def S_OR_B64_vi : SOP2_Real_vi <0x0f, S_OR_B64>;
1257def S_XOR_B32_vi : SOP2_Real_vi <0x10, S_XOR_B32>;
1258def S_XOR_B64_vi : SOP2_Real_vi <0x11, S_XOR_B64>;
1259def S_ANDN2_B32_vi : SOP2_Real_vi <0x12, S_ANDN2_B32>;
1260def S_ANDN2_B64_vi : SOP2_Real_vi <0x13, S_ANDN2_B64>;
1261def S_ORN2_B32_vi : SOP2_Real_vi <0x14, S_ORN2_B32>;
1262def S_ORN2_B64_vi : SOP2_Real_vi <0x15, S_ORN2_B64>;
1263def S_NAND_B32_vi : SOP2_Real_vi <0x16, S_NAND_B32>;
1264def S_NAND_B64_vi : SOP2_Real_vi <0x17, S_NAND_B64>;
1265def S_NOR_B32_vi : SOP2_Real_vi <0x18, S_NOR_B32>;
1266def S_NOR_B64_vi : SOP2_Real_vi <0x19, S_NOR_B64>;
1267def S_XNOR_B32_vi : SOP2_Real_vi <0x1a, S_XNOR_B32>;
1268def S_XNOR_B64_vi : SOP2_Real_vi <0x1b, S_XNOR_B64>;
1269def S_LSHL_B32_vi : SOP2_Real_vi <0x1c, S_LSHL_B32>;
1270def S_LSHL_B64_vi : SOP2_Real_vi <0x1d, S_LSHL_B64>;
1271def S_LSHR_B32_vi : SOP2_Real_vi <0x1e, S_LSHR_B32>;
1272def S_LSHR_B64_vi : SOP2_Real_vi <0x1f, S_LSHR_B64>;
1273def S_ASHR_I32_vi : SOP2_Real_vi <0x20, S_ASHR_I32>;
1274def S_ASHR_I64_vi : SOP2_Real_vi <0x21, S_ASHR_I64>;
1275def S_BFM_B32_vi : SOP2_Real_vi <0x22, S_BFM_B32>;
1276def S_BFM_B64_vi : SOP2_Real_vi <0x23, S_BFM_B64>;
1277def S_MUL_I32_vi : SOP2_Real_vi <0x24, S_MUL_I32>;
1278def S_BFE_U32_vi : SOP2_Real_vi <0x25, S_BFE_U32>;
1279def S_BFE_I32_vi : SOP2_Real_vi <0x26, S_BFE_I32>;
1280def S_BFE_U64_vi : SOP2_Real_vi <0x27, S_BFE_U64>;
1281def S_BFE_I64_vi : SOP2_Real_vi <0x28, S_BFE_I64>;
1282def S_CBRANCH_G_FORK_vi : SOP2_Real_vi <0x29, S_CBRANCH_G_FORK>;
1283def S_ABSDIFF_I32_vi : SOP2_Real_vi <0x2a, S_ABSDIFF_I32>;
Matt Arsenault9be7b0d2017-02-27 18:49:11 +00001284def S_PACK_LL_B32_B16_vi : SOP2_Real_vi <0x32, S_PACK_LL_B32_B16>;
1285def S_PACK_LH_B32_B16_vi : SOP2_Real_vi <0x33, S_PACK_LH_B32_B16>;
1286def S_PACK_HH_B32_B16_vi : SOP2_Real_vi <0x34, S_PACK_HH_B32_B16>;
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +00001287def S_RFE_RESTORE_B64_vi : SOP2_Real_vi <0x2b, S_RFE_RESTORE_B64>;
Valery Pykhtina34fb492016-08-30 15:20:31 +00001288
1289def S_MOVK_I32_vi : SOPK_Real_vi <0x00, S_MOVK_I32>;
1290def S_CMOVK_I32_vi : SOPK_Real_vi <0x01, S_CMOVK_I32>;
1291def S_CMPK_EQ_I32_vi : SOPK_Real_vi <0x02, S_CMPK_EQ_I32>;
1292def S_CMPK_LG_I32_vi : SOPK_Real_vi <0x03, S_CMPK_LG_I32>;
1293def S_CMPK_GT_I32_vi : SOPK_Real_vi <0x04, S_CMPK_GT_I32>;
1294def S_CMPK_GE_I32_vi : SOPK_Real_vi <0x05, S_CMPK_GE_I32>;
1295def S_CMPK_LT_I32_vi : SOPK_Real_vi <0x06, S_CMPK_LT_I32>;
1296def S_CMPK_LE_I32_vi : SOPK_Real_vi <0x07, S_CMPK_LE_I32>;
1297def S_CMPK_EQ_U32_vi : SOPK_Real_vi <0x08, S_CMPK_EQ_U32>;
1298def S_CMPK_LG_U32_vi : SOPK_Real_vi <0x09, S_CMPK_LG_U32>;
1299def S_CMPK_GT_U32_vi : SOPK_Real_vi <0x0A, S_CMPK_GT_U32>;
1300def S_CMPK_GE_U32_vi : SOPK_Real_vi <0x0B, S_CMPK_GE_U32>;
1301def S_CMPK_LT_U32_vi : SOPK_Real_vi <0x0C, S_CMPK_LT_U32>;
1302def S_CMPK_LE_U32_vi : SOPK_Real_vi <0x0D, S_CMPK_LE_U32>;
1303def S_ADDK_I32_vi : SOPK_Real_vi <0x0E, S_ADDK_I32>;
1304def S_MULK_I32_vi : SOPK_Real_vi <0x0F, S_MULK_I32>;
1305def S_CBRANCH_I_FORK_vi : SOPK_Real_vi <0x10, S_CBRANCH_I_FORK>;
1306def S_GETREG_B32_vi : SOPK_Real_vi <0x11, S_GETREG_B32>;
1307def S_SETREG_B32_vi : SOPK_Real_vi <0x12, S_SETREG_B32>;
1308//def S_GETREG_REGRD_B32_vi : SOPK_Real_vi <0x13, S_GETREG_REGRD_B32>; // see pseudo for comments
1309def S_SETREG_IMM32_B32_vi : SOPK_Real64<0x14, S_SETREG_IMM32_B32>,
Tom Stellard2add8a12016-09-06 20:00:26 +00001310 Select_vi<S_SETREG_IMM32_B32.Mnemonic>;