blob: 43c548759446f99e9cc2fbc95cb08f0e9a4033f6 [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),
820 "s_cbranch_scc1 $simm16",
821 [(si_uniform_br_scc SCC, bb:$simm16)]
822>;
823} // End Uses = [SCC]
824
825let Uses = [VCC] in {
826def S_CBRANCH_VCCZ : SOPP <
827 0x00000006, (ins sopp_brtarget:$simm16),
828 "s_cbranch_vccz $simm16"
829>;
830def S_CBRANCH_VCCNZ : SOPP <
831 0x00000007, (ins sopp_brtarget:$simm16),
832 "s_cbranch_vccnz $simm16"
833>;
834} // End Uses = [VCC]
835
836let Uses = [EXEC] in {
837def S_CBRANCH_EXECZ : SOPP <
838 0x00000008, (ins sopp_brtarget:$simm16),
839 "s_cbranch_execz $simm16"
840>;
841def S_CBRANCH_EXECNZ : SOPP <
842 0x00000009, (ins sopp_brtarget:$simm16),
843 "s_cbranch_execnz $simm16"
844>;
845} // End Uses = [EXEC]
846
Dmitry Preobrazhensky3ac63112017-04-05 17:26:45 +0000847def S_CBRANCH_CDBGSYS : SOPP <
848 0x00000017, (ins sopp_brtarget:$simm16),
849 "s_cbranch_cdbgsys $simm16"
850>;
851
852def S_CBRANCH_CDBGSYS_AND_USER : SOPP <
853 0x0000001A, (ins sopp_brtarget:$simm16),
854 "s_cbranch_cdbgsys_and_user $simm16"
855>;
856
857def S_CBRANCH_CDBGSYS_OR_USER : SOPP <
858 0x00000019, (ins sopp_brtarget:$simm16),
859 "s_cbranch_cdbgsys_or_user $simm16"
860>;
861
862def S_CBRANCH_CDBGUSER : SOPP <
863 0x00000018, (ins sopp_brtarget:$simm16),
864 "s_cbranch_cdbguser $simm16"
865>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000866
867} // End isBranch = 1
868} // End isTerminator = 1
869
870let hasSideEffects = 1 in {
871def S_BARRIER : SOPP <0x0000000a, (ins), "s_barrier",
872 [(int_amdgcn_s_barrier)]> {
873 let SchedRW = [WriteBarrier];
874 let simm16 = 0;
875 let mayLoad = 1;
876 let mayStore = 1;
877 let isConvergent = 1;
878}
879
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000880let SubtargetPredicate = isVI in {
881def S_WAKEUP : SOPP <0x00000003, (ins), "s_wakeup"> {
882 let simm16 = 0;
883 let mayLoad = 1;
884 let mayStore = 1;
885}
886}
887
Valery Pykhtina34fb492016-08-30 15:20:31 +0000888let mayLoad = 1, mayStore = 1, hasSideEffects = 1 in
889def S_WAITCNT : SOPP <0x0000000c, (ins WAIT_FLAG:$simm16), "s_waitcnt $simm16">;
890def S_SETHALT : SOPP <0x0000000d, (ins i16imm:$simm16), "s_sethalt $simm16">;
Dmitry Preobrazhensky3ac63112017-04-05 17:26:45 +0000891def S_SETKILL : SOPP <0x0000000b, (ins i16imm:$simm16), "s_setkill $simm16">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000892
893// On SI the documentation says sleep for approximately 64 * low 2
894// bits, consistent with the reported maximum of 448. On VI the
895// maximum reported is 960 cycles, so 960 / 64 = 15 max, so is the
896// maximum really 15 on VI?
897def S_SLEEP : SOPP <0x0000000e, (ins i32imm:$simm16),
898 "s_sleep $simm16", [(int_amdgcn_s_sleep SIMM16bit:$simm16)]> {
899 let hasSideEffects = 1;
900 let mayLoad = 1;
901 let mayStore = 1;
902}
903
904def S_SETPRIO : SOPP <0x0000000f, (ins i16imm:$simm16), "s_setprio $simm16">;
905
906let Uses = [EXEC, M0] in {
907// FIXME: Should this be mayLoad+mayStore?
908def S_SENDMSG : SOPP <0x00000010, (ins SendMsgImm:$simm16), "s_sendmsg $simm16",
909 [(AMDGPUsendmsg (i32 imm:$simm16))]
910>;
Jan Veselyd48445d2017-01-04 18:06:55 +0000911
912def S_SENDMSGHALT : SOPP <0x00000011, (ins SendMsgImm:$simm16), "s_sendmsghalt $simm16",
913 [(AMDGPUsendmsghalt (i32 imm:$simm16))]
914>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000915} // End Uses = [EXEC, M0]
916
Valery Pykhtina34fb492016-08-30 15:20:31 +0000917def S_TRAP : SOPP <0x00000012, (ins i16imm:$simm16), "s_trap $simm16">;
918def S_ICACHE_INV : SOPP <0x00000013, (ins), "s_icache_inv"> {
919 let simm16 = 0;
920}
921def S_INCPERFLEVEL : SOPP <0x00000014, (ins i32imm:$simm16), "s_incperflevel $simm16",
922 [(int_amdgcn_s_incperflevel SIMM16bit:$simm16)]> {
923 let hasSideEffects = 1;
924 let mayLoad = 1;
925 let mayStore = 1;
926}
927def S_DECPERFLEVEL : SOPP <0x00000015, (ins i32imm:$simm16), "s_decperflevel $simm16",
928 [(int_amdgcn_s_decperflevel SIMM16bit:$simm16)]> {
929 let hasSideEffects = 1;
930 let mayLoad = 1;
931 let mayStore = 1;
932}
933def S_TTRACEDATA : SOPP <0x00000016, (ins), "s_ttracedata"> {
934 let simm16 = 0;
935}
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000936
937let SubtargetPredicate = HasVGPRIndexMode in {
938def S_SET_GPR_IDX_OFF : SOPP<0x1c, (ins), "s_set_gpr_idx_off"> {
939 let simm16 = 0;
940}
941}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000942} // End hasSideEffects
943
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000944let SubtargetPredicate = HasVGPRIndexMode in {
945def S_SET_GPR_IDX_MODE : SOPP<0x1d, (ins GPRIdxMode:$simm16),
946 "s_set_gpr_idx_mode$simm16"> {
947 let Defs = [M0];
948}
949}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000950
Valery Pykhtina34fb492016-08-30 15:20:31 +0000951//===----------------------------------------------------------------------===//
952// S_GETREG_B32 Intrinsic Pattern.
953//===----------------------------------------------------------------------===//
Matt Arsenault90c75932017-10-03 00:06:41 +0000954def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000955 (int_amdgcn_s_getreg imm:$simm16),
956 (S_GETREG_B32 (as_i16imm $simm16))
957>;
958
959//===----------------------------------------------------------------------===//
960// SOP1 Patterns
961//===----------------------------------------------------------------------===//
962
Matt Arsenault90c75932017-10-03 00:06:41 +0000963def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000964 (i64 (ctpop i64:$src)),
965 (i64 (REG_SEQUENCE SReg_64,
966 (i32 (COPY_TO_REGCLASS (S_BCNT1_I32_B64 $src), SReg_32)), sub0,
Tom Stellard115a6152016-11-10 16:02:37 +0000967 (S_MOV_B32 (i32 0)), sub1))
Valery Pykhtina34fb492016-08-30 15:20:31 +0000968>;
969
Matt Arsenault90c75932017-10-03 00:06:41 +0000970def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000971 (i32 (smax i32:$x, (i32 (ineg i32:$x)))),
972 (S_ABS_I32 $x)
973>;
974
Matt Arsenault90c75932017-10-03 00:06:41 +0000975def : GCNPat <
Tom Stellard115a6152016-11-10 16:02:37 +0000976 (i16 imm:$imm),
977 (S_MOV_B32 imm:$imm)
978>;
979
980// Same as a 32-bit inreg
Matt Arsenault90c75932017-10-03 00:06:41 +0000981def : GCNPat<
Tom Stellard115a6152016-11-10 16:02:37 +0000982 (i32 (sext i16:$src)),
983 (S_SEXT_I32_I16 $src)
984>;
985
986
Valery Pykhtina34fb492016-08-30 15:20:31 +0000987//===----------------------------------------------------------------------===//
988// SOP2 Patterns
989//===----------------------------------------------------------------------===//
990
991// V_ADD_I32_e32/S_ADD_U32 produces carry in VCC/SCC. For the vector
992// case, the sgpr-copies pass will fix this to use the vector version.
Matt Arsenault90c75932017-10-03 00:06:41 +0000993def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000994 (i32 (addc i32:$src0, i32:$src1)),
995 (S_ADD_U32 $src0, $src1)
996>;
997
Tom Stellard115a6152016-11-10 16:02:37 +0000998// FIXME: We need to use COPY_TO_REGCLASS to work-around the fact that
999// REG_SEQUENCE patterns don't support instructions with multiple
1000// outputs.
Matt Arsenault90c75932017-10-03 00:06:41 +00001001def : GCNPat<
Tom Stellard115a6152016-11-10 16:02:37 +00001002 (i64 (zext i16:$src)),
1003 (REG_SEQUENCE SReg_64,
1004 (i32 (COPY_TO_REGCLASS (S_AND_B32 $src, (S_MOV_B32 (i32 0xffff))), SGPR_32)), sub0,
1005 (S_MOV_B32 (i32 0)), sub1)
1006>;
1007
Matt Arsenault90c75932017-10-03 00:06:41 +00001008def : GCNPat <
Tom Stellard115a6152016-11-10 16:02:37 +00001009 (i64 (sext i16:$src)),
1010 (REG_SEQUENCE SReg_64, (i32 (S_SEXT_I32_I16 $src)), sub0,
1011 (i32 (COPY_TO_REGCLASS (S_ASHR_I32 (i32 (S_SEXT_I32_I16 $src)), (S_MOV_B32 (i32 31))), SGPR_32)), sub1)
1012>;
1013
Matt Arsenault90c75932017-10-03 00:06:41 +00001014def : GCNPat<
Tom Stellard115a6152016-11-10 16:02:37 +00001015 (i32 (zext i16:$src)),
1016 (S_AND_B32 (S_MOV_B32 (i32 0xffff)), $src)
1017>;
1018
1019
1020
Valery Pykhtina34fb492016-08-30 15:20:31 +00001021//===----------------------------------------------------------------------===//
1022// SOPP Patterns
1023//===----------------------------------------------------------------------===//
1024
Matt Arsenault90c75932017-10-03 00:06:41 +00001025def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +00001026 (int_amdgcn_s_waitcnt i32:$simm16),
1027 (S_WAITCNT (as_i16imm $simm16))
1028>;
1029
Valery Pykhtina34fb492016-08-30 15:20:31 +00001030
1031//===----------------------------------------------------------------------===//
1032// Real target instructions, move this to the appropriate subtarget TD file
1033//===----------------------------------------------------------------------===//
1034
1035class Select_si<string opName> :
1036 SIMCInstr<opName, SIEncodingFamily.SI> {
1037 list<Predicate> AssemblerPredicates = [isSICI];
1038 string DecoderNamespace = "SICI";
1039}
1040
1041class SOP1_Real_si<bits<8> op, SOP1_Pseudo ps> :
1042 SOP1_Real<op, ps>,
1043 Select_si<ps.Mnemonic>;
1044
1045class SOP2_Real_si<bits<7> op, SOP2_Pseudo ps> :
1046 SOP2_Real<op, ps>,
1047 Select_si<ps.Mnemonic>;
1048
1049class SOPK_Real_si<bits<5> op, SOPK_Pseudo ps> :
1050 SOPK_Real32<op, ps>,
1051 Select_si<ps.Mnemonic>;
1052
1053def S_MOV_B32_si : SOP1_Real_si <0x03, S_MOV_B32>;
1054def S_MOV_B64_si : SOP1_Real_si <0x04, S_MOV_B64>;
1055def S_CMOV_B32_si : SOP1_Real_si <0x05, S_CMOV_B32>;
1056def S_CMOV_B64_si : SOP1_Real_si <0x06, S_CMOV_B64>;
1057def S_NOT_B32_si : SOP1_Real_si <0x07, S_NOT_B32>;
1058def S_NOT_B64_si : SOP1_Real_si <0x08, S_NOT_B64>;
1059def S_WQM_B32_si : SOP1_Real_si <0x09, S_WQM_B32>;
1060def S_WQM_B64_si : SOP1_Real_si <0x0a, S_WQM_B64>;
1061def S_BREV_B32_si : SOP1_Real_si <0x0b, S_BREV_B32>;
1062def S_BREV_B64_si : SOP1_Real_si <0x0c, S_BREV_B64>;
1063def S_BCNT0_I32_B32_si : SOP1_Real_si <0x0d, S_BCNT0_I32_B32>;
1064def S_BCNT0_I32_B64_si : SOP1_Real_si <0x0e, S_BCNT0_I32_B64>;
1065def S_BCNT1_I32_B32_si : SOP1_Real_si <0x0f, S_BCNT1_I32_B32>;
1066def S_BCNT1_I32_B64_si : SOP1_Real_si <0x10, S_BCNT1_I32_B64>;
1067def S_FF0_I32_B32_si : SOP1_Real_si <0x11, S_FF0_I32_B32>;
1068def S_FF0_I32_B64_si : SOP1_Real_si <0x12, S_FF0_I32_B64>;
1069def S_FF1_I32_B32_si : SOP1_Real_si <0x13, S_FF1_I32_B32>;
1070def S_FF1_I32_B64_si : SOP1_Real_si <0x14, S_FF1_I32_B64>;
1071def S_FLBIT_I32_B32_si : SOP1_Real_si <0x15, S_FLBIT_I32_B32>;
1072def S_FLBIT_I32_B64_si : SOP1_Real_si <0x16, S_FLBIT_I32_B64>;
1073def S_FLBIT_I32_si : SOP1_Real_si <0x17, S_FLBIT_I32>;
1074def S_FLBIT_I32_I64_si : SOP1_Real_si <0x18, S_FLBIT_I32_I64>;
1075def S_SEXT_I32_I8_si : SOP1_Real_si <0x19, S_SEXT_I32_I8>;
1076def S_SEXT_I32_I16_si : SOP1_Real_si <0x1a, S_SEXT_I32_I16>;
1077def S_BITSET0_B32_si : SOP1_Real_si <0x1b, S_BITSET0_B32>;
1078def S_BITSET0_B64_si : SOP1_Real_si <0x1c, S_BITSET0_B64>;
1079def S_BITSET1_B32_si : SOP1_Real_si <0x1d, S_BITSET1_B32>;
1080def S_BITSET1_B64_si : SOP1_Real_si <0x1e, S_BITSET1_B64>;
1081def S_GETPC_B64_si : SOP1_Real_si <0x1f, S_GETPC_B64>;
1082def S_SETPC_B64_si : SOP1_Real_si <0x20, S_SETPC_B64>;
1083def S_SWAPPC_B64_si : SOP1_Real_si <0x21, S_SWAPPC_B64>;
1084def S_RFE_B64_si : SOP1_Real_si <0x22, S_RFE_B64>;
1085def S_AND_SAVEEXEC_B64_si : SOP1_Real_si <0x24, S_AND_SAVEEXEC_B64>;
1086def S_OR_SAVEEXEC_B64_si : SOP1_Real_si <0x25, S_OR_SAVEEXEC_B64>;
1087def S_XOR_SAVEEXEC_B64_si : SOP1_Real_si <0x26, S_XOR_SAVEEXEC_B64>;
1088def S_ANDN2_SAVEEXEC_B64_si: SOP1_Real_si <0x27, S_ANDN2_SAVEEXEC_B64>;
1089def S_ORN2_SAVEEXEC_B64_si : SOP1_Real_si <0x28, S_ORN2_SAVEEXEC_B64>;
1090def S_NAND_SAVEEXEC_B64_si : SOP1_Real_si <0x29, S_NAND_SAVEEXEC_B64>;
1091def S_NOR_SAVEEXEC_B64_si : SOP1_Real_si <0x2a, S_NOR_SAVEEXEC_B64>;
1092def S_XNOR_SAVEEXEC_B64_si : SOP1_Real_si <0x2b, S_XNOR_SAVEEXEC_B64>;
1093def S_QUADMASK_B32_si : SOP1_Real_si <0x2c, S_QUADMASK_B32>;
1094def S_QUADMASK_B64_si : SOP1_Real_si <0x2d, S_QUADMASK_B64>;
1095def S_MOVRELS_B32_si : SOP1_Real_si <0x2e, S_MOVRELS_B32>;
1096def S_MOVRELS_B64_si : SOP1_Real_si <0x2f, S_MOVRELS_B64>;
1097def S_MOVRELD_B32_si : SOP1_Real_si <0x30, S_MOVRELD_B32>;
1098def S_MOVRELD_B64_si : SOP1_Real_si <0x31, S_MOVRELD_B64>;
1099def S_CBRANCH_JOIN_si : SOP1_Real_si <0x32, S_CBRANCH_JOIN>;
1100def S_MOV_REGRD_B32_si : SOP1_Real_si <0x33, S_MOV_REGRD_B32>;
1101def S_ABS_I32_si : SOP1_Real_si <0x34, S_ABS_I32>;
1102def S_MOV_FED_B32_si : SOP1_Real_si <0x35, S_MOV_FED_B32>;
1103
1104def S_ADD_U32_si : SOP2_Real_si <0x00, S_ADD_U32>;
1105def S_ADD_I32_si : SOP2_Real_si <0x02, S_ADD_I32>;
1106def S_SUB_U32_si : SOP2_Real_si <0x01, S_SUB_U32>;
1107def S_SUB_I32_si : SOP2_Real_si <0x03, S_SUB_I32>;
1108def S_ADDC_U32_si : SOP2_Real_si <0x04, S_ADDC_U32>;
1109def S_SUBB_U32_si : SOP2_Real_si <0x05, S_SUBB_U32>;
1110def S_MIN_I32_si : SOP2_Real_si <0x06, S_MIN_I32>;
1111def S_MIN_U32_si : SOP2_Real_si <0x07, S_MIN_U32>;
1112def S_MAX_I32_si : SOP2_Real_si <0x08, S_MAX_I32>;
1113def S_MAX_U32_si : SOP2_Real_si <0x09, S_MAX_U32>;
1114def S_CSELECT_B32_si : SOP2_Real_si <0x0a, S_CSELECT_B32>;
1115def S_CSELECT_B64_si : SOP2_Real_si <0x0b, S_CSELECT_B64>;
1116def S_AND_B32_si : SOP2_Real_si <0x0e, S_AND_B32>;
1117def S_AND_B64_si : SOP2_Real_si <0x0f, S_AND_B64>;
1118def S_OR_B32_si : SOP2_Real_si <0x10, S_OR_B32>;
1119def S_OR_B64_si : SOP2_Real_si <0x11, S_OR_B64>;
1120def S_XOR_B32_si : SOP2_Real_si <0x12, S_XOR_B32>;
1121def S_XOR_B64_si : SOP2_Real_si <0x13, S_XOR_B64>;
1122def S_ANDN2_B32_si : SOP2_Real_si <0x14, S_ANDN2_B32>;
1123def S_ANDN2_B64_si : SOP2_Real_si <0x15, S_ANDN2_B64>;
1124def S_ORN2_B32_si : SOP2_Real_si <0x16, S_ORN2_B32>;
1125def S_ORN2_B64_si : SOP2_Real_si <0x17, S_ORN2_B64>;
1126def S_NAND_B32_si : SOP2_Real_si <0x18, S_NAND_B32>;
1127def S_NAND_B64_si : SOP2_Real_si <0x19, S_NAND_B64>;
1128def S_NOR_B32_si : SOP2_Real_si <0x1a, S_NOR_B32>;
1129def S_NOR_B64_si : SOP2_Real_si <0x1b, S_NOR_B64>;
1130def S_XNOR_B32_si : SOP2_Real_si <0x1c, S_XNOR_B32>;
1131def S_XNOR_B64_si : SOP2_Real_si <0x1d, S_XNOR_B64>;
1132def S_LSHL_B32_si : SOP2_Real_si <0x1e, S_LSHL_B32>;
1133def S_LSHL_B64_si : SOP2_Real_si <0x1f, S_LSHL_B64>;
1134def S_LSHR_B32_si : SOP2_Real_si <0x20, S_LSHR_B32>;
1135def S_LSHR_B64_si : SOP2_Real_si <0x21, S_LSHR_B64>;
1136def S_ASHR_I32_si : SOP2_Real_si <0x22, S_ASHR_I32>;
1137def S_ASHR_I64_si : SOP2_Real_si <0x23, S_ASHR_I64>;
1138def S_BFM_B32_si : SOP2_Real_si <0x24, S_BFM_B32>;
1139def S_BFM_B64_si : SOP2_Real_si <0x25, S_BFM_B64>;
1140def S_MUL_I32_si : SOP2_Real_si <0x26, S_MUL_I32>;
1141def S_BFE_U32_si : SOP2_Real_si <0x27, S_BFE_U32>;
1142def S_BFE_I32_si : SOP2_Real_si <0x28, S_BFE_I32>;
1143def S_BFE_U64_si : SOP2_Real_si <0x29, S_BFE_U64>;
1144def S_BFE_I64_si : SOP2_Real_si <0x2a, S_BFE_I64>;
1145def S_CBRANCH_G_FORK_si : SOP2_Real_si <0x2b, S_CBRANCH_G_FORK>;
1146def S_ABSDIFF_I32_si : SOP2_Real_si <0x2c, S_ABSDIFF_I32>;
1147
1148def S_MOVK_I32_si : SOPK_Real_si <0x00, S_MOVK_I32>;
1149def S_CMOVK_I32_si : SOPK_Real_si <0x02, S_CMOVK_I32>;
1150def S_CMPK_EQ_I32_si : SOPK_Real_si <0x03, S_CMPK_EQ_I32>;
1151def S_CMPK_LG_I32_si : SOPK_Real_si <0x04, S_CMPK_LG_I32>;
1152def S_CMPK_GT_I32_si : SOPK_Real_si <0x05, S_CMPK_GT_I32>;
1153def S_CMPK_GE_I32_si : SOPK_Real_si <0x06, S_CMPK_GE_I32>;
1154def S_CMPK_LT_I32_si : SOPK_Real_si <0x07, S_CMPK_LT_I32>;
1155def S_CMPK_LE_I32_si : SOPK_Real_si <0x08, S_CMPK_LE_I32>;
1156def S_CMPK_EQ_U32_si : SOPK_Real_si <0x09, S_CMPK_EQ_U32>;
1157def S_CMPK_LG_U32_si : SOPK_Real_si <0x0a, S_CMPK_LG_U32>;
1158def S_CMPK_GT_U32_si : SOPK_Real_si <0x0b, S_CMPK_GT_U32>;
1159def S_CMPK_GE_U32_si : SOPK_Real_si <0x0c, S_CMPK_GE_U32>;
1160def S_CMPK_LT_U32_si : SOPK_Real_si <0x0d, S_CMPK_LT_U32>;
1161def S_CMPK_LE_U32_si : SOPK_Real_si <0x0e, S_CMPK_LE_U32>;
1162def S_ADDK_I32_si : SOPK_Real_si <0x0f, S_ADDK_I32>;
1163def S_MULK_I32_si : SOPK_Real_si <0x10, S_MULK_I32>;
1164def S_CBRANCH_I_FORK_si : SOPK_Real_si <0x11, S_CBRANCH_I_FORK>;
1165def S_GETREG_B32_si : SOPK_Real_si <0x12, S_GETREG_B32>;
1166def S_SETREG_B32_si : SOPK_Real_si <0x13, S_SETREG_B32>;
1167//def S_GETREG_REGRD_B32_si : SOPK_Real_si <0x14, S_GETREG_REGRD_B32>; // see pseudo for comments
1168def S_SETREG_IMM32_B32_si : SOPK_Real64<0x15, S_SETREG_IMM32_B32>,
1169 Select_si<S_SETREG_IMM32_B32.Mnemonic>;
1170
1171
1172class Select_vi<string opName> :
1173 SIMCInstr<opName, SIEncodingFamily.VI> {
1174 list<Predicate> AssemblerPredicates = [isVI];
1175 string DecoderNamespace = "VI";
1176}
1177
1178class SOP1_Real_vi<bits<8> op, SOP1_Pseudo ps> :
1179 SOP1_Real<op, ps>,
1180 Select_vi<ps.Mnemonic>;
1181
1182
1183class SOP2_Real_vi<bits<7> op, SOP2_Pseudo ps> :
1184 SOP2_Real<op, ps>,
1185 Select_vi<ps.Mnemonic>;
1186
1187class SOPK_Real_vi<bits<5> op, SOPK_Pseudo ps> :
1188 SOPK_Real32<op, ps>,
1189 Select_vi<ps.Mnemonic>;
1190
1191def S_MOV_B32_vi : SOP1_Real_vi <0x00, S_MOV_B32>;
1192def S_MOV_B64_vi : SOP1_Real_vi <0x01, S_MOV_B64>;
1193def S_CMOV_B32_vi : SOP1_Real_vi <0x02, S_CMOV_B32>;
1194def S_CMOV_B64_vi : SOP1_Real_vi <0x03, S_CMOV_B64>;
1195def S_NOT_B32_vi : SOP1_Real_vi <0x04, S_NOT_B32>;
1196def S_NOT_B64_vi : SOP1_Real_vi <0x05, S_NOT_B64>;
1197def S_WQM_B32_vi : SOP1_Real_vi <0x06, S_WQM_B32>;
1198def S_WQM_B64_vi : SOP1_Real_vi <0x07, S_WQM_B64>;
1199def S_BREV_B32_vi : SOP1_Real_vi <0x08, S_BREV_B32>;
1200def S_BREV_B64_vi : SOP1_Real_vi <0x09, S_BREV_B64>;
1201def S_BCNT0_I32_B32_vi : SOP1_Real_vi <0x0a, S_BCNT0_I32_B32>;
1202def S_BCNT0_I32_B64_vi : SOP1_Real_vi <0x0b, S_BCNT0_I32_B64>;
1203def S_BCNT1_I32_B32_vi : SOP1_Real_vi <0x0c, S_BCNT1_I32_B32>;
1204def S_BCNT1_I32_B64_vi : SOP1_Real_vi <0x0d, S_BCNT1_I32_B64>;
1205def S_FF0_I32_B32_vi : SOP1_Real_vi <0x0e, S_FF0_I32_B32>;
1206def S_FF0_I32_B64_vi : SOP1_Real_vi <0x0f, S_FF0_I32_B64>;
1207def S_FF1_I32_B32_vi : SOP1_Real_vi <0x10, S_FF1_I32_B32>;
1208def S_FF1_I32_B64_vi : SOP1_Real_vi <0x11, S_FF1_I32_B64>;
1209def S_FLBIT_I32_B32_vi : SOP1_Real_vi <0x12, S_FLBIT_I32_B32>;
1210def S_FLBIT_I32_B64_vi : SOP1_Real_vi <0x13, S_FLBIT_I32_B64>;
1211def S_FLBIT_I32_vi : SOP1_Real_vi <0x14, S_FLBIT_I32>;
1212def S_FLBIT_I32_I64_vi : SOP1_Real_vi <0x15, S_FLBIT_I32_I64>;
1213def S_SEXT_I32_I8_vi : SOP1_Real_vi <0x16, S_SEXT_I32_I8>;
1214def S_SEXT_I32_I16_vi : SOP1_Real_vi <0x17, S_SEXT_I32_I16>;
1215def S_BITSET0_B32_vi : SOP1_Real_vi <0x18, S_BITSET0_B32>;
1216def S_BITSET0_B64_vi : SOP1_Real_vi <0x19, S_BITSET0_B64>;
1217def S_BITSET1_B32_vi : SOP1_Real_vi <0x1a, S_BITSET1_B32>;
1218def S_BITSET1_B64_vi : SOP1_Real_vi <0x1b, S_BITSET1_B64>;
1219def S_GETPC_B64_vi : SOP1_Real_vi <0x1c, S_GETPC_B64>;
1220def S_SETPC_B64_vi : SOP1_Real_vi <0x1d, S_SETPC_B64>;
1221def S_SWAPPC_B64_vi : SOP1_Real_vi <0x1e, S_SWAPPC_B64>;
1222def S_RFE_B64_vi : SOP1_Real_vi <0x1f, S_RFE_B64>;
1223def S_AND_SAVEEXEC_B64_vi : SOP1_Real_vi <0x20, S_AND_SAVEEXEC_B64>;
1224def S_OR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x21, S_OR_SAVEEXEC_B64>;
1225def S_XOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x22, S_XOR_SAVEEXEC_B64>;
1226def S_ANDN2_SAVEEXEC_B64_vi: SOP1_Real_vi <0x23, S_ANDN2_SAVEEXEC_B64>;
1227def S_ORN2_SAVEEXEC_B64_vi : SOP1_Real_vi <0x24, S_ORN2_SAVEEXEC_B64>;
1228def S_NAND_SAVEEXEC_B64_vi : SOP1_Real_vi <0x25, S_NAND_SAVEEXEC_B64>;
1229def S_NOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x26, S_NOR_SAVEEXEC_B64>;
1230def S_XNOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x27, S_XNOR_SAVEEXEC_B64>;
1231def S_QUADMASK_B32_vi : SOP1_Real_vi <0x28, S_QUADMASK_B32>;
1232def S_QUADMASK_B64_vi : SOP1_Real_vi <0x29, S_QUADMASK_B64>;
1233def S_MOVRELS_B32_vi : SOP1_Real_vi <0x2a, S_MOVRELS_B32>;
1234def S_MOVRELS_B64_vi : SOP1_Real_vi <0x2b, S_MOVRELS_B64>;
1235def S_MOVRELD_B32_vi : SOP1_Real_vi <0x2c, S_MOVRELD_B32>;
1236def S_MOVRELD_B64_vi : SOP1_Real_vi <0x2d, S_MOVRELD_B64>;
1237def S_CBRANCH_JOIN_vi : SOP1_Real_vi <0x2e, S_CBRANCH_JOIN>;
1238def S_MOV_REGRD_B32_vi : SOP1_Real_vi <0x2f, S_MOV_REGRD_B32>;
1239def S_ABS_I32_vi : SOP1_Real_vi <0x30, S_ABS_I32>;
1240def S_MOV_FED_B32_vi : SOP1_Real_vi <0x31, S_MOV_FED_B32>;
Matt Arsenaultcc88ce32016-10-12 18:00:51 +00001241def S_SET_GPR_IDX_IDX_vi : SOP1_Real_vi <0x32, S_SET_GPR_IDX_IDX>;
Valery Pykhtina34fb492016-08-30 15:20:31 +00001242
1243def S_ADD_U32_vi : SOP2_Real_vi <0x00, S_ADD_U32>;
1244def S_ADD_I32_vi : SOP2_Real_vi <0x02, S_ADD_I32>;
1245def S_SUB_U32_vi : SOP2_Real_vi <0x01, S_SUB_U32>;
1246def S_SUB_I32_vi : SOP2_Real_vi <0x03, S_SUB_I32>;
1247def S_ADDC_U32_vi : SOP2_Real_vi <0x04, S_ADDC_U32>;
1248def S_SUBB_U32_vi : SOP2_Real_vi <0x05, S_SUBB_U32>;
1249def S_MIN_I32_vi : SOP2_Real_vi <0x06, S_MIN_I32>;
1250def S_MIN_U32_vi : SOP2_Real_vi <0x07, S_MIN_U32>;
1251def S_MAX_I32_vi : SOP2_Real_vi <0x08, S_MAX_I32>;
1252def S_MAX_U32_vi : SOP2_Real_vi <0x09, S_MAX_U32>;
1253def S_CSELECT_B32_vi : SOP2_Real_vi <0x0a, S_CSELECT_B32>;
1254def S_CSELECT_B64_vi : SOP2_Real_vi <0x0b, S_CSELECT_B64>;
1255def S_AND_B32_vi : SOP2_Real_vi <0x0c, S_AND_B32>;
1256def S_AND_B64_vi : SOP2_Real_vi <0x0d, S_AND_B64>;
1257def S_OR_B32_vi : SOP2_Real_vi <0x0e, S_OR_B32>;
1258def S_OR_B64_vi : SOP2_Real_vi <0x0f, S_OR_B64>;
1259def S_XOR_B32_vi : SOP2_Real_vi <0x10, S_XOR_B32>;
1260def S_XOR_B64_vi : SOP2_Real_vi <0x11, S_XOR_B64>;
1261def S_ANDN2_B32_vi : SOP2_Real_vi <0x12, S_ANDN2_B32>;
1262def S_ANDN2_B64_vi : SOP2_Real_vi <0x13, S_ANDN2_B64>;
1263def S_ORN2_B32_vi : SOP2_Real_vi <0x14, S_ORN2_B32>;
1264def S_ORN2_B64_vi : SOP2_Real_vi <0x15, S_ORN2_B64>;
1265def S_NAND_B32_vi : SOP2_Real_vi <0x16, S_NAND_B32>;
1266def S_NAND_B64_vi : SOP2_Real_vi <0x17, S_NAND_B64>;
1267def S_NOR_B32_vi : SOP2_Real_vi <0x18, S_NOR_B32>;
1268def S_NOR_B64_vi : SOP2_Real_vi <0x19, S_NOR_B64>;
1269def S_XNOR_B32_vi : SOP2_Real_vi <0x1a, S_XNOR_B32>;
1270def S_XNOR_B64_vi : SOP2_Real_vi <0x1b, S_XNOR_B64>;
1271def S_LSHL_B32_vi : SOP2_Real_vi <0x1c, S_LSHL_B32>;
1272def S_LSHL_B64_vi : SOP2_Real_vi <0x1d, S_LSHL_B64>;
1273def S_LSHR_B32_vi : SOP2_Real_vi <0x1e, S_LSHR_B32>;
1274def S_LSHR_B64_vi : SOP2_Real_vi <0x1f, S_LSHR_B64>;
1275def S_ASHR_I32_vi : SOP2_Real_vi <0x20, S_ASHR_I32>;
1276def S_ASHR_I64_vi : SOP2_Real_vi <0x21, S_ASHR_I64>;
1277def S_BFM_B32_vi : SOP2_Real_vi <0x22, S_BFM_B32>;
1278def S_BFM_B64_vi : SOP2_Real_vi <0x23, S_BFM_B64>;
1279def S_MUL_I32_vi : SOP2_Real_vi <0x24, S_MUL_I32>;
1280def S_BFE_U32_vi : SOP2_Real_vi <0x25, S_BFE_U32>;
1281def S_BFE_I32_vi : SOP2_Real_vi <0x26, S_BFE_I32>;
1282def S_BFE_U64_vi : SOP2_Real_vi <0x27, S_BFE_U64>;
1283def S_BFE_I64_vi : SOP2_Real_vi <0x28, S_BFE_I64>;
1284def S_CBRANCH_G_FORK_vi : SOP2_Real_vi <0x29, S_CBRANCH_G_FORK>;
1285def S_ABSDIFF_I32_vi : SOP2_Real_vi <0x2a, S_ABSDIFF_I32>;
Matt Arsenault9be7b0d2017-02-27 18:49:11 +00001286def S_PACK_LL_B32_B16_vi : SOP2_Real_vi <0x32, S_PACK_LL_B32_B16>;
1287def S_PACK_LH_B32_B16_vi : SOP2_Real_vi <0x33, S_PACK_LH_B32_B16>;
1288def S_PACK_HH_B32_B16_vi : SOP2_Real_vi <0x34, S_PACK_HH_B32_B16>;
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +00001289def S_RFE_RESTORE_B64_vi : SOP2_Real_vi <0x2b, S_RFE_RESTORE_B64>;
Valery Pykhtina34fb492016-08-30 15:20:31 +00001290
1291def S_MOVK_I32_vi : SOPK_Real_vi <0x00, S_MOVK_I32>;
1292def S_CMOVK_I32_vi : SOPK_Real_vi <0x01, S_CMOVK_I32>;
1293def S_CMPK_EQ_I32_vi : SOPK_Real_vi <0x02, S_CMPK_EQ_I32>;
1294def S_CMPK_LG_I32_vi : SOPK_Real_vi <0x03, S_CMPK_LG_I32>;
1295def S_CMPK_GT_I32_vi : SOPK_Real_vi <0x04, S_CMPK_GT_I32>;
1296def S_CMPK_GE_I32_vi : SOPK_Real_vi <0x05, S_CMPK_GE_I32>;
1297def S_CMPK_LT_I32_vi : SOPK_Real_vi <0x06, S_CMPK_LT_I32>;
1298def S_CMPK_LE_I32_vi : SOPK_Real_vi <0x07, S_CMPK_LE_I32>;
1299def S_CMPK_EQ_U32_vi : SOPK_Real_vi <0x08, S_CMPK_EQ_U32>;
1300def S_CMPK_LG_U32_vi : SOPK_Real_vi <0x09, S_CMPK_LG_U32>;
1301def S_CMPK_GT_U32_vi : SOPK_Real_vi <0x0A, S_CMPK_GT_U32>;
1302def S_CMPK_GE_U32_vi : SOPK_Real_vi <0x0B, S_CMPK_GE_U32>;
1303def S_CMPK_LT_U32_vi : SOPK_Real_vi <0x0C, S_CMPK_LT_U32>;
1304def S_CMPK_LE_U32_vi : SOPK_Real_vi <0x0D, S_CMPK_LE_U32>;
1305def S_ADDK_I32_vi : SOPK_Real_vi <0x0E, S_ADDK_I32>;
1306def S_MULK_I32_vi : SOPK_Real_vi <0x0F, S_MULK_I32>;
1307def S_CBRANCH_I_FORK_vi : SOPK_Real_vi <0x10, S_CBRANCH_I_FORK>;
1308def S_GETREG_B32_vi : SOPK_Real_vi <0x11, S_GETREG_B32>;
1309def S_SETREG_B32_vi : SOPK_Real_vi <0x12, S_SETREG_B32>;
1310//def S_GETREG_REGRD_B32_vi : SOPK_Real_vi <0x13, S_GETREG_REGRD_B32>; // see pseudo for comments
1311def S_SETREG_IMM32_B32_vi : SOPK_Real64<0x14, S_SETREG_IMM32_B32>,
Tom Stellard2add8a12016-09-06 20:00:26 +00001312 Select_vi<S_SETREG_IMM32_B32.Mnemonic>;