blob: 02a95a4b6f24952701a4153e7e52f7f7704bf21d [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">;
Marek Olsak2114fc32017-10-24 10:26:59 +0000142 def S_WQM_B64 : SOP1_64 <"s_wqm_b64",
143 [(set i1:$sdst, (int_amdgcn_wqm_vote i1:$src0))]
144 >;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000145} // End Defs = [SCC]
146
147
148def S_BREV_B32 : SOP1_32 <"s_brev_b32",
149 [(set i32:$sdst, (bitreverse i32:$src0))]
150>;
151def S_BREV_B64 : SOP1_64 <"s_brev_b64">;
152
153let Defs = [SCC] in {
154def S_BCNT0_I32_B32 : SOP1_32 <"s_bcnt0_i32_b32">;
155def S_BCNT0_I32_B64 : SOP1_32_64 <"s_bcnt0_i32_b64">;
156def S_BCNT1_I32_B32 : SOP1_32 <"s_bcnt1_i32_b32",
157 [(set i32:$sdst, (ctpop i32:$src0))]
158>;
159def S_BCNT1_I32_B64 : SOP1_32_64 <"s_bcnt1_i32_b64">;
160} // End Defs = [SCC]
161
162def S_FF0_I32_B32 : SOP1_32 <"s_ff0_i32_b32">;
163def S_FF0_I32_B64 : SOP1_32_64 <"s_ff0_i32_b64">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000164def S_FF1_I32_B64 : SOP1_32_64 <"s_ff1_i32_b64">;
165
Wei Ding5676aca2017-10-12 19:37:14 +0000166def S_FF1_I32_B32 : SOP1_32 <"s_ff1_i32_b32",
167 [(set i32:$sdst, (AMDGPUffbl_b32 i32:$src0))]
168>;
169
Valery Pykhtina34fb492016-08-30 15:20:31 +0000170def S_FLBIT_I32_B32 : SOP1_32 <"s_flbit_i32_b32",
171 [(set i32:$sdst, (AMDGPUffbh_u32 i32:$src0))]
172>;
173
174def S_FLBIT_I32_B64 : SOP1_32_64 <"s_flbit_i32_b64">;
175def S_FLBIT_I32 : SOP1_32 <"s_flbit_i32",
176 [(set i32:$sdst, (AMDGPUffbh_i32 i32:$src0))]
177>;
178def S_FLBIT_I32_I64 : SOP1_32_64 <"s_flbit_i32_i64">;
179def S_SEXT_I32_I8 : SOP1_32 <"s_sext_i32_i8",
180 [(set i32:$sdst, (sext_inreg i32:$src0, i8))]
181>;
182def S_SEXT_I32_I16 : SOP1_32 <"s_sext_i32_i16",
183 [(set i32:$sdst, (sext_inreg i32:$src0, i16))]
184>;
185
186def S_BITSET0_B32 : SOP1_32 <"s_bitset0_b32">;
187def S_BITSET0_B64 : SOP1_64_32 <"s_bitset0_b64">;
188def S_BITSET1_B32 : SOP1_32 <"s_bitset1_b32">;
189def S_BITSET1_B64 : SOP1_64_32 <"s_bitset1_b64">;
Konstantin Zhuravlyovb2ff8df2017-05-26 20:38:26 +0000190def S_GETPC_B64 : SOP1_64_0 <"s_getpc_b64",
191 [(set i64:$sdst, (int_amdgcn_s_getpc))]
192>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000193
Matt Arsenault2b1f9aa2017-05-17 21:56:25 +0000194let isTerminator = 1, isBarrier = 1, SchedRW = [WriteBranch] in {
195
196let isBranch = 1, isIndirectBranch = 1 in {
Valery Pykhtina34fb492016-08-30 15:20:31 +0000197def S_SETPC_B64 : SOP1_1 <"s_setpc_b64">;
Matt Arsenault2b1f9aa2017-05-17 21:56:25 +0000198} // End isBranch = 1, isIndirectBranch = 1
199
200let isReturn = 1 in {
201// Define variant marked as return rather than branch.
202def S_SETPC_B64_return : SOP1_1<"", [(AMDGPUret_flag i64:$src0)]>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000203}
Matt Arsenault2b1f9aa2017-05-17 21:56:25 +0000204} // End isTerminator = 1, isBarrier = 1
205
206let isCall = 1 in {
207def S_SWAPPC_B64 : SOP1_64 <"s_swappc_b64"
208>;
209}
210
Valery Pykhtina34fb492016-08-30 15:20:31 +0000211def S_RFE_B64 : SOP1_1 <"s_rfe_b64">;
212
213let hasSideEffects = 1, Uses = [EXEC], Defs = [EXEC, SCC] in {
214
215def S_AND_SAVEEXEC_B64 : SOP1_64 <"s_and_saveexec_b64">;
216def S_OR_SAVEEXEC_B64 : SOP1_64 <"s_or_saveexec_b64">;
217def S_XOR_SAVEEXEC_B64 : SOP1_64 <"s_xor_saveexec_b64">;
218def S_ANDN2_SAVEEXEC_B64 : SOP1_64 <"s_andn2_saveexec_b64">;
219def S_ORN2_SAVEEXEC_B64 : SOP1_64 <"s_orn2_saveexec_b64">;
220def S_NAND_SAVEEXEC_B64 : SOP1_64 <"s_nand_saveexec_b64">;
221def S_NOR_SAVEEXEC_B64 : SOP1_64 <"s_nor_saveexec_b64">;
222def S_XNOR_SAVEEXEC_B64 : SOP1_64 <"s_xnor_saveexec_b64">;
223
224} // End hasSideEffects = 1, Uses = [EXEC], Defs = [EXEC, SCC]
225
226def S_QUADMASK_B32 : SOP1_32 <"s_quadmask_b32">;
227def S_QUADMASK_B64 : SOP1_64 <"s_quadmask_b64">;
228
229let Uses = [M0] in {
230def S_MOVRELS_B32 : SOP1_32 <"s_movrels_b32">;
231def S_MOVRELS_B64 : SOP1_64 <"s_movrels_b64">;
232def S_MOVRELD_B32 : SOP1_32 <"s_movreld_b32">;
233def S_MOVRELD_B64 : SOP1_64 <"s_movreld_b64">;
234} // End Uses = [M0]
235
Dmitry Preobrazhensky12194e92017-04-12 12:40:19 +0000236def S_CBRANCH_JOIN : SOP1_0_32R <"s_cbranch_join">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000237def S_MOV_REGRD_B32 : SOP1_32 <"s_mov_regrd_b32">;
238let Defs = [SCC] in {
239def S_ABS_I32 : SOP1_32 <"s_abs_i32">;
240} // End Defs = [SCC]
241def S_MOV_FED_B32 : SOP1_32 <"s_mov_fed_b32">;
242
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000243let SubtargetPredicate = HasVGPRIndexMode in {
244def S_SET_GPR_IDX_IDX : SOP1_0_32<"s_set_gpr_idx_idx"> {
245 let Uses = [M0];
246 let Defs = [M0];
247}
248}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000249
250//===----------------------------------------------------------------------===//
251// SOP2 Instructions
252//===----------------------------------------------------------------------===//
253
254class SOP2_Pseudo<string opName, dag outs, dag ins,
255 string asmOps, list<dag> pattern=[]> :
256 InstSI<outs, ins, "", pattern>,
257 SIMCInstr<opName, SIEncodingFamily.NONE> {
258 let isPseudo = 1;
259 let isCodeGenOnly = 1;
260 let SubtargetPredicate = isGCN;
261 let mayLoad = 0;
262 let mayStore = 0;
263 let hasSideEffects = 0;
264 let SALU = 1;
265 let SOP2 = 1;
266 let SchedRW = [WriteSALU];
267 let UseNamedOperandTable = 1;
268
269 string Mnemonic = opName;
270 string AsmOperands = asmOps;
271
272 bits<1> has_sdst = 1;
273
274 // Pseudo instructions have no encodings, but adding this field here allows
275 // us to do:
276 // let sdst = xxx in {
277 // for multiclasses that include both real and pseudo instructions.
278 // field bits<7> sdst = 0;
279 // let Size = 4; // Do we need size here?
280}
281
282class SOP2_Real<bits<7> op, SOP2_Pseudo ps> :
283 InstSI <ps.OutOperandList, ps.InOperandList,
284 ps.Mnemonic # " " # ps.AsmOperands, []>,
285 Enc32 {
286 let isPseudo = 0;
287 let isCodeGenOnly = 0;
288
289 // copy relevant pseudo op flags
290 let SubtargetPredicate = ps.SubtargetPredicate;
291 let AsmMatchConverter = ps.AsmMatchConverter;
292
293 // encoding
294 bits<7> sdst;
295 bits<8> src0;
296 bits<8> src1;
297
298 let Inst{7-0} = src0;
299 let Inst{15-8} = src1;
300 let Inst{22-16} = !if(ps.has_sdst, sdst, ?);
301 let Inst{29-23} = op;
302 let Inst{31-30} = 0x2; // encoding
303}
304
305
306class SOP2_32 <string opName, list<dag> pattern=[]> : SOP2_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000307 opName, (outs SReg_32:$sdst), (ins SSrc_b32:$src0, SSrc_b32:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000308 "$sdst, $src0, $src1", pattern
309>;
310
311class SOP2_64 <string opName, list<dag> pattern=[]> : SOP2_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000312 opName, (outs SReg_64:$sdst), (ins SSrc_b64:$src0, SSrc_b64:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000313 "$sdst, $src0, $src1", pattern
314>;
315
316class SOP2_64_32 <string opName, list<dag> pattern=[]> : SOP2_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000317 opName, (outs SReg_64:$sdst), (ins SSrc_b64:$src0, SSrc_b32:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000318 "$sdst, $src0, $src1", pattern
319>;
320
321class SOP2_64_32_32 <string opName, list<dag> pattern=[]> : SOP2_Pseudo <
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000322 opName, (outs SReg_64:$sdst), (ins SSrc_b32:$src0, SSrc_b32:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000323 "$sdst, $src0, $src1", pattern
324>;
325
326let Defs = [SCC] in { // Carry out goes to SCC
327let isCommutable = 1 in {
328def S_ADD_U32 : SOP2_32 <"s_add_u32">;
329def S_ADD_I32 : SOP2_32 <"s_add_i32",
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000330 [(set i32:$sdst, (add SSrc_b32:$src0, SSrc_b32:$src1))]
Valery Pykhtina34fb492016-08-30 15:20:31 +0000331>;
332} // End isCommutable = 1
333
334def S_SUB_U32 : SOP2_32 <"s_sub_u32">;
335def S_SUB_I32 : SOP2_32 <"s_sub_i32",
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000336 [(set i32:$sdst, (sub SSrc_b32:$src0, SSrc_b32:$src1))]
Valery Pykhtina34fb492016-08-30 15:20:31 +0000337>;
338
339let Uses = [SCC] in { // Carry in comes from SCC
340let isCommutable = 1 in {
341def S_ADDC_U32 : SOP2_32 <"s_addc_u32",
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000342 [(set i32:$sdst, (adde (i32 SSrc_b32:$src0), (i32 SSrc_b32:$src1)))]>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000343} // End isCommutable = 1
344
345def S_SUBB_U32 : SOP2_32 <"s_subb_u32",
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000346 [(set i32:$sdst, (sube (i32 SSrc_b32:$src0), (i32 SSrc_b32:$src1)))]>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000347} // End Uses = [SCC]
348
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000349
350let isCommutable = 1 in {
Valery Pykhtina34fb492016-08-30 15:20:31 +0000351def S_MIN_I32 : SOP2_32 <"s_min_i32",
352 [(set i32:$sdst, (smin i32:$src0, i32:$src1))]
353>;
354def S_MIN_U32 : SOP2_32 <"s_min_u32",
355 [(set i32:$sdst, (umin i32:$src0, i32:$src1))]
356>;
357def S_MAX_I32 : SOP2_32 <"s_max_i32",
358 [(set i32:$sdst, (smax i32:$src0, i32:$src1))]
359>;
360def S_MAX_U32 : SOP2_32 <"s_max_u32",
361 [(set i32:$sdst, (umax i32:$src0, i32:$src1))]
362>;
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000363} // End isCommutable = 1
Valery Pykhtina34fb492016-08-30 15:20:31 +0000364} // End Defs = [SCC]
365
366
367let Uses = [SCC] in {
368 def S_CSELECT_B32 : SOP2_32 <"s_cselect_b32">;
369 def S_CSELECT_B64 : SOP2_64 <"s_cselect_b64">;
370} // End Uses = [SCC]
371
372let Defs = [SCC] in {
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000373let isCommutable = 1 in {
Valery Pykhtina34fb492016-08-30 15:20:31 +0000374def S_AND_B32 : SOP2_32 <"s_and_b32",
375 [(set i32:$sdst, (and i32:$src0, i32:$src1))]
376>;
377
378def S_AND_B64 : SOP2_64 <"s_and_b64",
379 [(set i64:$sdst, (and i64:$src0, i64:$src1))]
380>;
381
382def S_OR_B32 : SOP2_32 <"s_or_b32",
383 [(set i32:$sdst, (or i32:$src0, i32:$src1))]
384>;
385
386def S_OR_B64 : SOP2_64 <"s_or_b64",
387 [(set i64:$sdst, (or i64:$src0, i64:$src1))]
388>;
389
390def S_XOR_B32 : SOP2_32 <"s_xor_b32",
391 [(set i32:$sdst, (xor i32:$src0, i32:$src1))]
392>;
393
394def S_XOR_B64 : SOP2_64 <"s_xor_b64",
395 [(set i64:$sdst, (xor i64:$src0, i64:$src1))]
396>;
Konstantin Zhuravlyovca8946a2017-09-18 21:22:45 +0000397
398def S_XNOR_B32 : SOP2_32 <"s_xnor_b32",
399 [(set i32:$sdst, (not (xor_oneuse i32:$src0, i32:$src1)))]
400>;
401
402def S_XNOR_B64 : SOP2_64 <"s_xnor_b64",
403 [(set i64:$sdst, (not (xor_oneuse i64:$src0, i64:$src1)))]
404>;
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000405} // End isCommutable = 1
406
Valery Pykhtina34fb492016-08-30 15:20:31 +0000407def S_ANDN2_B32 : SOP2_32 <"s_andn2_b32">;
408def S_ANDN2_B64 : SOP2_64 <"s_andn2_b64">;
409def S_ORN2_B32 : SOP2_32 <"s_orn2_b32">;
410def S_ORN2_B64 : SOP2_64 <"s_orn2_b64">;
411def S_NAND_B32 : SOP2_32 <"s_nand_b32">;
412def S_NAND_B64 : SOP2_64 <"s_nand_b64">;
413def S_NOR_B32 : SOP2_32 <"s_nor_b32">;
414def S_NOR_B64 : SOP2_64 <"s_nor_b64">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000415} // End Defs = [SCC]
416
417// Use added complexity so these patterns are preferred to the VALU patterns.
418let AddedComplexity = 1 in {
419
420let Defs = [SCC] in {
421def S_LSHL_B32 : SOP2_32 <"s_lshl_b32",
422 [(set i32:$sdst, (shl i32:$src0, i32:$src1))]
423>;
424def S_LSHL_B64 : SOP2_64_32 <"s_lshl_b64",
425 [(set i64:$sdst, (shl i64:$src0, i32:$src1))]
426>;
427def S_LSHR_B32 : SOP2_32 <"s_lshr_b32",
428 [(set i32:$sdst, (srl i32:$src0, i32:$src1))]
429>;
430def S_LSHR_B64 : SOP2_64_32 <"s_lshr_b64",
431 [(set i64:$sdst, (srl i64:$src0, i32:$src1))]
432>;
433def S_ASHR_I32 : SOP2_32 <"s_ashr_i32",
434 [(set i32:$sdst, (sra i32:$src0, i32:$src1))]
435>;
436def S_ASHR_I64 : SOP2_64_32 <"s_ashr_i64",
437 [(set i64:$sdst, (sra i64:$src0, i32:$src1))]
438>;
439} // End Defs = [SCC]
440
441def S_BFM_B32 : SOP2_32 <"s_bfm_b32",
442 [(set i32:$sdst, (AMDGPUbfm i32:$src0, i32:$src1))]>;
443def S_BFM_B64 : SOP2_64_32_32 <"s_bfm_b64">;
444def S_MUL_I32 : SOP2_32 <"s_mul_i32",
Matt Arsenault479ba3a2016-09-07 06:25:55 +0000445 [(set i32:$sdst, (mul i32:$src0, i32:$src1))]> {
446 let isCommutable = 1;
447}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000448
449} // End AddedComplexity = 1
450
451let Defs = [SCC] in {
452def S_BFE_U32 : SOP2_32 <"s_bfe_u32">;
453def S_BFE_I32 : SOP2_32 <"s_bfe_i32">;
454def S_BFE_U64 : SOP2_64_32 <"s_bfe_u64">;
455def S_BFE_I64 : SOP2_64_32 <"s_bfe_i64">;
456} // End Defs = [SCC]
457
458def S_CBRANCH_G_FORK : SOP2_Pseudo <
459 "s_cbranch_g_fork", (outs),
Dmitry Preobrazhensky57148602017-04-14 11:52:26 +0000460 (ins SCSrc_b64:$src0, SCSrc_b64:$src1),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000461 "$src0, $src1"
462> {
463 let has_sdst = 0;
464}
465
466let Defs = [SCC] in {
467def S_ABSDIFF_I32 : SOP2_32 <"s_absdiff_i32">;
468} // End Defs = [SCC]
469
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000470let SubtargetPredicate = isVI in {
471 def S_RFE_RESTORE_B64 : SOP2_Pseudo <
472 "s_rfe_restore_b64", (outs),
473 (ins SSrc_b64:$src0, SSrc_b32:$src1),
474 "$src0, $src1"
475 > {
476 let hasSideEffects = 1;
477 let has_sdst = 0;
478 }
479}
480
Matt Arsenault9be7b0d2017-02-27 18:49:11 +0000481let SubtargetPredicate = isGFX9 in {
482 def S_PACK_LL_B32_B16 : SOP2_32<"s_pack_ll_b32_b16">;
483 def S_PACK_LH_B32_B16 : SOP2_32<"s_pack_lh_b32_b16">;
484 def S_PACK_HH_B32_B16 : SOP2_32<"s_pack_hh_b32_b16">;
485}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000486
487//===----------------------------------------------------------------------===//
488// SOPK Instructions
489//===----------------------------------------------------------------------===//
490
491class SOPK_Pseudo <string opName, dag outs, dag ins,
492 string asmOps, list<dag> pattern=[]> :
493 InstSI <outs, ins, "", pattern>,
494 SIMCInstr<opName, SIEncodingFamily.NONE> {
495 let isPseudo = 1;
496 let isCodeGenOnly = 1;
497 let SubtargetPredicate = isGCN;
498 let mayLoad = 0;
499 let mayStore = 0;
500 let hasSideEffects = 0;
501 let SALU = 1;
502 let SOPK = 1;
503 let SchedRW = [WriteSALU];
504 let UseNamedOperandTable = 1;
505 string Mnemonic = opName;
506 string AsmOperands = asmOps;
507
508 bits<1> has_sdst = 1;
509}
510
511class SOPK_Real<bits<5> op, SOPK_Pseudo ps> :
512 InstSI <ps.OutOperandList, ps.InOperandList,
513 ps.Mnemonic # " " # ps.AsmOperands, []> {
514 let isPseudo = 0;
515 let isCodeGenOnly = 0;
516
517 // copy relevant pseudo op flags
518 let SubtargetPredicate = ps.SubtargetPredicate;
519 let AsmMatchConverter = ps.AsmMatchConverter;
520 let DisableEncoding = ps.DisableEncoding;
521 let Constraints = ps.Constraints;
522
523 // encoding
524 bits<7> sdst;
525 bits<16> simm16;
526 bits<32> imm;
527}
528
529class SOPK_Real32<bits<5> op, SOPK_Pseudo ps> :
530 SOPK_Real <op, ps>,
531 Enc32 {
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}
537
538class SOPK_Real64<bits<5> op, SOPK_Pseudo ps> :
539 SOPK_Real<op, ps>,
540 Enc64 {
541 let Inst{15-0} = simm16;
542 let Inst{22-16} = !if(ps.has_sdst, sdst, ?);
543 let Inst{27-23} = op;
544 let Inst{31-28} = 0xb; //encoding
545 let Inst{63-32} = imm;
546}
547
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000548class SOPKInstTable <bit is_sopk, string cmpOp = ""> {
549 bit IsSOPK = is_sopk;
550 string BaseCmpOp = cmpOp;
551}
552
Valery Pykhtina34fb492016-08-30 15:20:31 +0000553class SOPK_32 <string opName, list<dag> pattern=[]> : SOPK_Pseudo <
554 opName,
555 (outs SReg_32:$sdst),
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000556 (ins s16imm:$simm16),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000557 "$sdst, $simm16",
558 pattern>;
559
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000560class SOPK_SCC <string opName, string base_op, bit isSignExt> : SOPK_Pseudo <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000561 opName,
562 (outs),
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000563 !if(isSignExt,
564 (ins SReg_32:$sdst, s16imm:$simm16),
565 (ins SReg_32:$sdst, u16imm:$simm16)),
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000566 "$sdst, $simm16", []>,
567 SOPKInstTable<1, base_op>{
Valery Pykhtina34fb492016-08-30 15:20:31 +0000568 let Defs = [SCC];
569}
570
571class SOPK_32TIE <string opName, list<dag> pattern=[]> : SOPK_Pseudo <
572 opName,
573 (outs SReg_32:$sdst),
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000574 (ins SReg_32:$src0, s16imm:$simm16),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000575 "$sdst, $simm16",
576 pattern
577>;
578
579let isReMaterializable = 1, isMoveImm = 1 in {
580def S_MOVK_I32 : SOPK_32 <"s_movk_i32">;
581} // End isReMaterializable = 1
582let Uses = [SCC] in {
583def S_CMOVK_I32 : SOPK_32 <"s_cmovk_i32">;
584}
585
586let isCompare = 1 in {
587
588// This instruction is disabled for now until we can figure out how to teach
589// the instruction selector to correctly use the S_CMP* vs V_CMP*
590// instructions.
591//
592// When this instruction is enabled the code generator sometimes produces this
593// invalid sequence:
594//
595// SCC = S_CMPK_EQ_I32 SGPR0, imm
596// VCC = COPY SCC
597// VGPR0 = V_CNDMASK VCC, VGPR0, VGPR1
598//
599// def S_CMPK_EQ_I32 : SOPK_SCC <"s_cmpk_eq_i32",
600// [(set i1:$dst, (setcc i32:$src0, imm:$src1, SETEQ))]
601// >;
602
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000603def S_CMPK_EQ_I32 : SOPK_SCC <"s_cmpk_eq_i32", "s_cmp_eq_i32", 1>;
604def S_CMPK_LG_I32 : SOPK_SCC <"s_cmpk_lg_i32", "s_cmp_lg_i32", 1>;
605def S_CMPK_GT_I32 : SOPK_SCC <"s_cmpk_gt_i32", "s_cmp_gt_i32", 1>;
606def S_CMPK_GE_I32 : SOPK_SCC <"s_cmpk_ge_i32", "s_cmp_ge_i32", 1>;
607def S_CMPK_LT_I32 : SOPK_SCC <"s_cmpk_lt_i32", "s_cmp_lt_i32", 1>;
608def S_CMPK_LE_I32 : SOPK_SCC <"s_cmpk_le_i32", "s_cmp_le_i32", 1>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000609
610let SOPKZext = 1 in {
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000611def S_CMPK_EQ_U32 : SOPK_SCC <"s_cmpk_eq_u32", "s_cmp_eq_u32", 0>;
612def S_CMPK_LG_U32 : SOPK_SCC <"s_cmpk_lg_u32", "s_cmp_lg_u32", 0>;
613def S_CMPK_GT_U32 : SOPK_SCC <"s_cmpk_gt_u32", "s_cmp_gt_u32", 0>;
614def S_CMPK_GE_U32 : SOPK_SCC <"s_cmpk_ge_u32", "s_cmp_ge_u32", 0>;
615def S_CMPK_LT_U32 : SOPK_SCC <"s_cmpk_lt_u32", "s_cmp_lt_u32", 0>;
616def S_CMPK_LE_U32 : SOPK_SCC <"s_cmpk_le_u32", "s_cmp_le_u32", 0>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000617} // End SOPKZext = 1
Valery Pykhtina34fb492016-08-30 15:20:31 +0000618} // End isCompare = 1
619
620let Defs = [SCC], isCommutable = 1, DisableEncoding = "$src0",
621 Constraints = "$sdst = $src0" in {
622 def S_ADDK_I32 : SOPK_32TIE <"s_addk_i32">;
623 def S_MULK_I32 : SOPK_32TIE <"s_mulk_i32">;
624}
625
626def S_CBRANCH_I_FORK : SOPK_Pseudo <
627 "s_cbranch_i_fork",
Dmitry Preobrazhenskyc7d35a02017-04-26 15:34:19 +0000628 (outs), (ins SReg_64:$sdst, s16imm:$simm16),
Valery Pykhtina34fb492016-08-30 15:20:31 +0000629 "$sdst, $simm16"
630>;
631
632let mayLoad = 1 in {
633def S_GETREG_B32 : SOPK_Pseudo <
634 "s_getreg_b32",
635 (outs SReg_32:$sdst), (ins hwreg:$simm16),
636 "$sdst, $simm16"
637>;
638}
639
Tom Stellard8485fa02016-12-07 02:42:15 +0000640let hasSideEffects = 1 in {
641
Valery Pykhtina34fb492016-08-30 15:20:31 +0000642def S_SETREG_B32 : SOPK_Pseudo <
643 "s_setreg_b32",
644 (outs), (ins SReg_32:$sdst, hwreg:$simm16),
Tom Stellard8485fa02016-12-07 02:42:15 +0000645 "$simm16, $sdst",
646 [(AMDGPUsetreg i32:$sdst, (i16 timm:$simm16))]
Valery Pykhtina34fb492016-08-30 15:20:31 +0000647>;
648
649// FIXME: Not on SI?
650//def S_GETREG_REGRD_B32 : SOPK_32 <sopk<0x14, 0x13>, "s_getreg_regrd_b32">;
651
652def S_SETREG_IMM32_B32 : SOPK_Pseudo <
653 "s_setreg_imm32_b32",
654 (outs), (ins i32imm:$imm, hwreg:$simm16),
Matt Arsenault10c17ca2016-10-06 10:13:23 +0000655 "$simm16, $imm"> {
656 let Size = 8; // Unlike every other SOPK instruction.
Valery Pykhtina34fb492016-08-30 15:20:31 +0000657 let has_sdst = 0;
658}
659
Tom Stellard8485fa02016-12-07 02:42:15 +0000660} // End hasSideEffects = 1
Valery Pykhtina34fb492016-08-30 15:20:31 +0000661
662//===----------------------------------------------------------------------===//
663// SOPC Instructions
664//===----------------------------------------------------------------------===//
665
666class SOPCe <bits<7> op> : Enc32 {
667 bits<8> src0;
668 bits<8> src1;
669
670 let Inst{7-0} = src0;
671 let Inst{15-8} = src1;
672 let Inst{22-16} = op;
673 let Inst{31-23} = 0x17e;
674}
675
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000676class SOPC <bits<7> op, dag outs, dag ins, string asm,
677 list<dag> pattern = []> :
Valery Pykhtina34fb492016-08-30 15:20:31 +0000678 InstSI<outs, ins, asm, pattern>, SOPCe <op> {
679 let mayLoad = 0;
680 let mayStore = 0;
681 let hasSideEffects = 0;
682 let SALU = 1;
683 let SOPC = 1;
684 let isCodeGenOnly = 0;
685 let Defs = [SCC];
686 let SchedRW = [WriteSALU];
687 let UseNamedOperandTable = 1;
688 let SubtargetPredicate = isGCN;
689}
690
691class SOPC_Base <bits<7> op, RegisterOperand rc0, RegisterOperand rc1,
692 string opName, list<dag> pattern = []> : SOPC <
693 op, (outs), (ins rc0:$src0, rc1:$src1),
694 opName#" $src0, $src1", pattern > {
695 let Defs = [SCC];
696}
697class SOPC_Helper <bits<7> op, RegisterOperand rc, ValueType vt,
698 string opName, PatLeaf cond> : SOPC_Base <
699 op, rc, rc, opName,
700 [(set SCC, (si_setcc_uniform vt:$src0, vt:$src1, cond))] > {
701}
702
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000703class SOPC_CMP_32<bits<7> op, string opName,
704 PatLeaf cond = COND_NULL, string revOp = opName>
705 : SOPC_Helper<op, SSrc_b32, i32, opName, cond>,
706 Commutable_REV<revOp, !eq(revOp, opName)>,
707 SOPKInstTable<0, opName> {
708 let isCompare = 1;
709 let isCommutable = 1;
710}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000711
Matt Arsenault7b1dc2c2016-09-17 02:02:19 +0000712class SOPC_CMP_64<bits<7> op, string opName,
713 PatLeaf cond = COND_NULL, string revOp = opName>
714 : SOPC_Helper<op, SSrc_b64, i64, opName, cond>,
715 Commutable_REV<revOp, !eq(revOp, opName)> {
716 let isCompare = 1;
717 let isCommutable = 1;
718}
719
Valery Pykhtina34fb492016-08-30 15:20:31 +0000720class SOPC_32<bits<7> op, string opName, list<dag> pattern = []>
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000721 : SOPC_Base<op, SSrc_b32, SSrc_b32, opName, pattern>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000722
723class SOPC_64_32<bits<7> op, string opName, list<dag> pattern = []>
Sam Kolton1eeb11b2016-09-09 14:44:04 +0000724 : SOPC_Base<op, SSrc_b64, SSrc_b32, opName, pattern>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000725
Matt Arsenault5d8eb252016-09-30 01:50:20 +0000726def S_CMP_EQ_I32 : SOPC_CMP_32 <0x00, "s_cmp_eq_i32">;
727def S_CMP_LG_I32 : SOPC_CMP_32 <0x01, "s_cmp_lg_i32">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000728def S_CMP_GT_I32 : SOPC_CMP_32 <0x02, "s_cmp_gt_i32", COND_SGT>;
729def S_CMP_GE_I32 : SOPC_CMP_32 <0x03, "s_cmp_ge_i32", COND_SGE>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000730def S_CMP_LT_I32 : SOPC_CMP_32 <0x04, "s_cmp_lt_i32", COND_SLT, "s_cmp_gt_i32">;
731def 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 +0000732def S_CMP_EQ_U32 : SOPC_CMP_32 <0x06, "s_cmp_eq_u32", COND_EQ>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000733def S_CMP_LG_U32 : SOPC_CMP_32 <0x07, "s_cmp_lg_u32", COND_NE>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000734def S_CMP_GT_U32 : SOPC_CMP_32 <0x08, "s_cmp_gt_u32", COND_UGT>;
735def S_CMP_GE_U32 : SOPC_CMP_32 <0x09, "s_cmp_ge_u32", COND_UGE>;
Matt Arsenault7ccf6cd2016-09-16 21:41:16 +0000736def S_CMP_LT_U32 : SOPC_CMP_32 <0x0a, "s_cmp_lt_u32", COND_ULT, "s_cmp_gt_u32">;
737def S_CMP_LE_U32 : SOPC_CMP_32 <0x0b, "s_cmp_le_u32", COND_ULE, "s_cmp_ge_u32">;
738
Valery Pykhtina34fb492016-08-30 15:20:31 +0000739def S_BITCMP0_B32 : SOPC_32 <0x0c, "s_bitcmp0_b32">;
740def S_BITCMP1_B32 : SOPC_32 <0x0d, "s_bitcmp1_b32">;
741def S_BITCMP0_B64 : SOPC_64_32 <0x0e, "s_bitcmp0_b64">;
742def S_BITCMP1_B64 : SOPC_64_32 <0x0f, "s_bitcmp1_b64">;
743def S_SETVSKIP : SOPC_32 <0x10, "s_setvskip">;
744
Matt Arsenault7b1dc2c2016-09-17 02:02:19 +0000745let SubtargetPredicate = isVI in {
746def S_CMP_EQ_U64 : SOPC_CMP_64 <0x12, "s_cmp_eq_u64", COND_EQ>;
747def S_CMP_LG_U64 : SOPC_CMP_64 <0x13, "s_cmp_lg_u64", COND_NE>;
748}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000749
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000750let SubtargetPredicate = HasVGPRIndexMode in {
751def S_SET_GPR_IDX_ON : SOPC <0x11,
752 (outs),
753 (ins SSrc_b32:$src0, GPRIdxMode:$src1),
754 "s_set_gpr_idx_on $src0,$src1"> {
755 let Defs = [M0]; // No scc def
756 let Uses = [M0]; // Other bits of m0 unmodified.
757 let hasSideEffects = 1; // Sets mode.gpr_idx_en
Matt Arsenault2d8c2892016-11-01 20:42:24 +0000758 let FixedSize = 1;
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000759}
760}
761
Valery Pykhtina34fb492016-08-30 15:20:31 +0000762//===----------------------------------------------------------------------===//
763// SOPP Instructions
764//===----------------------------------------------------------------------===//
765
766class SOPPe <bits<7> op> : Enc32 {
767 bits <16> simm16;
768
769 let Inst{15-0} = simm16;
770 let Inst{22-16} = op;
771 let Inst{31-23} = 0x17f; // encoding
772}
773
774class SOPP <bits<7> op, dag ins, string asm, list<dag> pattern = []> :
775 InstSI <(outs), ins, asm, pattern >, SOPPe <op> {
776
777 let mayLoad = 0;
778 let mayStore = 0;
779 let hasSideEffects = 0;
780 let SALU = 1;
781 let SOPP = 1;
Matt Arsenault10c17ca2016-10-06 10:13:23 +0000782 let Size = 4;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000783 let SchedRW = [WriteSALU];
784
785 let UseNamedOperandTable = 1;
786 let SubtargetPredicate = isGCN;
787}
788
789
790def S_NOP : SOPP <0x00000000, (ins i16imm:$simm16), "s_nop $simm16">;
791
792let isTerminator = 1 in {
793
794def S_ENDPGM : SOPP <0x00000001, (ins), "s_endpgm",
795 [(AMDGPUendpgm)]> {
796 let simm16 = 0;
797 let isBarrier = 1;
Matt Arsenault4e9c1e32016-10-28 23:00:38 +0000798 let isReturn = 1;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000799}
800
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000801let SubtargetPredicate = isVI in {
802def S_ENDPGM_SAVED : SOPP <0x0000001B, (ins), "s_endpgm_saved"> {
803 let simm16 = 0;
804 let isBarrier = 1;
805 let isReturn = 1;
806}
807}
808
Valery Pykhtina34fb492016-08-30 15:20:31 +0000809let isBranch = 1, SchedRW = [WriteBranch] in {
810def S_BRANCH : SOPP <
811 0x00000002, (ins sopp_brtarget:$simm16), "s_branch $simm16",
812 [(br bb:$simm16)]> {
813 let isBarrier = 1;
814}
815
816let Uses = [SCC] in {
817def S_CBRANCH_SCC0 : SOPP <
818 0x00000004, (ins sopp_brtarget:$simm16),
819 "s_cbranch_scc0 $simm16"
820>;
821def S_CBRANCH_SCC1 : SOPP <
822 0x00000005, (ins sopp_brtarget:$simm16),
Matt Arsenaultd674e0a2017-10-10 20:34:49 +0000823 "s_cbranch_scc1 $simm16"
Valery Pykhtina34fb492016-08-30 15:20:31 +0000824>;
825} // End Uses = [SCC]
826
827let Uses = [VCC] in {
828def S_CBRANCH_VCCZ : SOPP <
829 0x00000006, (ins sopp_brtarget:$simm16),
830 "s_cbranch_vccz $simm16"
831>;
832def S_CBRANCH_VCCNZ : SOPP <
833 0x00000007, (ins sopp_brtarget:$simm16),
834 "s_cbranch_vccnz $simm16"
835>;
836} // End Uses = [VCC]
837
838let Uses = [EXEC] in {
839def S_CBRANCH_EXECZ : SOPP <
840 0x00000008, (ins sopp_brtarget:$simm16),
841 "s_cbranch_execz $simm16"
842>;
843def S_CBRANCH_EXECNZ : SOPP <
844 0x00000009, (ins sopp_brtarget:$simm16),
845 "s_cbranch_execnz $simm16"
846>;
847} // End Uses = [EXEC]
848
Dmitry Preobrazhensky3ac63112017-04-05 17:26:45 +0000849def S_CBRANCH_CDBGSYS : SOPP <
850 0x00000017, (ins sopp_brtarget:$simm16),
851 "s_cbranch_cdbgsys $simm16"
852>;
853
854def S_CBRANCH_CDBGSYS_AND_USER : SOPP <
855 0x0000001A, (ins sopp_brtarget:$simm16),
856 "s_cbranch_cdbgsys_and_user $simm16"
857>;
858
859def S_CBRANCH_CDBGSYS_OR_USER : SOPP <
860 0x00000019, (ins sopp_brtarget:$simm16),
861 "s_cbranch_cdbgsys_or_user $simm16"
862>;
863
864def S_CBRANCH_CDBGUSER : SOPP <
865 0x00000018, (ins sopp_brtarget:$simm16),
866 "s_cbranch_cdbguser $simm16"
867>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000868
869} // End isBranch = 1
870} // End isTerminator = 1
871
872let hasSideEffects = 1 in {
873def S_BARRIER : SOPP <0x0000000a, (ins), "s_barrier",
874 [(int_amdgcn_s_barrier)]> {
875 let SchedRW = [WriteBarrier];
876 let simm16 = 0;
877 let mayLoad = 1;
878 let mayStore = 1;
879 let isConvergent = 1;
880}
881
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +0000882let SubtargetPredicate = isVI in {
883def S_WAKEUP : SOPP <0x00000003, (ins), "s_wakeup"> {
884 let simm16 = 0;
885 let mayLoad = 1;
886 let mayStore = 1;
887}
888}
889
Valery Pykhtina34fb492016-08-30 15:20:31 +0000890let mayLoad = 1, mayStore = 1, hasSideEffects = 1 in
891def S_WAITCNT : SOPP <0x0000000c, (ins WAIT_FLAG:$simm16), "s_waitcnt $simm16">;
892def S_SETHALT : SOPP <0x0000000d, (ins i16imm:$simm16), "s_sethalt $simm16">;
Dmitry Preobrazhensky3ac63112017-04-05 17:26:45 +0000893def S_SETKILL : SOPP <0x0000000b, (ins i16imm:$simm16), "s_setkill $simm16">;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000894
895// On SI the documentation says sleep for approximately 64 * low 2
896// bits, consistent with the reported maximum of 448. On VI the
897// maximum reported is 960 cycles, so 960 / 64 = 15 max, so is the
898// maximum really 15 on VI?
899def S_SLEEP : SOPP <0x0000000e, (ins i32imm:$simm16),
900 "s_sleep $simm16", [(int_amdgcn_s_sleep SIMM16bit:$simm16)]> {
901 let hasSideEffects = 1;
902 let mayLoad = 1;
903 let mayStore = 1;
904}
905
906def S_SETPRIO : SOPP <0x0000000f, (ins i16imm:$simm16), "s_setprio $simm16">;
907
908let Uses = [EXEC, M0] in {
909// FIXME: Should this be mayLoad+mayStore?
910def S_SENDMSG : SOPP <0x00000010, (ins SendMsgImm:$simm16), "s_sendmsg $simm16",
911 [(AMDGPUsendmsg (i32 imm:$simm16))]
912>;
Jan Veselyd48445d2017-01-04 18:06:55 +0000913
914def S_SENDMSGHALT : SOPP <0x00000011, (ins SendMsgImm:$simm16), "s_sendmsghalt $simm16",
915 [(AMDGPUsendmsghalt (i32 imm:$simm16))]
916>;
Valery Pykhtina34fb492016-08-30 15:20:31 +0000917} // End Uses = [EXEC, M0]
918
Valery Pykhtina34fb492016-08-30 15:20:31 +0000919def S_TRAP : SOPP <0x00000012, (ins i16imm:$simm16), "s_trap $simm16">;
920def S_ICACHE_INV : SOPP <0x00000013, (ins), "s_icache_inv"> {
921 let simm16 = 0;
922}
923def S_INCPERFLEVEL : SOPP <0x00000014, (ins i32imm:$simm16), "s_incperflevel $simm16",
924 [(int_amdgcn_s_incperflevel SIMM16bit:$simm16)]> {
925 let hasSideEffects = 1;
926 let mayLoad = 1;
927 let mayStore = 1;
928}
929def S_DECPERFLEVEL : SOPP <0x00000015, (ins i32imm:$simm16), "s_decperflevel $simm16",
930 [(int_amdgcn_s_decperflevel SIMM16bit:$simm16)]> {
931 let hasSideEffects = 1;
932 let mayLoad = 1;
933 let mayStore = 1;
934}
935def S_TTRACEDATA : SOPP <0x00000016, (ins), "s_ttracedata"> {
936 let simm16 = 0;
937}
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000938
939let SubtargetPredicate = HasVGPRIndexMode in {
940def S_SET_GPR_IDX_OFF : SOPP<0x1c, (ins), "s_set_gpr_idx_off"> {
941 let simm16 = 0;
942}
943}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000944} // End hasSideEffects
945
Matt Arsenaultcc88ce32016-10-12 18:00:51 +0000946let SubtargetPredicate = HasVGPRIndexMode in {
947def S_SET_GPR_IDX_MODE : SOPP<0x1d, (ins GPRIdxMode:$simm16),
948 "s_set_gpr_idx_mode$simm16"> {
949 let Defs = [M0];
950}
951}
Valery Pykhtina34fb492016-08-30 15:20:31 +0000952
Valery Pykhtina34fb492016-08-30 15:20:31 +0000953//===----------------------------------------------------------------------===//
954// S_GETREG_B32 Intrinsic Pattern.
955//===----------------------------------------------------------------------===//
Matt Arsenault90c75932017-10-03 00:06:41 +0000956def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000957 (int_amdgcn_s_getreg imm:$simm16),
958 (S_GETREG_B32 (as_i16imm $simm16))
959>;
960
961//===----------------------------------------------------------------------===//
962// SOP1 Patterns
963//===----------------------------------------------------------------------===//
964
Matt Arsenault90c75932017-10-03 00:06:41 +0000965def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000966 (i64 (ctpop i64:$src)),
967 (i64 (REG_SEQUENCE SReg_64,
968 (i32 (COPY_TO_REGCLASS (S_BCNT1_I32_B64 $src), SReg_32)), sub0,
Tom Stellard115a6152016-11-10 16:02:37 +0000969 (S_MOV_B32 (i32 0)), sub1))
Valery Pykhtina34fb492016-08-30 15:20:31 +0000970>;
971
Matt Arsenault90c75932017-10-03 00:06:41 +0000972def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000973 (i32 (smax i32:$x, (i32 (ineg i32:$x)))),
974 (S_ABS_I32 $x)
975>;
976
Matt Arsenault90c75932017-10-03 00:06:41 +0000977def : GCNPat <
Tom Stellard115a6152016-11-10 16:02:37 +0000978 (i16 imm:$imm),
979 (S_MOV_B32 imm:$imm)
980>;
981
982// Same as a 32-bit inreg
Matt Arsenault90c75932017-10-03 00:06:41 +0000983def : GCNPat<
Tom Stellard115a6152016-11-10 16:02:37 +0000984 (i32 (sext i16:$src)),
985 (S_SEXT_I32_I16 $src)
986>;
987
988
Valery Pykhtina34fb492016-08-30 15:20:31 +0000989//===----------------------------------------------------------------------===//
990// SOP2 Patterns
991//===----------------------------------------------------------------------===//
992
993// V_ADD_I32_e32/S_ADD_U32 produces carry in VCC/SCC. For the vector
994// case, the sgpr-copies pass will fix this to use the vector version.
Matt Arsenault90c75932017-10-03 00:06:41 +0000995def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +0000996 (i32 (addc i32:$src0, i32:$src1)),
997 (S_ADD_U32 $src0, $src1)
998>;
999
Tom Stellard115a6152016-11-10 16:02:37 +00001000// FIXME: We need to use COPY_TO_REGCLASS to work-around the fact that
1001// REG_SEQUENCE patterns don't support instructions with multiple
1002// outputs.
Matt Arsenault90c75932017-10-03 00:06:41 +00001003def : GCNPat<
Tom Stellard115a6152016-11-10 16:02:37 +00001004 (i64 (zext i16:$src)),
1005 (REG_SEQUENCE SReg_64,
1006 (i32 (COPY_TO_REGCLASS (S_AND_B32 $src, (S_MOV_B32 (i32 0xffff))), SGPR_32)), sub0,
1007 (S_MOV_B32 (i32 0)), sub1)
1008>;
1009
Matt Arsenault90c75932017-10-03 00:06:41 +00001010def : GCNPat <
Tom Stellard115a6152016-11-10 16:02:37 +00001011 (i64 (sext i16:$src)),
1012 (REG_SEQUENCE SReg_64, (i32 (S_SEXT_I32_I16 $src)), sub0,
1013 (i32 (COPY_TO_REGCLASS (S_ASHR_I32 (i32 (S_SEXT_I32_I16 $src)), (S_MOV_B32 (i32 31))), SGPR_32)), sub1)
1014>;
1015
Matt Arsenault90c75932017-10-03 00:06:41 +00001016def : GCNPat<
Tom Stellard115a6152016-11-10 16:02:37 +00001017 (i32 (zext i16:$src)),
1018 (S_AND_B32 (S_MOV_B32 (i32 0xffff)), $src)
1019>;
1020
1021
1022
Valery Pykhtina34fb492016-08-30 15:20:31 +00001023//===----------------------------------------------------------------------===//
1024// SOPP Patterns
1025//===----------------------------------------------------------------------===//
1026
Matt Arsenault90c75932017-10-03 00:06:41 +00001027def : GCNPat <
Valery Pykhtina34fb492016-08-30 15:20:31 +00001028 (int_amdgcn_s_waitcnt i32:$simm16),
1029 (S_WAITCNT (as_i16imm $simm16))
1030>;
1031
Valery Pykhtina34fb492016-08-30 15:20:31 +00001032
1033//===----------------------------------------------------------------------===//
1034// Real target instructions, move this to the appropriate subtarget TD file
1035//===----------------------------------------------------------------------===//
1036
1037class Select_si<string opName> :
1038 SIMCInstr<opName, SIEncodingFamily.SI> {
1039 list<Predicate> AssemblerPredicates = [isSICI];
1040 string DecoderNamespace = "SICI";
1041}
1042
1043class SOP1_Real_si<bits<8> op, SOP1_Pseudo ps> :
1044 SOP1_Real<op, ps>,
1045 Select_si<ps.Mnemonic>;
1046
1047class SOP2_Real_si<bits<7> op, SOP2_Pseudo ps> :
1048 SOP2_Real<op, ps>,
1049 Select_si<ps.Mnemonic>;
1050
1051class SOPK_Real_si<bits<5> op, SOPK_Pseudo ps> :
1052 SOPK_Real32<op, ps>,
1053 Select_si<ps.Mnemonic>;
1054
1055def S_MOV_B32_si : SOP1_Real_si <0x03, S_MOV_B32>;
1056def S_MOV_B64_si : SOP1_Real_si <0x04, S_MOV_B64>;
1057def S_CMOV_B32_si : SOP1_Real_si <0x05, S_CMOV_B32>;
1058def S_CMOV_B64_si : SOP1_Real_si <0x06, S_CMOV_B64>;
1059def S_NOT_B32_si : SOP1_Real_si <0x07, S_NOT_B32>;
1060def S_NOT_B64_si : SOP1_Real_si <0x08, S_NOT_B64>;
1061def S_WQM_B32_si : SOP1_Real_si <0x09, S_WQM_B32>;
1062def S_WQM_B64_si : SOP1_Real_si <0x0a, S_WQM_B64>;
1063def S_BREV_B32_si : SOP1_Real_si <0x0b, S_BREV_B32>;
1064def S_BREV_B64_si : SOP1_Real_si <0x0c, S_BREV_B64>;
1065def S_BCNT0_I32_B32_si : SOP1_Real_si <0x0d, S_BCNT0_I32_B32>;
1066def S_BCNT0_I32_B64_si : SOP1_Real_si <0x0e, S_BCNT0_I32_B64>;
1067def S_BCNT1_I32_B32_si : SOP1_Real_si <0x0f, S_BCNT1_I32_B32>;
1068def S_BCNT1_I32_B64_si : SOP1_Real_si <0x10, S_BCNT1_I32_B64>;
1069def S_FF0_I32_B32_si : SOP1_Real_si <0x11, S_FF0_I32_B32>;
1070def S_FF0_I32_B64_si : SOP1_Real_si <0x12, S_FF0_I32_B64>;
1071def S_FF1_I32_B32_si : SOP1_Real_si <0x13, S_FF1_I32_B32>;
1072def S_FF1_I32_B64_si : SOP1_Real_si <0x14, S_FF1_I32_B64>;
1073def S_FLBIT_I32_B32_si : SOP1_Real_si <0x15, S_FLBIT_I32_B32>;
1074def S_FLBIT_I32_B64_si : SOP1_Real_si <0x16, S_FLBIT_I32_B64>;
1075def S_FLBIT_I32_si : SOP1_Real_si <0x17, S_FLBIT_I32>;
1076def S_FLBIT_I32_I64_si : SOP1_Real_si <0x18, S_FLBIT_I32_I64>;
1077def S_SEXT_I32_I8_si : SOP1_Real_si <0x19, S_SEXT_I32_I8>;
1078def S_SEXT_I32_I16_si : SOP1_Real_si <0x1a, S_SEXT_I32_I16>;
1079def S_BITSET0_B32_si : SOP1_Real_si <0x1b, S_BITSET0_B32>;
1080def S_BITSET0_B64_si : SOP1_Real_si <0x1c, S_BITSET0_B64>;
1081def S_BITSET1_B32_si : SOP1_Real_si <0x1d, S_BITSET1_B32>;
1082def S_BITSET1_B64_si : SOP1_Real_si <0x1e, S_BITSET1_B64>;
1083def S_GETPC_B64_si : SOP1_Real_si <0x1f, S_GETPC_B64>;
1084def S_SETPC_B64_si : SOP1_Real_si <0x20, S_SETPC_B64>;
1085def S_SWAPPC_B64_si : SOP1_Real_si <0x21, S_SWAPPC_B64>;
1086def S_RFE_B64_si : SOP1_Real_si <0x22, S_RFE_B64>;
1087def S_AND_SAVEEXEC_B64_si : SOP1_Real_si <0x24, S_AND_SAVEEXEC_B64>;
1088def S_OR_SAVEEXEC_B64_si : SOP1_Real_si <0x25, S_OR_SAVEEXEC_B64>;
1089def S_XOR_SAVEEXEC_B64_si : SOP1_Real_si <0x26, S_XOR_SAVEEXEC_B64>;
1090def S_ANDN2_SAVEEXEC_B64_si: SOP1_Real_si <0x27, S_ANDN2_SAVEEXEC_B64>;
1091def S_ORN2_SAVEEXEC_B64_si : SOP1_Real_si <0x28, S_ORN2_SAVEEXEC_B64>;
1092def S_NAND_SAVEEXEC_B64_si : SOP1_Real_si <0x29, S_NAND_SAVEEXEC_B64>;
1093def S_NOR_SAVEEXEC_B64_si : SOP1_Real_si <0x2a, S_NOR_SAVEEXEC_B64>;
1094def S_XNOR_SAVEEXEC_B64_si : SOP1_Real_si <0x2b, S_XNOR_SAVEEXEC_B64>;
1095def S_QUADMASK_B32_si : SOP1_Real_si <0x2c, S_QUADMASK_B32>;
1096def S_QUADMASK_B64_si : SOP1_Real_si <0x2d, S_QUADMASK_B64>;
1097def S_MOVRELS_B32_si : SOP1_Real_si <0x2e, S_MOVRELS_B32>;
1098def S_MOVRELS_B64_si : SOP1_Real_si <0x2f, S_MOVRELS_B64>;
1099def S_MOVRELD_B32_si : SOP1_Real_si <0x30, S_MOVRELD_B32>;
1100def S_MOVRELD_B64_si : SOP1_Real_si <0x31, S_MOVRELD_B64>;
1101def S_CBRANCH_JOIN_si : SOP1_Real_si <0x32, S_CBRANCH_JOIN>;
1102def S_MOV_REGRD_B32_si : SOP1_Real_si <0x33, S_MOV_REGRD_B32>;
1103def S_ABS_I32_si : SOP1_Real_si <0x34, S_ABS_I32>;
1104def S_MOV_FED_B32_si : SOP1_Real_si <0x35, S_MOV_FED_B32>;
1105
1106def S_ADD_U32_si : SOP2_Real_si <0x00, S_ADD_U32>;
1107def S_ADD_I32_si : SOP2_Real_si <0x02, S_ADD_I32>;
1108def S_SUB_U32_si : SOP2_Real_si <0x01, S_SUB_U32>;
1109def S_SUB_I32_si : SOP2_Real_si <0x03, S_SUB_I32>;
1110def S_ADDC_U32_si : SOP2_Real_si <0x04, S_ADDC_U32>;
1111def S_SUBB_U32_si : SOP2_Real_si <0x05, S_SUBB_U32>;
1112def S_MIN_I32_si : SOP2_Real_si <0x06, S_MIN_I32>;
1113def S_MIN_U32_si : SOP2_Real_si <0x07, S_MIN_U32>;
1114def S_MAX_I32_si : SOP2_Real_si <0x08, S_MAX_I32>;
1115def S_MAX_U32_si : SOP2_Real_si <0x09, S_MAX_U32>;
1116def S_CSELECT_B32_si : SOP2_Real_si <0x0a, S_CSELECT_B32>;
1117def S_CSELECT_B64_si : SOP2_Real_si <0x0b, S_CSELECT_B64>;
1118def S_AND_B32_si : SOP2_Real_si <0x0e, S_AND_B32>;
1119def S_AND_B64_si : SOP2_Real_si <0x0f, S_AND_B64>;
1120def S_OR_B32_si : SOP2_Real_si <0x10, S_OR_B32>;
1121def S_OR_B64_si : SOP2_Real_si <0x11, S_OR_B64>;
1122def S_XOR_B32_si : SOP2_Real_si <0x12, S_XOR_B32>;
1123def S_XOR_B64_si : SOP2_Real_si <0x13, S_XOR_B64>;
1124def S_ANDN2_B32_si : SOP2_Real_si <0x14, S_ANDN2_B32>;
1125def S_ANDN2_B64_si : SOP2_Real_si <0x15, S_ANDN2_B64>;
1126def S_ORN2_B32_si : SOP2_Real_si <0x16, S_ORN2_B32>;
1127def S_ORN2_B64_si : SOP2_Real_si <0x17, S_ORN2_B64>;
1128def S_NAND_B32_si : SOP2_Real_si <0x18, S_NAND_B32>;
1129def S_NAND_B64_si : SOP2_Real_si <0x19, S_NAND_B64>;
1130def S_NOR_B32_si : SOP2_Real_si <0x1a, S_NOR_B32>;
1131def S_NOR_B64_si : SOP2_Real_si <0x1b, S_NOR_B64>;
1132def S_XNOR_B32_si : SOP2_Real_si <0x1c, S_XNOR_B32>;
1133def S_XNOR_B64_si : SOP2_Real_si <0x1d, S_XNOR_B64>;
1134def S_LSHL_B32_si : SOP2_Real_si <0x1e, S_LSHL_B32>;
1135def S_LSHL_B64_si : SOP2_Real_si <0x1f, S_LSHL_B64>;
1136def S_LSHR_B32_si : SOP2_Real_si <0x20, S_LSHR_B32>;
1137def S_LSHR_B64_si : SOP2_Real_si <0x21, S_LSHR_B64>;
1138def S_ASHR_I32_si : SOP2_Real_si <0x22, S_ASHR_I32>;
1139def S_ASHR_I64_si : SOP2_Real_si <0x23, S_ASHR_I64>;
1140def S_BFM_B32_si : SOP2_Real_si <0x24, S_BFM_B32>;
1141def S_BFM_B64_si : SOP2_Real_si <0x25, S_BFM_B64>;
1142def S_MUL_I32_si : SOP2_Real_si <0x26, S_MUL_I32>;
1143def S_BFE_U32_si : SOP2_Real_si <0x27, S_BFE_U32>;
1144def S_BFE_I32_si : SOP2_Real_si <0x28, S_BFE_I32>;
1145def S_BFE_U64_si : SOP2_Real_si <0x29, S_BFE_U64>;
1146def S_BFE_I64_si : SOP2_Real_si <0x2a, S_BFE_I64>;
1147def S_CBRANCH_G_FORK_si : SOP2_Real_si <0x2b, S_CBRANCH_G_FORK>;
1148def S_ABSDIFF_I32_si : SOP2_Real_si <0x2c, S_ABSDIFF_I32>;
1149
1150def S_MOVK_I32_si : SOPK_Real_si <0x00, S_MOVK_I32>;
1151def S_CMOVK_I32_si : SOPK_Real_si <0x02, S_CMOVK_I32>;
1152def S_CMPK_EQ_I32_si : SOPK_Real_si <0x03, S_CMPK_EQ_I32>;
1153def S_CMPK_LG_I32_si : SOPK_Real_si <0x04, S_CMPK_LG_I32>;
1154def S_CMPK_GT_I32_si : SOPK_Real_si <0x05, S_CMPK_GT_I32>;
1155def S_CMPK_GE_I32_si : SOPK_Real_si <0x06, S_CMPK_GE_I32>;
1156def S_CMPK_LT_I32_si : SOPK_Real_si <0x07, S_CMPK_LT_I32>;
1157def S_CMPK_LE_I32_si : SOPK_Real_si <0x08, S_CMPK_LE_I32>;
1158def S_CMPK_EQ_U32_si : SOPK_Real_si <0x09, S_CMPK_EQ_U32>;
1159def S_CMPK_LG_U32_si : SOPK_Real_si <0x0a, S_CMPK_LG_U32>;
1160def S_CMPK_GT_U32_si : SOPK_Real_si <0x0b, S_CMPK_GT_U32>;
1161def S_CMPK_GE_U32_si : SOPK_Real_si <0x0c, S_CMPK_GE_U32>;
1162def S_CMPK_LT_U32_si : SOPK_Real_si <0x0d, S_CMPK_LT_U32>;
1163def S_CMPK_LE_U32_si : SOPK_Real_si <0x0e, S_CMPK_LE_U32>;
1164def S_ADDK_I32_si : SOPK_Real_si <0x0f, S_ADDK_I32>;
1165def S_MULK_I32_si : SOPK_Real_si <0x10, S_MULK_I32>;
1166def S_CBRANCH_I_FORK_si : SOPK_Real_si <0x11, S_CBRANCH_I_FORK>;
1167def S_GETREG_B32_si : SOPK_Real_si <0x12, S_GETREG_B32>;
1168def S_SETREG_B32_si : SOPK_Real_si <0x13, S_SETREG_B32>;
1169//def S_GETREG_REGRD_B32_si : SOPK_Real_si <0x14, S_GETREG_REGRD_B32>; // see pseudo for comments
1170def S_SETREG_IMM32_B32_si : SOPK_Real64<0x15, S_SETREG_IMM32_B32>,
1171 Select_si<S_SETREG_IMM32_B32.Mnemonic>;
1172
1173
1174class Select_vi<string opName> :
1175 SIMCInstr<opName, SIEncodingFamily.VI> {
1176 list<Predicate> AssemblerPredicates = [isVI];
1177 string DecoderNamespace = "VI";
1178}
1179
1180class SOP1_Real_vi<bits<8> op, SOP1_Pseudo ps> :
1181 SOP1_Real<op, ps>,
1182 Select_vi<ps.Mnemonic>;
1183
1184
1185class SOP2_Real_vi<bits<7> op, SOP2_Pseudo ps> :
1186 SOP2_Real<op, ps>,
1187 Select_vi<ps.Mnemonic>;
1188
1189class SOPK_Real_vi<bits<5> op, SOPK_Pseudo ps> :
1190 SOPK_Real32<op, ps>,
1191 Select_vi<ps.Mnemonic>;
1192
1193def S_MOV_B32_vi : SOP1_Real_vi <0x00, S_MOV_B32>;
1194def S_MOV_B64_vi : SOP1_Real_vi <0x01, S_MOV_B64>;
1195def S_CMOV_B32_vi : SOP1_Real_vi <0x02, S_CMOV_B32>;
1196def S_CMOV_B64_vi : SOP1_Real_vi <0x03, S_CMOV_B64>;
1197def S_NOT_B32_vi : SOP1_Real_vi <0x04, S_NOT_B32>;
1198def S_NOT_B64_vi : SOP1_Real_vi <0x05, S_NOT_B64>;
1199def S_WQM_B32_vi : SOP1_Real_vi <0x06, S_WQM_B32>;
1200def S_WQM_B64_vi : SOP1_Real_vi <0x07, S_WQM_B64>;
1201def S_BREV_B32_vi : SOP1_Real_vi <0x08, S_BREV_B32>;
1202def S_BREV_B64_vi : SOP1_Real_vi <0x09, S_BREV_B64>;
1203def S_BCNT0_I32_B32_vi : SOP1_Real_vi <0x0a, S_BCNT0_I32_B32>;
1204def S_BCNT0_I32_B64_vi : SOP1_Real_vi <0x0b, S_BCNT0_I32_B64>;
1205def S_BCNT1_I32_B32_vi : SOP1_Real_vi <0x0c, S_BCNT1_I32_B32>;
1206def S_BCNT1_I32_B64_vi : SOP1_Real_vi <0x0d, S_BCNT1_I32_B64>;
1207def S_FF0_I32_B32_vi : SOP1_Real_vi <0x0e, S_FF0_I32_B32>;
1208def S_FF0_I32_B64_vi : SOP1_Real_vi <0x0f, S_FF0_I32_B64>;
1209def S_FF1_I32_B32_vi : SOP1_Real_vi <0x10, S_FF1_I32_B32>;
1210def S_FF1_I32_B64_vi : SOP1_Real_vi <0x11, S_FF1_I32_B64>;
1211def S_FLBIT_I32_B32_vi : SOP1_Real_vi <0x12, S_FLBIT_I32_B32>;
1212def S_FLBIT_I32_B64_vi : SOP1_Real_vi <0x13, S_FLBIT_I32_B64>;
1213def S_FLBIT_I32_vi : SOP1_Real_vi <0x14, S_FLBIT_I32>;
1214def S_FLBIT_I32_I64_vi : SOP1_Real_vi <0x15, S_FLBIT_I32_I64>;
1215def S_SEXT_I32_I8_vi : SOP1_Real_vi <0x16, S_SEXT_I32_I8>;
1216def S_SEXT_I32_I16_vi : SOP1_Real_vi <0x17, S_SEXT_I32_I16>;
1217def S_BITSET0_B32_vi : SOP1_Real_vi <0x18, S_BITSET0_B32>;
1218def S_BITSET0_B64_vi : SOP1_Real_vi <0x19, S_BITSET0_B64>;
1219def S_BITSET1_B32_vi : SOP1_Real_vi <0x1a, S_BITSET1_B32>;
1220def S_BITSET1_B64_vi : SOP1_Real_vi <0x1b, S_BITSET1_B64>;
1221def S_GETPC_B64_vi : SOP1_Real_vi <0x1c, S_GETPC_B64>;
1222def S_SETPC_B64_vi : SOP1_Real_vi <0x1d, S_SETPC_B64>;
1223def S_SWAPPC_B64_vi : SOP1_Real_vi <0x1e, S_SWAPPC_B64>;
1224def S_RFE_B64_vi : SOP1_Real_vi <0x1f, S_RFE_B64>;
1225def S_AND_SAVEEXEC_B64_vi : SOP1_Real_vi <0x20, S_AND_SAVEEXEC_B64>;
1226def S_OR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x21, S_OR_SAVEEXEC_B64>;
1227def S_XOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x22, S_XOR_SAVEEXEC_B64>;
1228def S_ANDN2_SAVEEXEC_B64_vi: SOP1_Real_vi <0x23, S_ANDN2_SAVEEXEC_B64>;
1229def S_ORN2_SAVEEXEC_B64_vi : SOP1_Real_vi <0x24, S_ORN2_SAVEEXEC_B64>;
1230def S_NAND_SAVEEXEC_B64_vi : SOP1_Real_vi <0x25, S_NAND_SAVEEXEC_B64>;
1231def S_NOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x26, S_NOR_SAVEEXEC_B64>;
1232def S_XNOR_SAVEEXEC_B64_vi : SOP1_Real_vi <0x27, S_XNOR_SAVEEXEC_B64>;
1233def S_QUADMASK_B32_vi : SOP1_Real_vi <0x28, S_QUADMASK_B32>;
1234def S_QUADMASK_B64_vi : SOP1_Real_vi <0x29, S_QUADMASK_B64>;
1235def S_MOVRELS_B32_vi : SOP1_Real_vi <0x2a, S_MOVRELS_B32>;
1236def S_MOVRELS_B64_vi : SOP1_Real_vi <0x2b, S_MOVRELS_B64>;
1237def S_MOVRELD_B32_vi : SOP1_Real_vi <0x2c, S_MOVRELD_B32>;
1238def S_MOVRELD_B64_vi : SOP1_Real_vi <0x2d, S_MOVRELD_B64>;
1239def S_CBRANCH_JOIN_vi : SOP1_Real_vi <0x2e, S_CBRANCH_JOIN>;
1240def S_MOV_REGRD_B32_vi : SOP1_Real_vi <0x2f, S_MOV_REGRD_B32>;
1241def S_ABS_I32_vi : SOP1_Real_vi <0x30, S_ABS_I32>;
1242def S_MOV_FED_B32_vi : SOP1_Real_vi <0x31, S_MOV_FED_B32>;
Matt Arsenaultcc88ce32016-10-12 18:00:51 +00001243def S_SET_GPR_IDX_IDX_vi : SOP1_Real_vi <0x32, S_SET_GPR_IDX_IDX>;
Valery Pykhtina34fb492016-08-30 15:20:31 +00001244
1245def S_ADD_U32_vi : SOP2_Real_vi <0x00, S_ADD_U32>;
1246def S_ADD_I32_vi : SOP2_Real_vi <0x02, S_ADD_I32>;
1247def S_SUB_U32_vi : SOP2_Real_vi <0x01, S_SUB_U32>;
1248def S_SUB_I32_vi : SOP2_Real_vi <0x03, S_SUB_I32>;
1249def S_ADDC_U32_vi : SOP2_Real_vi <0x04, S_ADDC_U32>;
1250def S_SUBB_U32_vi : SOP2_Real_vi <0x05, S_SUBB_U32>;
1251def S_MIN_I32_vi : SOP2_Real_vi <0x06, S_MIN_I32>;
1252def S_MIN_U32_vi : SOP2_Real_vi <0x07, S_MIN_U32>;
1253def S_MAX_I32_vi : SOP2_Real_vi <0x08, S_MAX_I32>;
1254def S_MAX_U32_vi : SOP2_Real_vi <0x09, S_MAX_U32>;
1255def S_CSELECT_B32_vi : SOP2_Real_vi <0x0a, S_CSELECT_B32>;
1256def S_CSELECT_B64_vi : SOP2_Real_vi <0x0b, S_CSELECT_B64>;
1257def S_AND_B32_vi : SOP2_Real_vi <0x0c, S_AND_B32>;
1258def S_AND_B64_vi : SOP2_Real_vi <0x0d, S_AND_B64>;
1259def S_OR_B32_vi : SOP2_Real_vi <0x0e, S_OR_B32>;
1260def S_OR_B64_vi : SOP2_Real_vi <0x0f, S_OR_B64>;
1261def S_XOR_B32_vi : SOP2_Real_vi <0x10, S_XOR_B32>;
1262def S_XOR_B64_vi : SOP2_Real_vi <0x11, S_XOR_B64>;
1263def S_ANDN2_B32_vi : SOP2_Real_vi <0x12, S_ANDN2_B32>;
1264def S_ANDN2_B64_vi : SOP2_Real_vi <0x13, S_ANDN2_B64>;
1265def S_ORN2_B32_vi : SOP2_Real_vi <0x14, S_ORN2_B32>;
1266def S_ORN2_B64_vi : SOP2_Real_vi <0x15, S_ORN2_B64>;
1267def S_NAND_B32_vi : SOP2_Real_vi <0x16, S_NAND_B32>;
1268def S_NAND_B64_vi : SOP2_Real_vi <0x17, S_NAND_B64>;
1269def S_NOR_B32_vi : SOP2_Real_vi <0x18, S_NOR_B32>;
1270def S_NOR_B64_vi : SOP2_Real_vi <0x19, S_NOR_B64>;
1271def S_XNOR_B32_vi : SOP2_Real_vi <0x1a, S_XNOR_B32>;
1272def S_XNOR_B64_vi : SOP2_Real_vi <0x1b, S_XNOR_B64>;
1273def S_LSHL_B32_vi : SOP2_Real_vi <0x1c, S_LSHL_B32>;
1274def S_LSHL_B64_vi : SOP2_Real_vi <0x1d, S_LSHL_B64>;
1275def S_LSHR_B32_vi : SOP2_Real_vi <0x1e, S_LSHR_B32>;
1276def S_LSHR_B64_vi : SOP2_Real_vi <0x1f, S_LSHR_B64>;
1277def S_ASHR_I32_vi : SOP2_Real_vi <0x20, S_ASHR_I32>;
1278def S_ASHR_I64_vi : SOP2_Real_vi <0x21, S_ASHR_I64>;
1279def S_BFM_B32_vi : SOP2_Real_vi <0x22, S_BFM_B32>;
1280def S_BFM_B64_vi : SOP2_Real_vi <0x23, S_BFM_B64>;
1281def S_MUL_I32_vi : SOP2_Real_vi <0x24, S_MUL_I32>;
1282def S_BFE_U32_vi : SOP2_Real_vi <0x25, S_BFE_U32>;
1283def S_BFE_I32_vi : SOP2_Real_vi <0x26, S_BFE_I32>;
1284def S_BFE_U64_vi : SOP2_Real_vi <0x27, S_BFE_U64>;
1285def S_BFE_I64_vi : SOP2_Real_vi <0x28, S_BFE_I64>;
1286def S_CBRANCH_G_FORK_vi : SOP2_Real_vi <0x29, S_CBRANCH_G_FORK>;
1287def S_ABSDIFF_I32_vi : SOP2_Real_vi <0x2a, S_ABSDIFF_I32>;
Matt Arsenault9be7b0d2017-02-27 18:49:11 +00001288def S_PACK_LL_B32_B16_vi : SOP2_Real_vi <0x32, S_PACK_LL_B32_B16>;
1289def S_PACK_LH_B32_B16_vi : SOP2_Real_vi <0x33, S_PACK_LH_B32_B16>;
1290def S_PACK_HH_B32_B16_vi : SOP2_Real_vi <0x34, S_PACK_HH_B32_B16>;
Dmitry Preobrazhensky14104e02017-04-12 17:10:07 +00001291def S_RFE_RESTORE_B64_vi : SOP2_Real_vi <0x2b, S_RFE_RESTORE_B64>;
Valery Pykhtina34fb492016-08-30 15:20:31 +00001292
1293def S_MOVK_I32_vi : SOPK_Real_vi <0x00, S_MOVK_I32>;
1294def S_CMOVK_I32_vi : SOPK_Real_vi <0x01, S_CMOVK_I32>;
1295def S_CMPK_EQ_I32_vi : SOPK_Real_vi <0x02, S_CMPK_EQ_I32>;
1296def S_CMPK_LG_I32_vi : SOPK_Real_vi <0x03, S_CMPK_LG_I32>;
1297def S_CMPK_GT_I32_vi : SOPK_Real_vi <0x04, S_CMPK_GT_I32>;
1298def S_CMPK_GE_I32_vi : SOPK_Real_vi <0x05, S_CMPK_GE_I32>;
1299def S_CMPK_LT_I32_vi : SOPK_Real_vi <0x06, S_CMPK_LT_I32>;
1300def S_CMPK_LE_I32_vi : SOPK_Real_vi <0x07, S_CMPK_LE_I32>;
1301def S_CMPK_EQ_U32_vi : SOPK_Real_vi <0x08, S_CMPK_EQ_U32>;
1302def S_CMPK_LG_U32_vi : SOPK_Real_vi <0x09, S_CMPK_LG_U32>;
1303def S_CMPK_GT_U32_vi : SOPK_Real_vi <0x0A, S_CMPK_GT_U32>;
1304def S_CMPK_GE_U32_vi : SOPK_Real_vi <0x0B, S_CMPK_GE_U32>;
1305def S_CMPK_LT_U32_vi : SOPK_Real_vi <0x0C, S_CMPK_LT_U32>;
1306def S_CMPK_LE_U32_vi : SOPK_Real_vi <0x0D, S_CMPK_LE_U32>;
1307def S_ADDK_I32_vi : SOPK_Real_vi <0x0E, S_ADDK_I32>;
1308def S_MULK_I32_vi : SOPK_Real_vi <0x0F, S_MULK_I32>;
1309def S_CBRANCH_I_FORK_vi : SOPK_Real_vi <0x10, S_CBRANCH_I_FORK>;
1310def S_GETREG_B32_vi : SOPK_Real_vi <0x11, S_GETREG_B32>;
1311def S_SETREG_B32_vi : SOPK_Real_vi <0x12, S_SETREG_B32>;
1312//def S_GETREG_REGRD_B32_vi : SOPK_Real_vi <0x13, S_GETREG_REGRD_B32>; // see pseudo for comments
1313def S_SETREG_IMM32_B32_vi : SOPK_Real64<0x14, S_SETREG_IMM32_B32>,
Tom Stellard2add8a12016-09-06 20:00:26 +00001314 Select_vi<S_SETREG_IMM32_B32.Mnemonic>;