source: CLRX/CLRadeonExtender/trunk/tests/amdasm/GCNAsmOpc11.cpp @ 3091

Last change on this file since 3091 was 3091, checked in by matszpk, 2 years ago

CLRadeonExtender: GCNAsm: Add parametrization to hwregisters and sendmsg.

File size: 204.0 KB
Line 
1/*
2 *  CLRadeonExtender - Unofficial OpenCL Radeon Extensions Library
3 *  Copyright (C) 2014-2017 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 encGCNOpcodeCases[] =
24{
25    { "    s_add_u32  s21, s4, s61", 0x80153d04U, 0, false, true, "" },
26    /* registers and literals */
27    { "    s_add_u32  vcc_lo, s4, s61", 0x806a3d04U, 0, false, true, "" },
28    { "    s_add_u32  vcc_hi, s4, s61", 0x806b3d04U, 0, false, true, "" },
29    { "    s_add_u32  tba_lo, s4, s61", 0x806c3d04U, 0, false, true, "" },
30    { "    s_add_u32  tba_hi, s4, s61", 0x806d3d04U, 0, false, true, "" },
31    { "    s_add_u32  tma_lo, s4, s61", 0x806e3d04U, 0, false, true, "" },
32    { "    s_add_u32  tma_hi, s4, s61", 0x806f3d04U, 0, false, true, "" },
33    { "    s_add_u32  m0, s4, s61", 0x807c3d04U, 0, false, true, "" },
34    { "    s_add_u32  ttmp0, s4, s61", 0x80703d04U, 0, false, true, "" },
35    { "    s_add_u32  ttmp1, s4, s61", 0x80713d04U, 0, false, true, "" },
36    { "    s_add_u32  ttmp[2:2], s4, s61", 0x80723d04U, 0, false, true, "" },
37    { "    s_add_u32  ttmp[2], s4, s61", 0x80723d04U, 0, false, true, "" },
38    { "    s_add_u32  s[21:21], s4, s61", 0x80153d04U, 0, false, true, "" },
39    { "    s_add_u32  s[21], s[4], s[61]", 0x80153d04U, 0, false, true, "" },
40    { "zx=21; ss=2; b=60;s_add_u32  s[zx], s[ss*2], s[b+1]",
41            0x80153d04U, 0, false, true, "" },
42    /* register's symbols */
43    { "zx=%s[20:23]; ss=%s4; b=%s[57:67];s_add_u32  zx[1], ss, b[4]",
44            0x80153d04U, 0, false, true, "" },
45    { "xv=2; zx=%s[xv+18:xv+19]; ss=%s[xv+2]; b=%s[xv+55:xv+65];"
46        "s_add_u32  zx[1], ss, b[4]", 0x80153d04U, 0, false, true, "" },
47    { "zx=%s[20:23]; ss=%execz; b=%s[57:67];s_add_u32  zx[1], ss, b[4]",
48            0x80153dfcU, 0, false, true, "" },
49    { "    s_add_u32  s21, s4, 0", 0x80158004U, 0, false, true, "" },
50    { "lit=3;s_add_u32  s21, s4, lit*5", 0x80158f04U, 0, false, true, "" },
51    { "    s_add_u32  s21, s4, 1", 0x80158104U, 0, false, true, "" },
52    { "    s_add_u32  s21, s4, 0x2a", 0x8015aa04U, 0, false, true, "" },
53    { "    s_add_u32  s21, s4, -7", 0x8015c704U, 0, false, true, "" },
54    { "    s_add_u32  s21, s4, lit(-7)", 0x8015ff04U, 0xfffffff9, true, true, "" },
55    { "    s_add_u32_e64  s21, s4, -7", 0x8015ff04U, 0xfffffff9, true, true, "" },
56    { "    s_add_u32  s21, s4, lit(0)", 0x8015ff04U, 0x0, true, true, "" },
57    { "    s_add_u32  s21, s4, lit(32)", 0x8015ff04U, 0x20, true, true, "" },
58    { "    s_add_u32_e64 s21, s4, 32", 0x8015ff04U, 0x20, true, true, "" },
59    { "    s_add_u32_e64 s21, 32, s4", 0x801504ffU, 0x20, true, true, "" },
60    { "    s_add_u32  s21, s4, lit  (  32  )  ", 0x8015ff04U, 0x20, true, true, "" },
61    { "    s_add_u32  s21, s4, LiT  (  32  )  ", 0x8015ff04U, 0x20, true, true, "" },
62    { "    s_add_u32  s21, s4, lit(0.0)", 0x8015ff04U, 0x0, true, true, "" },
63    { "    s_add_u32  s21, s4, lit(-.5)", 0x8015ff04U, 0xbf000000, true, true, "" },
64    { "    s_add_u32_e64  s21, s4, -.5", 0x8015ff04U, 0xbf000000, true, true, "" },
65    { "    s_add_u32  s21, s4, lit(2.0)", 0x8015ff04U, 0x40000000, true, true, "" },
66    { "    s_add_u32  s21, s4, lit  ( 2.0 )", 0x8015ff04U, 0x40000000, true, true, "" },
67    { "    s_add_u32_e64  s21, s4, 2.0", 0x8015ff04U, 0x40000000, true, true, "" },
68    { "    s_add_u32  s21, scc, s61", 0x80153dfdU, 0, false, true, "" },
69    { "    s_add_u32  s21, src_scc, s61", 0x80153dfdU, 0, false, true, "" },
70    { "    s_add_u32  s21, execz, s61", 0x80153dfcU, 0, false, true, "" },
71    { "    s_add_u32  s21, src_execz, s61", 0x80153dfcU, 0, false, true, "" },
72    { "    s_add_u32  s21, vccz, s61", 0x80153dfbU, 0, false, true, "" },
73    { "    s_add_u32  s21, src_vccz, s61", 0x80153dfbU, 0, false, true, "" },
74    { "t=0x2b;    s_add_u32  s21, s4, t", 0x8015ab04U, 0, false, true, "" },
75    { "s0=0x2b;    s_add_u32  s21, s4, @s0", 0x8015ab04U, 0, false, true, "" },
76    { "s0=0x2c;    s_add_u32  s21, s4, @s0-1", 0x8015ab04U, 0, false, true, "" },
77    { "s123x=0x2b;    s_add_u32  s21, s4, s123x", 0x8015ab04U, 0, false, true, "" },
78    { "ttmp123x=0x2b;    s_add_u32  s21, s4, ttmp123x", 0x8015ab04U, 0, false, true, "" },
79    { "s_add_u32  s21, s4, @s0-1; s0=600", 0x8015ff04U, 599, true, true, "" },
80    { "s_add_u32  s21, s4, @s0-1; s0=40", 0x8015ff04U, 39, true, true, "" },
81    { "s_add_u32  s21, s4, 3254500000000", 0x8015ff04U, 0xbf510100U, true, true,
82        "test.s:1:21: Warning: Value 0x2f5bf510100 truncated to 0xbf510100\n" },
83    { "s_add_u32  s21, s4, xx\nxx=3254500000000", 0x8015ff04U, 0xbf510100U, true, true,
84        "test.s:1:21: Warning: Value 0x2f5bf510100 truncated to 0xbf510100\n" },
85    /* parse second source as expression ('@' force that) */
86    { ".5=0x2b;    s_add_u32       s21, s4, @.5", 0x8015ab04U, 0, false, true, "" },
87    { "    s_add_u32  s21, s4, .5", 0x8015f004U, 0, false, true, "" },
88    { "    s_add_u32  s21, s4, -.5", 0x8015f104U, 0, false, true, "" },
89    { "    s_add_u32  s21, s4, 1.", 0x8015f204U, 0, false, true, "" },
90    { "    s_add_u32  s21, s4, -1.", 0x8015f304U, 0, false, true, "" },
91    { "    s_add_u32  s21, s4, 2.", 0x8015f404U, 0, false, true, "" },
92    { "    s_add_u32  s21, s4, -2.", 0x8015f504U, 0, false, true, "" },
93    { "    s_add_u32  s21, s4, 4.", 0x8015f604U, 0, false, true, "" },
94    { "    s_add_u32  s21, s4, -4.", 0x8015f704U, 0, false, true, "" },
95    { "    s_add_u32  s21, s4, 1234", 0x8015ff04U, 1234, true, true, "" },
96    { "    s_add_u32  s21, 1234, s4", 0x801504ffU, 1234, true, true, "" },
97    { "    s_add_u32  s21, s4, -4.5", 0x8015ff04U, 0xc0900000U, true, true, "" },
98    { "    s_add_u32  s21, s4, -4.5s", 0x8015ff04U, 0xc0900000U, true, true, "" },
99    { "    s_add_u32  s21, s4, -4.5h", 0x8015ff04U, 0xc480U, true, true, "" },
100    { "    s_add_u32  s21, s4, 3e-7", 0x8015ff04U, 0x34a10fb0U, true, true, "" },
101    /* 64-bit registers and literals */
102    { "    s_xor_b64 s[22:23], s[4:5], s[62:63]\n", 0x89963e04U, 0, false, true, "" },
103    { "s1=22; s2=4;s3=62;s_xor_b64 s[s1:s1+1], s[s2:s2+1], s[s3:s3+1]\n",
104        0x89963e04U, 0, false, true, "" },
105    { "    s_xor_b64 vcc, s[4:5], s[62:63]\n", 0x89ea3e04U, 0, false, true, "" },
106    { "    s_xor_b64 tba, s[4:5], s[62:63]\n", 0x89ec3e04U, 0, false, true, "" },
107    { "    s_xor_b64 tma, s[4:5], s[62:63]\n", 0x89ee3e04U, 0, false, true, "" },
108    { "    s_xor_b64 ttmp[4:5], s[4:5], s[62:63]\n", 0x89f43e04U, 0, false, true, "" },
109    { "    s_xor_b64 exec, s[4:5], s[62:63]\n", 0x89fe3e04U, 0, false, true, "" },
110    { "    s_xor_b64 exec, s[4:5], 4000\n", 0x89feff04U, 4000, true, true, "" },
111    { "    s_xor_b64 s[22:23], 0x2e, s[62:63]\n", 0x89963eaeU, 0, false, true, "" },
112    { "    s_xor_b64 s[22:23], -12, s[62:63]\n", 0x89963eccU, 0, false, true, "" },
113    { "    s_xor_b64 s[22:23], 1.0, s[62:63]\n", 0x89963ef2U, 0, false, true, "" },
114    { "    s_xor_b64 s[22:23], vccz, s[62:63]\n", 0x89963efbU, 0, false, true, "" },
115    { "    s_xor_b64 s[22:23], execz, s[62:63]\n", 0x89963efcU, 0, false, true, "" },
116    { "    s_xor_b64 s[22:23], scc, s[62:63]\n", 0x89963efdU, 0, false, true, "" },
117    /* long var names */
118    { "sx1111111111111111111222222222=67777\n"
119      "s_add_u32  s21, s4, sx1111111111111111111222222222\n",
120      0x8015ff04U, 67777, true, true, "" },
121    { "vx1111111111111111111222222222=67777\n"
122      "s_add_u32  s21, s4, vx1111111111111111111222222222\n",
123      0x8015ff04U, 67777, true, true, "" },
124    /* errors */
125    { "    s_add_u32  xx, s4, s61", 0, 0, false, false,
126        "test.s:1:16: Error: Expected 1 scalar register\n" },
127    { "    s_add_u32  s[2:3], s4, s61", 0, 0, false, false,
128        "test.s:1:16: Error: Required 1 scalar register\n" },
129    { "    s_add_u32  ttmp[2:3], s4, s61", 0, 0, false, false,
130        "test.s:1:16: Error: Required 1 scalar register\n" },
131    { "    s_add_u32  s[3:4], s4, s61", 0, 0, false, false,
132        "test.s:1:16: Error: Required 1 scalar register\n" },
133    { "    s_add_u32  ttmp[3:4], s4, s61", 0, 0, false, false,
134        "test.s:1:16: Error: Required 1 scalar register\n" },
135    { "    s_add_u32  s104, s4, s61", 0, 0, false, false,
136        "test.s:1:16: Error: Scalar register number out of range\n" },
137    { "    s_add_u32  ttmp12, s4, s61", 0, 0, false, false,
138        "test.s:1:16: Error: TTMPRegister number out of range (0-11)\n" },
139    { "    s_add_u32  s[104:105], s4, s61", 0, 0, false, false,
140        "test.s:1:16: Error: Some scalar register number out of range\n" },
141    { "    s_add_u32  ttmp[12:13], s4, s61", 0, 0, false, false,
142        "test.s:1:16: Error: Some TTMPRegister number out of range (0-11)\n" },
143    { "    s_add_u32  s[44:42], s4, s61", 0, 0, false, false,
144        "test.s:1:16: Error: Illegal scalar register range\n" },
145    { "    s_add_u32  ttmp[10:8], s4, s61", 0, 0, false, false,
146        "test.s:1:16: Error: Illegal TTMPRegister range\n" },
147    { "    s_add_u32  s[z], s4, s61", 0, 0, false, false,
148        "test.s:1:18: Error: Expression have unresolved symbol 'z'\n"
149        "test.s:1:19: Error: Expected ',' before argument\n" },
150    { "    s_add_u32  ttmp[z], s4, s61", 0, 0, false, false,
151        "test.s:1:21: Error: Expression have unresolved symbol 'z'\n"
152        "test.s:1:22: Error: Expected ',' before argument\n" },
153    { "    s_add_u32  sxzz, s4, s61", 0, 0, false, false,
154        "test.s:1:16: Error: Expected 1 scalar register\n" },
155    { "    s_add_u32  ttmpxzz, s4, s61", 0, 0, false, false,
156        "test.s:1:16: Error: Expected 1 scalar register\n" },
157    { "    s_add_u32  s30, s[4, s[61", 0, 0, false, false,
158        "test.s:1:21: Error: Unterminated scalar register range\n"
159        "test.s:1:26: Error: Unterminated scalar register range\n" },
160    { "    s_xor_b64  s[30:31], s[3:4], s[15:16]", 0, 0, false, false,
161        "test.s:1:26: Error: Unaligned scalar register range\n"
162        "test.s:1:34: Error: Unaligned scalar register range\n" },
163    { "    s_xor_b64  s[30:31], vcc_lo, s[14:15]", 0, 0, false, false,
164        "test.s:1:26: Error: Required 2 scalar registers\n" },
165    { "    s_xor_b64  s[30:31], vcc_hi, s[14:15]", 0, 0, false, false,
166        "test.s:1:26: Error: Required 2 scalar registers\n" },
167    { "    s_add_u32  s10, xfdd+a*, s61", 0, 0, false, false,
168        "test.s:1:28: Error: Unterminated expression\n" },
169    { "    s_add_u32  s10, , ", 0, 0, false, false,
170        "test.s:1:21: Error: Expected instruction operand\n"
171        "test.s:1:23: Error: Expected instruction operand\n" },
172    { "  s_add_u32  s35, 400000, 1111116", 0, 0, false, false,
173        "test.s:1:27: Error: Only one literal can be used in instruction\n" },
174    { "    s_xor_b64  s[30:31], vcc_hi, s[14:15]", 0, 0, false, false,
175        "test.s:1:26: Error: Required 2 scalar registers\n" },
176    { "k=%s5; s_xor_b64  s[30:31], k, s[14:15]", 0, 0, false, false,
177        "test.s:1:29: Error: Required 2 scalar registers\n" },
178    { "k=%execz; s_xor_b64  s[30:31], k, s[14:15]", 0, 0, false, false,
179        "test.s:1:32: Error: Required 2 scalar registers\n" },
180    { "k=%v[10:11]; s_xor_b64  s[30:31], k, s[14:15]", 0, 0, false, false,
181        "test.s:1:35: Error: Expression have register symbol\n"
182        "test.s:1:35: Error: Expected ',' before argument\n" },
183    /* SOP2 encodings */
184    { "    s_sub_u32  s21, s4, s61", 0x80953d04U, 0, false, true, "" },
185    { "    s_sub_u32_e32  s21, s4, s61", 0x80953d04U, 0, false, true, "" },
186    { "    s_add_i32  s21, s4, s61", 0x81153d04U, 0, false, true, "" },
187    { "    s_sub_i32  s21, s4, s61", 0x81953d04U, 0, false, true, "" },
188    { "    s_addc_u32  s21, s4, s61", 0x82153d04U, 0, false, true, "" },
189    { "    s_subb_u32  s21, s4, s61", 0x82953d04U, 0, false, true, "" },
190    { "    s_min_i32  s21, s4, s61", 0x83153d04U, 0, false, true, "" },
191    { "    s_min_u32  s21, s4, s61", 0x83953d04U, 0, false, true, "" },
192    { "    s_max_i32  s21, s4, s61", 0x84153d04U, 0, false, true, "" },
193    { "    s_max_u32  s21, s4, s61", 0x84953d04U, 0, false, true, "" },
194    { "    s_cselect_b32  s21, s4, s61", 0x85153d04U, 0, false, true, "" },
195    { "    s_cselect_b64  s[20:21], s[4:5], s[62:63]", 0x85943e04U, 0, false, true, "" },
196    { "    s_and_b32  s21, s4, s61", 0x87153d04U, 0, false, true, "" },
197    { "    s_and_b64  s[20:21], s[4:5], s[62:63]", 0x87943e04U, 0, false, true, "" },
198    { "    s_or_b32  s21, s4, s61", 0x88153d04U, 0, false, true, "" },
199    { "    s_or_b64  s[20:21], s[4:5], s[62:63]", 0x88943e04U, 0, false, true, "" },
200    { "    s_xor_b32  s21, s4, s61", 0x89153d04U, 0, false, true, "" },
201    { "    s_xor_b64  s[20:21], s[4:5], s[62:63]", 0x89943e04U, 0, false, true, "" },
202    { "    s_andn2_b32  s21, s4, s61", 0x8a153d04U, 0, false, true, "" },
203    { "    s_andn2_b64  s[20:21], s[4:5], s[62:63]", 0x8a943e04U, 0, false, true, "" },
204    { "    s_orn2_b32  s21, s4, s61", 0x8b153d04U, 0, false, true, "" },
205    { "    s_orn2_b64  s[20:21], s[4:5], s[62:63]", 0x8b943e04U, 0, false, true, "" },
206    { "    s_nand_b32  s21, s4, s61", 0x8c153d04U, 0, false, true, "" },
207    { "    s_nand_b64  s[20:21], s[4:5], s[62:63]", 0x8c943e04U, 0, false, true, "" },
208    { "    s_nor_b32  s21, s4, s61", 0x8d153d04U, 0, false, true, "" },
209    { "    s_nor_b64  s[20:21], s[4:5], s[62:63]", 0x8d943e04U, 0, false, true, "" },
210    { "    s_xnor_b32  s21, s4, s61", 0x8e153d04U, 0, false, true, "" },
211    { "    s_xnor_b64  s[20:21], s[4:5], s[62:63]", 0x8e943e04U, 0, false, true, "" },
212    { "    s_lshl_b32  s21, s4, s61", 0x8f153d04U, 0, false, true, "" },
213    { "    s_lshl_b64  s[20:21], s[4:5], s61", 0x8f943d04U, 0, false, true, "" },
214    { "    s_lshr_b32  s21, s4, s61", 0x90153d04U, 0, false, true, "" },
215    { "    s_lshr_b64  s[20:21], s[4:5], s61", 0x90943d04U, 0, false, true, "" },
216    { "    s_ashr_i32  s21, s4, s61", 0x91153d04U, 0, false, true, "" },
217    { "    s_ashr_i64  s[20:21], s[4:5], s61", 0x91943d04U, 0, false, true, "" },
218    { "    s_bfm_b32  s21, s4, s61", 0x92153d04U, 0, false, true, "" },
219    { "    s_bfm_b64  s[20:21], s4, s62", 0x92943e04U, 0, false, true, "" },
220    { "    s_mul_i32  s21, s4, s61", 0x93153d04U, 0, false, true, "" },
221    { "    s_bfe_u32  s21, s4, s61", 0x93953d04U, 0, false, true, "" },
222    { "    s_bfe_i32  s21, s4, s61", 0x94153d04U, 0, false, true, "" },
223    { "    s_bfe_u64  s[20:21], s[4:5], s61", 0x94943d04U, 0, false, true, "" },
224    { "    s_bfe_i64  s[20:21], s[4:5], s61", 0x95143d04U, 0, false, true, "" },
225    { "    s_cbranch_g_fork  s[4:5], s[62:63]", 0x95803e04U, 0, false, true, "" },
226    { "    s_absdiff_i32  s21, s4, s61", 0x96153d04U, 0, false, true, "" },
227    /* SOP1 */
228    { "    s_mov_b32  s86, s20", 0xbed60314U, 0, false, true, "" },
229    { "    s_mov_b32_e64  s86, -4", 0xbed603ffU, 0xfffffffcU, true, true, "" },
230    { "    s_mov_b32  s86, 0xadbc", 0xbed603ff, 0xadbc, true, true, "" },
231    { "    s_mov_b32  s86, xx; xx=0xadbc", 0xbed603ff, 0xadbc, true, true, "" },
232    { "    s_mov_b64  s[86:87], s[20:21]", 0xbed60414U, 0, false, true, "" },
233    { "    s_cmov_b32  s86, s20", 0xbed60514U, 0, false, true, "" },
234    { "    s_cmov_b64  s[86:87], s[20:21]", 0xbed60614U, 0, false, true, "" },
235    { "    s_not_b32  s86, s20", 0xbed60714U, 0, false, true, "" },
236    { "    s_not_b64  s[86:87], s[20:21]", 0xbed60814U, 0, false, true, "" },
237    { "    s_wqm_b32  s86, s20", 0xbed60914U, 0, false, true, "" },
238    { "    s_wqm_b64  s[86:87], s[20:21]", 0xbed60a14U, 0, false, true, "" },
239    { "    s_brev_b32  s86, s20", 0xbed60b14U, 0, false, true, "" },
240    { "    s_brev_b64  s[86:87], s[20:21]", 0xbed60c14U, 0, false, true, "" },
241    { "    s_bcnt0_i32_b32  s86, s20", 0xbed60d14U, 0, false, true, "" },
242    { "    s_bcnt0_i32_b64  s86, s[20:21]", 0xbed60e14U, 0, false, true, "" },
243    { "    s_bcnt1_i32_b32  s86, s20", 0xbed60f14U, 0, false, true, "" },
244    { "    s_bcnt1_i32_b64  s86, s[20:21]", 0xbed61014U, 0, false, true, "" },
245    { "    s_ff0_i32_b32  s86, s20", 0xbed61114U, 0, false, true, "" },
246    { "    s_ff0_i32_b64  s86, s[20:21]", 0xbed61214U, 0, false, true, "" },
247    { "    s_ff1_i32_b32  s86, s20", 0xbed61314U, 0, false, true, "" },
248    { "    s_ff1_i32_b64  s86, s[20:21]", 0xbed61414U, 0, false, true, "" },
249    { "    s_flbit_i32_b32  s86, s20", 0xbed61514U, 0, false, true, "" },
250    { "    s_flbit_i32_b64  s86, s[20:21]", 0xbed61614U, 0, false, true, "" },
251    { "    s_flbit_i32  s86, s20", 0xbed61714U, 0, false, true, "" },
252    { "    s_flbit_i32_i64  s86, s[20:21]", 0xbed61814U, 0, false, true, "" },
253    { "    s_sext_i32_i8  s86, s20", 0xbed61914U, 0, false, true, "" },
254    { "    s_sext_i32_i16  s86, s20", 0xbed61a14U, 0, false, true, "" },
255    { "    s_bitset0_b32  s86, s20", 0xbed61b14U, 0, false, true, "" },
256    { "    s_bitset0_b64  s[86:87], s20", 0xbed61c14U, 0, false, true, "" },
257    { "    s_bitset1_b32  s86, s20", 0xbed61d14U, 0, false, true, "" },
258    { "    s_bitset1_b64  s[86:87], s20", 0xbed61e14U, 0, false, true, "" },
259    { "    s_getpc_b64  s[86:87]", 0xbed61f00U, 0, false, true, "" },
260    { "    s_setpc_b64  s[20:21]", 0xbe802014U, 0, false, true, "" },
261    { "    s_swappc_b64  s[86:87], s[20:21]", 0xbed62114U, 0, false, true, "" },
262    { "    s_rfe_b64  s[20:21]", 0xbe802214U, 0, false, true, "" },
263    { "    s_and_saveexec_b64 s[86:87], s[20:21]", 0xbed62414U, 0, false, true, "" },
264    { "    s_or_saveexec_b64 s[86:87], s[20:21]", 0xbed62514U, 0, false, true, "" },
265    { "    s_xor_saveexec_b64 s[86:87], s[20:21]", 0xbed62614U, 0, false, true, "" },
266    { "    s_andn2_saveexec_b64 s[86:87], s[20:21]", 0xbed62714U, 0, false, true, "" },
267    { "    s_orn2_saveexec_b64 s[86:87], s[20:21]", 0xbed62814U, 0, false, true, "" },
268    { "    s_nand_saveexec_b64 s[86:87], s[20:21]", 0xbed62914U, 0, false, true, "" },
269    { "    s_nor_saveexec_b64 s[86:87], s[20:21]", 0xbed62a14U, 0, false, true, "" },
270    { "    s_xnor_saveexec_b64 s[86:87], s[20:21]", 0xbed62b14U, 0, false, true, "" },
271    { "    s_quadmask_b32  s86, s20",  0xbed62c14U, 0, false, true, "" },
272    { "    s_quadmask_b64  s[86:87], s[20:21]",  0xbed62d14U, 0, false, true, "" },
273    { "    s_movrels_b32  s86, s20",  0xbed62e14U, 0, false, true, "" },
274    { "    s_movrels_b64  s[86:87], s[20:21]",  0xbed62f14U, 0, false, true, "" },
275    { "    s_movreld_b32  s86, s20",  0xbed63014U, 0, false, true, "" },
276    { "    s_movreld_b64  s[86:87], s[20:21]",  0xbed63114U, 0, false, true, "" },
277    { "    s_cbranch_join  s20", 0xbe803214U, 0, false, true, "" },
278    { "    s_mov_regrd_b32 s86, s20", 0xbed63314U, 0, false, true, "" },
279    { "    s_abs_i32  s86, s20", 0xbed63414U, 0, false, true, "" },
280    { "    s_mov_fed_b32  s86, s20", 0xbed63514U, 0, false, true, "" },
281    /* SOPC */
282    { "    s_cmp_eq_i32  s29, s69", 0xbf00451dU, 0, false, true, "" },
283    { "    s_cmp_eq_i32_e64  s29, 51", 0xbf00ff1dU, 51, true, true, "" },
284    { "    s_cmp_eq_i32_e64  51, s69", 0xbf0045ffU, 51, true, true, "" },
285    { "    s_cmp_eq_i32  12222, s69", 0xbf0045ffU, 12222, true, true, "" },
286    { "    s_cmp_eq_i32  xx, s69; xx=12222", 0xbf0045ffU, 12222, true, true, "" },
287    { "    s_cmp_eq_i32  s29, 32545", 0xbf00ff1dU, 32545, true, true, "" },
288    { "    s_cmp_eq_i32  s29, xx; xx=32545", 0xbf00ff1dU, 32545, true, true, "" },
289    { "    s_cmp_lg_i32  s29, s69", 0xbf01451dU, 0, false, true, "" },
290    { "    s_cmp_gt_i32  s29, s69", 0xbf02451dU, 0, false, true, "" },
291    { "    s_cmp_ge_i32  s29, s69", 0xbf03451dU, 0, false, true, "" },
292    { "    s_cmp_lt_i32  s29, s69", 0xbf04451dU, 0, false, true, "" },
293    { "    s_cmp_le_i32  s29, s69", 0xbf05451dU, 0, false, true, "" },
294    { "    s_cmp_eq_u32  s29, s69", 0xbf06451dU, 0, false, true, "" },
295    { "    s_cmp_lg_u32  s29, s69", 0xbf07451dU, 0, false, true, "" },
296    { "    s_cmp_gt_u32  s29, s69", 0xbf08451dU, 0, false, true, "" },
297    { "    s_cmp_ge_u32  s29, s69", 0xbf09451dU, 0, false, true, "" },
298    { "    s_cmp_lt_u32  s29, s69", 0xbf0a451dU, 0, false, true, "" },
299    { "    s_cmp_le_u32  s29, s69", 0xbf0b451dU, 0, false, true, "" },
300    { "    s_bitcmp0_b32  s29, s69", 0xbf0c451dU, 0, false, true, "" },
301    { "    s_bitcmp1_b32  s29, s69", 0xbf0d451dU, 0, false, true, "" },
302    { "    s_bitcmp0_b64  s[28:29], s69", 0xbf0e451cU, 0, false, true, "" },
303    { "    s_bitcmp1_b64  s[28:29], s69", 0xbf0f451cU, 0, false, true, "" },
304    { "    s_setvskip  s29, s69", 0xbf10451dU, 0, false, true, "" },
305    /* SOPK */
306    { "    s_movk_i32  s43, 0xd3b9", 0xb02bd3b9U, 0, false, true, "" },
307    { "xc = 0xd4ba\n    s_movk_i32  s43, xc", 0xb02bd4baU, 0, false, true, "" },
308    { "    s_movk_i32  s43, xc; xc = 0xd4ba", 0xb02bd4baU, 0, false, true, "" },
309    { "xc = 0x11d4ba\n    s_movk_i32  s43, xc", 0xb02bd4baU, 0, false, true,
310        "test.s:2:22: Warning: Value 0x11d4ba truncated to 0xd4ba\n" },
311    { "    s_movk_i32  s43, xc; xc = 0x22d4ba", 0xb02bd4baU, 0, false, true,
312        "test.s:1:22: Warning: Value 0x22d4ba truncated to 0xd4ba\n" },
313    { "    s_cmovk_i32  s43, 0xd3b9", 0xb12bd3b9U, 0, false, true, "" },
314    { "    s_cmpk_eq_i32  s43, 0xd3b9", 0xb1abd3b9U, 0, false, true, "" },
315    { "    s_cmpk_lg_i32  s43, 0xd3b9", 0xb22bd3b9U, 0, false, true, "" },
316    { "    s_cmpk_gt_i32  s43, 0xd3b9", 0xb2abd3b9U, 0, false, true, "" },
317    { "    s_cmpk_ge_i32  s43, 0xd3b9", 0xb32bd3b9U, 0, false, true, "" },
318    { "    s_cmpk_lt_i32  s43, 0xd3b9", 0xb3abd3b9U, 0, false, true, "" },
319    { "    s_cmpk_le_i32  s43, 0xd3b9", 0xb42bd3b9U, 0, false, true, "" },
320    { "    s_cmpk_eq_u32  s43, 0xd3b9", 0xb4abd3b9U, 0, false, true, "" },
321    { "    s_cmpk_lg_u32  s43, 0xd3b9", 0xb52bd3b9U, 0, false, true, "" },
322    { "    s_cmpk_gt_u32  s43, 0xd3b9", 0xb5abd3b9U, 0, false, true, "" },
323    { "    s_cmpk_ge_u32  s43, 0xd3b9", 0xb62bd3b9U, 0, false, true, "" },
324    { "    s_cmpk_lt_u32  s43, 0xd3b9", 0xb6abd3b9U, 0, false, true, "" },
325    { "    s_cmpk_le_u32  s43, 0xd3b9", 0xb72bd3b9U, 0, false, true, "" },
326    { "    s_addk_i32  s43, 0xd3b9", 0xb7abd3b9U, 0, false, true, "" },
327    { "    s_mulk_i32  s43, 0xd3b9", 0xb82bd3b9U, 0, false, true, "" },
328    { "    s_cbranch_i_fork s[44:45], xxxx-8\nxxxx:\n", 0xb8acfffeU, 0, false, true, "" },
329    { "xxxx:    s_cbranch_i_fork s[44:45], xxxx-8\n", 0xb8acfffdU, 0, false, true, "" },
330    { "    s_cbranch_i_fork s[44:45], xxxx+8\nxxxx:\n", 0xb8ac0002U, 0, false, true, "" },
331    { "xxxx:    s_cbranch_i_fork s[44:45], xxxx+16\n", 0xb8ac0003U, 0, false, true, "" },
332    { "    s_cbranch_i_fork s[44:45], xxxx+9\nxxxx:\n", 0, 0, false, false,
333        "test.s:1:32: Error: Jump is not aligned to word!\n" },
334    { "    s_cbranch_i_fork s[44:45], xxxx+10\nxxxx:\n", 0, 0, false, false,
335        "test.s:1:32: Error: Jump is not aligned to word!\n" },
336    { "xxxx:    s_cbranch_i_fork s[44:45], xxxx+17\n", 0, 0, false, false,
337        "test.s:1:44: Error: Jump is not aligned to word!\n" },
338    { "    s_cbranch_i_fork s[44:45], xxxx+8\n.rodata\nxxxx:\n", 0, 0, false, false,
339        "test.s:1:32: Error: Jump over current section!\n" },
340    { ".rodata\nxxxx:.text\n    s_cbranch_i_fork s[44:45], xxxx+8", 0, 0, false, false,
341        "test.s:3:32: Error: Jump over current section!\n" },
342    /* hwregs */
343    { "    s_getreg_b32    s43, hwreg(mode, 0, 1)", 0xb92b0001U, 0, false, true, "" },
344    { "    s_getreg_b32    s43, hwreg  (mode, 0, 1)", 0xb92b0001U, 0, false, true, "" },
345    { "    s_getreg_b32    s43, hwreg  (mode  ,   0  , 1  )",
346                    0xb92b0001U, 0, false, true, "" },
347    { "    s_getreg_b32    s43, hwreg(HWREG_MODE, 0, 1)", 0xb92b0001U, 0, false, true, "" },
348    { "    s_getreg_b32    s43, hwreg(status, 0, 1)", 0xb92b0002U, 0, false, true, "" },
349    { "    s_getreg_b32    s43, hwreg(HWREG_STATUS, 0, 1)",
350        0xb92b0002U, 0, false, true, "" },
351    { "    s_getreg_b32    s43, hwreg(trapsts, 0, 1)", 0xb92b0003U, 0, false, true, "" },
352    { "    s_getreg_b32    s43, hwreg(HWREG_TRAPSTS, 0, 1)",
353                    0xb92b0003U, 0, false, true, "" },
354    { "    s_getreg_b32    s43, hwreg(hw_id, 0, 1)", 0xb92b0004U, 0, false, true, "" },
355    { "    s_getreg_b32    s43, hwreg(HWREG_HW_ID, 0, 1)",
356                    0xb92b0004U, 0, false, true, "" },
357    { "    s_getreg_b32    s43, hwreg(gpr_alloc, 0, 1)", 0xb92b0005U, 0, false, true, "" },
358    { "    s_getreg_b32    s43, hwreg(HWREG_GPR_ALLOC, 0, 1)",
359                    0xb92b0005U, 0, false, true, "" },
360    { "    s_getreg_b32    s43, hwreg(lds_alloc, 0, 1)", 0xb92b0006U, 0, false, true, "" },
361    { "    s_getreg_b32    s43, hwreg(HWREG_LDS_ALLOC, 0, 1)",
362                    0xb92b0006U, 0, false, true, "" },
363    { "    s_getreg_b32    s43, hwreg(ib_sts, 0, 1)", 0xb92b0007U, 0, false, true, "" },
364    { "    s_getreg_b32    s43, hwreg(HWREG_IB_STS, 0, 1)",
365                    0xb92b0007U, 0, false, true, "" },
366    { "    s_getreg_b32    s43, hwreg(pc_lo, 0, 1)", 0xb92b0008U, 0, false, true, "" },
367    { "    s_getreg_b32    s43, hwreg(HWREG_PC_LO, 0, 1)",
368                    0xb92b0008U, 0, false, true, "" },
369    { "    s_getreg_b32    s43, hwreg(pc_hi, 0, 1)", 0xb92b0009U, 0, false, true, "" },
370    { "    s_getreg_b32    s43, hwreg(HWREG_PC_HI, 0, 1)",
371                    0xb92b0009U, 0, false, true, "" },
372    { "    s_getreg_b32    s43, hwreg(inst_dw0, 0, 1)", 0xb92b000aU, 0, false, true, "" },
373    { "    s_getreg_b32    s43, hwreg(HWREG_INST_DW0, 0, 1)",
374                    0xb92b000aU, 0, false, true, "" },
375    { "    s_getreg_b32    s43, hwreg(inst_dw1, 0, 1)", 0xb92b000bU, 0, false, true, "" },
376    { "    s_getreg_b32    s43, hwreg(HWREG_INST_DW1, 0, 1)",
377                    0xb92b000bU, 0, false, true, "" },
378    { "    s_getreg_b32    s43, hwreg(ib_dbg0, 0, 1)", 0xb92b000cU, 0, false, true, "" },
379    { "    s_getreg_b32    s43, hwreg(HWREG_IB_DBG0, 0, 1)",
380                    0xb92b000cU, 0, false, true, "" },
381    { "    s_getreg_b32    s43, hwreg(trapsts, 10, 1)", 0xb92b0283u, 0, false, true, "" },
382    { "    s_getreg_b32    s43, hwreg(trapsts, 3, 10)", 0xb92b48c3u, 0, false, true, "" },
383    { "    s_getreg_b32    s43, hwreg(trapsts, 3, 32)", 0xb92bf8c3u, 0, false, true, "" },
384    { "    s_getreg_b32    s43, hwreg(@10, 0, 1)", 0xb92b000aU, 0, false, true, "" },
385    { "    s_getreg_b32    s43, hwreg(@8, 0, 1)", 0xb92b0008U, 0, false, true, "" },
386    { "    s_setreg_imm32_b32 hwreg(trapsts, 3, 10), 0x24da4f",
387                    0xba8048c3u, 0x24da4fU, true, true, "" },
388    { "    s_setreg_imm32_b32 hwreg(trapsts, 3, 10), xx; xx=0x24da4f",
389                    0xba8048c3u, 0x24da4fU, true, true, "" },
390    { "xx=0x24da4e;    s_setreg_imm32_b32 hwreg(trapsts, 3, 10), xx",
391                    0xba8048c3u, 0x24da4eU, true, true, "" },
392    { "     s_setreg_b32  hwreg(trapsts, 3, 10), s43", 0xb9ab48c3u, 0, false, true, "" },
393    /* hw regs errors */
394    { "    s_getreg_b32  s43, hwreg   (HWREG_MODE, 0, 2", 0, 0, false, false,
395        "test.s:1:49: Error: Unterminated hwreg function\n" },
396    { "    s_getreg_b32  s43, hwrX(mode, 0, 1)", 0, 0, false, false,
397        "test.s:1:24: Error: Expected hwreg function\n" },
398    { "    s_getreg_b32  s43, hwreg(mode, , )", 0, 0, false, false,
399        "test.s:1:36: Error: Expected expression\n"
400        "test.s:1:38: Error: Expected operator or value or symbol\n"
401        "test.s:1:39: Error: Unterminated hwreg function\n" },
402    { "    s_getreg_b32  s43, hwreg(XXX,6,8)", 0, 0, false, false,
403        "test.s:1:30: Error: Unknown HWRegister\n" },
404    { "    s_getreg_b32  s43, hwreg(ib_dbg1,6,8)", 0, 0, false, false,
405        "test.s:1:30: Error: Unknown HWRegister\n" },
406    /// s_getreg_b32  s43, hwreg(HW_REG_IB_DBG0, 0, 1)
407    /* SOPP */
408    { "s_nop  0x0", 0xbf800000U, 0, false, true, "" },
409    { "s_nop  7", 0xbf800007U, 0, false, true, "" },
410    { "s_nop  644", 0xbf800284U, 0, false, true, "" },
411    { "xv=6; xt=65; s_nop  xv+xt", 0xbf800047U, 0, false, true, "" },
412    { "s_nop  xv+xt; xv=6; xt=65", 0xbf800047U, 0, false, true, "" },
413    { "s_endpgm", 0xbf810000U, 0, false, true, "" },
414    { "    s_branch xxxx-8\nxxxx:\n", 0xbf82fffeU, 0, false, true, "" },
415    { "xxxx:    s_branch xxxx-8\n", 0xbf82fffdU, 0, false, true, "" },
416    { "    s_branch xxxx+8\nxxxx:\n", 0xbf820002U, 0, false, true, "" },
417    { "xxxx:    s_branch xxxx+16\n", 0xbf820003U, 0, false, true, "" },
418    { "    s_branch xxxx+9\nxxxx:\n", 0, 0, false, false,
419        "test.s:1:14: Error: Jump is not aligned to word!\n" },
420    { "    s_branch xxxx+10\nxxxx:\n", 0, 0, false, false,
421        "test.s:1:14: Error: Jump is not aligned to word!\n" },
422    { "xxxx:    s_branch xxxx+17\n", 0, 0, false, false,
423        "test.s:1:26: Error: Jump is not aligned to word!\n" },
424    { "    s_branch xxxx+8\n.rodata\nxxxx:\n", 0, 0, false, false,
425        "test.s:1:14: Error: Jump over current section!\n" },
426    { ".rodata\nxxxx:.text\n    s_branch xxxx+8", 0, 0, false, false,
427        "test.s:3:14: Error: Jump over current section!\n" },
428    { "    s_cbranch_scc0  xxxx-8\nxxxx:\n", 0xbf84fffeU, 0, false, true, "" },
429    { "    s_cbranch_scc1  xxxx-8\nxxxx:\n", 0xbf85fffeU, 0, false, true, "" },
430    { "    s_cbranch_vccz  xxxx-8\nxxxx:\n", 0xbf86fffeU, 0, false, true, "" },
431    { "    s_cbranch_vccnz  xxxx-8\nxxxx:\n", 0xbf87fffeU, 0, false, true, "" },
432    { "    s_cbranch_execz  xxxx-8\nxxxx:\n", 0xbf88fffeU, 0, false, true, "" },
433    { "    s_cbranch_execnz  xxxx-8\nxxxx:\n", 0xbf89fffeU, 0, false, true, "" },
434    { "s_barrier", 0xbf8a0000U, 0, false, true, "" },
435    { "s_waitcnt  vmcnt(14) & expcnt(2)", 0xbf8c0f2eU, 0, false, true, "" },
436    { "vmcnt=14\nexpcnt=2\ns_waitcnt  vmcnt(vmcnt) & expcnt(expcnt)",
437        0xbf8c0f2eU, 0, false, true, "" },
438    { "a=14\nb=2\ns_waitcnt  vmcnt(a) & expcnt(b)", 0xbf8c0f2eU, 0, false, true, "" },
439    { "s_waitcnt  vmcnt  (14  ) & expcnt(  2)", 0xbf8c0f2eU, 0, false, true, "" },
440    { "s_waitcnt  vmcnt  (14  ) expcnt(  2)", 0xbf8c0f2eU, 0, false, true, "" },
441    { "s_waitcnt  vmcnt  (  14  )&expcnt(  2  )", 0xbf8c0f2eU, 0, false, true, "" },
442    { "s_waitcnt  VmCnt  (  14  )&exPCnt(  2  )", 0xbf8c0f2eU, 0, false, true, "" },
443    { "s_waitcnt  lgkmcnt(13) & expcnt(2)", 0xbf8c0d2fU, 0, false, true, "" },
444    { "s_waitcnt  vmcnt(14) & lgkmcnt(13)", 0xbf8c0d7eU, 0, false, true, "" },
445    { "s_waitcnt  vmcnt(14)", 0xbf8c0f7eU, 0, false, true, "" },
446    { "s_waitcnt  lgkmcnt(9)", 0xbf8c097fU, 0, false, true, "" },
447    { "s_waitcnt  expcnt(2)", 0xbf8c0f2fU, 0, false, true, "" },
448    { "s_waitcnt  vmcnt(0) & expcnt(0) & lgkmcnt(0)", 0xbf8c0000U, 0, false, true, "" },
449    { "s_waitcnt  vmcnt(11) & expcnt(4) & lgkmcnt(12)", 0xbf8c0c4bU, 0, false, true, "" },
450    /* waitcnt warnings */
451    { "s_waitcnt  vmcnt(33) & expcnt(10) & lgkmcnt(27)", 0xbf8c0b21U, 0, false, true,
452        "test.s:1:18: Warning: Value out of range\n"
453        "test.s:1:31: Warning: Value out of range\n"
454        "test.s:1:45: Warning: Value out of range\n" },
455    { "s_waitcnt  vmcnt(14) & expcnt(2)&expcnt(3)", 0xbf8c0f3eU, 0, false, true,
456        "test.s:1:34: Warning: expcnt was already defined\n" },
457    { "s_waitcnt  vmcnt(14) & expcnt(2)&vmcnt(12)", 0xbf8c0f2cU, 0, false, true,
458        "test.s:1:34: Warning: vmcnt was already defined\n" },
459    { "s_waitcnt  lgkmcnt(13) & expcnt(2) & lgkmcnt(11)", 0xbf8c0b2fU, 0, false, true,
460        "test.s:1:38: Warning: lgkmcnt was already defined\n" },
461    /* waitcnt errors */
462    { "s_waitcnt  vmcnt(11) & expcnt() & lgkmcnt(12)", 0, 0, false, false,
463        "test.s:1:31: Error: Expected operator or value or symbol\n"
464        "test.s:1:33: Error: Expected primary expression before operator\n"
465        "test.s:1:35: Error: Expression have unresolved symbol 'lgkmcnt'\n"
466        "test.s:1:42: Error: Expected operator\n"
467        "test.s:1:43: Error: Unterminated function\n" },
468    { "s_waitcnt  vmcnt(11) & expcnt(3", 0, 0, false, false,
469        "test.s:1:32: Error: Unterminated function\n" },
470    { "s_waitcnt  vmcxxnt(11)", 0, 0, false, false,
471        "test.s:1:12: Error: Expected vmcnt, lgkmcnt or expcnt\n" },
472    { "s_waitcnt  vmcnt(11) _", 0, 0, false, false,
473        "test.s:1:22: Error: Expected vmcnt, lgkmcnt or expcnt\n" },
474    { "s_waitcnt  vmcnt  (14  ) & expcnt(  2) & aaaa(6) & vmcnt(4)", 0, 0, false, false,
475        "test.s:1:42: Error: Expected vmcnt, lgkmcnt or expcnt\n"
476        "test.s:1:52: Warning: vmcnt was already defined\n" },
477    /* other SOPP opcodes */
478    { "    s_sethalt       0x32b", 0xbf8d032bU, 0, false, true, "" },
479    { "    s_sleep         0x32b", 0xbf8e032bU, 0, false, true, "" },
480    { "    s_setprio       0x32b", 0xbf8f032bU, 0, false, true, "" },
481    /* sendmsg */
482    { "    s_sendmsg  sendmsg(interrupt)", 0xbf900001U, 0, false, true, "" },
483    { "    s_sendmsg  sendmsg(MSG_INTERRUPT)", 0xbf900001U, 0, false, true, "" },
484    { "    s_sendmsg  sendmsg(system)", 0xbf90000fU, 0, false, true, "" },
485    { "    s_sendmsg  sendmsg(MSG_SYSTEM)", 0xbf90000fU, 0, false, true, "" },
486    { "    s_sendmsg  sendmsg(MSG_SYSMSG)", 0xbf90000fU, 0, false, true, "" },
487    { "    s_sendmsg  sendmsg(gs, nop)", 0xbf900002U, 0, false, true, "" },
488    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_NOP)", 0xbf900002U, 0, false, true, "" },
489    { "    s_sendmsg  sendmsg(gs, cut, 0)", 0xbf900012U, 0, false, true, "" },
490    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_CUT, 0)", 0xbf900012U, 0, false, true, "" },
491    { "    s_sendmsg  sendmsg(gs, cut, 1)", 0xbf900112U, 0, false, true, "" },
492    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_CUT, 1)", 0xbf900112U, 0, false, true, "" },
493    { "    s_sendmsg  sendmsg(gs, emit, 0)", 0xbf900022U, 0, false, true, "" },
494    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_EMIT, 0)", 0xbf900022U, 0, false, true, "" },
495    { "    s_sendmsg  sendmsg(gs, emit_cut, 3)", 0xbf900332U, 0,
496        false, true, "" },
497    { "    s_sendmsg  sendmsg(gs, emit-cut, 3)", 0xbf900332U, 0,
498        false, true, "" },
499    { "    s_sendmsg  sendmsg ( gs    , emit_cut  , 3  )", 0xbf900332U, 0,
500        false, true, "" },
501    { "    s_sendmsg  sendmsg(MSG_GS, GS_OP_EMIT_CUT, 3)", 0xbf900332U, 0,
502        false, true, "" },
503    { "    s_sendmsg  sendmsg(gs_done, nop)", 0xbf900003U, 0, false, true, "" },
504    { "    s_sendmsg  sendmsg(MSG_GS_DONE, GS_OP_NOP)", 0xbf900003U, 0, false, true, "" },
505    { "    s_sendmsghalt  sendmsg(interrupt)", 0xbf910001U, 0, false, true, "" },
506    { "    s_sendmsg  sendmsg(@2, GS_OP_CUT, 0)", 0xbf900012U, 0, false, true, "" },
507    { "    s_sendmsg  sendmsg(@2, @1, 0)", 0xbf900012U, 0, false, true, "" },
508    /* msg errors */
509    { "    s_sendmsg  sendmsg(interrupxt)", 0, 0, false, false,
510        "test.s:1:24: Error: Unknown message\n" },
511    { "    s_sendmsg  sendmsg(savewave)", 0, 0, false, false,
512        "test.s:1:24: Error: Unknown message\n" },
513    { "    s_sendmsg  sendmsg(gs, nop__x)", 0, 0, false, false,
514        "test.s:1:28: Error: Unknown GSOP\n" },
515    { "    s_sendmsg  sendmsg(gs, nop__x", 0, 0, false, false,
516        "test.s:1:28: Error: Unknown GSOP\n"
517        "test.s:1:34: Error: Unterminated sendmsg function\n" },
518    { "    s_sendmsg  sendmsg(gs, cut, 122)", 0xbf900212U, 0, false, true,
519        "test.s:1:33: Warning: StreamId (3rd argument) out of range\n" },
520    /* other SOPP encoding */
521    { "    s_trap  0x32b", 0xbf92032bU, 0, false, true, "" },
522    { "    s_icache_inv", 0xbf930000U, 0, false, true, "" },
523    { "    s_incperflevel  0x1234", 0xbf941234U, 0, false, true, "" },
524    { "    s_decperflevel  0x1234", 0xbf951234U, 0, false, true, "" },
525    { "    s_ttracedata", 0xbf960000U, 0, false, true, "" },
526    /* SMRD encoding */
527    { "    s_load_dword    s50, s[58:59], 0x5b", 0xc0193b5bU, 0, false, true, "" },
528    { "    s_load_dword    s50, s[58:59], s91", 0xc0193a5bU, 0, false, true, "" },
529    { "    s_load_dword    s51, s[58:59], s91", 0xc019ba5bU, 0, false, true, "" },
530    { "s0=191;    s_load_dword    s50, s[58:59], @s0", 0xc0193bbfU, 0, false, true, "" },
531    { "    s_load_dword    s50, s[58:59], @s0; s0=191", 0xc0193bbfU, 0, false, true, "" },
532    { "x0=191;    s_load_dword    s50, s[58:59], x0", 0xc0193bbfU, 0, false, true, "" },
533    { "    s_load_dword    s50, s[58:59], x0; x0=191", 0xc0193bbfU, 0, false, true, "" },
534    { "    s_load_dwordx2  s[52:53], s[58:59], s83", 0xc05a3a53U, 0, false, true, "" },
535    { "    s_load_dwordx4  s[52:55], s[58:59], s83", 0xc09a3a53U, 0, false, true, "" },
536    { "    s_load_dwordx8  s[52:59], s[58:59], s83", 0xc0da3a53U, 0, false, true, "" },
537    { "    s_load_dwordx16  s[52:67], s[58:59], s83", 0xc11a3a53U, 0, false, true, "" },
538    { "    s_buffer_load_dword    s50, s[60:63], 191", 0xc2193dbfU, 0, false, true, "" },
539    { "    s_buffer_load_dwordx2  s[52:53], s[60:63], s83",
540        0xc25a3c53U, 0, false, true, "" },
541    { "    s_buffer_load_dwordx4  s[52:55], s[60:63], s83",
542        0xc29a3c53U, 0, false, true, "" },
543    { "    s_buffer_load_dwordx8  s[52:59], s[60:63], s83",
544        0xc2da3c53U, 0, false, true, "" },
545    { "    s_buffer_load_dwordx16  s[52:67], s[60:63], s83",
546        0xc31a3c53U, 0, false, true, "" },
547    /* vccz as variable */
548    { "    s_load_dword    s50, s[58:59], vccz; vccz=33",
549        0xc0193b21U, 0, false, true, "" },
550    /* other with only sdst */
551    { "    s_memtime  s[50:51]", 0xc7990000U, 0, false, true, "" },
552    { "    s_dcache_inv", 0xc7c00000U, 0, false, true, "" },
553    /* SMRD warnings */
554    { "s0=3191; s_load_dword    s50, s[58:59], @s0", 0xc0193b77U, 0, false, true,
555        "test.s:1:42: Warning: Value 0xc77 truncated to 0x77\n" },
556    { "s_load_dword    s50, s[58:59], @s0; s0=3191", 0xc0193b77U, 0, false, true,
557        "test.s:1:33: Warning: Value 0xc77 truncated to 0x77\n" },
558    /* SMRD errors */
559    { "    s_load_dword    vccz, s[58:59], 0x5b", 0, 0, false, false,
560        "test.s:1:21: Error: Expected 1 scalar register\n" },
561    { "    s_load_dword    s50, s[59:60], 0x5b", 0, 0, false, false,
562        "test.s:1:26: Error: Unaligned scalar register range\n" },
563    /* VOP2/(VOP2 in VOP3) encoding */
564    { "    v_cndmask_b32   v154, v21, v107, vcc", 0x0134d715U, 0, false, true, "" },
565    { "    v_cndmask_b32   v154, v21, v107, vcc     ", 0x0134d715U, 0, false, true, "" },
566    { "    v_cndmask_b32   v[154:154], v[21:21], v[107], vcc",
567        0x0134d715U, 0, false, true, "" },
568    { "    v_cndmask_b32   v[  154 : 154], v[ 21:21 ], v[ 107  ], vcc",
569        0x0134d715U, 0, false, true, "" },
570    { "    v_cndmask_b32   v154  , v21 , v107  , vcc", 0x0134d715U, 0, false, true, "" },
571    { "    v_cndmask_b32   v154, lds, v107, vcc", 0x0134d6feU, 0, false, true, "" },
572    { "    v_cndmask_b32   v154, lds_direct, v107, vcc", 0x0134d6feU, 0, false, true, "" },
573    { "    v_cndmask_b32   v154, src_lds_direct, v107, vcc",
574        0x0134d6feU, 0, false, true, "" },
575    { "    v_add_f32   v154, s21, v107", 0x0734d615U, 0, false, true, "" },
576    { "    v_cndmask_b32   v154, 2, v107, vcc", 0x0134d682U, 0, false, true, "" },
577    { "    v_cndmask_b32   v154, -9, v107, vcc", 0x0134d6c9U, 0, false, true, "" },
578    { "    v_cndmask_b32   v154, 20e-1, v107, vcc", 0x0134d6f4U, 0, false, true, "" },
579    { "    v_cndmask_b32   v154, 1323, v107, vcc", 0x0134d6ffU, 1323, true, true, "" },
580    { "xx=1323;v_cndmask_b32   v154, xx, v107, vcc", 0x0134d6ffU, 1323, true, true, "" },
581    { "v_cndmask_b32   v154, xx, v107, vcc; xx=1323", 0x0134d6ffU, 1323, true, true, "" },
582    { "v_cndmask_b32   v154, xx, v107, vcc; xx=2", 0x0134d6ffU, 2, true, true, "" },
583    { "v0=1323;v_cndmask_b32   v154, @v0, v107, vcc", 0x0134d6ffU, 1323, true, true, "" },
584    { "v_cndmask_b32   v154, @v0, v107, vcc; v0=1323", 0x0134d6ffU, 1323, true, true, "" },
585    { "s0=1323;v_cndmask_b32   v154, @s0, v107, vcc", 0x0134d6ffU, 1323, true, true, "" },
586    { "v_cndmask_b32   v154, @s0, v107, vcc; s0=1323", 0x0134d6ffU, 1323, true, true, "" },
587    { "    v_readlane_b32  s26, v21, s94", 0x0234bd15U, 0, false, true, "" },
588    { "    v_writelane_b32  v26, v21, s94", 0x0434bd15U, 0, false, true, "" },
589    { "    v_add_f32  v154, v21, v107", 0x0734d715U, 0, false, true, "" },
590    /* register names */
591    { "tx=%v21; ty=%v107; v_add_f32  v154, tx, ty", 0x0734d715U, 0, false, true, "" },
592    { "tx=%v[16:23]; ty=%v107; v_add_f32  v154, tx[5], ty",
593        0x0734d715U, 0, false, true, "" },
594    { "tx=%s21; v_add_f32  v154, tx, v107", 0x0734d615U, 0, false, true, "" },
595    { "    v_add_f32  v154, s21, v107", 0x0734d615U, 0, false, true, "" },
596    { " fla=%v154;   v_add_f32  fla, s21, v107", 0x0734d615U, 0, false, true, "" },
597    { "    v_add_f32  v154, v21, v107 vop3", 0xd206009aU, 0x0002d715U, true, true, "" },
598    { "    v_add_f32  v154, v21, v107 vop3:1", 0xd206009aU, 0x0002d715U, true, true, "" },
599    { "    v_add_f32_e64  v154, v21, v107", 0xd206009aU, 0x0002d715U, true, true, "" },
600    { "    v_add_f32_e64  v154, v21, v107 vop3:0",
601        0xd206009aU, 0x0002d715U, true, true, "" },
602    { "    v_add_f32  v154, v21, s98", 0xd206009aU, 0x0000c515U, true, true, "" },
603    { "    v_add_f32  v154, abs(v21), v107", 0xd206019aU, 0x0002d715U, true, true, "" },
604    { "    v_add_f32  v154, |v21|, v107", 0xd206019aU, 0x0002d715U, true, true, "" },
605    { "dd=%v21; v_add_f32  v154, |dd|, v107", 0xd206019aU, 0x0002d715U, true, true, "" },
606    { "    v_add_f32  v154, abs(v21), abs(v107)",
607        0xd206039aU, 0x0002d715U, true, true, "" },
608    { "    v_add_f32  v154, v21, abs(v107)", 0xd206029aU, 0x0002d715U, true, true, "" },
609    { "    v_add_f32  v154, -v21, v107", 0xd206009aU, 0x2002d715U, true, true, "" },
610    { "    v_add_f32  v154, v21, -v107", 0xd206009aU, 0x4002d715U, true, true, "" },
611    { "    v_add_f32  v154, -v21, -v107", 0xd206009aU, 0x6002d715U, true, true, "" },
612    { "    v_add_f32  v154, -abs(v21), -abs(v107)",
613        0xd206039aU, 0x6002d715U, true, true, "" },
614    { "    v_add_f32  v154, v21, v107 mul:2", 0xd206009aU, 0x0802d715U, true, true, "" },
615    { "    v_add_f32  v154, v21, v107 omod:1", 0xd206009aU, 0x0802d715U, true, true, "" },
616    { "    v_add_f32  v154, v21, v107 mul:2 clamp:0",
617        0xd206009aU, 0x0802d715U, true, true, "" },
618    { "    v_add_f32  v154, v21, v107 mul:002", 0xd206009aU, 0x0802d715U, true, true, "" },
619    { "    v_add_f32  v154, v21, v107 mul:4", 0xd206009aU, 0x1002d715U, true, true, "" },
620    { "    v_add_f32  v154, v21, v107 omod:2", 0xd206009aU, 0x1002d715U, true, true, "" },
621    { "    v_add_f32  v154, v21, v107 div:2", 0xd206009aU, 0x1802d715U, true, true, "" },
622    { "    v_add_f32  v154, v21, v107 omod:3", 0xd206009aU, 0x1802d715U, true, true, "" },
623    { "    v_add_f32  v154, v21, v107 div:002", 0xd206009aU, 0x1802d715U, true, true, "" },
624    { "    v_add_f32  v154, v21, v107 mul:2 clamp",
625        0xd206089aU, 0x0802d715U, true, true, "" },
626    { "    v_add_f32  v154, v21, v107 mul:2 clamp:1",
627        0xd206089aU, 0x0802d715U, true, true, "" },
628    { "    v_add_f32  v154, v21, v107 clamp", 0xd206089aU, 0x0002d715U, true, true, "" },
629    { "    v_cndmask_b32   v154, v21, v107, s[6:7]",
630        0xd200009aU, 0x001ad715U, true, true, "" },
631    { "    v_cndmask_b32   v154, abs(v21), abs(v107), s[6:7] clamp",
632        0xd2000b9aU, 0x001ad715U, true, true, "" },
633    /* negated expressions */
634    { "vx=7;    v_add_f32  v154, -vx, v107", 0x0734d6c7U, 0, false, true, "" },
635    { "v12ZZ=7;    v_add_f32  v154, -v12ZZ, v107", 0x0734d6c7U, 0, false, true, "" },
636    { "v_add_f32  v154, -vx, v107; vx=7", 0x0734d6ffU, uint32_t(-7), true, true, "" },
637    { "vx=7737;    v_add_f32  v154, -vx, v107",
638        0x0734d6ffU, uint32_t(-7737), true, true, "" },
639    { "    v_add_f32  v154, s2, s2", 0xd206009aU, 0x0402U, true, true, "" },
640    /* var long names */
641    { "xtmp1111111111111111111222222222=67777\n"
642        "v_add_f32  v154, xtmp1111111111111111111222222222, v107",
643        0x0734d6ffU, 67777, true, true, "" },
644    /* VOP2 errors */
645    { "    v_cndmask_b32   v[154:155], v21, v107, vcc", 0, 0, false, false,
646        "test.s:1:21: Error: Required 1 vector register\n" },
647    { "    v_cndmask_b32   v154, v[21:22], v107, vcc", 0, 0, false, false,
648        "test.s:1:27: Error: Required 1 vector register\n" },
649    { "    v_cndmask_b32   v154, v21, v[107:108], vcc", 0, 0, false, false,
650        "test.s:1:32: Error: Required 1 vector register\n" },
651    { "    v_cndmask_b32   v[154:, v21, v107, vcc", 0, 0, false, false,
652        "test.s:1:27: Error: Expected expression\n" },
653    { "    v_cndmask_b32   v[14, v21, v107, vcc", 0, 0, false, false,
654        "test.s:1:21: Error: Unterminated vector register range\n" },
655    { "    v_cndmask_b32   v[14:15, v21, v107, vcc", 0, 0, false, false,
656        "test.s:1:21: Error: Unterminated vector register range\n" },
657    { "    v_cndmask_b32   v256, v21, v107, vcc", 0, 0, false, false,
658        "test.s:1:24: Error: Number is too big\n"
659        "test.s:1:24: Error: Expected ',' before argument\n" },
660    { "    v_cndmask_b32   v[255:256], v21, v107, vcc", 0, 0, false, false,
661        "test.s:1:21: Error: Some vector register number out of range\n" },
662    { "    v_add_f32  v154, v21, v107 mul,", 0, 0, false, false,
663        "test.s:1:35: Error: Expected ':' before multiplier number\n"
664        "test.s:1:35: Error: Some garbages at VOP modifier place\n" },
665    { "    v_add_f32  v154, v21, v107 div,", 0, 0, false, false,
666        "test.s:1:35: Error: Expected ':' before divider number\n"
667        "test.s:1:35: Error: Some garbages at VOP modifier place\n" },
668    /* VOP2 in VOP3 errors */
669    { "    v_add_f32  v154, v21, v107 mul:3", 0, 0, false, false,
670        "test.s:1:32: Error: Unknown VOP3 mul:X modifier\n" },
671    { "    v_add_f32  v154, v21, v107 mul:", 0, 0, false, false,
672        "test.s:1:36: Error: Missing number\n" },
673    { "    v_add_f32  v154, v21, v107 mul", 0, 0, false, false,
674        "test.s:1:35: Error: Expected ':' before multiplier number\n" },
675    { "    v_add_f32  v154, v21, v107 mxl", 0, 0, false, false,
676        "test.s:1:32: Error: Unknown VOP modifier\n" },
677    { "    v_add_f32  v154, abs(v21), 12343", 0, 0, false, false,
678        "test.s:1:5: Error: Literal in VOP3 encoding is illegal\n" },
679    { "    v_add_f32  v154, 13243, abs(v21)", 0, 0, false, false,
680        "test.s:1:5: Error: Literal in VOP3 encoding is illegal\n" },
681    { "    v_add_f32  v154, 3123, s3", 0, 0, false, false,
682        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
683    { "    v_add_f32  v154, 3123, m0", 0, 0, false, false,
684        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
685    { "    v_add_f32  v154, s3, 3123", 0, 0, false, false,
686        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
687    { "    v_add_f32  v154, m0, 3123", 0, 0, false, false,
688        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
689    { "    v_add_f32  v154, s2, s4", 0, 0, false, false,
690        "test.s:1:5: Error: More than one SGPR to read in instruction\n" },
691    /* out holds scalar register (not vector) */
692    { "out=%s64;v_add_f32  out, s21, v107", 0, 0, false, false,
693        "test.s:1:21: Error: Expected 1 vector register\n" },
694    { "out=%v[64:65];v_add_f32  out, s21, v107", 0, 0, false, false,
695        "test.s:1:26: Error: Required 1 vector register\n" },
696    /* OMOD already defined */
697    { "    v_add_f32  v154, v21, v107 mul:4 div:2", 0xd206009aU, 0x1802d715U, true, true, 
698        "test.s:1:38: Warning: OMOD is already defined\n" },
699    /* rest of the VOP2 pcodes */
700    { "    v_sub_f32  v154, v21, v107", 0x0934d715U, 0, false, true, "" },
701    { "    v_sub_f32  v55, s27, -v90", 0xd2080037U, 0x4002b41bU, true, true, "" },
702    { "    v_subrev_f32  v154, v21, v107", 0x0b34d715U, 0, false, true, "" },
703    { "    v_subrev_f32  v55, s27, -v90", 0xd20a0037U, 0x4002b41bU, true, true, "" },
704    { "    v_mac_legacy_f32  v154, v21, v107", 0x0d34d715U, 0, false, true, "" },
705    { "    v_mac_legacy_f32  v55, s27, -v90", 0xd20c0037U, 0x4002b41bU, true, true, "" },
706    { "    v_mul_legacy_f32  v154, v21, v107", 0x0f34d715U, 0, false, true, "" },
707    { "    v_mul_legacy_f32  v55, s27, -v90", 0xd20e0037U, 0x4002b41bU, true, true, "" },
708    { "    v_mul_f32  v154, v21, v107", 0x1134d715U, 0, false, true, "" },
709    { "    v_mul_f32  v55, s27, -v90", 0xd2100037U, 0x4002b41bU, true, true, "" },
710    { "    v_mul_i32_i24  v154, v21, v107", 0x1334d715U, 0, false, true, "" },
711    { "    v_mul_i32_i24  v55, s27, -v90", 0xd2120037U, 0x4002b41bU, true, true, "" },
712    { "    v_mul_hi_i32_i24  v154, v21, v107", 0x1534d715U, 0, false, true, "" },
713    { "    v_mul_hi_i32_i24  v55, s27, -v90", 0xd2140037U, 0x4002b41bU, true, true, "" },
714    { "    v_mul_u32_u24  v154, v21, v107", 0x1734d715U, 0, false, true, "" },
715    { "    v_mul_u32_u24  v55, s27, -v90", 0xd2160037U, 0x4002b41bU, true, true, "" },
716    { "    v_mul_hi_u32_u24  v154, v21, v107", 0x1934d715U, 0, false, true, "" },
717    { "    v_mul_hi_u32_u24  v55, s27, -v90", 0xd2180037U, 0x4002b41bU, true, true, "" },
718    { "    v_min_legacy_f32  v154, v21, v107", 0x1b34d715U, 0, false, true, "" },
719    { "    v_min_legacy_f32  v55, s27, -v90", 0xd21a0037U, 0x4002b41bU, true, true, "" },
720    { "    v_max_legacy_f32  v154, v21, v107", 0x1d34d715U, 0, false, true, "" },
721    { "    v_max_legacy_f32  v55, s27, -v90", 0xd21c0037U, 0x4002b41bU, true, true, "" },
722    { "    v_min_f32  v154, v21, v107", 0x1f34d715U, 0, false, true, "" },
723    { "    v_min_f32  v55, s27, -v90", 0xd21e0037U, 0x4002b41bU, true, true, "" },
724    { "    v_max_f32  v154, v21, v107", 0x2134d715U, 0, false, true, "" },
725    { "    v_max_f32  v55, s27, -v90", 0xd2200037U, 0x4002b41bU, true, true, "" },
726    { "    v_min_i32  v154, v21, v107", 0x2334d715U, 0, false, true, "" },
727    { "    v_min_i32  v55, s27, -v90", 0xd2220037U, 0x4002b41bU, true, true, "" },
728    { "    v_max_i32  v154, v21, v107", 0x2534d715U, 0, false, true, "" },
729    { "    v_max_i32  v55, s27, -v90", 0xd2240037U, 0x4002b41bU, true, true, "" },
730    { "    v_min_u32  v154, v21, v107", 0x2734d715U, 0, false, true, "" },
731    { "    v_min_u32  v55, s27, -v90", 0xd2260037U, 0x4002b41bU, true, true, "" },
732    { "    v_max_u32  v154, v21, v107", 0x2934d715U, 0, false, true, "" },
733    { "    v_max_u32  v55, s27, -v90", 0xd2280037U, 0x4002b41bU, true, true, "" },
734    { "    v_lshr_b32  v154, v21, v107", 0x2b34d715U, 0, false, true, "" },
735    { "    v_lshr_b32  v55, s27, -v90", 0xd22a0037U, 0x4002b41bU, true, true, "" },
736    { "    v_lshrrev_b32  v154, v21, v107", 0x2d34d715U, 0, false, true, "" },
737    { "    v_lshrrev_b32  v55, s27, -v90", 0xd22c0037U, 0x4002b41bU, true, true, "" },
738    { "    v_ashr_i32  v154, v21, v107", 0x2f34d715U, 0, false, true, "" },
739    { "    v_ashr_i32  v55, s27, -v90", 0xd22e0037U, 0x4002b41bU, true, true, "" },
740    { "    v_ashrrev_i32  v154, v21, v107", 0x3134d715U, 0, false, true, "" },
741    { "    v_ashrrev_i32  v55, s27, -v90", 0xd2300037U, 0x4002b41bU, true, true, "" },
742    { "    v_lshl_b32  v154, v21, v107", 0x3334d715U, 0, false, true, "" },
743    { "    v_lshl_b32  v55, s27, -v90", 0xd2320037U, 0x4002b41bU, true, true, "" },
744    { "    v_lshlrev_b32  v154, v21, v107", 0x3534d715U, 0, false, true, "" },
745    { "    v_lshlrev_b32  v55, s27, -v90", 0xd2340037U, 0x4002b41bU, true, true, "" },
746    { "    v_and_b32  v154, v21, v107", 0x3734d715U, 0, false, true, "" },
747    { "    v_and_b32  v55, s27, -v90", 0xd2360037U, 0x4002b41bU, true, true, "" },
748    { "    v_or_b32  v154, v21, v107", 0x3934d715U, 0, false, true, "" },
749    { "    v_or_b32  v55, s27, -v90", 0xd2380037U, 0x4002b41bU, true, true, "" },
750    { "    v_xor_b32  v154, v21, v107", 0x3b34d715U, 0, false, true, "" },
751    { "    v_xor_b32  v55, s27, -v90", 0xd23a0037U, 0x4002b41bU, true, true, "" },
752    { "    v_bfm_b32  v154, v21, v107", 0x3d34d715U, 0, false, true, "" },
753    { "    v_bfm_b32  v55, s27, -v90", 0xd23c0037U, 0x4002b41bU, true, true, "" },
754    { "    v_mac_f32  v154, v21, v107", 0x3f34d715U, 0, false, true, "" },
755    { "    v_mac_f32  v55, s27, -v90", 0xd23e0037U, 0x4002b41bU, true, true, "" },
756    { "    v_madmk_f32 v154, v21, 6.9551627e+13, v107",
757        0x4134d715U, 0x567d0700U, true, true, "" },
758    { "    v_madmk_f32 v154, v21, 45543, v107", 0x4134d715U, 45543, true, true, "" },
759    { "cxx=77111;v_madmk_f32 v154, v21, cxx, v107", 0x4134d715U, 77111, true, true, "" },
760    { "v_madmk_f32 v154, v21, cxx, v107; cxx=77111", 0x4134d715U, 77111, true, true, "" },
761    { "    v_madak_f32 v154, v21, v107, 6.9551627e+13",
762        0x4334d715U, 0x567d0700U, true, true, "" },
763    { "    v_madak_f32 v154, v21, v107, 6.9551627e+13s",
764        0x4334d715U, 0x567d0700U, true, true, "" },
765    { "    v_madak_f32 v154, v21, v107, 6.9551627h", 0x4334d715U, 0x46f5U, true, true, "" },
766    { "    v_madak_f32 v154, v21, v107, 45543", 0x4334d715U, 45543, true, true, "" },
767    { "cxx=77111;v_madak_f32 v154, v21, v107, cxx", 0x4334d715U, 77111, true, true, "" },
768    { "v_madak_f32 v154, v21, v107, cxx; cxx=77111", 0x4334d715U, 77111, true, true, "" },
769    { "    v_bcnt_u32_b32  v154, v21, v107", 0x4534d715U, 0, false, true, "" },
770    { "    v_bcnt_u32_b32  v55, s27, -v90", 0xd2440037U, 0x4002b41bU, true, true, "" },
771    { "    v_mbcnt_lo_u32_b32  v154, v21, v107", 0x4734d715U, 0, false, true, "" },
772    { "    v_mbcnt_lo_u32_b32  v55, s27, -v90", 0xd2460037U, 0x4002b41bU, true, true, "" },
773    { "    v_mbcnt_hi_u32_b32  v154, v21, v107", 0x4934d715U, 0, false, true, "" },
774    { "    v_mbcnt_hi_u32_b32  v55, s27, -v90", 0xd2480037U, 0x4002b41bU, true, true, "" },
775    { "    v_add_i32  v154, vcc, v21, v107", 0x4b34d715U, 0, false, true, "" },
776    { "    v_add_i32  v55, s[10:11], s27, -v90",
777        0xd24a0a37U, 0x4002b41bU, true, true, "" },
778    { "    v_add_u32  v154, vcc, v21, v107", 0x4b34d715U, 0, false, true, "" },
779    { "    v_add_u32  v55, s[10:11], s27, -v90",
780        0xd24a0a37U, 0x4002b41bU, true, true, "" },
781    { "    v_sub_i32  v154, vcc, v21, v107", 0x4d34d715U, 0, false, true, "" },
782    { "    v_sub_i32  v55, s[10:11], s27, -v90",
783        0xd24c0a37U, 0x4002b41bU, true, true, "" },
784    { "    v_sub_u32  v154, vcc, v21, v107", 0x4d34d715U, 0, false, true, "" },
785    { "    v_sub_u32  v55, s[10:11], s27, -v90",
786        0xd24c0a37U, 0x4002b41bU, true, true, "" },
787    { "    v_sub_i32  v55, s[11:12], s27, -v90",
788        0xd24c0b37U, 0x4002b41bU, true, true, "" },
789    { "    v_subrev_i32  v154, vcc, v21, v107", 0x4f34d715U, 0, false, true, "" },
790    { "    v_subrev_i32  v55, s[10:11], s27, -v90",
791        0xd24e0a37U, 0x4002b41bU, true, true, "" },
792    { "    v_subrev_u32  v154, vcc, v21, v107", 0x4f34d715U, 0, false, true, "" },
793    { "    v_subrev_u32  v55, s[10:11], s27, -v90",
794        0xd24e0a37U, 0x4002b41bU, true, true, "" },
795    { "    v_addc_u32  v154, vcc, v21, v107, vcc", 0x5134d715U, 0, false, true, "" },
796    { "    v_addc_u32_e32  v154, vcc, v21, v107, vcc", 0x5134d715U, 0, false, true, "" },
797    { "    v_subb_u32  v154, vcc, v21, v107, vcc", 0x5334d715U, 0, false, true, "" },
798    { "    v_subbrev_u32  v154, vcc, v21, v107, vcc", 0x5534d715U, 0, false, true, "" },
799    { "    v_addc_u32 v55, s[6:7], v27, -v90, s[24:25]\n",
800            0xd2500637U, 0x4062b51bU, true, true, "" },
801    /* VOP3B errors */
802    { "    v_add_i32  v55, s[10:11], s27, abs(v90)", 0, 0, false, false,
803        "test.s:1:39: Error: Expected operator\n"
804        "test.s:1:40: Error: Unknown VOP modifier\n"
805        "test.s:1:43: Error: Some garbages at VOP modifier place\n" },
806    { "    v_add_i32  v55, s[10:11], abs(s27), v90", 0, 0, false, false,
807        "test.s:1:34: Error: Expected operator\n"
808        "test.s:1:35: Error: Expected ',' before argument\n" },
809    { "    v_add_i32  v55, s[10:11], s27, v90 clamp", 0, 0, false, false,
810        "test.s:1:40: Error: Modifier CLAMP in VOP3B is illegal\n" },
811    /* rest of the VOP2 */
812    { "    v_ldexp_f32  v154, v21, v107", 0x5734d715U, 0, false, true, "" },
813    { "    v_ldexp_f32  v55, s27, -v90", 0xd2560037U, 0x4002b41bU, true, true, "" },
814    { "    v_cvt_pkaccum_u8_f32 v154, v21, v107", 0x5934d715U, 0, false, true, "" },
815    { "    v_cvt_pkaccum_u8_f32 v55, s27, -v90",
816        0xd2580037U, 0x4002b41bU, true, true, "" },
817    { "    v_cvt_pknorm_i16_f32 v154, v21, v107", 0x5b34d715U, 0, false, true, "" },
818    { "    v_cvt_pknorm_i16_f32 v55, s27, -v90",
819        0xd25a0037U, 0x4002b41bU, true, true, "" },
820    { "    v_cvt_pknorm_u16_f32 v154, v21, v107", 0x5d34d715U, 0, false, true, "" },
821    { "    v_cvt_pknorm_u16_f32 v55, s27, -v90",
822        0xd25c0037U, 0x4002b41bU, true, true, "" },
823    { "    v_cvt_pkrtz_f16_f32 v154, v21, v107", 0x5f34d715U, 0, false, true, "" },
824    { "    v_cvt_pkrtz_f16_f32 v55, s27, -v90", 0xd25e0037U, 0x4002b41bU, true, true, "" },
825    { "    v_cvt_pk_u16_u32  v154, v21, v107", 0x6134d715U, 0, false, true, "" },
826    { "    v_cvt_pk_u16_u32  v55, s27, -v90", 0xd2600037U, 0x4002b41bU, true, true, "" },
827    { "    v_cvt_pk_i16_i32  v154, v21, v107", 0x6334d715U, 0, false, true, "" },
828    { "    v_cvt_pk_i16_i32  v55, s27, -v90", 0xd2620037U, 0x4002b41bU, true, true, "" },
829    // double value
830    { "    v_cvt_f32_f64 v3, 0.51119751l", 0x7e061effU, 0x3fe05bbbU, true, true,"" },
831    /* VOP1 and VOP1 in VOP3 */
832    { "    v_nop", 0x7e000000U, 0, false, true, "" },
833    { "    v_nop vop3", 0xd3000000U, 0, true, true, "" },
834    { "    v_mov_b32  v158, s79", 0x7f3c024fU, 0, false, true, "" },
835    { "    v_mov_b32  v15, s79", 0x7e1e024fU, 0, false, true, "" },
836    { "    v_mov_b32  v15, v79", 0x7e1e034fU, 0, false, true, "" },
837    { "vxx=9; v_mov_b32  v15, vxx", 0x7e1e0289U, 0, false, true, "" },
838    { "vxx=9111; v_mov_b32  v15, vxx", 0x7e1e02ffU, 9111, true, true, "" },
839    { "v_mov_b32  v15, vxx; vxx=9", 0x7e1e02ffU, 9, true, true, "" },
840    { "v_mov_b32  v15, vxx; vxx=9111", 0x7e1e02ffU, 9111, true, true, "" },
841    { "v0=9111; v_mov_b32  v15, @v0", 0x7e1e02ffU, 9111, true, true, "" },
842    { "v_mov_b32  v15, @v0; v0=9", 0x7e1e02ffU, 9, true, true, "" },
843    { "    v_mov_b32  v15, lds", 0x7e1e02feU, 0, false, true, "" },
844    { "    v_mov_b32  v15, lds_direct", 0x7e1e02feU, 0, false, true, "" },
845    { "    v_mov_b32  v55, s27 vop3", 0xd3020037U, 0x0000001bU, true, true, "" },
846    { "    v_mov_b32  v55, v27 vop3", 0xd3020037U, 0x0000011bU, true, true, "" },
847    { "    v_mov_b32  v55, v27 clamp", 0xd3020837U, 0x0000011bU, true, true, "" },
848    { "    v_mov_b32  v55, abs(s27)", 0xd3020137U, 0x0000001bU, true, true, "" },
849    { "    v_mov_b32  v55, -s27", 0xd3020037U, 0x2000001bU, true, true, "" },
850    { "    v_mov_b32  v55, -abs(s27)", 0xd3020137U, 0x2000001bU, true, true, "" },
851    { "    v_readfirstlane_b32 s30, s79", 0x7e3c044fU, 0, false, true, "" },
852    { "    v_readfirstlane_b32 s30, v79", 0x7e3c054fU, 0, false, true, "" },
853    { "    v_cvt_i32_f64  v158, v[79:80]", 0x7f3c074fU, 0, false, true, "" },
854    { "    v_cvt_i32_f64  v55, abs(v[27:28])", 0xd3060137U, 0x0000011bU, true, true, "" },
855    { "    v_cvt_i32_f64  v55, abs(s[26:27])", 0xd3060137U, 0x0000001aU, true, true, "" },
856    { "    v_cvt_i32_f64  v55, -s[26:27]", 0xd3060037U, 0x2000001aU, true, true, "" },
857    { "    v_cvt_f32_i32  v158, v79", 0x7f3c0b4fU, 0, false, true, "" },
858    { "    v_cvt_f32_i32  v55, v27 vop3", 0xd30a0037U, 0x0000011bU, true, true, "" },
859    { "    v_cvt_f32_u32  v158, v79", 0x7f3c0d4fU, 0, false, true, "" },
860    { "    v_cvt_f32_u32  v55, v27 vop3", 0xd30c0037U, 0x0000011bU, true, true, "" },
861    { "    v_cvt_u32_f32  v158, v79", 0x7f3c0f4fU, 0, false, true, "" },
862    { "    v_cvt_u32_f32  v55, v27 vop3", 0xd30e0037U, 0x0000011bU, true, true, "" },
863    { "    v_cvt_i32_f32  v158, v79", 0x7f3c114fU, 0, false, true, "" },
864    { "    v_cvt_i32_f32  v55, v27 vop3", 0xd3100037U, 0x0000011bU, true, true, "" },
865    { "    v_mov_fed_b32  v158, v79", 0x7f3c134fU, 0, false, true, "" },
866    { "    v_mov_fed_b32  v55, v27 vop3", 0xd3120037U, 0x0000011bU, true, true, "" },
867    { "    v_cvt_f16_f32  v158, v79", 0x7f3c154fU, 0, false, true, "" },
868    { "    v_cvt_f16_f32  v55, v27 vop3", 0xd3140037U, 0x0000011bU, true, true, "" },
869    { "    v_cvt_f32_f16  v158, v79", 0x7f3c174fU, 0, false, true, "" },
870    { "    v_cvt_f32_f16  v55, v27 vop3", 0xd3160037U, 0x0000011bU, true, true, "" },
871    { "    v_cvt_f32_f16  v158, -23.56h", 0x7f3c16ffU, 0xcde4U, true, true, "" },
872    /* constant immediates */
873    { "    v_cvt_f32_f16  v158, 0.0", 0x7f3c1680U, 0, false, true, "" },
874    { "    v_cvt_f32_f16  v158, 0.5s", 0x7f3c16f0U, 0, false, true, "" },
875    { "    v_cvt_f32_f16  v158, -0.5s", 0x7f3c16f1U, 0, false, true, "" },
876    { "    v_cvt_f32_f16  v158, 1.s", 0x7f3c16f2U, 0, false, true, "" },
877    { "    v_cvt_f32_f16  v158, -1.s", 0x7f3c16f3U, 0, false, true, "" },
878    { "    v_cvt_f32_f16  v158, 2.s", 0x7f3c16f4U, 0, false, true, "" },
879    { "    v_cvt_f32_f16  v158, -2.s", 0x7f3c16f5U, 0, false, true, "" },
880    { "    v_cvt_f32_f16  v158, 4.s", 0x7f3c16f6U, 0, false, true, "" },
881    { "    v_cvt_f32_f16  v158, -4.s", 0x7f3c16f7U, 0, false, true, "" },
882    { "    v_cvt_f32_f64  v158, 0.5l", 0x7f3c1ef0U, 0, false, true, "" },
883    { "    v_cvt_f32_f64  v158, -0.5l", 0x7f3c1ef1U, 0, false, true, "" },
884    { "    v_cvt_f32_f64  v158, 1.l", 0x7f3c1ef2U, 0, false, true, "" },
885    { "    v_cvt_f32_f64  v158, -1.l", 0x7f3c1ef3U, 0, false, true, "" },
886    { "    v_cvt_f32_f64  v158, 2.l", 0x7f3c1ef4U, 0, false, true, "" },
887    { "    v_cvt_f32_f64  v158, -2.l", 0x7f3c1ef5U, 0, false, true, "" },
888    { "    v_cvt_f32_f64  v158, 4.l", 0x7f3c1ef6U, 0, false, true, "" },
889    { "    v_cvt_f32_f64  v158, -4.l", 0x7f3c1ef7U, 0, false, true, "" },
890    { "    v_cvt_f32_f16  v158, 0.5", 0x7f3c16f0U, 0, false, true, "" },
891    { "    v_cvt_f32_f16  v158, 2.", 0x7f3c16f4U, 0, false, true, "" },
892    { "    v_cvt_f32_f16  v158, -2.", 0x7f3c16f5U, 0, false, true, "" },
893    /* rest of VOP1 instructions */
894    { "    v_cvt_rpi_i32_f32  v158, v79", 0x7f3c194fU, 0, false, true, "" },
895    { "    v_cvt_rpi_i32_f32  v55, v27 vop3", 0xd3180037U, 0x0000011bU, true, true, "" },
896    { "    v_cvt_flr_i32_f32  v158, v79", 0x7f3c1b4fU, 0, false, true, "" },
897    { "    v_cvt_flr_i32_f32  v55, v27 vop3", 0xd31a0037U, 0x0000011bU, true, true, "" },
898    { "    v_cvt_off_f32_i4  v158, v79", 0x7f3c1d4fU, 0, false, true, "" },
899    { "    v_cvt_off_f32_i4  v55, v27 vop3", 0xd31c0037U, 0x0000011bU, true, true, "" },
900    { "    v_cvt_f32_f64  v158, v[79:80]", 0x7f3c1f4fU, 0, false, true, "" },
901    { "    v_cvt_f32_f64  v55, v[27:28] vop3", 0xd31e0037U, 0x0000011bU, true, true, "" },
902    { "    v_cvt_f64_f32  v[158:159], v79", 0x7f3c214fU, 0, false, true, "" },
903    { "    v_cvt_f64_f32  v[55:56], v27 vop3", 0xd3200037U, 0x0000011bU, true, true, "" },
904    { "    v_cvt_f32_ubyte0  v158, v79", 0x7f3c234fU, 0, false, true, "" },
905    { "    v_cvt_f32_ubyte0  v55, v27 vop3", 0xd3220037U, 0x0000011bU, true, true, "" },
906    { "    v_cvt_f32_ubyte1  v158, v79", 0x7f3c254fU, 0, false, true, "" },
907    { "    v_cvt_f32_ubyte1  v55, v27 vop3", 0xd3240037U, 0x0000011bU, true, true, "" },
908    { "    v_cvt_f32_ubyte2  v158, v79", 0x7f3c274fU, 0, false, true, "" },
909    { "    v_cvt_f32_ubyte2  v55, v27 vop3", 0xd3260037U, 0x0000011bU, true, true, "" },
910    { "    v_cvt_f32_ubyte3  v158, v79", 0x7f3c294fU, 0, false, true, "" },
911    { "    v_cvt_f32_ubyte3  v55, v27 vop3", 0xd3280037U, 0x0000011bU, true, true, "" },
912    { "    v_cvt_u32_f64  v158, v[79:80]", 0x7f3c2b4fU, 0, false, true, "" },
913    { "    v_cvt_u32_f64  v55, v[27:28] vop3", 0xd32a0037U, 0x0000011bU, true, true, "" },
914    { "    v_cvt_f64_u32  v[158:159], v79", 0x7f3c2d4fU, 0, false, true, "" },
915    { "    v_cvt_f64_u32  v[55:56], v27 vop3", 0xd32c0037U, 0x0000011bU, true, true, "" },
916    { "    v_fract_f32  v158, v79", 0x7f3c414fU, 0, false, true, "" },
917    { "    v_fract_f32  v55, v27 vop3", 0xd3400037U, 0x0000011bU, true, true, "" },
918    { "    v_trunc_f32  v158, v79", 0x7f3c434fU, 0, false, true, "" },
919    { "    v_trunc_f32  v55, v27 vop3", 0xd3420037U, 0x0000011bU, true, true, "" },
920    { "    v_ceil_f32  v158, v79", 0x7f3c454fU, 0, false, true, "" },
921    { "    v_ceil_f32  v55, v27 vop3", 0xd3440037U, 0x0000011bU, true, true, "" },
922    { "    v_rndne_f32  v158, v79", 0x7f3c474fU, 0, false, true, "" },
923    { "    v_rndne_f32  v55, v27 vop3", 0xd3460037U, 0x0000011bU, true, true, "" },
924    { "    v_floor_f32  v158, v79", 0x7f3c494fU, 0, false, true, "" },
925    { "    v_floor_f32  v55, v27 vop3", 0xd3480037U, 0x0000011bU, true, true, "" },
926    { "    v_exp_f32  v158, v79", 0x7f3c4b4fU, 0, false, true, "" },
927    { "    v_exp_f32  v55, v27 vop3", 0xd34a0037U, 0x0000011bU, true, true, "" },
928    { "    v_log_clamp_f32  v158, v79", 0x7f3c4d4fU, 0, false, true, "" },
929    { "    v_log_clamp_f32  v55, v27 vop3", 0xd34c0037U, 0x0000011bU, true, true, "" },
930    { "    v_log_f32  v158, v79", 0x7f3c4f4fU, 0, false, true, "" },
931    { "    v_log_f32  v55, v27 vop3", 0xd34e0037U, 0x0000011bU, true, true, "" },
932    { "    v_rcp_clamp_f32  v158, v79", 0x7f3c514fU, 0, false, true, "" },
933    { "    v_rcp_clamp_f32  v55, v27 vop3", 0xd3500037U, 0x0000011bU, true, true, "" },
934    { "    v_rcp_legacy_f32  v158, v79", 0x7f3c534fU, 0, false, true, "" },
935    { "    v_rcp_legacy_f32  v55, v27 vop3", 0xd3520037U, 0x0000011bU, true, true, "" },
936    { "    v_rcp_f32  v158, v79", 0x7f3c554fU, 0, false, true, "" },
937    { "    v_rcp_f32  v55, v27 vop3", 0xd3540037U, 0x0000011bU, true, true, "" },
938    { "    v_rcp_iflag_f32  v158, v79", 0x7f3c574fU, 0, false, true, "" },
939    { "    v_rcp_iflag_f32  v55, v27 vop3", 0xd3560037U, 0x0000011bU, true, true, "" },
940    { "    v_rsq_clamp_f32  v158, v79", 0x7f3c594fU, 0, false, true, "" },
941    { "    v_rsq_clamp_f32  v55, v27 vop3", 0xd3580037U, 0x0000011bU, true, true, "" },
942    { "    v_rsq_legacy_f32  v158, v79", 0x7f3c5b4fU, 0, false, true, "" },
943    { "    v_rsq_legacy_f32  v55, v27 vop3", 0xd35a0037U, 0x0000011bU, true, true, "" },
944    { "    v_rsq_f32  v158, v79", 0x7f3c5d4fU, 0, false, true, "" },
945    { "    v_rsq_f32  v55, v27 vop3", 0xd35c0037U, 0x0000011bU, true, true, "" },
946    { "    v_rcp_f64  v[158:159], v[79:80]", 0x7f3c5f4fU, 0, false, true, "" },
947    { "    v_rcp_f64  v[158:159], s[79:80]", 0x7f3c5e4fU, 0, false, true, "" },
948    { "    v_rcp_f64  v[55:56], v[27:28] vop3", 0xd35e0037U, 0x0000011bU, true, true, "" },
949    { "    v_rcp_clamp_f64  v[158:159], v[79:80]", 0x7f3c614fU, 0, false, true, "" },
950    { "    v_rcp_clamp_f64  v[55:56], v[27:28] vop3",
951        0xd3600037U, 0x0000011bU, true, true, "" },
952    { "    v_rsq_f64  v[158:159], v[79:80]", 0x7f3c634fU, 0, false, true, "" },
953    { "    v_rsq_f64  v[55:56], v[27:28] vop3", 0xd3620037U, 0x0000011bU, true, true, "" },
954    { "    v_rsq_clamp_f64  v[158:159], v[79:80]", 0x7f3c654fU, 0, false, true, "" },
955    { "    v_rsq_clamp_f64  v[55:56], v[27:28] vop3",
956        0xd3640037U, 0x0000011bU, true, true, "" },
957    { "    v_sqrt_f32  v158, v79", 0x7f3c674fU, 0, false, true, "" },
958    { "    v_sqrt_f32  v55, v27 vop3", 0xd3660037U, 0x0000011bU, true, true, "" },
959    { "    v_sqrt_f64  v[158:159], v[79:80]", 0x7f3c694fU, 0, false, true, "" },
960    { "    v_sqrt_f64  v[55:56], v[27:28] vop3", 0xd3680037U, 0x0000011bU, true, true, "" },
961    { "    v_sin_f32  v158, v79", 0x7f3c6b4fU, 0, false, true, "" },
962    { "    v_sin_f32  v55, v27 vop3", 0xd36a0037U, 0x0000011bU, true, true, "" },
963    { "    v_cos_f32  v158, v79", 0x7f3c6d4fU, 0, false, true, "" },
964    { "    v_cos_f32  v55, v27 vop3", 0xd36c0037U, 0x0000011bU, true, true, "" },
965    { "    v_not_b32  v158, v79", 0x7f3c6f4fU, 0, false, true, "" },
966    { "    v_not_b32  v55, v27 vop3", 0xd36e0037U, 0x0000011bU, true, true, "" },
967    { "    v_bfrev_b32  v158, v79", 0x7f3c714fU, 0, false, true, "" },
968    { "    v_bfrev_b32  v55, v27 vop3", 0xd3700037U, 0x0000011bU, true, true, "" },
969    { "    v_ffbh_u32  v158, v79", 0x7f3c734fU, 0, false, true, "" },
970    { "    v_ffbh_u32  v55, v27 vop3", 0xd3720037U, 0x0000011bU, true, true, "" },
971    { "    v_ffbl_b32  v158, v79", 0x7f3c754fU, 0, false, true, "" },
972    { "    v_ffbl_b32  v55, v27 vop3", 0xd3740037U, 0x0000011bU, true, true, "" },
973    { "    v_ffbh_i32  v158, v79", 0x7f3c774fU, 0, false, true, "" },
974    { "    v_ffbh_i32  v55, v27 vop3", 0xd3760037U, 0x0000011bU, true, true, "" },
975    { "    v_frexp_exp_i32_f64 v158, v[79:80]", 0x7f3c794fU, 0, false, true, "" },
976    { "    v_frexp_exp_i32_f64 v55, v[27:28] vop3",
977        0xd3780037U, 0x0000011bU, true, true, "" },
978    { "    v_frexp_mant_f64 v[158:159], v[79:80]", 0x7f3c7b4fU, 0, false, true, "" },
979    { "    v_frexp_mant_f64 v[55:56], v[27:28] vop3",
980        0xd37a0037U, 0x0000011bU, true, true, "" },
981    { "    v_fract_f64  v[158:159], v[79:80]", 0x7f3c7d4fU, 0, false, true, "" },
982    { "    v_fract_f64  v[55:56], v[27:28] vop3",
983        0xd37c0037U, 0x0000011bU, true, true, "" },
984    { "    v_frexp_exp_i32_f32  v158, v79", 0x7f3c7f4fU, 0, false, true, "" },
985    { "    v_frexp_exp_i32_f32  v55, v27 vop3", 0xd37e0037U, 0x0000011bU, true, true, "" },
986    { "    v_frexp_mant_f32  v158, v79", 0x7f3c814fU, 0, false, true, "" },
987    { "    v_frexp_mant_f32  v55, v27 vop3", 0xd3800037U, 0x0000011bU, true, true, "" },
988    { "    v_clrexcp", 0x7e008200U, 0, false, true, "" },
989    { "    v_clrexcp vop3", 0xd3820000U, 0, true, true, "" },
990    { "    v_movreld_b32  v158, v79", 0x7f3c854fU, 0, false, true, "" },
991    { "    v_movreld_b32  v55, v27 vop3", 0xd3840037U, 0x0000011bU, true, true, "" },
992    { "    v_movrels_b32  v158, v79", 0x7f3c874fU, 0, false, true, "" },
993    { "    v_movrels_b32  v55, v27 vop3", 0xd3860037U, 0x0000011bU, true, true, "" },
994    { "    v_movrelsd_b32  v158, v79", 0x7f3c894fU, 0, false, true, "" },
995    { "    v_movrelsd_b32  v55, v27 vop3", 0xd3880037U, 0x0000011bU, true, true, "" },
996    /* VOP1 errors */
997    { "    v_mov_b32  v15, 133 vop3", 0, 0, false, false,
998        "test.s:1:5: Error: Literal in VOP3 encoding is illegal\n" },
999    { "    v_rcp_f64  v[158:], v[79:80]", 0, 0, false, false,
1000        "test.s:1:22: Error: Expected expression\n"
1001        "test.s:1:22: Error: Expected ',' before argument\n" },
1002    { "    v_rcp_f64  v[158:159, v[79:80]", 0, 0, false, false,
1003        "test.s:1:16: Error: Unterminated vector register range\n" },
1004    { "    v_rcp_f64  v158, s79", 0, 0, false, false,
1005        "test.s:1:16: Error: Required 2 vector registers\n"
1006        "test.s:1:25: Error: Required 2 scalar registers\n" },
1007    { "    v_mov_b32  v[48:59], s[80:81]", 0, 0, false, false,
1008        "test.s:1:16: Error: Required 1 vector register\n"
1009        "test.s:1:26: Error: Required 1 scalar register\n" },
1010    /* VOPC encoding */
1011    { "    v_cmp_f_f32  vcc, v79, v201", 0x7c01934fU, 0, false, true, "" },
1012    { "    v_cmp_f_f32  vcc, v79, v93", 0x7c00bb4fU, 0, false, true, "" },
1013    { "    v_cmp_f_f32  vcc, lds, v201", 0x7c0192feU, 0, false, true, "" },
1014    { "    v_cmp_f_f32  vcc, lds_direct, v201", 0x7c0192feU, 0, false, true, "" },
1015    { "    v_cmp_f_f32  vcc, s79, v201", 0x7c01924fU, 0, false, true, "" },
1016    { "    v_cmp_f_f32  vcc, -9, v201", 0x7c0192c9U, 0, false, true, "" },
1017    { "    v_cmp_f_f32  vcc, 44517, v201", 0x7c0192ffU, 44517, true, true, "" },
1018    { "txy=54244;v_cmp_f_f32  vcc, txy, v201", 0x7c0192ffU, 54244, true, true, "" },
1019    { "v_cmp_f_f32  vcc, txy, v201;txy=54244", 0x7c0192ffU, 54244, true, true, "" },
1020    { "    v_cmp_f_f32  vcc, v79, v201 vop3", 0xd000006aU, 0x3934fU, true, true, "" },
1021    { "    v_cmp_f_f32  vcc, v79, v201 clamp", 0xd000086aU, 0x3934fU, true, true, "" },
1022    { "    v_cmp_f_f32  vcc, v79, abs(v201)", 0xd000026aU, 0x3934fU, true, true, "" },
1023    { "    v_cmp_f_f32  vcc, -v79, v201", 0xd000006aU, 0x2003934fU, true, true, "" },
1024    { "    v_cmp_f_f32  vcc, v79, -v201", 0xd000006aU, 0x4003934fU, true, true, "" },
1025    { "    v_cmp_f_f32  vcc, v79, v201 mul:2", 0xd000006aU, 0x0803934fU, true, true, "" },
1026    { "    v_cmp_f_f32  vcc, v79, s101", 0xd000006aU, 0x0cb4fU, true, true, "" },
1027    { "    v_cmp_f_f32  vcc, v79, 24", 0xd000006aU, 0x1314fU, true, true, "" },
1028    { "    v_cmp_f_f32  s[28:29], v79, v201", 0xd000001cU, 0x3934fU, true, true, "" },
1029    { "    v_cmp_f_f32  s[29:30], v79, v201", 0xd000001dU, 0x3934fU, true, true, "" },
1030    { "    v_cmp_f_f32  vcc, 10.5332, v201", 0x7c0192ffU, 0x412887fd, true, true, "" },
1031    { "    v_cmp_f_f32  vcc, s8, s8", 0xd000006aU, 0x1008U, true, true, "" },
1032    /* VOPC errors */
1033    { "    v_cmp_f_f32  vcc_lo, v79, v201", 0, 0, false, false,
1034        "test.s:1:18: Error: Required 2 scalar registers\n" },
1035    { "    v_cmp_f_f32  vcc, 42321, s37", 0, 0, false, false,
1036        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
1037    { "    v_cmp_f_f32  vcc, 42321, m0", 0, 0, false, false,
1038        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
1039    { "    v_cmp_f_f32  vcc, s68, 42321", 0, 0, false, false,
1040        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
1041    { "    v_cmp_f_f32  vcc, m0, 42321", 0, 0, false, false,
1042        "test.s:1:5: Error: Literal with SGPR or M0 is illegal\n" },
1043    { "    v_cmp_f_f32  vcc, s8, s9", 0, 0, false, false,
1044        "test.s:1:5: Error: More than one SGPR to read in instruction\n" },
1045    { "    v_cmp_f_f32  vcc, 44517, v201 vop3", 0, 0, false, false,
1046        "test.s:1:5: Error: Literal in VOP3 encoding is illegal\n" },
1047    { "    v_cmp_f_f32  vcc, 44517, 63111", 0, 0, false, false,
1048        "test.s:1:30: Error: Only one literal can be used in instruction\n" },
1049    { "    v_cmp_f_f32  vcc, sss, dddd", 0, 0, false, false,
1050        "test.s:1:28: Error: Only one literal can be used in instruction\n" },
1051    /* VOPC instructions */
1052    { "    v_cmp_f_f32  vcc, v79, v201", 0x7c01934fU, 0, false, true, "" },
1053    { "    v_cmp_f_f32  s[42:43], v50, v107", 0xd000002aU, 0x0002d732U, true, true, "" },
1054    { "    v_cmp_lt_f32  vcc, v79, v201", 0x7c03934fU, 0, false, true, "" },
1055    { "    v_cmp_lt_f32  s[42:43], v50, v107", 0xd002002aU, 0x0002d732U, true, true, "" },
1056    { "    v_cmp_eq_f32  vcc, v79, v201", 0x7c05934fU, 0, false, true, "" },
1057    { "    v_cmp_eq_f32  s[42:43], v50, v107", 0xd004002aU, 0x0002d732U, true, true, "" },
1058    { "    v_cmp_le_f32  vcc, v79, v201", 0x7c07934fU, 0, false, true, "" },
1059    { "    v_cmp_le_f32  s[42:43], v50, v107", 0xd006002aU, 0x0002d732U, true, true, "" },
1060    { "    v_cmp_gt_f32  vcc, v79, v201", 0x7c09934fU, 0, false, true, "" },
1061    { "    v_cmp_gt_f32  s[42:43], v50, v107", 0xd008002aU, 0x0002d732U, true, true, "" },
1062    { "    v_cmp_lg_f32  vcc, v79, v201", 0x7c0b934fU, 0, false, true, "" },
1063    { "    v_cmp_lg_f32  s[42:43], v50, v107", 0xd00a002aU, 0x0002d732U, true, true, "" },
1064    { "    v_cmp_ge_f32  vcc, v79, v201", 0x7c0d934fU, 0, false, true, "" },
1065    { "    v_cmp_ge_f32  s[42:43], v50, v107", 0xd00c002aU, 0x0002d732U, true, true, "" },
1066    { "    v_cmp_o_f32  vcc, v79, v201", 0x7c0f934fU, 0, false, true, "" },
1067    { "    v_cmp_o_f32  s[42:43], v50, v107", 0xd00e002aU, 0x0002d732U, true, true, "" },
1068    { "    v_cmp_u_f32  vcc, v79, v201", 0x7c11934fU, 0, false, true, "" },
1069    { "    v_cmp_u_f32  s[42:43], v50, v107", 0xd010002aU, 0x0002d732U, true, true, "" },
1070    { "    v_cmp_nge_f32  vcc, v79, v201", 0x7c13934fU, 0, false, true, "" },
1071    { "    v_cmp_nge_f32  s[42:43], v50, v107", 0xd012002aU, 0x0002d732U, true, true, "" },
1072    { "    v_cmp_nlg_f32  vcc, v79, v201", 0x7c15934fU, 0, false, true, "" },
1073    { "    v_cmp_nlg_f32  s[42:43], v50, v107", 0xd014002aU, 0x0002d732U, true, true, "" },
1074    { "    v_cmp_ngt_f32  vcc, v79, v201", 0x7c17934fU, 0, false, true, "" },
1075    { "    v_cmp_ngt_f32  s[42:43], v50, v107", 0xd016002aU, 0x0002d732U, true, true, "" },
1076    { "    v_cmp_nle_f32  vcc, v79, v201", 0x7c19934fU, 0, false, true, "" },
1077    { "    v_cmp_nle_f32  s[42:43], v50, v107", 0xd018002aU, 0x0002d732U, true, true, "" },
1078    { "    v_cmp_neq_f32  vcc, v79, v201", 0x7c1b934fU, 0, false, true, "" },
1079    { "    v_cmp_neq_f32  s[42:43], v50, v107", 0xd01a002aU, 0x0002d732U, true, true, "" },
1080    { "    v_cmp_nlt_f32  vcc, v79, v201", 0x7c1d934fU, 0, false, true, "" },
1081    { "    v_cmp_nlt_f32  s[42:43], v50, v107", 0xd01c002aU, 0x0002d732U, true, true, "" },
1082    { "    v_cmp_tru_f32  vcc, v79, v201", 0x7c1f934fU, 0, false, true, "" },
1083    { "    v_cmp_tru_f32  s[42:43], v50, v107", 0xd01e002aU, 0x0002d732U, true, true, "" },
1084    { "    v_cmp_t_f32  vcc, v79, v201", 0x7c1f934fU, 0, false, true, "" },
1085    { "    v_cmp_t_f32  s[42:43], v50, v107", 0xd01e002aU, 0x0002d732U, true, true, "" },
1086   
1087    { "    v_cmpx_f_f32  vcc, v79, v201", 0x7c21934fU, 0, false, true, "" },
1088    { "    v_cmpx_f_f32  s[42:43], v50, v107", 0xd020002aU, 0x0002d732U, true, true, "" },
1089    { "    v_cmpx_lt_f32  vcc, v79, v201", 0x7c23934fU, 0, false, true, "" },
1090    { "    v_cmpx_lt_f32  s[42:43], v50, v107", 0xd022002aU, 0x0002d732U, true, true, "" },
1091    { "    v_cmpx_eq_f32  vcc, v79, v201", 0x7c25934fU, 0, false, true, "" },
1092    { "    v_cmpx_eq_f32  s[42:43], v50, v107", 0xd024002aU, 0x0002d732U, true, true, "" },
1093    { "    v_cmpx_le_f32  vcc, v79, v201", 0x7c27934fU, 0, false, true, "" },
1094    { "    v_cmpx_le_f32  s[42:43], v50, v107", 0xd026002aU, 0x0002d732U, true, true, "" },
1095    { "    v_cmpx_gt_f32  vcc, v79, v201", 0x7c29934fU, 0, false, true, "" },
1096    { "    v_cmpx_gt_f32  s[42:43], v50, v107", 0xd028002aU, 0x0002d732U, true, true, "" },
1097    { "    v_cmpx_lg_f32  vcc, v79, v201", 0x7c2b934fU, 0, false, true, "" },
1098    { "    v_cmpx_lg_f32  s[42:43], v50, v107", 0xd02a002aU, 0x0002d732U, true, true, "" },
1099    { "    v_cmpx_ge_f32  vcc, v79, v201", 0x7c2d934fU, 0, false, true, "" },
1100    { "    v_cmpx_ge_f32  s[42:43], v50, v107", 0xd02c002aU, 0x0002d732U, true, true, "" },
1101    { "    v_cmpx_o_f32  vcc, v79, v201", 0x7c2f934fU, 0, false, true, "" },
1102    { "    v_cmpx_o_f32  s[42:43], v50, v107", 0xd02e002aU, 0x0002d732U, true, true, "" },
1103    { "    v_cmpx_u_f32  vcc, v79, v201", 0x7c31934fU, 0, false, true, "" },
1104    { "    v_cmpx_u_f32  s[42:43], v50, v107", 0xd030002aU, 0x0002d732U, true, true, "" },
1105    { "    v_cmpx_nge_f32  vcc, v79, v201", 0x7c33934fU, 0, false, true, "" },
1106    { "    v_cmpx_nge_f32  s[42:43], v50, v107", 0xd032002aU, 0x0002d732U, true, true, "" },
1107    { "    v_cmpx_nlg_f32  vcc, v79, v201", 0x7c35934fU, 0, false, true, "" },
1108    { "    v_cmpx_nlg_f32  s[42:43], v50, v107", 0xd034002aU, 0x0002d732U, true, true, "" },
1109    { "    v_cmpx_ngt_f32  vcc, v79, v201", 0x7c37934fU, 0, false, true, "" },
1110    { "    v_cmpx_ngt_f32  s[42:43], v50, v107", 0xd036002aU, 0x0002d732U, true, true, "" },
1111    { "    v_cmpx_nle_f32  vcc, v79, v201", 0x7c39934fU, 0, false, true, "" },
1112    { "    v_cmpx_nle_f32  s[42:43], v50, v107", 0xd038002aU, 0x0002d732U, true, true, "" },
1113    { "    v_cmpx_neq_f32  vcc, v79, v201", 0x7c3b934fU, 0, false, true, "" },
1114    { "    v_cmpx_neq_f32  s[42:43], v50, v107", 0xd03a002aU, 0x0002d732U, true, true, "" },
1115    { "    v_cmpx_nlt_f32  vcc, v79, v201", 0x7c3d934fU, 0, false, true, "" },
1116    { "    v_cmpx_nlt_f32  s[42:43], v50, v107", 0xd03c002aU, 0x0002d732U, true, true, "" },
1117    { "    v_cmpx_tru_f32  vcc, v79, v201", 0x7c3f934fU, 0, false, true, "" },
1118    { "    v_cmpx_tru_f32  s[42:43], v50, v107", 0xd03e002aU, 0x0002d732U, true, true, "" },
1119    { "    v_cmpx_t_f32  vcc, v79, v201", 0x7c3f934fU, 0, false, true, "" },
1120    { "    v_cmpx_t_f32  s[42:43], v50, v107", 0xd03e002aU, 0x0002d732U, true, true, "" },
1121   
1122    { "    v_cmp_f_f64  vcc, v[79:80], v[201:202]", 0x7c41934fU, 0, false, true, "" },
1123    { "    v_cmp_f_f64  s[42:43], v[50:51], v[107:108]",
1124        0xd040002aU, 0x0002d732U, true, true, "" },
1125    { "    v_cmp_lt_f64  vcc, v[79:80], v[201:202]", 0x7c43934fU, 0, false, true, "" },
1126    { "    v_cmp_lt_f64  s[42:43], v[50:51], v[107:108]",
1127        0xd042002aU, 0x0002d732U, true, true, "" },
1128    { "    v_cmp_eq_f64  vcc, v[79:80], v[201:202]", 0x7c45934fU, 0, false, true, "" },
1129    { "    v_cmp_eq_f64  s[42:43], v[50:51], v[107:108]",
1130        0xd044002aU, 0x0002d732U, true, true, "" },
1131    { "    v_cmp_le_f64  vcc, v[79:80], v[201:202]", 0x7c47934fU, 0, false, true, "" },
1132    { "    v_cmp_le_f64  s[42:43], v[50:51], v[107:108]",
1133        0xd046002aU, 0x0002d732U, true, true, "" },
1134    { "    v_cmp_gt_f64  vcc, v[79:80], v[201:202]", 0x7c49934fU, 0, false, true, "" },
1135    { "    v_cmp_gt_f64  s[42:43], v[50:51], v[107:108]",
1136        0xd048002aU, 0x0002d732U, true, true, "" },
1137    { "    v_cmp_lg_f64  vcc, v[79:80], v[201:202]", 0x7c4b934fU, 0, false, true, "" },
1138    { "    v_cmp_lg_f64  s[42:43], v[50:51], v[107:108]",
1139        0xd04a002aU, 0x0002d732U, true, true, "" },
1140    { "    v_cmp_ge_f64  vcc, v[79:80], v[201:202]", 0x7c4d934fU, 0, false, true, "" },
1141    { "    v_cmp_ge_f64  s[42:43], v[50:51], v[107:108]",
1142        0xd04c002aU, 0x0002d732U, true, true, "" },
1143    { "    v_cmp_o_f64  vcc, v[79:80], v[201:202]", 0x7c4f934fU, 0, false, true, "" },
1144    { "    v_cmp_o_f64  s[42:43], v[50:51], v[107:108]",
1145        0xd04e002aU, 0x0002d732U, true, true, "" },
1146    { "    v_cmp_u_f64  vcc, v[79:80], v[201:202]", 0x7c51934fU, 0, false, true, "" },
1147    { "    v_cmp_u_f64  s[42:43], v[50:51], v[107:108]",
1148        0xd050002aU, 0x0002d732U, true, true, "" },
1149    { "    v_cmp_nge_f64  vcc, v[79:80], v[201:202]", 0x7c53934fU, 0, false, true, "" },
1150    { "    v_cmp_nge_f64  s[42:43], v[50:51], v[107:108]",
1151        0xd052002aU, 0x0002d732U, true, true, "" },
1152    { "    v_cmp_nlg_f64  vcc, v[79:80], v[201:202]", 0x7c55934fU, 0, false, true, "" },
1153    { "    v_cmp_nlg_f64  s[42:43], v[50:51], v[107:108]",
1154        0xd054002aU, 0x0002d732U, true, true, "" },
1155    { "    v_cmp_ngt_f64  vcc, v[79:80], v[201:202]", 0x7c57934fU, 0, false, true, "" },
1156    { "    v_cmp_ngt_f64  s[42:43], v[50:51], v[107:108]",
1157        0xd056002aU, 0x0002d732U, true, true, "" },
1158    { "    v_cmp_nle_f64  vcc, v[79:80], v[201:202]", 0x7c59934fU, 0, false, true, "" },
1159    { "    v_cmp_nle_f64  s[42:43], v[50:51], v[107:108]",
1160        0xd058002aU, 0x0002d732U, true, true, "" },
1161    { "    v_cmp_neq_f64  vcc, v[79:80], v[201:202]", 0x7c5b934fU, 0, false, true, "" },
1162    { "    v_cmp_neq_f64  s[42:43], v[50:51], v[107:108]",
1163        0xd05a002aU, 0x0002d732U, true, true, "" },
1164    { "    v_cmp_nlt_f64  vcc, v[79:80], v[201:202]", 0x7c5d934fU, 0, false, true, "" },
1165    { "    v_cmp_nlt_f64  s[42:43], v[50:51], v[107:108]",
1166        0xd05c002aU, 0x0002d732U, true, true, "" },
1167    { "    v_cmp_tru_f64  vcc, v[79:80], v[201:202]", 0x7c5f934fU, 0, false, true, "" },
1168    { "    v_cmp_tru_f64  s[42:43], v[50:51], v[107:108]",
1169        0xd05e002aU, 0x0002d732U, true, true, "" },
1170    { "    v_cmp_t_f64  vcc, v[79:80], v[201:202]", 0x7c5f934fU, 0, false, true, "" },
1171    { "    v_cmp_t_f64  s[42:43], v[50:51], v[107:108]",
1172        0xd05e002aU, 0x0002d732U, true, true, "" },
1173   
1174    { "    v_cmpx_f_f64  vcc, v[79:80], v[201:202]", 0x7c61934fU, 0, false, true, "" },
1175    { "    v_cmpx_f_f64  s[42:43], v[50:51], v[107:108]",
1176        0xd060002aU, 0x0002d732U, true, true, "" },
1177    { "    v_cmpx_lt_f64  vcc, v[79:80], v[201:202]", 0x7c63934fU, 0, false, true, "" },
1178    { "    v_cmpx_lt_f64  s[42:43], v[50:51], v[107:108]",
1179        0xd062002aU, 0x0002d732U, true, true, "" },
1180    { "    v_cmpx_eq_f64  vcc, v[79:80], v[201:202]", 0x7c65934fU, 0, false, true, "" },
1181    { "    v_cmpx_eq_f64  s[42:43], v[50:51], v[107:108]",
1182        0xd064002aU, 0x0002d732U, true, true, "" },
1183    { "    v_cmpx_le_f64  vcc, v[79:80], v[201:202]", 0x7c67934fU, 0, false, true, "" },
1184    { "    v_cmpx_le_f64  s[42:43], v[50:51], v[107:108]",
1185        0xd066002aU, 0x0002d732U, true, true, "" },
1186    { "    v_cmpx_gt_f64  vcc, v[79:80], v[201:202]", 0x7c69934fU, 0, false, true, "" },
1187    { "    v_cmpx_gt_f64  s[42:43], v[50:51], v[107:108]",
1188        0xd068002aU, 0x0002d732U, true, true, "" },
1189    { "    v_cmpx_lg_f64  vcc, v[79:80], v[201:202]", 0x7c6b934fU, 0, false, true, "" },
1190    { "    v_cmpx_lg_f64  s[42:43], v[50:51], v[107:108]",
1191        0xd06a002aU, 0x0002d732U, true, true, "" },
1192    { "    v_cmpx_ge_f64  vcc, v[79:80], v[201:202]", 0x7c6d934fU, 0, false, true, "" },
1193    { "    v_cmpx_ge_f64  s[42:43], v[50:51], v[107:108]",
1194        0xd06c002aU, 0x0002d732U, true, true, "" },
1195    { "    v_cmpx_o_f64  vcc, v[79:80], v[201:202]", 0x7c6f934fU, 0, false, true, "" },
1196    { "    v_cmpx_o_f64  s[42:43], v[50:51], v[107:108]",
1197        0xd06e002aU, 0x0002d732U, true, true, "" },
1198    { "    v_cmpx_u_f64  vcc, v[79:80], v[201:202]", 0x7c71934fU, 0, false, true, "" },
1199    { "    v_cmpx_u_f64  s[42:43], v[50:51], v[107:108]",
1200        0xd070002aU, 0x0002d732U, true, true, "" },
1201    { "    v_cmpx_nge_f64  vcc, v[79:80], v[201:202]", 0x7c73934fU, 0, false, true, "" },
1202    { "    v_cmpx_nge_f64  s[42:43], v[50:51], v[107:108]",
1203        0xd072002aU, 0x0002d732U, true, true, "" },
1204    { "    v_cmpx_nlg_f64  vcc, v[79:80], v[201:202]", 0x7c75934fU, 0, false, true, "" },
1205    { "    v_cmpx_nlg_f64  s[42:43], v[50:51], v[107:108]",
1206        0xd074002aU, 0x0002d732U, true, true, "" },
1207    { "    v_cmpx_ngt_f64  vcc, v[79:80], v[201:202]", 0x7c77934fU, 0, false, true, "" },
1208    { "    v_cmpx_ngt_f64  s[42:43], v[50:51], v[107:108]",
1209        0xd076002aU, 0x0002d732U, true, true, "" },
1210    { "    v_cmpx_nle_f64  vcc, v[79:80], v[201:202]", 0x7c79934fU, 0, false, true, "" },
1211    { "    v_cmpx_nle_f64  s[42:43], v[50:51], v[107:108]",
1212        0xd078002aU, 0x0002d732U, true, true, "" },
1213    { "    v_cmpx_neq_f64  vcc, v[79:80], v[201:202]", 0x7c7b934fU, 0, false, true, "" },
1214    { "    v_cmpx_neq_f64  s[42:43], v[50:51], v[107:108]",
1215        0xd07a002aU, 0x0002d732U, true, true, "" },
1216    { "    v_cmpx_nlt_f64  vcc, v[79:80], v[201:202]", 0x7c7d934fU, 0, false, true, "" },
1217    { "    v_cmpx_nlt_f64  s[42:43], v[50:51], v[107:108]",
1218        0xd07c002aU, 0x0002d732U, true, true, "" },
1219    { "    v_cmpx_tru_f64  vcc, v[79:80], v[201:202]", 0x7c7f934fU, 0, false, true, "" },
1220    { "    v_cmpx_tru_f64  s[42:43], v[50:51], v[107:108]",
1221        0xd07e002aU, 0x0002d732U, true, true, "" },
1222    { "    v_cmpx_t_f64  vcc, v[79:80], v[201:202]", 0x7c7f934fU, 0, false, true, "" },
1223    { "    v_cmpx_t_f64  s[42:43], v[50:51], v[107:108]",
1224        0xd07e002aU, 0x0002d732U, true, true, "" },
1225   
1226    { "    v_cmps_f_f32  vcc, v79, v201", 0x7c81934fU, 0, false, true, "" },
1227    { "    v_cmps_f_f32  s[42:43], v50, v107", 0xd080002aU, 0x0002d732U, true, true, "" },
1228    { "    v_cmps_lt_f32  vcc, v79, v201", 0x7c83934fU, 0, false, true, "" },
1229    { "    v_cmps_lt_f32  s[42:43], v50, v107", 0xd082002aU, 0x0002d732U, true, true, "" },
1230    { "    v_cmps_eq_f32  vcc, v79, v201", 0x7c85934fU, 0, false, true, "" },
1231    { "    v_cmps_eq_f32  s[42:43], v50, v107", 0xd084002aU, 0x0002d732U, true, true, "" },
1232    { "    v_cmps_le_f32  vcc, v79, v201", 0x7c87934fU, 0, false, true, "" },
1233    { "    v_cmps_le_f32  s[42:43], v50, v107", 0xd086002aU, 0x0002d732U, true, true, "" },
1234    { "    v_cmps_gt_f32  vcc, v79, v201", 0x7c89934fU, 0, false, true, "" },
1235    { "    v_cmps_gt_f32  s[42:43], v50, v107", 0xd088002aU, 0x0002d732U, true, true, "" },
1236    { "    v_cmps_lg_f32  vcc, v79, v201", 0x7c8b934fU, 0, false, true, "" },
1237    { "    v_cmps_lg_f32  s[42:43], v50, v107", 0xd08a002aU, 0x0002d732U, true, true, "" },
1238    { "    v_cmps_ge_f32  vcc, v79, v201", 0x7c8d934fU, 0, false, true, "" },
1239    { "    v_cmps_ge_f32  s[42:43], v50, v107", 0xd08c002aU, 0x0002d732U, true, true, "" },
1240    { "    v_cmps_o_f32  vcc, v79, v201", 0x7c8f934fU, 0, false, true, "" },
1241    { "    v_cmps_o_f32  s[42:43], v50, v107", 0xd08e002aU, 0x0002d732U, true, true, "" },
1242    { "    v_cmps_u_f32  vcc, v79, v201", 0x7c91934fU, 0, false, true, "" },
1243    { "    v_cmps_u_f32  s[42:43], v50, v107", 0xd090002aU, 0x0002d732U, true, true, "" },
1244    { "    v_cmps_nge_f32  vcc, v79, v201", 0x7c93934fU, 0, false, true, "" },
1245    { "    v_cmps_nge_f32  s[42:43], v50, v107", 0xd092002aU, 0x0002d732U, true, true, "" },
1246    { "    v_cmps_nlg_f32  vcc, v79, v201", 0x7c95934fU, 0, false, true, "" },
1247    { "    v_cmps_nlg_f32  s[42:43], v50, v107", 0xd094002aU, 0x0002d732U, true, true, "" },
1248    { "    v_cmps_ngt_f32  vcc, v79, v201", 0x7c97934fU, 0, false, true, "" },
1249    { "    v_cmps_ngt_f32  s[42:43], v50, v107", 0xd096002aU, 0x0002d732U, true, true, "" },
1250    { "    v_cmps_nle_f32  vcc, v79, v201", 0x7c99934fU, 0, false, true, "" },
1251    { "    v_cmps_nle_f32  s[42:43], v50, v107", 0xd098002aU, 0x0002d732U, true, true, "" },
1252    { "    v_cmps_neq_f32  vcc, v79, v201", 0x7c9b934fU, 0, false, true, "" },
1253    { "    v_cmps_neq_f32  s[42:43], v50, v107", 0xd09a002aU, 0x0002d732U, true, true, "" },
1254    { "    v_cmps_nlt_f32  vcc, v79, v201", 0x7c9d934fU, 0, false, true, "" },
1255    { "    v_cmps_nlt_f32  s[42:43], v50, v107", 0xd09c002aU, 0x0002d732U, true, true, "" },
1256    { "    v_cmps_tru_f32  vcc, v79, v201", 0x7c9f934fU, 0, false, true, "" },
1257    { "    v_cmps_tru_f32  s[42:43], v50, v107", 0xd09e002aU, 0x0002d732U, true, true, "" },
1258    { "    v_cmps_t_f32  vcc, v79, v201", 0x7c9f934fU, 0, false, true, "" },
1259    { "    v_cmps_t_f32  s[42:43], v50, v107", 0xd09e002aU, 0x0002d732U, true, true, "" },
1260   
1261    { "    v_cmpsx_f_f32  vcc, v79, v201", 0x7ca1934fU, 0, false, true, "" },
1262    { "    v_cmpsx_f_f32  s[42:43], v50, v107", 0xd0a0002aU, 0x0002d732U, true, true, "" },
1263    { "    v_cmpsx_lt_f32  vcc, v79, v201", 0x7ca3934fU, 0, false, true, "" },
1264    { "    v_cmpsx_lt_f32  s[42:43], v50, v107", 0xd0a2002aU, 0x0002d732U, true, true, "" },
1265    { "    v_cmpsx_eq_f32  vcc, v79, v201", 0x7ca5934fU, 0, false, true, "" },
1266    { "    v_cmpsx_eq_f32  s[42:43], v50, v107", 0xd0a4002aU, 0x0002d732U, true, true, "" },
1267    { "    v_cmpsx_le_f32  vcc, v79, v201", 0x7ca7934fU, 0, false, true, "" },
1268    { "    v_cmpsx_le_f32  s[42:43], v50, v107", 0xd0a6002aU, 0x0002d732U, true, true, "" },
1269    { "    v_cmpsx_gt_f32  vcc, v79, v201", 0x7ca9934fU, 0, false, true, "" },
1270    { "    v_cmpsx_gt_f32  s[42:43], v50, v107", 0xd0a8002aU, 0x0002d732U, true, true, "" },
1271    { "    v_cmpsx_lg_f32  vcc, v79, v201", 0x7cab934fU, 0, false, true, "" },
1272    { "    v_cmpsx_lg_f32  s[42:43], v50, v107", 0xd0aa002aU, 0x0002d732U, true, true, "" },
1273    { "    v_cmpsx_ge_f32  vcc, v79, v201", 0x7cad934fU, 0, false, true, "" },
1274    { "    v_cmpsx_ge_f32  s[42:43], v50, v107", 0xd0ac002aU, 0x0002d732U, true, true, "" },
1275    { "    v_cmpsx_o_f32  vcc, v79, v201", 0x7caf934fU, 0, false, true, "" },
1276    { "    v_cmpsx_o_f32  s[42:43], v50, v107", 0xd0ae002aU, 0x0002d732U, true, true, "" },
1277    { "    v_cmpsx_u_f32  vcc, v79, v201", 0x7cb1934fU, 0, false, true, "" },
1278    { "    v_cmpsx_u_f32  s[42:43], v50, v107", 0xd0b0002aU, 0x0002d732U, true, true, "" },
1279    { "    v_cmpsx_nge_f32  vcc, v79, v201", 0x7cb3934fU, 0, false, true, "" },
1280    { "    v_cmpsx_nge_f32  s[42:43], v50, v107",
1281        0xd0b2002aU, 0x0002d732U, true, true, "" },
1282    { "    v_cmpsx_nlg_f32  vcc, v79, v201", 0x7cb5934fU, 0, false, true, "" },
1283    { "    v_cmpsx_nlg_f32  s[42:43], v50, v107",
1284        0xd0b4002aU, 0x0002d732U, true, true, "" },
1285    { "    v_cmpsx_ngt_f32  vcc, v79, v201", 0x7cb7934fU, 0, false, true, "" },
1286    { "    v_cmpsx_ngt_f32  s[42:43], v50, v107",
1287        0xd0b6002aU, 0x0002d732U, true, true, "" },
1288    { "    v_cmpsx_nle_f32  vcc, v79, v201", 0x7cb9934fU, 0, false, true, "" },
1289    { "    v_cmpsx_nle_f32  s[42:43], v50, v107",
1290        0xd0b8002aU, 0x0002d732U, true, true, "" },
1291    { "    v_cmpsx_neq_f32  vcc, v79, v201", 0x7cbb934fU, 0, false, true, "" },
1292    { "    v_cmpsx_neq_f32  s[42:43], v50, v107",
1293        0xd0ba002aU, 0x0002d732U, true, true, "" },
1294    { "    v_cmpsx_nlt_f32  vcc, v79, v201", 0x7cbd934fU, 0, false, true, "" },
1295    { "    v_cmpsx_nlt_f32  s[42:43], v50, v107",
1296        0xd0bc002aU, 0x0002d732U, true, true, "" },
1297    { "    v_cmpsx_tru_f32  vcc, v79, v201", 0x7cbf934fU, 0, false, true, "" },
1298    { "    v_cmpsx_tru_f32  s[42:43], v50, v107",
1299        0xd0be002aU, 0x0002d732U, true, true, "" },
1300    { "    v_cmpsx_t_f32  vcc, v79, v201", 0x7cbf934fU, 0, false, true, "" },
1301    { "    v_cmpsx_t_f32  s[42:43], v50, v107",
1302        0xd0be002aU, 0x0002d732U, true, true, "" },
1303   
1304    { "    v_cmps_f_f64  vcc, v[79:80], v[201:202]", 0x7cc1934fU, 0, false, true, "" },
1305    { "    v_cmps_f_f64  s[42:43], v[50:51], v[107:108]",
1306        0xd0c0002aU, 0x0002d732U, true, true, "" },
1307    { "    v_cmps_lt_f64  vcc, v[79:80], v[201:202]", 0x7cc3934fU, 0, false, true, "" },
1308    { "    v_cmps_lt_f64  s[42:43], v[50:51], v[107:108]",
1309        0xd0c2002aU, 0x0002d732U, true, true, "" },
1310    { "    v_cmps_eq_f64  vcc, v[79:80], v[201:202]", 0x7cc5934fU, 0, false, true, "" },
1311    { "    v_cmps_eq_f64  s[42:43], v[50:51], v[107:108]",
1312        0xd0c4002aU, 0x0002d732U, true, true, "" },
1313    { "    v_cmps_le_f64  vcc, v[79:80], v[201:202]", 0x7cc7934fU, 0, false, true, "" },
1314    { "    v_cmps_le_f64  s[42:43], v[50:51], v[107:108]",
1315        0xd0c6002aU, 0x0002d732U, true, true, "" },
1316    { "    v_cmps_gt_f64  vcc, v[79:80], v[201:202]", 0x7cc9934fU, 0, false, true, "" },
1317    { "    v_cmps_gt_f64  s[42:43], v[50:51], v[107:108]",
1318        0xd0c8002aU, 0x0002d732U, true, true, "" },
1319    { "    v_cmps_lg_f64  vcc, v[79:80], v[201:202]", 0x7ccb934fU, 0, false, true, "" },
1320    { "    v_cmps_lg_f64  s[42:43], v[50:51], v[107:108]",
1321        0xd0ca002aU, 0x0002d732U, true, true, "" },
1322    { "    v_cmps_ge_f64  vcc, v[79:80], v[201:202]", 0x7ccd934fU, 0, false, true, "" },
1323    { "    v_cmps_ge_f64  s[42:43], v[50:51], v[107:108]",
1324        0xd0cc002aU, 0x0002d732U, true, true, "" },
1325    { "    v_cmps_o_f64  vcc, v[79:80], v[201:202]", 0x7ccf934fU, 0, false, true, "" },
1326    { "    v_cmps_o_f64  s[42:43], v[50:51], v[107:108]",
1327        0xd0ce002aU, 0x0002d732U, true, true, "" },
1328    { "    v_cmps_u_f64  vcc, v[79:80], v[201:202]", 0x7cd1934fU, 0, false, true, "" },
1329    { "    v_cmps_u_f64  s[42:43], v[50:51], v[107:108]",
1330        0xd0d0002aU, 0x0002d732U, true, true, "" },
1331    { "    v_cmps_nge_f64  vcc, v[79:80], v[201:202]", 0x7cd3934fU, 0, false, true, "" },
1332    { "    v_cmps_nge_f64  s[42:43], v[50:51], v[107:108]",
1333        0xd0d2002aU, 0x0002d732U, true, true, "" },
1334    { "    v_cmps_nlg_f64  vcc, v[79:80], v[201:202]", 0x7cd5934fU, 0, false, true, "" },
1335    { "    v_cmps_nlg_f64  s[42:43], v[50:51], v[107:108]",
1336        0xd0d4002aU, 0x0002d732U, true, true, "" },
1337    { "    v_cmps_ngt_f64  vcc, v[79:80], v[201:202]", 0x7cd7934fU, 0, false, true, "" },
1338    { "    v_cmps_ngt_f64  s[42:43], v[50:51], v[107:108]",
1339        0xd0d6002aU, 0x0002d732U, true, true, "" },
1340    { "    v_cmps_nle_f64  vcc, v[79:80], v[201:202]", 0x7cd9934fU, 0, false, true, "" },
1341    { "    v_cmps_nle_f64  s[42:43], v[50:51], v[107:108]",
1342        0xd0d8002aU, 0x0002d732U, true, true, "" },
1343    { "    v_cmps_neq_f64  vcc, v[79:80], v[201:202]", 0x7cdb934fU, 0, false, true, "" },
1344    { "    v_cmps_neq_f64  s[42:43], v[50:51], v[107:108]",
1345        0xd0da002aU, 0x0002d732U, true, true, "" },
1346    { "    v_cmps_nlt_f64  vcc, v[79:80], v[201:202]", 0x7cdd934fU, 0, false, true, "" },
1347    { "    v_cmps_nlt_f64  s[42:43], v[50:51], v[107:108]",
1348        0xd0dc002aU, 0x0002d732U, true, true, "" },
1349    { "    v_cmps_tru_f64  vcc, v[79:80], v[201:202]", 0x7cdf934fU, 0, false, true, "" },
1350    { "    v_cmps_tru_f64  s[42:43], v[50:51], v[107:108]",
1351        0xd0de002aU, 0x0002d732U, true, true, "" },
1352    { "    v_cmps_t_f64  vcc, v[79:80], v[201:202]", 0x7cdf934fU, 0, false, true, "" },
1353    { "    v_cmps_t_f64  s[42:43], v[50:51], v[107:108]",
1354        0xd0de002aU, 0x0002d732U, true, true, "" },
1355   
1356    { "    v_cmpsx_f_f64  vcc, v[79:80], v[201:202]", 0x7ce1934fU, 0, false, true, "" },
1357    { "    v_cmpsx_f_f64  s[42:43], v[50:51], v[107:108]",
1358        0xd0e0002aU, 0x0002d732U, true, true, "" },
1359    { "    v_cmpsx_lt_f64  vcc, v[79:80], v[201:202]", 0x7ce3934fU, 0, false, true, "" },
1360    { "    v_cmpsx_lt_f64  s[42:43], v[50:51], v[107:108]",
1361        0xd0e2002aU, 0x0002d732U, true, true, "" },
1362    { "    v_cmpsx_eq_f64  vcc, v[79:80], v[201:202]", 0x7ce5934fU, 0, false, true, "" },
1363    { "    v_cmpsx_eq_f64  s[42:43], v[50:51], v[107:108]",
1364        0xd0e4002aU, 0x0002d732U, true, true, "" },
1365    { "    v_cmpsx_le_f64  vcc, v[79:80], v[201:202]", 0x7ce7934fU, 0, false, true, "" },
1366    { "    v_cmpsx_le_f64  s[42:43], v[50:51], v[107:108]",
1367        0xd0e6002aU, 0x0002d732U, true, true, "" },
1368    { "    v_cmpsx_gt_f64  vcc, v[79:80], v[201:202]", 0x7ce9934fU, 0, false, true, "" },
1369    { "    v_cmpsx_gt_f64  s[42:43], v[50:51], v[107:108]",
1370        0xd0e8002aU, 0x0002d732U, true, true, "" },
1371    { "    v_cmpsx_lg_f64  vcc, v[79:80], v[201:202]", 0x7ceb934fU, 0, false, true, "" },
1372    { "    v_cmpsx_lg_f64  s[42:43], v[50:51], v[107:108]",
1373        0xd0ea002aU, 0x0002d732U, true, true, "" },
1374    { "    v_cmpsx_ge_f64  vcc, v[79:80], v[201:202]", 0x7ced934fU, 0, false, true, "" },
1375    { "    v_cmpsx_ge_f64  s[42:43], v[50:51], v[107:108]",
1376        0xd0ec002aU, 0x0002d732U, true, true, "" },
1377    { "    v_cmpsx_o_f64  vcc, v[79:80], v[201:202]", 0x7cef934fU, 0, false, true, "" },
1378    { "    v_cmpsx_o_f64  s[42:43], v[50:51], v[107:108]",
1379        0xd0ee002aU, 0x0002d732U, true, true, "" },
1380    { "    v_cmpsx_u_f64  vcc, v[79:80], v[201:202]", 0x7cf1934fU, 0, false, true, "" },
1381    { "    v_cmpsx_u_f64  s[42:43], v[50:51], v[107:108]",
1382        0xd0f0002aU, 0x0002d732U, true, true, "" },
1383    { "    v_cmpsx_nge_f64  vcc, v[79:80], v[201:202]", 0x7cf3934fU, 0, false, true, "" },
1384    { "    v_cmpsx_nge_f64  s[42:43], v[50:51], v[107:108]",
1385        0xd0f2002aU, 0x0002d732U, true, true, "" },
1386    { "    v_cmpsx_nlg_f64  vcc, v[79:80], v[201:202]", 0x7cf5934fU, 0, false, true, "" },
1387    { "    v_cmpsx_nlg_f64  s[42:43], v[50:51], v[107:108]",
1388        0xd0f4002aU, 0x0002d732U, true, true, "" },
1389    { "    v_cmpsx_ngt_f64  vcc, v[79:80], v[201:202]", 0x7cf7934fU, 0, false, true, "" },
1390    { "    v_cmpsx_ngt_f64  s[42:43], v[50:51], v[107:108]",
1391        0xd0f6002aU, 0x0002d732U, true, true, "" },
1392    { "    v_cmpsx_nle_f64  vcc, v[79:80], v[201:202]", 0x7cf9934fU, 0, false, true, "" },
1393    { "    v_cmpsx_nle_f64  s[42:43], v[50:51], v[107:108]",
1394        0xd0f8002aU, 0x0002d732U, true, true, "" },
1395    { "    v_cmpsx_neq_f64  vcc, v[79:80], v[201:202]", 0x7cfb934fU, 0, false, true, "" },
1396    { "    v_cmpsx_neq_f64  s[42:43], v[50:51], v[107:108]",
1397        0xd0fa002aU, 0x0002d732U, true, true, "" },
1398    { "    v_cmpsx_nlt_f64  vcc, v[79:80], v[201:202]", 0x7cfd934fU, 0, false, true, "" },
1399    { "    v_cmpsx_nlt_f64  s[42:43], v[50:51], v[107:108]",
1400        0xd0fc002aU, 0x0002d732U, true, true, "" },
1401    { "    v_cmpsx_tru_f64  vcc, v[79:80], v[201:202]", 0x7cff934fU, 0, false, true, "" },
1402    { "    v_cmpsx_tru_f64  s[42:43], v[50:51], v[107:108]",
1403        0xd0fe002aU, 0x0002d732U, true, true, "" },
1404    { "    v_cmpsx_t_f64  vcc, v[79:80], v[201:202]", 0x7cff934fU, 0, false, true, "" },
1405    { "    v_cmpsx_t_f64  s[42:43], v[50:51], v[107:108]",
1406        0xd0fe002aU, 0x0002d732U, true, true, "" },
1407   
1408    { "    v_cmp_f_i32  vcc, v79, v201", 0x7d01934fU, 0, false, true, "" },
1409    { "    v_cmp_f_i32  s[42:43], v50, v107", 0xd100002aU, 0x0002d732U, true, true, "" },
1410    { "    v_cmp_lt_i32  vcc, v79, v201", 0x7d03934fU, 0, false, true, "" },
1411    { "    v_cmp_lt_i32  s[42:43], v50, v107", 0xd102002aU, 0x0002d732U, true, true, "" },
1412    { "    v_cmp_eq_i32  vcc, v79, v201", 0x7d05934fU, 0, false, true, "" },
1413    { "    v_cmp_eq_i32  s[42:43], v50, v107", 0xd104002aU, 0x0002d732U, true, true, "" },
1414    { "    v_cmp_le_i32  vcc, v79, v201", 0x7d07934fU, 0, false, true, "" },
1415    { "    v_cmp_le_i32  s[42:43], v50, v107", 0xd106002aU, 0x0002d732U, true, true, "" },
1416    { "    v_cmp_gt_i32  vcc, v79, v201", 0x7d09934fU, 0, false, true, "" },
1417    { "    v_cmp_gt_i32  s[42:43], v50, v107", 0xd108002aU, 0x0002d732U, true, true, "" },
1418    { "    v_cmp_lg_i32  vcc, v79, v201", 0x7d0b934fU, 0, false, true, "" },
1419    { "    v_cmp_lg_i32  s[42:43], v50, v107", 0xd10a002aU, 0x0002d732U, true, true, "" },
1420    { "    v_cmp_ne_i32  vcc, v79, v201", 0x7d0b934fU, 0, false, true, "" },
1421    { "    v_cmp_ne_i32  s[42:43], v50, v107", 0xd10a002aU, 0x0002d732U, true, true, "" },
1422    { "    v_cmp_ge_i32  vcc, v79, v201", 0x7d0d934fU, 0, false, true, "" },
1423    { "    v_cmp_ge_i32  s[42:43], v50, v107", 0xd10c002aU, 0x0002d732U, true, true, "" },
1424    { "    v_cmp_tru_i32  vcc, v79, v201", 0x7d0f934fU, 0, false, true, "" },
1425    { "    v_cmp_tru_i32  s[42:43], v50, v107", 0xd10e002aU, 0x0002d732U, true, true, "" },
1426    { "    v_cmp_t_i32  vcc, v79, v201", 0x7d0f934fU, 0, false, true, "" },
1427    { "    v_cmp_t_i32  s[42:43], v50, v107", 0xd10e002aU, 0x0002d732U, true, true, "" },
1428   
1429    { "    v_cmpx_f_i32  vcc, v79, v201", 0x7d21934fU, 0, false, true, "" },
1430    { "    v_cmpx_f_i32  s[42:43], v50, v107", 0xd120002aU, 0x0002d732U, true, true, "" },
1431    { "    v_cmpx_lt_i32  vcc, v79, v201", 0x7d23934fU, 0, false, true, "" },
1432    { "    v_cmpx_lt_i32  s[42:43], v50, v107", 0xd122002aU, 0x0002d732U, true, true, "" },
1433    { "    v_cmpx_eq_i32  vcc, v79, v201", 0x7d25934fU, 0, false, true, "" },
1434    { "    v_cmpx_eq_i32  s[42:43], v50, v107", 0xd124002aU, 0x0002d732U, true, true, "" },
1435    { "    v_cmpx_le_i32  vcc, v79, v201", 0x7d27934fU, 0, false, true, "" },
1436    { "    v_cmpx_le_i32  s[42:43], v50, v107", 0xd126002aU, 0x0002d732U, true, true, "" },
1437    { "    v_cmpx_gt_i32  vcc, v79, v201", 0x7d29934fU, 0, false, true, "" },
1438    { "    v_cmpx_gt_i32  s[42:43], v50, v107", 0xd128002aU, 0x0002d732U, true, true, "" },
1439    { "    v_cmpx_lg_i32  vcc, v79, v201", 0x7d2b934fU, 0, false, true, "" },
1440    { "    v_cmpx_lg_i32  s[42:43], v50, v107", 0xd12a002aU, 0x0002d732U, true, true, "" },
1441    { "    v_cmpx_ne_i32  vcc, v79, v201", 0x7d2b934fU, 0, false, true, "" },
1442    { "    v_cmpx_ne_i32  s[42:43], v50, v107", 0xd12a002aU, 0x0002d732U, true, true, "" },
1443    { "    v_cmpx_ge_i32  vcc, v79, v201", 0x7d2d934fU, 0, false, true, "" },
1444    { "    v_cmpx_ge_i32  s[42:43], v50, v107", 0xd12c002aU, 0x0002d732U, true, true, "" },
1445    { "    v_cmpx_tru_i32  vcc, v79, v201", 0x7d2f934fU, 0, false, true, "" },
1446    { "    v_cmpx_tru_i32  s[42:43], v50, v107", 0xd12e002aU, 0x0002d732U, true, true, "" },
1447    { "    v_cmpx_t_i32  vcc, v79, v201", 0x7d2f934fU, 0, false, true, "" },
1448    { "    v_cmpx_t_i32  s[42:43], v50, v107", 0xd12e002aU, 0x0002d732U, true, true, "" },
1449   
1450    { "    v_cmp_f_i64  vcc, v[79:80], v[201:202]", 0x7d41934fU, 0, false, true, "" },
1451    { "    v_cmp_f_i64  s[42:43], v[50:51], v[107:108]",
1452        0xd140002aU, 0x0002d732U, true, true, "" },
1453    { "    v_cmp_lt_i64  vcc, v[79:80], v[201:202]", 0x7d43934fU, 0, false, true, "" },
1454    { "    v_cmp_lt_i64  s[42:43], v[50:51], v[107:108]",
1455        0xd142002aU, 0x0002d732U, true, true, "" },
1456    { "    v_cmp_eq_i64  vcc, v[79:80], v[201:202]", 0x7d45934fU, 0, false, true, "" },
1457    { "    v_cmp_eq_i64  s[42:43], v[50:51], v[107:108]",
1458        0xd144002aU, 0x0002d732U, true, true, "" },
1459    { "    v_cmp_le_i64  vcc, v[79:80], v[201:202]", 0x7d47934fU, 0, false, true, "" },
1460    { "    v_cmp_le_i64  s[42:43], v[50:51], v[107:108]",
1461        0xd146002aU, 0x0002d732U, true, true, "" },
1462    { "    v_cmp_gt_i64  vcc, v[79:80], v[201:202]", 0x7d49934fU, 0, false, true, "" },
1463    { "    v_cmp_gt_i64  s[42:43], v[50:51], v[107:108]",
1464        0xd148002aU, 0x0002d732U, true, true, "" },
1465    { "    v_cmp_lg_i64  vcc, v[79:80], v[201:202]", 0x7d4b934fU, 0, false, true, "" },
1466    { "    v_cmp_lg_i64  s[42:43], v[50:51], v[107:108]",
1467        0xd14a002aU, 0x0002d732U, true, true, "" },
1468    { "    v_cmp_ne_i64  vcc, v[79:80], v[201:202]", 0x7d4b934fU, 0, false, true, "" },
1469    { "    v_cmp_ne_i64  s[42:43], v[50:51], v[107:108]",
1470        0xd14a002aU, 0x0002d732U, true, true, "" },
1471    { "    v_cmp_ge_i64  vcc, v[79:80], v[201:202]", 0x7d4d934fU, 0, false, true, "" },
1472    { "    v_cmp_ge_i64  s[42:43], v[50:51], v[107:108]",
1473        0xd14c002aU, 0x0002d732U, true, true, "" },
1474    { "    v_cmp_tru_i64  vcc, v[79:80], v[201:202]", 0x7d4f934fU, 0, false, true, "" },
1475    { "    v_cmp_tru_i64  s[42:43], v[50:51], v[107:108]",
1476        0xd14e002aU, 0x0002d732U, true, true, "" },
1477    { "    v_cmp_t_i64  vcc, v[79:80], v[201:202]", 0x7d4f934fU, 0, false, true, "" },
1478    { "    v_cmp_t_i64  s[42:43], v[50:51], v[107:108]",
1479        0xd14e002aU, 0x0002d732U, true, true, "" },
1480   
1481    { "    v_cmpx_f_i64  vcc, v[79:80], v[201:202]", 0x7d61934fU, 0, false, true, "" },
1482    { "    v_cmpx_f_i64  s[42:43], v[50:51], v[107:108]",
1483        0xd160002aU, 0x0002d732U, true, true, "" },
1484    { "    v_cmpx_lt_i64  vcc, v[79:80], v[201:202]", 0x7d63934fU, 0, false, true, "" },
1485    { "    v_cmpx_lt_i64  s[42:43], v[50:51], v[107:108]",
1486        0xd162002aU, 0x0002d732U, true, true, "" },
1487    { "    v_cmpx_eq_i64  vcc, v[79:80], v[201:202]", 0x7d65934fU, 0, false, true, "" },
1488    { "    v_cmpx_eq_i64  s[42:43], v[50:51], v[107:108]",
1489        0xd164002aU, 0x0002d732U, true, true, "" },
1490    { "    v_cmpx_le_i64  vcc, v[79:80], v[201:202]", 0x7d67934fU, 0, false, true, "" },
1491    { "    v_cmpx_le_i64  s[42:43], v[50:51], v[107:108]",
1492        0xd166002aU, 0x0002d732U, true, true, "" },
1493    { "    v_cmpx_gt_i64  vcc, v[79:80], v[201:202]", 0x7d69934fU, 0, false, true, "" },
1494    { "    v_cmpx_gt_i64  s[42:43], v[50:51], v[107:108]",
1495        0xd168002aU, 0x0002d732U, true, true, "" },
1496    { "    v_cmpx_lg_i64  vcc, v[79:80], v[201:202]", 0x7d6b934fU, 0, false, true, "" },
1497    { "    v_cmpx_lg_i64  s[42:43], v[50:51], v[107:108]",
1498        0xd16a002aU, 0x0002d732U, true, true, "" },
1499    { "    v_cmpx_ne_i64  vcc, v[79:80], v[201:202]", 0x7d6b934fU, 0, false, true, "" },
1500    { "    v_cmpx_ne_i64  s[42:43], v[50:51], v[107:108]",
1501        0xd16a002aU, 0x0002d732U, true, true, "" },
1502    { "    v_cmpx_ge_i64  vcc, v[79:80], v[201:202]", 0x7d6d934fU, 0, false, true, "" },
1503    { "    v_cmpx_ge_i64  s[42:43], v[50:51], v[107:108]",
1504        0xd16c002aU, 0x0002d732U, true, true, "" },
1505    { "    v_cmpx_tru_i64  vcc, v[79:80], v[201:202]", 0x7d6f934fU, 0, false, true, "" },
1506    { "    v_cmpx_tru_i64  s[42:43], v[50:51], v[107:108]",
1507        0xd16e002aU, 0x0002d732U, true, true, "" },
1508    { "    v_cmpx_t_i64  vcc, v[79:80], v[201:202]", 0x7d6f934fU, 0, false, true, "" },
1509    { "    v_cmpx_t_i64  s[42:43], v[50:51], v[107:108]",
1510        0xd16e002aU, 0x0002d732U, true, true, "" },
1511   
1512    { "    v_cmp_f_u32  vcc, v79, v201", 0x7d81934fU, 0, false, true, "" },
1513    { "    v_cmp_f_u32  s[42:43], v50, v107", 0xd180002aU, 0x0002d732U, true, true, "" },
1514    { "    v_cmp_lt_u32  vcc, v79, v201", 0x7d83934fU, 0, false, true, "" },
1515    { "    v_cmp_lt_u32  s[42:43], v50, v107", 0xd182002aU, 0x0002d732U, true, true, "" },
1516    { "    v_cmp_eq_u32  vcc, v79, v201", 0x7d85934fU, 0, false, true, "" },
1517    { "    v_cmp_eq_u32  s[42:43], v50, v107", 0xd184002aU, 0x0002d732U, true, true, "" },
1518    { "    v_cmp_le_u32  vcc, v79, v201", 0x7d87934fU, 0, false, true, "" },
1519    { "    v_cmp_le_u32  s[42:43], v50, v107", 0xd186002aU, 0x0002d732U, true, true, "" },
1520    { "    v_cmp_gt_u32  vcc, v79, v201", 0x7d89934fU, 0, false, true, "" },
1521    { "    v_cmp_gt_u32  s[42:43], v50, v107", 0xd188002aU, 0x0002d732U, true, true, "" },
1522    { "    v_cmp_lg_u32  vcc, v79, v201", 0x7d8b934fU, 0, false, true, "" },
1523    { "    v_cmp_lg_u32  s[42:43], v50, v107", 0xd18a002aU, 0x0002d732U, true, true, "" },
1524    { "    v_cmp_ne_u32  vcc, v79, v201", 0x7d8b934fU, 0, false, true, "" },
1525    { "    v_cmp_ne_u32  s[42:43], v50, v107", 0xd18a002aU, 0x0002d732U, true, true, "" },
1526    { "    v_cmp_ge_u32  vcc, v79, v201", 0x7d8d934fU, 0, false, true, "" },
1527    { "    v_cmp_ge_u32  s[42:43], v50, v107", 0xd18c002aU, 0x0002d732U, true, true, "" },
1528    { "    v_cmp_tru_u32  vcc, v79, v201", 0x7d8f934fU, 0, false, true, "" },
1529    { "    v_cmp_tru_u32  s[42:43], v50, v107", 0xd18e002aU, 0x0002d732U, true, true, "" },
1530    { "    v_cmp_t_u32  vcc, v79, v201", 0x7d8f934fU, 0, false, true, "" },
1531    { "    v_cmp_t_u32  s[42:43], v50, v107", 0xd18e002aU, 0x0002d732U, true, true, "" },
1532   
1533    { "    v_cmpx_f_u32  vcc, v79, v201", 0x7da1934fU, 0, false, true, "" },
1534    { "    v_cmpx_f_u32  s[42:43], v50, v107", 0xd1a0002aU, 0x0002d732U, true, true, "" },
1535    { "    v_cmpx_lt_u32  vcc, v79, v201", 0x7da3934fU, 0, false, true, "" },
1536    { "    v_cmpx_lt_u32  s[42:43], v50, v107", 0xd1a2002aU, 0x0002d732U, true, true, "" },
1537    { "    v_cmpx_eq_u32  vcc, v79, v201", 0x7da5934fU, 0, false, true, "" },
1538    { "    v_cmpx_eq_u32  s[42:43], v50, v107", 0xd1a4002aU, 0x0002d732U, true, true, "" },
1539    { "    v_cmpx_le_u32  vcc, v79, v201", 0x7da7934fU, 0, false, true, "" },
1540    { "    v_cmpx_le_u32  s[42:43], v50, v107", 0xd1a6002aU, 0x0002d732U, true, true, "" },
1541    { "    v_cmpx_gt_u32  vcc, v79, v201", 0x7da9934fU, 0, false, true, "" },
1542    { "    v_cmpx_gt_u32  s[42:43], v50, v107", 0xd1a8002aU, 0x0002d732U, true, true, "" },
1543    { "    v_cmpx_lg_u32  vcc, v79, v201", 0x7dab934fU, 0, false, true, "" },
1544    { "    v_cmpx_lg_u32  s[42:43], v50, v107", 0xd1aa002aU, 0x0002d732U, true, true, "" },
1545    { "    v_cmpx_ne_u32  vcc, v79, v201", 0x7dab934fU, 0, false, true, "" },
1546    { "    v_cmpx_ne_u32  s[42:43], v50, v107", 0xd1aa002aU, 0x0002d732U, true, true, "" },
1547    { "    v_cmpx_ge_u32  vcc, v79, v201", 0x7dad934fU, 0, false, true, "" },
1548    { "    v_cmpx_ge_u32  s[42:43], v50, v107", 0xd1ac002aU, 0x0002d732U, true, true, "" },
1549    { "    v_cmpx_tru_u32  vcc, v79, v201", 0x7daf934fU, 0, false, true, "" },
1550    { "    v_cmpx_tru_u32  s[42:43], v50, v107", 0xd1ae002aU, 0x0002d732U, true, true, "" },
1551    { "    v_cmpx_t_u32  vcc, v79, v201", 0x7daf934fU, 0, false, true, "" },
1552    { "    v_cmpx_t_u32  s[42:43], v50, v107", 0xd1ae002aU, 0x0002d732U, true, true, "" },
1553   
1554    { "    v_cmp_f_u64  vcc, v[79:80], v[201:202]", 0x7dc1934fU, 0, false, true, "" },
1555    { "    v_cmp_f_u64  s[42:43], v[50:51], v[107:108]",
1556        0xd1c0002aU, 0x0002d732U, true, true, "" },
1557    { "    v_cmp_lt_u64  vcc, v[79:80], v[201:202]", 0x7dc3934fU, 0, false, true, "" },
1558    { "    v_cmp_lt_u64  s[42:43], v[50:51], v[107:108]",
1559        0xd1c2002aU, 0x0002d732U, true, true, "" },
1560    { "    v_cmp_eq_u64  vcc, v[79:80], v[201:202]", 0x7dc5934fU, 0, false, true, "" },
1561    { "    v_cmp_eq_u64  s[42:43], v[50:51], v[107:108]",
1562        0xd1c4002aU, 0x0002d732U, true, true, "" },
1563    { "    v_cmp_le_u64  vcc, v[79:80], v[201:202]", 0x7dc7934fU, 0, false, true, "" },
1564    { "    v_cmp_le_u64  s[42:43], v[50:51], v[107:108]",
1565        0xd1c6002aU, 0x0002d732U, true, true, "" },
1566    { "    v_cmp_gt_u64  vcc, v[79:80], v[201:202]", 0x7dc9934fU, 0, false, true, "" },
1567    { "    v_cmp_gt_u64  s[42:43], v[50:51], v[107:108]",
1568        0xd1c8002aU, 0x0002d732U, true, true, "" },
1569    { "    v_cmp_lg_u64  vcc, v[79:80], v[201:202]", 0x7dcb934fU, 0, false, true, "" },
1570    { "    v_cmp_lg_u64  s[42:43], v[50:51], v[107:108]",
1571        0xd1ca002aU, 0x0002d732U, true, true, "" },
1572    { "    v_cmp_ne_u64  vcc, v[79:80], v[201:202]", 0x7dcb934fU, 0, false, true, "" },
1573    { "    v_cmp_ne_u64  s[42:43], v[50:51], v[107:108]",
1574        0xd1ca002aU, 0x0002d732U, true, true, "" },
1575    { "    v_cmp_ge_u64  vcc, v[79:80], v[201:202]", 0x7dcd934fU, 0, false, true, "" },
1576    { "    v_cmp_ge_u64  s[42:43], v[50:51], v[107:108]",
1577        0xd1cc002aU, 0x0002d732U, true, true, "" },
1578    { "    v_cmp_tru_u64  vcc, v[79:80], v[201:202]", 0x7dcf934fU, 0, false, true, "" },
1579    { "    v_cmp_tru_u64  s[42:43], v[50:51], v[107:108]",
1580        0xd1ce002aU, 0x0002d732U, true, true, "" },
1581    { "    v_cmp_t_u64  vcc, v[79:80], v[201:202]", 0x7dcf934fU, 0, false, true, "" },
1582    { "    v_cmp_t_u64  s[42:43], v[50:51], v[107:108]",
1583        0xd1ce002aU, 0x0002d732U, true, true, "" },
1584   
1585    { "    v_cmpx_f_u64  vcc, v[79:80], v[201:202]", 0x7de1934fU, 0, false, true, "" },
1586    { "    v_cmpx_f_u64  s[42:43], v[50:51], v[107:108]",
1587        0xd1e0002aU, 0x0002d732U, true, true, "" },
1588    { "    v_cmpx_lt_u64  vcc, v[79:80], v[201:202]", 0x7de3934fU, 0, false, true, "" },
1589    { "    v_cmpx_lt_u64  s[42:43], v[50:51], v[107:108]",
1590        0xd1e2002aU, 0x0002d732U, true, true, "" },
1591    { "    v_cmpx_eq_u64  vcc, v[79:80], v[201:202]", 0x7de5934fU, 0, false, true, "" },
1592    { "    v_cmpx_eq_u64  s[42:43], v[50:51], v[107:108]",
1593        0xd1e4002aU, 0x0002d732U, true, true, "" },
1594    { "    v_cmpx_le_u64  vcc, v[79:80], v[201:202]", 0x7de7934fU, 0, false, true, "" },
1595    { "    v_cmpx_le_u64  s[42:43], v[50:51], v[107:108]",
1596        0xd1e6002aU, 0x0002d732U, true, true, "" },
1597    { "    v_cmpx_gt_u64  vcc, v[79:80], v[201:202]", 0x7de9934fU, 0, false, true, "" },
1598    { "    v_cmpx_gt_u64  s[42:43], v[50:51], v[107:108]",
1599        0xd1e8002aU, 0x0002d732U, true, true, "" },
1600    { "    v_cmpx_lg_u64  vcc, v[79:80], v[201:202]", 0x7deb934fU, 0, false, true, "" },
1601    { "    v_cmpx_lg_u64  s[42:43], v[50:51], v[107:108]",
1602        0xd1ea002aU, 0x0002d732U, true, true, "" },
1603    { "    v_cmpx_ne_u64  vcc, v[79:80], v[201:202]", 0x7deb934fU, 0, false, true, "" },
1604    { "    v_cmpx_ne_u64  s[42:43], v[50:51], v[107:108]",
1605        0xd1ea002aU, 0x0002d732U, true, true, "" },
1606    { "    v_cmpx_ge_u64  vcc, v[79:80], v[201:202]", 0x7ded934fU, 0, false, true, "" },
1607    { "    v_cmpx_ge_u64  s[42:43], v[50:51], v[107:108]",
1608        0xd1ec002aU, 0x0002d732U, true, true, "" },
1609    { "    v_cmpx_tru_u64  vcc, v[79:80], v[201:202]", 0x7def934fU, 0, false, true, "" },
1610    { "    v_cmpx_tru_u64  s[42:43], v[50:51], v[107:108]",
1611        0xd1ee002aU, 0x0002d732U, true, true, "" },
1612    { "    v_cmpx_t_u64  vcc, v[79:80], v[201:202]", 0x7def934fU, 0, false, true, "" },
1613    { "    v_cmpx_t_u64  s[42:43], v[50:51], v[107:108]",
1614        0xd1ee002aU, 0x0002d732U, true, true, "" },
1615   
1616    { "    v_cmp_class_f32  vcc, v79, v201", 0x7d11934fU, 0, false, true, "" },
1617    { "    v_cmp_class_f32  s[42:43], v50, v107",
1618        0xd110002aU, 0x0002d732U, true, true, "" },
1619    { "    v_cmpx_class_f32  vcc, v79, v201", 0x7d31934fU, 0, false, true, "" },
1620    { "    v_cmpx_class_f32  s[42:43], v50, v107",
1621        0xd130002aU, 0x0002d732U, true, true, "" },
1622    { "    v_cmp_class_f64  vcc, v[79:80], v[201:202]", 0x7d51934fU, 0, false, true, "" },
1623    { "    v_cmp_class_f64  s[42:43], v[50:51], v[107:108]",
1624        0xd150002aU, 0x0002d732U, true, true, "" },
1625    { "    v_cmpx_class_f64  vcc, v[79:80], v[201:202]", 0x7d71934fU, 0, false, true, "" },
1626    { "    v_cmpx_class_f64  s[42:43], v[50:51], v[107:108]",
1627        0xd170002aU, 0x0002d732U, true, true, "" },
1628   
1629    /* VOP3 encoding */
1630    { "   v_mad_legacy_f32 v55, v79, v166, v229",
1631        0xd2800037U, 0x07974d4fU, true, true, "" },
1632    { "   v_mad_legacy_f32 v55, v79, v166, s101",
1633        0xd2800037U, 0x1974d4fU, true, true, "" },
1634    { "   v_mad_legacy_f32 v55, v79, s63, v229",
1635        0xd2800037U, 0x07947f4fU, true, true, "" },
1636    { "   v_mad_legacy_f32 v55, s79, v166, v229",
1637        0xd2800037U, 0x07974c4fU, true, true, "" },
1638    { "   v_mad_legacy_f32 v55, abs(v79), v166, v229",
1639        0xd2800137U, 0x07974d4fU, true, true, "" },
1640    { "   v_mad_legacy_f32 v55, v79, abs(v166), v229",
1641        0xd2800237U, 0x07974d4fU, true, true, "" },
1642    { "   v_mad_legacy_f32 v55, v79, v166, abs(v229)",
1643        0xd2800437U, 0x07974d4fU, true, true, "" },
1644    { "   v_mad_legacy_f32 v55, -v79, v166, v229",
1645        0xd2800037U, 0x27974d4fU, true, true, "" },
1646    { "   v_mad_legacy_f32 v55, v79, -v166, v229",
1647        0xd2800037U, 0x47974d4fU, true, true, "" },
1648    { "   v_mad_legacy_f32 v55, v79, v166, -v229",
1649        0xd2800037U, 0x87974d4fU, true, true, "" },
1650    { "   v_mad_legacy_f32 v55, v79, v166, v229 clamp",
1651        0xd2800837U, 0x07974d4fU, true, true, "" },
1652    { "   v_mad_legacy_f32 v55, v79, v166, v229 mul:2",
1653        0xd2800037U, 0x0f974d4fU, true, true, "" },
1654    { "   v_mad_legacy_f32 v55, v79, v166, v229 mul:4",
1655        0xd2800037U, 0x17974d4fU, true, true, "" },
1656    { "   v_mad_legacy_f32 v55, v79, v166, v229 div:2",
1657        0xd2800037U, 0x1f974d4fU, true, true, "" },
1658    { "   v_mad_legacy_f32 v55, 56, v166, v229",
1659        0xd2800037U, 0x07974cb8U, true, true, "" },
1660    { "bx=51;v_mad_legacy_f32 v55, bx+5, v166, v229",
1661        0xd2800037U, 0x07974cb8U, true, true, "" },
1662    { "   v_mad_legacy_f32 v55, v56, -15, v229",
1663        0xd2800037U, 0x07959f38U, true, true, "" },
1664    { "vxt=15; v_mad_legacy_f32 v55, v56, -vxt, v229",
1665        0xd2800037U, 0x07959f38U, true, true, "" },
1666    { "   v_mad_legacy_f32 v55, v79, v166, 45",
1667        0xd2800037U, 0x02b74d4fU, true, true, "" },
1668    { "gg=22;v_mad_legacy_f32 v55, v79, v166, 2*gg+1",
1669        0xd2800037U, 0x02b74d4fU, true, true, "" },
1670    /* one SGPR */
1671    { "    v_mad_legacy_f32 v55, s79, v166, s79",
1672        0xd2800037U, 0x013f4c4fU, true, true, "" },
1673    { "    v_mad_legacy_f32 v55, s79, s79, s79",
1674        0xd2800037U, 0x013c9e4fU, true, true, "" },
1675    /* VOP3 errors */
1676    { "v_mad_legacy_f32 v55, 66, v166, v229", 0, 0, false, false,
1677        "test.s:1:23: Error: Literal in VOP3 is illegal\n" },
1678    { "v_mad_legacy_f32 v55, s79, 743, v229", 0, 0, false, false,
1679        "test.s:1:28: Error: Literal in VOP3 is illegal\n" },
1680    { "v_mad_legacy_f32 v55, s79, v44, 6434", 0, 0, false, false,
1681        "test.s:1:33: Error: Literal in VOP3 is illegal\n" },
1682    { "    v_mad_legacy_f32 v55, s79, s166, v229", 0, 0, false, false,
1683        "test.s:1:32: Error: Scalar register number out of range\n" },
1684    { "    v_mad_legacy_f32 v55, s79, s100, v229", 0, 0, false, false,
1685        "test.s:1:5: Error: More than one SGPR to read in instruction\n" },
1686    { "    v_mad_legacy_f32 v55, s79, v166, s91", 0, 0, false, false,
1687        "test.s:1:5: Error: More than one SGPR to read in instruction\n" },
1688    { "    v_mad_legacy_f32 v55, s79, v166, s52", 0, 0, false, false,
1689        "test.s:1:5: Error: More than one SGPR to read in instruction\n" },
1690    { "   v_fma_f64  v[55], v[79], v[166], v[229]", 0, 0, false, false,
1691        "test.s:1:15: Error: Required 2 vector registers\n"
1692        "test.s:1:22: Error: Required 2 vector registers\n"
1693        "test.s:1:29: Error: Required 2 vector registers\n"
1694        "test.s:1:37: Error: Required 2 vector registers\n" },
1695    { "   v_fma_f64  v[55:56], s[79:80], v[166:167], s[29:30]", 0, 0, false, false,
1696        "test.s:1:4: Error: More than one SGPR to read in instruction\n" },
1697    { "   v_div_scale_f32  v55, s[36:37], v79, v166, v79 clamp", 0, 0, false, false,
1698        "test.s:1:51: Error: Modifier CLAMP in VOP3B is illegal\n" },
1699    { "   v_div_scale_f32  v55, s[36:37], abs(v79), v166, v79", 0, 0, false, false,
1700        "test.s:1:39: Error: Expected operator\n"
1701        "test.s:1:40: Error: Expected ',' before argument\n" },
1702    { "   v_mad_legacy_f32 v55, v79, v166, v229 clamp ,", 0, 0, false, false,
1703        "test.s:1:48: Error: Some garbages at VOP modifier place\n" },
1704    /* VOP3 instructions */
1705    { "   v_mad_f32  v55, v79, v166, v229", 0xd2820037U, 0x07974d4fU, true, true, "" },
1706    { "   v_mad_i32_i24  v55, v79, v166, v229", 0xd2840037U, 0x07974d4fU, true, true, "" },
1707    { "   v_mad_u32_u24  v55, v79, v166, v229", 0xd2860037U, 0x07974d4fU, true, true, "" },
1708    { "   v_cubeid_f32  v55, v79, v166, v229", 0xd2880037U, 0x07974d4fU, true, true, "" },
1709    { "   v_cubesc_f32  v55, v79, v166, v229", 0xd28a0037U, 0x07974d4fU, true, true, "" },
1710    { "   v_cubetc_f32  v55, v79, v166, v229", 0xd28c0037U, 0x07974d4fU, true, true, "" },
1711    { "   v_cubema_f32  v55, v79, v166, v229", 0xd28e0037U, 0x07974d4fU, true, true, "" },
1712    { "   v_bfe_u32  v55, v79, v166, v229", 0xd2900037U, 0x07974d4fU, true, true, "" },
1713    { "   v_bfe_i32  v55, v79, v166, v229", 0xd2920037U, 0x07974d4fU, true, true, "" },
1714    { "   v_bfi_b32  v55, v79, v166, v229", 0xd2940037U, 0x07974d4fU, true, true, "" },
1715    { "   v_fma_f32  v55, v79, v166, v229", 0xd2960037U, 0x07974d4fU, true, true, "" },
1716    { "   v_fma_f64  v[55:56], v[79:80], v[166:167], v[229:230]",
1717        0xd2980037U, 0x07974d4fU, true, true, "" },
1718    { "   v_fma_f64 v[5:6], v[1:2], v[3:4], s[1:2]",
1719        0xd2980005U, 0x00060701U, true, true, "" },
1720    { "   v_lerp_u8  v55, v79, v166, v229", 0xd29a0037U, 0x07974d4fU, true, true, "" },
1721    { "   v_alignbit_b32  v55, v79, v166, v229", 0xd29c0037U, 0x07974d4fU, true, true, "" },
1722    { "   v_alignbyte_b32  v55, v79, v166, v229",
1723        0xd29e0037U, 0x07974d4fU, true, true, "" },
1724    { "   v_mullit_f32    v55, v79, v166, s0", 0xd2a00037U, 0x00034d4fU, true, true, "" },
1725    { "   v_mullit_f32    v55, v79, v166, s0", 0xd2a00037U, 0x00034d4fU, true, true, "" },
1726    { "   v_mullit_f32    v55, s79, v166, v229", 0xd2a00037U, 0x07974c4fU, true, true, "" },
1727    { "   v_min3_f32  v55, v79, v166, v229", 0xd2a20037U, 0x07974d4fU, true, true, "" },
1728    { "   v_min3_i32  v55, v79, v166, v229", 0xd2a40037U, 0x07974d4fU, true, true, "" },
1729    { "   v_min3_u32  v55, v79, v166, v229", 0xd2a60037U, 0x07974d4fU, true, true, "" },
1730    { "   v_max3_f32  v55, v79, v166, v229", 0xd2a80037U, 0x07974d4fU, true, true, "" },
1731    { "   v_max3_i32  v55, v79, v166, v229", 0xd2aa0037U, 0x07974d4fU, true, true, "" },
1732    { "   v_max3_u32  v55, v79, v166, v229", 0xd2ac0037U, 0x07974d4fU, true, true, "" },
1733    { "   v_med3_f32  v55, v79, v166, v229", 0xd2ae0037U, 0x07974d4fU, true, true, "" },
1734    { "   v_med3_i32  v55, v79, v166, v229", 0xd2b00037U, 0x07974d4fU, true, true, "" },
1735    { "   v_med3_u32  v55, v79, v166, v229", 0xd2b20037U, 0x07974d4fU, true, true, "" },
1736    { "   v_sad_u8  v55, v79, v166, v229", 0xd2b40037U, 0x07974d4fU, true, true, "" },
1737    { "   v_sad_hi_u8  v55, v79, v166, v229", 0xd2b60037U, 0x07974d4fU, true, true, "" },
1738    { "   v_sad_u16  v55, v79, v166, v229", 0xd2b80037U, 0x07974d4fU, true, true, "" },
1739    { "   v_sad_u32  v55, v79, v166, v229", 0xd2ba0037U, 0x07974d4fU, true, true, "" },
1740    { "   v_cvt_pk_u8_f32 v55, v79, v166, v229", 0xd2bc0037U, 0x07974d4fU, true, true, "" },
1741    { "   v_div_fixup_f32 v55, v79, v166, v229", 0xd2be0037U, 0x07974d4fU, true, true, "" },
1742    { "   v_div_fixup_f64 v[55:56], v[79:80], v[166:167], v[229:230]",
1743        0xd2c00037U, 0x07974d4fU, true, true, "" },
1744    { "   v_lshl_b64  v[55:56], v[79:80], v166", 0xd2c20037U, 0x00034d4fU, true, true, "" },
1745    { "   v_lshr_b64  v[55:56], v[79:80], v166", 0xd2c40037U, 0x00034d4fU, true, true, "" },
1746    { "   v_ashr_i64  v[55:56], v[79:80], v166", 0xd2c60037U, 0x00034d4fU, true, true, "" },
1747    { "   v_add_f64  v[55:56], v[79:80], v[166:167]",
1748        0xd2c80037U, 0x00034d4fU, true, true, "" },
1749    { "   v_mul_f64  v[55:56], v[79:80], v[166:167]",
1750        0xd2ca0037U, 0x00034d4fU, true, true, "" },
1751    { "   v_min_f64  v[55:56], v[79:80], v[166:167]",
1752        0xd2cc0037U, 0x00034d4fU, true, true, "" },
1753    { "   v_max_f64  v[55:56], v[79:80], v[166:167]",
1754        0xd2ce0037U, 0x00034d4fU, true, true, "" },
1755    { "   v_ldexp_f64  v[55:56], v[79:80], v166",
1756        0xd2d00037U, 0x00034d4fU, true, true, "" },
1757    { "   v_mul_lo_u32  v55, v79, v166", 0xd2d20037U, 0x00034d4fU, true, true, "" },
1758    { "   v_mul_hi_u32  v55, v79, v166", 0xd2d40037U, 0x00034d4fU, true, true, "" },
1759    { "   v_mul_lo_i32  v55, v79, v166", 0xd2d60037U, 0x00034d4fU, true, true, "" },
1760    { "   v_mul_hi_i32  v55, v79, v166", 0xd2d80037U, 0x00034d4fU, true, true, "" },
1761    { "   v_div_scale_f32  v55, s[38:39], v79, v166, v79",
1762        0xd2da2637U, 0x053f4d4fU, true, true, "" },
1763    { "   v_div_scale_f32  v55, s[39:40], v79, v166, v79",
1764        0xd2da2737U, 0x053f4d4fU, true, true, "" },
1765    { "   v_div_scale_f32  v55, s[38:39], v79, v79, v229",
1766        0xd2da2637U, 0x07969f4fU, true, true, "" },
1767    { "   v_div_scale_f64 v[55:56], s[38:39], v[79:80], v[166:167], v[79:80]",
1768        0xd2dc2637U, 0x053f4d4fU, true, true, "" },
1769    { "   v_div_scale_f64 v[55:56], s[38:39], v[79:80], v[79:80], v[229:230]",
1770        0xd2dc2637U, 0x07969f4fU, true, true, "" },
1771    { "   v_div_fmas_f32  v55, v79, v166, v229", 0xd2de0037U, 0x07974d4fU, true, true, "" },
1772    { "   v_div_fmas_f64  v[55:56], v[79:80], v[166:167], v[229:230]",
1773        0xd2e00037U, 0x07974d4fU, true, true, "" },
1774    { "   v_msad_u8  v55, v79, v166, v229", 0xd2e20037U, 0x07974d4fU, true, true, "" },
1775    { "   v_qsad_u8  v[55:56], v[79:80], v166, v[229:230]",
1776        0xd2e40037U, 0x07974d4fU, true, true, "" },
1777    { "   v_mqsad_u8  v[55:56], v[79:80], v166, v[229:230]",
1778        0xd2e60037U, 0x07974d4fU, true, true, "" },
1779    { "   v_trig_preop_f64  v[55:56], v[79:80], v166",
1780        0xd2e80037U, 0x00034d4fU, true, true, "" },
1781    /* VINTRP encoding */
1782    { "   v_interp_p1_f32 v93, v211, attr26.w", 0xc9746bd3U, 0, false, true, "" },
1783    { "   v_interp_p1_f32_e32 v93, v211, attr26.w", 0xc9746bd3U, 0, false, true, "" },
1784    { "   v_interp_p1_f32 v93, v211, attr26 . w", 0xc9746bd3U, 0, false, true, "" },
1785    { "   v_interp_p1_f32 v93, v211, aTTR26 . W", 0xc9746bd3U, 0, false, true, "" },
1786    { "   v_interp_p1_f32 v93, v211, aTTR00026 . W", 0xc9746bd3U, 0, false, true, "" },
1787    { "   v_interp_p1_f32 v93, v211, attr26.x", 0xc97468d3U, 0, false, true, "" },
1788    { "   v_interp_p1_f32 v93, v211, attr26.y", 0xc97469d3U, 0, false, true, "" },
1789    { "   v_interp_p1_f32 v93, v211, attr26.z", 0xc9746ad3U, 0, false, true, "" },
1790    { "   v_interp_p1_f32 v93, v211, attr63.z", 0xc974fed3U, 0, false, true, "" },
1791    { "   v_interp_p1_f32 v93  , v211  , attr63.z", 0xc974fed3U, 0, false, true, "" },
1792    { "   v_interp_p2_f32 v93, v211, attr26.w", 0xc9756bd3U, 0, false, true, "" },
1793    { "   v_interp_mov_f32 v93, p10, attr26.w", 0xc9766b00U, 0, false, true, "" },
1794    { "   v_interp_mov_f32 v93, p20, attr26.w", 0xc9766b01U, 0, false, true, "" },
1795    { "   v_interp_mov_f32 v93, p0, attr26.w", 0xc9766b02U, 0, false, true, "" },
1796    /* VINTRP errors */
1797    { "   v_interp_p1_f32 v[93:94], v211, attr26.w", 0, 0, false, false,
1798        "test.s:1:20: Error: Required 1 vector register\n" },
1799    { "   v_interp_p1_f32 v93, v211, at26.w", 0, 0, false, false,
1800        "test.s:1:31: Error: Expected 'attr' keyword\n" },
1801    { "   v_interp_p1_f32 v93, v211, ", 0, 0, false, false,
1802        "test.s:1:31: Error: Expected 'attr' keyword\n" },
1803    { "   v_interp_p1_f32 v93, v211, attr22111.x", 0, 0, false, false,
1804        "test.s:1:38: Error: Number is too big\n" },
1805    { "   v_interp_p1_f32 v93, v211, attr64.w", 0, 0, false, false,
1806        "test.s:1:35: Error: Attribute number out of range (0-63)\n" },
1807    { "   v_interp_p1_f32 v93, v211, attr26", 0, 0, false, false,
1808        "test.s:1:37: Error: Expected '.' after attribute number\n" },
1809    { "   v_interp_p1_f32 v93, v211, attr26,", 0, 0, false, false,
1810        "test.s:1:37: Error: Expected '.' after attribute number\n" },
1811    { "   v_interp_p1_f32 v93, v211, attr26.t", 0, 0, false, false,
1812        "test.s:1:38: Error: Expected attribute component\n" },
1813    { "   v_interp_p1_f32 v93, v211, attr26.", 0, 0, false, false,
1814        "test.s:1:38: Error: Expected attribute component\n" },
1815    { "   v_interp_mov_f32 v93, xx, attr26.w", 0, 0, false, false,
1816        "test.s:1:26: Error: Unknown VINTRP parameter\n" },
1817    { "   v_interp_mov_f32 v93, xxffff, attr26.w", 0, 0, false, false,
1818        "test.s:1:32: Error: VINTRP parameter is too long\n" },
1819    /* DS encoding */
1820    { "   ds_add_u32  v71, v169 offset:52583", 0xd800cd67U, 0x0000a947U, true, true, "" },
1821    { "   ds_add_u32  v71, v169 offset:52583 gds:0",
1822            0xd800cd67U, 0x0000a947U, true, true, "" },
1823    { "   ds_add_u32  v71, v169   ", 0xd8000000U, 0x0000a947U, true, true, "" },
1824    { "   ds_add_u32_e64  v71, v169   ", 0xd8000000U, 0x0000a947U, true, true, "" },
1825    { "   ds_add_u32  v71, v169 offset :  52583",
1826        0xd800cd67U, 0x0000a947U, true, true, "" },
1827    { "   ds_add_u32  v71, v169", 0xd8000000U, 0x0000a947U, true, true, "" },
1828    { "dct=771; ds_add_u32  v71, v169 offset:dct+2",
1829        0xd8000305U, 0x0000a947U, true, true, "" },
1830    { "ds_add_u32  v71, v169 offset:dct+2; dct=771",
1831        0xd8000305U, 0x0000a947U, true, true, "" },
1832    { "   ds_add_u32  v71, v169 gds", 0xd8020000U, 0x0000a947U, true, true, "" },
1833    { "   ds_add_u32  v71, v169 gds:1", 0xd8020000U, 0x0000a947U, true, true, "" },
1834    { "   ds_consume  v155 offset:52583", 0xd8f4cd67U, 0x9b000000U, true, true, "" },
1835    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87]"
1836      " offset0:103 offset1:205", 0xd9bccd67U, 0x8b56a947U, true, true, "" },
1837    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87]"
1838      " offset1:205 offset0:103", 0xd9bccd67U, 0x8b56a947U, true, true, "" },
1839    { "aa=32; bb=74;ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87]"
1840      " offset0:1+aa offset1:bb+1", 0xd9bc4b21U, 0x8b56a947U, true, true, "" },
1841    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87] offset0:1+aa "
1842        "offset1:bb+1;aa=32; bb=74", 0xd9bc4b21U, 0x8b56a947U, true, true, "" },
1843    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87] offset0:1+aa "
1844        "gds offset1:bb+1;aa=32; bb=74", 0xd9be4b21U, 0x8b56a947U, true, true, "" },
1845    /* DS warnings */
1846    { "   ds_add_u32  v71, v169 offset:52 offset:42",
1847        0xd800002aU, 0x0000a947U, true, true,
1848        "test.s:1:36: Warning: Offset is already defined\n" },
1849    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87] "
1850        "offset0:103 offset1:205 offset1:51 offset0:6",
1851        0xd9bc3306U, 0x8b56a947U, true, true,
1852        "test.s:1:89: Warning: Offset1 is already defined\n"
1853        "test.s:1:100: Warning: Offset0 is already defined\n" },
1854    /* DS errors */
1855    { "   ds_add_u32  v71, v169 xdff:5444", 0, 0, false, false,
1856        "test.s:1:26: Error: Expected 'offset'\n"
1857        "test.s:1:30: Error: Some garbages at DS modifier place\n" },
1858    { "   ds_add_u32  v71, v169 offset0:5444", 0, 0, false, false,
1859        "test.s:1:26: Error: Expected 'offset'\n"
1860        "test.s:1:33: Error: Some garbages at DS modifier place\n" },
1861    { "   ds_add_u32  v71, v169 offset1:5444", 0, 0, false, false,
1862        "test.s:1:26: Error: Expected 'offset'\n"
1863        "test.s:1:33: Error: Some garbages at DS modifier place\n" },
1864    { "   ds_wrxchg2st64_rtn_b64 v139, v[71:72], v169, v86"
1865      " offset0:103 offset1:205", 0, 0, false, false,
1866        "test.s:1:27: Error: Required 4 vector registers\n"
1867        "test.s:1:33: Error: Required 1 vector register\n"
1868        "test.s:1:43: Error: Required 2 vector registers\n"
1869        "test.s:1:49: Error: Required 2 vector registers\n" },
1870    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87] offset2:103 "
1871        "offsetx:205 offset:3221 oxxs", 0, 0, false, false,
1872        "test.s:1:65: Error: Expected 'offset', 'offset0' or 'offset1'\n"
1873        "test.s:1:72: Error: Some garbages at DS modifier place\n"
1874        "test.s:1:77: Error: Expected 'offset', 'offset0' or 'offset1'\n"
1875        "test.s:1:84: Error: Some garbages at DS modifier place\n"
1876        "test.s:1:89: Error: Expected 'offset', 'offset0' or 'offset1'\n"
1877        "test.s:1:95: Error: Some garbages at DS modifier place\n"
1878        "test.s:1:101: Error: Expected 'offset', 'offset0' or 'offset1'\n" },
1879    { "   ds_xor_b64  v71, v[169:170], v3 offset:52583", 0, 0, false, false,
1880        "test.s:1:31: Error: Some garbages at DS modifier place\n"
1881        "test.s:1:33: Error: Expected 'offset'\n" },
1882    { "   ds_gws_init  v71 offset:52583", 0, 0, false, false,
1883        "test.s:1:4: Error: Instruction requires GDS modifier\n" },
1884    { "   ds_add_u32  v71, v169 offset:,", 0, 0, false, false,
1885        "test.s:1:33: Error: Expected expression\n"
1886        "test.s:1:33: Error: Some garbages at DS modifier place\n" },
1887    { "   ds_add_u32  v71, v169 offset,", 0, 0, false, false,
1888        "test.s:1:32: Error: Expected ':' before offset\n"
1889        "test.s:1:32: Error: Some garbages at DS modifier place\n" },
1890    { "   ds_write2_b32  v71, v169, v39 offset0, offset1,",
1891        0, 0, false, false,
1892        "test.s:1:41: Error: Expected ':' before offset\n"
1893        "test.s:1:41: Error: Some garbages at DS modifier place\n"
1894        "test.s:1:50: Error: Expected ':' before offset\n"
1895        "test.s:1:50: Error: Some garbages at DS modifier place\n" },
1896    /* DS instructions */
1897    { "   ds_sub_u32  v71, v169 offset:52583", 0xd804cd67U, 0x0000a947U, true, true, "" },
1898    { "   ds_rsub_u32 v71, v169 offset:52583", 0xd808cd67U, 0x0000a947U, true, true, "" },
1899    { "   ds_inc_u32  v71, v169 offset:52583", 0xd80ccd67U, 0x0000a947U, true, true, "" },
1900    { "   ds_dec_u32  v71, v169 offset:52583", 0xd810cd67U, 0x0000a947U, true, true, "" },
1901    { "   ds_min_i32  v71, v169 offset:52583", 0xd814cd67U, 0x0000a947U, true, true, "" },
1902    { "   ds_max_i32  v71, v169 offset:52583", 0xd818cd67U, 0x0000a947U, true, true, "" },
1903    { "   ds_min_u32  v71, v169 offset:52583", 0xd81ccd67U, 0x0000a947U, true, true, "" },
1904    { "   ds_max_u32  v71, v169 offset:52583", 0xd820cd67U, 0x0000a947U, true, true, "" },
1905    { "   ds_and_b32  v71, v169 offset:52583", 0xd824cd67U, 0x0000a947U, true, true, "" },
1906    { "   ds_or_b32  v71, v169 offset:52583", 0xd828cd67U, 0x0000a947U, true, true, "" },
1907    { "   ds_xor_b32  v71, v169 offset:52583", 0xd82ccd67U, 0x0000a947U, true, true, "" },
1908    { "   ds_mskor_b32  v71, v169, v39 offset:52583",
1909        0xd830cd67U, 0x0027a947U, true, true, "" },
1910    { "   ds_write_b32 v71, v169 offset:52583", 0xd834cd67U, 0x0000a947U, true, true, "" },
1911    { "   ds_write2_b32  v71, v169, v39 offset0:103 offset1:205",
1912        0xd838cd67U, 0x0027a947U, true, true, "" },
1913    { "   ds_write2st64_b32 v71, v169, v39 offset0:103 offset1:205",
1914        0xd83ccd67U, 0x0027a947U, true, true, "" },
1915    { "   ds_cmpst_b32  v71, v169, v39 offset:52583",
1916        0xd840cd67U, 0x0027a947U, true, true, "" },
1917    { "   ds_cmpst_f32  v71, v169, v39 offset:52583",
1918        0xd844cd67U, 0x0027a947U, true, true, "" },
1919    { "   ds_min_f32  v71, v169 offset:52583", 0xd848cd67U, 0x0000a947U, true, true, "" },
1920    { "   ds_max_f32  v71, v169 offset:52583", 0xd84ccd67U, 0x0000a947U, true, true, "" },
1921    { "   ds_gws_init  v71 offset:52583 gds", 0xd866cd67U, 0x00000047U, true, true, "" },
1922    { "   ds_gws_sema_v v71 offset:52583 gds", 0xd86acd67U, 0x00000047U, true, true, "" },
1923    { "   ds_gws_sema_br v71 offset:52583 gds", 0xd86ecd67U, 0x00000047U, true, true, "" },
1924    { "   ds_gws_sema_p v71 offset:52583 gds", 0xd872cd67U, 0x00000047U, true, true, "" },
1925    { "   ds_gws_barrier v71 offset:52583 gds", 0xd876cd67U, 0x00000047U, true, true, "" },
1926    { "   ds_write_b8  v71, v169 offset:52583", 0xd878cd67U, 0x0000a947U, true, true, "" },
1927    { "   ds_write_b16  v71, v169 offset:52583", 0xd87ccd67U, 0x0000a947U, true, true, "" },
1928    { "   ds_add_rtn_u32  v155, v71, v169 offset:52583",
1929        0xd880cd67U, 0x9b00a947U, true,  true, "" },
1930    { "   ds_sub_rtn_u32  v155, v71, v169 offset:52583",
1931        0xd884cd67U, 0x9b00a947U, true,  true, "" },
1932    { "   ds_rsub_rtn_u32  v155, v71, v169 offset:52583",
1933        0xd888cd67U, 0x9b00a947U, true,  true, "" },
1934    { "   ds_rsub_rtn_u32  v155, v71, v169 offset:52583",
1935        0xd888cd67U, 0x9b00a947U, true, true, "" },
1936    { "   ds_inc_rtn_u32  v155, v71, v169 offset:52583",
1937        0xd88ccd67U, 0x9b00a947U, true, true, "" },
1938    { "   ds_dec_rtn_u32  v155, v71, v169 offset:52583",
1939        0xd890cd67U, 0x9b00a947U, true, true, "" },
1940    { "   ds_min_rtn_i32  v155, v71, v169 offset:52583",
1941        0xd894cd67U, 0x9b00a947U, true, true, "" },
1942    { "   ds_max_rtn_i32  v155, v71, v169 offset:52583",
1943        0xd898cd67U, 0x9b00a947U, true, true, "" },
1944    { "   ds_min_rtn_u32  v155, v71, v169 offset:52583",
1945        0xd89ccd67U, 0x9b00a947U, true, true, "" },
1946    { "   ds_max_rtn_u32  v155, v71, v169 offset:52583",
1947        0xd8a0cd67U, 0x9b00a947U, true, true, "" },
1948    { "   ds_and_rtn_b32  v155, v71, v169 offset:52583",
1949        0xd8a4cd67U, 0x9b00a947U, true, true, "" },
1950    { "   ds_or_rtn_b32  v155, v71, v169 offset:52583",
1951        0xd8a8cd67U, 0x9b00a947U, true, true, "" },
1952    { "   ds_xor_rtn_b32  v155, v71, v169 offset:52583",
1953        0xd8accd67U, 0x9b00a947U, true, true, "" },
1954    { "   ds_mskor_rtn_b32 v155, v71, v169, v26 offset:52583",
1955        0xd8b0cd67U, 0x9b1aa947U, true, true, "" },
1956    { "   ds_wrxchg_rtn_b32  v155, v71, v169 offset:52583",
1957        0xd8b4cd67U, 0x9b00a947U, true, true, "" },
1958    { "   ds_wrxchg2_rtn_b32 v[155:156], v71, v169, v26 offset0:103 offset1:205",
1959        0xd8b8cd67U, 0x9b1aa947U, true, true, "" },
1960    { "   ds_wrxchg2st64_rtn_b32  v[155:156], v71, v169, v26 offset0:103 offset1:205",
1961        0xd8bccd67U, 0x9b1aa947U, true, true, "" },
1962    { "   ds_cmpst_rtn_b32  v155, v71, v169, v26 offset:52583",
1963        0xd8c0cd67U, 0x9b1aa947U, true, true, "" },
1964    { "   ds_cmpst_rtn_f32  v155, v71, v169, v26 offset:52583",
1965        0xd8c4cd67U, 0x9b1aa947U, true, true, "" },
1966    { "   ds_min_rtn_f32  v155, v71, v169 offset:52583",
1967        0xd8c8cd67U, 0x9b00a947U, true, true, "" },
1968    { "   ds_max_rtn_f32  v155, v71, v169 offset:52583",
1969        0xd8cccd67U, 0x9b00a947U, true, true, "" },
1970    { "   ds_swizzle_b32  v155, v71 offset:52583",
1971        0xd8d4cd67U, 0x9b000047U, true, true, "" },
1972    { "   ds_read_b32 v155, v71 offset:52583", 0xd8d8cd67U, 0x9b000047U, true, true, "" },
1973    { "   ds_read2_b32 v[155:156], v71 offset0:103 offset1:205",
1974        0xd8dccd67U, 0x9b000047U, true, true, "" },
1975    { "   ds_read2st64_b32 v[155:156], v71 offset0:103 offset1:205",
1976        0xd8e0cd67U, 0x9b000047U, true, true, "" },
1977    { "   ds_read_i8  v155, v71 offset:52583", 0xd8e4cd67U, 0x9b000047U, true, true, "" },
1978    { "   ds_read_u8  v155, v71 offset:52583", 0xd8e8cd67U, 0x9b000047U, true, true, "" },
1979    { "   ds_read_i16  v155, v71 offset:52583", 0xd8eccd67U, 0x9b000047U, true, true, "" },
1980    { "   ds_read_u16  v155, v71 offset:52583", 0xd8f0cd67U, 0x9b000047U, true, true, "" },
1981    { "   ds_consume  v155 offset:52583", 0xd8f4cd67U, 0x9b000000U, true, true, "" },
1982    { "   ds_append  v155 offset:52583", 0xd8f8cd67U, 0x9b000000U, true, true, "" },
1983    { "   ds_ordered_count v155, v71 offset:52583",
1984        0xd8fccd67U, 0x9b000047U, true, true, "" },
1985    { "   ds_add_u64  v71, v[169:170] offset:52583",
1986        0xd900cd67U, 0x0000a947U, true, true, "" },
1987    { "   ds_sub_u64  v71, v[169:170] offset:52583",
1988        0xd904cd67U, 0x0000a947U, true, true, "" },
1989    { "   ds_rsub_u64  v71, v[169:170] offset:52583",
1990        0xd908cd67U, 0x0000a947U, true, true, "" },
1991    { "   ds_inc_u64  v71, v[169:170] offset:52583",
1992        0xd90ccd67U, 0x0000a947U, true, true, "" },
1993    { "   ds_dec_u64  v71, v[169:170] offset:52583",
1994        0xd910cd67U, 0x0000a947U, true, true, "" },
1995    { "   ds_min_i64  v71, v[169:170] offset:52583",
1996        0xd914cd67U, 0x0000a947U, true, true, "" },
1997    { "   ds_max_i64  v71, v[169:170] offset:52583",
1998        0xd918cd67U, 0x0000a947U, true, true, "" },
1999    { "   ds_min_u64  v71, v[169:170] offset:52583",
2000        0xd91ccd67U, 0x0000a947U, true, true, "" },
2001    { "   ds_max_u64  v71, v[169:170] offset:52583",
2002        0xd920cd67U, 0x0000a947U, true, true, "" },
2003    { "   ds_and_b64  v71, v[169:170] offset:52583",
2004        0xd924cd67U, 0x0000a947U, true, true, "" },
2005    { "   ds_or_b64  v71, v[169:170] offset:52583",
2006        0xd928cd67U, 0x0000a947U, true, true, "" },
2007    { "   ds_xor_b64  v71, v[169:170] offset:52583",
2008        0xd92ccd67U, 0x0000a947U, true, true, "" },
2009    { "   ds_mskor_b64  v71, v[169:170], v[23:24] offset:52583",
2010        0xd930cd67U, 0x0017a947U, true, true, "" },
2011    { "   ds_write_b64  v71, v[169:170] offset:52583",
2012        0xd934cd67U, 0x0000a947U, true, true, "" },
2013    { "   ds_write2_b64  v71, v[169:170], v[39:40] offset0:103 offset1:205",
2014        0xd938cd67U, 0x0027a947U, true, true, "" },
2015    { "   ds_write2st64_b64 v71, v[169:170], v[39:40] offset0:103 offset1:205",
2016        0xd93ccd67U, 0x0027a947U, true, true, "" },
2017    { "   ds_cmpst_b64  v71, v[169:170], v[39:40] offset:52583",
2018        0xd940cd67U, 0x0027a947U, true, true, "" },
2019    { "   ds_cmpst_f64  v71, v[169:170], v[39:40] offset:52583",
2020        0xd944cd67U, 0x0027a947U, true, true, "" },
2021    { "   ds_min_f64  v71, v[169:170] offset:52583",
2022        0xd948cd67U, 0x0000a947U, true, true, "" },
2023    { "   ds_max_f64  v71, v[169:170] offset:52583",
2024        0xd94ccd67U, 0x0000a947U, true, true, "" },
2025    { "   ds_add_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2026        0xd980cd67U, 0x8b00a947U, true, true, "" },
2027    { "   ds_sub_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2028        0xd984cd67U, 0x8b00a947U, true, true, "" },
2029    { "   ds_rsub_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2030        0xd988cd67U, 0x8b00a947U, true, true, "" },
2031    { "   ds_inc_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2032        0xd98ccd67U, 0x8b00a947U, true, true, "" },
2033    { "   ds_dec_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2034        0xd990cd67U, 0x8b00a947U, true, true, "" },
2035    { "   ds_min_rtn_i64  v[139:140], v71, v[169:170] offset:52583",
2036        0xd994cd67U, 0x8b00a947U, true, true, "" },
2037    { "   ds_max_rtn_i64  v[139:140], v71, v[169:170] offset:52583",
2038        0xd998cd67U, 0x8b00a947U, true, true, "" },
2039    { "   ds_min_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2040        0xd99ccd67U, 0x8b00a947U, true, true, "" },
2041    { "   ds_max_rtn_u64  v[139:140], v71, v[169:170] offset:52583",
2042        0xd9a0cd67U, 0x8b00a947U, true, true, "" },
2043    { "   ds_and_rtn_b64  v[139:140], v71, v[169:170] offset:52583",
2044        0xd9a4cd67U, 0x8b00a947U, true, true, "" },
2045    { "   ds_or_rtn_b64  v[139:140], v71, v[169:170] offset:52583",
2046        0xd9a8cd67U, 0x8b00a947U, true, true, "" },
2047    { "   ds_xor_rtn_b64  v[139:140], v71, v[169:170] offset:52583",
2048        0xd9accd67U, 0x8b00a947U, true, true, "" },
2049    { "   ds_mskor_rtn_b64 v[139:140], v71, v[169:170], v[86:87] offset:52583",
2050        0xd9b0cd67U, 0x8b56a947U, true, true, "" },
2051    { "   ds_wrxchg_rtn_b64  v[139:140], v71, v[169:170] offset:52583",
2052        0xd9b4cd67U, 0x8b00a947U, true, true, "" },
2053    { "   ds_wrxchg2_rtn_b64 v[139:142], v71, v[169:170], v[86:87] "
2054        "offset0:103 offset1:205", 0xd9b8cd67U, 0x8b56a947U, true, true, "" },
2055    { "   ds_wrxchg2st64_rtn_b64 v[139:142], v71, v[169:170], v[86:87] "
2056        "offset0:103 offset1:205", 0xd9bccd67U, 0x8b56a947U, true, true, "" },
2057    { "   ds_cmpst_rtn_b64 v[139:140], v71, v[169:170], v[86:87] offset:52583",
2058        0xd9c0cd67U, 0x8b56a947U, true, true, "" },
2059    { "   ds_cmpst_rtn_f64 v[139:140], v71, v[169:170], v[86:87] offset:52583",
2060        0xd9c4cd67U, 0x8b56a947U, true, true, "" },
2061    { "   ds_min_rtn_f64 v[139:140], v71, v[169:170] offset:52583",
2062        0xd9c8cd67U, 0x8b00a947U, true, true, "" },
2063    { "   ds_max_rtn_f64 v[139:140], v71, v[169:170] offset:52583",
2064        0xd9cccd67U, 0x8b00a947U, true, true, "" },
2065    { "   ds_read_b64  v[139:140], v71 offset:52583",
2066        0xd9d8cd67U, 0x8b000047U, true, true, "" },
2067    { "   ds_read2_b64  v[139:142], v71 offset0:103 offset1:205",
2068        0xd9dccd67U, 0x8b000047U, true, true, "" },
2069    { "   ds_read2st64_b64 v[139:142], v71 offset0:103 offset1:205",
2070        0xd9e0cd67U, 0x8b000047U, true, true, "" },
2071    { "   ds_add_src2_u32 v71 offset:52583", 0xda00cd67U, 0x00000047U, true, true, "" },
2072    { "   ds_sub_src2_u32 v71 offset:52583", 0xda04cd67U, 0x00000047U, true, true, "" },
2073    { "   ds_rsub_src2_u32 v71 offset:52583", 0xda08cd67U, 0x00000047U, true, true, "" },
2074    { "   ds_inc_src2_u32 v71 offset:52583", 0xda0ccd67U, 0x00000047U, true, true, "" },
2075    { "   ds_dec_src2_u32 v71 offset:52583", 0xda10cd67U, 0x00000047U, true, true, "" },
2076    { "   ds_min_src2_i32 v71 offset:52583", 0xda14cd67U, 0x00000047U, true, true, "" },
2077    { "   ds_max_src2_i32 v71 offset:52583", 0xda18cd67U, 0x00000047U, true, true, "" },
2078    { "   ds_min_src2_u32 v71 offset:52583", 0xda1ccd67U, 0x00000047U, true, true, "" },
2079    { "   ds_max_src2_u32 v71 offset:52583", 0xda20cd67U, 0x00000047U, true, true, "" },
2080    { "   ds_and_src2_b32 v71 offset:52583", 0xda24cd67U, 0x00000047U, true, true, "" },
2081    { "   ds_or_src2_b32 v71 offset:52583", 0xda28cd67U, 0x00000047U, true, true, "" },
2082    { "   ds_xor_src2_b32 v71 offset:52583", 0xda2ccd67U, 0x00000047U, true, true, "" },
2083    { "   ds_write_src2_b32 v71 offset:52583", 0xda34cd67U, 0x00000047U, true, true, "" },
2084    { "   ds_min_src2_f32 v71 offset:52583", 0xda48cd67U, 0x00000047U, true, true, "" },
2085    { "   ds_max_src2_f32 v71 offset:52583", 0xda4ccd67U, 0x00000047U, true, true, "" },
2086    { "   ds_add_src2_u64 v71 offset:52583", 0xdb00cd67U, 0x00000047U, true, true, "" },
2087    { "   ds_sub_src2_u64 v71 offset:52583", 0xdb04cd67U, 0x00000047U, true, true, "" },
2088    { "   ds_rsub_src2_u64 v71 offset:52583", 0xdb08cd67U, 0x00000047U, true, true, "" },
2089    { "   ds_inc_src2_u64 v71 offset:52583", 0xdb0ccd67U, 0x00000047U, true, true, "" },
2090    { "   ds_dec_src2_u64 v71 offset:52583", 0xdb10cd67U, 0x00000047U, true, true, "" },
2091    { "   ds_min_src2_i64 v71 offset:52583", 0xdb14cd67U, 0x00000047U, true, true, "" },
2092    { "   ds_max_src2_i64 v71 offset:52583", 0xdb18cd67U, 0x00000047U, true, true, "" },
2093    { "   ds_min_src2_u64 v71 offset:52583", 0xdb1ccd67U, 0x00000047U, true, true, "" },
2094    { "   ds_max_src2_u64 v71 offset:52583", 0xdb20cd67U, 0x00000047U, true, true, "" },
2095    { "   ds_and_src2_b64 v71 offset:52583", 0xdb24cd67U, 0x00000047U, true, true, "" },
2096    { "   ds_or_src2_b64 v71 offset:52583", 0xdb28cd67U, 0x00000047U, true, true, "" },
2097    { "   ds_xor_src2_b64 v71 offset:52583", 0xdb2ccd67U, 0x00000047U, true, true, "" },
2098    { "   ds_write_src2_b64 v71 offset:52583", 0xdb34cd67U, 0x00000047U, true, true, "" },
2099    { "   ds_min_src2_f64 v71 offset:52583", 0xdb48cd67U, 0x00000047U, true, true, "" },
2100    { "   ds_max_src2_f64 v71 offset:52583", 0xdb4ccd67U, 0x00000047U, true, true, "" },
2101    /* MUBUF */
2102    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 "
2103        "offset:603 glc slc addr64 tfe", 0xe000c25bU, 0x23d43d12U, true, true, "" },
2104    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 "
2105        "offset:603 glc slc addr64 tfe:1", 0xe000c25bU, 0x23d43d12U, true, true, "" },
2106    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 "
2107        "offset:603 glc slc:1 addr64 tfe:1", 0xe000c25bU, 0x23d43d12U, true, true, "" },
2108    { "    buffer_load_format_x  v[61:62], s[80:83], s35 "
2109        "offset:603 glc slc tfe", 0xe000425bU, 0x23d43d00U, true, true, "" },
2110    { "    buffer_load_format_x  v[61:62], s[80:83], s35 "
2111        "offset:603 glc:1 slc:1 tfe:1 addr64:0 lds:0",
2112        0xe000425bU, 0x23d43d00U, true, true, "" },
2113    { "    buffer_load_format_x  v[61:62], off, s[80:83], s35 "
2114        "offset:603 glc slc tfe", 0xe000425bU, 0x23d43d00U, true, true, "" },
2115    { "    buffer_load_format_x_e64  v[61:62], v[18:19], s[80:83], s35 "
2116        "offset:603 glc slc addr64 tfe", 0xe000c25bU, 0x23d43d12U, true, true, "" },
2117    { "    buffer_load_format_x  v61, v[18:19], s[80:83], s35 "
2118        "offset:603 glc slc addr64 lds", 0xe001c25bU, 0x23543d12U, true, true, "" },
2119    { "    buffer_load_format_x  v61, v[18:19], s[80:83], s35 "
2120        "offset:603 glc:1 slc:1 addr64:1 lds:1", 0xe001c25bU, 0x23543d12U, true, true, "" },
2121    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 "
2122        "offset:603 glc slc addr64 lds tfe", 0, 0, false, false,
2123        "test.s:1:5: Error: Both LDS and TFE is illegal\n" },
2124    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], 31 "
2125        "offset:603 glc slc addr64 tfe", 0xe000c25bU, 0x9fd43d12U, true, true, "" },
2126    { "    buffer_load_format_x  v61, v18, s[80:83], s35   ",
2127        0xe0000000U, 0x23143d12U, true, true, "" },
2128    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 "
2129        "offset:603 glc slc addr64 tfe", 0xe000c25bU, 0x23d43d12U, true, true, "" },
2130    { "    buffer_load_format_x  v61, v[18:19], s[80:83], s35 offset:603 glc slc addr64",
2131        0xe000c25bU, 0x23543d12U, true, true, "" },
2132    { "    buffer_load_format_x  v61, v18, s[80:83], s35 offset:603",
2133        0xe000025bU, 0x23143d12U, true, true, "" },
2134    { "    buffer_load_format_x  v61, v18, s[80:83], s35 offset  :  603",
2135        0xe000025bU, 0x23143d12U, true, true, "" },
2136    { "    buffer_load_format_x  v61, v18, s[80:83], s35 OfFset  :  603",
2137        0xe000025bU, 0x23143d12U, true, true, "" },
2138    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 "
2139        "glc slc addr64 tfe", 0xe000c000U, 0x23d43d12U, true, true, "" },
2140    { "xx=5; yy=7;buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 "
2141        "offset:xx+yy glc slc addr64 tfe", 0xe000c00cU, 0x23d43d12U, true, true, "" },
2142    { "buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 offset:xx+yy "
2143        "glc slc addr64 tfe;xx=5; yy=7", 0xe000c00cU, 0x23d43d12U, true, true, "" },
2144    { "    buffer_load_format_x v[61:62], v[18:19], s[80:83], s35 offen idxen "
2145        "glc slc tfe", 0xe0007000U, 0x23d43d12U, true, true, "" },
2146    { "    buffer_load_format_x v[61:62], v18, s[80:83], s35 offset:577 idxen "
2147        "glc slc tfe", 0xe0006241U, 0x23d43d12U, true, true, "" },
2148    /* MUBUF/MTBUF offset warnings */
2149    { "    buffer_load_format_x  v61, v18, s[80:83], s35 offset:4603",
2150        0xe00001fbU, 0x23143d12U, true, true,
2151        "test.s:1:58: Warning: Value 0x11fb truncated to 0x1fb\n" },
2152    { "    buffer_load_format_x  v61, v18, s[80:83], s35 offset:x; x=4603",
2153        0xe00001fbU, 0x23143d12U, true, true,
2154        "test.s:1:58: Warning: Value 0x11fb truncated to 0x1fb\n" },
2155    { "    buffer_load_format_x  v61, v18, s[80:83], s35 offset:x glc; x=4603",
2156        0xe00041fbU, 0x23143d12U, true, true,
2157        "test.s:1:58: Warning: Value 0x11fb truncated to 0x1fb\n" },
2158    { "    buffer_load_format_x  v61, v18, s[80:83], s35 offset:1779 offset:603",
2159        0xe000025bU, 0x23143d12U, true, true,
2160        "test.s:1:63: Warning: Offset is already defined\n" },
2161    /* MUBUF errors */
2162    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 "
2163        "offset:603 glc slc addr64 lds tfe idxen", 0, 0, false, false,
2164        "test.s:1:5: Error: Idxen and offen must be zero in 64-bit address mode\n" },
2165    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35 "
2166        "offset:603 glc slc addr64 lds tfe offen", 0, 0, false, false,
2167        "test.s:1:5: Error: Idxen and offen must be zero in 64-bit address mode\n" },
2168    { "    buffer_load_format_x  v61, v18, s[80:83], s35 offset,", 0, 0, false, false,
2169        "test.s:1:57: Error: Expected ':' before offset\n"
2170        "test.s:1:57: Error: Some garbages at MUBUF modifier place\n" },
2171    { "    buffer_load_format_x  v[61:63], v[18:20], s[80:83], s35 "
2172        "offset:603 glc slc addr64 lds tfe", 0, 0, false, false,
2173        "test.s:1:27: Error: Required 2 vector registers\n"
2174        "test.s:1:37: Error: Required 2 vector registers\n" },
2175    { "    buffer_load_format_x  v[61:62], v[18:19], s[80:83], s35"
2176        "offset:603 glc slc addr64 lds", 0, 0, false, false,
2177        "test.s:1:57: Error: Literal in MUBUF is illegal\n"
2178        "test.s:1:66: Error: Some garbages at MUBUF modifier place\n"
2179        "test.s:1:27: Error: Required 1 vector register\n" },
2180    { "    buffer_load_format_x  v61, v18, s[80:83], s35 offset:603 tfx",
2181        0, 0, false, false, "test.s:1:62: Error: Unknown MUBUF modifier\n" },
2182    { "    buffer_store_format_xyz v[61:63], v18, s[80:83], s35 idxen offset:603 tfe",
2183        0, 0, false, false, "test.s:1:29: Error: Required 4 vector registers\n" },
2184    { "    buffer_store_format_xyzw v[61:64], v18, s[80:83], s35 idxen offset:603 tfe",
2185        0, 0, false, false, "test.s:1:30: Error: Required 5 vector registers\n" },
2186    { "    buffer_load_format_x v61, v18, s[80:83], 3435 idxen offset:603",
2187        0, 0, false, false, "test.s:1:46: Error: Literal in MUBUF is illegal\n" },
2188    { "    buffer_load_format_x v61, v18, s[80:83], xx idxen offset:603",
2189        0, 0, false, false, "test.s:1:46: Error: Literal in MUBUF is illegal\n" },
2190    { "    buffer_load_format_x  v[61:62], s[80:83], s35 "
2191        "offset:603 glc slc addr64 tfe", 0, 0, false, false,
2192        "test.s:1:37: Error: VADDR is required if idxen, offen or addr64 is enabled\n" },
2193    /* other MUBUF instructions */
2194    { "    buffer_load_format_x v61, v18, s[80:83], s35 idxen offset:603",
2195        0xe000225bU, 0x23143d12U, true, true, "" },
2196    { "    buffer_load_format_xy v[61:62], v18, s[80:83], s35 idxen offset:603",
2197        0xe004225bU, 0x23143d12U, true, true, "" },
2198    { "    buffer_load_format_xyz v[61:63], v18, s[80:83], s35 idxen offset:603",
2199        0xe008225bU, 0x23143d12U, true, true, "" },
2200    { "    buffer_load_format_xyzw v[61:64], v18, s[80:83], s35 idxen offset:603",
2201        0xe00c225bU, 0x23143d12U, true, true, "" },
2202    { "    buffer_store_format_x v61, v18, s[80:83], s35 idxen offset:603",
2203        0xe010225bU, 0x23143d12U, true, true, "" },
2204    { "    buffer_store_format_xy v[61:62], v18, s[80:83], s35 idxen offset:603",
2205        0xe014225bU, 0x23143d12U, true, true, "" },
2206    { "    buffer_store_format_xy v[61:63], v18, s[80:83], s35 idxen offset:603 tfe",
2207        0xe014225bU, 0x23943d12U, true, true, "" },
2208    { "    buffer_store_format_xyz v[61:63], v18, s[80:83], s35 idxen offset:603",
2209        0xe018225bU, 0x23143d12U, true, true, "" },
2210    { "    buffer_store_format_xyz v[61:64], v18, s[80:83], s35 idxen offset:603 tfe",
2211        0xe018225bU, 0x23943d12U, true, true, "" },
2212    { "    buffer_store_format_xyzw v[61:64], v18, s[80:83], s35 idxen offset:603",
2213        0xe01c225bU, 0x23143d12U, true, true, "" },
2214    { "    buffer_store_format_xyzw v[61:65], v18, s[80:83], s35 idxen offset:603 tfe",
2215        0xe01c225bU, 0x23943d12U, true, true, "" },
2216    { "    buffer_load_ubyte v61, v18, s[80:83], s35 idxen offset:603",
2217        0xe020225bU, 0x23143d12U, true, true, "" },
2218    { "    buffer_load_sbyte v61, v18, s[80:83], s35 idxen offset:603",
2219        0xe024225bU, 0x23143d12U, true, true, "" },
2220    { "    buffer_load_ushort v61, v18, s[80:83], s35 idxen offset:603",
2221        0xe028225bU, 0x23143d12U, true, true, "" },
2222    { "    buffer_load_sshort v61, v18, s[80:83], s35 idxen offset:603",
2223        0xe02c225bU, 0x23143d12U, true, true, "" },
2224    { "    buffer_load_dword v61, v18, s[80:83], s35 idxen offset:603",
2225        0xe030225bU, 0x23143d12U, true, true, "" },
2226    { "    buffer_load_dwordx2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2227        0xe034225bU, 0x23143d12U, true, true, "" },
2228    { "    buffer_load_dwordx4 v[61:64], v18, s[80:83], s35 idxen offset:603",
2229        0xe038225bU, 0x23143d12U, true, true, "" },
2230    { "    buffer_store_byte v61, v18, s[80:83], s35 idxen offset:603",
2231        0xe060225bU, 0x23143d12U, true, true, "" },
2232    { "    buffer_store_short v61, v18, s[80:83], s35 idxen offset:603",
2233        0xe068225bU, 0x23143d12U, true, true, "" },
2234    { "    buffer_store_dword v61, v18, s[80:83], s35 idxen offset:603",
2235        0xe070225bU, 0x23143d12U, true, true, "" },
2236    { "    buffer_store_dwordx2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2237        0xe074225bU, 0x23143d12U, true, true, "" },
2238    { "    buffer_store_dwordx4 v[61:64], v18, s[80:83], s35 idxen offset:603",
2239        0xe078225bU, 0x23143d12U, true, true, "" },
2240    { "    buffer_atomic_swap v61, v18, s[80:83], s35 idxen offset:603",
2241        0xe0c0225bU, 0x23143d12U, true, true, "" },
2242    { "    buffer_atomic_cmpswap v[61:62], v18, s[80:83], s35 idxen offset:603",
2243        0xe0c4225bU, 0x23143d12U, true, true, "" },
2244    { "    buffer_atomic_add v61, v18, s[80:83], s35 idxen offset:603",
2245        0xe0c8225bU, 0x23143d12U, true, true, "" },
2246    { "    buffer_atomic_sub v61, v18, s[80:83], s35 idxen offset:603",
2247        0xe0cc225bU, 0x23143d12U, true, true, "" },
2248    { "    buffer_atomic_rsub v61, v18, s[80:83], s35 idxen offset:603",
2249        0xe0d0225bU, 0x23143d12U, true, true, "" },
2250    { "    buffer_atomic_smin v61, v18, s[80:83], s35 idxen offset:603",
2251        0xe0d4225bU, 0x23143d12U, true, true, "" },
2252    { "    buffer_atomic_umin v61, v18, s[80:83], s35 idxen offset:603",
2253        0xe0d8225bU, 0x23143d12U, true, true, "" },
2254    { "    buffer_atomic_smax v61, v18, s[80:83], s35 idxen offset:603",
2255        0xe0dc225bU, 0x23143d12U, true, true, "" },
2256    { "    buffer_atomic_umax v61, v18, s[80:83], s35 idxen offset:603",
2257        0xe0e0225bU, 0x23143d12U, true, true, "" },
2258    { "    buffer_atomic_and v61, v18, s[80:83], s35 idxen offset:603",
2259        0xe0e4225bU, 0x23143d12U, true, true, "" },
2260    { "    buffer_atomic_or v61, v18, s[80:83], s35 idxen offset:603",
2261        0xe0e8225bU, 0x23143d12U, true, true, "" },
2262    { "    buffer_atomic_xor v61, v18, s[80:83], s35 idxen offset:603",
2263        0xe0ec225bU, 0x23143d12U, true, true, "" },
2264    { "    buffer_atomic_inc v61, v18, s[80:83], s35 idxen offset:603",
2265        0xe0f0225bU, 0x23143d12U, true, true, "" },
2266    { "    buffer_atomic_dec v61, v18, s[80:83], s35 idxen offset:603",
2267        0xe0f4225bU, 0x23143d12U, true, true, "" },
2268    { "    buffer_atomic_fcmpswap v[61:62], v18, s[80:83], s35 idxen offset:603",
2269        0xe0f8225bU, 0x23143d12U, true, true, "" },
2270    { "    buffer_atomic_fmin v61, v18, s[80:83], s35 idxen offset:603",
2271        0xe0fc225bU, 0x23143d12U, true, true, "" },
2272    { "    buffer_atomic_fmax v61, v18, s[80:83], s35 idxen offset:603",
2273        0xe100225bU, 0x23143d12U, true, true, "" },
2274    { "    buffer_atomic_swap_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2275        0xe140225bU, 0x23143d12U, true, true, "" },
2276    { "    buffer_atomic_cmpswap_x2 v[61:64], v18, s[80:83], s35 idxen offset:603",
2277        0xe144225bU, 0x23143d12U, true, true, "" },
2278    { "    buffer_atomic_add_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2279        0xe148225bU, 0x23143d12U, true, true, "" },
2280    { "    buffer_atomic_sub_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2281        0xe14c225bU, 0x23143d12U, true, true, "" },
2282    { "    buffer_atomic_rsub_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2283        0xe150225bU, 0x23143d12U, true, true, "" },
2284    { "    buffer_atomic_smin_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2285        0xe154225bU, 0x23143d12U, true, true, "" },
2286    { "    buffer_atomic_umin_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2287        0xe158225bU, 0x23143d12U, true, true, "" },
2288    { "    buffer_atomic_smax_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2289        0xe15c225bU, 0x23143d12U, true, true, "" },
2290    { "    buffer_atomic_umax_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2291        0xe160225bU, 0x23143d12U, true, true, "" },
2292    { "    buffer_atomic_and_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2293        0xe164225bU, 0x23143d12U, true, true, "" },
2294    { "    buffer_atomic_or_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2295        0xe168225bU, 0x23143d12U, true, true, "" },
2296    { "    buffer_atomic_xor_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2297        0xe16c225bU, 0x23143d12U, true, true, "" },
2298    { "    buffer_atomic_inc_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2299        0xe170225bU, 0x23143d12U, true, true, "" },
2300    { "    buffer_atomic_dec_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2301        0xe174225bU, 0x23143d12U, true, true, "" },
2302    { "    buffer_atomic_fcmpswap_x2 v[61:64], v18, s[80:83], s35 idxen offset:603",
2303        0xe178225bU, 0x23143d12U, true, true, "" },
2304    { "    buffer_atomic_fmin_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2305        0xe17c225bU, 0x23143d12U, true, true, "" },
2306    { "    buffer_atomic_fmax_x2 v[61:62], v18, s[80:83], s35 idxen offset:603",
2307        0xe180225bU, 0x23143d12U, true, true, "" },
2308    { "    buffer_wbinvl1_sc", 0xe1c00000U, 0x00000000U, true, true, "" },
2309    { "    buffer_wbinvl1_sc idxen offset:603 lds",
2310        0xe1c1225bU, 0x00000000U, true, true, "" },
2311    { "    buffer_wbinvl1", 0xe1c40000U, 0x00000000U, true, true, "" },
2312    /* MTBUF encoding */
2313    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2314        "glc slc tfe format:[8,sint]", 0xea8867d4U, 0x23d43d12U, true, true, "" },
2315    /* formats */
2316    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2317        "glc slc tfe", 0xe80867d4U, 0x23d43d12U, true, true, "" },
2318    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2319        "glc slc tfe format:[sint]", 0xea8867d4U, 0x23d43d12U, true, true, "" },
2320    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2321        "glc slc tfe format:[BUF_DATA_FORMAT_8,BUF_NUM_FORMAT_SINT]",
2322        0xea8867d4U, 0x23d43d12U, true, true, "" },
2323    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2324        "glc slc tfe format:[16]", 0xe81067d4U, 0x23d43d12U, true, true, "" },
2325    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2326        "glc slc tfe format:[@2]", 0xe81067d4U, 0x23d43d12U, true, true, "" },
2327    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2328        "glc slc tfe format:[8_8]", 0xe81867d4U, 0x23d43d12U, true, true, "" },
2329    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2330        "glc slc tfe format:[32]", 0xe82067d4U, 0x23d43d12U, true, true, "" },
2331    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2332        "glc slc tfe format:[16_16]", 0xe82867d4U, 0x23d43d12U, true, true, "" },
2333    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2334        "glc slc tfe format:[10_11_11]", 0xe83067d4U, 0x23d43d12U, true, true, "" },
2335    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2336        "glc slc tfe format:[11_11_10]", 0xe83867d4U, 0x23d43d12U, true, true, "" },
2337    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2338        "glc slc tfe format:[10_10_10_2]", 0xe84067d4U, 0x23d43d12U, true, true, "" },
2339    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2340        "glc slc tfe format:[2_10_10_10]", 0xe84867d4U, 0x23d43d12U, true, true, "" },
2341    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2342        "glc slc tfe format:[@9]", 0xe84867d4U, 0x23d43d12U, true, true, "" },
2343    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2344        "glc slc tfe format:[8_8_8_8]", 0xe85067d4U, 0x23d43d12U, true, true, "" },
2345    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2346        "glc slc tfe format:[32_32]", 0xe85867d4U, 0x23d43d12U, true, true, "" },
2347    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2348        "glc slc tfe format:[16_16_16_16]", 0xe86067d4U, 0x23d43d12U, true, true, "" },
2349    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2350        "glc slc tfe format:[32_32_32]", 0xe86867d4U, 0x23d43d12U, true, true, "" },
2351    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2352        "glc slc tfe format:[32_32_32_32]", 0xe87067d4U, 0x23d43d12U, true, true, "" },
2353    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2354        "glc slc tfe format:[BUF_DATA_FORMAT_16]",
2355        0xe81067d4U, 0x23d43d12U, true, true, "" },
2356    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2357        "glc slc tfe format:[BUF_DATA_FORMAT_8_8]",
2358        0xe81867d4U, 0x23d43d12U, true, true, "" },
2359    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2360        "glc slc tfe format:[BUF_DATA_FORMAT_32]",
2361        0xe82067d4U, 0x23d43d12U, true, true, "" },
2362    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2363        "glc slc tfe format:[BUF_DATA_FORMAT_16_16]",
2364        0xe82867d4U, 0x23d43d12U, true, true, "" },
2365    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2366        "glc slc tfe format:[BUF_DATA_FORMAT_10_11_11]",
2367        0xe83067d4U, 0x23d43d12U, true, true, "" },
2368    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2369        "glc slc tfe format:[BUF_DATA_FORMAT_11_11_10]",
2370        0xe83867d4U, 0x23d43d12U, true, true, "" },
2371    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2372        "glc slc tfe format:[BUF_DATA_FORMAT_10_10_10_2]",
2373        0xe84067d4U, 0x23d43d12U, true, true, "" },
2374    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2375        "glc slc tfe format:[BUF_DATA_FORMAT_2_10_10_10]",
2376        0xe84867d4U, 0x23d43d12U, true, true, "" },
2377    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2378        "glc slc tfe format:[BUF_DATA_FORMAT_8_8_8_8]",
2379        0xe85067d4U, 0x23d43d12U, true, true, "" },
2380    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2381        "glc slc tfe format:[BUF_DATA_FORMAT_32_32]",
2382        0xe85867d4U, 0x23d43d12U, true, true, "" },
2383    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2384        "glc slc tfe format:[BUF_DATA_FORMAT_16_16_16_16]",
2385        0xe86067d4U, 0x23d43d12U, true, true, "" },
2386    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2387        "glc slc tfe format:[BUF_DATA_FORMAT_32_32_32]",
2388        0xe86867d4U, 0x23d43d12U, true, true, "" },
2389    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2390        "glc slc tfe format:[BUF_DATA_FORMAT_32_32_32_32]",
2391        0xe87067d4U, 0x23d43d12U, true, true, "" },
2392   
2393    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2394        "glc slc tfe format:[unorm]", 0xe80867d4U, 0x23d43d12U, true, true, "" },
2395    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2396        "glc slc tfe format:[snorm]", 0xe88867d4U, 0x23d43d12U, true, true, "" },
2397    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2398        "glc slc tfe format:[uscaled]", 0xe90867d4U, 0x23d43d12U, true, true, "" },
2399    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2400        "glc slc tfe format:[sscaled]", 0xe98867d4U, 0x23d43d12U, true, true, "" },
2401    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2402        "glc slc tfe format:[uint]", 0xea0867d4U, 0x23d43d12U, true, true, "" },
2403    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2404        "glc slc tfe format:[sint]", 0xea8867d4U, 0x23d43d12U, true, true, "" },
2405    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2406        "glc slc tfe format:[snorm_ogl]", 0xeb0867d4U, 0x23d43d12U, true, true, "" },
2407    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2408        "glc slc tfe format:[float]", 0xeb8867d4U, 0x23d43d12U, true, true, "" },
2409    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2410        "glc slc tfe format:[BUF_NUM_FORMAT_UNORM]",
2411        0xe80867d4U, 0x23d43d12U, true, true, "" },
2412    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2413        "glc slc tfe format:[BUF_NUM_FORMAT_SNORM]",
2414        0xe88867d4U, 0x23d43d12U, true, true, "" },
2415    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2416        "glc slc tfe format:[BUF_NUM_FORMAT_USCALED]",
2417        0xe90867d4U, 0x23d43d12U, true, true, "" },
2418    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2419        "glc slc tfe format:[BUF_NUM_FORMAT_SSCALED]",
2420        0xe98867d4U, 0x23d43d12U, true, true, "" },
2421    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2422        "glc slc tfe format:[BUF_NUM_FORMAT_UINT]",
2423        0xea0867d4U, 0x23d43d12U, true, true, "" },
2424    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2425        "glc slc tfe format:[BUF_NUM_FORMAT_SINT]",
2426        0xea8867d4U, 0x23d43d12U, true, true, "" },
2427    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2428        "glc slc tfe format:[BUF_NUM_FORMAT_SNORM_OGL]",
2429        0xeb0867d4U, 0x23d43d12U, true, true, "" },
2430    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2431        "glc slc tfe format:[BUF_NUM_FORMAT_FLOAT]",
2432        0xeb8867d4U, 0x23d43d12U, true, true, "" },
2433   
2434    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2435        "glc slc tfe format:[10_11_11,sscaled]", 0xe9b067d4U, 0x23d43d12U, true, true, "" },
2436    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2437        "glc slc tfe format  : [  10_11_11 , sscaled  ]",
2438        0xe9b067d4U, 0x23d43d12U, true, true, "" },
2439    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2440        "glc slc tfe format:[BUF_DATA_FORMAT_10_11_11,BUF_NUM_FORMAT_SSCALED]",
2441        0xe9b067d4U, 0x23d43d12U, true, true, "" },
2442    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2443        "glc slc tfe format:[@6,@3]", 0xe9b067d4U, 0x23d43d12U, true, true, "" },
2444    /* MTBUF format errors */
2445    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2446        "glc slc tfe format:[]", 0, 0, false, false,
2447        "test.s:1:94: Error: Some garbages at data/number format place\n"
2448        "test.s:1:95: Error: Unterminated format modifier\n" },
2449    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2450        "glc slc tfe format:[xxx]", 0, 0, false, false,
2451        "test.s:1:94: Error: Unknown data/number format\n" },
2452    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2453        "glc slc tfe format:[16_16,aaa]", 0, 0, false, false,
2454        "test.s:1:100: Error: Unknown number format\n" },
2455    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2456        "glc slc tfe format:[16_16", 0, 0, false, false,
2457        "test.s:1:99: Error: Unterminated format modifier\n" },
2458    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2459        "glc slc tfe format:[xx,yy", 0, 0, false, false,
2460        "test.s:1:94: Error: Unknown data/number format\n"
2461        "test.s:1:97: Error: Unknown number format\n"
2462        "test.s:1:99: Error: Unterminated format modifier\n" },
2463    /* MTBUF errors */
2464    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2465        "glc slc tfe lds", 0, 0, false, false,
2466        "test.s:1:86: Error: Unknown MTBUF modifier\n" },
2467    { "    tbuffer_load_format_x v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2468        "glc slc tfe offenx", 0, 0, false, false,
2469        "test.s:1:86: Error: Unknown MTBUF modifier\n" },
2470    /* MTBUF instructions */
2471    { "    tbuffer_load_format_xy v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2472        "glc slc", 0xe80967d4U, 0x23543d12U, true, true, "" },
2473    { "    tbuffer_load_format_xyz v[61:63], v18, s[80:83], s35 idxen offset:2004 "
2474        "glc slc", 0xe80a67d4U, 0x23543d12U, true, true, "" },
2475    { "    tbuffer_load_format_xyzw v[61:64], v18, s[80:83], s35 idxen offset:2004 "
2476        "glc slc", 0xe80b67d4U, 0x23543d12U, true, true, "" },
2477    { "    tbuffer_store_format_x v61, v18, s[80:83], s35 idxen offset:2004 "
2478        "glc slc", 0xe80c67d4U, 0x23543d12U, true, true, "" },
2479    { "    tbuffer_store_format_xy v[61:62], v18, s[80:83], s35 idxen offset:2004 "
2480        "glc slc", 0xe80d67d4U, 0x23543d12U, true, true, "" },
2481    { "    tbuffer_store_format_xyz v[61:63], v18, s[80:83], s35 idxen offset:2004 "
2482        "glc slc", 0xe80e67d4U, 0x23543d12U, true, true, "" },
2483    { "    tbuffer_store_format_xyzw v[61:64], v18, s[80:83], s35 idxen offset:2004 "
2484        "glc slc", 0xe80f67d4U, 0x23543d12U, true, true, "" },
2485    /* MIMG encoding */
2486    { "    image_load  v[157:160], v[121:124], s[84:87] dmask:11 unorm glc slc r128 "
2487        "tfe lwe da", 0xf203fb00U, 0x00159d79U, true, true, "" },
2488    { "    image_load      v[157:158], v[121:124], s[84:87] unorm glc slc r128 tfe lwe da",
2489        0xf203f100U, 0x00159d79U, true, true, "" },
2490    { "    image_load  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc slc r128 "
2491        "lwe da", 0xf202fb00U, 0x00159d79U, true, true, "" },
2492    { "dmask=5;image_load  v[157:158], v[121:124], s[84:87] dmask:dmask unorm glc "
2493        "slc r128 lwe da", 0xf202f500U, 0x00159d79U, true, true, "" },
2494    { "    image_load  v157, v[121:124], s[84:91]    ",
2495        0xf0000100U, 0x00159d79U, true, true, "" },
2496    /* dmask */
2497    { "    image_load  v157, v[121:124], s[84:87] dmask:1 unorm glc slc r128 lwe da",
2498        0xf202f100U, 0x00159d79U, true, true, "" },
2499    { "    image_load  v157, v[121:124], s[84:87] "
2500        "dmask:1 unorm:1 glc:1 slc:1 r128:1 lwe:1 da:1",
2501        0xf202f100U, 0x00159d79U, true, true, "" },
2502    { "    image_load  v157, v[121:124], s[84:87] dmask:2 unorm glc slc r128 lwe da",
2503        0xf202f200U, 0x00159d79U, true, true, "" },
2504    { "    image_load  v[157:158], v[121:124], s[84:87] dmask:3 unorm glc slc r128 "
2505        "lwe da", 0xf202f300U, 0x00159d79U, true, true, "" },
2506    { "    image_load  v157, v[121:124], s[84:87] dmask:4 unorm glc slc r128 lwe da",
2507        0xf202f400U, 0x00159d79U, true, true, "" },
2508    { "    image_load  v[157:158], v[121:124], s[84:87] dmask:5 unorm glc slc r128 "
2509        "lwe da", 0xf202f500U, 0x00159d79U, true, true, "" },
2510    { "    image_load  v[157:158], v[121:124], s[84:87] dmask:6 unorm glc slc r128 "
2511        "lwe da", 0xf202f600U, 0x00159d79U, true, true, "" },
2512    { "    image_load  v[157:159], v[121:124], s[84:87] dmask:7 unorm glc slc r128 "
2513        "lwe da", 0xf202f700U, 0x00159d79U, true, true, "" },
2514    { "    image_load  v157, v[121:124], s[84:87] dmask:8 unorm glc slc r128 lwe da",
2515        0xf202f800U, 0x00159d79U, true, true, "" },
2516    { "    image_load  v[157:158], v[121:124], s[84:87] dmask:9 unorm glc slc r128 "
2517        "lwe da", 0xf202f900U, 0x00159d79U, true, true, "" },
2518    { "    image_load  v[157:158], v[121:124], s[84:87] dmask:10 unorm glc slc r128 "
2519        "lwe da", 0xf202fa00U, 0x00159d79U, true, true, "" },
2520    { "    image_load  v[157:158], v[121:124], s[84:87] dmask:0xa unorm glc slc r128 "
2521        "lwe da", 0xf202fa00U, 0x00159d79U, true, true, "" },
2522    { "    image_load  v[157:160], v[121:124], s[84:87] dmask:15 unorm glc slc r128 "
2523        "lwe da", 0xf202ff00U, 0x00159d79U, true, true, "" },
2524    { "    image_load  v[157:160], v[121:124], s[84:87] dmask:0xf unorm glc slc r128 "
2525        "lwe da", 0xf202ff00U, 0x00159d79U, true, true, "" },
2526    { "    image_load  v[157:161], v[121:124], s[84:87] dmask:0xf unorm glc tfe slc r128 "
2527        "lwe da", 0xf203ff00U, 0x00159d79U, true, true, "" },
2528    /* MIMG flags */
2529    { "    image_load  v157, v[121:124], s[84:91]",
2530        0xf0000100U, 0x00159d79U, true, true, "" },
2531    { "    image_load  v157, v[121:124], s[84:91] unorm",
2532        0xf0001100U, 0x00159d79U, true, true, "" },
2533    { "    image_load  v157, v[121:124], s[84:91] glc",
2534        0xf0002100U, 0x00159d79U, true, true, "" },
2535    { "    image_load  v157, v[121:124], s[84:91] da",
2536        0xf0004100U, 0x00159d79U, true, true, "" },
2537    { "    image_load  v157, v[121:124], s[84:87] r128",
2538        0xf0008100U, 0x00159d79U, true, true, "" },
2539    { "    image_load  v[157:158], v[121:124], s[84:91] tfe",
2540        0xf0010100U, 0x00159d79U, true, true, "" },
2541    { "    image_load  v157, v[121:124], s[84:91] lwe",
2542        0xf0020100U, 0x00159d79U, true, true, "" },
2543    { "    image_load  v157, v[121:124], s[84:91] slc",
2544        0xf2000100U, 0x00159d79U, true, true, "" },
2545    { "    image_load  v157, v[121:124], s[84:91] unorm:0 glc:0 da:0 r128:0 tfe:0 lwe:0",
2546        0xf0000100U, 0x00159d79U, true, true, "" },
2547    { "    image_load  v157, v[121:124], s[84:91] unorm:1 glc:0 da:0 r128:0 tfe:0 lwe:0",
2548        0xf0001100U, 0x00159d79U, true, true, "" },
2549    { "    image_load  v157, v[121:124], s[84:91] unorm:0 glc:1 da:0 r128:0 tfe:0 lwe:0",
2550        0xf0002100U, 0x00159d79U, true, true, "" },
2551    { "    image_load  v157, v[121:124], s[84:91] unorm:0 glc:0 da:1 r128:0 tfe:0 lwe:0",
2552        0xf0004100U, 0x00159d79U, true, true, "" },
2553    { "    image_load  v157, v[121:124], s[84:87] unorm:0 glc:0 da:0 r128:1 tfe:0 lwe:0",
2554        0xf0008100U, 0x00159d79U, true, true, "" },
2555    { "    image_load  v[157:158], v[121:124], s[84:91] "
2556        "unorm:0 glc:0 da:0 r128:0 tfe:1 lwe:0",
2557        0xf0010100U, 0x00159d79U, true, true, "" },
2558    { "    image_load  v157, v[121:124], s[84:91] unorm:0 glc:0 da:0 r128:0 tfe:0 lwe:1",
2559        0xf0020100U, 0x00159d79U, true, true, "" },
2560    { "    image_load  v157, v[121:124], s[84:91] unorm:0 glc:0 da:0 r128:0 tfe:0 slc:1",
2561        0xf2000100U, 0x00159d79U, true, true, "" },
2562    /* MIMG errors */
2563    { "    image_load  v157, v[121:124], s[84:91] sxc", 0, 0, false, false,
2564        "test.s:1:44: Error: Unknown MIMG modifier\n" },
2565    { "    image_load  v157, v[121:124], s[84:91] g53 aa3 daa db", 0, 0, false, false,
2566        "test.s:1:44: Error: Unknown MIMG modifier\n"
2567        "test.s:1:48: Error: Unknown MIMG modifier\n"
2568        "test.s:1:52: Error: Unknown MIMG modifier\n"
2569        "test.s:1:56: Error: Unknown MIMG modifier\n" },
2570    { "    image_load  v157, v[121:124], s[84:91] dmask:", 0, 0, false, false,
2571        "test.s:1:50: Error: Expected expression\n" },
2572    { "    image_load  v157, v[121:124], s[84:91] dmask", 0, 0, false, false,
2573        "test.s:1:49: Error: Expected ':' before dmask\n" },
2574    { "    image_load  v157, v[121:124], s[84:90]", 0, 0, false, false,
2575        "test.s:1:35: Error: Required 8 scalar registers\n" },
2576    { "    image_load  v157, v[121:124], s[84:90] r128", 0, 0, false, false,
2577        "test.s:1:35: Error: Required 4 scalar registers\n" },
2578    { "    image_store v157, v[121:124], s[84:91]", 0, 0, false, false,
2579        "test.s:1:5: Error: Unorm is not set for store or atomic instruction\n" },
2580    { "    image_atomic_add v157, v[121:124], s[84:91]", 0, 0, false, false,
2581        "test.s:1:5: Error: Unorm is not set for store or atomic instruction\n" },
2582    { "    image_load  v[157:158], v[121:124], s[84:87] dmask:8 unorm r128 lwe da",
2583        0, 0, false, false, "test.s:1:17: Error: Required 1 vector register\n" },
2584    { "    image_load  v[157:158], v[121:124], s[84:87] dmask:11 unorm r128 lwe da",
2585        0, 0, false, false, "test.s:1:17: Error: Required 3 vector registers\n" },
2586    { "    image_load  v157, v[121:124], s[84:87] dmask:0 unorm glc slc r128 lwe da",
2587        0, 0, false, false, "test.s:1:50: Error: Zero in dmask is illegal\n" },
2588    { "    image_load  v157, v[121:124], s[84:87] dmask:0x1ab0 unorm glc slc r128 lwe da",
2589        0, 0, false, false, "test.s:1:50: Warning: Dmask out of range (0-15)\n"
2590        "test.s:1:50: Error: Zero in dmask is illegal\n" },
2591    /* MIMG warnings */
2592    { "    image_load  v[157:161], v[121:124], s[84:87] dmask:0xdaf unorm glc tfe slc r128 "
2593        "lwe da", 0xf203ff00U, 0x00159d79U, true, true,
2594        "test.s:1:56: Warning: Dmask out of range (0-15)\n" },
2595    /* MIMG instructions */
2596    { "    image_load_mip  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2597        0xf004fb00U, 0x00159d79U, true, true, "" },
2598    { "    image_load_pck  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2599        0xf008fb00U, 0x00159d79U, true, true, "" },
2600    { "    image_load_pck_sgn  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2601        0xf00cfb00U, 0x00159d79U, true, true, "" },
2602    { "    image_load_mip_pck  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2603        0xf010fb00U, 0x00159d79U, true, true, "" },
2604    { "    image_load_mip_pck_sgn  v[157:159], v[121:124], s[84:87] dmask:11 unorm "
2605        "glc r128 da", 0xf014fb00U, 0x00159d79U, true, true, "" },
2606    { "    image_store  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2607        0xf020fb00U, 0x00159d79U, true, true, "" },
2608    { "    image_store_mip  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2609        0xf024fb00U, 0x00159d79U, true, true, "" },
2610    { "    image_store_pck  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2611        0xf028fb00U, 0x00159d79U, true, true, "" },
2612    { "    image_store_mip_pck  v[157:159], v[121:124], s[84:87] dmask:11 unorm "
2613        "glc r128 da", 0xf02cfb00U, 0x00159d79U, true, true, "" },
2614    { "    image_get_resinfo  v[157:159], v[121:124], s[84:87] dmask:11 unorm "
2615        "glc r128 da", 0xf038fb00U, 0x00159d79U, true, true, "" },
2616    { "    image_get_resinfo  v[157:159], v[121:124], s[84:87] dmask:11 glc r128 da",
2617        0xf038eb00U, 0x00159d79U, true, true, "" },
2618    { "    image_atomic_swap  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2619        0xf03cfb00U, 0x00159d79U, true, true, "" },
2620    { "    image_atomic_cmpswap  v[157:159], v[121:124], s[84:87] dmask:11 unorm "
2621        "glc r128 da", 0xf040fb00U, 0x00159d79U, true, true, "" },
2622    { "    image_atomic_add  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2623        0xf044fb00U, 0x00159d79U, true, true, "" },
2624    { "    image_atomic_sub  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2625        0xf048fb00U, 0x00159d79U, true, true, "" },
2626    { "    image_atomic_rsub  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2627        0xf04cfb00U, 0x00159d79U, true, true, "" },
2628    { "    image_atomic_smin  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2629        0xf050fb00U, 0x00159d79U, true, true, "" },
2630    { "    image_atomic_umin  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2631        0xf054fb00U, 0x00159d79U, true, true, "" },
2632    { "    image_atomic_smax  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2633        0xf058fb00U, 0x00159d79U, true, true, "" },
2634    { "    image_atomic_umax  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2635        0xf05cfb00U, 0x00159d79U, true, true, "" },
2636    { "    image_atomic_and  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2637        0xf060fb00U, 0x00159d79U, true, true, "" },
2638    { "    image_atomic_or v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2639        0xf064fb00U, 0x00159d79U, true, true, "" },
2640    { "    image_atomic_xor  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2641        0xf068fb00U, 0x00159d79U, true, true, "" },
2642    { "    image_atomic_inc  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2643        0xf06cfb00U, 0x00159d79U, true, true, "" },
2644    { "    image_atomic_dec  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2645        0xf070fb00U, 0x00159d79U, true, true, "" },
2646    { "    image_atomic_fcmpswap  v[157:159], v[121:124], s[84:87] dmask:11 unorm "
2647        "glc r128 da", 0xf074fb00U, 0x00159d79U, true, true, "" },
2648    { "    image_atomic_fmin  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2649        0xf078fb00U, 0x00159d79U, true, true, "" },
2650    { "    image_atomic_fmax  v[157:159], v[121:124], s[84:87] dmask:11 unorm glc r128 da",
2651        0xf07cfb00U, 0x00159d79U, true, true, "" },
2652    { "    image_sample  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2653        "glc r128 da", 0xf080fb00U, 0x02559d79U, true, true, "" },
2654    { "    image_sample_cl  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2655        "glc r128 da", 0xf084fb00U, 0x02559d79U, true, true, "" },
2656    { "    image_sample_d  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2657        "glc r128 da", 0xf088fb00U, 0x02559d79U, true, true, "" },
2658    { "    image_sample_d_cl  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2659        "glc r128 da", 0xf08cfb00U, 0x02559d79U, true, true, "" },
2660    { "    image_sample_l  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2661        "glc r128 da", 0xf090fb00U, 0x02559d79U, true, true, "" },
2662    { "    image_sample_b  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2663        "glc r128 da", 0xf094fb00U, 0x02559d79U, true, true, "" },
2664    { "    image_sample_b_cl  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2665        "glc r128 da", 0xf098fb00U, 0x02559d79U, true, true, "" },
2666    { "    image_sample_lz  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2667        "glc r128 da", 0xf09cfb00U, 0x02559d79U, true, true, "" },
2668    { "    image_sample_c  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2669        "glc r128 da", 0xf0a0fb00U, 0x02559d79U, true, true, "" },
2670    { "    image_sample_c_cl  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2671        "glc r128 da", 0xf0a4fb00U, 0x02559d79U, true, true, "" },
2672    { "    image_sample_c_d  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2673        "glc r128 da", 0xf0a8fb00U, 0x02559d79U, true, true, "" },
2674    { "    image_sample_c_d_cl  v[157:159], v[121:125], s[84:87], s[72:75] dmask:11 unorm "
2675        "glc r128 da", 0xf0acfb00U, 0x02559d79U, true, true, "" },
2676    { "    image_sample_c_l  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2677        "glc r128 da", 0xf0b0fb00U, 0x02559d79U, true, true, "" },
2678    { "    image_sample_c_b  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2679        "glc r128 da", 0xf0b4fb00U, 0x02559d79U, true, true, "" },
2680    { "    image_sample_c_b_cl  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2681        "glc r128 da", 0xf0b8fb00U, 0x02559d79U, true, true, "" },
2682    { "    image_sample_c_lz  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2683        "glc r128 da", 0xf0bcfb00U, 0x02559d79U, true, true, "" },
2684    { "    image_sample_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2685        "glc r128 da", 0xf0c0fb00U, 0x02559d79U, true, true, "" },
2686    { "    image_sample_cl_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2687        "glc r128 da", 0xf0c4fb00U, 0x02559d79U, true, true, "" },
2688    { "    image_sample_d_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2689        "glc r128 da", 0xf0c8fb00U, 0x02559d79U, true, true, "" },
2690    { "    image_sample_d_cl_o  v[157:159], v[121:125], s[84:87], s[72:75] dmask:11 unorm "
2691        "glc r128 da", 0xf0ccfb00U, 0x02559d79U, true, true, "" },
2692    { "    image_sample_l_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2693        "glc r128 da", 0xf0d0fb00U, 0x02559d79U, true, true, "" },
2694    { "    image_sample_b_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2695        "glc r128 da", 0xf0d4fb00U, 0x02559d79U, true, true, "" },
2696    { "    image_sample_b_cl_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2697        "glc r128 da", 0xf0d8fb00U, 0x02559d79U, true, true, "" },
2698    { "    image_sample_lz_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2699        "glc r128 da", 0xf0dcfb00U, 0x02559d79U, true, true, "" },
2700    { "    image_sample_c_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2701        "glc r128 da", 0xf0e0fb00U, 0x02559d79U, true, true, "" },
2702    { "    image_sample_c_cl_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2703        "glc r128 da", 0xf0e4fb00U, 0x02559d79U, true, true, "" },
2704    { "    image_sample_c_d_o  v[157:159], v[121:125], s[84:87], s[72:75] dmask:11 unorm "
2705        "glc r128 da", 0xf0e8fb00U, 0x02559d79U, true, true, "" },
2706    { "    image_sample_c_d_cl_o  v[157:159], v[121:126], s[84:87], s[72:75] dmask:11 "
2707        "unorm glc r128 da", 0xf0ecfb00U, 0x02559d79U, true, true, "" },
2708    { "    image_sample_c_l_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2709        "glc r128 da", 0xf0f0fb00U, 0x02559d79U, true, true, "" },
2710    { "    image_sample_c_b_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2711        "glc r128 da", 0xf0f4fb00U, 0x02559d79U, true, true, "" },
2712    { "    image_sample_c_b_cl_o  v[157:159], v[121:125], s[84:87], s[72:75] dmask:11 "
2713        "unorm glc r128 da", 0xf0f8fb00U, 0x02559d79U, true, true, "" },
2714    { "    image_sample_c_lz_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2715        "glc r128 da", 0xf0fcfb00U, 0x02559d79U, true, true, "" },
2716    { "    image_gather4  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2717        "glc r128 da", 0xf100fb00U, 0x02559d79U, true, true, "" },
2718    { "    image_gather4_cl  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2719        "glc r128 da", 0xf104fb00U, 0x02559d79U, true, true, "" },
2720    { "    image_gather4_l  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2721        "glc r128 da", 0xf110fb00U, 0x02559d79U, true, true, "" },
2722    { "    image_gather4_b  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2723        "glc r128 da", 0xf114fb00U, 0x02559d79U, true, true, "" },
2724    { "    image_gather4_b_cl  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2725        "glc r128 da", 0xf118fb00U, 0x02559d79U, true, true, "" },
2726    { "    image_gather4_lz  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2727        "glc r128 da", 0xf11cfb00U, 0x02559d79U, true, true, "" },
2728    { "    image_gather4_c  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2729        "glc r128 da", 0xf120fb00U, 0x02559d79U, true, true, "" },
2730    { "    image_gather4_c_cl  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2731        "glc r128 da", 0xf124fb00U, 0x02559d79U, true, true, "" },
2732    { "    image_gather4_c_l  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2733        "glc r128 da", 0xf130fb00U, 0x02559d79U, true, true, "" },
2734    { "    image_gather4_c_b  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2735        "glc r128 da", 0xf134fb00U, 0x02559d79U, true, true, "" },
2736    { "    image_gather4_c_b_cl  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 "
2737        "unorm glc r128 da", 0xf138fb00U, 0x02559d79U, true, true, "" },
2738    { "    image_gather4_c_lz  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2739        "glc r128 da", 0xf13cfb00U, 0x02559d79U, true, true, "" },
2740    { "    image_gather4_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2741        "glc r128 da", 0xf140fb00U, 0x02559d79U, true, true, "" },
2742    { "    image_gather4_cl_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2743        "glc r128 da", 0xf144fb00U, 0x02559d79U, true, true, "" },
2744    { "    image_gather4_l_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2745        "glc r128 da", 0xf150fb00U, 0x02559d79U, true, true, "" },
2746    { "    image_gather4_b_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2747        "glc r128 da", 0xf154fb00U, 0x02559d79U, true, true, "" },
2748    { "    image_gather4_b_cl_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 "
2749        "unorm glc r128 da", 0xf158fb00U, 0x02559d79U, true, true, "" },
2750    { "    image_gather4_lz_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2751        "glc r128 da", 0xf15cfb00U, 0x02559d79U, true, true, "" },
2752    { "    image_gather4_c_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2753        "glc r128 da", 0xf160fb00U, 0x02559d79U, true, true, "" },
2754    { "    image_gather4_c_cl_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 "
2755        "unorm glc r128 da", 0xf164fb00U, 0x02559d79U, true, true, "" },
2756    { "    image_gather4_c_l_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2757        "glc r128 da", 0xf170fb00U, 0x02559d79U, true, true, "" },
2758    { "    image_gather4_c_b_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2759        "glc r128 da", 0xf174fb00U, 0x02559d79U, true, true, "" },
2760    { "    image_gather4_c_b_cl_o  v[157:160], v[121:125], s[84:87], s[72:75] dmask:11 "
2761        "unorm glc r128 da", 0xf178fb00U, 0x02559d79U, true, true, "" },
2762    { "    image_gather4_c_lz_o  v[157:160], v[121:124], s[84:87], s[72:75] dmask:11 "
2763        "unorm glc r128 da", 0xf17cfb00U, 0x02559d79U, true, true, "" },
2764    { "    image_get_lod  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2765        "glc r128 da", 0xf180fb00U, 0x02559d79U, true, true, "" },
2766    { "    image_sample_cd  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2767        "glc r128 da", 0xf1a0fb00U, 0x02559d79U, true, true, "" },
2768    { "    image_sample_cd_cl  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2769        "glc r128 da", 0xf1a4fb00U, 0x02559d79U, true, true, "" },
2770    { "    image_sample_c_cd  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 unorm "
2771        "glc r128 da", 0xf1a8fb00U, 0x02559d79U, true, true, "" },
2772    { "    image_sample_c_cd_cl  v[157:159], v[121:125], s[84:87], s[72:75] dmask:11 "
2773        "unorm glc r128 da", 0xf1acfb00U, 0x02559d79U, true, true, "" },
2774    { "    image_sample_cd_o  v[157:159], v[121:124], s[84:87], s[72:75] dmask:11 "
2775        "unorm glc r128 da", 0xf1b0fb00U, 0x02559d79U, true, true, "" },
2776    { "    image_sample_cd_cl_o  v[157:159], v[121:125], s[84:87], s[72:75] dmask:11 "
2777        "unorm glc r128 da", 0xf1b4fb00U, 0x02559d79U, true, true, "" },
2778    { "    image_sample_c_cd_o  v[157:159], v[121:125], s[84:87], s[72:75] dmask:11 "
2779        "unorm glc r128 da", 0xf1b8fb00U, 0x02559d79U, true, true, "" },
2780    { "    image_sample_c_cd_cl_o  v[157:159], v[121:126], s[84:87], s[72:75] dmask:11 "
2781        "unorm glc r128 da", 0xf1bcfb00U, 0x02559d79U, true, true, "" },
2782    /* EXP encoding */
2783    { "exp  param5, v116, v93, v27, v124 done vm",
2784        0xf8001a5fU, 0x7c1b5d74U, true, true, "" },
2785    { "exp  param25, v116, v93, v27, v124 done vm",
2786        0xf8001b9fU, 0x7c1b5d74U, true, true, "" },
2787    { "exp  param0025, v116, v93, v27, v124 done vm",
2788        0xf8001b9fU, 0x7c1b5d74U, true, true, "" },
2789    { "exp  mrt0, v116, v93, v27, v124 done vm",
2790        0xf800180fU, 0x7c1b5d74U, true, true, "" },
2791    { "exp  mrt6, v116, v93, v27, v124 done vm",
2792        0xf800186fU, 0x7c1b5d74U, true, true, "" },
2793    { "exp  pos0, v116, v93, v27, v124 done vm",
2794        0xf80018cfU, 0x7c1b5d74U, true, true, "" },
2795    { "exp  pos1, v116, v93, v27, v124 done vm",
2796        0xf80018dfU, 0x7c1b5d74U, true, true, "" },
2797    { "exp  pos2, v116, v93, v27, v124 done vm",
2798        0xf80018efU, 0x7c1b5d74U, true, true, "" },
2799    { "exp  pos02, v116, v93, v27, v124 done vm",
2800        0xf80018efU, 0x7c1b5d74U, true, true, "" },
2801    { "exp  pos3, v116, v93, v27, v124 done vm",
2802        0xf80018ffU, 0x7c1b5d74U, true, true, "" },
2803    { "exp  null, v116, v93, v27, v124 done vm",
2804        0xf800189fU, 0x7c1b5d74U, true, true, "" },
2805    { "exp  mrtz, v116, v93, v27, v124 done vm",
2806        0xf800188fU, 0x7c1b5d74U, true, true, "" },
2807    /* EXP encoding: flags */
2808    { "exp  param5, v116, v93, v27, v124 done", 0xf8000a5fU, 0x7c1b5d74U, true, true, "" },
2809    { "exp  param5, v116, v93, v27, v124", 0xf800025fU, 0x7c1b5d74U, true, true, "" },
2810    { "exp  param5, v116, v93, v27, v124   ", 0xf800025fU, 0x7c1b5d74U, true, true, "" },
2811    { "exp  mrt0, v116, v116, v93, off done compr vm",
2812        0xf8001c07U, 0x00005d74U, true, true, "" },
2813    { "exp  mrt0, v116, v116, v93, v93 done compr vm",
2814        0xf8001c0fU, 0x00005d74U, true, true, "" },
2815    { "exp  param5, v116, v93, v27, v124 done:1 compr:0 vm:0",
2816        0xf8000a5fU, 0x7c1b5d74U, true, true, "" },
2817    { "exp  mrt0, v116, v116, v93, v93 done:1 compr:1 vm:1",
2818        0xf8001c0fU, 0x00005d74U, true, true, "" },
2819    { "exp  param5, v116, v93, v27, v124 done:0 compr:0 vm:0",
2820        0xf800025fU, 0x7c1b5d74U, true, true, "" },
2821    { "exp  param5, v116, v93, v27, v124 done:0 compr:0 vm:1",
2822        0xf800125fU, 0x7c1b5d74U, true, true, "" },
2823    /* EXP encoding src enables */
2824    { "exp  param5, v116, v93, v27, off done", 0xf8000a57U, 0x001b5d74U, true, true, "" },
2825    { "exp  param5, v116, v93, off, v124 done", 0xf8000a5bU, 0x7c005d74U, true, true, "" },
2826    { "exp  param5, v116, off, off, v124 done", 0xf8000a59U, 0x7c000074U, true, true, "" },
2827    { "exp  param5, off, v93, v27, off done", 0xf8000a56U, 0x001b5d00U, true, true, "" },
2828    { "exp  param5, off, v93, off, off done", 0xf8000a52U, 0x00005d00U, true, true, "" },
2829    { "exp  mrt0, v116, v116, v93, off done compr vm",
2830        0xf8001c07U, 0x00005d74U, true, true, "" },
2831    { "exp  mrt0, off , v116, v93, v93 done compr vm",
2832        0xf8001c0eU, 0x00005d00U, true, true, "" },
2833    { "exp  mrt0, off , v116, off, v93 done compr vm", 0xf8001c0aU, 0, true, true, "" },
2834    { "exp  mrt0, v116, off, v93, off done compr vm",
2835        0xf8001c05U, 0x00005d74U, true, true, "" },
2836    { "exp  mrt0, off, off, v93, off done compr vm",
2837        0xf8001c04U, 0x00005d00U, true, true, "" },
2838    { "exp  mrt0, v116, off, off, off done compr vm",
2839        0xf8001c01U, 0x00000074U, true, true, "" },
2840    { "exp  param5, v116, v93, off, off",
2841        0xf8000253U, 0x00005d74U, true, true, "" },
2842    /* EXP encoding errors */
2843    { "exp  param5, v116, v93, v27, v124 xxx", 0, 0, false, false,
2844        "test.s:1:35: Error: Unknown EXP modifier\n" },
2845    { "exp  param32, v116, v93, v27, v124 done vm", 0, 0, false, false,
2846        "test.s:1:6: Error: Param number out of range (0-31)\n" },
2847    { "exp  pos4, v116, v93, v27, v124 done vm", 0, 0, false, false,
2848        "test.s:1:6: Error: Pos number out of range (0-3)\n" },
2849    { "exp  mrt8, v116, v93, v27, v124 done vm", 0, 0, false, false,
2850        "test.s:1:6: Error: MRT number out of range (0-7)\n" },
2851    { "exp  mrt0, v116, v117, v93, v93 done compr vm", 0, 0, false, false,
2852        "test.s:1:18: Error: VSRC1 must be equal to VSRC0 in compr mode\n" },
2853    { "exp  mrt0, v116, v116, v93, v91 done compr vm", 0, 0, false, false,
2854        "test.s:1:29: Error: VSRC3 must be equal to VSRC2 in compr mode\n" },
2855    { "exp  paxxx, v116, v93, v27, v124 done vm", 0, 0, false, false,
2856        "test.s:1:6: Error: Unknown EXP target\n" },
2857    { "exp  param, v116, v93, v27, v124 done vm", 0, 0, false, false,
2858        "test.s:1:6: Error: Missing number\n" },
2859    { nullptr, 0, 0, false, false, 0 }
2860};
2861
2862const GCNAsmOpcodeCase encGCN11OpcodeCases[] =
2863{   /* flat registers */
2864    { "    s_add_u32  flat_scratch_lo, s4, s61", 0x80683d04U, 0, false, true, "" },
2865    { "    s_add_u32  flat_scratch_hi, s4, s61", 0x80693d04U, 0, false, true, "" },
2866    { "    s_xor_b64 s[22:23], flat_scratch, s[62:63]\n",
2867        0x89963e68U, 0, false, true, "" },
2868    /* SOPP encoding */
2869    { "    s_setkill  0x32b", 0xbf8b032bU, 0, false, true, "" },
2870    { "xxx: s_cbranch_cdbgsys xxx+16", 0xbf970003U, 0, false, true, "" },
2871    { "xxx: s_cbranch_cdbguser xxx+16", 0xbf980003U, 0, false, true, "" },
2872    { "xxx: s_cbranch_cdbgsys_or_user xxx+16", 0xbf990003U, 0, false, true, "" },
2873    { "xxx: s_cbranch_cdbgsys_and_user xxx+16", 0xbf9a0003U, 0, false, true, "" },
2874    /* SMRD */
2875    { "   s_dcache_inv_vol", 0xc7400000U, 0, false, true, "" },
2876    /* VOP1 encoding */
2877    { "    v_trunc_f64  v[158:159], v[79:80]", 0x7f3c2f4fU, 0, false, true, "" },
2878    { "    v_ceil_f64  v[158:159], v[79:80]", 0x7f3c314fU, 0, false, true, "" },
2879    { "    v_rndne_f64  v[158:159], v[79:80]", 0x7f3c334fU, 0, false, true, "" },
2880    { "    v_floor_f64  v[158:159], v[79:80]", 0x7f3c354fU, 0, false, true, "" },
2881    { "    v_log_legacy_f32 v158, v79", 0x7f3c8b4fU, 0, false, true, "" },
2882    { "    v_exp_legacy_f32 v158, v79", 0x7f3c8d4fU, 0, false, true, "" },
2883    /* VOP1 in VOP3 */
2884    { "    v_trunc_f64  v[55:56], v[27:28] vop3",
2885        0xd32e0037U, 0x0000011bU, true, true, "" },
2886    { "    v_ceil_f64  v[55:56], v[27:28] vop3",
2887        0xd3300037U, 0x0000011bU, true, true, "" },
2888    { "    v_rndne_f64  v[55:56], v[27:28] vop3",
2889        0xd3320037U, 0x0000011bU, true, true, "" },
2890    { "    v_floor_f64  v[55:56], v[27:28] vop3",
2891        0xd3340037U, 0x0000011bU, true, true, "" },
2892    { "    v_log_legacy_f32 v55, v27 vop3",
2893        0xd38a0037U, 0x0000011bU, true, true, "" },
2894    { "    v_exp_legacy_f32 v55, v27 vop3",
2895        0xd38c0037U, 0x0000011bU, true, true, "" },
2896    /* VOP3 encoding */
2897    { "   v_msad_u8  v55, v79, v166, v229", 0xd2e20037U, 0x07974d4fU, true, true, "" },
2898    { "    v_qsad_pk_u16_u8  v[55:56], v[79:80], v166, v[229:230]",
2899        0xd2e40037U, 0x07974d4fU, true, true, "" },
2900    { "    v_qsad_u8  v[55:56], v[79:80], v166, v[229:230]",
2901        0xd2e40037U, 0x07974d4fU, true, true, "" },
2902    { "    v_mqsad_pk_u16_u8  v[55:56], v[79:80], v166, v[229:230]",
2903        0xd2e60037U, 0x07974d4fU, true, true, "" },
2904    { "    v_mqsad_u8  v[55:56], v[79:80], v166, v[229:230]",
2905        0xd2e60037U, 0x07974d4fU, true, true, "" },
2906    { "    v_mqsad_u32_u8  v[55:58], v[79:80], v166, v[229:232]",
2907        0xd2ea0037U, 0x07974d4fU, true, true, "" },
2908    { "    v_mqsad_u32_u8  v[55:58], v[79:80], v166, s[29:32]",
2909        0xd2ea0037U, 0x00774d4fU, true, true, "" },
2910    { "    v_mad_u64_u32  v[55:56], s[46:47], v79, v166, v[229:230]",
2911        0xd2ec2e37U, 0x07974d4fU, true, true, "" },
2912    { "    v_mad_i64_i32  v[55:56], s[46:47], v79, v166, v[229:230]",
2913        0xd2ee2e37U, 0x07974d4fU, true, true, "" },
2914    /* DS encoding */
2915    { "    ds_nop  v71 offset:52583", 0xd850cd67U, 0x00000047U, true, true, "" },
2916    { "    ds_gws_sema_release_all v71 gds offset:52583",
2917        0xd862cd67U, 0x00000047U, true, true, "" },
2918    { "    ds_wrap_rtn_b32  v155, v71, v169, v86 offset:52583",
2919        0xd8d0cd67U, 0x9b56a947U, true, true, "" },
2920    { "   ds_condxchg32_rtn_b64 v[155:156], v71, v[169:170] offset:52583",
2921        0xd9f8cd67U, 0x9b00a947U, true, true, "" },
2922    { "    ds_write_b96  v71, v[169:171] offset:52583",
2923        0xdb78cd67U, 0x0000a947U, true, true, "" },
2924    { "    ds_write_b128  v71, v[169:172] offset:52583",
2925        0xdb7ccd67U, 0x0000a947U, true, true, "" },
2926    { "    ds_condxchg32_rtn_b128  v[155:158] offset:52583",
2927        0xdbf4cd67U, 0x9b000000U, true, true, "" },
2928    { "    ds_read_b96  v[155:157], v71 offset:52583",
2929        0xdbf8cd67U, 0x9b000047U, true, true, "" },
2930    { "    ds_read_b128  v[155:158], v71 offset:52583",
2931        0xdbfccd67U, 0x9b000047U, true, true, "" },
2932    /* MUBUF encoding */
2933    { "    buffer_load_dwordx3 v[61:63], v18, s[80:83], s35 idxen offset:603",
2934        0xe03c225bU, 0x23143d12U, true, true, "" },
2935    { "    buffer_store_dwordx3 v[61:63], v18, s[80:83], s35 idxen offset:603",
2936        0xe07c225bU, 0x23143d12U, true, true, "" },
2937    /* MUBUF unknown instrunctions */
2938    { "    buffer_atomic_rsub v61, v18, s[80:83], s35 idxen offset:603",
2939        0, 0, false, false, "test.s:1:5: Error: Unknown instruction\n" },
2940    { "    buffer_atomic_rsub v[61:62], v18, s[80:83], s35 idxen offset:603",
2941        0, 0, false, false, "test.s:1:5: Error: Unknown instruction\n" },
2942    /* FLAT encoding */
2943    { "flat_load_ubyte v[47:48], v[187:188] glc slc tfe",
2944        0xdc230000U, 0x2f8000bbU, true, true, "" },
2945    { "flat_load_ubyte v47, v[187:188] glc slc",
2946        0xdc230000U, 0x2f0000bbU, true, true, "" },
2947    { "flat_load_ubyte v[47:48], v[187:188] glc:1 slc:1 tfe:1",
2948        0xdc230000U, 0x2f8000bbU, true, true, "" },
2949    { "flat_load_ubyte v47, v[187:188] glc:1 slc:1 tfe:0",
2950        0xdc230000U, 0x2f0000bbU, true, true, "" },
2951    { "flat_load_ubyte v47, v[187:188] glc", 0xdc210000U, 0x2f0000bbU, true, true, "" },
2952    { "flat_load_ubyte v47, v[187:188] glc:1 slc:0 tfe:0",
2953        0xdc210000U, 0x2f0000bbU, true, true, "" },
2954    { "flat_load_ubyte v47, v[187:188] glc   ", 0xdc210000U, 0x2f0000bbU, true, true, "" },
2955    { "flat_load_ubyte v47, v[187:188]", 0xdc200000U, 0x2f0000bbU, true, true, "" },
2956    { "flat_load_ubyte v47, v[187:188]   ", 0xdc200000U, 0x2f0000bbU, true, true, "" },
2957    /* FLAT errors */
2958    { "flat_load_ubyte v47, v[187:188] glc slcx", 0, 0, false, false,
2959        "test.s:1:37: Error: Unknown FLAT modifier\n" },
2960    { "flat_load_ubyte v[47:48], v[187:188] glc", 0, 0, false, false,
2961        "test.s:1:17: Error: Required 1 vector register\n" },
2962    { "flat_load_ubyte v47, v[187:188] glc slc tfe", 0, 0, false, false,
2963        "test.s:1:17: Error: Required 2 vector registers\n" },
2964    /* FLAT instructions */
2965    { "flat_load_sbyte  v47, v[187:188]", 0xdc240000U, 0x2f0000bbU, true, true, "" },
2966    { "flat_load_ushort  v47, v[187:188]", 0xdc280000U, 0x2f0000bbU, true, true, "" },
2967    { "flat_load_sshort  v47, v[187:188]", 0xdc2c0000U, 0x2f0000bbU, true, true, "" },
2968    { "flat_load_dword  v47, v[187:188]", 0xdc300000U, 0x2f0000bbU, true, true, "" },
2969    { "flat_load_dwordx2  v[47:48], v[187:188]",
2970        0xdc340000U, 0x2f0000bbU, true, true, "" },
2971    { "flat_load_dwordx4  v[47:50], v[187:188]",
2972        0xdc380000U, 0x2f0000bbU, true, true, "" },
2973    { "flat_load_dwordx3  v[47:49], v[187:188]",
2974        0xdc3c0000U, 0x2f0000bbU, true, true, "" },
2975    { "flat_store_byte v[191:192], v84 glc slc tfe",
2976        0xdc630000U, 0x008054bfU, true, true, "" },
2977    { "flat_store_short v[191:192], v84 glc slc tfe",
2978        0xdc6b0000U, 0x008054bfU, true, true, "" },
2979    { "flat_store_dword v[191:192], v84", 0xdc700000U, 0x000054bfU, true, true, "" },
2980    { "flat_store_dwordx2 v[191:192], v[84:85]", 0xdc740000U, 0x000054bfU, true, true, "" },
2981    { "flat_store_dwordx4 v[191:192], v[84:87]", 0xdc780000U, 0x000054bfU, true, true, "" },
2982    { "flat_store_dwordx3 v[191:192], v[84:86]", 0xdc7c0000U, 0x000054bfU, true, true, "" },
2983    { "flat_atomic_swap  v[47:48], v[187:188], v65 glc slc tfe",
2984        0xdcc30000U, 0x2f8041bbU, true, true, "" },
2985    { "flat_atomic_swap  v47, v[187:188], v65 glc slc",
2986        0xdcc30000U, 0x2f0041bbU, true, true, "" },
2987    { "flat_atomic_cmpswap v47, v[187:188], v[65:66] glc slc",
2988        0xdcc70000U, 0x2f0041bbU, true, true, "" },
2989    { "flat_atomic_add v47, v[187:188], v65", 0xdcc80000U, 0x2f0041bbU, true, true, "" },
2990    { "flat_atomic_sub v47, v[187:188], v65", 0xdccc0000U, 0x2f0041bbU, true, true, "" },
2991    { "flat_atomic_smin v47, v[187:188], v65", 0xdcd40000U, 0x2f0041bbU, true, true, "" },
2992    { "flat_atomic_umin v47, v[187:188], v65", 0xdcd80000U, 0x2f0041bbU, true, true, "" },
2993    { "flat_atomic_smax v47, v[187:188], v65", 0xdcdc0000U, 0x2f0041bbU, true, true, "" },
2994    { "flat_atomic_umax v47, v[187:188], v65", 0xdce00000U, 0x2f0041bbU, true, true, "" },
2995    { "flat_atomic_and v47, v[187:188], v65", 0xdce40000U, 0x2f0041bbU, true, true, "" },
2996    { "flat_atomic_or v47, v[187:188], v65", 0xdce80000U, 0x2f0041bbU, true, true, "" },
2997    { "flat_atomic_xor v47, v[187:188], v65", 0xdcec0000U, 0x2f0041bbU, true, true, "" },
2998    { "flat_atomic_inc v47, v[187:188], v65", 0xdcf00000U, 0x2f0041bbU, true, true, "" },
2999    { "flat_atomic_dec v47, v[187:188], v65", 0xdcf40000U, 0x2f0041bbU, true, true, "" },
3000    { "flat_atomic_fcmpswap v47, v[187:188], v[65:66] glc slc",
3001        0xdcfb0000U, 0x2f0041bbU, true, true, "" },
3002    { "flat_atomic_fmin v47, v[187:188], v65", 0xdcfc0000U, 0x2f0041bbU, true, true, "" },
3003    { "flat_atomic_fmax v47, v[187:188], v65", 0xdd000000U, 0x2f0041bbU, true, true, "" },
3004   
3005    { "flat_atomic_swap_x2  v[47:49], v[187:188], v[65:66] glc slc tfe",
3006        0xdd430000U, 0x2f8041bbU, true, true, "" },
3007    { "flat_atomic_swap_x2  v[47:48], v[187:188], v[65:66] glc slc",
3008        0xdd430000U, 0x2f0041bbU, true, true, "" },
3009    { "flat_atomic_cmpswap_x2 v[47:48], v[187:188], v[65:68] glc slc",
3010        0xdd470000U, 0x2f0041bbU, true, true, "" },
3011    { "flat_atomic_add_x2 v[47:48], v[187:188], v[65:66]",
3012        0xdd480000U, 0x2f0041bbU, true, true, "" },
3013    { "flat_atomic_sub_x2 v[47:48], v[187:188], v[65:66]",
3014        0xdd4c0000U, 0x2f0041bbU, true, true, "" },
3015    { "flat_atomic_smin_x2 v[47:48], v[187:188], v[65:66]",
3016        0xdd540000U, 0x2f0041bbU, true, true, "" },
3017    { "flat_atomic_umin_x2 v[47:48], v[187:188], v[65:66]",
3018        0xdd580000U, 0x2f0041bbU, true, true, "" },
3019    { "flat_atomic_smax_x2 v[47:48], v[187:188], v[65:66]",
3020        0xdd5c0000U, 0x2f0041bbU, true, true, "" },
3021    { "flat_atomic_umax_x2 v[47:48], v[187:188], v[65:66]",
3022        0xdd600000U, 0x2f0041bbU, true, true, "" },
3023    { "flat_atomic_and_x2 v[47:48], v[187:188], v[65:66]",
3024        0xdd640000U, 0x2f0041bbU, true, true, "" },
3025    { "flat_atomic_or_x2 v[47:48], v[187:188], v[65:66]",
3026        0xdd680000U, 0x2f0041bbU, true, true, "" },
3027    { "flat_atomic_xor_x2 v[47:48], v[187:188], v[65:66]",
3028        0xdd6c0000U, 0x2f0041bbU, true, true, "" },
3029    { "flat_atomic_inc_x2 v[47:48], v[187:188], v[65:66]",
3030        0xdd700000U, 0x2f0041bbU, true, true, "" },
3031    { "flat_atomic_dec_x2 v[47:48], v[187:188], v[65:66]",
3032        0xdd740000U, 0x2f0041bbU, true, true, "" },
3033    { "flat_atomic_fcmpswap_x2 v[47:48], v[187:188], v[65:68] glc slc",
3034        0xdd7b0000U, 0x2f0041bbU, true, true, "" },
3035    { "flat_atomic_fmin_x2 v[47:48], v[187:188], v[65:66]",
3036        0xdd7c0000U, 0x2f0041bbU, true, true, "" },
3037    { "flat_atomic_fmax_x2 v[47:48], v[187:188], v[65:66]",
3038        0xdd800000U, 0x2f0041bbU, true, true, "" },
3039    { nullptr, 0, 0, false, false, 0 }
3040};
Note: See TracBrowser for help on using the repository browser.