source: CLRX/CLRadeonExtender/trunk/tests/amdasm/GCNAsmOpc15.cpp @ 4863

Last change on this file since 4863 was 4863, checked in by matszpk, 7 weeks ago

CLRadeonExtender: GCNAsm: MIMG instruction testcases (GFX10).

File size: 242.9 KB
Line 
1/*
2 *  CLRadeonExtender - Unofficial OpenCL Radeon Extensions Library
3 *  Copyright (C) 2014-2018 Mateusz Szpakowski
4 *
5 *  This library is free software; you can redistribute it and/or
6 *  modify it under the terms of the GNU Lesser General Public
7 *  License as published by the Free Software Foundation; either
8 *  version 2.1 of the License, or (at your option) any later version.
9 *
10 *  This library is distributed in the hope that it will be useful,
11 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
12 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13 *  Lesser General Public License for more details.
14 *
15 *  You should have received a copy of the GNU Lesser General Public
16 *  License along with this library; if not, write to the Free Software
17 *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
18 */
19
20#include <CLRX/Config.h>
21#include "GCNAsmOpc.h"
22
23const GCNAsmOpcodeCase encGCN15OpcodeCases[] =
24{
25    { "    s_add_u32  flat_scratch_lo, s4, s61", 0, 0, false, false,
26        "test.s:1:16: Error: Expected 1 scalar register\n" },
27    { "    s_add_u32  flat_scratch_hi, s4, s61", 0, 0, false, false,
28        "test.s:1:16: Error: Expected 1 scalar register\n" },
29    { "    s_add_u32  xnack_mask_lo, s4, s61", 0, 0, false, false,
30        "test.s:1:16: Error: Expected 1 scalar register\n" },
31    { "    s_add_u32  xnack_mask_hi, s4, s61", 0, 0, false, false,
32        "test.s:1:16: Error: Expected 1 scalar register\n" },
33    { "        s_add_u32       s21, s4, s61\n", 0x80153d04U, 0, false, true, "" },
34    { "        s_add_u32       s21, s4, s100\n", 0x80156404U, 0, false, true, "" },
35    { "        s_add_u32       s21, s4, s102\n", 0x80156604U, 0, false, true, "" },
36    { "        s_add_u32       s21, s4, s103\n", 0x80156704U, 0, false, true, "" },
37    { "        s_add_u32       s21, s4, s104\n", 0x80156804U, 0, false, true, "" },
38    { "        s_add_u32       s21, s4, s105\n", 0x80156904U, 0, false, true, "" },
39    { "xrv = %s105; s_add_u32 s21, s4, xrv\n", 0x80156904U, 0, false, true, "" },
40    { "        s_add_u32       s21, s4, vcc_lo\n", 0x80156a04U, 0, false, true, "" },
41    { "        s_add_u32       s21, s4, vcc_hi\n", 0x80156b04U, 0, false, true, "" },
42    { "    s_add_u32  s21, 0.15915494, s61", 0x80153df8U, 0, false, true, "" },
43    { "vval=%0.15915494; s_add_u32  s21, vval, s61",
44        0x80153df8U, 0, false, true, "" },
45    { "        s_add_u32       s21, s4, null\n", 0x80157d04U, 0, false, true, "" },
46    { "        s_add_u32       s21, null, s61\n", 0x80153d7dU, 0, false, true, "" },
47    { "        s_add_u32       null, s4, s61\n", 0x807d3d04U, 0, false, true, "" },
48    { "    s_add_u32  vcc[1:1], s4, s61", 0x806b3d04U, 0, false, true, "" },
49    { "    s_add_u32  vcc[1], s4, s61", 0x806b3d04U, 0, false, true, "" },
50    { "    s_add_u32  vcc[0:0], s4, s61", 0x806a3d04U, 0, false, true, "" },
51    { "    s_add_u32  vcc[0], s4, s61", 0x806a3d04U, 0, false, true, "" },
52    { "    s_add_u32  vcc_lo, s4, s61", 0x806a3d04U, 0, false, true, "" },
53    { "    s_add_u32  vcc_hi, s4, s61", 0x806b3d04U, 0, false, true, "" },
54    { "    s_add_u32  ttmp0, s4, s61", 0x806c3d04U, 0, false, true, "" },
55    { "    s_add_u32  ttmp1, s4, s61", 0x806d3d04U, 0, false, true, "" },
56    { "    s_add_u32  ttmp[2:2], s4, s61", 0x806e3d04U, 0, false, true, "" },
57    { "    s_add_u32  ttmp12, s4, s61", 0x80783d04U, 0, false, true, "" },
58    { "    s_add_u32  ttmp15, s4, s61", 0x807b3d04U, 0, false, true, "" },
59    { "s_add_u32 ttmp16, s4, s61", 0x807b3d04U, 0, false, false,
60        "test.s:1:11: Error: TTMPRegister number out of range (0-15)\n" },
61    { "    s_add_u32  tba_lo, s4, s61", 0, 0, false, false,
62        "test.s:1:16: Error: Expected 1 scalar register\n" },
63    { "    s_add_u32  tba_hi, s4, s61", 0, 0, false, false,
64        "test.s:1:16: Error: Expected 1 scalar register\n" },
65    { "    s_add_u32  tma_lo, s4, s61", 0, 0, false, false,
66        "test.s:1:16: Error: Expected 1 scalar register\n" },
67    { "    s_add_u32  tma_hi, s4, s61", 0, 0, false, false,
68        "test.s:1:16: Error: Expected 1 scalar register\n" },
69    { "s_add_u32 s21, shared_base, s61\n", 0x80153debU, 0, false, true, "" },
70    { "s_add_u32 s21, src_shared_base, s61\n", 0x80153debU, 0, false, true, "" },
71    { "s_add_u32 s21, shared_limit, s61\n", 0x80153decU, 0, false, true, "" },
72    { "s_add_u32 s21, src_shared_limit, s61\n", 0x80153decU, 0, false, true, "" },
73    { "s_add_u32 s21, private_base, s61\n", 0x80153dedU, 0, false, true, "" },
74    { "s_add_u32 s21, src_private_base, s61\n", 0x80153dedU, 0, false, true, "" },
75    { "s_add_u32 s21, private_limit, s61\n", 0x80153deeU, 0, false, true, "" },
76    { "s_add_u32 s21, src_private_limit, s61\n", 0x80153deeU, 0, false, true, "" },
77    { "s_add_u32 s21, pops_exiting_wave_id, s61\n", 0x80153defU, 0, false, true, "" },
78    { "s_add_u32 s21, src_pops_exiting_wave_id, s61\n", 0x80153defU, 0, false, true, "" },
79    { "s_add_u32 s21, execz, s61\n", 0x80153dfcU, 0, false, true, "" },
80    { "s_add_u32 s21, src_execz, s61\n", 0x80153dfcU, 0, false, true, "" },
81    { "s_add_u32 s21, vccz, s61\n", 0x80153dfbU, 0, false, true, "" },
82    { "s_add_u32 s21, src_vccz, s61\n", 0x80153dfbU, 0, false, true, "" },
83    { "s_add_u32 s21, scc, s61\n", 0x80153dfdU, 0, false, true, "" },
84    { "s_add_u32 s21, src_scc, s61\n", 0x80153dfdU, 0, false, true, "" },
85    /* register's symbols */
86    { "zx=%s[20:23]; ss=%s4; b=%s[57:67];s_add_u32  zx[1], ss, b[4]",
87            0x80153d04U, 0, false, true, "" },
88    { "xv=2; zx=%s[xv+18:xv+19]; ss=%s[xv+2]; b=%s[xv+55:xv+65];"
89        "s_add_u32  zx[1], ss, b[4]", 0x80153d04U, 0, false, true, "" },
90    { "zx=%s[20:23]; ss=%execz; b=%s[57:67];s_add_u32  zx[1], ss, b[4]",
91            0x80153dfcU, 0, false, true, "" },
92    /* literals */
93    { "    s_add_u32  s21, s4, 0x2a", 0x8015aa04U, 0, false, true, "" },
94    { "    s_add_u32  s21, s4, -7", 0x8015c704U, 0, false, true, "" },
95    { "    s_add_u32  s21, s4, lit(-7)", 0x8015ff04U, 0xfffffff9, true, true, "" },
96    { "    s_add_u32_e64  s21, s4, -7", 0x8015ff04U, 0xfffffff9, true, true, "" },
97    { "    s_add_u32  s21, s4, lit(0)", 0x8015ff04U, 0x0, true, true, "" },
98    { "    s_add_u32  s21, s4, lit(32)", 0x8015ff04U, 0x20, true, true, "" },
99    { "    s_add_u32_e64 s21, s4, 32", 0x8015ff04U, 0x20, true, true, "" },
100    { "    s_add_u32_e64 s21, 32, s4", 0x801504ffU, 0x20, true, true, "" },
101    { "    s_add_u32  s21, s4, lit  (  32  )  ", 0x8015ff04U, 0x20, true, true, "" },
102    { "    s_add_u32  s21, s4, LiT  (  32  )  ", 0x8015ff04U, 0x20, true, true, "" },
103    { "    s_add_u32  s21, s4, lit(0.0)", 0x8015ff04U, 0x0, true, true, "" },
104    { "    s_add_u32  s21, s4, lit(-.5)", 0x8015ff04U, 0xbf000000, true, true, "" },
105    { "    s_add_u32_e64  s21, s4, -.5", 0x8015ff04U, 0xbf000000, true, true, "" },
106    { "    s_add_u32  s21, s4, lit(2.0)", 0x8015ff04U, 0x40000000, true, true, "" },
107    { "    s_add_u32  s21, s4, lit  ( 2.0 )", 0x8015ff04U, 0x40000000, true, true, "" },
108    { "    s_add_u32_e64  s21, s4, 2.0", 0x8015ff04U, 0x40000000, true, true, "" },
109    { "    s_add_u32  s21, s4, 1.", 0x8015f204U, 0, false, true, "" },
110    { "    s_add_u32  s21, s4, -1.", 0x8015f304U, 0, false, true, "" },
111    { "    s_add_u32  s21, s4, 2.", 0x8015f404U, 0, false, true, "" },
112    { "    s_add_u32  s21, s4, -2.", 0x8015f504U, 0, false, true, "" },
113    { "    s_add_u32  s21, s4, 4.", 0x8015f604U, 0, false, true, "" },
114    { "    s_add_u32  s21, s4, -4.", 0x8015f704U, 0, false, true, "" },
115    { "    s_add_u32  s21, s4, 1234", 0x8015ff04U, 1234, true, true, "" },
116    { "    s_add_u32  s21, 1234, s4", 0x801504ffU, 1234, true, true, "" },
117    { "    s_add_u32  s21, s4, -4.5", 0x8015ff04U, 0xc0900000U, true, true, "" },
118    { "    s_add_u32  s21, s4, -4.5s", 0x8015ff04U, 0xc0900000U, true, true, "" },
119    { "    s_add_u32  s21, s4, -4.5h", 0x8015ff04U, 0xc480U, true, true, "" },
120    { "    s_add_u32  s21, s4, 3e-7", 0x8015ff04U, 0x34a10fb0U, true, true, "" },
121    /* 64-bit registers and literals */
122    { "    s_xor_b64 s[22:23], s[4:5], s[62:63]\n", 0x89963e04U, 0, false, true, "" },
123    { "s1=22; s2=4;s3=62;s_xor_b64 s[s1:s1+1], s[s2:s2+1], s[s3:s3+1]\n",
124        0x89963e04U, 0, false, true, "" },
125    { "    s_xor_b64 vcc, s[4:5], s[62:63]\n", 0x89ea3e04U, 0, false, true, "" },
126    { "    s_xor_b64 vcc[0:1], s[4:5], s[62:63]\n", 0x89ea3e04U, 0, false, true, "" },
127    { "    s_xor_b64 s[22:23], 1.0, s[62:63]\n", 0x89963ef2U, 0, false, true, "" },
128    { "    s_xor_b64 s[22:23], vccz, s[62:63]\n", 0x89963efbU, 0, false, true, "" },
129    { "    s_xor_b64 s[22:23], execz, s[62:63]\n", 0x89963efcU, 0, false, true, "" },
130    { "    s_xor_b64 s[22:23], scc, s[62:63]\n", 0x89963efdU, 0, false, true, "" },
131    /* SOP2 encodings */
132    { "    s_sub_u32  s21, s4, s61", 0x80953d04U, 0, false, true, "" },
133    { "    s_sub_u32_e32  s21, s4, s61", 0x80953d04U, 0, false, true, "" },
134    { "    s_add_i32  s21, s4, s61", 0x81153d04U, 0, false, true, "" },
135    { "    s_sub_i32  s21, s4, s61", 0x81953d04U, 0, false, true, "" },
136    { "    s_addc_u32  s21, s4, s61", 0x82153d04U, 0, false, true, "" },
137    { "    s_subb_u32  s21, s4, s61", 0x82953d04U, 0, false, true, "" },
138    { "    s_min_i32  s21, s4, s61", 0x83153d04U, 0, false, true, "" },
139    { "    s_min_u32  s21, s4, s61", 0x83953d04U, 0, false, true, "" },
140    { "    s_max_i32  s21, s4, s61", 0x84153d04U, 0, false, true, "" },
141    { "    s_max_u32  s21, s4, s61", 0x84953d04U, 0, false, true, "" },
142    { "    s_cselect_b32  s21, s4, s61", 0x85153d04U, 0, false, true, "" },
143    { "    s_cselect_b64  s[20:21], s[4:5], s[62:63]", 0x85943e04U, 0, false, true, "" },
144    { "    s_and_b32  s21, s4, s61", 0x87153d04U, 0, false, true, "" },
145    { "    s_and_b64  s[20:21], s[4:5], s[62:63]", 0x87943e04U, 0, false, true, "" },
146    { "    s_or_b32  s21, s4, s61", 0x88153d04U, 0, false, true, "" },
147    { "    s_or_b64  s[20:21], s[4:5], s[62:63]", 0x88943e04U, 0, false, true, "" },
148    { "    s_xor_b32  s21, s4, s61", 0x89153d04U, 0, false, true, "" },
149    { "    s_xor_b64  s[20:21], s[4:5], s[62:63]", 0x89943e04U, 0, false, true, "" },
150    { "    s_andn2_b32  s21, s4, s61", 0x8a153d04U, 0, false, true, "" },
151    { "    s_andn2_b64  s[20:21], s[4:5], s[62:63]", 0x8a943e04U, 0, false, true, "" },
152    { "    s_orn2_b32  s21, s4, s61", 0x8b153d04U, 0, false, true, "" },
153    { "    s_orn2_b64  s[20:21], s[4:5], s[62:63]", 0x8b943e04U, 0, false, true, "" },
154    { "    s_nand_b32  s21, s4, s61", 0x8c153d04U, 0, false, true, "" },
155    { "    s_nand_b64  s[20:21], s[4:5], s[62:63]", 0x8c943e04U, 0, false, true, "" },
156    { "    s_nor_b32  s21, s4, s61", 0x8d153d04U, 0, false, true, "" },
157    { "    s_nor_b64  s[20:21], s[4:5], s[62:63]", 0x8d943e04U, 0, false, true, "" },
158    { "    s_xnor_b32  s21, s4, s61", 0x8e153d04U, 0, false, true, "" },
159    { "    s_xnor_b64  s[20:21], s[4:5], s[62:63]", 0x8e943e04U, 0, false, true, "" },
160    { "    s_lshl_b32  s21, s4, s61", 0x8f153d04U, 0, false, true, "" },
161    { "    s_lshl_b64  s[20:21], s[4:5], s61", 0x8f943d04U, 0, false, true, "" },
162    { "    s_lshr_b32  s21, s4, s61", 0x90153d04U, 0, false, true, "" },
163    { "    s_lshr_b64  s[20:21], s[4:5], s61", 0x90943d04U, 0, false, true, "" },
164    { "    s_ashr_i32  s21, s4, s61", 0x91153d04U, 0, false, true, "" },
165    { "    s_ashr_i64  s[20:21], s[4:5], s61", 0x91943d04U, 0, false, true, "" },
166    { "    s_bfm_b32  s21, s4, s61", 0x92153d04U, 0, false, true, "" },
167    { "    s_bfm_b64  s[20:21], s4, s62", 0x92943e04U, 0, false, true, "" },
168    { "    s_mul_i32  s21, s4, s61", 0x93153d04U, 0, false, true, "" },
169    { "    s_bfe_u32  s21, s4, s61", 0x93953d04U, 0, false, true, "" },
170    { "    s_bfe_i32  s21, s4, s61", 0x94153d04U, 0, false, true, "" },
171    { "    s_bfe_u64  s[20:21], s[4:5], s61", 0x94943d04U, 0, false, true, "" },
172    { "    s_bfe_i64  s[20:21], s[4:5], s61", 0x95143d04U, 0, false, true, "" },
173    { "    s_cbranch_g_fork  s[4:5], s[62:63]", 0, 0, false, false,
174        "test.s:1:5: Error: Unknown instruction\n" },
175    { "    s_absdiff_i32  s21, s4, s61", 0x96153d04U, 0, false, true, "" },
176    { "        s_lshl1_add_u32 s21, s4, s61\n", 0x97153d04U, 0, false, true, "" },
177    { "        s_lshl2_add_u32 s21, s4, s61\n", 0x97953d04U, 0, false, true, "" },
178    { "        s_lshl3_add_u32 s21, s4, s61\n", 0x98153d04U, 0, false, true, "" },
179    { "        s_lshl4_add_u32 s21, s4, s61\n", 0x98953d04U, 0, false, true, "" },
180    { "        s_pack_ll_b32_b16 s21, s4, s61\n", 0x99153d04U, 0, false, true, "" },
181    { "        s_pack_lh_b32_b16 s21, s4, s61\n", 0x99953d04U, 0, false, true, "" },
182    { "        s_pack_hh_b32_b16 s21, s4, s61\n", 0x9a153d04U, 0, false, true, "" },
183    { "        s_mul_hi_u32    s21, s4, s61\n", 0x9a953d04U, 0, false, true, "" },
184    { "        s_mul_hi_i32    s21, s4, s61\n", 0x9b153d04U, 0, false, true, "" },
185    /* SOP1 */
186    { "    s_mov_b32  s86, s20", 0xbed60314U, 0, false, true, "" },
187    { "    s_mov_b32_e64  s86, -4", 0xbed603ffU, 0xfffffffcU, true, true, "" },
188    { "    s_mov_b32  s86, 0xadbc", 0xbed603ff, 0xadbc, true, true, "" },
189    { "    s_mov_b32  s86, xx; xx=0xadbc", 0xbed603ff, 0xadbc, true, true, "" },
190    { "    s_mov_b64  s[86:87], s[20:21]", 0xbed60414U, 0, false, true, "" },
191    { "    s_cmov_b32  s86, s20", 0xbed60514U, 0, false, true, "" },
192    { "    s_cmov_b64  s[86:87], s[20:21]", 0xbed60614U, 0, false, true, "" },
193    { "    s_not_b32  s86, s20", 0xbed60714U, 0, false, true, "" },
194    { "    s_not_b64  s[86:87], s[20:21]", 0xbed60814U, 0, false, true, "" },
195    { "    s_wqm_b32  s86, s20", 0xbed60914U, 0, false, true, "" },
196    { "    s_wqm_b64  s[86:87], s[20:21]", 0xbed60a14U, 0, false, true, "" },
197    { "    s_brev_b32  s86, s20", 0xbed60b14U, 0, false, true, "" },
198    { "    s_brev_b64  s[86:87], s[20:21]", 0xbed60c14U, 0, false, true, "" },
199    { "    s_bcnt0_i32_b32  s86, s20", 0xbed60d14U, 0, false, true, "" },
200    { "    s_bcnt0_i32_b64  s86, s[20:21]", 0xbed60e14U, 0, false, true, "" },
201    { "    s_bcnt1_i32_b32  s86, s20", 0xbed60f14U, 0, false, true, "" },
202    { "    s_bcnt1_i32_b64  s86, s[20:21]", 0xbed61014U, 0, false, true, "" },
203    { "    s_ff0_i32_b32  s86, s20", 0xbed61114U, 0, false, true, "" },
204    { "    s_ff0_i32_b64  s86, s[20:21]", 0xbed61214U, 0, false, true, "" },
205    { "    s_ff1_i32_b32  s86, s20", 0xbed61314U, 0, false, true, "" },
206    { "    s_ff1_i32_b64  s86, s[20:21]", 0xbed61414U, 0, false, true, "" },
207    { "    s_flbit_i32_b32  s86, s20", 0xbed61514U, 0, false, true, "" },
208    { "    s_flbit_i32_b64  s86, s[20:21]", 0xbed61614U, 0, false, true, "" },
209    { "    s_flbit_i32  s86, s20", 0xbed61714U, 0, false, true, "" },
210    { "    s_flbit_i32_i64  s86, s[20:21]", 0xbed61814U, 0, false, true, "" },
211    { "    s_sext_i32_i8  s86, s20", 0xbed61914U, 0, false, true, "" },
212    { "    s_sext_i32_i16  s86, s20", 0xbed61a14U, 0, false, true, "" },
213    { "    s_bitset0_b32  s86, s20", 0xbed61b14U, 0, false, true, "" },
214    { "    s_bitset0_b64  s[86:87], s20", 0xbed61c14U, 0, false, true, "" },
215    { "    s_bitset1_b32  s86, s20", 0xbed61d14U, 0, false, true, "" },
216    { "    s_bitset1_b64  s[86:87], s20", 0xbed61e14U, 0, false, true, "" },
217    { "    s_getpc_b64  s[86:87]", 0xbed61f00U, 0, false, true, "" },
218    { "    s_setpc_b64  s[20:21]", 0xbe802014U, 0, false, true, "" },
219    { "    s_swappc_b64  s[86:87], s[20:21]", 0xbed62114U, 0, false, true, "" },
220    { "    s_rfe_b64  s[20:21]", 0xbe802214U, 0, false, true, "" },
221    { "    s_and_saveexec_b64 s[86:87], s[20:21]", 0xbed62414U, 0, false, true, "" },
222    { "    s_or_saveexec_b64 s[86:87], s[20:21]", 0xbed62514U, 0, false, true, "" },
223    { "    s_xor_saveexec_b64 s[86:87], s[20:21]", 0xbed62614U, 0, false, true, "" },
224    { "    s_andn2_saveexec_b64 s[86:87], s[20:21]", 0xbed62714U, 0, false, true, "" },
225    { "    s_orn2_saveexec_b64 s[86:87], s[20:21]", 0xbed62814U, 0, false, true, "" },
226    { "    s_nand_saveexec_b64 s[86:87], s[20:21]", 0xbed62914U, 0, false, true, "" },
227    { "    s_nor_saveexec_b64 s[86:87], s[20:21]", 0xbed62a14U, 0, false, true, "" },
228    { "    s_xnor_saveexec_b64 s[86:87], s[20:21]", 0xbed62b14U, 0, false, true, "" },
229    { "    s_quadmask_b32  s86, s20",  0xbed62c14U, 0, false, true, "" },
230    { "    s_quadmask_b64  s[86:87], s[20:21]",  0xbed62d14U, 0, false, true, "" },
231    { "    s_movrels_b32  s86, s20",  0xbed62e14U, 0, false, true, "" },
232    { "    s_movrels_b64  s[86:87], s[20:21]",  0xbed62f14U, 0, false, true, "" },
233    { "    s_movreld_b32  s86, s20",  0xbed63014U, 0, false, true, "" },
234    { "    s_movreld_b64  s[86:87], s[20:21]",  0xbed63114U, 0, false, true, "" },
235    { "    s_cbranch_join  s20", 0xbe803214U, 0, false, false,
236        "test.s:1:5: Error: Unknown instruction\n" },
237    { "    s_mov_regrd_b32 s86, s20", 0xbed63314U, 0, false, false,
238        "test.s:1:5: Error: Unknown instruction\n" },
239    { "    s_abs_i32  s86, s20", 0xbed63414U, 0, false, true, "" },
240    { "    s_mov_fed_b32  s86, s20", 0xbed63514U, 0, false, true, "" },
241    { "    s_andn1_saveexec_b64 s[86:87], s[20:21]", 0xbed63714U, 0, false, true, "" },
242    { "    s_orn1_saveexec_b64 s[86:87], s[20:21]", 0xbed63814U, 0, false, true, "" },
243    { "    s_andn1_wrexec_b64 s[86:87], s[20:21]", 0xbed63914U, 0, false, true, "" },
244    { "    s_andn2_wrexec_b64 s[86:87], s[20:21]", 0xbed63a14U, 0, false, true, "" },
245    { "s_bitreplicate_b64_b32 s[86:87], s20\n", 0xbed63b14U, 0, false, true, "" },
246    { "    s_and_saveexec_b32 s86, s20", 0xbed63c14U, 0, false, true, "" },
247    { "    s_or_saveexec_b32 s86, s20", 0xbed63d14U, 0, false, true, "" },
248    { "    s_xor_saveexec_b32 s86, s20", 0xbed63e14U, 0, false, true, "" },
249    { "    s_andn2_saveexec_b32 s86, s20", 0xbed63f14U, 0, false, true, "" },
250    { "    s_orn2_saveexec_b32 s86, s20", 0xbed64014U, 0, false, true, "" },
251    { "    s_nand_saveexec_b32 s86, s20", 0xbed64114U, 0, false, true, "" },
252    { "    s_nor_saveexec_b32 s86, s20", 0xbed64214U, 0, false, true, "" },
253    { "    s_xnor_saveexec_b32 s86, s20", 0xbed64314U, 0, false, true, "" },
254    { "    s_andn1_saveexec_b32 s86, s20", 0xbed64414U, 0, false, true, "" },
255    { "    s_orn1_saveexec_b32 s86, s20", 0xbed64514U, 0, false, true, "" },
256    { "    s_andn1_wrexec_b32 s86, s20", 0xbed64614U, 0, false, true, "" },
257    { "    s_andn2_wrexec_b32 s86, s20", 0xbed64714U, 0, false, true, "" },
258    { "    s_movrelsd_2_b32 s86, s20", 0xbed64914U, 0, false, true, "" },
259    /* SOPC */
260    { "    s_cmp_eq_i32  s29, s69", 0xbf00451dU, 0, false, true, "" },
261    { "    s_cmp_eq_i32_e64  s29, 51", 0xbf00ff1dU, 51, true, true, "" },
262    { "    s_cmp_eq_i32_e64  51, s69", 0xbf0045ffU, 51, true, true, "" },
263    { "    s_cmp_eq_i32  12222, s69", 0xbf0045ffU, 12222, true, true, "" },
264    { "    s_cmp_eq_i32  xx, s69; xx=12222", 0xbf0045ffU, 12222, true, true, "" },
265    { "    s_cmp_eq_i32  s29, 32545", 0xbf00ff1dU, 32545, true, true, "" },
266    { "    s_cmp_eq_i32  s29, xx; xx=32545", 0xbf00ff1dU, 32545, true, true, "" },
267    { "    s_cmp_lg_i32  s29, s69", 0xbf01451dU, 0, false, true, "" },
268    { "    s_cmp_gt_i32  s29, s69", 0xbf02451dU, 0, false, true, "" },
269    { "    s_cmp_ge_i32  s29, s69", 0xbf03451dU, 0, false, true, "" },
270    { "    s_cmp_lt_i32  s29, s69", 0xbf04451dU, 0, false, true, "" },
271    { "    s_cmp_le_i32  s29, s69", 0xbf05451dU, 0, false, true, "" },
272    { "    s_cmp_eq_u32  s29, s69", 0xbf06451dU, 0, false, true, "" },
273    { "    s_cmp_lg_u32  s29, s69", 0xbf07451dU, 0, false, true, "" },
274    { "    s_cmp_gt_u32  s29, s69", 0xbf08451dU, 0, false, true, "" },
275    { "    s_cmp_ge_u32  s29, s69", 0xbf09451dU, 0, false, true, "" },
276    { "    s_cmp_lt_u32  s29, s69", 0xbf0a451dU, 0, false, true, "" },
277    { "    s_cmp_le_u32  s29, s69", 0xbf0b451dU, 0, false, true, "" },
278    { "    s_bitcmp0_b32  s29, s69", 0xbf0c451dU, 0, false, true, "" },
279    { "    s_bitcmp1_b32  s29, s69", 0xbf0d451dU, 0, false, true, "" },
280    { "    s_bitcmp0_b64  s[28:29], s69", 0xbf0e451cU, 0, false, true, "" },
281    { "    s_bitcmp1_b64  s[28:29], s69", 0xbf0f451cU, 0, false, true, "" },
282    { "    s_setvskip  s29, s69", 0xbf10451dU, 0, false, false,
283        "test.s:1:5: Error: Unknown instruction\n" },
284    { "    s_cmp_eq_u64  s[28:29], s[68:69]", 0xbf12441cU, 0, false, true, "" },
285    { "    s_cmp_lg_u64  s[28:29], s[68:69]", 0xbf13441cU, 0, false, true, "" },
286    { "    s_cmp_ne_u64  s[28:29], s[68:69]", 0xbf13441cU, 0, false, true, "" },
287    /* SOPK */
288    { "    s_movk_i32  s43, 0xd3b9", 0xb02bd3b9U, 0, false, true, "" },
289    { "xc = 0xd4ba\n    s_movk_i32  s43, xc", 0xb02bd4baU, 0, false, true, "" },
290    { "    s_movk_i32  s43, xc; xc = 0xd4ba", 0xb02bd4baU, 0, false, true, "" },
291    { "xc = 0x11d4ba\n    s_movk_i32  s43, xc", 0xb02bd4baU, 0, false, true,
292        "test.s:2:22: Warning: Value 0x11d4ba truncated to 0xd4ba\n" },
293    { "    s_movk_i32  s43, xc; xc = 0x22d4ba", 0xb02bd4baU, 0, false, true,
294        "test.s:1:22: Warning: Value 0x22d4ba truncated to 0xd4ba\n" },
295    { "    s_version 4331", 0xb08010ebU, 0, false, true, "" },
296    { "    s_cmovk_i32  s43, 0xd3b9", 0xb12bd3b9U, 0, false, true, "" },
297    { "    s_cmpk_eq_i32  s43, 0xd3b9", 0xb1abd3b9U, 0, false, true, "" },
298    { "    s_cmpk_lg_i32  s43, 0xd3b9", 0xb22bd3b9U, 0, false, true, "" },
299    { "    s_cmpk_gt_i32  s43, 0xd3b9", 0xb2abd3b9U, 0, false, true, "" },
300    { "    s_cmpk_ge_i32  s43, 0xd3b9", 0xb32bd3b9U, 0, false, true, "" },
301    { "    s_cmpk_lt_i32  s43, 0xd3b9", 0xb3abd3b9U, 0, false, true, "" },
302    { "    s_cmpk_le_i32  s43, 0xd3b9", 0xb42bd3b9U, 0, false, true, "" },
303    { "    s_cmpk_eq_u32  s43, 0xd3b9", 0xb4abd3b9U, 0, false, true, "" },
304    { "    s_cmpk_lg_u32  s43, 0xd3b9", 0xb52bd3b9U, 0, false, true, "" },
305    { "    s_cmpk_gt_u32  s43, 0xd3b9", 0xb5abd3b9U, 0, false, true, "" },
306    { "    s_cmpk_ge_u32  s43, 0xd3b9", 0xb62bd3b9U, 0, false, true, "" },
307    { "    s_cmpk_lt_u32  s43, 0xd3b9", 0xb6abd3b9U, 0, false, true, "" },
308    { "    s_cmpk_le_u32  s43, 0xd3b9", 0xb72bd3b9U, 0, false, true, "" },
309    { "    s_addk_i32  s43, 0xd3b9", 0xb7abd3b9U, 0, false, true, "" },
310    { "    s_mulk_i32  s43, 0xd3b9", 0xb82bd3b9U, 0, false, true, "" },
311    { "    s_cbranch_i_fork s[44:45], xxxx-8\nxxxx:\n", 0, 0, false, false,
312        "test.s:1:5: Error: Unknown instruction\n" },
313    { "    s_getreg_b32    s43, hwreg(mode, 0, 1)", 0xb92b0001U, 0, false, true, "" },
314    { "    s_getreg_b32    s43, hwreg  (mode, 0, 1)", 0xb92b0001U, 0, false, true, "" },
315    { "    s_getreg_b32    s43, hwreg  (mode  ,   0  , 1  )",
316                    0xb92b0001U, 0, false, true, "" },
317    { "    s_getreg_b32    s43, hwreg(HWREG_MODE, 0, 1)", 0xb92b0001U, 0, false, true, "" },
318    { "    s_getreg_b32    s43, hwreg(status, 0, 1)", 0xb92b0002U, 0, false, true, "" },
319    { "    s_getreg_b32    s43, hwreg(HWREG_STATUS, 0, 1)",
320        0xb92b0002U, 0, false, true, "" },
321    { "    s_getreg_b32    s43, hwreg(trapsts, 0, 1)", 0xb92b0003U, 0, false, true, "" },
322    { "    s_getreg_b32    s43, hwreg(HWREG_TRAPSTS, 0, 1)",
323                    0xb92b0003U, 0, false, true, "" },
324    { "    s_getreg_b32    s43, hwreg(hw_id, 0, 1)", 0xb92b0004U, 0, false, true, "" },
325    { "    s_getreg_b32    s43, hwreg(HWREG_HW_ID, 0, 1)",
326                    0xb92b0004U, 0, false, true, "" },
327    { "    s_getreg_b32    s43, hwreg(gpr_alloc, 0, 1)", 0xb92b0005U, 0, false, true, "" },
328    { "    s_getreg_b32    s43, hwreg(HWREG_GPR_ALLOC, 0, 1)",
329                    0xb92b0005U, 0, false, true, "" },
330    { "    s_getreg_b32    s43, hwreg(lds_alloc, 0, 1)", 0xb92b0006U, 0, false, true, "" },
331    { "    s_getreg_b32    s43, hwreg(HWREG_LDS_ALLOC, 0, 1)",
332                    0xb92b0006U, 0, false, true, "" },
333    { "    s_getreg_b32    s43, hwreg(ib_sts, 0, 1)", 0xb92b0007U, 0, false, true, "" },
334    { "    s_getreg_b32    s43, hwreg(HWREG_IB_STS, 0, 1)",
335                    0xb92b0007U, 0, false, true, "" },
336    { "    s_getreg_b32    s43, hwreg(pc_lo, 0, 1)", 0xb92b0008U, 0, false, true, "" },
337    { "    s_getreg_b32    s43, hwreg(HWREG_PC_LO, 0, 1)",
338                    0xb92b0008U, 0, false, true, "" },
339    { "    s_getreg_b32    s43, hwreg(pc_hi, 0, 1)", 0xb92b0009U, 0, false, true, "" },
340    { "    s_getreg_b32    s43, hwreg(HWREG_PC_HI, 0, 1)",
341                    0xb92b0009U, 0, false, true, "" },
342    { "    s_getreg_b32    s43, hwreg(inst_dw0, 0, 1)", 0xb92b000aU, 0, false, true, "" },
343    { "    s_getreg_b32    s43, hwreg(HWREG_INST_DW0, 0, 1)",
344                    0xb92b000aU, 0, false, true, "" },
345    { "    s_getreg_b32    s43, hwreg(inst_dw1, 0, 1)", 0xb92b000bU, 0, false, true, "" },
346    { "    s_getreg_b32    s43, hwreg(HWREG_INST_DW1, 0, 1)",
347                    0xb92b000bU, 0, false, true, "" },
348    { "    s_getreg_b32    s43, hwreg(ib_dbg0, 0, 1)", 0xb92b000cU, 0, false, true, "" },
349    { "    s_getreg_b32    s43, hwreg(HWREG_IB_DBG0, 0, 1)",
350                    0xb92b000cU, 0, false, true, "" },
351    { "    s_getreg_b32    s43, hwreg(trapsts, 10, 1)", 0xb92b0283u, 0, false, true, "" },
352    { "    s_getreg_b32    s43, hwreg(trapsts, 3, 10)", 0xb92b48c3u, 0, false, true, "" },
353    { "    s_getreg_b32    s43, hwreg(trapsts, 3, 32)", 0xb92bf8c3u, 0, false, true, "" },
354    { "    s_getreg_b32    s43, hwreg(@10, 0, 1)", 0xb92b000aU, 0, false, true, "" },
355    { "    s_getreg_b32    s43, hwreg(@8, 0, 1)", 0xb92b0008U, 0, false, true, "" },
356    { "    s_setreg_imm32_b32 hwreg(trapsts, 3, 10), 0x24da4f",
357                    0xba8048c3u, 0x24da4fU, true, true, "" },
358    { "    s_setreg_imm32_b32 hwreg(trapsts, 3, 10), xx; xx=0x24da4f",
359                    0xba8048c3u, 0x24da4fU, true, true, "" },
360    { "xx=0x24da4e;    s_setreg_imm32_b32 hwreg(trapsts, 3, 10), xx",
361                    0xba8048c3u, 0x24da4eU, true, true, "" },
362    { "     s_setreg_b32  hwreg(trapsts, 3, 10), s43", 0xb9ab48c3u, 0, false, true, "" },
363    { "    s_getreg_b32    s43, hwreg(ib_dbg1, 0, 1)", 0xb92b000dU, 0, false, true, "" },
364    { "    s_getreg_b32    s43, hwreg(flush_ib, 0, 1)", 0xb92b000eU, 0, false, true, "" },
365    { "    s_getreg_b32    s43, hwreg(HWREG_FLUSH_IB, 0, 1)",
366                0xb92b000eU, 0, false, true, "" },
367    { "    s_getreg_b32    s43, hwreg(sh_mem_bases, 0, 1)",
368                0xb92b000fU, 0, false, true, "" },
369    { "    s_getreg_b32    s43, hwreg(HWREG_SH_MEM_BASES, 0, 1)",
370                0xb92b000fU, 0, false, true, "" },
371    { "    s_getreg_b32    s43, hwreg(sq_shader_tba_lo, 0, 1)",
372                0xb92b0010U, 0, false, true, "" },
373    { "    s_getreg_b32    s43, hwreg(HWREG_SQ_SHADER_TBA_LO, 0, 1)",
374                0xb92b0010U, 0, false, true, "" },
375    { "    s_getreg_b32    s43, hwreg(sq_shader_tba_hi, 0, 1)",
376                0xb92b0011U, 0, false, true, "" },
377    { "    s_getreg_b32    s43, hwreg(HWREG_SQ_SHADER_TBA_HI, 0, 1)",
378                0xb92b0011U, 0, false, true, "" },
379    { "    s_getreg_b32    s43, hwreg(sq_shader_tma_lo, 0, 1)",
380                0xb92b0012U, 0, false, true, "" },
381    { "    s_getreg_b32    s43, hwreg(HWREG_SQ_SHADER_TMA_LO, 0, 1)",
382                0xb92b0012U, 0, false, true, "" },
383    { "    s_getreg_b32    s43, hwreg(sq_shader_tma_hi, 0, 1)",
384                0xb92b0013U, 0, false, true, "" },
385    { "    s_getreg_b32    s43, hwreg(HWREG_SQ_SHADER_TMA_HI, 0, 1)",
386                0xb92b0013U, 0, false, true, "" },
387    { "    s_getreg_b32    s43, hwreg(tba_lo, 0, 1)", 0xb92b0010U, 0, false, true, "" },
388    { "    s_getreg_b32    s43, hwreg(HWREG_TBA_LO, 0, 1)",
389                0xb92b0010U, 0, false, true, "" },
390    { "    s_getreg_b32    s43, hwreg(tba_hi, 0, 1)", 0xb92b0011U, 0, false, true, "" },
391    { "    s_getreg_b32    s43, hwreg(HWREG_TBA_HI, 0, 1)",
392                0xb92b0011U, 0, false, true, "" },
393    { "    s_getreg_b32    s43, hwreg(tma_lo, 0, 1)", 0xb92b0012U, 0, false, true, "" },
394    { "    s_getreg_b32    s43, hwreg(HWREG_TMA_LO, 0, 1)",
395                0xb92b0012U, 0, false, true, "" },
396    { "    s_getreg_b32    s43, hwreg(tma_hi, 0, 1)", 0xb92b0013U, 0, false, true, "" },
397    { "    s_getreg_b32    s43, hwreg(HWREG_TMA_HI, 0, 1)",
398                0xb92b0013U, 0, false, true, "" },
399    { "    s_getreg_b32    s43, hwreg(flat_scr_lo, 0, 1)",
400                0xb92b0014U, 0, false, true, "" },
401    { "    s_getreg_b32    s43, hwreg(HWREG_FLAT_SCR_LO, 0, 1)",
402                0xb92b0014U, 0, false, true, "" },
403    { "    s_getreg_b32    s43, hwreg(flat_scr_hi, 0, 1)",
404                0xb92b0015U, 0, false, true, "" },
405    { "    s_getreg_b32    s43, hwreg(HWREG_FLAT_SCR_HI, 0, 1)",
406                0xb92b0015U, 0, false, true, "" },
407    { "    s_getreg_b32    s43, hwreg(xnack_mask, 0, 1)",
408                0xb92b0016U, 0, false, true, "" },
409    { "    s_getreg_b32    s43, hwreg(HWREG_XNACK_MASK, 0, 1)",
410                0xb92b0016U, 0, false, true, "" },
411    { "    s_getreg_b32    s43, hwreg(pops_packer, 0, 1)",
412                0xb92b0017U, 0, false, true, "" },
413    { "    s_getreg_b32    s43, hwreg(HWREG_POPS_PACKER, 0, 1)",
414                0xb92b0017U, 0, false, true, "" },
415    // SOPK instructions
416    { "s_call_b64 s[44:45], xxxx+8\nxxxx:", 0xbb2c0002U, 0, false, true, "" },
417    { "    s_waitcnt_vscnt  s43, 0xd3b9", 0xbbabd3b9U, 0, false, true, "" },
418    { "    s_waitcnt_vmcnt  s43, 0xd3b9", 0xbc2bd3b9U, 0, false, true, "" },
419    { "    s_waitcnt_expcnt s43, 0xd3b9", 0xbcabd3b9U, 0, false, true, "" },
420    { "    s_waitcnt_lgkmcnt s43, 0xd3b9", 0xbd2bd3b9U, 0, false, true, "" },
421    { "    s_subvector_loop_begin s43, 0xd3b9", 0xbdabd3b9U, 0, false, true, "" },
422    { "    s_subvector_loop_end s43, 0xd3b9", 0xbe2bd3b9U, 0, false, true, "" },
423    /* SOPP encoding */
424    { "s_nop  0x0", 0xbf800000U, 0, false, true, "" },
425    { "s_nop  7", 0xbf800007U, 0, false, true, "" },
426    { "s_nop  644", 0xbf800284U, 0, false, true, "" },
427    { "xv=6; xt=65; s_nop  xv+xt", 0xbf800047U, 0, false, true, "" },
428    { "s_nop  xv+xt; xv=6; xt=65", 0xbf800047U, 0, false, true, "" },
429    { "s_endpgm", 0xbf810000U, 0, false, true, "" },
430    { "    s_wakeup\n", 0xbf830000U, 0, false, true, "" },
431    { "    s_branch xxxx-8\nxxxx:\n", 0xbf82fffeU, 0, false, true, "" },
432    { "xxxx:    s_branch xxxx-8\n", 0xbf82fffdU, 0, false, true, "" },
433    { "    s_branch xxxx+8\nxxxx:\n", 0xbf820002U, 0, false, true, "" },
434    { "    s_cbranch_scc0  xxxx-8\nxxxx:\n", 0xbf84fffeU, 0, false, true, "" },
435    { "    s_cbranch_scc1  xxxx-8\nxxxx:\n", 0xbf85fffeU, 0, false, true, "" },
436    { "    s_cbranch_vccz  xxxx-8\nxxxx:\n", 0xbf86fffeU, 0, false, true, "" },
437    { "    s_cbranch_vccnz  xxxx-8\nxxxx:\n", 0xbf87fffeU, 0, false, true, "" },
438    { "    s_cbranch_execz  xxxx-8\nxxxx:\n", 0xbf88fffeU, 0, false, true, "" },
439    { "    s_cbranch_execnz  xxxx-8\nxxxx:\n", 0xbf89fffeU, 0, false, true, "" },
440    { "s_barrier", 0xbf8a0000U, 0, false, true, "" },
441    { "s_waitcnt       vmcnt(6) & expcnt(3) & lgkmcnt(13)\n",
442        0xbf8c0d36U, 0, false, true, "" },
443    { "s_waitcnt       vmcnt(22) & expcnt(3) & lgkmcnt(13)\n",
444        0xbf8c4d36U, 0, false, true, "" },
445    { "s_waitcnt       vmcnt(38) & expcnt(3) & lgkmcnt(13)\n",
446        0xbf8c8d36U, 0, false, true, "" },
447    { "s_waitcnt       vmcnt(54) & expcnt(3) & lgkmcnt(13)\n",
448        0xbf8ccd36U, 0, false, true, "" },
449    { "s_waitcnt       vmcnt(15) & expcnt(3) & lgkmcnt(13)\n",
450        0xbf8c0d3fU, 0, false, true, "" },
451    { "s_waitcnt       vmcnt(31) & expcnt(3) & lgkmcnt(13)\n",
452        0xbf8c4d3fU, 0, false, true, "" },
453    { "s_waitcnt       vmcnt(47) & expcnt(3) & lgkmcnt(13)\n",
454        0xbf8c8d3fU, 0, false, true, "" },
455    { "s_waitcnt       expcnt(3) & lgkmcnt(13)\n", 0xbf8ccd3fU, 0, false, true, "" },
456    { "s_waitcnt       " "vmcnt(0) & expcnt(0) & lgkmcnt(0)\n",
457        0xbf8c0000U, 0, false, true, "" },
458    { "s_waitcnt  vmcnt(14) & expcnt(2)", 0xbf8c3f2eU, 0, false, true, "" },
459    { "s_waitcnt  lgkmcnt(13) & expcnt(2)", 0xbf8ccd2fU, 0, false, true, "" },
460    { "s_waitcnt  lgkmcnt(21) & expcnt(2)", 0xbf8cd52fU, 0, false, true, "" },
461    { "s_waitcnt  lgkmcnt(44) & expcnt(2)", 0xbf8cec2fU, 0, false, true, "" },
462    { "s_waitcnt  lgkmcnt(53) & expcnt(2)", 0xbf8cf52fU, 0, false, true, "" },
463    { "        s_waitcnt       vmcnt(6) & expcnt(3) & lgkmcnt(53)\n",
464        0xbf8c3536U, 0, false, true, "" },
465    /* other SOPP opcodes */
466    { "    s_sethalt       0x32b", 0xbf8d032bU, 0, false, true, "" },
467    { "    s_sleep         0x32b", 0xbf8e032bU, 0, false, true, "" },
468    { "    s_setprio       0x32b", 0xbf8f032bU, 0, false, true, "" },
469    /* sendmsg */
470    { "    s_sendmsg  sendmsg(interrupt)", 0xbf900001U, 0, false, true, "" },
471    { "    s_sendmsg  sendmsg(MSG_INTERRUPT)", 0xbf900001U, 0, false, true, "" },
472    { "    s_sendmsg  sendmsg(system)", 0xbf90000fU, 0, false, true, "" },
473    { "    s_sendmsg  sendmsg(MSG_SYSTEM)", 0xbf90000fU, 0, false, true, "" },
474    { "    s_sendmsg  sendmsg(MSG_SYSMSG)", 0xbf90000fU, 0, false, true, "" },
475    { "    s_sendmsg  sendmsg(gs, nop)", 0xbf900002U, 0, false, true, "" },
476    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_NOP)", 0xbf900002U, 0, false, true, "" },
477    { "    s_sendmsg  sendmsg(gs, cut, 0)", 0xbf900012U, 0, false, true, "" },
478    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_CUT, 0)", 0xbf900012U, 0, false, true, "" },
479    { "    s_sendmsg  sendmsg(gs, cut, 1)", 0xbf900112U, 0, false, true, "" },
480    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_CUT, 1)", 0xbf900112U, 0, false, true, "" },
481    { "    s_sendmsg  sendmsg(gs, emit, 0)", 0xbf900022U, 0, false, true, "" },
482    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_EMIT, 0)", 0xbf900022U, 0, false, true, "" },
483    { "    s_sendmsg  sendmsg(gs, emit_cut, 3)", 0xbf900332U, 0,
484        false, true, "" },
485    { "    s_sendmsg  sendmsg(gs, emit-cut, 3)", 0xbf900332U, 0,
486        false, true, "" },
487    { "    s_sendmsg  sendmsg ( gs    , emit_cut  , 3  )", 0xbf900332U, 0,
488        false, true, "" },
489    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_EMIT_CUT, 3)", 0xbf900332U, 0,
490        false, true, "" },
491    { "    s_sendmsg  sendmsg(gs_done, nop)", 0xbf900003U, 0, false, true, "" },
492    { "    s_sendmsg  sendmsg(MSG_GS_DONE, GS_OP_NOP)", 0xbf900003U, 0, false, true, "" },
493    { "    s_sendmsghalt  sendmsg(interrupt)", 0xbf910001U, 0, false, true, "" },
494    { "    s_sendmsg  sendmsg(@2, GS_OP_CUT, 0)", 0xbf900012U, 0, false, true, "" },
495    { "    s_sendmsg  sendmsg(@2, @1, 0)", 0xbf900012U, 0, false, true, "" },
496    { "    s_sendmsg  sendmsg(savewave)", 0xbf900004U, 0, false, true, "" },
497    { "    s_sendmsg  sendmsg(MSG_STALL_WAVE_GEN)", 0xbf900005U, 0, false, true, "" },
498    { "    s_sendmsg  sendmsg(stall_wave_gen)", 0xbf900005U, 0, false, true, "" },
499    { "    s_sendmsg  sendmsg(MSG_HALT_WAVES)", 0xbf900006U, 0, false, true, "" },
500    { "    s_sendmsg  sendmsg(halt_waves)", 0xbf900006U, 0, false, true, "" },
501    { "    s_sendmsg  sendmsg(MSG_ORDERED_PS_DONE)", 0xbf900007U, 0, false, true, "" },
502    { "    s_sendmsg  sendmsg(ordered_ps_done)", 0xbf900007U, 0, false, true, "" },
503    { "    s_sendmsg  sendmsg(MSG_EARLY_PRIM_DEALLOC)", 0xbf900008U, 0, false, true, "" },
504    { "    s_sendmsg  sendmsg(early_prim_dealloc)", 0xbf900008U, 0, false, true, "" },
505    { "    s_sendmsg  sendmsg(MSG_GS_ALLOC_REQ)", 0xbf900009U, 0, false, true, "" },
506    { "    s_sendmsg  sendmsg(gs_alloc_req)", 0xbf900009U, 0, false, true, "" },
507    { "    s_sendmsg  sendmsg(MSG_GET_DOORBELL)", 0xbf90000aU, 0, false, true, "" },
508    { "    s_sendmsg  sendmsg(get_doorbell)", 0xbf90000aU, 0, false, true, "" },
509    /* msg errors */
510    { "    s_sendmsg  sendmsg(interrupxt)", 0, 0, false, false,
511        "test.s:1:24: Error: Unknown message\n" },
512    { "    s_sendmsg  sendmsg(gs, nop__x)", 0, 0, false, false,
513        "test.s:1:28: Error: Unknown GSOP\n" },
514    { "    s_sendmsg  sendmsg(gs, nop__x", 0, 0, false, false,
515        "test.s:1:28: Error: Unknown GSOP\n"
516        "test.s:1:34: Error: Unterminated sendmsg function\n" },
517    { "    s_sendmsg  sendmsg(gs, cut, 122)", 0xbf900212U, 0, false, true,
518        "test.s:1:33: Warning: StreamId (3rd argument) out of range\n" },
519    /* other SOPP encoding */
520    { "    s_trap  0x32b", 0xbf92032bU, 0, false, true, "" },
521    { "    s_icache_inv", 0xbf930000U, 0, false, true, "" },
522    { "    s_incperflevel  0x1234", 0xbf941234U, 0, false, true, "" },
523    { "    s_decperflevel  0x1234", 0xbf951234U, 0, false, true, "" },
524    { "    s_ttracedata", 0xbf960000U, 0, false, true, "" },
525    { "    s_setkill  0x32b", 0xbf8b032bU, 0, false, true, "" },
526    { "xxx: s_cbranch_cdbgsys xxx+16", 0xbf970003U, 0, false, true, "" },
527    { "xxx: s_cbranch_cdbguser xxx+16", 0xbf980003U, 0, false, true, "" },
528    { "xxx: s_cbranch_cdbgsys_or_user xxx+16", 0xbf990003U, 0, false, true, "" },
529    { "xxx: s_cbranch_cdbgsys_and_user xxx+16", 0xbf9a0003U, 0, false, true, "" },
530    { "        s_endpgm_ordered_ps_done\n", 0xbf9e0000U, 0, false, true, "" },
531    { "        s_code_end\n", 0xbf9f0000U, 0, false, true, ""  },
532    { "        s_inst_prefetch 0x1234\n", 0xbfa01234U, 0, false, true, "" },
533    { "        s_clause        0x1234\n", 0xbfa11234U, 0, false, true, "" },
534    { "        s_wait_idle\n", 0xbfa20000U, 0, false, true, "" },
535    { "        s_waitcnt_decptr 0x1234\n", 0xbfa31234U, 0, false, true, "" },
536    { "        s_round_mode    0x1234\n", 0xbfa41234U, 0, false, true, "" },
537    { "        s_denorm_mode   0x1234\n", 0xbfa51234U, 0, false, true, "" },
538    { "        s_ttracedata_imm 0x1234\n", 0xbfa81234U, 0, false, true, "" },
539    /* SMEM encoding */
540    { "    s_load_dword    s3, s[0:1], s4\n", 0xf40000c0U, 0x08000000U, true, true, "" },
541    { "        s_load_dword    s3, s[0:1], 0x6ba23\n",
542                0xf40000c0U, 0xfa06ba23U, true, true, "" },
543    { "        s_load_dword    s3, s[18:19], s4\n",
544                0xf40000c9U, 0x08000000U, true, true, "" },
545    { "        s_load_dword    s3, s[18:19], 0x6ba23\n",
546                0xf40000c9U, 0xfa06ba23U, true, true, "" },
547    { "        s_load_dword    s3, s[0:1], s4 glc dlc\n",
548                0xf40140c0U, 0x08000000U, true, true, "" },
549    { "        s_load_dword    s3, s[0:1], s4 glc:1 dlc:1\n",
550                0xf40140c0U, 0x08000000U, true, true, "" },
551    { "        s_load_dword    s3, s[0:1], s4 dlc\n",
552                0xf40040c0U, 0x08000000U, true, true, "" },
553    { "        s_load_dword    s3, s[0:1], s4 nv\n",
554                0xf40080c0U, 0x08000000U, true, true, "" },
555    { "        s_load_dword    s3, s[0:1], s4 dlc:0 nv\n",
556                0xf40080c0U, 0x08000000U, true, true, "" },
557    { "        s_load_dword    s3, s[6:7], s4 nv glc:0\n",
558                0xf40080c3U, 0x08000000U, true, true, "" },
559    { "ft=42; by=21; s_load_dword    s3, s[18:19], ft*by\n",
560                0xf40000c9U, 0xfa000372U, true, true, "" },
561    { "s_load_dword    s3, s[18:19], ft*by; ft=42; by=21\n",
562                0xf40000c9U, 0xfa000372U, true, true, "" },
563    { "s7=0x3cda; s_load_dword    s3, s[18:19], @s7\n",
564                0xf40000c9U, 0xfa003cdaU, true, true, "" },
565    { "x7=0x1f3cda; s_load_dword    s3, s[18:19], x7\n", 0xf40000c9U, 0xfa0f3cdaU,
566            true, true, "test.s:1:44: Warning: Value 0x1f3cda truncated to 0xf3cda\n" },
567    { "s_load_dword    s3, s[18:19], x7; x7=0x1f3cda\n", 0xf40000c9U, 0xfa0f3cdaU,
568            true, true, "test.s:1:31: Warning: Value 0x1f3cda truncated to 0xf3cda\n" },
569    /* SMEM errors */
570    { "    s_load_dword  s[50:53], s[58:59], 0x1345b", 0, 0, false, false,
571        "test.s:1:19: Error: Required 1 scalar register\n" },
572    { "    s_load_dword  s50, s[58:58], 0x1345b", 0, 0, false, false,
573        "test.s:1:24: Error: Required 2 scalar registers\n" },
574    { "    s_load_dword    s50, -1, 0x5b", 0, 0, false, false,
575        "test.s:1:26: Error: Some garbages at register name place\n" },
576    { "    s_load_dword    s50, execz, 0x5b", 0, 0, false, false,
577        "test.s:1:26: Error: Expected 2 scalar registers\n" },
578    /* SMEM instructions */
579    { "    s_load_dwordx2  s[6:7], s[18:19], s4\n",
580                0xf4040189U, 0x08000000U, true, true, "" },
581    { "    s_load_dwordx4  s[12:15], s[18:19], s4\n",
582                0xf4080309U, 0x08000000U, true, true, "" },
583    { "    s_load_dwordx8  s[12:19], s[18:19], s4\n",
584                0xf40c0309U, 0x08000000U, true, true, "" },
585    { "    s_load_dwordx16 s[12:27], s[18:19], s4\n",
586                0xf4100309U, 0x08000000U, true, true, "" },
587    { "    s_scratch_load_dword s3, s[18:19], s4\n",
588                0xf41400c9U, 0x08000000U, true, true, "" },
589    { "    s_scratch_load_dwordx2 s[6:7], s[18:19], s4\n",
590                0xf4180189U, 0x08000000U, true, true, "" },
591    { "    s_scratch_load_dwordx4 s[12:15], s[18:19], s4\n",
592                0xf41c0309U, 0x08000000U, true, true, "" },
593    { "    s_buffer_load_dword s3, s[20:23], s4\n",
594                0xf42000caU, 0x08000000U, true, true, "" },
595    { "    s_buffer_load_dwordx2 s[6:7], s[20:23], s4\n",
596                0xf424018aU, 0x08000000U, true, true, "" },
597    { "    s_buffer_load_dwordx4 s[12:15], s[20:23], s4\n",
598                0xf428030aU, 0x08000000U, true, true, "" },
599    { "    s_buffer_load_dwordx8 s[12:19], s[20:23], s4\n",
600                0xf42c030aU, 0x08000000U, true, true, "" },
601    { "    s_buffer_load_dwordx16 s[12:27], s[20:23], s4\n",
602                0xf430030aU, 0x08000000U, true, true, "" },
603    { "    s_store_dword   s3, s[20:21], s4\n", 0xf44000caU, 0x08000000U, true, true, "" },
604    { "    s_store_dwordx2 s[6:7], s[20:21], s4\n",
605                0xf444018aU, 0x08000000U, true, true, "" },
606    { "    s_store_dwordx4 s[12:15], s[20:21], s4\n",
607                0xf448030aU, 0x08000000U, true, true, "" },
608    { "    s_scratch_store_dword s3, s[18:19], s4\n",
609                0xf45400c9U, 0x08000000U, true, true, "" },
610    { "    s_scratch_store_dwordx2 s[6:7], s[18:19], s4\n",
611                0xf4580189U, 0x08000000U, true, true, "" },
612    { "    s_scratch_store_dwordx4 s[12:15], s[18:19], s4\n",
613                0xf45c0309U, 0x08000000U, true, true, "" },
614    { "    s_buffer_store_dword s3, s[20:23], s4\n",
615                0xf46000caU, 0x08000000U, true, true, "" },
616    { "    s_buffer_store_dwordx2 s[6:7], s[20:23], s4\n",
617                0xf464018aU, 0x08000000U, true, true, "" },
618    { "    s_buffer_store_dwordx4 s[12:15], s[20:23], s4\n",
619                0xf468030aU, 0x08000000U, true, true, "" },
620    { "    s_gl1_inv\n", 0xf47c0000U, 0x00000000U, true, true, "" },
621    { "    s_dcache_inv\n", 0xf4800000U, 0x00000000U, true, true, "" },
622    { "    s_dcache_wb\n", 0xf4840000U, 0x00000000U, true, true, "" },
623    { "    s_memtime       s[6:7]\n", 0xf4900180U, 0x00000000U, true, true, "" },
624    { "    s_memrealtime   s[6:7]\n", 0xf4940180U, 0x00000000U, true, true, "" },
625    { "    s_atc_probe     0x3, s[20:21], s4\n",
626                0xf49800caU, 0x08000000U, true, true, "" },
627    { "    s_atc_probe_buffer 0x3, s[20:23], s4\n",
628                0xf49c00caU, 0x08000000U, true, true, "" },
629    { "    s_dcache_discard s[20:21], s4\n", 0xf4a0000aU, 0x08000000U, true, true, "" },
630    { "    s_dcache_discard_x2 s[20:21], s4\n", 0xf4a4000aU, 0x08000000U, true, true, "" },
631    { "    s_get_waveid_in_workgroup s7\n", 0xf4a801c0U, 0x00000000U, true, true, "" },
632    { "    s_buffer_atomic_swap s3, s[20:23], s4\n",
633                0xf50000caU, 0x08000000U, true, true, "" },
634    { "    s_buffer_atomic_cmpswap s[10:11], s[20:23], s4\n",
635                0xf504028aU, 0x08000000U, true, true, "" },
636    { "    s_buffer_atomic_add s3, s[20:23], s4\n",
637                0xf50800caU, 0x08000000U, true, true, "" },
638    { "    s_buffer_atomic_sub s3, s[20:23], s4\n",
639                0xf50c00caU, 0x08000000U, true, true, "" },
640    { "    s_buffer_atomic_smin s3, s[20:23], s4\n",
641                0xf51000caU, 0x08000000U, true, true, "" },
642    { "    s_buffer_atomic_umin s3, s[20:23], s4\n",
643                0xf51400caU, 0x08000000U, true, true, "" },
644    { "    s_buffer_atomic_smax s3, s[20:23], s4\n",
645                0xf51800caU, 0x08000000U, true, true, "" },
646    { "    s_buffer_atomic_umax s3, s[20:23], s4\n",
647                0xf51c00caU, 0x08000000U, true, true, "" },
648    { "    s_buffer_atomic_and s3, s[20:23], s4\n",
649                0xf52000caU, 0x08000000U, true, true, "" },
650    { "    s_buffer_atomic_or s3, s[20:23], s4\n",
651                0xf52400caU, 0x08000000U, true, true, "" },
652    { "    s_buffer_atomic_xor s3, s[20:23], s4\n",
653                0xf52800caU, 0x08000000U, true, true, "" },
654    { "    s_buffer_atomic_inc s3, s[20:23], s4\n",
655                0xf52c00caU, 0x08000000U, true, true, "" },
656    { "    s_buffer_atomic_dec s3, s[20:23], s4\n",
657                0xf53000caU, 0x08000000U, true, true, "" },
658    { "    s_buffer_atomic_swap_x2 s[6:7], s[20:23], s4\n",
659                0xf580018aU, 0x08000000U, true, true, "" },
660    { "    s_buffer_atomic_cmpswap_x2 s[12:15], s[20:23], s4\n",
661                0xf584030aU, 0x08000000U, true, true, "" },
662    { "    s_buffer_atomic_add_x2 s[10:11], s[20:23], s4\n",
663                0xf588028aU, 0x08000000U, true, true, "" },
664    { "    s_buffer_atomic_sub_x2 s[10:11], s[20:23], s4\n",
665                0xf58c028aU, 0x08000000U, true, true, "" },
666    { "    s_buffer_atomic_smin_x2 s[10:11], s[20:23], s4\n",
667                0xf590028aU, 0x08000000U, true, true, "" },
668    { "    s_buffer_atomic_umin_x2 s[10:11], s[20:23], s4\n",
669                0xf594028aU, 0x08000000U, true, true, "" },
670    { "    s_buffer_atomic_smax_x2 s[10:11], s[20:23], s4\n",
671                0xf598028aU, 0x08000000U, true, true, "" },
672    { "    s_buffer_atomic_umax_x2 s[10:11], s[20:23], s4\n",
673                0xf59c028aU, 0x08000000U, true, true, "" },
674    { "    s_buffer_atomic_and_x2 s[10:11], s[20:23], s4\n",
675                0xf5a0028aU, 0x08000000U, true, true, "" },
676    { "    s_buffer_atomic_or_x2 s[10:11], s[20:23], s4\n",
677                0xf5a4028aU, 0x08000000U, true, true, "" },
678    { "    s_buffer_atomic_xor_x2 s[10:11], s[20:23], s4\n",
679                0xf5a8028aU, 0x08000000U, true, true, "" },
680    { "    s_buffer_atomic_inc_x2 s[10:11], s[20:23], s4\n",
681                0xf5ac028aU, 0x08000000U, true, true, "" },
682    { "    s_buffer_atomic_dec_x2 s[10:11], s[20:23], s4\n",
683                0xf5b0028aU, 0x08000000U, true, true, "" },
684    { "    s_atomic_swap   s3, s[20:21], s4\n", 0xf60000caU, 0x08000000U, true, true, "" },
685    { "    s_atomic_cmpswap s[10:11], s[20:21], s4\n",
686                0xf604028aU, 0x08000000U, true, true, "" },
687    { "    s_atomic_add    s3, s[20:21], s4\n", 0xf60800caU, 0x08000000U, true, true, "" },
688    { "    s_atomic_sub    s3, s[20:21], s4\n", 0xf60c00caU, 0x08000000U, true, true, "" },
689    { "    s_atomic_smin   s3, s[20:21], s4\n", 0xf61000caU, 0x08000000U, true, true, "" },
690    { "    s_atomic_umin   s3, s[20:21], s4\n", 0xf61400caU, 0x08000000U, true, true, "" },
691    { "    s_atomic_smax   s3, s[20:21], s4\n", 0xf61800caU, 0x08000000U, true, true, "" },
692    { "    s_atomic_umax   s3, s[20:21], s4\n", 0xf61c00caU, 0x08000000U, true, true, "" },
693    { "    s_atomic_and    s3, s[20:21], s4\n", 0xf62000caU, 0x08000000U, true, true, "" },
694    { "    s_atomic_or     s3, s[20:21], s4\n", 0xf62400caU, 0x08000000U, true, true, "" },
695    { "    s_atomic_xor    s3, s[20:21], s4\n", 0xf62800caU, 0x08000000U, true, true, "" },
696    { "    s_atomic_inc    s3, s[20:21], s4\n", 0xf62c00caU, 0x08000000U, true, true, "" },
697    { "    s_atomic_dec    s3, s[20:21], s4\n", 0xf63000caU, 0x08000000U, true, true, "" },
698    { "    s_atomic_swap_x2 s[6:7], s[20:21], s4\n",
699                0xf680018aU, 0x08000000U, true, true, "" },
700    { "    s_atomic_cmpswap_x2 s[12:15], s[20:21], s4\n",
701                0xf684030aU, 0x08000000U, true, true, "" },
702    { "    s_atomic_add_x2 s[10:11], s[20:21], s4\n",
703                0xf688028aU, 0x08000000U, true, true, "" },
704    { "    s_atomic_sub_x2 s[10:11], s[20:21], s4\n",
705                0xf68c028aU, 0x08000000U, true, true, "" },
706    { "    s_atomic_smin_x2 s[10:11], s[20:21], s4\n",
707                0xf690028aU, 0x08000000U, true, true, "" },
708    { "    s_atomic_umin_x2 s[10:11], s[20:21], s4\n",
709                0xf694028aU, 0x08000000U, true, true, "" },
710    { "    s_atomic_smax_x2 s[10:11], s[20:21], s4\n",
711                0xf698028aU, 0x08000000U, true, true, "" },
712    { "    s_atomic_umax_x2 s[10:11], s[20:21], s4\n",
713                0xf69c028aU, 0x08000000U, true, true, "" },
714    { "    s_atomic_and_x2 s[10:11], s[20:21], s4\n",
715                0xf6a0028aU, 0x08000000U, true, true, "" },
716    { "    s_atomic_or_x2  s[10:11], s[20:21], s4\n",
717                0xf6a4028aU, 0x08000000U, true, true, "" },
718    { "    s_atomic_xor_x2 s[10:11], s[20:21], s4\n",
719                0xf6a8028aU, 0x08000000U, true, true, "" },
720    { "    s_atomic_inc_x2 s[10:11], s[20:21], s4\n",
721                0xf6ac028aU, 0x08000000U, true, true, "" },
722    { "    s_atomic_dec_x2 s[10:11], s[20:21], s4\n",
723                0xf6b0028aU, 0x08000000U, true, true, "" },
724    /* VOP2/(VOP2 in VOP3) encoding */
725    { "    v_cndmask_b32   v154, v21, v107, vcc", 0x0334d715U, 0, false, true, "" },
726    { "    v_cndmask_b32   v154, v21, v107, vcc     ", 0x0334d715U, 0, false, true, "" },
727    { "    v_cndmask_b32   v[154:154], v[21:21], v[107], vcc",
728        0x0334d715U, 0, false, true, "" },
729    { "    v_cndmask_b32   v[  154 : 154], v[ 21:21 ], v[ 107  ], vcc",
730        0x0334d715U, 0, false, true, "" },
731    { "    v_cndmask_b32   v154  , v21 , v107  , vcc", 0x0334d715U, 0, false, true, "" },
732    { "    v_cndmask_b32   v154, lds, v107, vcc", 0x0334d6feU, 0, false, true, "" },
733    { "    v_cndmask_b32   v154, lds_direct, v107, vcc", 0x0334d6feU, 0, false, true, "" },
734    { "    v_cndmask_b32   v154, src_lds_direct, v107, vcc",
735        0x0334d6feU, 0, false, true, "" },
736    { "    v_add_f32   v154, s21, v107", 0x0734d615U, 0, false, true, "" },
737    { "    v_cndmask_b32   v154, 2, v107, vcc", 0x0334d682U, 0, false, true, "" },
738    { "    v_cndmask_b32   v154, -9, v107, vcc", 0x0334d6c9U, 0, false, true, "" },
739    { "    v_cndmask_b32   v154, 20e-1, v107, vcc", 0x0334d6f4U, 0, false, true, "" },
740    { "    v_cndmask_b32   v154, 1323, v107, vcc", 0x0334d6ffU, 1323, true, true, "" },
741    { "xx=1323;v_cndmask_b32   v154, xx, v107, vcc", 0x0334d6ffU, 1323, true, true, "" },
742    { "v_cndmask_b32   v154, xx, v107, vcc; xx=1323", 0x0334d6ffU, 1323, true, true, "" },
743    { "v_cndmask_b32   v154, xx, v107, vcc; xx=2", 0x0334d6ffU, 2, true, true, "" },
744    { "v0=1323;v_cndmask_b32   v154, @v0, v107, vcc", 0x0334d6ffU, 1323, true, true, "" },
745    { "v_cndmask_b32   v154, @v0, v107, vcc; v0=1323", 0x0334d6ffU, 1323, true, true, "" },
746    { "s0=1323;v_cndmask_b32   v154, @s0, v107, vcc", 0x0334d6ffU, 1323, true, true, "" },
747    { "v_cndmask_b32   v154, @s0, v107, vcc; s0=1323", 0x0334d6ffU, 1323, true, true, "" },
748    { "    v_add_f32  v154, v21, v107", 0x0734d715U, 0, false, true, "" },
749    { "tx=%s21; v_add_f32  v154, tx, v107", 0x0734d615U, 0, false, true, "" },
750    { "    v_add_f32  v154, s21, v107", 0x0734d615U, 0, false, true, "" },
751    { " fla=%v154;   v_add_f32  fla, s21, v107", 0x0734d615U, 0, false, true, "" },
752    { "    v_add_f32  v154, v21, v107 vop3", 0xd503009aU, 0x0002d715U, true, true, "" },
753    { "    v_add_f32  v154, v21, v107 vop3:1", 0xd503009aU, 0x0002d715U, true, true, "" },
754    { "    v_add_f32_e64  v154, v21, v107", 0xd503009aU, 0x0002d715U, true, true, "" },
755    { "    v_add_f32_e64  v154, v21, v107 vop3:0",
756        0xd503009aU, 0x0002d715U, true, true, "" },
757    { "    v_add_f32  v154, v21, s98", 0xd503009aU, 0x0000c515U, true, true, "" },
758    { "    v_add_f32  v154, abs(v21), v107", 0xd503019aU, 0x0002d715U, true, true, "" },
759    { "    v_add_f32  v154, |v21|, v107", 0xd503019aU, 0x0002d715U, true, true, "" },
760    { "dd=%v21; v_add_f32  v154, |dd|, v107", 0xd503019aU, 0x0002d715U, true, true, "" },
761    { "    v_add_f32  v154, abs(v21), abs(v107)",
762        0xd503039aU, 0x0002d715U, true, true, "" },
763    { "    v_add_f32  v154, v21, v107 abs:3",
764        0xd503039aU, 0x0002d715U, true, true, "" },
765    { "    v_add_f32  v154, v21, abs(v107)", 0xd503029aU, 0x0002d715U, true, true, "" },
766    { "    v_add_f32  v154, -v21, v107", 0xd503009aU, 0x2002d715U, true, true, "" },
767    { "    v_add_f32  v154, v21, -v107", 0xd503009aU, 0x4002d715U, true, true, "" },
768    { "    v_add_f32  v154, v21, v107 neg:2", 0xd503009aU, 0x4002d715U, true, true, "" },
769    { "    v_add_f32  v154, v21, v107 neg:[0,1]",
770        0xd503009aU, 0x4002d715U, true, true, "" },
771    { "    v_add_f32  v154, v21, v107 neg: [ 0  , 1  ] ",
772        0xd503009aU, 0x4002d715U, true, true, "" },
773    { "    v_add_f32  v154, -v21, -v107", 0xd503009aU, 0x6002d715U, true, true, "" },
774    { "    v_add_f32  v154, -abs(v21), -abs(v107)",
775        0xd503039aU, 0x6002d715U, true, true, "" },
776    { "    v_add_f32  v154, v21, v107 neg:3 abs:3",
777        0xd503039aU, 0x6002d715U, true, true, "" },
778    { "    v_add_f32  v154, v21, v107 neg:[1,1] abs:[1,1]",
779        0xd503039aU, 0x6002d715U, true, true, "" },
780    { "    v_add_f32  v154, v21, v107 mul:2", 0xd503009aU, 0x0802d715U, true, true, "" },
781    { "    v_add_f32  v154, v21, v107 omod:1", 0xd503009aU, 0x0802d715U, true, true, "" },
782    { "    v_add_f32  v154, v21, v107 mul:2 clamp:0",
783        0xd503009aU, 0x0802d715U, true, true, "" },
784    { "    v_add_f32  v154, v21, v107 mul:002", 0xd503009aU, 0x0802d715U, true, true, "" },
785    { "    v_add_f32  v154, v21, v107 mul:4", 0xd503009aU, 0x1002d715U, true, true, "" },
786    { "    v_add_f32  v154, v21, v107 omod:2", 0xd503009aU, 0x1002d715U, true, true, "" },
787    { "    v_add_f32  v154, v21, v107 div:2", 0xd503009aU, 0x1802d715U, true, true, "" },
788    { "    v_add_f32  v154, v21, v107 omod:3", 0xd503009aU, 0x1802d715U, true, true, "" },
789    { "    v_add_f32  v154, v21, v107 div:002", 0xd503009aU, 0x1802d715U, true, true, "" },
790    { "    v_add_f32  v154, v21, v107 mul:2 clamp",
791        0xd503809aU, 0x0802d715U, true, true, "" },
792    { "    v_add_f32  v154, v21, v107 mul:2 clamp:1",
793        0xd503809aU, 0x0802d715U, true, true, "" },
794    { "    v_add_f32  v154, v21, v107 clamp", 0xd503809aU, 0x0002d715U, true, true, "" },
795    { "    v_cndmask_b32   v154, v21, v107, s[6:7]",
796        0xd501009aU, 0x001ad715U, true, true, "" },
797    { "    v_cndmask_b32   v154, abs(v21), abs(v107), s[6:7] clamp",
798        0xd501839aU, 0x001ad715U, true, true, "" },
799    /* negated expressions */
800    { "vx=7;    v_add_f32  v154, -vx, v107", 0x0734d6c7U, 0, false, true, "" },
801    { "v12ZZ=7;    v_add_f32  v154, -v12ZZ, v107", 0x0734d6c7U, 0, false, true, "" },
802    { "v_add_f32  v154, -vx, v107; vx=7", 0x0734d6ffU, uint32_t(-7), true, true, "" },
803    { "vx=7737;    v_add_f32  v154, -vx, v107",
804        0x0734d6ffU, uint32_t(-7737), true, true, "" },
805    { "    v_add_f32  v154, s2, s2", 0xd503009aU, 0x0402U, true, true, "" },
806    /* var long names */
807    { "xtmp1111111111111111111222222222=67777\n"
808        "v_add_f32  v154, xtmp1111111111111111111222222222, v107",
809        0x0734d6ffU, 67777, true, true, "" },
810    // VOP3/VOP2 more than 2 SGPR registers
811    { "    v_add_f32  v154, s2, s4", 0xd503009aU, 0x00000802U, true, true, "" },
812    /* VOP2 errors */
813    { "    v_cndmask_b32   v[154:155], v21, v107, vcc", 0, 0, false, false,
814        "test.s:1:21: Error: Required 1 vector register\n" },
815    { "    v_cndmask_b32   v154, v[21:22], v107, vcc", 0, 0, false, false,
816        "test.s:1:27: Error: Required 1 vector register\n" },
817    { "    v_cndmask_b32   v154, v21, v[107:108], vcc", 0, 0, false, false,
818        "test.s:1:32: Error: Required 1 vector register\n" },
819    { "    v_cndmask_b32   v[154:, v21, v107, vcc", 0, 0, false, false,
820        "test.s:1:27: Error: Expected expression\n" },
821    { "    v_cndmask_b32   v[14, v21, v107, vcc", 0, 0, false, false,
822        "test.s:1:21: Error: Unterminated vector register range\n" },
823    { "    v_cndmask_b32   v[14:15, v21, v107, vcc", 0, 0, false, false,
824        "test.s:1:21: Error: Unterminated vector register range\n" },
825    { "    v_cndmask_b32   v256, v21, v107, vcc", 0, 0, false, false,
826        "test.s:1:24: Error: Number is too big\n"
827        "test.s:1:24: Error: Expected ',' before argument\n" },
828    { "    v_cndmask_b32   v[255:256], v21, v107, vcc", 0, 0, false, false,
829        "test.s:1:21: Error: Some vector register number out of range\n" },
830    { "    v_add_f32  v154, v21, v107 mul,", 0, 0, false, false,
831        "test.s:1:35: Error: Expected ':' before multiplier number\n"
832        "test.s:1:35: Error: Some garbages at VOP modifier place\n" },
833    { "    v_add_f32  v154, v21, v107 div,", 0, 0, false, false,
834        "test.s:1:35: Error: Expected ':' before divider number\n"
835        "test.s:1:35: Error: Some garbages at VOP modifier place\n" },
836    /* VOP2 in VOP3 errors */
837    { "    v_add_f32  v154, v21, v107 mul:3", 0, 0, false, false,
838        "test.s:1:32: Error: Unknown VOP3 mul:X modifier\n" },
839    { "    v_add_f32  v154, v21, v107 mul:", 0, 0, false, false,
840        "test.s:1:36: Error: Missing number\n" },
841    { "    v_add_f32  v154, v21, v107 mul", 0, 0, false, false,
842        "test.s:1:35: Error: Expected ':' before multiplier number\n" },
843    { "    v_add_f32  v154, v21, v107 mxl", 0, 0, false, false,
844        "test.s:1:32: Error: Unknown VOP modifier\n" },
845    { "    v_add_f32  v154, abs(v21), 12343", 0, 0, false, false,
846        "test.s:1:5: Error: Literal in VOP3 encoding is illegal\n" },
847    { "    v_add_f32  v154, 13243, abs(v21)", 0, 0, false, false,
848        "test.s:1:5: Error: Literal in VOP3 encoding is illegal\n" },
849    { "    v_add_f32  v154, 3123, s3", 0, 0, false, false,
850        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
851    { "    v_add_f32  v154, 3123, m0", 0, 0, false, false,
852        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
853    { "    v_add_f32  v154, s3, 3123", 0, 0, false, false,
854        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
855    { "    v_add_f32  v154, m0, 3123", 0, 0, false, false,
856        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
857    /* VOP2 encoding - VOP_SDWA */
858    { "   v_cndmask_b32   v154, v0, v107, vcc dst_sel:byte0 src0_sel:byte0 src1_sel:byte0",
859        0x0334d6f9U, 0, true, true, "" },
860    { "   v_cndmask_b32   v154, v0, v107, vcc dst_sel:byte_0 src0_sel:BYTE_0 src1_sel:b0",
861        0x0334d6f9U, 0, true, true, "" },
862    { "   v_cndmask_b32   v154, v0, v107, vcc dst_sel :byte_0 src0_sel : b0 src1_sel : b0 ",
863        0x0334d6f9U, 0, true, true, "" },
864    { "   v_cndmask_b32   v154, v61, v107, vcc dst_sel:byte0 src0_sel:byte0 src1_sel:byte0",
865        0x0334d6f9U, 0x3dU, true, true, "" },
866    { "   v_cndmask_b32   v154, v61, v107, vcc dst_sel:byte3 src0_sel:byte2 src1_sel:byte1",
867        0x0334d6f9U, 0x0102033dU, true, true, "" },
868    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:b1 src0_sel:byte1 src1_sel:byte_1",
869        0x0334d6f9U, 0x01010141U, true, true, "" },
870    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:b2 src0_sel:byte2 src1_sel:byte_2",
871        0x0334d6f9U, 0x02020241U, true, true, "" },
872    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:@2 src0_sel:@2 src1_sel:@2",
873        0x0334d6f9U, 0x02020241U, true, true, "" },
874    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:b3 src0_sel:byte3 src1_sel:byte_3",
875        0x0334d6f9U, 0x03030341U, true, true, "" },
876    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:w0 src0_sel:word0 src1_sel:word_0",
877        0x0334d6f9U, 0x04040441U, true, true, "" },
878    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:w1 src0_sel:word1 src1_sel:word_1",
879        0x0334d6f9U, 0x05050541U, true, true, "" },
880    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:w1 src0_sel:word0 src1_sel:dword",
881        0x0334d6f9U, 0x06040541U, true, true, "" },
882    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:@5 src0_sel:@4 src1_sel:@6",
883        0x0334d6f9U, 0x06040541U, true, true, "" },
884    { "   v_cndmask_b32   v154, v65, v107, vcc dst_un:preserve",
885        0x0334d6f9U, 0x06061641U, true, true, "" },
886    { "   v_cndmask_b32   v154, v65, v107, vcc dst_unused:UNUSED_PRESERVE",
887        0x0334d6f9U, 0x06061641U, true, true, "" },
888    { "   v_cndmask_b32   v154, v65, v107, vcc dst_unused : SEXT",
889        0x0334d6f9U, 0x06060e41U, true, true, "" },
890    { "   v_cndmask_b32   v154, v65, v107, vcc dst_unused : @1",
891        0x0334d6f9U, 0x06060e41U, true, true, "" },
892    { "   v_cndmask_b32   v154, v65, v107, vcc dst_unused:pad",
893        0x0334d6f9U, 0x06060641U, true, true, "" },
894    /* VOP_SDWA - operand modifiers */
895    { "   v_cndmask_b32   v154, abs(v65), v107, vcc dst_sel:word1",
896        0x0334d6f9U, 0x06260541U, true, true, "" },
897    { "   v_cndmask_b32   v154, -abs(v65), v107, vcc dst_sel:word1",
898        0x0334d6f9U, 0x06360541U, true, true, "" },
899    { "   v_cndmask_b32   v154, sext(-abs(v65)), v107, vcc dst_sel:word1",
900        0x0334d6f9U, 0x063e0541U, true, true, "" },
901    { "   v_cndmask_b32   v154, sext(-v65), v107, vcc dst_sel:word1",
902        0x0334d6f9U, 0x061e0541U, true, true, "" },
903    { "   v_cndmask_b32   v154, v65, abs(v107), vcc dst_sel:word1",
904        0x0334d6f9U, 0x26060541U, true, true, "" },
905    { "   v_cndmask_b32   v154, v65, -abs(v107), vcc dst_sel:word1",
906        0x0334d6f9U, 0x36060541U, true, true, "" },
907    { "   v_cndmask_b32   v154, v65, sext(-abs(v107)), vcc dst_sel:word1",
908        0x0334d6f9U, 0x3e060541U, true, true, "" },
909    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:word1 sext:2 neg:2 abs:2",
910        0x0334d6f9U, 0x3e060541U, true, true, "" },
911    { "   v_cndmask_b32   v154, v65, sext(-v107), vcc dst_sel:word1",
912        0x0334d6f9U, 0x1e060541U, true, true, "" },
913    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:word1 sext:2 neg:2",
914        0x0334d6f9U, 0x1e060541U, true, true, "" },
915    { "   v_cndmask_b32   v154, v65, v107, vcc dst_sel:word1 sext:[0,1] neg:[0,1]",
916        0x0334d6f9U, 0x1e060541U, true, true, "" },
917    { "   v_cndmask_b32   v154, abs(v65), v107, vcc clamp dst_sel:word1",
918        0x0334d6f9U, 0x06262541U, true, true, "" },
919    /* VOP_SDWA - warnings */
920    { "   v_cndmask_b32   v154, abs(v65), v107, vcc dst_sel:word1 dst_sel:word0",
921        0x0334d6f9U, 0x06260441U, true, true,
922        "test.s:1:60: Warning: Dst_sel is already defined\n" },
923    { "   v_cndmask_b32   v154, abs(v65), v107, vcc src0_sel:word1 src0_sel:word0",
924        0x0334d6f9U, 0x06240641U, true, true,
925        "test.s:1:61: Warning: Src0_sel is already defined\n" },
926    { "   v_cndmask_b32   v154, abs(v65), v107, vcc src1_sel:word1 src1_sel:word0",
927        0x0334d6f9U, 0x04260641U, true, true,
928        "test.s:1:61: Warning: Src1_sel is already defined\n" },
929    { "   v_cndmask_b32   v154, v65, v107, vcc dst_unused:pad dst_un:PRESERVE",
930        0x0334d6f9U, 0x06061641U, true, true,
931        "test.s:1:56: Warning: Dst_unused is already defined\n" },
932    /* VOP_SDWA - errors */
933    { "   v_cndmask_b32   v154, v67, v107, vcc dst_sel:byte", 0, 0, false, false,
934        "test.s:1:49: Error: Unknown dst_sel\n" },
935    { "   v_cndmask_b32   v154, v67, v107, vcc dst_sel:", 0, 0, false, false,
936        "test.s:1:49: Error: Expected dst_sel\n" },
937    { "   v_cndmask_b32   v154, v67, v107, vcc dst_sel  ", 0, 0, false, false,
938        "test.s:1:50: Error: Expected ':' before dst_sel\n" },
939    { "   v_cndmask_b32   v154, v67, v107, vcc src0_sel:byte", 0, 0, false, false,
940        "test.s:1:50: Error: Unknown src0_sel\n" },
941    { "   v_cndmask_b32   v154, v67, v107, vcc src0_sel:", 0, 0, false, false,
942        "test.s:1:50: Error: Expected src0_sel\n" },
943    { "   v_cndmask_b32   v154, v67, v107, vcc src0_sel  ", 0, 0, false, false,
944        "test.s:1:51: Error: Expected ':' before src0_sel\n" },
945    { "   v_cndmask_b32   v154, v67, v107, vcc src1_sel:byte", 0, 0, false, false,
946        "test.s:1:50: Error: Unknown src1_sel\n" },
947    { "   v_cndmask_b32   v154, v67, v107, vcc src1_sel:", 0, 0, false, false,
948        "test.s:1:50: Error: Expected src1_sel\n" },
949    { "   v_cndmask_b32   v154, v67, v107, vcc src1_sel  ", 0, 0, false, false,
950        "test.s:1:51: Error: Expected ':' before src1_sel\n" },
951    { "   v_cndmask_b32   v154, v65, v107, vcc dst_unused:xpad", 0, 0, false, false,
952        "test.s:1:52: Error: Unknown dst_unused\n" },
953    { "   v_cndmask_b32   v154, v65, v107, vcc dst_unused", 0, 0, false, false,
954        "test.s:1:51: Error: Expected ':' before dst_unused\n" },
955    { "   v_cndmask_b32   v154, 65, v107, vcc dst_sel:word1", 0, 0, false, false,
956        "test.s:1:4: Error: Literal with SDWA or DPP word is illegal\n" },
957    // extra from GCN 1.4
958    { "   v_cndmask_b32   v154, v0, v107, vcc dst_sel:byte0 src0_sel:byte0 src1_sel:byte0",
959        0x0334d6f9U, 0, true, true, "" },
960    { "   v_cndmask_b32   v154, v0, v107, vcc "
961        "mul:4 dst_sel:byte0 src0_sel:byte0 src1_sel:byte0",
962        0x0334d6f9U, 0x8000, true, true, "" },
963    { "v_add_f32   v154, v61, v107 dst_sel:byte0 src0_sel:byte0 src1_sel:byte0\n",
964        0x0734d6f9U, 0x0000003dU, true, true, "" },
965    { "v_add_f32   v154, v61, vcc_hi dst_sel:byte0 src0_sel:byte0 src1_sel:byte0\n",
966        0x0734d6f9U, 0x8000003dU, true, true, "" },
967    { "v_add_f32   v154, s61, v107 dst_sel:byte0 src0_sel:byte0 src1_sel:byte0\n",
968        0x0734d6f9U, 0x0080003dU, true, true, "" },
969    { "v_cndmask_b32   v154, sext(-abs(v65)), v107, vcc mul:2",
970        0x0334d6f9U, 0x063e4641U, true, true, "" },
971    { "v_add_f32   v154, sext(-abs(v65)), vcc_hi",
972        0x0734d6f9U, 0x863e0641U, true, true, "" },
973    { "v_add_f32   v154, sext(-abs(s65)), v107",
974        0x0734d6f9U, 0x06be0641U, true, true, "" },
975    /* VOP2 - DPP */
976    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bank_mask:0 row_mask:0",
977        0x0334d6faU, 0xbe, true, true, ""  },
978    { "   v_cndmask_b32  v154, v190, v107, vcc bank_mask:0 row_mask:0",
979        0x0334d6faU, 0xe4be, true, true, ""  },
980    { "   v_cndmask_b32_dpp  v154, v190, v107, vcc bank_mask:0 row_mask:0",
981        0x0334d6faU, 0xe4be, true, true, ""  },
982    { "   v_cndmask_b32_dpp  v154, v190, v107, vcc",
983        0x0334d6faU, 0xff00e4be, true, true, ""  },
984    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[2,1,0,3] "
985        "bank_mask:14 row_mask:11", 0x0334d6faU, 0xbe00c6be, true, true, "" },
986    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[3,2,1,2] "
987        "bank_mask:14 row_mask:11", 0x0334d6faU, 0xbe009bbe, true, true, "" },
988    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm :  [ 2  , 1 , 0  , 3  ] "
989        "bank_mask  : 14 row_mask  :  11   ", 0x0334d6faU, 0xbe00c6be, true, true, "" },
990    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bound_ctrl",
991        0x0334d6faU, 0xff0800be, true, true, "" },
992    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bound_ctrl : 1",
993        0x0334d6faU, 0xff0800be, true, true, "" },
994    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bound_ctrl : 0 ",
995        0x0334d6faU, 0xff0800be, true, true, "" },
996    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bound_ctrl:0:1",
997        0x0334d6faU, 0xff0800be, true, true, "" },
998    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bound_ctrl:0:0",
999        0x0334d6faU, 0xff0000be, true, true, "" },
1000    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bound_ctrl:1:1",
1001        0x0334d6faU, 0xff0800be, true, true, "" },
1002    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bound_ctrl:1:0",
1003        0x0334d6faU, 0xff0000be, true, true, "" },
1004    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bank_mask:0 row_mask:0",
1005        0x0334d6faU, 0xbe, true, true, "" },
1006    { "   v_cndmask_b32  v154, v190, v107, vcc row_shl:3 ",
1007        0x0334d6faU, 0xff0103be, true, true, "" },
1008    { "   v_cndmask_b32  v154, v190, v107, vcc row_shl:14 ",
1009        0x0334d6faU, 0xff010ebe, true, true, "" },
1010    { "   v_cndmask_b32  v154, v190, v107, vcc row_shr:3 ",
1011        0x0334d6faU, 0xff0113be, true, true, "" },
1012    { "   v_cndmask_b32  v154, v190, v107, vcc row_shr:14 ",
1013        0x0334d6faU, 0xff011ebe, true, true, "" },
1014    { "   v_cndmask_b32  v154, v190, v107, vcc row_ror:3 ",
1015        0x0334d6faU, 0xff0123be, true, true, "" },
1016    { "   v_cndmask_b32  v154, v190, v107, vcc row_ror:14 ",
1017        0x0334d6faU, 0xff012ebe, true, true, "" },
1018    { "   v_cndmask_b32  v154, v190, v107, vcc row_ror :  14 ",
1019        0x0334d6faU, 0xff012ebe, true, true, "" },
1020    { "   v_cndmask_b32  v154, v190, v107, vcc row_mirror",
1021        0x0334d6faU, 0xff0140be, true, true, "" },
1022    { "   v_cndmask_b32  v154, v190, v107, vcc row_half_mirror",
1023        0x0334d6faU, 0xff0141be, true, true, "" },
1024    { "   v_cndmask_b32  v154, v190, v107, vcc row_hmirror",
1025        0x0334d6faU, 0xff0141be, true, true, "" },
1026    { "   v_cndmask_b32  v154, abs(v190), -v107, vcc row_shl:3 ",
1027        0x0334d6faU, 0xff6103be, true, true, "" },
1028    { "   v_cndmask_b32  v154, abs(v190), -abs(v107), vcc row_shl:3 ",
1029        0x0334d6faU, 0xffe103be, true, true, "" },
1030    { "   v_cndmask_b32  v154, -v190, -abs(v107), vcc row_shl:3 ",
1031        0x0334d6faU, 0xffd103be, true, true, "" },
1032    /* VOP_DPP warnings */
1033    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[2,1,0,3] bank_mask:1 "
1034        "bank_mask:14 row_mask:2 row_mask:11", 0x0334d6faU, 0xbe00c6be, true, true,
1035        "test.s:1:73: Warning: Bank_mask is already defined\n"
1036        "test.s:1:97: Warning: Row_mask is already defined\n"  },
1037    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[0,0,0,0] bound_ctrl:0 bound_ctrl",
1038        0x0334d6faU, 0xff0800be, true, true,
1039        "test.s:1:74: Warning: BoundCtrl is already defined\n" },
1040    { "   v_cndmask_b32  v154, v190, v107, vcc row_ror:2 row_ror:1 ",
1041        0x0334d6faU, 0xff0121be, true, true,
1042        "test.s:1:51: Warning: DppCtrl is already defined\n" },
1043    { "   v_cndmask_b32  v154, v190, v107, vcc row_half_mirror row_ror:1 ",
1044        0x0334d6faU, 0xff0121be, true, true,
1045        "test.s:1:57: Warning: DppCtrl is already defined\n" },
1046    { "   v_cndmask_b32  v154, v190, v107, vcc row_ror:35 ",
1047        0x0334d6faU, 0xff0123be, true, true,
1048        "test.s:1:49: Warning: Value 0x23 truncated to 0x3\n" },
1049    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[2,1,0,3] "
1050        "bank_mask:0xdde row_mask:0xabc3b", 0x0334d6faU, 0xbe00c6be, true, true,
1051        "test.s:1:71: Warning: Value 0xdde truncated to 0xe\n"
1052        "test.s:1:86: Warning: Value 0xabc3b truncated to 0xb\n" },
1053    /* VOP_DPP errors */
1054    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[2,,0,3]", 0, 0, false, false,
1055        "test.s:1:54: Error: Expected expression\n" },
1056    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[2,1,0,3  ", 0, 0, false, false,
1057        "test.s:1:61: Error: Unterminated quad_perm\n" },
1058    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[2 1 0 3]  ", 0, 0, false, false,
1059        "test.s:1:54: Error: Expected ',' before quad_perm component\n"
1060        "test.s:1:54: Error: Some garbages at VOP modifier place\n"
1061        "test.s:1:56: Error: Some garbages at VOP modifier place\n"
1062        "test.s:1:58: Error: Some garbages at VOP modifier place\n" },
1063    { "   v_cndmask_b32  v154, v190, v107, vcc row_shl:0", 0, 0, false, false,
1064        "test.s:1:49: Error: Illegal zero shift for row_XXX shift\n" },
1065    { "   v_cndmask_b32  v154, v190, v107, vcc row_shl:32", 0, 0, false, false,
1066        "test.s:1:49: Warning: Value 0x20 truncated to 0x0\n"
1067        "test.s:1:49: Error: Illegal zero shift for row_XXX shift\n" },
1068    { "   v_cndmask_b32  v154, v190, v107, vcc row_shl:1 bound_ctrl:3", 0, 0, false, false,
1069        "test.s:1:62: Error: Value must be '0' or '1'\n"
1070        "test.s:1:62: Error: Some garbages at VOP modifier place\n" },
1071    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm:[2,1,0,3] "
1072        "bank_mask:, row_mask:", 0, 0, false, false,
1073        "test.s:1:71: Error: Expected expression\n"
1074        "test.s:1:71: Error: Some garbages at VOP modifier place\n"
1075        "test.s:1:82: Error: Expected expression\n" },
1076    { "   v_cndmask_b32  v154, v190, v107, vcc quad_perm bank_mask row_mask",
1077        0, 0, false, false, "test.s:1:51: Error: Expected ':' before quad_perm\n"
1078        "test.s:1:61: Error: Expected ':' before bank_mask\n"
1079        "test.s:1:69: Error: Expected ':' before row_mask\n" },
1080    { "   v_cndmask_b32  v154, v190, v107, vcc row_shl ", 0, 0, false, false,
1081        "test.s:1:49: Error: Expected ':' before row_shl\n" },
1082    { "   v_cndmask_b32  v154, sext(v190), v107, vcc row_shl:3 ", 0, 0, false, false,
1083        "test.s:1:4: Error: SEXT modifiers is unavailable for DPP word\n" },
1084    { "   v_cndmask_b32  v154, 12333, v107, vcc bank_mask:0 row_mask:0", 0, 0,
1085        false, false, "test.s:1:4: Error: Literal with SDWA or DPP word is illegal\n" },
1086    { "   v_cndmask_b32  v154, v190, v107, vcc wave_shl ", 0, 0, false, false,
1087        "test.s:1:41: Error: Unknown VOP modifier\n" },
1088    { "   v_cndmask_b32  v154, v190, v107, vcc wave_rol ", 0, 0, false, false,
1089        "test.s:1:41: Error: Unknown VOP modifier\n" },
1090    { "   v_cndmask_b32  v154, v190, v107, vcc wave_shr ", 0, 0, false, false,
1091        "test.s:1:41: Error: Unknown VOP modifier\n" },
1092    { "   v_cndmask_b32  v154, v190, v107, vcc wave_ror ", 0, 0, false, false,
1093        "test.s:1:41: Error: Unknown VOP modifier\n" },
1094    { "   v_cndmask_b32  v154, v190, v107, vcc row_bcast:15", 0, 0, false, false,
1095        "test.s:1:41: Error: Unknown VOP modifier\n"
1096        "test.s:1:50: Error: Some garbages at VOP modifier place\n" },
1097    { "   v_cndmask_b32  v154, v190, v107, vcc row_bcast15", 0, 0, false, false,
1098        "test.s:1:41: Error: Unknown VOP modifier\n" },
1099    { "   v_cndmask_b32  v154, v190, v107, vcc row_bcast:31", 0, 0, false, false,
1100        "test.s:1:41: Error: Unknown VOP modifier\n"
1101        "test.s:1:50: Error: Some garbages at VOP modifier place\n" },
1102    { "   v_cndmask_b32  v154, v190, v107, vcc row_bcast31", 0, 0, false, false,
1103        "test.s:1:41: Error: Unknown VOP modifier\n" },
1104    /* VOP DPP for GFX10 */
1105    { "v_add_f32       v154, v190, v107 row_share:6 bank_mask:0 row_mask:0\n",
1106        0x0734d6faU, 0x156be, true, true, "" },
1107    { "v_add_f32       v154, v190, v107 row_share:15 bank_mask:0 row_mask:0\n",
1108        0x0734d6faU, 0x15fbe, true, true, "" },
1109    { "v_add_f32       v154, v190, v107 row_share:0 bank_mask:0 row_mask:0\n",
1110        0x0734d6faU, 0x150be, true, true, "" },
1111    { "v_add_f32       v154, v190, v107 row_xmask:6 bank_mask:0 row_mask:0\n",
1112        0x0734d6faU, 0x166be, true, true, "" },
1113    { "v_add_f32       v154, v190, v107 row_xmask:15 bank_mask:0 row_mask:0\n",
1114        0x0734d6faU, 0x16fbe, true, true, "" },
1115    { "v_add_f32       v154, v190, v107 row_xmask:0 bank_mask:0 row_mask:0\n",
1116        0x0734d6faU, 0x160be, true, true, "" },
1117    { "v_add_f32       v154, v190, v107 row_mirror bank_mask:0 row_mask:0 fi\n",
1118        0x0734d6faU, 0x540be, true, true, "" },
1119    { "v_add_f32       v154, v190, v107 row_mirror bank_mask:0 row_mask:0 fi:1\n",
1120        0x0734d6faU, 0x540be, true, true, "" },
1121    { "v_add_f32       v154, v190, v107 row_mirror bank_mask:0 row_mask:0 fi  :  1\n",
1122        0x0734d6faU, 0x540be, true, true, "" },
1123    { "v_add_f32       v154, v190, v107 row_mirror bank_mask:0 row_mask:0 fi:0\n",
1124        0x0734d6faU, 0x140be, true, true, "" },
1125    /* VOP DPP8 */
1126    { "v_add_f32       v154, v190, v107 dpp8:[1,7,2,5,6,3,6,4]\n",
1127        0x0734d6e9U, 0x99eab9be, true, true, "" },
1128    { "v_add_f32_dpp   v154, v190, v107 dpp8:[1,7,2,5,6,3,6,4]\n",
1129        0x0734d6e9U, 0x99eab9be, true, true, "" },
1130    { "v_add_f32       v154, v190, v107 dpp8 :  [ 1 ,  7, 2, 5, 6, 3 , 6 , 4  ]  \n",
1131        0x0734d6e9U, 0x99eab9be, true, true, "" },
1132    { "a=6; v_add_f32       v154, v190, v107 dpp8:[1,7,2,5,a,a/2,a,4]\n",
1133        0x0734d6e9U, 0x99eab9be, true, true, "" },
1134    { "v_add_f32       v154, v190, v107 dpp8:[1,7,2,5,6,3,6,4] fi\n",
1135        0x0734d6eaU, 0x99eab9be, true, true, "" },
1136    { "v_add_f32       v154, v190, v107  fi:1   dpp8:[1,7,2,5,6,3,6,4]\n",
1137        0x0734d6eaU, 0x99eab9be, true, true, "" },
1138    { "v_add_f32       v154, v190, v107 dpp8:[1,7,2,13,6,3,6,4]\n",
1139        0x0734d6e9U, 0x99eab9be, true, true,
1140        "test.s:1:46: Warning: Value 0xd truncated to 0x5\n" },
1141    { "v_add_f32       v154, v190, v107 dpp8:[1,7,2,5,6,3,6,0x1114]\n",
1142        0x0734d6e9U, 0x99eab9be, true, true,
1143        "test.s:1:54: Warning: Value 0x1114 truncated to 0x4\n" },
1144    { "v_add_f32       v154, v190, v107 dpp8:[0,7,0,0,0,0,0,0]\n",
1145        0x0734d6e9U, 0x38be, true, true, "" },
1146    { "v_add_f32       v154, v190, v107 dpp8:[0,0,7,0,0,0,0,0]\n",
1147        0x0734d6e9U, 0x1c0be, true, true, "" },
1148    { "v_add_f32       v154, v190, v107 dpp8:[0,0,0,7,0,0,0,0]\n",
1149        0x0734d6e9U, 0xe00be, true, true, "" },
1150    { "v_add_f32       v154, v190, v107 dpp8:[0,0,0,0,0,0,7,0]\n",
1151        0x0734d6e9U, 0x1c0000be, true, true, "" },
1152    { "v_add_f32       v154, v190, v107 dpp8:[0,0,0,0,0,0,0,7]\n",
1153        0x0734d6e9U, 0xe00000be, true, true, "" },
1154    /* VOP DPP8 errors */
1155    { "v_add_f32  v154, v190, abs(v107) dpp8:[1,7,2,5,6,3,6,4]\n", 0, 0, false, false,
1156        "test.s:1:1: Error: ABS and NEG modifiers is unavailable for DPP8 word\n" },
1157    { "v_add_f32  v154, v190, -v107 dpp8:[1,7,2,5,6,3,6,4]\n", 0, 0, false, false,
1158        "test.s:1:1: Error: ABS and NEG modifiers is unavailable for DPP8 word\n" },
1159    { "v_add_f32  v154, abs(v190), v107 dpp8:[1,7,2,5,6,3,6,4]\n", 0, 0, false, false,
1160        "test.s:1:1: Error: ABS and NEG modifiers is unavailable for DPP8 word\n" },
1161    { "v_add_f32  v154, -v190, v107 dpp8:[1,7,2,5,6,3,6,4]\n", 0, 0, false, false,
1162        "test.s:1:1: Error: ABS and NEG modifiers is unavailable for DPP8 word\n" },
1163    { "v_add_f32       v154, s10, v107 dpp8:[1,7,2,5,6,3,6,4]\n", 0, 0, false, false,
1164        "test.s:1:1: Error: SRC0 must be a vector register with DPP word\n" },
1165    { "v_add_f32 v154, v190, sext(v107) dpp8:[1,7,2,5,6,3,6,4]\n", 0, 0, false, false,
1166        "test.s:1:1: Error: SEXT modifiers is unavailable for DPP word\n" },
1167    { "v_add_f32 v154, v190, v107 row_shl:3 dpp8:[1,7,2,5,6,3,6,4]\n", 0, 0, false, false,
1168        "test.s:1:28: Error: Mixing modifiers from different encodings is illegal\n" },
1169    /* VOP2 instructions */
1170    { "    v_sub_f32  v154, v21, v107", 0x0934d715U, 0, false, true, "" },
1171    { "    v_sub_f32  v55, s27, -v90", 0xd5040037U, 0x4002b41bU, true, true, "" },
1172    { "    v_subrev_f32  v154, v21, v107", 0x0b34d715U, 0, false, true, "" },
1173    { "    v_subrev_f32  v55, s27, -v90", 0xd5050037U, 0x4002b41bU, true, true, "" },
1174    { "    v_mac_legacy_f32  v154, v21, v107", 0x0d34d715U, 0, false, true, "" },
1175    { "    v_mac_legacy_f32  v55, s27, -v90", 0xd5060037U, 0x4002b41bU, true, true, "" },
1176    { "    v_mul_legacy_f32  v154, v21, v107", 0x0f34d715U, 0, false, true, "" },
1177    { "    v_mul_legacy_f32  v55, s27, -v90", 0xd5070037U, 0x4002b41bU, true, true, "" },
1178    { "    v_mul_f32  v154, v21, v107", 0x1134d715U, 0, false, true, "" },
1179    { "    v_mul_f32  v55, s27, -v90", 0xd5080037U, 0x4002b41bU, true, true, "" },
1180    { "    v_mul_i32_i24  v154, v21, v107", 0x1334d715U, 0, false, true, "" },
1181    { "    v_mul_i32_i24  v55, s27, -v90", 0xd5090037U, 0x4002b41bU, true, true, "" },
1182    { "    v_mul_hi_i32_i24  v154, v21, v107", 0x1534d715U, 0, false, true, "" },
1183    { "    v_mul_hi_i32_i24  v55, s27, -v90", 0xd50a0037U, 0x4002b41bU, true, true, "" },
1184    { "    v_mul_u32_u24  v154, v21, v107", 0x1734d715U, 0, false, true, "" },
1185    { "    v_mul_u32_u24  v55, s27, -v90", 0xd50b0037U, 0x4002b41bU, true, true, "" },
1186    { "    v_mul_hi_u32_u24  v154, v21, v107", 0x1934d715U, 0, false, true, "" },
1187    { "    v_mul_hi_u32_u24  v55, s27, -v90", 0xd50c0037U, 0x4002b41bU, true, true, "" },
1188    { "    v_min_legacy_f32  v154, v21, v107", 0, 0, false, false,
1189        "test.s:1:5: Error: Unknown instruction\n" },
1190    { "    v_min_legacy_f32  v55, s27, -v90", 0, 0, false, false,
1191        "test.s:1:5: Error: Unknown instruction\n" },
1192    { "    v_max_legacy_f32  v154, v21, v107", 0, 0, false, false,
1193        "test.s:1:5: Error: Unknown instruction\n" },
1194    { "    v_max_legacy_f32  v55, s27, -v90", 0, 0, false, false,
1195        "test.s:1:5: Error: Unknown instruction\n" },
1196    { "    v_min_f32  v154, v21, v107", 0x1f34d715U, 0, false, true, "" },
1197    { "    v_min_f32  v55, s27, -v90", 0xd50f0037U, 0x4002b41bU, true, true, "" },
1198    { "    v_max_f32  v154, v21, v107", 0x2134d715U, 0, false, true, "" },
1199    { "    v_max_f32  v55, s27, -v90", 0xd5100037U, 0x4002b41bU, true, true, "" },
1200    { "    v_min_i32  v154, v21, v107", 0x2334d715U, 0, false, true, "" },
1201    { "    v_min_i32  v55, s27, -v90", 0xd5110037U, 0x4002b41bU, true, true, "" },
1202    { "    v_max_i32  v154, v21, v107", 0x2534d715U, 0, false, true, "" },
1203    { "    v_max_i32  v55, s27, -v90", 0xd5120037U, 0x4002b41bU, true, true, "" },
1204    { "    v_min_u32  v154, v21, v107", 0x2734d715U, 0, false, true, "" },
1205    { "    v_min_u32  v55, s27, -v90", 0xd5130037U, 0x4002b41bU, true, true, "" },
1206    { "    v_max_u32  v154, v21, v107", 0x2934d715U, 0, false, true, "" },
1207    { "    v_max_u32  v55, s27, -v90", 0xd5140037U, 0x4002b41bU, true, true, "" },
1208    { "    v_lshr_b32  v154, v21, v107", 0, 0, false, false,
1209        "test.s:1:5: Error: Unknown instruction\n" },
1210    { "    v_lshr_b32  v55, s27, -v90", 0, 0, false, false,
1211        "test.s:1:5: Error: Unknown instruction\n" },
1212    { "    v_lshrrev_b32  v154, v21, v107", 0x2d34d715U, 0, false, true, "" },
1213    { "    v_lshrrev_b32  v55, s27, -v90", 0xd5160037U, 0x4002b41bU, true, true, "" },
1214    { "    v_ashr_i32  v154, v21, v107", 0, 0, false, false,
1215        "test.s:1:5: Error: Unknown instruction\n" },
1216    { "    v_ashr_i32  v55, s27, -v90", 0, 0, false, false,
1217        "test.s:1:5: Error: Unknown instruction\n" },
1218    { "    v_ashrrev_i32  v154, v21, v107", 0x3134d715U, 0, false, true, "" },
1219    { "    v_ashrrev_i32  v55, s27, -v90", 0xd5180037U, 0x4002b41bU, true, true, "" },
1220    { "    v_lshl_b32  v154, v21, v107", 0, 0, false, false,
1221        "test.s:1:5: Error: Unknown instruction\n" },
1222    { "    v_lshl_b32  v55, s27, -v90", 0, 0, false, false,
1223        "test.s:1:5: Error: Unknown instruction\n" },
1224    { "    v_lshlrev_b32  v154, v21, v107", 0x3534d715U, 0, false, true, "" },
1225    { "    v_lshlrev_b32  v55, s27, -v90", 0xd51a0037U, 0x4002b41bU, true, true, "" },
1226    { "    v_and_b32  v154, v21, v107", 0x3734d715U, 0, false, true, "" },
1227    { "    v_and_b32  v55, s27, -v90", 0xd51b0037U, 0x4002b41bU, true, true, "" },
1228    { "    v_or_b32  v154, v21, v107", 0x3934d715U, 0, false, true, "" },
1229    { "    v_or_b32  v55, s27, -v90", 0xd51c0037U, 0x4002b41bU, true, true, "" },
1230    { "    v_xor_b32  v154, v21, v107", 0x3b34d715U, 0, false, true, "" },
1231    { "    v_xor_b32  v55, s27, -v90", 0xd51d0037U, 0x4002b41bU, true, true, "" },
1232    { "    v_xnor_b32  v154, v21, v107", 0x3d34d715U, 0, false, true, "" },
1233    { "    v_xnor_b32  v55, s27, -v90", 0xd51e0037U, 0x4002b41bU, true, true, "" },
1234    { "    v_mac_f32  v154, v21, v107", 0x3f34d715U, 0, false, true, "" },
1235    { "    v_mac_f32  v55, s27, -v90", 0xd51f0037U, 0x4002b41bU, true, true, "" },
1236    { "    v_madmk_f32 v154, v21, 6.9551627e+13, v107",
1237        0x4134d715U, 0x567d0700U, true, true, "" },
1238    { "    v_madmk_f32 v154, v21, 45543, v107", 0x4134d715U, 45543, true, true, "" },
1239    { "cxx=77111;v_madmk_f32 v154, v21, cxx, v107", 0x4134d715U, 77111, true, true, "" },
1240    { "v_madmk_f32 v154, v21, cxx, v107; cxx=77111", 0x4134d715U, 77111, true, true, "" },
1241    { "    v_madak_f32 v154, v21, v107, 6.9551627e+13",
1242        0x4334d715U, 0x567d0700U, true, true, "" },
1243    { "    v_madak_f32 v154, v21, v107, 6.9551627e+13s",
1244        0x4334d715U, 0x567d0700U, true, true, "" },
1245    { "    v_madak_f32 v154, v21, v107, 6.9551627h", 0x4334d715U, 0x46f5U, true, true, "" },
1246    { "    v_madak_f32 v154, v21, v107, 45543", 0x4334d715U, 45543, true, true, "" },
1247    { "cxx=77111;v_madak_f32 v154, v21, v107, cxx", 0x4334d715U, 77111, true, true, "" },
1248    { "v_madak_f32 v154, v21, v107, cxx; cxx=77111", 0x4334d715U, 77111, true, true, "" },
1249    { "    v_add_nc_u32  v154, v21, v107", 0x4b34d715U, 0, false, true, "" },
1250    { "    v_add_nc_u32  v55, s27, -v90", 0xd5250037U, 0x4002b41bU, true, true, "" },
1251    { "    v_sub_nc_u32  v154, v21, v107", 0x4d34d715U, 0, false, true, "" },
1252    { "    v_sub_nc_u32  v55, s27, -v90", 0xd5260037U, 0x4002b41bU, true, true, "" },
1253    { "    v_subrev_nc_u32  v154, v21, v107", 0x4f34d715U, 0, false, true, "" },
1254    { "    v_subrev_nc_u32  v55, s27, -v90", 0xd5270037U, 0x4002b41bU, true, true, "" },
1255    { "    v_addc_u32  v154, vcc, v21, v107, vcc", 0x5134d715U, 0, false, true, "" },
1256    { "    v_addc_u32  v154, vcc[0:1], v21, v107, vcc[0:1]",
1257        0x5134d715U, 0, false, true, "" },
1258    { "    v_addc_u32_e32  v154, vcc, v21, v107, vcc", 0x5134d715U, 0, false, true, "" },
1259    { "    v_add_co_ci_u32  v154, vcc, v21, v107, vcc", 0x5134d715U, 0, false, true, "" },
1260    { "    v_add_co_ci_u32  v154, vcc[0:1], v21, v107, vcc[0:1]",
1261        0x5134d715U, 0, false, true, "" },
1262    { "    v_add_co_ci_u32_e32  v154, vcc, v21, v107, vcc",
1263        0x5134d715U, 0, false, true, "" },
1264    { "    v_subb_u32  v154, vcc, v21, v107, vcc", 0x5334d715U, 0, false, true, "" },
1265    { "    v_subbrev_u32  v154, vcc, v21, v107, vcc", 0x5534d715U, 0, false, true, "" },
1266    { "    v_sub_co_ci_u32  v154, vcc, v21, v107, vcc", 0x5334d715U, 0, false, true, "" },
1267    { "    v_subrev_co_ci_u32  v154, vcc, v21, v107, vcc",
1268        0x5534d715U, 0, false, true, "" },
1269    { "    v_addc_u32 v55, s[6:7], v27, -v90, s[24:25]\n",
1270            0xd5280637U, 0x4062b51bU, true, true, "" },
1271    { "    v_subb_u32 v55, s[6:7], v27, -v90, s[24:25]\n",
1272            0xd5290637U, 0x4062b51bU, true, true, "" },
1273    { "    v_subbrev_u32 v55, s[6:7], v27, -v90, s[24:25]\n",
1274            0xd52a0637U, 0x4062b51bU, true, true, "" },
1275    { "    v_add_co_ci_u32 v55, s[6:7], v27, -v90, s[24:25]\n",
1276            0xd5280637U, 0x4062b51bU, true, true, "" },
1277    { "    v_sub_co_ci_u32 v55, s[6:7], v27, -v90, s[24:25]\n",
1278            0xd5290637U, 0x4062b51bU, true, true, "" },
1279    { "    v_subrev_co_ci_u32 v55, s[6:7], v27, -v90, s[24:25]\n",
1280            0xd52a0637U, 0x4062b51bU, true, true, "" },
1281    { "    v_fmac_f32  v154, v21, v107", 0x5734d715U, 0, false, true, "" },
1282    { "    v_fmac_f32  v55, s27, -v90", 0xd52b0037U, 0x4002b41bU, true, true, "" },
1283    { "    v_fmamk_f32 v154, v21, 45543, v107", 0x5934d715U, 45543, true, true, "" },
1284    { "cxx=72133;v_fmamk_f32 v154, v21, cxx, v107", 0x5934d715U, 72133, true, true, "" },
1285    { "v_fmamk_f32 v154, v21, cxx, v107; cxx=55345", 0x5934d715U, 55345, true, true, "" },
1286    { "    v_fmamk_f32 v154, v21, 6.9551627e+13, v107",
1287        0x5934d715U, 0x567d0700U, true, true, "" },
1288    { "    v_fmamk_f32 v154, v21, 6.9551627e+13s, v107",
1289        0x5934d715U, 0x567d0700U, true, true, "" },
1290    { "    v_fmaak_f32 v154, v21, v107, 6.9551627e+13",
1291        0x5b34d715U, 0x567d0700U, true, true, "" },
1292    { "    v_fmaak_f32 v154, v21, v107, 6.9551627e+13s",
1293        0x5b34d715U, 0x567d0700U, true, true, "" },
1294    { "    v_fmaak_f32 v154, v21, v107, 6.9551627h", 0x5b34d715U, 0x46f5U, true, true, "" },
1295    { "    v_fmaak_f32 v154, v21, v107, 45521", 0x5b34d715U, 45521, true, true, "" },
1296    { "cxx=142113;v_fmaak_f32 v154, v21, v107, cxx", 0x5b34d715U, 142113, true, true, "" },
1297    { "v_fmaak_f32 v154, v21, v107, cxx; cxx=389921", 0x5b34d715U, 389921, true, true, "" },
1298    { "    v_cvt_pkrtz_f16_f32 v154, v21, v107", 0x5f34d715U, 0, false, true, "" },
1299    { "    v_cvt_pkrtz_f16_f32 v55, s27, -v90", 0xd52f0037U, 0x4002b41bU, true, true, "" },
1300    { "    v_add_f16  v154, v21, v107", 0x6534d715U, 0, false, true, "" },
1301    { "    v_add_f16  v154, 1.374, v107", 0x6534d6ffU, 0x3d7f, true, true, "" },
1302    { "    v_add_f16  v55, s27, v90 vop3", 0xd5320037U, 0x0002b41bU, true, true, "" },
1303    { "    v_sub_f16  v154, v21, v107", 0x6734d715U, 0, false, true, "" },
1304    { "    v_sub_f16  v55, s27, v90 vop3", 0xd5330037U, 0x0002b41bU, true, true, "" },
1305    { "    v_subrev_f16  v154, v21, v107", 0x6934d715U, 0, false, true, "" },
1306    { "    v_subrev_f16  v55, s27, v90 vop3", 0xd5340037U, 0x0002b41bU, true, true, "" },
1307    { "    v_mul_f16  v154, v21, v107", 0x6b34d715U, 0, false, true, "" },
1308    { "    v_mul_f16  v55, s27, v90 vop3", 0xd5350037U, 0x0002b41bU, true, true, "" },
1309    { "    v_fmac_f16  v154, v21, v107", 0x6d34d715U, 0, false, true, "" },
1310    { "    v_fmac_f16  v55, s27, v90 vop3", 0xd5360037U, 0x0002b41bU, true, true, "" },
1311    { "    v_fmamk_f16 v154, v21, 6.9551, v107", 0x6f34d715U, 0x000046f5U, true, true, "" },
1312    { "    v_fmamk_f16 v154, v21, 45543, v107", 0x6f34d715U, 45543, true, true, "" },
1313    { "    v_fmaak_f16 v154, v21, v107, 6.9551", 0x7134d715U, 0x000046f5U, true, true, "" },
1314    { "    v_fmaak_f16 v154, v21, v107, 45543", 0x7134d715U, 45543, true, true, "" },
1315    { "    v_max_f16  v154, v21, v107", 0x7334d715U, 0, false, true, "" },
1316    { "    v_max_f16  v55, s27, v90 vop3", 0xd5390037U, 0x0002b41bU, true, true, "" },
1317    { "    v_min_f16  v154, v21, v107", 0x7534d715U, 0, false, true, "" },
1318    { "    v_min_f16  v55, s27, v90 vop3", 0xd53a0037U, 0x0002b41bU, true, true, "" },
1319    { "    v_ldexp_f16  v154, v21, v107", 0x7734d715U, 0, false, true, "" },
1320    { "    v_ldexp_f16  v55, s27, v90 vop3", 0xd53b0037U, 0x0002b41bU, true, true, "" },
1321    { "    v_pk_fmac_f16  v154, v21, v107", 0x7934d715U, 0, false, true, "" },
1322    { "    v_pk_fmac_f16  v55, s27, v90 vop3", 0, 0, false, false,
1323        "test.s:1:5: Error: No VOP3 encoding for this instruction\n" },
1324    /* VOP1 and VOP1 in VOP3 */
1325    { "    v_nop", 0x7e000000U, 0, false, true, "" },
1326    { "    v_nop vop3", 0xd5800000U, 0, true, true, "" },
1327    { "    v_mov_b32  v158, s79", 0x7f3c024fU, 0, false, true, "" },
1328    { "    v_mov_b32  v15, s79", 0x7e1e024fU, 0, false, true, "" },
1329    { "    v_mov_b32  v15, v79", 0x7e1e034fU, 0, false, true, "" },
1330    { "vxx=9; v_mov_b32  v15, vxx", 0x7e1e0289U, 0, false, true, "" },
1331    { "vxx=9111; v_mov_b32  v15, vxx", 0x7e1e02ffU, 9111, true, true, "" },
1332    { "v_mov_b32  v15, vxx; vxx=9", 0x7e1e02ffU, 9, true, true, "" },
1333    { "v_mov_b32  v15, vxx; vxx=9111", 0x7e1e02ffU, 9111, true, true, "" },
1334    { "v0=9111; v_mov_b32  v15, @v0", 0x7e1e02ffU, 9111, true, true, "" },
1335    { "v_mov_b32  v15, @v0; v0=9", 0x7e1e02ffU, 9, true, true, "" },
1336    { "    v_mov_b32  v15, lds", 0x7e1e02feU, 0, false, true, "" },
1337    { "    v_mov_b32  v15, lds_direct", 0x7e1e02feU, 0, false, true, "" },
1338    { "    v_mov_b32  v55, s27 vop3", 0xd5810037U, 0x0000001bU, true, true, "" },
1339    { "    v_mov_b32  v55, v27 vop3", 0xd5810037U, 0x0000011bU, true, true, "" },
1340    { "    v_mov_b32  v55, v27 clamp", 0xd5818037U, 0x0000011bU, true, true, "" },
1341    { "    v_mov_b32  v55, abs(s27)", 0xd5810137U, 0x0000001bU, true, true, "" },
1342    { "    v_mov_b32  v55, -s27", 0xd5810037U, 0x2000001bU, true, true, "" },
1343    { "    v_mov_b32  v55, -abs(s27)", 0xd5810137U, 0x2000001bU, true, true, "" },
1344    { "    v_readfirstlane_b32 s30, s79", 0x7e3c044fU, 0, false, true, "" },
1345    { "    v_readfirstlane_b32 s30, v79", 0x7e3c054fU, 0, false, true, "" },
1346    { "    v_cvt_i32_f64  v158, v[79:80]", 0x7f3c074fU, 0, false, true, "" },
1347    { "    v_cvt_i32_f64  v55, abs(v[27:28])", 0xd5830137U, 0x0000011bU, true, true, "" },
1348    { "    v_cvt_i32_f64  v55, abs(s[26:27])", 0xd5830137U, 0x0000001aU, true, true, "" },
1349    { "    v_cvt_i32_f64  v55, -s[26:27]", 0xd5830037U, 0x2000001aU, true, true, "" },
1350    { "    v_cvt_f64_i32  v[158:159], v79", 0x7f3c094fU, 0, false, true, "" },
1351    { "    v_cvt_f64_i32  v[55:56], abs(v27)", 0xd5840137U, 0x0000011bU, true, true, "" },
1352    { "    v_cvt_f32_i32  v158, v79", 0x7f3c0b4fU, 0, false, true, "" },
1353    { "    v_cvt_f32_i32  v55, v27 vop3", 0xd5850037U, 0x0000011bU, true, true, "" },
1354    { "    v_cvt_f32_u32  v158, v79", 0x7f3c0d4fU, 0, false, true, "" },
1355    { "    v_cvt_f32_u32  v55, v27 vop3", 0xd5860037U, 0x0000011bU, true, true, "" },
1356    { "    v_cvt_u32_f32  v158, v79", 0x7f3c0f4fU, 0, false, true, "" },
1357    { "    v_cvt_u32_f32  v55, v27 vop3", 0xd5870037U, 0x0000011bU, true, true, "" },
1358    { "    v_cvt_i32_f32  v158, v79", 0x7f3c114fU, 0, false, true, "" },
1359    { "    v_cvt_i32_f32  v55, v27 vop3", 0xd5880037U, 0x0000011bU, true, true, "" },
1360    { "    v_mov_fed_b32  v158, v79", 0x7f3c134fU, 0, false, true, "" },
1361    { "    v_mov_fed_b32  v55, v27 vop3", 0xd5890037U, 0x0000011bU, true, true, "" },
1362    { "    v_cvt_f16_f32  v158, v79", 0x7f3c154fU, 0, false, true, "" },
1363    { "    v_cvt_f16_f32  v55, v27 vop3", 0xd58a0037U, 0x0000011bU, true, true, "" },
1364    { "    v_cvt_f32_f16  v158, v79", 0x7f3c174fU, 0, false, true, "" },
1365    { "    v_cvt_f32_f16  v55, v27 vop3", 0xd58b0037U, 0x0000011bU, true, true, "" },
1366    { "    v_cvt_f32_f16  v158, -23.56h", 0x7f3c16ffU, 0xcde4U, true, true, "" },
1367    /* constant immediates */
1368    { "    v_cvt_f16_f32  v158, 0.0", 0x7f3c1480U, 0, false, true, "" },
1369    { "    v_cvt_f16_f32  v158, 0.5s", 0x7f3c14f0U, 0, false, true, "" },
1370    { "    v_cvt_f16_f32  v158, -0.5s", 0x7f3c14f1U, 0, false, true, "" },
1371    { "    v_cvt_f16_f32  v158, 1.s", 0x7f3c14f2U, 0, false, true, "" },
1372    { "    v_cvt_f16_f32  v158, -1.s", 0x7f3c14f3U, 0, false, true, "" },
1373    { "    v_cvt_f16_f32  v158, 2.s", 0x7f3c14f4U, 0, false, true, "" },
1374    { "    v_cvt_f16_f32  v158, -2.s", 0x7f3c14f5U, 0, false, true, "" },
1375    { "    v_cvt_f16_f32  v158, 4.s", 0x7f3c14f6U, 0, false, true, "" },
1376    { "    v_cvt_f16_f32  v158, -4.s", 0x7f3c14f7U, 0, false, true, "" },
1377    { "    v_cvt_f32_f64  v158, 0.5l", 0x7f3c1ef0U, 0, false, true, "" },
1378    { "    v_cvt_f32_f64  v158, -0.5l", 0x7f3c1ef1U, 0, false, true, "" },
1379    { "    v_cvt_f32_f64  v158, 1.l", 0x7f3c1ef2U, 0, false, true, "" },
1380    { "    v_cvt_f32_f64  v158, -1.l", 0x7f3c1ef3U, 0, false, true, "" },
1381    { "    v_cvt_f32_f64  v158, 2.l", 0x7f3c1ef4U, 0, false, true, "" },
1382    { "    v_cvt_f32_f64  v158, -2.l", 0x7f3c1ef5U, 0, false, true, "" },
1383    { "    v_cvt_f32_f64  v158, 4.l", 0x7f3c1ef6U, 0, false, true, "" },
1384    { "    v_cvt_f32_f64  v158, -4.l", 0x7f3c1ef7U, 0, false, true, "" },
1385    { "    v_cvt_f32_f16  v158, 0.5", 0x7f3c16f0U, 0, false, true, "" },
1386    { "    v_cvt_f32_f16  v158, 2.", 0x7f3c16f4U, 0, false, true, "" },
1387    { "    v_cvt_f32_f16  v158, -2.", 0x7f3c16f5U, 0, false, true, "" },
1388    /* rest of VOP1 instructions */
1389    { "    v_cvt_rpi_i32_f32  v158, v79", 0x7f3c194fU, 0, false, true, "" },
1390    { "    v_cvt_rpi_i32_f32  v55, v27 vop3", 0xd58c0037U, 0x0000011bU, true, true, "" },
1391    { "    v_cvt_flr_i32_f32  v158, v79", 0x7f3c1b4fU, 0, false, true, "" },
1392    { "    v_cvt_flr_i32_f32  v55, v27 vop3", 0xd58d0037U, 0x0000011bU, true, true, "" },
1393    { "    v_cvt_off_f32_i4  v158, v79", 0x7f3c1d4fU, 0, false, true, "" },
1394    { "    v_cvt_off_f32_i4  v55, v27 vop3", 0xd58e0037U, 0x0000011bU, true, true, "" },
1395    { "    v_cvt_f32_f64  v158, v[79:80]", 0x7f3c1f4fU, 0, false, true, "" },
1396    { "    v_cvt_f32_f64  v55, v[27:28] vop3", 0xd58f0037U, 0x0000011bU, true, true, "" },
1397    { "    v_cvt_f64_f32  v[158:159], v79", 0x7f3c214fU, 0, false, true, "" },
1398    { "    v_cvt_f64_f32  v[55:56], v27 vop3", 0xd5900037U, 0x0000011bU, true, true, "" },
1399    { "    v_cvt_f32_ubyte0  v158, v79", 0x7f3c234fU, 0, false, true, "" },
1400    { "    v_cvt_f32_ubyte0  v55, v27 vop3", 0xd5910037U, 0x0000011bU, true, true, "" },
1401    { "    v_cvt_f32_ubyte1  v158, v79", 0x7f3c254fU, 0, false, true, "" },
1402    { "    v_cvt_f32_ubyte1  v55, v27 vop3", 0xd5920037U, 0x0000011bU, true, true, "" },
1403    { "    v_cvt_f32_ubyte2  v158, v79", 0x7f3c274fU, 0, false, true, "" },
1404    { "    v_cvt_f32_ubyte2  v55, v27 vop3", 0xd5930037U, 0x0000011bU, true, true, "" },
1405    { "    v_cvt_f32_ubyte3  v158, v79", 0x7f3c294fU, 0, false, true, "" },
1406    { "    v_cvt_f32_ubyte3  v55, v27 vop3", 0xd5940037U, 0x0000011bU, true, true, "" },
1407    { "    v_cvt_u32_f64  v158, v[79:80]", 0x7f3c2b4fU, 0, false, true, "" },
1408    { "    v_cvt_u32_f64  v55, v[27:28] vop3", 0xd5950037U, 0x0000011bU, true, true, "" },
1409    { "    v_cvt_f64_u32  v[158:159], v79", 0x7f3c2d4fU, 0, false, true, "" },
1410    { "    v_cvt_f64_u32  v[55:56], v27 vop3", 0xd5960037U, 0x0000011bU, true, true, "" },
1411    { "    v_trunc_f64  v[158:159], v[79:80]", 0x7f3c2f4fU, 0, false, true, "" },
1412    { "    v_ceil_f64  v[158:159], v[79:80]", 0x7f3c314fU, 0, false, true, "" },
1413    { "    v_rndne_f64  v[158:159], v[79:80]", 0x7f3c334fU, 0, false, true, "" },
1414    { "    v_floor_f64  v[158:159], v[79:80]", 0x7f3c354fU, 0, false, true, "" },
1415    { "    v_pipeflush\n", 0x7e003600, 0, false, true, "" },
1416    { "    v_fract_f32  v158, v79", 0x7f3c414fU, 0, false, true, "" },
1417    { "    v_fract_f32  v55, v27 vop3", 0xd5a00037U, 0x0000011bU, true, true, "" },
1418    { "    v_trunc_f32  v158, v79", 0x7f3c434fU, 0, false, true, "" },
1419    { "    v_trunc_f32  v55, v27 vop3", 0xd5a10037U, 0x0000011bU, true, true, "" },
1420    { "    v_ceil_f32  v158, v79", 0x7f3c454fU, 0, false, true, "" },
1421    { "    v_ceil_f32  v55, v27 vop3", 0xd5a20037U, 0x0000011bU, true, true, "" },
1422    { "    v_rndne_f32  v158, v79", 0x7f3c474fU, 0, false, true, "" },
1423    { "    v_rndne_f32  v55, v27 vop3", 0xd5a30037U, 0x0000011bU, true, true, "" },
1424    { "    v_floor_f32  v158, v79", 0x7f3c494fU, 0, false, true, "" },
1425    { "    v_floor_f32  v55, v27 vop3", 0xd5a40037U, 0x0000011bU, true, true, "" },
1426    { "    v_exp_f32  v158, v79", 0x7f3c4b4fU, 0, false, true, "" },
1427    { "    v_exp_f32  v55, v27 vop3", 0xd5a50037U, 0x0000011bU, true, true, "" },
1428    { "    v_log_clamp_f32  v158, v79", 0, 0, false, false,
1429        "test.s:1:5: Error: Unknown instruction\n" },
1430    { "    v_log_f32  v158, v79", 0x7f3c4f4fU, 0, false, true, "" },
1431    { "    v_log_f32  v55, v27 vop3", 0xd5a70037U, 0x0000011bU, true, true, "" },
1432    { "    v_rcp_clamp_f32  v158, v79", 0, 0, false, false,
1433        "test.s:1:5: Error: Unknown instruction\n" },
1434    { "    v_rcp_legacy_f32  v158, v79", 0, 0, false, false,
1435        "test.s:1:5: Error: Unknown instruction\n" },
1436    { "    v_rcp_f32  v158, v79", 0x7f3c554fU, 0, false, true, "" },
1437    { "    v_rcp_f32  v55, v27 vop3", 0xd5aa0037U, 0x0000011bU, true, true, "" },
1438    { "    v_rcp_iflag_f32  v158, v79", 0x7f3c574fU, 0, false, true, "" },
1439    { "    v_rcp_iflag_f32  v55, v27 vop3", 0xd5ab0037U, 0x0000011bU, true, true, "" },
1440    { "    v_rsq_clamp_f32  v158, v79", 0, 0, false, false,
1441        "test.s:1:5: Error: Unknown instruction\n" },
1442    { "    v_rsq_legacy_f32  v158, v79", 0, 0, false, false,
1443        "test.s:1:5: Error: Unknown instruction\n" },
1444    { "    v_rsq_f32  v158, v79", 0x7f3c5d4fU, 0, false, true, "" },
1445    { "    v_rsq_f32  v55, v27 vop3", 0xd5ae0037U, 0x0000011bU, true, true, "" },
1446    { "    v_rcp_f64  v[158:159], v[79:80]", 0x7f3c5f4fU, 0, false, true, "" },
1447    { "    v_rcp_f64  v[158:159], s[81:82]", 0x7f3c5e51U, 0, false, true, "" },
1448    { "    v_rcp_f64  v[55:56], v[27:28] vop3", 0xd5af0037U, 0x0000011bU, true, true, "" },
1449    { "    v_rcp_clamp_f64  v[158:159], v[79:80]", 0, 0, false, false,
1450        "test.s:1:5: Error: Unknown instruction\n" },
1451    { "    v_rsq_f64  v[158:159], v[79:80]", 0x7f3c634fU, 0, false, true, "" },
1452    { "    v_rsq_f64  v[55:56], v[27:28] vop3", 0xd5b10037U, 0x0000011bU, true, true, "" },
1453    { "    v_rsq_clamp_f64  v[158:159], v[79:80]", 0, 0, false, false,
1454        "test.s:1:5: Error: Unknown instruction\n" },
1455    { "    v_sqrt_f32  v158, v79", 0x7f3c674fU, 0, false, true, "" },
1456    { "    v_sqrt_f32  v55, v27 vop3", 0xd5b30037U, 0x0000011bU, true, true, "" },
1457    { "    v_sqrt_f64  v[158:159], v[79:80]", 0x7f3c694fU, 0, false, true, "" },
1458    { "    v_sqrt_f64  v[55:56], v[27:28] vop3", 0xd5b40037U, 0x0000011bU, true, true, "" },
1459    { "    v_sin_f32  v158, v79", 0x7f3c6b4fU, 0, false, true, "" },
1460    { "    v_sin_f32  v55, v27 vop3", 0xd5b50037U, 0x0000011bU, true, true, "" },
1461    { "    v_cos_f32  v158, v79", 0x7f3c6d4fU, 0, false, true, "" },
1462    { "    v_cos_f32  v55, v27 vop3", 0xd5b60037U, 0x0000011bU, true, true, "" },
1463    { "    v_not_b32  v158, v79", 0x7f3c6f4fU, 0, false, true, "" },
1464    { "    v_not_b32  v55, v27 vop3", 0xd5b70037U, 0x0000011bU, true, true, "" },
1465    { "    v_bfrev_b32  v158, v79", 0x7f3c714fU, 0, false, true, "" },
1466    { "    v_bfrev_b32  v55, v27 vop3", 0xd5b80037U, 0x0000011bU, true, true, "" },
1467    { "    v_ffbh_u32  v158, v79", 0x7f3c734fU, 0, false, true, "" },
1468    { "    v_ffbh_u32  v55, v27 vop3", 0xd5b90037U, 0x0000011bU, true, true, "" },
1469    { "    v_ffbl_b32  v158, v79", 0x7f3c754fU, 0, false, true, "" },
1470    { "    v_ffbl_b32  v55, v27 vop3", 0xd5ba0037U, 0x0000011bU, true, true, "" },
1471    { "    v_ffbh_i32  v158, v79", 0x7f3c774fU, 0, false, true, "" },
1472    { "    v_ffbh_i32  v55, v27 vop3", 0xd5bb0037U, 0x0000011bU, true, true, "" },
1473    { "    v_frexp_exp_i32_f64 v158, v[79:80]", 0x7f3c794fU, 0, false, true, "" },
1474    { "    v_frexp_exp_i32_f64 v55, v[27:28] vop3",
1475        0xd5bc0037U, 0x0000011bU, true, true, "" },
1476    { "    v_frexp_mant_f64 v[158:159], v[79:80]", 0x7f3c7b4fU, 0, false, true, "" },
1477    { "    v_frexp_mant_f64 v[55:56], v[27:28] vop3",
1478        0xd5bd0037U, 0x0000011bU, true, true, "" },
1479    { "    v_fract_f64  v[158:159], v[79:80]", 0x7f3c7d4fU, 0, false, true, "" },
1480    { "    v_fract_f64  v[55:56], v[27:28] vop3",
1481        0xd5be0037U, 0x0000011bU, true, true, "" },
1482    { "    v_frexp_exp_i32_f32  v158, v79", 0x7f3c7f4fU, 0, false, true, "" },
1483    { "    v_frexp_exp_i32_f32  v55, v27 vop3", 0xd5bf0037U, 0x0000011bU, true, true, "" },
1484    { "    v_frexp_mant_f32  v158, v79", 0x7f3c814fU, 0, false, true, "" },
1485    { "    v_frexp_mant_f32  v55, v27 vop3", 0xd5c00037U, 0x0000011bU, true, true, "" },
1486    { "    v_clrexcp", 0x7e008200U, 0, false, true, "" },
1487    { "    v_clrexcp vop3", 0xd5c10000U, 0, true, true, "" },
1488    { "    v_movreld_b32  v158, v79", 0x7f3c854fU, 0, false, true, "" },
1489    { "    v_movreld_b32  v55, v27 vop3", 0xd5c20037U, 0x0000011bU, true, true, "" },
1490    { "    v_movrels_b32  v158, v79", 0x7f3c874fU, 0, false, true, "" },
1491    { "    v_movrels_b32  v55, v27 vop3", 0xd5c30037U, 0x0000011bU, true, true, "" },
1492    { "    v_movrelsd_b32  v158, v79", 0x7f3c894fU, 0, false, true, "" },
1493    { "    v_movrelsd_b32  v55, v27 vop3", 0xd5c40037U, 0x0000011bU, true, true, "" },
1494    { "    v_movrelsd_2_b32  v158, v79", 0x7f3c914fU, 0, false, true, "" },
1495    { "    v_movrelsd_2_b32  v55, v27 vop3", 0xd5c80037U, 0x0000011bU, true, true, "" },
1496    { "    v_cvt_f16_u16  v158, v79", 0x7f3ca14fU, 0, false, true, "" },
1497    { "    v_cvt_f16_u16  v55, v27 vop3", 0xd5d00037U, 0x0000011bU, true, true, "" },
1498    { "    v_cvt_f16_i16  v158, v79", 0x7f3ca34fU, 0, false, true, "" },
1499    { "    v_cvt_f16_i16  v55, v27 vop3", 0xd5d10037U, 0x0000011bU, true, true, "" },
1500    { "    v_cvt_u16_f16  v158, v79", 0x7f3ca54fU, 0, false, true, "" },
1501    { "    v_cvt_u16_f16  v55, v27 vop3", 0xd5d20037U, 0x0000011bU, true, true, "" },
1502    { "    v_cvt_i16_f16  v158, v79", 0x7f3ca74fU, 0, false, true, "" },
1503    { "    v_cvt_i16_f16  v55, v27 vop3", 0xd5d30037U, 0x0000011bU, true, true, "" },
1504    { "    v_rcp_f16  v158, v79", 0x7f3ca94fU, 0, false, true, "" },
1505    { "    v_rcp_f16  v55, v27 vop3", 0xd5d40037U, 0x0000011bU, true, true, "" },
1506    { "    v_sqrt_f16  v158, v79", 0x7f3cab4fU, 0, false, true, "" },
1507    { "    v_sqrt_f16  v55, v27 vop3", 0xd5d50037U, 0x0000011bU, true, true, "" },
1508    { "    v_rsq_f16  v158, v79", 0x7f3cad4fU, 0, false, true, "" },
1509    { "    v_rsq_f16  v55, v27 vop3", 0xd5d60037U, 0x0000011bU, true, true, "" },
1510    { "    v_log_f16  v158, v79", 0x7f3caf4fU, 0, false, true, "" },
1511    { "    v_log_f16  v55, v27 vop3", 0xd5d70037U, 0x0000011bU, true, true, "" },
1512    { "    v_exp_f16  v158, v79", 0x7f3cb14fU, 0, false, true, "" },
1513    { "    v_exp_f16  v55, v27 vop3", 0xd5d80037U, 0x0000011bU, true, true, "" },
1514    { "    v_frexp_mant_f16  v158, v79", 0x7f3cb34fU, 0, false, true, "" },
1515    { "    v_frexp_mant_f16  v55, v27 vop3", 0xd5d90037U, 0x0000011bU, true, true, "" },
1516    { "    v_frexp_exp_i16_f16  v158, v79", 0x7f3cb54fU, 0, false, true, "" },
1517    { "    v_frexp_exp_i16_f16  v55, v27 vop3", 0xd5da0037U, 0x0000011bU, true, true, "" },
1518    { "    v_floor_f16  v158, v79", 0x7f3cb74fU, 0, false, true, "" },
1519    { "    v_floor_f16  v55, v27 vop3", 0xd5db0037U, 0x0000011bU, true, true, "" },
1520    { "    v_ceil_f16  v158, v79", 0x7f3cb94fU, 0, false, true, "" },
1521    { "    v_ceil_f16  v55, v27 vop3", 0xd5dc0037U, 0x0000011bU, true, true, "" },
1522    { "    v_trunc_f16  v158, v79", 0x7f3cbb4fU, 0, false, true, "" },
1523    { "    v_trunc_f16  v55, v27 vop3", 0xd5dd0037U, 0x0000011bU, true, true, "" },
1524    { "    v_rndne_f16  v158, v79", 0x7f3cbd4fU, 0, false, true, "" },
1525    { "    v_rndne_f16  v55, v27 vop3", 0xd5de0037U, 0x0000011bU, true, true, "" },
1526    { "    v_fract_f16  v158, v79", 0x7f3cbf4fU, 0, false, true, "" },
1527    { "    v_fract_f16  v55, v27 vop3", 0xd5df0037U, 0x0000011bU, true, true, "" },
1528    { "    v_sin_f16  v158, v79", 0x7f3cc14fU, 0, false, true, "" },
1529    { "    v_sin_f16  v55, v27 vop3", 0xd5e00037U, 0x0000011bU, true, true, "" },
1530    { "    v_cos_f16  v158, v79", 0x7f3cc34fU, 0, false, true, "" },
1531    { "    v_cos_f16  v55, v27 vop3", 0xd5e10037U, 0x0000011bU, true, true, "" },
1532    { "    v_sat_pk_u8_i16  v158, v79", 0x7f3cc54fU, 0, false, true, "" },
1533    { "    v_sat_pk_u8_i16  v55, v27 vop3", 0xd5e20037U, 0x0000011bU, true, true, "" },
1534    { "    v_cvt_norm_i16_f16  v158, v79", 0x7f3cc74fU, 0, false, true, "" },
1535    { "    v_cvt_norm_i16_f16  v55, v27 vop3", 0xd5e30037U, 0x0000011bU, true, true, "" },
1536    { "    v_cvt_norm_u16_f16  v158, v79", 0x7f3cc94fU, 0, false, true, "" },
1537    { "    v_cvt_norm_u16_f16  v55, v27 vop3", 0xd5e40037U, 0x0000011bU, true, true, "" },
1538    { "    v_swap_b32  v158, v79", 0x7f3ccb4fU, 0, false, true, "" },
1539    { "    v_swap_b32  v55, v27 vop3", 0xd5e50037U, 0x0000011bU, true, true, "" },
1540    { "    v_swaprel_b32  v158, v79", 0x7f3cd14fU, 0, false, true, "" },
1541    { "    v_swaprel_b32  v55, v27 vop3", 0xd5e80037U, 0x0000011bU, true, true, "" },
1542    /* VOP1 SDWA */
1543    { "    v_sin_f32  v158, -abs(v79) dst_sel:word1",
1544            0x7f3c6af9U, 0x36054fU, true, true, "" },
1545    { "    v_sin_f32  v158, -abs(v79) dst_sel:word1 src0_sel:word0",
1546            0x7f3c6af9U, 0x34054fU, true, true, "" },
1547    { "    v_sin_f32  v158, -abs(s79) dst_sel:word1",
1548            0x7f3c6af9U, 0xb6054fU, true, true, "" },
1549    /* VOP DPP */
1550    { "    v_sin_f32  v158, v79 row_shr:14", 0x7f3c6afaU, 0xff011e4fU, true, true, "" },
1551    /* VOP DPP8 */
1552    { "    v_sin_f32  v158, v79 dpp8:[1,7,2,5,6,3,6,4]",
1553        0x7f3c6ae9U, 0x99eab94fU, true, true, "" },
1554        { "    v_sin_f32  v158, v79 dpp8:[1,7,2,5,6,3,6,4] fi",
1555        0x7f3c6aeaU, 0x99eab94fU, true, true, "" },
1556    /* VOP1 errors */
1557    { "    v_mov_b32  v15, 133 vop3", 0, 0, false, false,
1558        "test.s:1:5: Error: Literal in VOP3 encoding is illegal\n" },
1559    { "    v_rcp_f64  v[158:], v[79:80]", 0, 0, false, false,
1560        "test.s:1:22: Error: Expected expression\n"
1561        "test.s:1:22: Error: Expected ',' before argument\n" },
1562    { "    v_rcp_f64  v[158:159, v[79:80]", 0, 0, false, false,
1563        "test.s:1:16: Error: Unterminated vector register range\n" },
1564    { "    v_rcp_f64  v158, s79", 0, 0, false, false,
1565        "test.s:1:16: Error: Required 2 vector registers\n"
1566        "test.s:1:25: Error: Required 2 scalar registers\n" },
1567    { "    v_mov_b32  v[48:59], s[80:81]", 0, 0, false, false,
1568        "test.s:1:16: Error: Required 1 vector register\n"
1569        "test.s:1:26: Error: Required 1 scalar register\n" },
1570    /* VOPC encoding */
1571    { "    v_cmp_f_f32  vcc, v79, v201", 0x7c01934fU, 0, false, true, "" },
1572    { "    v_cmp_f_f32  vcc, v79, v93", 0x7c00bb4fU, 0, false, true, "" },
1573    { "    v_cmp_f_f32  vcc, lds, v201", 0x7c0192feU, 0, false, true, "" },
1574    { "    v_cmp_f_f32  vcc, lds_direct, v201", 0x7c0192feU, 0, false, true, "" },
1575    { "    v_cmp_f_f32  vcc, s79, v201", 0x7c01924fU, 0, false, true, "" },
1576    { "    v_cmp_f_f32  vcc, -9, v201", 0x7c0192c9U, 0, false, true, "" },
1577    { "    v_cmp_f_f32  vcc, 44517, v201", 0x7c0192ffU, 44517, true, true, "" },
1578    { "txy=54244;v_cmp_f_f32  vcc, txy, v201", 0x7c0192ffU, 54244, true, true, "" },
1579    { "v_cmp_f_f32  vcc, txy, v201;txy=54244", 0x7c0192ffU, 54244, true, true, "" },
1580    { "    v_cmp_f_f32  vcc, v79, v201 vop3", 0xd400006aU, 0x3934fU, true, true, "" },
1581    { "    v_cmp_f_f32  vcc, v79, v201 clamp", 0xd400806aU, 0x3934fU, true, true, "" },
1582    { "    v_cmp_f_f32  vcc, v79, abs(v201)", 0xd400026aU, 0x3934fU, true, true, "" },
1583    { "    v_cmp_f_f32  vcc, -v79, v201", 0xd400006aU, 0x2003934fU, true, true, "" },
1584    { "    v_cmp_f_f32  vcc, v79, -v201", 0xd400006aU, 0x4003934fU, true, true, "" },
1585    { "    v_cmp_f_f32  vcc, v79, v201 mul:2", 0xd400006aU, 0x0803934fU, true, true, "" },
1586    { "    v_cmp_f_f32  vcc, v79, s101", 0xd400006aU, 0x0cb4fU, true, true, "" },
1587    { "    v_cmp_f_f32  vcc, v79, 24", 0xd400006aU, 0x1314fU, true, true, "" },
1588    { "    v_cmp_f_f32  s[28:29], v79, v201", 0xd400001cU, 0x3934fU, true, true, "" },
1589    { "    v_cmp_f_f32  s[29:30], v79, v201", 0xd400001dU, 0x3934fU, true, true, "" },
1590    { "    v_cmp_f_f32  vcc, 10.5332, v201", 0x7c0192ffU, 0x412887fd, true, true, "" },
1591    { "    v_cmp_f_f32  vcc, s8, s8", 0xd400006aU, 0x1008U, true, true, "" },
1592    { "    v_cmp_f_f32  vcc, s8, s9", 0xd400006aU, 0x1208U, true, true, "" },
1593    /* VOPC SDWAB */
1594    { "v_cmp_class_f32 vcc, v0, v107 src0_sel:byte0 src1_sel:byte0",
1595        0x7d10d6f9U, 0x0000, true, true, "" },
1596    { "v_cmp_class_f32 vcc, v61, v107 src0_sel:byte0 src1_sel:byte0",
1597        0x7d10d6f9U, 0x3dU, true, true, "" },
1598    { "v_cmp_class_f32 vcc, v61, vcc_hi src0_sel:byte0 src1_sel:byte0",
1599        0x7d10d6f9U, 0x8000003dU, true, true, "" },
1600    { "v_cmp_class_f32 vcc, s61, v107 src0_sel:byte0 src1_sel:byte0\n",
1601        0x7d10d6f9U, 0x0080003dU, true, true, "" },
1602    { "v_cmp_class_f32 vcc, sext(-abs(v65)), v107",
1603        0x7d10d6f9U, 0x063e0041U, true, true, "" },
1604    { "v_cmp_class_f32 vcc, sext(-abs(v65)), vcc_hi",
1605        0x7d10d6f9U, 0x863e0041U, true, true, "" },
1606    { "v_cmp_class_f32 vcc, sext(-abs(s65)), v107",
1607        0x7d10d6f9U, 0x06be0041U, true, true, "" },
1608    { "v_cmp_class_f32 s[38:39], v0, v107 src0_sel:byte0 src1_sel:byte0",
1609        0x7d10d6f9U, 0xa600, true, true, "" },
1610    // ERRORS
1611    { "v_cmp_class_f32 vcc, v0, v107 mul:4 dst_sel:byte0 src0_sel:byte0 src1_sel:byte0",
1612        0, 0, false, false, "test.s:1:37: Error: Unknown VOP modifier\n"
1613        "test.s:1:44: Error: Some garbages at VOP modifier place\n" },
1614    { "v_cmp_class_f32 vcc, v0, v107 mul:4 dst_un:preserve src0_sel:byte0 src1_sel:byte0",
1615        0, 0, false, false, "test.s:1:37: Error: Unknown VOP modifier\n"
1616        "test.s:1:43: Error: Some garbages at VOP modifier place\n" },
1617    { "v_cmp_class_f32 vcc, sext(-abs(v65)), v107 mul:2",
1618        0, 0, false, false,
1619        "test.s:1:1: Error: Modifiers CLAMP and OMOD is illegal in SDWAB\n" },
1620    { "v_cmp_class_f32 vcc, sext(-abs(v65)), v107 clamp",
1621        0, 0, false, false,
1622        "test.s:1:1: Error: Modifiers CLAMP and OMOD is illegal in SDWAB\n" },
1623    /* VOPC DPP */
1624    { "v_cmp_class_f32 vcc, v61, v107 row_shr:14",
1625        0x7d10d6faU, 0xff011e3dU, true, true, "" },
1626    /* VOPC DPP8 */
1627    { "v_cmp_class_f32 vcc, v61, v107 dpp8:[1,7,2,5,6,3,6,4]",
1628        0x7d10d6e9U, 0x99eab93dU, true, true, "" },
1629    { "v_cmp_class_f32 vcc, v61, v107 dpp8:[1,7,2,5,6,3,6,4] fi",
1630        0x7d10d6eaU, 0x99eab93dU, true, true, "" },
1631    /* VOPC errors */
1632    { "    v_cmp_f_f32  vcc_lo, v79, v201", 0, 0, false, false,
1633        "test.s:1:18: Error: Required 2 scalar registers\n" },
1634    { "    v_cmp_f_f32  vcc, 42321, s37", 0, 0, false, false,
1635        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
1636    { "    v_cmp_f_f32  vcc, 42321, m0", 0, 0, false, false,
1637        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
1638    { "    v_cmp_f_f32  vcc, s68, 42321", 0, 0, false, false,
1639        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
1640    { "    v_cmp_f_f32  vcc, m0, 42321", 0, 0, false, false,
1641        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
1642    { "    v_cmp_f_f32  vcc, 44517, v201 vop3", 0, 0, false, false,
1643        "test.s:1:5: Error: Literal in VOP3 encoding is illegal\n" },
1644    { "    v_cmp_f_f32  vcc, 44517, 63111", 0, 0, false, false,
1645        "test.s:1:30: Error: Only one literal can be used in instruction\n" },
1646    { "    v_cmp_f_f32  vcc, sss, dddd", 0, 0, false, false,
1647        "test.s:1:28: Error: Only one literal can be used in instruction\n" },
1648    /* VOPC instructions */
1649    { "    v_cmp_f_f32  vcc, v79, v201", 0x7c01934fU, 0, false, true, "" },
1650    { "    v_cmp_f_f32  s[42:43], v50, v107", 0xd400002aU, 0x0002d732U, true, true, "" },
1651    { "    v_cmp_lt_f32  vcc, v79, v201", 0x7c03934fU, 0, false, true, "" },
1652    { "    v_cmp_lt_f32  s[42:43], v50, v107", 0xd401002aU, 0x0002d732U, true, true, "" },
1653    { "    v_cmp_eq_f32  vcc, v79, v201", 0x7c05934fU, 0, false, true, "" },
1654    { "    v_cmp_eq_f32  s[42:43], v50, v107", 0xd402002aU, 0x0002d732U, true, true, "" },
1655    { "    v_cmp_le_f32  vcc, v79, v201", 0x7c07934fU, 0, false, true, "" },
1656    { "    v_cmp_le_f32  s[42:43], v50, v107", 0xd403002aU, 0x0002d732U, true, true, "" },
1657    { "    v_cmp_gt_f32  vcc, v79, v201", 0x7c09934fU, 0, false, true, "" },
1658    { "    v_cmp_gt_f32  s[42:43], v50, v107", 0xd404002aU, 0x0002d732U, true, true, "" },
1659    { "    v_cmp_lg_f32  vcc, v79, v201", 0x7c0b934fU, 0, false, true, "" },
1660    { "    v_cmp_lg_f32  s[42:43], v50, v107", 0xd405002aU, 0x0002d732U, true, true, "" },
1661    { "    v_cmp_ge_f32  vcc, v79, v201", 0x7c0d934fU, 0, false, true, "" },
1662    { "    v_cmp_ge_f32  s[42:43], v50, v107", 0xd406002aU, 0x0002d732U, true, true, "" },
1663    { "    v_cmp_o_f32  vcc, v79, v201", 0x7c0f934fU, 0, false, true, "" },
1664    { "    v_cmp_o_f32  s[42:43], v50, v107", 0xd407002aU, 0x0002d732U, true, true, "" },
1665    { "    v_cmp_u_f32  vcc, v79, v201", 0x7c11934fU, 0, false, true, "" },
1666    { "    v_cmp_u_f32  s[42:43], v50, v107", 0xd408002aU, 0x0002d732U, true, true, "" },
1667    { "    v_cmp_nge_f32  vcc, v79, v201", 0x7c13934fU, 0, false, true, "" },
1668    { "    v_cmp_nge_f32  s[42:43], v50, v107", 0xd409002aU, 0x0002d732U, true, true, "" },
1669    { "    v_cmp_nlg_f32  vcc, v79, v201", 0x7c15934fU, 0, false, true, "" },
1670    { "    v_cmp_nlg_f32  s[42:43], v50, v107", 0xd40a002aU, 0x0002d732U, true, true, "" },
1671    { "    v_cmp_ngt_f32  vcc, v79, v201", 0x7c17934fU, 0, false, true, "" },
1672    { "    v_cmp_ngt_f32  s[42:43], v50, v107", 0xd40b002aU, 0x0002d732U, true, true, "" },
1673    { "    v_cmp_nle_f32  vcc, v79, v201", 0x7c19934fU, 0, false, true, "" },
1674    { "    v_cmp_nle_f32  s[42:43], v50, v107", 0xd40c002aU, 0x0002d732U, true, true, "" },
1675    { "    v_cmp_neq_f32  vcc, v79, v201", 0x7c1b934fU, 0, false, true, "" },
1676    { "    v_cmp_neq_f32  s[42:43], v50, v107", 0xd40d002aU, 0x0002d732U, true, true, "" },
1677    { "    v_cmp_nlt_f32  vcc, v79, v201", 0x7c1d934fU, 0, false, true, "" },
1678    { "    v_cmp_nlt_f32  s[42:43], v50, v107", 0xd40e002aU, 0x0002d732U, true, true, "" },
1679    { "    v_cmp_tru_f32  vcc, v79, v201", 0x7c1f934fU, 0, false, true, "" },
1680    { "    v_cmp_tru_f32  s[42:43], v50, v107", 0xd40f002aU, 0x0002d732U, true, true, "" },
1681    { "    v_cmp_t_f32  vcc, v79, v201", 0x7c1f934fU, 0, false, true, "" },
1682    { "    v_cmp_t_f32  s[42:43], v50, v107", 0xd40f002aU, 0x0002d732U, true, true, "" },
1683   
1684    { "    v_cmpx_f_f32  v79, v201", 0x7c21934fU, 0, false, true, "" },
1685    { "    v_cmpx_f_f32  v50, v107 vop3", 0xd4100000U, 0x0002d732U, true, true, "" },
1686    { "    v_cmpx_lt_f32  v79, v201", 0x7c23934fU, 0, false, true, "" },
1687    { "    v_cmpx_lt_f32  v50, v107 vop3", 0xd4110000U, 0x0002d732U, true, true, "" },
1688    { "    v_cmpx_eq_f32  v79, v201", 0x7c25934fU, 0, false, true, "" },
1689    { "    v_cmpx_eq_f32  v50, v107 vop3", 0xd4120000U, 0x0002d732U, true, true, "" },
1690    { "    v_cmpx_le_f32  v79, v201", 0x7c27934fU, 0, false, true, "" },
1691    { "    v_cmpx_le_f32  v50, v107 vop3", 0xd4130000U, 0x0002d732U, true, true, "" },
1692    { "    v_cmpx_gt_f32  v79, v201", 0x7c29934fU, 0, false, true, "" },
1693    { "    v_cmpx_gt_f32  v50, v107 vop3", 0xd4140000U, 0x0002d732U, true, true, "" },
1694    { "    v_cmpx_lg_f32  v79, v201", 0x7c2b934fU, 0, false, true, "" },
1695    { "    v_cmpx_lg_f32  v50, v107 vop3", 0xd4150000U, 0x0002d732U, true, true, "" },
1696    { "    v_cmpx_ge_f32  v79, v201", 0x7c2d934fU, 0, false, true, "" },
1697    { "    v_cmpx_ge_f32  v50, v107 vop3", 0xd4160000U, 0x0002d732U, true, true, "" },
1698    { "    v_cmpx_o_f32  v79, v201", 0x7c2f934fU, 0, false, true, "" },
1699    { "    v_cmpx_o_f32  v50, v107 vop3", 0xd4170000U, 0x0002d732U, true, true, "" },
1700    { "    v_cmpx_u_f32  v79, v201", 0x7c31934fU, 0, false, true, "" },
1701    { "    v_cmpx_u_f32  v50, v107 vop3", 0xd4180000U, 0x0002d732U, true, true, "" },
1702    { "    v_cmpx_nge_f32  v79, v201", 0x7c33934fU, 0, false, true, "" },
1703    { "    v_cmpx_nge_f32  v50, v107 vop3", 0xd4190000U, 0x0002d732U, true, true, "" },
1704    { "    v_cmpx_nlg_f32  v79, v201", 0x7c35934fU, 0, false, true, "" },
1705    { "    v_cmpx_nlg_f32  v50, v107 vop3", 0xd41a0000U, 0x0002d732U, true, true, "" },
1706    { "    v_cmpx_ngt_f32  v79, v201", 0x7c37934fU, 0, false, true, "" },
1707    { "    v_cmpx_ngt_f32  v50, v107 vop3", 0xd41b0000U, 0x0002d732U, true, true, "" },
1708    { "    v_cmpx_nle_f32  v79, v201", 0x7c39934fU, 0, false, true, "" },
1709    { "    v_cmpx_nle_f32  v50, v107 vop3", 0xd41c0000U, 0x0002d732U, true, true, "" },
1710    { "    v_cmpx_neq_f32  v79, v201", 0x7c3b934fU, 0, false, true, "" },
1711    { "    v_cmpx_neq_f32  v50, v107 vop3", 0xd41d0000U, 0x0002d732U, true, true, "" },
1712    { "    v_cmpx_nlt_f32  v79, v201", 0x7c3d934fU, 0, false, true, "" },
1713    { "    v_cmpx_nlt_f32  v50, v107 vop3", 0xd41e0000U, 0x0002d732U, true, true, "" },
1714    { "    v_cmpx_tru_f32  v79, v201", 0x7c3f934fU, 0, false, true, "" },
1715    { "    v_cmpx_tru_f32  v50, v107 vop3", 0xd41f0000U, 0x0002d732U, true, true, "" },
1716    { "    v_cmpx_t_f32  v79, v201", 0x7c3f934fU, 0, false, true, "" },
1717    { "    v_cmpx_t_f32  v50, v107 vop3", 0xd41f0000U, 0x0002d732U, true, true, "" },
1718   
1719    { "    v_cmp_f_f64  vcc, v[79:80], v[201:202]", 0x7c41934fU, 0, false, true, "" },
1720    { "    v_cmp_f_f64  s[42:43], v[50:51], v[107:108]",
1721        0xd420002aU, 0x0002d732U, true, true, "" },
1722    { "    v_cmp_lt_f64  vcc, v[79:80], v[201:202]", 0x7c43934fU, 0, false, true, "" },
1723    { "    v_cmp_lt_f64  s[42:43], v[50:51], v[107:108]",
1724        0xd421002aU, 0x0002d732U, true, true, "" },
1725    { "    v_cmp_eq_f64  vcc, v[79:80], v[201:202]", 0x7c45934fU, 0, false, true, "" },
1726    { "    v_cmp_eq_f64  s[42:43], v[50:51], v[107:108]",
1727        0xd422002aU, 0x0002d732U, true, true, "" },
1728    { "    v_cmp_le_f64  vcc, v[79:80], v[201:202]", 0x7c47934fU, 0, false, true, "" },
1729    { "    v_cmp_le_f64  s[42:43], v[50:51], v[107:108]",
1730        0xd423002aU, 0x0002d732U, true, true, "" },
1731    { "    v_cmp_gt_f64  vcc, v[79:80], v[201:202]", 0x7c49934fU, 0, false, true, "" },
1732    { "    v_cmp_gt_f64  s[42:43], v[50:51], v[107:108]",
1733        0xd424002aU, 0x0002d732U, true, true, "" },
1734    { "    v_cmp_lg_f64  vcc, v[79:80], v[201:202]", 0x7c4b934fU, 0, false, true, "" },
1735    { "    v_cmp_lg_f64  s[42:43], v[50:51], v[107:108]",
1736        0xd425002aU, 0x0002d732U, true, true, "" },
1737    { "    v_cmp_ge_f64  vcc, v[79:80], v[201:202]", 0x7c4d934fU, 0, false, true, "" },
1738    { "    v_cmp_ge_f64  s[42:43], v[50:51], v[107:108]",
1739        0xd426002aU, 0x0002d732U, true, true, "" },
1740    { "    v_cmp_o_f64  vcc, v[79:80], v[201:202]", 0x7c4f934fU, 0, false, true, "" },
1741    { "    v_cmp_o_f64  s[42:43], v[50:51], v[107:108]",
1742        0xd427002aU, 0x0002d732U, true, true, "" },
1743    { "    v_cmp_u_f64  vcc, v[79:80], v[201:202]", 0x7c51934fU, 0, false, true, "" },
1744    { "    v_cmp_u_f64  s[42:43], v[50:51], v[107:108]",
1745        0xd428002aU, 0x0002d732U, true, true, "" },
1746    { "    v_cmp_nge_f64  vcc, v[79:80], v[201:202]", 0x7c53934fU, 0, false, true, "" },
1747    { "    v_cmp_nge_f64  s[42:43], v[50:51], v[107:108]",
1748        0xd429002aU, 0x0002d732U, true, true, "" },
1749    { "    v_cmp_nlg_f64  vcc, v[79:80], v[201:202]", 0x7c55934fU, 0, false, true, "" },
1750    { "    v_cmp_nlg_f64  s[42:43], v[50:51], v[107:108]",
1751        0xd42a002aU, 0x0002d732U, true, true, "" },
1752    { "    v_cmp_ngt_f64  vcc, v[79:80], v[201:202]", 0x7c57934fU, 0, false, true, "" },
1753    { "    v_cmp_ngt_f64  s[42:43], v[50:51], v[107:108]",
1754        0xd42b002aU, 0x0002d732U, true, true, "" },
1755    { "    v_cmp_nle_f64  vcc, v[79:80], v[201:202]", 0x7c59934fU, 0, false, true, "" },
1756    { "    v_cmp_nle_f64  s[42:43], v[50:51], v[107:108]",
1757        0xd42c002aU, 0x0002d732U, true, true, "" },
1758    { "    v_cmp_neq_f64  vcc, v[79:80], v[201:202]", 0x7c5b934fU, 0, false, true, "" },
1759    { "    v_cmp_neq_f64  s[42:43], v[50:51], v[107:108]",
1760        0xd42d002aU, 0x0002d732U, true, true, "" },
1761    { "    v_cmp_nlt_f64  vcc, v[79:80], v[201:202]", 0x7c5d934fU, 0, false, true, "" },
1762    { "    v_cmp_nlt_f64  s[42:43], v[50:51], v[107:108]",
1763        0xd42e002aU, 0x0002d732U, true, true, "" },
1764    { "    v_cmp_tru_f64  vcc, v[79:80], v[201:202]", 0x7c5f934fU, 0, false, true, "" },
1765    { "    v_cmp_tru_f64  s[42:43], v[50:51], v[107:108]",
1766        0xd42f002aU, 0x0002d732U, true, true, "" },
1767    { "    v_cmp_t_f64  vcc, v[79:80], v[201:202]", 0x7c5f934fU, 0, false, true, "" },
1768    { "    v_cmp_t_f64  s[42:43], v[50:51], v[107:108]",
1769        0xd42f002aU, 0x0002d732U, true, true, "" },
1770   
1771    { "    v_cmpx_f_f64  v[79:80], v[201:202]", 0x7c61934fU, 0, false, true, "" },
1772    { "    v_cmpx_f_f64  v[50:51], v[107:108] vop3",
1773        0xd4300000U, 0x0002d732U, true, true, "" },
1774    { "    v_cmpx_lt_f64  v[79:80], v[201:202]", 0x7c63934fU, 0, false, true, "" },
1775    { "    v_cmpx_lt_f64  v[50:51], v[107:108] vop3",
1776        0xd4310000U, 0x0002d732U, true, true, "" },
1777    { "    v_cmpx_eq_f64  v[79:80], v[201:202]", 0x7c65934fU, 0, false, true, "" },
1778    { "    v_cmpx_eq_f64  v[50:51], v[107:108] vop3",
1779        0xd4320000U, 0x0002d732U, true, true, "" },
1780    { "    v_cmpx_le_f64  v[79:80], v[201:202]", 0x7c67934fU, 0, false, true, "" },
1781    { "    v_cmpx_le_f64  v[50:51], v[107:108] vop3",
1782        0xd4330000U, 0x0002d732U, true, true, "" },
1783    { "    v_cmpx_gt_f64  v[79:80], v[201:202]", 0x7c69934fU, 0, false, true, "" },
1784    { "    v_cmpx_gt_f64  v[50:51], v[107:108] vop3",
1785        0xd4340000U, 0x0002d732U, true, true, "" },
1786    { "    v_cmpx_lg_f64  v[79:80], v[201:202]", 0x7c6b934fU, 0, false, true, "" },
1787    { "    v_cmpx_lg_f64  v[50:51], v[107:108] vop3",
1788        0xd4350000U, 0x0002d732U, true, true, "" },
1789    { "    v_cmpx_ge_f64  v[79:80], v[201:202]", 0x7c6d934fU, 0, false, true, "" },
1790    { "    v_cmpx_ge_f64  v[50:51], v[107:108] vop3",
1791        0xd4360000U, 0x0002d732U, true, true, "" },
1792    { "    v_cmpx_o_f64  v[79:80], v[201:202]", 0x7c6f934fU, 0, false, true, "" },
1793    { "    v_cmpx_o_f64  v[50:51], v[107:108] vop3",
1794        0xd4370000U, 0x0002d732U, true, true, "" },
1795    { "    v_cmpx_u_f64  v[79:80], v[201:202]", 0x7c71934fU, 0, false, true, "" },
1796    { "    v_cmpx_u_f64  v[50:51], v[107:108] vop3",
1797        0xd4380000U, 0x0002d732U, true, true, "" },
1798    { "    v_cmpx_nge_f64  v[79:80], v[201:202]", 0x7c73934fU, 0, false, true, "" },
1799    { "    v_cmpx_nge_f64  v[50:51], v[107:108] vop3",
1800        0xd4390000U, 0x0002d732U, true, true, "" },
1801    { "    v_cmpx_nlg_f64  v[79:80], v[201:202]", 0x7c75934fU, 0, false, true, "" },
1802    { "    v_cmpx_nlg_f64  v[50:51], v[107:108] vop3",
1803        0xd43a0000U, 0x0002d732U, true, true, "" },
1804    { "    v_cmpx_ngt_f64  v[79:80], v[201:202]", 0x7c77934fU, 0, false, true, "" },
1805    { "    v_cmpx_ngt_f64  v[50:51], v[107:108] vop3",
1806        0xd43b0000U, 0x0002d732U, true, true, "" },
1807    { "    v_cmpx_nle_f64  v[79:80], v[201:202]", 0x7c79934fU, 0, false, true, "" },
1808    { "    v_cmpx_nle_f64  v[50:51], v[107:108] vop3",
1809        0xd43c0000U, 0x0002d732U, true, true, "" },
1810    { "    v_cmpx_neq_f64  v[79:80], v[201:202]", 0x7c7b934fU, 0, false, true, "" },
1811    { "    v_cmpx_neq_f64  v[50:51], v[107:108] vop3",
1812        0xd43d0000U, 0x0002d732U, true, true, "" },
1813    { "    v_cmpx_nlt_f64  v[79:80], v[201:202]", 0x7c7d934fU, 0, false, true, "" },
1814    { "    v_cmpx_nlt_f64  v[50:51], v[107:108] vop3",
1815        0xd43e0000U, 0x0002d732U, true, true, "" },
1816    { "    v_cmpx_tru_f64  v[79:80], v[201:202]", 0x7c7f934fU, 0, false, true, "" },
1817    { "    v_cmpx_tru_f64  v[50:51], v[107:108] vop3",
1818        0xd43f0000U, 0x0002d732U, true, true, "" },
1819    { "    v_cmpx_t_f64  v[79:80], v[201:202]", 0x7c7f934fU, 0, false, true, "" },
1820    { "    v_cmpx_t_f64  v[50:51], v[107:108] vop3",
1821        0xd43f0000U, 0x0002d732U, true, true, "" },
1822   
1823    { "    v_cmp_f_i32  vcc, v79, v201", 0x7d01934fU, 0, false, true, "" },
1824    { "    v_cmp_f_i32  s[42:43], v50, v107", 0xd480002aU, 0x0002d732U, true, true, "" },
1825    { "    v_cmp_lt_i32  vcc, v79, v201", 0x7d03934fU, 0, false, true, "" },
1826    { "    v_cmp_lt_i32  s[42:43], v50, v107", 0xd481002aU, 0x0002d732U, true, true, "" },
1827    { "    v_cmp_eq_i32  vcc, v79, v201", 0x7d05934fU, 0, false, true, "" },
1828    { "    v_cmp_eq_i32  s[42:43], v50, v107", 0xd482002aU, 0x0002d732U, true, true, "" },
1829    { "    v_cmp_le_i32  vcc, v79, v201", 0x7d07934fU, 0, false, true, "" },
1830    { "    v_cmp_le_i32  s[42:43], v50, v107", 0xd483002aU, 0x0002d732U, true, true, "" },
1831    { "    v_cmp_gt_i32  vcc, v79, v201", 0x7d09934fU, 0, false, true, "" },
1832    { "    v_cmp_gt_i32  s[42:43], v50, v107", 0xd484002aU, 0x0002d732U, true, true, "" },
1833    { "    v_cmp_lg_i32  vcc, v79, v201", 0x7d0b934fU, 0, false, true, "" },
1834    { "    v_cmp_lg_i32  s[42:43], v50, v107", 0xd485002aU, 0x0002d732U, true, true, "" },
1835    { "    v_cmp_ne_i32  vcc, v79, v201", 0x7d0b934fU, 0, false, true, "" },
1836    { "    v_cmp_ne_i32  s[42:43], v50, v107", 0xd485002aU, 0x0002d732U, true, true, "" },
1837    { "    v_cmp_ge_i32  vcc, v79, v201", 0x7d0d934fU, 0, false, true, "" },
1838    { "    v_cmp_ge_i32  s[42:43], v50, v107", 0xd486002aU, 0x0002d732U, true, true, "" },
1839    { "    v_cmp_tru_i32  vcc, v79, v201", 0x7d0f934fU, 0, false, true, "" },
1840    { "    v_cmp_tru_i32  s[42:43], v50, v107", 0xd487002aU, 0x0002d732U, true, true, "" },
1841    { "    v_cmp_t_i32  vcc, v79, v201", 0x7d0f934fU, 0, false, true, "" },
1842    { "    v_cmp_t_i32  s[42:43], v50, v107", 0xd487002aU, 0x0002d732U, true, true, "" },
1843    { "    v_cmp_class_f32  vcc, v79, v201", 0x7d11934fU, 0, false, true, "" },
1844    { "    v_cmp_class_f32  s[42:43], v50, v107",
1845        0xd488002aU, 0x0002d732U, true, true, "" },
1846    { "    v_cmp_lt_i16  vcc, v79, v201", 0x7d13934fU, 0, false, true, "" },
1847    { "    v_cmp_lt_i16  s[42:43], v50, v107", 0xd489002aU, 0x0002d732U, true, true, "" },
1848    { "    v_cmp_eq_i16  vcc, v79, v201", 0x7d15934fU, 0, false, true, "" },
1849    { "    v_cmp_eq_i16  s[42:43], v50, v107", 0xd48a002aU, 0x0002d732U, true, true, "" },
1850    { "    v_cmp_le_i16  vcc, v79, v201", 0x7d17934fU, 0, false, true, "" },
1851    { "    v_cmp_le_i16  s[42:43], v50, v107", 0xd48b002aU, 0x0002d732U, true, true, "" },
1852    { "    v_cmp_gt_i16  vcc, v79, v201", 0x7d19934fU, 0, false, true, "" },
1853    { "    v_cmp_gt_i16  s[42:43], v50, v107", 0xd48c002aU, 0x0002d732U, true, true, "" },
1854    { "    v_cmp_lg_i16  vcc, v79, v201", 0x7d1b934fU, 0, false, true, "" },
1855    { "    v_cmp_lg_i16  s[42:43], v50, v107", 0xd48d002aU, 0x0002d732U, true, true, "" },
1856    { "    v_cmp_ne_i16  vcc, v79, v201", 0x7d1b934fU, 0, false, true, "" },
1857    { "    v_cmp_ne_i16  s[42:43], v50, v107", 0xd48d002aU, 0x0002d732U, true, true, "" },
1858    { "    v_cmp_ge_i16  vcc, v79, v201", 0x7d1d934fU, 0, false, true, "" },
1859    { "    v_cmp_ge_i16  s[42:43], v50, v107", 0xd48e002aU, 0x0002d732U, true, true, "" },
1860    { "    v_cmp_class_f16  vcc, v79, v201", 0x7d1f934fU, 0, false, true, "" },
1861    { "    v_cmp_class_f16  s[42:43], v50, v107",
1862        0xd48f002aU, 0x0002d732U, true, true, "" },
1863   
1864    { "    v_cmpx_f_i32  v79, v201", 0x7d21934fU, 0, false, true, "" },
1865    { "    v_cmpx_f_i32  v50, v107 vop3", 0xd4900000U, 0x0002d732U, true, true, "" },
1866    { "    v_cmpx_lt_i32  v79, v201", 0x7d23934fU, 0, false, true, "" },
1867    { "    v_cmpx_lt_i32  v50, v107 vop3", 0xd4910000U, 0x0002d732U, true, true, "" },
1868    { "    v_cmpx_eq_i32  v79, v201", 0x7d25934fU, 0, false, true, "" },
1869    { "    v_cmpx_eq_i32  v50, v107 vop3", 0xd4920000U, 0x0002d732U, true, true, "" },
1870    { "    v_cmpx_le_i32  v79, v201", 0x7d27934fU, 0, false, true, "" },
1871    { "    v_cmpx_le_i32  v50, v107 vop3", 0xd4930000U, 0x0002d732U, true, true, "" },
1872    { "    v_cmpx_gt_i32  v79, v201", 0x7d29934fU, 0, false, true, "" },
1873    { "    v_cmpx_gt_i32  v50, v107 vop3", 0xd4940000U, 0x0002d732U, true, true, "" },
1874    { "    v_cmpx_lg_i32  v79, v201", 0x7d2b934fU, 0, false, true, "" },
1875    { "    v_cmpx_lg_i32  v50, v107 vop3", 0xd4950000U, 0x0002d732U, true, true, "" },
1876    { "    v_cmpx_ne_i32  v79, v201", 0x7d2b934fU, 0, false, true, "" },
1877    { "    v_cmpx_ne_i32  v50, v107 vop3", 0xd4950000U, 0x0002d732U, true, true, "" },
1878    { "    v_cmpx_ge_i32  v79, v201", 0x7d2d934fU, 0, false, true, "" },
1879    { "    v_cmpx_ge_i32  v50, v107 vop3", 0xd4960000U, 0x0002d732U, true, true, "" },
1880    { "    v_cmpx_tru_i32  v79, v201", 0x7d2f934fU, 0, false, true, "" },
1881    { "    v_cmpx_tru_i32  v50, v107 vop3", 0xd4970000U, 0x0002d732U, true, true, "" },
1882    { "    v_cmpx_t_i32  v79, v201", 0x7d2f934fU, 0, false, true, "" },
1883    { "    v_cmpx_t_i32  v50, v107 vop3", 0xd4970000U, 0x0002d732U, true, true, "" },
1884    { "    v_cmpx_class_f32  v79, v201", 0x7d31934fU, 0, false, true, "" },
1885    { "    v_cmpx_class_f32  v50, v107 vop3", 0xd4980000U, 0x0002d732U, true, true, "" },
1886    { "    v_cmpx_lt_i16  v79, v201", 0x7d33934fU, 0, false, true, "" },
1887    { "    v_cmpx_lt_i16  v50, v107 vop3", 0xd4990000U, 0x0002d732U, true, true, "" },
1888    { "    v_cmpx_eq_i16  v79, v201", 0x7d35934fU, 0, false, true, "" },
1889    { "    v_cmpx_eq_i16  v50, v107 vop3", 0xd49a0000U, 0x0002d732U, true, true, "" },
1890    { "    v_cmpx_le_i16  v79, v201", 0x7d37934fU, 0, false, true, "" },
1891    { "    v_cmpx_le_i16  v50, v107 vop3", 0xd49b0000U, 0x0002d732U, true, true, "" },
1892    { "    v_cmpx_gt_i16  v79, v201", 0x7d39934fU, 0, false, true, "" },
1893    { "    v_cmpx_gt_i16  v50, v107 vop3", 0xd49c0000U, 0x0002d732U, true, true, "" },
1894    { "    v_cmpx_lg_i16  v79, v201", 0x7d3b934fU, 0, false, true, "" },
1895    { "    v_cmpx_lg_i16  v50, v107 vop3", 0xd49d0000U, 0x0002d732U, true, true, "" },
1896    { "    v_cmpx_ne_i16  v79, v201", 0x7d3b934fU, 0, false, true, "" },
1897    { "    v_cmpx_ne_i16  v50, v107 vop3", 0xd49d0000U, 0x0002d732U, true, true, "" },
1898    { "    v_cmpx_ge_i16  v79, v201", 0x7d3d934fU, 0, false, true, "" },
1899    { "    v_cmpx_ge_i16  v50, v107 vop3", 0xd49e0000U, 0x0002d732U, true, true, "" },
1900    { "    v_cmpx_class_f16  v79, v201", 0x7d3f934fU, 0, false, true, "" },
1901    { "    v_cmpx_class_f16  v50, v107 vop3", 0xd49f0000U, 0x0002d732U, true, true, "" },
1902   
1903    { "    v_cmp_f_i64  vcc, v[79:80], v[201:202]", 0x7d41934fU, 0, false, true, "" },
1904    { "    v_cmp_f_i64  s[42:43], v[50:51], v[107:108]",
1905        0xd4a0002aU, 0x0002d732U, true, true, "" },
1906    { "    v_cmp_lt_i64  vcc, v[79:80], v[201:202]", 0x7d43934fU, 0, false, true, "" },
1907    { "    v_cmp_lt_i64  s[42:43], v[50:51], v[107:108]",
1908        0xd4a1002aU, 0x0002d732U, true, true, "" },
1909    { "    v_cmp_eq_i64  vcc, v[79:80], v[201:202]", 0x7d45934fU, 0, false, true, "" },
1910    { "    v_cmp_eq_i64  s[42:43], v[50:51], v[107:108]",
1911        0xd4a2002aU, 0x0002d732U, true, true, "" },
1912    { "    v_cmp_le_i64  vcc, v[79:80], v[201:202]", 0x7d47934fU, 0, false, true, "" },
1913    { "    v_cmp_le_i64  s[42:43], v[50:51], v[107:108]",
1914        0xd4a3002aU, 0x0002d732U, true, true, "" },
1915    { "    v_cmp_gt_i64  vcc, v[79:80], v[201:202]", 0x7d49934fU, 0, false, true, "" },
1916    { "    v_cmp_gt_i64  s[42:43], v[50:51], v[107:108]",
1917        0xd4a4002aU, 0x0002d732U, true, true, "" },
1918    { "    v_cmp_lg_i64  vcc, v[79:80], v[201:202]", 0x7d4b934fU, 0, false, true, "" },
1919    { "    v_cmp_lg_i64  s[42:43], v[50:51], v[107:108]",
1920        0xd4a5002aU, 0x0002d732U, true, true, "" },
1921    { "    v_cmp_ne_i64  vcc, v[79:80], v[201:202]", 0x7d4b934fU, 0, false, true, "" },
1922    { "    v_cmp_ne_i64  s[42:43], v[50:51], v[107:108]",
1923        0xd4a5002aU, 0x0002d732U, true, true, "" },
1924    { "    v_cmp_ge_i64  vcc, v[79:80], v[201:202]", 0x7d4d934fU, 0, false, true, "" },
1925    { "    v_cmp_ge_i64  s[42:43], v[50:51], v[107:108]",
1926        0xd4a6002aU, 0x0002d732U, true, true, "" },
1927    { "    v_cmp_tru_i64  vcc, v[79:80], v[201:202]", 0x7d4f934fU, 0, false, true, "" },
1928    { "    v_cmp_tru_i64  s[42:43], v[50:51], v[107:108]",
1929        0xd4a7002aU, 0x0002d732U, true, true, "" },
1930    { "    v_cmp_t_i64  vcc, v[79:80], v[201:202]", 0x7d4f934fU, 0, false, true, "" },
1931    { "    v_cmp_t_i64  s[42:43], v[50:51], v[107:108]",
1932        0xd4a7002aU, 0x0002d732U, true, true, "" },
1933    { "    v_cmp_class_f64  vcc, v[79:80], v[201:202]", 0x7d51934fU, 0, false, true, "" },
1934    { "    v_cmp_class_f64  s[42:43], v[50:51], v[107:108]",
1935        0xd4a8002aU, 0x0002d732U, true, true, "" },
1936    { "    v_cmp_lt_u16  vcc, v79, v201", 0x7d53934fU, 0, false, true, "" },
1937    { "    v_cmp_lt_u16  s[42:43], v50, v107", 0xd4a9002aU, 0x0002d732U, true, true, "" },
1938    { "    v_cmp_eq_u16  vcc, v79, v201", 0x7d55934fU, 0, false, true, "" },
1939    { "    v_cmp_eq_u16  s[42:43], v50, v107", 0xd4aa002aU, 0x0002d732U, true, true, "" },
1940    { "    v_cmp_le_u16  vcc, v79, v201", 0x7d57934fU, 0, false, true, "" },
1941    { "    v_cmp_le_u16  s[42:43], v50, v107", 0xd4ab002aU, 0x0002d732U, true, true, "" },
1942    { "    v_cmp_gt_u16  vcc, v79, v201", 0x7d59934fU, 0, false, true, "" },
1943    { "    v_cmp_gt_u16  s[42:43], v50, v107", 0xd4ac002aU, 0x0002d732U, true, true, "" },
1944    { "    v_cmp_lg_u16  vcc, v79, v201", 0x7d5b934fU, 0, false, true, "" },
1945    { "    v_cmp_lg_u16  s[42:43], v50, v107", 0xd4ad002aU, 0x0002d732U, true, true, "" },
1946    { "    v_cmp_ne_u16  vcc, v79, v201", 0x7d5b934fU, 0, false, true, "" },
1947    { "    v_cmp_ne_u16  s[42:43], v50, v107", 0xd4ad002aU, 0x0002d732U, true, true, "" },
1948    { "    v_cmp_ge_u16  vcc, v79, v201", 0x7d5d934fU, 0, false, true, "" },
1949    { "    v_cmp_ge_u16  s[42:43], v50, v107", 0xd4ae002aU, 0x0002d732U, true, true, "" },
1950   
1951    { "    v_cmpx_f_i64  v[79:80], v[201:202]", 0x7d61934fU, 0, false, true, "" },
1952    { "    v_cmpx_f_i64  v[50:51], v[107:108] vop3",
1953        0xd4b00000U, 0x0002d732U, true, true, "" },
1954    { "    v_cmpx_lt_i64  v[79:80], v[201:202]", 0x7d63934fU, 0, false, true, "" },
1955    { "    v_cmpx_lt_i64  v[50:51], v[107:108] vop3",
1956        0xd4b10000U, 0x0002d732U, true, true, "" },
1957    { "    v_cmpx_eq_i64  v[79:80], v[201:202]", 0x7d65934fU, 0, false, true, "" },
1958    { "    v_cmpx_eq_i64  v[50:51], v[107:108] vop3",
1959        0xd4b20000U, 0x0002d732U, true, true, "" },
1960    { "    v_cmpx_le_i64  v[79:80], v[201:202]", 0x7d67934fU, 0, false, true, "" },
1961    { "    v_cmpx_le_i64  v[50:51], v[107:108] vop3",
1962        0xd4b30000U, 0x0002d732U, true, true, "" },
1963    { "    v_cmpx_gt_i64  v[79:80], v[201:202]", 0x7d69934fU, 0, false, true, "" },
1964    { "    v_cmpx_gt_i64  v[50:51], v[107:108] vop3",
1965        0xd4b40000U, 0x0002d732U, true, true, "" },
1966    { "    v_cmpx_lg_i64  v[79:80], v[201:202]", 0x7d6b934fU, 0, false, true, "" },
1967    { "    v_cmpx_lg_i64  v[50:51], v[107:108] vop3",
1968        0xd4b50000U, 0x0002d732U, true, true, "" },
1969    { "    v_cmpx_ne_i64  v[79:80], v[201:202]", 0x7d6b934fU, 0, false, true, "" },
1970    { "    v_cmpx_ne_i64  v[50:51], v[107:108] vop3",
1971        0xd4b50000U, 0x0002d732U, true, true, "" },
1972    { "    v_cmpx_ge_i64  v[79:80], v[201:202]", 0x7d6d934fU, 0, false, true, "" },
1973    { "    v_cmpx_ge_i64  v[50:51], v[107:108] vop3",
1974        0xd4b60000U, 0x0002d732U, true, true, "" },
1975    { "    v_cmpx_tru_i64  v[79:80], v[201:202]", 0x7d6f934fU, 0, false, true, "" },
1976    { "    v_cmpx_tru_i64  v[50:51], v[107:108] vop3",
1977        0xd4b70000U, 0x0002d732U, true, true, "" },
1978    { "    v_cmpx_t_i64  v[79:80], v[201:202]", 0x7d6f934fU, 0, false, true, "" },
1979    { "    v_cmpx_t_i64  v[50:51], v[107:108] vop3",
1980        0xd4b70000U, 0x0002d732U, true, true, "" },
1981    { "    v_cmpx_class_f64  v[79:80], v[201:202]", 0x7d71934fU, 0, false, true, "" },
1982    { "    v_cmpx_class_f64  v[50:51], v[107:108] vop3",
1983        0xd4b80000U, 0x0002d732U, true, true, "" },
1984    { "    v_cmpx_lt_u16  v79, v201", 0x7d73934fU, 0, false, true, "" },
1985    { "    v_cmpx_lt_u16  v50, v107 vop3", 0xd4b90000U, 0x0002d732U, true, true, "" },
1986    { "    v_cmpx_eq_u16  v79, v201", 0x7d75934fU, 0, false, true, "" },
1987    { "    v_cmpx_eq_u16  v50, v107 vop3", 0xd4ba0000U, 0x0002d732U, true, true, "" },
1988    { "    v_cmpx_le_u16  v79, v201", 0x7d77934fU, 0, false, true, "" },
1989    { "    v_cmpx_le_u16  v50, v107 vop3", 0xd4bb0000U, 0x0002d732U, true, true, "" },
1990    { "    v_cmpx_gt_u16  v79, v201", 0x7d79934fU, 0, false, true, "" },
1991    { "    v_cmpx_gt_u16  v50, v107 vop3", 0xd4bc0000U, 0x0002d732U, true, true, "" },
1992    { "    v_cmpx_lg_u16  v79, v201", 0x7d7b934fU, 0, false, true, "" },
1993    { "    v_cmpx_lg_u16  v50, v107 vop3", 0xd4bd0000U, 0x0002d732U, true, true, "" },
1994    { "    v_cmpx_ne_u16  v79, v201", 0x7d7b934fU, 0, false, true, "" },
1995    { "    v_cmpx_ne_u16  v50, v107 vop3", 0xd4bd0000U, 0x0002d732U, true, true, "" },
1996    { "    v_cmpx_ge_u16  v79, v201", 0x7d7d934fU, 0, false, true, "" },
1997    { "    v_cmpx_ge_u16  v50, v107 vop3", 0xd4be0000U, 0x0002d732U, true, true, "" },
1998   
1999    { "    v_cmp_f_u32  vcc, v79, v201", 0x7d81934fU, 0, false, true, "" },
2000    { "    v_cmp_f_u32  s[42:43], v50, v107", 0xd4c0002aU, 0x0002d732U, true, true, "" },
2001    { "    v_cmp_lt_u32  vcc, v79, v201", 0x7d83934fU, 0, false, true, "" },
2002    { "    v_cmp_lt_u32  s[42:43], v50, v107", 0xd4c1002aU, 0x0002d732U, true, true, "" },
2003    { "    v_cmp_eq_u32  vcc, v79, v201", 0x7d85934fU, 0, false, true, "" },
2004    { "    v_cmp_eq_u32  s[42:43], v50, v107", 0xd4c2002aU, 0x0002d732U, true, true, "" },
2005    { "    v_cmp_le_u32  vcc, v79, v201", 0x7d87934fU, 0, false, true, "" },
2006    { "    v_cmp_le_u32  s[42:43], v50, v107", 0xd4c3002aU, 0x0002d732U, true, true, "" },
2007    { "    v_cmp_gt_u32  vcc, v79, v201", 0x7d89934fU, 0, false, true, "" },
2008    { "    v_cmp_gt_u32  s[42:43], v50, v107", 0xd4c4002aU, 0x0002d732U, true, true, "" },
2009    { "    v_cmp_lg_u32  vcc, v79, v201", 0x7d8b934fU, 0, false, true, "" },
2010    { "    v_cmp_lg_u32  s[42:43], v50, v107", 0xd4c5002aU, 0x0002d732U, true, true, "" },
2011    { "    v_cmp_ne_u32  vcc, v79, v201", 0x7d8b934fU, 0, false, true, "" },
2012    { "    v_cmp_ne_u32  s[42:43], v50, v107", 0xd4c5002aU, 0x0002d732U, true, true, "" },
2013    { "    v_cmp_ge_u32  vcc, v79, v201", 0x7d8d934fU, 0, false, true, "" },
2014    { "    v_cmp_ge_u32  s[42:43], v50, v107", 0xd4c6002aU, 0x0002d732U, true, true, "" },
2015    { "    v_cmp_tru_u32  vcc, v79, v201", 0x7d8f934fU, 0, false, true, "" },
2016    { "    v_cmp_tru_u32  s[42:43], v50, v107", 0xd4c7002aU, 0x0002d732U, true, true, "" },
2017    { "    v_cmp_t_u32  vcc, v79, v201", 0x7d8f934fU, 0, false, true, "" },
2018    { "    v_cmp_t_u32  s[42:43], v50, v107", 0xd4c7002aU, 0x0002d732U, true, true, "" },
2019    { "    v_cmp_f_f16  vcc, v79, v201", 0x7d91934fU, 0, false, true, "" },
2020    { "    v_cmp_f_f16  s[42:43], v50, v107", 0xd4c8002aU, 0x0002d732U, true, true, "" },
2021    { "    v_cmp_lt_f16  vcc, v79, v201", 0x7d93934fU, 0, false, true, "" },
2022    { "    v_cmp_lt_f16  s[42:43], v50, v107", 0xd4c9002aU, 0x0002d732U, true, true, "" },
2023    { "    v_cmp_eq_f16  vcc, v79, v201", 0x7d95934fU, 0, false, true, "" },
2024    { "    v_cmp_eq_f16  s[42:43], v50, v107", 0xd4ca002aU, 0x0002d732U, true, true, "" },
2025    { "    v_cmp_le_f16  vcc, v79, v201", 0x7d97934fU, 0, false, true, "" },
2026    { "    v_cmp_le_f16  s[42:43], v50, v107", 0xd4cb002aU, 0x0002d732U, true, true, "" },
2027    { "    v_cmp_gt_f16  vcc, v79, v201", 0x7d99934fU, 0, false, true, "" },
2028    { "    v_cmp_gt_f16  s[42:43], v50, v107", 0xd4cc002aU, 0x0002d732U, true, true, "" },
2029    { "    v_cmp_lg_f16  vcc, v79, v201", 0x7d9b934fU, 0, false, true, "" },
2030    { "    v_cmp_lg_f16  s[42:43], v50, v107", 0xd4cd002aU, 0x0002d732U, true, true, "" },
2031    { "    v_cmp_ge_f16  vcc, v79, v201", 0x7d9d934fU, 0, false, true, "" },
2032    { "    v_cmp_ge_f16  s[42:43], v50, v107", 0xd4ce002aU, 0x0002d732U, true, true, "" },
2033    { "    v_cmp_o_f16  vcc, v79, v201", 0x7d9f934fU, 0, false, true, "" },
2034    { "    v_cmp_o_f16  s[42:43], v50, v107", 0xd4cf002aU, 0x0002d732U, true, true, "" },
2035   
2036    { "    v_cmpx_f_u32  v79, v201", 0x7da1934fU, 0, false, true, "" },
2037    { "    v_cmpx_f_u32  v50, v107 vop3", 0xd4d00000U, 0x0002d732U, true, true, "" },
2038    { "    v_cmpx_lt_u32  v79, v201", 0x7da3934fU, 0, false, true, "" },
2039    { "    v_cmpx_lt_u32  v50, v107 vop3", 0xd4d10000U, 0x0002d732U, true, true, "" },
2040    { "    v_cmpx_eq_u32  v79, v201", 0x7da5934fU, 0, false, true, "" },
2041    { "    v_cmpx_eq_u32  v50, v107 vop3", 0xd4d20000U, 0x0002d732U, true, true, "" },
2042    { "    v_cmpx_le_u32  v79, v201", 0x7da7934fU, 0, false, true, "" },
2043    { "    v_cmpx_le_u32  v50, v107 vop3", 0xd4d30000U, 0x0002d732U, true, true, "" },
2044    { "    v_cmpx_gt_u32  v79, v201", 0x7da9934fU, 0, false, true, "" },
2045    { "    v_cmpx_gt_u32  v50, v107 vop3", 0xd4d40000U, 0x0002d732U, true, true, "" },
2046    { "    v_cmpx_lg_u32  v79, v201", 0x7dab934fU, 0, false, true, "" },
2047    { "    v_cmpx_lg_u32  v50, v107 vop3", 0xd4d50000U, 0x0002d732U, true, true, "" },
2048    { "    v_cmpx_ne_u32  v79, v201", 0x7dab934fU, 0, false, true, "" },
2049    { "    v_cmpx_ne_u32  v50, v107 vop3", 0xd4d50000U, 0x0002d732U, true, true, "" },
2050    { "    v_cmpx_ge_u32  v79, v201", 0x7dad934fU, 0, false, true, "" },
2051    { "    v_cmpx_ge_u32  v50, v107 vop3", 0xd4d60000U, 0x0002d732U, true, true, "" },
2052    { "    v_cmpx_tru_u32  v79, v201", 0x7daf934fU, 0, false, true, "" },
2053    { "    v_cmpx_tru_u32  v50, v107 vop3", 0xd4d70000U, 0x0002d732U, true, true, "" },
2054    { "    v_cmpx_t_u32  v79, v201", 0x7daf934fU, 0, false, true, "" },
2055    { "    v_cmpx_t_u32  v50, v107 vop3", 0xd4d70000U, 0x0002d732U, true, true, "" },
2056    { "    v_cmpx_f_f16  v79, v201", 0x7db1934fU, 0, false, true, "" },
2057    { "    v_cmpx_f_f16  v50, v107 vop3", 0xd4d80000U, 0x0002d732U, true, true, "" },
2058    { "    v_cmpx_lt_f16  v79, v201", 0x7db3934fU, 0, false, true, "" },
2059    { "    v_cmpx_lt_f16  v50, v107 vop3", 0xd4d90000U, 0x0002d732U, true, true, "" },
2060    { "    v_cmpx_eq_f16  v79, v201", 0x7db5934fU, 0, false, true, "" },
2061    { "    v_cmpx_eq_f16  v50, v107 vop3", 0xd4da0000U, 0x0002d732U, true, true, "" },
2062    { "    v_cmpx_le_f16  v79, v201", 0x7db7934fU, 0, false, true, "" },
2063    { "    v_cmpx_le_f16  v50, v107 vop3", 0xd4db0000U, 0x0002d732U, true, true, "" },
2064    { "    v_cmpx_gt_f16  v79, v201", 0x7db9934fU, 0, false, true, "" },
2065    { "    v_cmpx_gt_f16  v50, v107 vop3", 0xd4dc0000U, 0x0002d732U, true, true, "" },
2066    { "    v_cmpx_lg_f16  v79, v201", 0x7dbb934fU, 0, false, true, "" },
2067    { "    v_cmpx_lg_f16  v50, v107 vop3", 0xd4dd0000U, 0x0002d732U, true, true, "" },
2068    { "    v_cmpx_ge_f16  v79, v201", 0x7dbd934fU, 0, false, true, "" },
2069    { "    v_cmpx_ge_f16  v50, v107 vop3", 0xd4de0000U, 0x0002d732U, true, true, "" },
2070    { "    v_cmpx_o_f16  v79, v201", 0x7dbf934fU, 0, false, true, "" },
2071    { "    v_cmpx_o_f16  v50, v107 vop3", 0xd4df0000U, 0x0002d732U, true, true, "" },
2072   
2073    { "    v_cmp_f_u64  vcc, v[79:80], v[201:202]", 0x7dc1934fU, 0, false, true, "" },
2074    { "    v_cmp_f_u64  s[42:43], v[50:51], v[107:108]",
2075        0xd4e0002aU, 0x0002d732U, true, true, "" },
2076    { "    v_cmp_lt_u64  vcc, v[79:80], v[201:202]", 0x7dc3934fU, 0, false, true, "" },
2077    { "    v_cmp_lt_u64  s[42:43], v[50:51], v[107:108]",
2078        0xd4e1002aU, 0x0002d732U, true, true, "" },
2079    { "    v_cmp_eq_u64  vcc, v[79:80], v[201:202]", 0x7dc5934fU, 0, false, true, "" },
2080    { "    v_cmp_eq_u64  s[42:43], v[50:51], v[107:108]",
2081        0xd4e2002aU, 0x0002d732U, true, true, "" },
2082    { "    v_cmp_le_u64  vcc, v[79:80], v[201:202]", 0x7dc7934fU, 0, false, true, "" },
2083    { "    v_cmp_le_u64  s[42:43], v[50:51], v[107:108]",
2084        0xd4e3002aU, 0x0002d732U, true, true, "" },
2085    { "    v_cmp_gt_u64  vcc, v[79:80], v[201:202]", 0x7dc9934fU, 0, false, true, "" },
2086    { "    v_cmp_gt_u64  s[42:43], v[50:51], v[107:108]",
2087        0xd4e4002aU, 0x0002d732U, true, true, "" },
2088    { "    v_cmp_lg_u64  vcc, v[79:80], v[201:202]", 0x7dcb934fU, 0, false, true, "" },
2089    { "    v_cmp_lg_u64  s[42:43], v[50:51], v[107:108]",
2090        0xd4e5002aU, 0x0002d732U, true, true, "" },
2091    { "    v_cmp_ne_u64  vcc, v[79:80], v[201:202]", 0x7dcb934fU, 0, false, true, "" },
2092    { "    v_cmp_ne_u64  s[42:43], v[50:51], v[107:108]",
2093        0xd4e5002aU, 0x0002d732U, true, true, "" },
2094    { "    v_cmp_ge_u64  vcc, v[79:80], v[201:202]", 0x7dcd934fU, 0, false, true, "" },
2095    { "    v_cmp_ge_u64  s[42:43], v[50:51], v[107:108]",
2096        0xd4e6002aU, 0x0002d732U, true, true, "" },
2097    { "    v_cmp_tru_u64  vcc, v[79:80], v[201:202]", 0x7dcf934fU, 0, false, true, "" },
2098    { "    v_cmp_tru_u64  s[42:43], v[50:51], v[107:108]",
2099        0xd4e7002aU, 0x0002d732U, true, true, "" },
2100    { "    v_cmp_t_u64  vcc, v[79:80], v[201:202]", 0x7dcf934fU, 0, false, true, "" },
2101    { "    v_cmp_t_u64  s[42:43], v[50:51], v[107:108]",
2102        0xd4e7002aU, 0x0002d732U, true, true, "" },
2103    { "    v_cmp_u_f16  vcc, v79, v201", 0x7dd1934fU, 0, false, true, "" },
2104    { "    v_cmp_u_f16  s[42:43], v50, v107", 0xd4e8002aU, 0x0002d732U, true, true, "" },
2105    { "    v_cmp_nge_f16  vcc, v79, v201", 0x7dd3934fU, 0, false, true, "" },
2106    { "    v_cmp_nge_f16  s[42:43], v50, v107", 0xd4e9002aU, 0x0002d732U, true, true, "" },
2107    { "    v_cmp_nlg_f16  vcc, v79, v201", 0x7dd5934fU, 0, false, true, "" },
2108    { "    v_cmp_nlg_f16  s[42:43], v50, v107", 0xd4ea002aU, 0x0002d732U, true, true, "" },
2109    { "    v_cmp_ngt_f16  vcc, v79, v201", 0x7dd7934fU, 0, false, true, "" },
2110    { "    v_cmp_ngt_f16  s[42:43], v50, v107", 0xd4eb002aU, 0x0002d732U, true, true, "" },
2111    { "    v_cmp_nle_f16  vcc, v79, v201", 0x7dd9934fU, 0, false, true, "" },
2112    { "    v_cmp_nle_f16  s[42:43], v50, v107", 0xd4ec002aU, 0x0002d732U, true, true, "" },
2113    { "    v_cmp_neq_f16  vcc, v79, v201", 0x7ddb934fU, 0, false, true, "" },
2114    { "    v_cmp_neq_f16  s[42:43], v50, v107", 0xd4ed002aU, 0x0002d732U, true, true, "" },
2115    { "    v_cmp_nlt_f16  vcc, v79, v201", 0x7ddd934fU, 0, false, true, "" },
2116    { "    v_cmp_nlt_f16  s[42:43], v50, v107", 0xd4ee002aU, 0x0002d732U, true, true, "" },
2117    { "    v_cmp_tru_f16  vcc, v79, v201", 0x7ddf934fU, 0, false, true, "" },
2118    { "    v_cmp_tru_f16  s[42:43], v50, v107", 0xd4ef002aU, 0x0002d732U, true, true, "" },
2119    { "    v_cmp_t_f16  vcc, v79, v201", 0x7ddf934fU, 0, false, true, "" },
2120    { "    v_cmp_t_f16  s[42:43], v50, v107", 0xd4ef002aU, 0x0002d732U, true, true, "" },
2121   
2122    { "    v_cmpx_f_u64  v[79:80], v[201:202]", 0x7de1934fU, 0, false, true, "" },
2123    { "    v_cmpx_f_u64  v[50:51], v[107:108] vop3",
2124        0xd4f00000U, 0x0002d732U, true, true, "" },
2125    { "    v_cmpx_lt_u64  v[79:80], v[201:202]", 0x7de3934fU, 0, false, true, "" },
2126    { "    v_cmpx_lt_u64  v[50:51], v[107:108] vop3",
2127        0xd4f10000U, 0x0002d732U, true, true, "" },
2128    { "    v_cmpx_eq_u64  v[79:80], v[201:202]", 0x7de5934fU, 0, false, true, "" },
2129    { "    v_cmpx_eq_u64  v[50:51], v[107:108] vop3",
2130        0xd4f20000U, 0x0002d732U, true, true, "" },
2131    { "    v_cmpx_le_u64  v[79:80], v[201:202]", 0x7de7934fU, 0, false, true, "" },
2132    { "    v_cmpx_le_u64  v[50:51], v[107:108] vop3",
2133        0xd4f30000U, 0x0002d732U, true, true, "" },
2134    { "    v_cmpx_gt_u64  v[79:80], v[201:202]", 0x7de9934fU, 0, false, true, "" },
2135    { "    v_cmpx_gt_u64  v[50:51], v[107:108] vop3",
2136        0xd4f40000U, 0x0002d732U, true, true, "" },
2137    { "    v_cmpx_lg_u64  v[79:80], v[201:202]", 0x7deb934fU, 0, false, true, "" },
2138    { "    v_cmpx_lg_u64  v[50:51], v[107:108] vop3",
2139        0xd4f50000U, 0x0002d732U, true, true, "" },
2140    { "    v_cmpx_ne_u64  v[79:80], v[201:202]", 0x7deb934fU, 0, false, true, "" },
2141    { "    v_cmpx_ne_u64  v[50:51], v[107:108] vop3",
2142        0xd4f50000U, 0x0002d732U, true, true, "" },
2143    { "    v_cmpx_ge_u64  v[79:80], v[201:202]", 0x7ded934fU, 0, false, true, "" },
2144    { "    v_cmpx_ge_u64  v[50:51], v[107:108] vop3",
2145        0xd4f60000U, 0x0002d732U, true, true, "" },
2146    { "    v_cmpx_tru_u64  v[79:80], v[201:202]", 0x7def934fU, 0, false, true, "" },
2147    { "    v_cmpx_tru_u64  v[50:51], v[107:108] vop3",
2148        0xd4f70000U, 0x0002d732U, true, true, "" },
2149    { "    v_cmpx_t_u64  v[79:80], v[201:202]", 0x7def934fU, 0, false, true, "" },
2150    { "    v_cmpx_t_u64  v[50:51], v[107:108] vop3",
2151        0xd4f70000U, 0x0002d732U, true, true, "" },
2152    { "    v_cmpx_u_f16  v79, v201", 0x7df1934fU, 0, false, true, "" },
2153    { "    v_cmpx_u_f16  v50, v107 vop3", 0xd4f80000U, 0x0002d732U, true, true, "" },
2154    { "    v_cmpx_nge_f16  v79, v201", 0x7df3934fU, 0, false, true, "" },
2155    { "    v_cmpx_nge_f16  v50, v107 vop3", 0xd4f90000U, 0x0002d732U, true, true, "" },
2156    { "    v_cmpx_nlg_f16  v79, v201", 0x7df5934fU, 0, false, true, "" },
2157    { "    v_cmpx_nlg_f16  v50, v107 vop3", 0xd4fa0000U, 0x0002d732U, true, true, "" },
2158    { "    v_cmpx_ngt_f16  v79, v201", 0x7df7934fU, 0, false, true, "" },
2159    { "    v_cmpx_ngt_f16  v50, v107 vop3", 0xd4fb0000U, 0x0002d732U, true, true, "" },
2160    { "    v_cmpx_nle_f16  v79, v201", 0x7df9934fU, 0, false, true, "" },
2161    { "    v_cmpx_nle_f16  v50, v107 vop3", 0xd4fc0000U, 0x0002d732U, true, true, "" },
2162    { "    v_cmpx_neq_f16  v79, v201", 0x7dfb934fU, 0, false, true, "" },
2163    { "    v_cmpx_neq_f16  v50, v107 vop3", 0xd4fd0000U, 0x0002d732U, true, true, "" },
2164    { "    v_cmpx_nlt_f16  v79, v201", 0x7dfd934fU, 0, false, true, "" },
2165    { "    v_cmpx_nlt_f16  v50, v107 vop3", 0xd4fe0000U, 0x0002d732U, true, true, "" },
2166    { "    v_cmpx_tru_f16  v79, v201", 0x7dff934fU, 0, false, true, "" },
2167    { "    v_cmpx_tru_f16  v50, v107 vop3", 0xd4ff0000U, 0x0002d732U, true, true, "" },
2168    { "    v_cmpx_t_f16  v79, v201", 0x7dff934fU, 0, false, true, "" },
2169    { "    v_cmpx_t_f16  v50, v107 vop3", 0xd4ff0000U, 0x0002d732U, true, true, "" },
2170    /* OP_SEL */
2171    /* for VOP1/VOP3 */
2172    { "    v_not_b32  v55, v27 op_sel:[0,1]", 0xd5b74037U, 0x0000011bU, true, true, "" },
2173    { "    v_not_b32  v55, v27 op_sel:[1,0]", 0xd5b70837U, 0x0000011bU, true, true, "" },
2174    /* for VOP2/VOP3 */
2175    { "    v_min_f32  v55, s27, -v90 op_sel:[1,0,0]",
2176        0xd50f0837U, 0x4002b41bU, true, true, "" },
2177    { "    v_min_f32  v55, s27, -v90 op_sel:[0,1,0]",
2178        0xd50f1037U, 0x4002b41bU, true, true, "" },
2179    { "    v_min_f32  v55, s27, -v90 op_sel:[0,0,1]",
2180        0xd50f4037U, 0x4002b41bU, true, true, "" },
2181    /* for VOPC/VOP3 */
2182    { "    v_cmp_lt_i16  s[42:43], v50, v107 op_sel:[1,0,0]",
2183        0xd489082aU, 0x0002d732U, true, true, "" },
2184    { "    v_cmp_lt_i16  s[42:43], v50, v107 op_sel:[0,1,0]",
2185        0xd489102aU, 0x0002d732U, true, true, "" },
2186    { "    v_cmp_lt_i16  s[42:43], v50, v107 op_sel:[0,0,1]",
2187        0xd489402aU, 0x0002d732U, true, true, "" },
2188    /* VOP3 encoding */
2189    { "   v_mad_legacy_f32 v55, v79, v166, v229",
2190        0xd5400037U, 0x07974d4fU, true, true, "" },
2191    { "   v_mad_legacy_f32 v55, v79, v166, s101",
2192        0xd5400037U, 0x1974d4fU, true, true, "" },
2193    { "   v_mad_legacy_f32 v55, v79, s63, v229",
2194        0xd5400037U, 0x07947f4fU, true, true, "" },
2195    { "   v_mad_legacy_f32 v55, s79, v166, v229",
2196        0xd5400037U, 0x07974c4fU, true, true, "" },
2197    { "   v_mad_legacy_f32 v55, abs(v79), v166, v229",
2198        0xd5400137U, 0x07974d4fU, true, true, "" },
2199    { "   v_mad_legacy_f32 v55, v79, abs(v166), v229",
2200        0xd5400237U, 0x07974d4fU, true, true, "" },
2201    { "   v_mad_legacy_f32 v55, v79, v166, abs(v229)",
2202        0xd5400437U, 0x07974d4fU, true, true, "" },
2203    { "   v_mad_legacy_f32 v55, v79, v166, v229 abs:4",
2204        0xd5400437U, 0x07974d4fU, true, true, "" },
2205    { "   v_mad_legacy_f32 v55, -v79, v166, v229",
2206        0xd5400037U, 0x27974d4fU, true, true, "" },
2207    { "   v_mad_legacy_f32 v55, v79, -v166, v229",
2208        0xd5400037U, 0x47974d4fU, true, true, "" },
2209    { "   v_mad_legacy_f32 v55, v79, v166, -v229",
2210        0xd5400037U, 0x87974d4fU, true, true, "" },
2211    { "   v_mad_legacy_f32 v55, v79, v166, v229 neg:4",
2212        0xd5400037U, 0x87974d4fU, true, true, "" },
2213    { "   v_mad_legacy_f32 v55, v79, v166, v229 neg:[0,0,1]",
2214        0xd5400037U, 0x87974d4fU, true, true, "" },
2215    { "   v_mad_legacy_f32 v55, v79, v166, v229 clamp",
2216        0xd5408037U, 0x07974d4fU, true, true, "" },
2217    { "   v_mad_legacy_f32 v55, v79, v166, v229 mul:2",
2218        0xd5400037U, 0x0f974d4fU, true, true, "" },
2219    { "   v_mad_legacy_f32 v55, v79, v166, v229 mul:4",
2220        0xd5400037U, 0x17974d4fU, true, true, "" },
2221    { "   v_mad_legacy_f32 v55, v79, v166, v229 div:2",
2222        0xd5400037U, 0x1f974d4fU, true, true, "" },
2223    { "   v_mad_legacy_f32 v55, 56, v166, v229",
2224        0xd5400037U, 0x07974cb8U, true, true, "" },
2225    { "bx=51;v_mad_legacy_f32 v55, bx+5, v166, v229",
2226        0xd5400037U, 0x07974cb8U, true, true, "" },
2227    { "   v_mad_legacy_f32 v55, v56, -15, v229",
2228        0xd5400037U, 0x07959f38U, true, true, "" },
2229    { "vxt=15; v_mad_legacy_f32 v55, v56, -vxt, v229",
2230        0xd5400037U, 0x07959f38U, true, true, "" },
2231    { "   v_mad_legacy_f32 v55, v79, v166, 45",
2232        0xd5400037U, 0x02b74d4fU, true, true, "" },
2233    { "gg=22;v_mad_legacy_f32 v55, v79, v166, 2*gg+1",
2234        0xd5400037U, 0x02b74d4fU, true, true, "" },
2235    /* one SGPR */
2236    { "    v_mad_legacy_f32 v55, s79, v166, s79",
2237        0xd5400037U, 0x013f4c4fU, true, true, "" },
2238    { "    v_mad_legacy_f32 v55, s79, s79, s79",
2239        0xd5400037U, 0x013c9e4fU, true, true, "" },
2240    /* two SGPRs */
2241    { "    v_mad_legacy_f32 v55, s79, s99, v229",
2242        0xd5400037U, 0x0794c64fU, true, true, "" },
2243    { "    v_mad_legacy_f32 v55, s79, v99, s18",
2244        0xd5400037U, 0x004ac64fU, true, true, "" },
2245    /* VOP3 errors */
2246    { "    v_mad_legacy_f32 v55, s79, s166, v229", 0, 0, false, false,
2247        "test.s:1:32: Error: Scalar register number out of range\n" },
2248    { "   v_mad_legacy_f32 v55, v79, v166, v229 clamp ,", 0, 0, false, false,
2249        "test.s:1:48: Error: Some garbages at VOP modifier place\n" },
2250    { "v_mad_f32 v55, abs(v79), abs(v166), sext(-v229)", 0, 0, true, false,
2251        "test.s:1:41: Error: Expected operator\n"
2252        "test.s:1:47: Error: Some garbages at VOP modifier place\n" },
2253    { "v_mad_f32 v55, abs(v79), abs(v166), -v229 sext:4", 0, 0, true, false,
2254        "test.s:1:43: Error: Unknown VOP modifier\n"
2255        "test.s:1:47: Error: Some garbages at VOP modifier place\n" },
2256    /* VOP3 instructions */
2257    { "   v_mad_f32  v55, v79, v166, v229", 0xd5410037U, 0x07974d4fU, true, true, "" },
2258    { "   v_mad_i32_i24  v55, v79, v166, v229", 0xd5420037U, 0x07974d4fU, true, true, "" },
2259    { "   v_mad_u32_u24  v55, v79, v166, v229", 0xd5430037U, 0x07974d4fU, true, true, "" },
2260    { "   v_cubeid_f32  v55, v79, v166, v229", 0xd5440037U, 0x07974d4fU, true, true, "" },
2261    { "   v_cubesc_f32  v55, v79, v166, v229", 0xd5450037U, 0x07974d4fU, true, true, "" },
2262    { "   v_cubetc_f32  v55, v79, v166, v229", 0xd5460037U, 0x07974d4fU, true, true, "" },
2263    { "   v_cubema_f32  v55, v79, v166, v229", 0xd5470037U, 0x07974d4fU, true, true, "" },
2264    { "   v_bfe_u32  v55, v79, v166, v229", 0xd5480037U, 0x07974d4fU, true, true, "" },
2265    { "   v_bfe_i32  v55, v79, v166, v229", 0xd5490037U, 0x07974d4fU, true, true, "" },
2266    { "   v_bfi_b32  v55, v79, v166, v229", 0xd54a0037U, 0x07974d4fU, true, true, "" },
2267    { "   v_fma_f32  v55, v79, v166, v229", 0xd54b0037U, 0x07974d4fU, true, true, "" },
2268    { "   v_fma_f64  v[55:56], v[79:80], v[166:167], v[229:230]",
2269        0xd54c0037U, 0x07974d4fU, true, true, "" },
2270    { "   v_fma_f64 v[5:6], v[1:2], v[3:4], s[1:2]",
2271        0xd54c0005U, 0x00060701U, true, true, "" },
2272    { "   v_lerp_u8  v55, v79, v166, v229", 0xd54d0037U, 0x07974d4fU, true, true, "" },
2273    { "   v_alignbit_b32  v55, v79, v166, v229", 0xd54e0037U, 0x07974d4fU, true, true, "" },
2274    { "   v_alignbyte_b32  v55, v79, v166, v229",
2275        0xd54f0037U, 0x07974d4fU, true, true, "" },
2276    { "   v_mullit_f32    v55, v79, v166, s0", 0xd5500037U, 0x00034d4fU, true, true, "" },
2277    { "   v_mullit_f32    v55, v79, v166, s0", 0xd5500037U, 0x00034d4fU, true, true, "" },
2278    { "   v_mullit_f32    v55, s79, v166, v229", 0xd5500037U, 0x07974c4fU, true, true, "" },
2279    { "   v_min3_f32  v55, v79, v166, v229", 0xd5510037U, 0x07974d4fU, true, true, "" },
2280    { "   v_min3_i32  v55, v79, v166, v229", 0xd5520037U, 0x07974d4fU, true, true, "" },
2281    { "   v_min3_u32  v55, v79, v166, v229", 0xd5530037U, 0x07974d4fU, true, true, "" },
2282    { "   v_max3_f32  v55, v79, v166, v229", 0xd5540037U, 0x07974d4fU, true, true, "" },
2283    { "   v_max3_i32  v55, v79, v166, v229", 0xd5550037U, 0x07974d4fU, true, true, "" },
2284    { "   v_max3_u32  v55, v79, v166, v229", 0xd5560037U, 0x07974d4fU, true, true, "" },
2285    { "   v_med3_f32  v55, v79, v166, v229", 0xd5570037U, 0x07974d4fU, true, true, "" },
2286    { "   v_med3_i32  v55, v79, v166, v229", 0xd5580037U, 0x07974d4fU, true, true, "" },
2287    { "   v_med3_u32  v55, v79, v166, v229", 0xd5590037U, 0x07974d4fU, true, true, "" },
2288    { "   v_sad_u8  v55, v79, v166, v229", 0xd55a0037U, 0x07974d4fU, true, true, "" },
2289    { "   v_sad_hi_u8  v55, v79, v166, v229", 0xd55b0037U, 0x07974d4fU, true, true, "" },
2290    { "   v_sad_u16  v55, v79, v166, v229", 0xd55c0037U, 0x07974d4fU, true, true, "" },
2291    { "   v_sad_u32  v55, v79, v166, v229", 0xd55d0037U, 0x07974d4fU, true, true, "" },
2292    { "   v_cvt_pk_u8_f32 v55, v79, v166, v229", 0xd55e0037U, 0x07974d4fU, true, true, "" },
2293    { "   v_div_fixup_f32 v55, v79, v166, v229", 0xd55f0037U, 0x07974d4fU, true, true, "" },
2294    { "   v_div_fixup_f64 v[55:56], v[79:80], v[166:167], v[229:230]",
2295        0xd5600037U, 0x07974d4fU, true, true, "" },
2296    { "   v_lshl_b64  v[55:56], v[79:80], v166", 0, 0, false, false,
2297        "test.s:1:4: Error: Unknown instruction\n" },
2298    { "   v_lshr_b64  v[55:56], v[79:80], v166", 0, 0, false, false,
2299        "test.s:1:4: Error: Unknown instruction\n" },
2300    { "   v_ashr_i64  v[55:56], v[79:80], v166", 0, 0, false, false,
2301        "test.s:1:4: Error: Unknown instruction\n" },
2302    { "   v_add_f64  v[55:56], v[79:80], v[166:167]",
2303        0xd5640037U, 0x00034d4fU, true, true, "" },
2304    { "   v_mul_f64  v[55:56], v[79:80], v[166:167]",
2305        0xd5650037U, 0x00034d4fU, true, true, "" },
2306    // sgpr alignment check
2307    { "   v_mul_f64  v[55:56], s[79:80], v[166:167]",
2308        0xd5650037U, 0x00034c4fU, true, true, "" },
2309    { "z=%s[70:89] ;v_mul_f64  v[55:56], z[9:10], v[166:167]",
2310        0xd5650037U, 0x00034c4fU, true, true, "" },
2311    { "   v_mul_f64  v[55:56], s[77:78], v[166:167]",
2312        0xd5650037U, 0x00034c4dU, true, true, "" },
2313    { "   v_min_f64  v[55:56], v[79:80], v[166:167]",
2314        0xd5660037U, 0x00034d4fU, true, true, "" },
2315    { "   v_max_f64  v[55:56], v[79:80], v[166:167]",
2316        0xd5670037U, 0x00034d4fU, true, true, "" },
2317    { "   v_ldexp_f64  v[55:56], v[79:80], v166",
2318        0xd5680037U, 0x00034d4fU, true, true, "" },
2319    { "   v_mul_lo_u32  v55, v79, v166", 0xd5690037U, 0x00034d4fU, true, true, "" },
2320    { "   v_mul_hi_u32  v55, v79, v166", 0xd56a0037U, 0x00034d4fU, true, true, "" },
2321    { "   v_mul_lo_i32  v55, v79, v166", 0xd56b0037U, 0x00034d4fU, true, true, "" },
2322    { "   v_mul_hi_i32  v55, v79, v166", 0xd56c0037U, 0x00034d4fU, true, true, "" },
2323    { "   v_div_scale_f32  v55, s[38:39], v79, v166, v79",
2324        0xd56d2637U, 0x053f4d4fU, true, true, "" },
2325    { "   v_div_scale_f32  v55, s[37:38], v79, v166, v79",
2326        0xd56d2537U, 0x053f4d4fU, true, true, "" },
2327    { "   v_div_scale_f32  v55, s[38:39], v79, v79, v229",
2328        0xd56d2637U, 0x07969f4fU, true, true, "" },
2329    { "   v_div_scale_f64 v[55:56], s[38:39], v[79:80], v[166:167], v[79:80]",
2330        0xd56e2637U, 0x053f4d4fU, true, true, "" },
2331    { "   v_div_scale_f64 v[55:56], s[38:39], v[79:80], v[79:80], v[229:230]",
2332        0xd56e2637U, 0x07969f4fU, true, true, "" },
2333    { "   v_div_fmas_f32  v55, v79, v166, v229", 0xd56f0037U, 0x07974d4fU, true, true, "" },
2334    { "   v_div_fmas_f64  v[55:56], v[79:80], v[166:167], v[229:230]",
2335        0xd5700037U, 0x07974d4fU, true, true, "" },
2336    { "   v_msad_u8  v55, v79, v166, v229", 0xd5710037U, 0x07974d4fU, true, true, "" },
2337    { "    v_qsad_pk_u16_u8  v[55:56], v[79:80], v166, v[229:230]",
2338        0xd5720037U, 0x07974d4fU, true, true, "" },
2339    { "    v_mqsad_pk_u16_u8  v[55:56], v[79:80], v166, v[229:230]",
2340        0xd5730037U, 0x07974d4fU, true, true, "" },
2341    { "   v_trig_preop_f64  v[55:56], v[79:80], v166",
2342        0xd5740037U, 0x00034d4fU, true, true, "" },
2343    { "    v_mqsad_u32_u8  v[55:58], v[79:80], v166, v[229:232]",
2344        0xd5750037U, 0x07974d4fU, true, true, "" },
2345    { "    v_mqsad_u32_u8  v[55:58], v[79:80], v166, s[28:31]",
2346        0xd5750037U, 0x00734d4fU, true, true, "" },
2347    { "    v_mad_u64_u32  v[55:56], s[46:47], v79, v166, v[229:230]",
2348        0xd5762e37U, 0x07974d4fU, true, true, "" },
2349    { "    v_mad_i64_i32  v[55:56], s[46:47], v79, v166, v[229:230]",
2350        0xd5772e37U, 0x07974d4fU, true, true, "" },
2351    { "   v_xor3_b32  v55, v79, v166, v229", 0xd5780037U, 0x07974d4fU, true, true, "" },
2352    { "   v_lshlrev_b64  v[55:56], v79, v[166:167]",
2353        0xd6ff0037U, 0x00034d4fU, true, true, "" },
2354    { "   v_lshrrev_b64  v[55:56], v79, v[166:167]",
2355        0xd7000037U, 0x00034d4fU, true, true, "" },
2356    { "   v_ashrrev_i64  v[55:56], v79, v[166:167]",
2357        0xd7010037U, 0x00034d4fU, true, true, "" },
2358    { "   v_add_nc_u16  v55, v79, v166", 0xd7030037U, 0x00034d4fU, true, true, "" },
2359    { "   v_sub_nc_u16  v55, v79, v166", 0xd7040037U, 0x00034d4fU, true, true, "" },
2360    { "   v_mul_lo_u16  v55, v79, v166", 0xd7050037U, 0x00034d4fU, true, true, "" },
2361    { "   v_lshrrev_b16  v55, v79, v166", 0xd7070037U, 0x00034d4fU, true, true, "" },
2362    { "   v_ashrrev_i16  v55, v79, v166", 0xd7080037U, 0x00034d4fU, true, true, "" },
2363    { "   v_max_u16  v55, v79, v166", 0xd7090037U, 0x00034d4fU, true, true, "" },
2364    { "   v_max_i16  v55, v79, v166", 0xd70a0037U, 0x00034d4fU, true, true, "" },
2365    { "   v_min_u16  v55, v79, v166", 0xd70b0037U, 0x00034d4fU, true, true, "" },
2366    { "   v_min_i16  v55, v79, v166", 0xd70c0037U, 0x00034d4fU, true, true, "" },
2367    { "   v_add_nc_i16  v55, v79, v166", 0xd70d0037U, 0x00034d4fU, true, true, "" },
2368    { "   v_sub_nc_i16  v55, v79, v166", 0xd70e0037U, 0x00034d4fU, true, true, "" },
2369    { "   v_add_co_u32  v55, s[76:77], v79, v166",
2370        0xd70f4c37U, 0x00034d4fU, true, true, "" },
2371    { "   v_sub_co_u32  v55, s[76:77], v79, v166",
2372        0xd7104c37U, 0x00034d4fU, true, true, "" },
2373    { "   v_pack_b32_f16  v55, v79, v166", 0xd7110037U, 0x00034d4fU, true, true, "" },
2374    { "   v_cvt_pknorm_i16_f16  v55, v79, v166", 0xd7120037U, 0x00034d4fU, true, true, "" },
2375    { "   v_cvt_pknorm_u16_f16  v55, v79, v166", 0xd7130037U, 0x00034d4fU, true, true, "" },
2376    { "   v_lshlrev_b16  v55, v79, v166", 0xd7140037U, 0x00034d4fU, true, true, "" },
2377    { "   v_subrev_co_u32  v55, s[76:77], v79, v166",
2378        0xd7194c37U, 0x00034d4fU, true, true, "" },
2379    { "   v_mad_u16  v55, v79, v166, v229", 0xd7400037U, 0x07974d4fU, true, true, "" },
2380    { "    v_interp_p1ll_f16 v42, v22, attr39.z",
2381        0xd742002aU, 0x00022ca7U, true, true, "" },
2382    { "    v_interp_p1lv_f16 v42, v22, attr39.z, s29",
2383        0xd743002aU, 0x00762ca7, true, true, "" },
2384    { "    v_interp_p1lv_f16 v42, v22, attr39.z, v29",
2385        0xd743002aU, 0x04762ca7, true, true, "" },
2386    { "    v_interp_p1lv_f16 v42, v22, attr39.z, s29 high  ",
2387        0xd743002aU, 0x00762da7, true, true, "" },
2388    { "   v_perm_b32  v55, v79, v166, v229", 0xd7440037U, 0x07974d4fU, true, true, "" },
2389    { "   v_xad_u32  v55, v79, v166, v229", 0xd7450037U, 0x07974d4fU, true, true, "" },
2390    { "   v_lshl_add_u32  v55, v79, v166, v229", 0xd7460037U, 0x07974d4fU, true, true, "" },
2391    { "   v_add_lshl_u32  v55, v79, v166, v229", 0xd7470037U, 0x07974d4fU, true, true, "" },
2392    { "   v_fma_f16  v55, v79, v166, v229", 0xd74b0037U, 0x07974d4fU, true, true, "" },
2393    { "   v_min3_f16  v55, v79, v166, v229", 0xd7510037U, 0x07974d4fU, true, true, "" },
2394    { "   v_min3_i16  v55, v79, v166, v229", 0xd7520037U, 0x07974d4fU, true, true, "" },
2395    { "   v_min3_u16  v55, v79, v166, v229", 0xd7530037U, 0x07974d4fU, true, true, "" },
2396    { "   v_max3_f16  v55, v79, v166, v229", 0xd7540037U, 0x07974d4fU, true, true, "" },
2397    { "   v_max3_i16  v55, v79, v166, v229", 0xd7550037U, 0x07974d4fU, true, true, "" },
2398    { "   v_max3_u16  v55, v79, v166, v229", 0xd7560037U, 0x07974d4fU, true, true, "" },
2399    { "   v_med3_f16  v55, v79, v166, v229", 0xd7570037U, 0x07974d4fU, true, true, "" },
2400    { "   v_med3_i16  v55, v79, v166, v229", 0xd7580037U, 0x07974d4fU, true, true, "" },
2401    { "   v_med3_u16  v55, v79, v166, v229", 0xd7590037U, 0x07974d4fU, true, true, "" },
2402    { "v_interp_p2_f16 v42, v1, attr39.z, s29\n",
2403        0xd75a002aU, 0x007602a7U, true, true, "" },
2404    { "    v_interp_p2_f16 v42, v22, attr39.z, s29 high  ",
2405        0xd75a002aU, 0x00762da7U, true, true, "" },
2406    { "   v_mad_i16  v55, v79, v166, v229", 0xd75e0037U, 0x07974d4fU, true, true, "" },
2407    { "v_div_fixup_f16 v55, v79, v166, v229\n", 0xd75f0037U, 0x07974d4fU, true, true, "" },
2408    { "v_readlane_b32  s55, v27, v90", 0xd7600037U, 0x0002b51bU, true, true, "" },
2409    { "v_writelane_b32 v55, v27, v90", 0xd7610037U, 0x0002b51bU, true, true, "" },
2410    { "v_writelane_b32 v55, s27, v90", 0xd7610037U, 0x0002b41bU, true, true, "" },
2411    { "   v_ldexp_f32  v55, v79, v166", 0xd7620037U, 0x00034d4fU, true, true, "" },
2412    { "   v_bfm_b32  v55, v79, v166", 0xd7630037U, 0x00034d4fU, true, true, "" },
2413    { "   v_bcnt_u32_b32  v55, v79, v166", 0xd7640037U, 0x00034d4fU, true, true, "" },
2414    { "   v_mbcnt_lo_u32_b32  v55, v79, v166", 0xd7650037U, 0x00034d4fU, true, true, "" },
2415    { "   v_mbcnt_hi_u32_b32  v55, v79, v166", 0xd7660037U, 0x00034d4fU, true, true, "" },
2416    { "   v_cvt_pknorm_i16_f32  v55, v79, v166", 0xd7680037U, 0x00034d4fU, true, true, "" },
2417    { "   v_cvt_pknorm_u16_f32  v55, v79, v166", 0xd7690037U, 0x00034d4fU, true, true, "" },
2418    { "   v_cvt_pk_u16_u32  v55, v79, v166", 0xd76a0037U, 0x00034d4fU, true, true, "" },
2419    { "   v_cvt_pk_i16_i32  v55, v79, v166", 0xd76b0037U, 0x00034d4fU, true, true, "" },
2420    { "   v_add3_u32  v55, v79, v166, v229", 0xd76d0037U, 0x07974d4fU, true, true, "" },
2421    { "   v_lshl_or_b32  v55, v79, v166, v229", 0xd76f0037U, 0x07974d4fU, true, true, "" },
2422    { "   v_and_or_b32  v55, v79, v166, v229", 0xd7710037U, 0x07974d4fU, true, true, "" },
2423    { "   v_or3_b32  v55, v79, v166, v229", 0xd7720037U, 0x07974d4fU, true, true, "" },
2424    { "   v_mad_u32_u16  v55, v79, v166, v229", 0xd7730037U, 0x07974d4fU, true, true, "" },
2425    { "   v_mad_i32_i16  v55, v79, v166, v229", 0xd7750037U, 0x07974d4fU, true, true, "" },
2426    { "   v_sub_nc_i32  v55, v79, v166", 0xd7760037U, 0x00034d4fU, true, true, "" },
2427    { "   v_permlane16_b32  v55, v79, v166, v229",
2428        0xd7770037U, 0x07974d4fU, true, true, "" },
2429    { "   v_permlanex16_b32  v55, v79, v166, v229",
2430        0xd7780037U, 0x07974d4fU, true, true, "" },
2431    { "   v_add_nc_i32  v55, v79, v166", 0xd77f0037U, 0x00034d4fU, true, true, "" },
2432    /* VOP3 op_sel */
2433    { "v_interp_p2_f16 v42, v1, attr39.z, s29 op_sel:[1,1,1,1]\n",
2434        0xd75a782aU, 0x007602a7, true, true, "" },
2435    { "v_interp_p2_f16 v42, v1, attr39.z, s29 op_sel:15\n",
2436        0xd75a782aU, 0x007602a7, true, true, "" },
2437    { "v_interp_p2_f16 v42, v1, attr39.z, s29 op_sel:[0,1,1,1]\n",
2438        0xd75a702aU, 0x007602a7, true, true, "" },
2439    { "v_interp_p2_f16 v42, v1, attr39.z, s29 op_sel:14\n",
2440        0xd75a702aU, 0x007602a7, true, true, "" },
2441    { "v_interp_p2_f16 v42, v1, attr39.z, s29 op_sel:[1,0,0,1]\n",
2442        0xd75a482aU, 0x007602a7, true, true, "" },
2443    { "v_interp_p2_f16 v42, v1, attr39.z, s29 op_sel:9\n",
2444        0xd75a482aU, 0x007602a7, true, true, "" },
2445    { "v_alignbit_b32  v55, v79, v166, v229 op_sel:[1,1,0,1]\n",
2446        0xd54e5837U, 0x07974d4fU, true, true, "" },
2447    { "v_alignbit_b32  v55, v79, v166, v229 op_sel:0xb\n",
2448        0xd54e5837U, 0x07974d4fU, true, true, "" },
2449    { "v_alignbit_b32  v55, v79, v166, v229 op_sel:[0,1,1,0]\n",
2450        0xd54e3037U, 0x07974d4fU, true, true, "" },
2451    { "v_alignbit_b32  v55, v79, v166, v229 op_sel:0x6\n",
2452        0xd54e3037U, 0x07974d4fU, true, true, "" },
2453    { "v_min3_f16      v55, v79, v166, v229 op_sel:[1,1,0,1]\n",
2454        0xd7515837U, 0x07974d4fU, true, true, "" },
2455    { "v_cvt_pknorm_i16_f16 v55, v27, v90 op_sel:[1,1,0]\n",
2456        0xd7121837U, 0x0002b51bU, true, true, "" },
2457    { "v_cvt_pknorm_i16_f16 v55, v27, v90 op_sel:[1,1,1]\n",
2458        0xd7125837U, 0x0002b51bU, true, true, "" },
2459    { "v_cvt_pknorm_u16_f16 v55, v27, v90 op_sel:[1,1,0]\n",
2460        0xd7131837U, 0x0002b51bU, true, true, "" },
2461    { "v_cvt_pknorm_u16_f16 v55, v27, v90 op_sel:[1,1,1]\n",
2462        0xd7135837U, 0x0002b51bU, true, true, "" },
2463    { "v_cvt_pknorm_u16_f16 v55, v27, v90 op_sel:7\n",
2464        0xd7135837U, 0x0002b51bU, true, true, "" },
2465    { "v_add_nc_i16     v55, v27, v90 op_sel:[1,1,0]\n",
2466        0xd70d1837U, 0x0002b51bU, true, true, "" },
2467    { "v_sub_nc_i16     v55, v27, v90 op_sel:[1,1,0]\n",
2468        0xd70e1837U, 0x0002b51bU, true, true, "" },
2469    { "v_pack_b32_f16  v55, v27, v90 op_sel:[1,1,0]\n",
2470        0xd7111837U, 0x0002b51bU, true, true, "" },
2471    /* VOP3P encoding */
2472    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel_hi:[0,0,0]\n",
2473        0xcc000037U, 0x07974d4fU, true, true, "" },
2474    { "v_pk_mad_i16    v55, v79, v166, v229\n",
2475        0xcc004037U, 0x1f974d4fU, true, true, "" },
2476    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel_hi:[1,0,0]\n",
2477        0xcc000037U, 0x0f974d4fU, true, true, "" },
2478    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel_hi:[0,1,0]\n",
2479        0xcc000037U, 0x17974d4fU, true, true, "" },
2480    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel_hi:[0,1,1]\n",
2481        0xcc004037U, 0x17974d4fU, true, true, "" },
2482    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel_hi:6\n",
2483        0xcc004037U, 0x17974d4fU, true, true, "" },
2484    { "v_pk_add_i16    v55, v79, v166 op_sel_hi:[0,1]\n",
2485        0xcc020037U, 0x10034d4fU, true, true, "" },
2486    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel:[1,0,0] op_sel_hi:[0,0,0]\n",
2487        0xcc000837U, 0x07974d4fU, true, true, "" },
2488    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel:[1,0,0] op_sel_hi:[1,0,1]\n",
2489        0xcc004837U, 0x0f974d4fU, true, true, "" },
2490    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel:[1,0,0]\n",
2491        0xcc004837U, 0x1f974d4fU, true, true, "" },
2492    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel:[0,1,0] op_sel_hi:[0,0,0]\n",
2493        0xcc001037U, 0x07974d4fU, true, true, "" },
2494    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel:[0,0,1] op_sel_hi:[0,0,0]\n",
2495        0xcc002037U, 0x07974d4fU, true, true, "" },
2496    { "v_pk_mad_i16    v55, v79, v166, v229 op_sel:4 op_sel_hi:[0,0,0]\n",
2497        0xcc002037U, 0x07974d4fU, true, true, "" },
2498    { "v_pk_add_i16    v55, v79, v166 op_sel:[1,1] op_sel_hi:[0,1]\n",
2499        0xcc021837U, 0x10034d4fU, true, true, "" },
2500    { "v_pk_mad_i16    v55, v79, v166, v229 neg_hi:[1,0,0]\n",
2501        0xcc004137U, 0x1f974d4fU, true, true, "" },
2502    { "v_pk_mad_i16    v55, v79, v166, v229 neg_hi:[0,1,0]\n",
2503        0xcc004237U, 0x1f974d4fU, true, true, "" },
2504    { "v_pk_mad_i16    v55, v79, v166, v229 neg_hi:[1,1,0]\n",
2505        0xcc004337U, 0x1f974d4fU, true, true, "" },
2506    { "v_pk_mad_i16    v55, v79, v166, v229 neg_hi:[0,0,1]\n",
2507        0xcc004437U, 0x1f974d4fU, true, true, "" },
2508    { "v_pk_mad_i16    v55, v79, v166, v229 neg_hi:[1,0,1]\n",
2509        0xcc004537U, 0x1f974d4fU, true, true, "" },
2510    { "v_pk_mad_i16    v55, v79, v166, v229 neg_hi:5\n",
2511        0xcc004537U, 0x1f974d4fU, true, true, "" },
2512    { "v_pk_mad_i16    v55, v79, v166, v229 neg_hi:[0,1,1]\n",
2513        0xcc004637U, 0x1f974d4fU, true, true, "" },
2514    { "v_pk_mad_i16    v55, v79, v166, v229 neg_hi:[1,1,1]\n",
2515        0xcc004737U, 0x1f974d4fU, true, true, "" },
2516    { "v_pk_add_i16    v55, v79, v166 neg_hi:[1,1]\n",
2517        0xcc024337U, 0x18034d4fU, true, true, "" },
2518    { "v_pk_mad_i16    v55, v79, v166, v229 neg_lo:[1,0,0]\n",
2519        0xcc004037U, 0x3f974d4fU, true, true, "" },
2520    { "v_pk_mad_i16    v55, v79, v166, v229 neg_lo:[0,1,0]\n",
2521        0xcc004037U, 0x5f974d4fU, true, true, "" },
2522    { "v_pk_mad_i16    v55, v79, v166, v229 neg_lo:[1,1,0]\n",
2523        0xcc004037U, 0x7f974d4fU, true, true, "" },
2524    { "v_pk_mad_i16    v55, v79, v166, v229 neg_lo:3\n",
2525        0xcc004037U, 0x7f974d4fU, true, true, "" },
2526    { "v_pk_mad_i16    v55, -v79, -v166, v229\n",
2527        0xcc004037U, 0x7f974d4fU, true, true, "" },
2528    { "v_pk_mad_i16    v55, v79, v166, v229 neg_lo:[0,0,1]\n",
2529        0xcc004037U, 0x9f974d4fU, true, true, "" },
2530    { "v_pk_mad_i16    v55, v79, v166, v229 neg_lo:[1,0,1]\n",
2531        0xcc004037U, 0xbf974d4fU, true, true, "" },
2532    { "v_pk_mad_i16    v55, v79, v166, v229 neg_lo:[0,1,1]\n",
2533        0xcc004037U, 0xdf974d4fU, true, true, "" },
2534    { "v_pk_mad_i16    v55, v79, v166, v229 neg_lo:[1,1,1]\n",
2535        0xcc004037U, 0xff974d4fU, true, true, "" },
2536    { "v_pk_add_i16    v55, v79, v166 neg_lo:[1,1]\n",
2537        0xcc024037U, 0x78034d4fU, true, true, "" },
2538    { "v_pk_mad_i16    v55, v79, v166, v229 neg_lo:[1,1,0] neg_hi:[1,0,1]\n",
2539        0xcc004537U, 0x7f974d4fU, true, true, "" },
2540    { "v_pk_mad_i16    v55, -v79, -v166, v229 clamp\n",
2541        0xcc00c037U, 0x7f974d4fU, true, true, "" },
2542    /* VOP3P errors */
2543    { "v_pk_mad_i16    v55, -v79, -v166, v229 clamp mul:2\n", 0, 0, true, false,
2544        "test.s:1:46: Error: Unknown VOP modifier\n"
2545        "test.s:1:49: Error: Some garbages at VOP modifier place\n" },
2546    { "v_pk_mad_i16    v55, -v79, -v166, v229 clamp sext:2\n", 0, 0, true, false,
2547        "test.s:1:46: Error: Unknown VOP modifier\n"
2548        "test.s:1:50: Error: Some garbages at VOP modifier place\n" },
2549    { "v_pk_mad_i16    v55, -v79, -v166, v229 clamp abs:2\n", 0, 0, true, false,
2550        "test.s:1:46: Error: Unknown VOP modifier\n"
2551        "test.s:1:49: Error: Some garbages at VOP modifier place\n" },
2552    { "v_pk_mad_i16    v55, -v79, -abs(v166), v229 clamp\n", 0, 0, true, false,
2553        "test.s:1:32: Error: Expected operator\n"
2554        "test.s:1:33: Error: Expected ',' before argument\n" },
2555    { "v_pk_mad_i16    v55, -v79, sext(v166), v229 clamp\n", 0, 0, true, false,
2556        "test.s:1:32: Error: Expected operator\n"
2557        "test.s:1:33: Error: Expected ',' before argument\n" },
2558    /* VOP3P instructions */
2559    { "v_pk_mul_lo_u16 v55, v79, v166\n", 0xcc014037U, 0x18034d4fU, true, true, "" },
2560    { "v_pk_add_i16    v55, v79, v166\n", 0xcc024037U, 0x18034d4fU, true, true, "" },
2561    { "v_pk_sub_i16    v55, v79, v166\n", 0xcc034037U, 0x18034d4fU, true, true, "" },
2562    { "v_pk_lshlrev_b16 v55, v79, v166\n", 0xcc044037U, 0x18034d4fU, true, true, "" },
2563    { "v_pk_lshrrev_b16 v55, v79, v166\n", 0xcc054037U, 0x18034d4fU, true, true, "" },
2564    { "v_pk_ashrrev_i16 v55, v79, v166\n", 0xcc064037U, 0x18034d4fU, true, true, "" },
2565    { "v_pk_max_i16    v55, v79, v166\n", 0xcc074037U, 0x18034d4fU, true, true, "" },
2566    { "v_pk_min_i16    v55, v79, v166\n", 0xcc084037U, 0x18034d4fU, true, true, "" },
2567    { "v_pk_mad_u16    v55, v79, v166, v229\n", 0xcc094037U, 0x1f974d4fU, true, true, "" },
2568    { "v_pk_add_u16    v55, v79, v166\n", 0xcc0a4037U, 0x18034d4fU, true, true, "" },
2569    { "v_pk_sub_u16    v55, v79, v166\n", 0xcc0b4037U, 0x18034d4fU, true, true, "" },
2570    { "v_pk_max_u16    v55, v79, v166\n", 0xcc0c4037U, 0x18034d4fU, true, true, "" },
2571    { "v_pk_min_u16    v55, v79, v166\n", 0xcc0d4037U, 0x18034d4fU, true, true, "" },
2572    { "v_pk_fma_f16    v55, v79, v166, v229\n", 0xcc0e4037U, 0x1f974d4fU, true, true, "" },
2573    { "v_pk_add_f16    v55, v79, v166\n", 0xcc0f4037U, 0x18034d4fU, true, true, "" },
2574    { "v_pk_mul_f16    v55, v79, v166\n", 0xcc104037U, 0x18034d4fU, true, true, "" },
2575    { "v_pk_min_f16    v55, v79, v166\n", 0xcc114037U, 0x18034d4fU, true, true, "" },
2576    { "v_pk_max_f16    v55, v79, v166\n", 0xcc124037U, 0x18034d4fU, true, true, "" },
2577    { "v_fma_mix_f32   v55, v79, v166, v229\n", 0xcc204037U, 0x1f974d4fU, true, true, "" },
2578    { "v_fma_mixlo_f16 v55, v79, v166, v229\n", 0xcc214037U, 0x1f974d4fU, true, true, "" },
2579    { "v_fma_mixhi_f16 v55, v79, v166, v229\n", 0xcc224037U, 0x1f974d4fU, true, true, "" },
2580    { "v_mad_mix_f32   v55, v79, v166, v229\n", 0, 0, false, false,
2581        "test.s:1:1: Error: Unknown instruction\n" },
2582    { "v_mad_mixlo_f16 v55, v79, v166, v229\n", 0, 0, false, false,
2583        "test.s:1:1: Error: Unknown instruction\n" },
2584    { "v_mad_mixhi_f16 v55, v79, v166, v229\n", 0, 0, false, false,
2585        "test.s:1:1: Error: Unknown instruction\n" },
2586    /* VINTRP encoding */
2587    { "   v_interp_p1_f32 v93, v211, attr26.w", 0xc9746bd3U, 0, false, true, "" },
2588    { "   v_interp_p1_f32_e32 v93, v211, attr26.w", 0xc9746bd3U, 0, false, true, "" },
2589    { "   v_interp_p1_f32 v93, v211, attr26 . w", 0xc9746bd3U, 0, false, true, "" },
2590    { "   v_interp_p1_f32 v93, v211, aTTR26 . W", 0xc9746bd3U, 0, false, true, "" },
2591    { "   v_interp_p1_f32 v93, v211, aTTR00026 . W", 0xc9746bd3U, 0, false, true, "" },
2592    { "   v_interp_p1_f32 v93, v211, attr26.x", 0xc97468d3U, 0, false, true, "" },
2593    { "   v_interp_p1_f32 v93, v211, attr26.y", 0xc97469d3U, 0, false, true, "" },
2594    { "   v_interp_p1_f32 v93, v211, attr26.z", 0xc9746ad3U, 0, false, true, "" },
2595    { "   v_interp_p1_f32 v93, v211, attr63.z", 0xc974fed3U, 0, false, true, "" },
2596    { "   v_interp_p1_f32 v93  , v211  , attr63.z", 0xc974fed3U, 0, false, true, "" },
2597    { "   v_interp_p2_f32 v93, v211, attr26.w", 0xc9756bd3U, 0, false, true, "" },
2598    { "   v_interp_mov_f32 v93, p10, attr26.w", 0xc9766b00U, 0, false, true, "" },
2599    { "   v_interp_mov_f32 v93, p20, attr26.w", 0xc9766b01U, 0, false, true, "" },
2600    { "   v_interp_mov_f32 v93, p0, attr26.w", 0xc9766b02U, 0, false, true, "" },
2601    /* VINTRP errors */
2602    { "   v_interp_p1_f32 v[93:94], v211, attr26.w", 0, 0, false, false,
2603        "test.s:1:20: Error: Required 1 vector register\n" },
2604    { "   v_interp_p1_f32 v93, v211, at26.w", 0, 0, false, false,
2605        "test.s:1:31: Error: Expected 'attr' keyword\n" },
2606    { "   v_interp_p1_f32 v93, v211, ", 0, 0, false, false,
2607        "test.s:1:31: Error: Expected 'attr' keyword\n" },
2608    { "   v_interp_p1_f32 v93, v211, attr22111.x", 0, 0, false, false,
2609        "test.s:1:38: Error: Number is too big\n" },
2610    { "   v_interp_p1_f32 v93, v211, attr64.w", 0, 0, false, false,
2611        "test.s:1:35: Error: Attribute number out of range (0-63)\n" },
2612    { "   v_interp_p1_f32 v93, v211, attr26", 0, 0, false, false,
2613        "test.s:1:37: Error: Expected '.' after attribute number\n" },
2614    { "   v_interp_p1_f32 v93, v211, attr26,", 0, 0, false, false,
2615        "test.s:1:37: Error: Expected '.' after attribute number\n" },
2616    { "   v_interp_p1_f32 v93, v211, attr26.t", 0, 0, false, false,
2617        "test.s:1:38: Error: Expected attribute component\n" },
2618    { "   v_interp_p1_f32 v93, v211, attr26.", 0, 0, false, false,
2619        "test.s:1:38: Error: Expected attribute component\n" },
2620    { "   v_interp_mov_f32 v93, xx, attr26.w", 0, 0, false, false,
2621        "test.s:1:26: Error: Unknown VINTRP parameter\n" },
2622    { "   v_interp_mov_f32 v93, xxffff, attr26.w", 0, 0, false, false,
2623        "test.s:1:32: Error: VINTRP parameter is too long\n" },
2624    /* DS encoding */
2625    { "   ds_add_u32  v71, v169 offset:52583", 0xd800cd67U, 0x0000a947U, true, true, "" },
2626    { "   ds_add_u32  v71, v169 offset:52583 gds:0",
2627            0xd800cd67U, 0x0000a947U, true, true, "" },
2628    { "   ds_add_u32  v71, v169 gds", 0xd8020000U, 0x0000a947U, true, true, "" },
2629    { "   ds_add_u32  v71, v169 gds:1", 0xd8020000U, 0x0000a947U, true, true, "" },
2630    { "   ds_add_u32  v71, v169   ", 0xd8000000U, 0x0000a947U, true, true, "" },
2631    { "   ds_add_u32_e64  v71, v169   ", 0xd8000000U, 0x0000a947U, true, true, "" },
2632    { "   ds_add_u32  v71, v169 offset :  52583",
2633        0xd800cd67U, 0x0000a947U, true, true, "" },
2634    { "   ds_add_u32  v71, v169", 0xd8000000U, 0x0000a947U, true, true, "" },
2635    { "dct=771; ds_add_u32  v71, v169 offset:dct+2",
2636        0xd8000305U, 0x0000a947U, true, true, "" },
2637    { "ds_add_u32  v71, v169 offset:dct+2; dct=771",
2638        0xd8000305U, 0x0000a947U, true, true, "" },
2639    { "   ds_consume  v155 offset:52583", 0xd8f4cd67U, 0x9b000000U, true, true, "" },
2640    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87] offset0:1+aa "
2641        "gds offset1:bb+1;aa=32; bb=74", 0xd9be4b21U, 0x8b56a947U, true, true, "" },
2642    /* DS warnings */
2643    { "   ds_add_u32  v71, v169 offset:52 offset:42",
2644        0xd800002aU, 0x0000a947U, true, true,
2645        "test.s:1:36: Warning: Offset is already defined\n" },
2646    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87] "
2647        "offset0:103 offset1:205 offset1:51 offset0:6",
2648        0xd9bc3306U, 0x8b56a947U, true, true,
2649        "test.s:1:89: Warning: Offset1 is already defined\n"
2650        "test.s:1:100: Warning: Offset0 is already defined\n" },
2651    /* DS errors */
2652    { "   ds_add_u32  v71, v169 xdff:5444", 0, 0, false, false,
2653        "test.s:1:26: Error: Expected 'offset'\n"
2654        "test.s:1:30: Error: Some garbages at DS modifier place\n" },
2655    /* DS instructions */
2656    { "   ds_sub_u32  v71, v169 offset:52583", 0xd804cd67U, 0x0000a947U, true, true, "" },
2657    { "   ds_rsub_u32 v71, v169 offset:52583", 0xd808cd67U, 0x0000a947U, true, true, "" },
2658    { "   ds_inc_u32  v71, v169 offset:52583", 0xd80ccd67U, 0x0000a947U, true, true, "" },
2659    { "   ds_dec_u32  v71, v169 offset:52583", 0xd810cd67U, 0x0000a947U, true, true, "" },
2660    { "   ds_min_i32  v71, v169 offset:52583", 0xd814cd67U, 0x0000a947U, true, true, "" },
2661    { "   ds_max_i32  v71, v169 offset:52583", 0xd818cd67U, 0x0000a947U, true, true, "" },
2662    { "   ds_min_u32  v71, v169 offset:52583", 0xd81ccd67U, 0x0000a947U, true, true, "" },
2663    { "   ds_max_u32  v71, v169 offset:52583", 0xd820cd67U, 0x0000a947U, true, true, "" },
2664    { "   ds_and_b32  v71, v169 offset:52583", 0xd824cd67U, 0x0000a947U, true, true, "" },
2665    { "   ds_or_b32  v71, v169 offset:52583", 0xd828cd67U, 0x0000a947U, true, true, "" },
2666    { "   ds_xor_b32  v71, v169 offset:52583", 0xd82ccd67U, 0x0000a947U, true, true, "" },
2667    { "   ds_mskor_b32  v71, v169, v39 offset:52583",
2668        0xd830cd67U, 0x0027a947U, true, true, "" },
2669    { "   ds_write_b32 v71, v169 offset:52583", 0xd834cd67U, 0x0000a947U, true, true, "" },
2670    { "   ds_write2_b32  v71, v169, v39 offset0:103 offset1:205",
2671        0xd838cd67U, 0x0027a947U, true, true, "" },
2672    { "   ds_write2st64_b32 v71, v169, v39 offset0:103 offset1:205",
2673        0xd83ccd67U, 0x0027a947U, true, true, "" },
2674    { "   ds_cmpst_b32  v71, v169, v39 offset:52583",
2675        0xd840cd67U, 0x0027a947U, true, true, "" },
2676    { "   ds_cmpst_f32  v71, v169, v39 offset:52583",
2677        0xd844cd67U, 0x0027a947U, true, true, "" },
2678    { "   ds_min_f32  v71, v169 offset:52583", 0xd848cd67U, 0x0000a947U, true, true, "" },
2679    { "   ds_max_f32  v71, v169 offset:52583", 0xd84ccd67U, 0x0000a947U, true, true, "" },
2680    { "   ds_nop  v71 offset:52583", 0xd850cd67U, 0x00000047U, true, true, "" },
2681    { "   ds_add_f32  v71, v169 offset:52583", 0xd854cd67U, 0x0000a947U, true, true, "" },
2682    { "    ds_gws_sema_release_all v71 gds offset:52583",
2683        0xd862cd67U, 0x00000047U, true, true, "" },
2684    { "   ds_gws_init  v71 offset:52583 gds", 0xd866cd67U, 0x00000047U, true, true, "" },
2685    { "   ds_gws_sema_v v71 offset:52583 gds", 0xd86acd67U, 0x00000047U, true, true, "" },
2686    { "   ds_gws_sema_br v71 offset:52583 gds", 0xd86ecd67U, 0x00000047U, true, true, "" },
2687    { "   ds_gws_sema_p v71 offset:52583 gds", 0xd872cd67U, 0x00000047U, true, true, "" },
2688    { "   ds_gws_barrier v71 offset:52583 gds", 0xd876cd67U, 0x00000047U, true, true, "" },
2689    { "   ds_write_b8  v71, v169 offset:52583", 0xd878cd67U, 0x0000a947U, true, true, "" },
2690    { "   ds_write_b16  v71, v169 offset:52583", 0xd87ccd67U, 0x0000a947U, true, true, "" },
2691    { "   ds_add_rtn_u32  v155, v71, v169 offset:52583",
2692        0xd880cd67U, 0x9b00a947U, true,  true, "" },
2693    { "   ds_sub_rtn_u32  v155, v71, v169 offset:52583",
2694        0xd884cd67U, 0x9b00a947U, true,  true, "" },
2695    { "   ds_rsub_rtn_u32  v155, v71, v169 offset:52583",
2696        0xd888cd67U, 0x9b00a947U, true,  true, "" },
2697    { "   ds_rsub_rtn_u32  v155, v71, v169 offset:52583",
2698        0xd888cd67U, 0x9b00a947U, true, true, "" },
2699    { "   ds_inc_rtn_u32  v155, v71, v169 offset:52583",
2700        0xd88ccd67U, 0x9b00a947U, true, true, "" },
2701    { "   ds_dec_rtn_u32  v155, v71, v169 offset:52583",
2702        0xd890cd67U, 0x9b00a947U, true, true, "" },
2703    { "   ds_min_rtn_i32  v155, v71, v169 offset:52583",
2704        0xd894cd67U, 0x9b00a947U, true, true, "" },
2705    { "   ds_max_rtn_i32  v155, v71, v169 offset:52583",
2706        0xd898cd67U, 0x9b00a947U, true, true, "" },
2707    { "   ds_min_rtn_u32  v155, v71, v169 offset:52583",
2708        0xd89ccd67U, 0x9b00a947U, true, true, "" },
2709    { "   ds_max_rtn_u32  v155, v71, v169 offset:52583",
2710        0xd8a0cd67U, 0x9b00a947U, true, true, "" },
2711    { "   ds_and_rtn_b32  v155, v71, v169 offset:52583",
2712        0xd8a4cd67U, 0x9b00a947U, true, true, "" },
2713    { "   ds_or_rtn_b32  v155, v71, v169 offset:52583",
2714        0xd8a8cd67U, 0x9b00a947U, true, true, "" },
2715    { "   ds_xor_rtn_b32  v155, v71, v169 offset:52583",
2716        0xd8accd67U, 0x9b00a947U, true, true, "" },
2717    { "   ds_mskor_rtn_b32 v155, v71, v169, v26 offset:52583",
2718        0xd8b0cd67U, 0x9b1aa947U, true, true, "" },
2719    { "   ds_wrxchg_rtn_b32  v155, v71, v169 offset:52583",
2720        0xd8b4cd67U, 0x9b00a947U, true, true, "" },
2721    { "   ds_wrxchg2_rtn_b32 v[155:156], v71, v169, v26 offset0:103 offset1:205",
2722        0xd8b8cd67U, 0x9b1aa947U, true, true, "" },
2723    { "   ds_wrxchg2st64_rtn_b32  v[155:156], v71, v169, v26 offset0:103 offset1:205",
2724        0xd8bccd67U, 0x9b1aa947U, true, true, "" },
2725    { "   ds_cmpst_rtn_b32  v155, v71, v169, v26 offset:52583",
2726        0xd8c0cd67U, 0x9b1aa947U, true, true, "" },
2727    { "   ds_cmpst_rtn_f32  v155, v71, v169, v26 offset:52583",
2728        0xd8c4cd67U, 0x9b1aa947U, true, true, "" },
2729    { "   ds_min_rtn_f32  v155, v71, v169 offset:52583",
2730        0xd8c8cd67U, 0x9b00a947U, true, true, "" },
2731    { "   ds_max_rtn_f32  v155, v71, v169 offset:52583",
2732        0xd8cccd67U, 0x9b00a947U, true, true, "" },
2733    { "   ds_wrap_rtn_b32  v155, v71, v169, v86 offset:52583",
2734        0xd8d0cd67U, 0x9b56a947U, true, true, "" },
2735    { "   ds_swizzle_b32  v155, v71 offset:52583",
2736        0xd8d4cd67U, 0x9b000047U, true, true, "" },
2737    { "   ds_read_b32 v155, v71 offset:52583", 0xd8d8cd67U, 0x9b000047U, true, true, "" },
2738    { "   ds_read2_b32 v[155:156], v71 offset0:103 offset1:205",
2739        0xd8dccd67U, 0x9b000047U, true, true, "" },
2740    { "   ds_read2st64_b32 v[155:156], v71 offset0:103 offset1:205",
2741        0xd8e0cd67U, 0x9b000047U, true, true, "" },
2742    { "   ds_read_i8  v155, v71 offset:52583", 0xd8e4cd67U, 0x9b000047U, true, true, "" },
2743    { "   ds_read_u8  v155, v71 offset:52583", 0xd8e8cd67U, 0x9b000047U, true, true, "" },
2744    { "   ds_read_i16  v155, v71 offset:52583", 0xd8eccd67U, 0x9b000047U, true, true, "" },
2745    { "   ds_read_u16  v155, v71 offset:52583", 0xd8f0cd67U, 0x9b000047U, true, true, "" },
2746    { "   ds_consume  v155 offset:52583", 0xd8f4cd67U, 0x9b000000U, true, true, "" },
2747    { "   ds_append  v155 offset:52583", 0xd8f8cd67U, 0x9b000000U, true, true, "" },
2748    { "   ds_ordered_count v155, v71 offset:52583",
2749        0xd8fccd67U, 0x9b000047U, true, true, "" },
2750    { "   ds_add_u64  v71, v[169:170] offset:52583",
2751        0xd900cd67U, 0x0000a947U, true, true, "" },
2752    { "   ds_sub_u64  v71, v[169:170] offset:52583",
2753        0xd904cd67U, 0x0000a947U, true, true, "" },
2754    { "   ds_rsub_u64  v71, v[169:170] offset:52583",
2755        0xd908cd67U, 0x0000a947U, true, true, "" },
2756    { "   ds_inc_u64  v71, v[169:170] offset:52583",
2757        0xd90ccd67U, 0x0000a947U, true, true, "" },
2758    { "   ds_dec_u64  v71, v[169:170] offset:52583",
2759        0xd910cd67U, 0x0000a947U, true, true, "" },
2760    { "   ds_min_i64  v71, v[169:170] offset:52583",
2761        0xd914cd67U, 0x0000a947U, true, true, "" },
2762    { "   ds_max_i64  v71, v[169:170] offset:52583",
2763        0xd918cd67U, 0x0000a947U, true, true, "" },
2764    { "   ds_min_u64  v71, v[169:170] offset:52583",
2765        0xd91ccd67U, 0x0000a947U, true, true, "" },
2766    { "   ds_max_u64  v71, v[169:170] offset:52583",
2767        0xd920cd67U, 0x0000a947U, true, true, "" },
2768    { "   ds_and_b64  v71, v[169:170] offset:52583",
2769        0xd924cd67U, 0x0000a947U, true, true, "" },
2770    { "   ds_or_b64  v71, v[169:170] offset:52583",
2771        0xd928cd67U, 0x0000a947U, true, true, "" },
2772    { "   ds_xor_b64  v71, v[169:170] offset:52583",
2773        0xd92ccd67U, 0x0000a947U, true, true, "" },
2774    { "   ds_mskor_b64  v71, v[169:170], v[23:24] offset:52583",
2775        0xd930cd67U, 0x0017a947U, true, true, "" },
2776    { "   ds_write_b64  v71, v[169:170] offset:52583",
2777        0xd934cd67U, 0x0000a947U, true, true, "" },
2778    { "   ds_write2_b64  v71, v[169:170], v[39:40] offset0:103 offset1:205",
2779        0xd938cd67U, 0x0027a947U, true, true, "" },
2780    { "   ds_write2st64_b64 v71, v[169:170], v[39:40] offset0:103 offset1:205",
2781        0xd93ccd67U, 0x0027a947U, true, true, "" },
2782    { "   ds_cmpst_b64  v71, v[169:170], v[39:40] offset:52583",
2783        0xd940cd67U, 0x0027a947U, true, true, "" },
2784    { "   ds_cmpst_f64  v71, v[169:170], v[39:40] offset:52583",
2785        0xd944cd67U, 0x0027a947U, true, true, "" },
2786    { "   ds_min_f64  v71, v[169:170] offset:52583",
2787        0xd948cd67U, 0x0000a947U, true, true, "" },
2788    { "   ds_max_f64  v71, v[169:170] offset:52583",
2789        0xd94ccd67U, 0x0000a947U, true, true, "" },
2790    { "   ds_add_rtn_f32  v155, v71, v169 offset:52583",
2791        0xd954cd67U, 0x9b00a947U, true, true, "" },
2792    { "   ds_add_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2793        0xd980cd67U, 0x8b00a947U, true, true, "" },
2794    { "   ds_sub_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2795        0xd984cd67U, 0x8b00a947U, true, true, "" },
2796    { "   ds_rsub_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2797        0xd988cd67U, 0x8b00a947U, true, true, "" },
2798    { "   ds_inc_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2799        0xd98ccd67U, 0x8b00a947U, true, true, "" },
2800    { "   ds_dec_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2801        0xd990cd67U, 0x8b00a947U, true, true, "" },
2802    { "   ds_min_rtn_i64  v[139:140], v71, v[169:170] offset:52583",
2803        0xd994cd67U, 0x8b00a947U, true, true, "" },
2804    { "   ds_max_rtn_i64  v[139:140], v71, v[169:170] offset:52583",
2805        0xd998cd67U, 0x8b00a947U, true, true, "" },
2806    { "   ds_min_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2807        0xd99ccd67U, 0x8b00a947U, true, true, "" },
2808    { "   ds_max_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2809        0xd9a0cd67U, 0x8b00a947U, true, true, "" },
2810    { "   ds_and_rtn_b64  v[139:140], v71, v[169:170] offset:52583",
2811        0xd9a4cd67U, 0x8b00a947U, true, true, "" },
2812    { "   ds_or_rtn_b64  v[139:140], v71, v[169:170] offset:52583",
2813        0xd9a8cd67U, 0x8b00a947U, true, true, "" },
2814    { "   ds_xor_rtn_b64  v[139:140], v71, v[169:170] offset:52583",
2815        0xd9accd67U, 0x8b00a947U, true, true, "" },
2816    { "   ds_mskor_rtn_b64 v[139:140], v71, v[169:170], v[86:87] offset:52583",
2817        0xd9b0cd67U, 0x8b56a947U, true, true, "" },
2818    { "   ds_wrxchg_rtn_b64  v[139:140], v71, v[169:170] offset:52583",
2819        0xd9b4cd67U, 0x8b00a947U, true, true, "" },
2820    { "   ds_wrxchg2_rtn_b64 v[139:142], v71, v[169:170], v[86:87] "
2821        "offset0:103 offset1:205", 0xd9b8cd67U, 0x8b56a947U, true, true, "" },
2822    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87] "
2823        "offset0:103 offset1:205", 0xd9bccd67U, 0x8b56a947U, true, true, "" },
2824    { "   ds_cmpst_rtn_b64 v[139:140], v71, v[169:170], v[86:87] offset:52583",
2825        0xd9c0cd67U, 0x8b56a947U, true, true, "" },
2826    { "   ds_cmpst_rtn_f64 v[139:140], v71, v[169:170], v[86:87] offset:52583",
2827        0xd9c4cd67U, 0x8b56a947U, true, true, "" },
2828    { "   ds_min_rtn_f64 v[139:140], v71, v[169:170] offset:52583",
2829        0xd9c8cd67U, 0x8b00a947U, true, true, "" },
2830    { "   ds_max_rtn_f64 v[139:140], v71, v[169:170] offset:52583",
2831        0xd9cccd67U, 0x8b00a947U, true, true, "" },
2832    { "   ds_read_b64  v[139:140], v71 offset:52583",
2833        0xd9d8cd67U, 0x8b000047U, true, true, "" },
2834    { "   ds_read2_b64  v[139:142], v71 offset0:103 offset1:205",
2835        0xd9dccd67U, 0x8b000047U, true, true, "" },
2836    { "   ds_read2st64_b64 v[139:142], v71 offset0:103 offset1:205",
2837        0xd9e0cd67U, 0x8b000047U, true, true, "" },
2838    { "   ds_condxchg32_rtn_b64 v[155:156], v71, v[169:170] offset:52583",
2839        0xd9f8cd67U, 0x9b00a947U, true, true, "" },
2840    { "   ds_add_src2_u32 v71 offset:52583", 0xda00cd67U, 0x00000047U, true, true, "" },
2841    { "   ds_sub_src2_u32 v71 offset:52583", 0xda04cd67U, 0x00000047U, true, true, "" },
2842    { "   ds_rsub_src2_u32 v71 offset:52583", 0xda08cd67U, 0x00000047U, true, true, "" },
2843    { "   ds_inc_src2_u32 v71 offset:52583", 0xda0ccd67U, 0x00000047U, true, true, "" },
2844    { "   ds_dec_src2_u32 v71 offset:52583", 0xda10cd67U, 0x00000047U, true, true, "" },
2845    { "   ds_min_src2_i32 v71 offset:52583", 0xda14cd67U, 0x00000047U, true, true, "" },
2846    { "   ds_max_src2_i32 v71 offset:52583", 0xda18cd67U, 0x00000047U, true, true, "" },
2847    { "   ds_min_src2_u32 v71 offset:52583", 0xda1ccd67U, 0x00000047U, true, true, "" },
2848    { "   ds_max_src2_u32 v71 offset:52583", 0xda20cd67U, 0x00000047U, true, true, "" },
2849    { "   ds_and_src2_b32 v71 offset:52583", 0xda24cd67U, 0x00000047U, true, true, "" },
2850    { "   ds_or_src2_b32 v71 offset:52583", 0xda28cd67U, 0x00000047U, true, true, "" },
2851    { "   ds_xor_src2_b32 v71 offset:52583", 0xda2ccd67U, 0x00000047U, true, true, "" },
2852    { "   ds_write_src2_b32 v71 offset:52583", 0xda34cd67U, 0x00000047U, true, true, "" },
2853    { "   ds_min_src2_f32 v71 offset:52583", 0xda48cd67U, 0x00000047U, true, true, "" },
2854    { "   ds_max_src2_f32 v71 offset:52583", 0xda4ccd67U, 0x00000047U, true, true, "" },
2855    { "   ds_add_src2_f32 v71 offset:52583", 0xda54cd67U, 0x00000047U, true, true, "" },
2856    { "ds_write_b8_d16_hi v71, v169 offset:52583\n",
2857        0xda80cd67U, 0x0000a947U, true, true, "" },
2858    { "ds_write_b16_d16_hi v71, v169 offset:52583\n",
2859        0xda84cd67U, 0x0000a947U, true, true, "" },
2860    { "ds_read_u8_d16  v139, v71 offset:52583\n",
2861        0xda88cd67U, 0x8b000047U, true, true, "" },
2862    { "ds_read_u8_d16_hi v139, v71 offset:52583\n",
2863        0xda8ccd67U, 0x8b000047U, true, true, "" },
2864    { "ds_read_i8_d16  v139, v71 offset:52583\n",
2865        0xda90cd67U, 0x8b000047U, true, true, "" },
2866    { "ds_read_i8_d16_hi v139, v71 offset:52583\n",
2867        0xda94cd67U, 0x8b000047U, true, true, "" },
2868    { "ds_read_u16_d16 v139, v71 offset:52583\n",
2869        0xda98cd67U, 0x8b000047U, true, true, "" },
2870    { "ds_read_u16_d16_hi v139, v71 offset:52583\n",
2871        0xda9ccd67U, 0x8b000047U, true, true, "" },
2872    { "ds_write_addtid_b32 v71 offset:52583\n", 0xdac0cd67U, 0x00004700U, true, true, "" },
2873    { "ds_read_addtid_b32 v139 offset:52583\n", 0xdac4cd67U, 0x8b000000U, true, true, "" },
2874    { "   ds_permute_b32  v155, v71, v169 offset:52583",
2875        0xdac8cd67U, 0x9b00a947U, true, true, "" },
2876    { "   ds_bpermute_b32  v155, v71, v169 offset:52583",
2877        0xdacccd67U, 0x9b00a947U, true, true, "" },
2878    { "   ds_add_src2_u64 v71 offset:52583", 0xdb00cd67U, 0x00000047U, true, true, "" },
2879    { "   ds_sub_src2_u64 v71 offset:52583", 0xdb04cd67U, 0x00000047U, true, true, "" },
2880    { "   ds_rsub_src2_u64 v71 offset:52583", 0xdb08cd67U, 0x00000047U, true, true, "" },
2881    { "   ds_inc_src2_u64 v71 offset:52583", 0xdb0ccd67U, 0x00000047U, true, true, "" },
2882    { "   ds_dec_src2_u64 v71 offset:52583", 0xdb10cd67U, 0x00000047U, true, true, "" },
2883    { "   ds_min_src2_i64 v71 offset:52583", 0xdb14cd67U, 0x00000047U, true, true, "" },
2884    { "   ds_max_src2_i64 v71 offset:52583", 0xdb18cd67U, 0x00000047U, true, true, "" },
2885    { "   ds_min_src2_u64 v71 offset:52583", 0xdb1ccd67U, 0x00000047U, true, true, "" },
2886    { "   ds_max_src2_u64 v71 offset:52583", 0xdb20cd67U, 0x00000047U, true, true, "" },
2887    { "   ds_and_src2_b64 v71 offset:52583", 0xdb24cd67U, 0x00000047U, true, true, "" },
2888    { "   ds_or_src2_b64 v71 offset:52583", 0xdb28cd67U, 0x00000047U, true, true, "" },
2889    { "   ds_xor_src2_b64 v71 offset:52583", 0xdb2ccd67U, 0x00000047U, true, true, "" },
2890    { "   ds_write_src2_b64 v71 offset:52583", 0xdb34cd67U, 0x00000047U, true, true, "" },
2891    { "   ds_min_src2_f64 v71 offset:52583", 0xdb48cd67U, 0x00000047U, true, true, "" },
2892    { "   ds_max_src2_f64 v71 offset:52583", 0xdb4ccd67U, 0x00000047U, true, true, "" },
2893    { "    ds_write_b96  v71, v[169:171] offset:52583",
2894        0xdb78cd67U, 0x0000a947U, true, true, "" },
2895    { "    ds_write_b128  v71, v[169:172] offset:52583",
2896        0xdb7ccd67U, 0x0000a947U, true, true, "" },
2897    { "    ds_condxchg32_rtn_b128  v[155:158] offset:5258