xref: /netbsd-src/external/gpl3/binutils/dist/opcodes/loongarch-opc.c (revision cb63e24e8d6aae7ddac1859a9015f48b1d8bd90e)
1 /* LoongArch opcode support.
2    Copyright (C) 2021-2024 Free Software Foundation, Inc.
3    Contributed by Loongson Ltd.
4 
5    This file is part of the GNU opcodes library.
6 
7    This library is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 3, or (at your option)
10    any later version.
11 
12    It is distributed in the hope that it will be useful, but WITHOUT
13    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
15    License for more details.
16 
17    You should have received a copy of the GNU General Public License
18    along with this program; see the file COPYING3.  If not,
19    see <http://www.gnu.org/licenses/>.  */
20 
21 #include <stddef.h>
22 #include "opcode/loongarch.h"
23 #include "libiberty.h"
24 
25 struct loongarch_ASEs_option LARCH_opts =
26 {
27   .relax = 1
28 };
29 
30 size_t
loongarch_insn_length(insn_t insn ATTRIBUTE_UNUSED)31 loongarch_insn_length (insn_t insn ATTRIBUTE_UNUSED)
32 {
33   return 4;
34 }
35 
36 const char *const loongarch_r_normal_name[32] =
37 {
38   "$r0",  "$r1",  "$r2",  "$r3",  "$r4",  "$r5",  "$r6",  "$r7",
39   "$r8",  "$r9",  "$r10", "$r11", "$r12", "$r13", "$r14", "$r15",
40   "$r16", "$r17", "$r18", "$r19", "$r20", "$r21", "$r22", "$r23",
41   "$r24", "$r25", "$r26", "$r27", "$r28", "$r29", "$r30", "$r31",
42 };
43 
44 const char *const loongarch_r_alias[32] =
45 {
46   "$zero", "$ra", "$tp", "$sp", "$a0", "$a1", "$a2", "$a3",
47   "$a4",   "$a5", "$a6", "$a7", "$t0", "$t1", "$t2", "$t3",
48   "$t4",   "$t5", "$t6", "$t7", "$t8", "$r21","$fp", "$s0",
49   "$s1",   "$s2", "$s3", "$s4", "$s5", "$s6", "$s7", "$s8",
50 };
51 
52 /* Add support for $s9.  */
53 const char *const loongarch_r_alias_1[32] =
54 {
55   "", "", "", "", "", "", "", "",
56   "", "", "", "", "", "", "", "",
57   "", "", "", "", "", "", "$s9", "",
58   "", "", "", "", "", "", "", "",
59 };
60 
61 const char *const loongarch_r_alias_deprecated[32] =
62 {
63   "", "", "", "", "$v0", "$v1", "", "", "", "", "", "", "", "", "", "",
64   "", "", "", "", "",    "$x",  "", "", "", "", "", "", "", "", "", "",
65 };
66 
67 const char *const loongarch_f_normal_name[32] =
68 {
69   "$f0",  "$f1",  "$f2",  "$f3",  "$f4",  "$f5",  "$f6",  "$f7",
70   "$f8",  "$f9",  "$f10", "$f11", "$f12", "$f13", "$f14", "$f15",
71   "$f16", "$f17", "$f18", "$f19", "$f20", "$f21", "$f22", "$f23",
72   "$f24", "$f25", "$f26", "$f27", "$f28", "$f29", "$f30", "$f31",
73 };
74 
75 const char *const loongarch_f_alias[32] =
76 {
77   "$fa0", "$fa1", "$fa2",  "$fa3",  "$fa4",  "$fa5",  "$fa6",  "$fa7",
78   "$ft0", "$ft1", "$ft2",  "$ft3",  "$ft4",  "$ft5",  "$ft6",  "$ft7",
79   "$ft8", "$ft9", "$ft10", "$ft11", "$ft12", "$ft13", "$ft14", "$ft15",
80   "$fs0", "$fs1", "$fs2",  "$fs3",  "$fs4",  "$fs5",  "$fs6",  "$fs7",
81 };
82 
83 const char *const loongarch_f_alias_deprecated[32] =
84 {
85   "$fv0", "$fv1", "", "", "", "", "", "", "", "", "", "", "", "", "", "",
86   "",     "",     "", "", "", "", "", "", "", "", "", "", "", "", "", "",
87 };
88 
89 const char *const loongarch_fc_normal_name[4] =
90 {
91   "$fcsr0", "$fcsr1", "$fcsr2", "$fcsr3",
92 };
93 
94 const char *const loongarch_fc_numeric_name[4] =
95 {
96   "$r0", "$r1", "$r2", "$r3",
97 };
98 
99 const char *const loongarch_c_normal_name[8] =
100 {
101   "$fcc0", "$fcc1", "$fcc2", "$fcc3", "$fcc4", "$fcc5", "$fcc6", "$fcc7",
102 };
103 
104 const char *const loongarch_cr_normal_name[4] =
105 {
106   "$scr0",
107   "$scr1",
108   "$scr2",
109   "$scr3",
110 };
111 
112 const char *const loongarch_v_normal_name[32] =
113 {
114   "$vr0",  "$vr1",  "$vr2",  "$vr3",  "$vr4",  "$vr5",  "$vr6",  "$vr7",
115   "$vr8",  "$vr9",  "$vr10", "$vr11", "$vr12", "$vr13", "$vr14", "$vr15",
116   "$vr16", "$vr17", "$vr18", "$vr19", "$vr20", "$vr21", "$vr22", "$vr23",
117   "$vr24", "$vr25", "$vr26", "$vr27", "$vr28", "$vr29", "$vr30", "$vr31",
118 };
119 
120 const char *const loongarch_x_normal_name[32] =
121 {
122   "$xr0",  "$xr1",  "$xr2",  "$xr3",  "$xr4",  "$xr5",  "$xr6",  "$xr7",
123   "$xr8",  "$xr9",  "$xr10", "$xr11", "$xr12", "$xr13", "$xr14", "$xr15",
124   "$xr16", "$xr17", "$xr18", "$xr19", "$xr20", "$xr21", "$xr22", "$xr23",
125   "$xr24", "$xr25", "$xr26", "$xr27", "$xr28", "$xr29", "$xr30", "$xr31",
126 };
127 
128 /* Can not use xx_pa for abs.  */
129 
130 /* For LoongArch32 abs.  */
131 #define INSN_LA_ABS32		    \
132   "lu12i.w %1,%%abs_hi20(%2);"	    \
133   "ori %1,%1,%%abs_lo12(%2);",	    \
134   &LARCH_opts.ase_ilp32,	    \
135   &LARCH_opts.ase_lp64
136 #define INSN_LA_ABS64			\
137   "lu12i.w %1,%%abs_hi20(%2);"		\
138   "ori %1,%1,%%abs_lo12(%2);"		\
139   "lu32i.d %1,%%abs64_lo20(%2);"	\
140   "lu52i.d %1,%1,%%abs64_hi12(%2);",	\
141   &LARCH_opts.ase_lp64, 0
142 
143 #define INSN_LA_PCREL32		    \
144   "pcalau12i %1,%%pc_hi20(%2);"	    \
145   "addi.w %1,%1,%%pc_lo12(%2);",    \
146   &LARCH_opts.ase_ilp32,	    \
147   &LARCH_opts.ase_lp64
148 #define INSN_LA_PCREL64		    \
149   "pcalau12i %1,%%pc_hi20(%2);"	    \
150   "addi.d %1,%1,%%pc_lo12(%2);",    \
151   &LARCH_opts.ase_lp64, 0
152 #define INSN_LA_PCREL64_LARGE	    \
153   "pcalau12i %1,%%pc_hi20(%3);"	    \
154   "addi.d %2,$r0,%%pc_lo12(%3);"    \
155   "lu32i.d %2,%%pc64_lo20(%3);"	    \
156   "lu52i.d %2,%2,%%pc64_hi12(%3);"  \
157   "add.d %1,%1,%2;",		    \
158   &LARCH_opts.ase_lp64, 0
159 
160 #define INSN_LA_GOT32		    \
161   "pcalau12i %1,%%got_pc_hi20(%2);" \
162   "ld.w %1,%1,%%got_pc_lo12(%2);",  \
163   &LARCH_opts.ase_ilp32,	    \
164   &LARCH_opts.ase_lp64
165 /* got32 abs.  */
166 #define INSN_LA_GOT32_ABS	    \
167   "lu12i.w %1,%%got_hi20(%2);"	    \
168   "ori %1,%1,%%got_lo12(%2);"	    \
169   "ld.w %1,%1,0;",		    \
170   &LARCH_opts.ase_gabs,		    \
171   &LARCH_opts.ase_lp64
172 #define INSN_LA_GOT64		    \
173   "pcalau12i %1,%%got_pc_hi20(%2);" \
174   "ld.d %1,%1,%%got_pc_lo12(%2);",  \
175   &LARCH_opts.ase_lp64, 0
176 /* got64 abs.  */
177 #define INSN_LA_GOT64_LARGE_ABS	    \
178   "lu12i.w %1,%%got_hi20(%2);"	    \
179   "ori %1,%1,%%got_lo12(%2);"	    \
180   "lu32i.d %1,%%got64_lo20(%2);"    \
181   "lu52i.d %1,%1,%%got64_hi12(%2);" \
182   "ld.d %1,%1,0",		    \
183   &LARCH_opts.ase_gabs,		    \
184   &LARCH_opts.ase_gpcr
185 /* got64 pic.  */
186 #define INSN_LA_GOT64_LARGE_PCREL     \
187   "pcalau12i %1,%%got_pc_hi20(%3);"   \
188   "addi.d %2,$r0,%%got_pc_lo12(%3);"  \
189   "lu32i.d %2,%%got64_pc_lo20(%3);"   \
190   "lu52i.d %2,%2,%%got64_pc_hi12(%3);"\
191   "ldx.d %1,%1,%2;",		      \
192   &LARCH_opts.ase_lp64,		      \
193   &LARCH_opts.ase_gabs
194 
195 /* For LoongArch32/64 cmode=normal.  */
196 #define INSN_LA_TLS_LE		    \
197   "lu12i.w %1,%%le_hi20(%2);"	    \
198   "ori %1,%1,%%le_lo12(%2);",	    \
199   &LARCH_opts.ase_ilp32, 0
200 
201 /* For LoongArch64 cmode=large.  */
202 #define INSN_LA_TLS_LE64_LARGE	    \
203   "lu12i.w %1,%%le_hi20(%2);"	    \
204   "ori %1,%1,%%le_lo12(%2);"	    \
205   "lu32i.d %1,%%le64_lo20(%2);"	    \
206   "lu52i.d %1,%1,%%le64_hi12(%2);", \
207   &LARCH_opts.ase_lp64, 0
208 
209 #define INSN_LA_TLS_IE32	    \
210   "pcalau12i %1,%%ie_pc_hi20(%2);"  \
211   "ld.w %1,%1,%%ie_pc_lo12(%2);",   \
212   &LARCH_opts.ase_ilp32,	    \
213   &LARCH_opts.ase_lp64
214 /* For ie32 abs.  */
215 #define INSN_LA_TLS_IE32_ABS	    \
216   "lu12i.w %1,%%ie_hi20(%2);"	    \
217   "ori %1,%1,%%ie_lo12(%2);"	    \
218   "ld.w %1,%1,0",		    \
219   &LARCH_opts.ase_gabs,		    \
220   &LARCH_opts.ase_lp64
221 #define INSN_LA_TLS_IE64	    \
222   "pcalau12i %1,%%ie_pc_hi20(%2);"  \
223   "ld.d %1,%1,%%ie_pc_lo12(%2);",   \
224   &LARCH_opts.ase_lp64, 0
225 /* For ie64 pic.  */
226 #define INSN_LA_TLS_IE64_LARGE_PCREL  \
227   "pcalau12i %1,%%ie_pc_hi20(%3);"    \
228   "addi.d %2,$r0,%%ie_pc_lo12(%3);"   \
229   "lu32i.d %2,%%ie64_pc_lo20(%3);"    \
230   "lu52i.d %2,%2,%%ie64_pc_hi12(%3);" \
231   "ldx.d %1,%1,%2;",		      \
232   &LARCH_opts.ase_lp64,		      \
233   &LARCH_opts.ase_gabs
234 /* For ie64 abs.  */
235 #define INSN_LA_TLS_IE64_LARGE_ABS  \
236   "lu12i.w %1,%%ie_hi20(%2);"	    \
237   "ori %1,%1,%%ie_lo12(%2);"	    \
238   "lu32i.d %1,%%ie64_lo20(%2);"	    \
239   "lu52i.d %1,%1,%%ie64_hi12(%2);"  \
240   "ld.d %1,%1,0",		    \
241   &LARCH_opts.ase_gabs,		    \
242   &LARCH_opts.ase_gpcr
243 
244 /* For LoongArch32/64 cmode=normal.  */
245 #define INSN_LA_TLS_LD32	      \
246   "pcalau12i %1,%%ld_pc_hi20(%2);"    \
247   "addi.w %1,%1,%%got_pc_lo12(%2);",  \
248   &LARCH_opts.ase_ilp32,	      \
249   &LARCH_opts.ase_lp64
250 #define INSN_LA_TLS_LD32_ABS	      \
251   "lu12i.w %1,%%ld_hi20(%2);"	      \
252   "ori %1,%1,%%got_lo12(%2);",	      \
253   &LARCH_opts.ase_gabs,		      \
254   &LARCH_opts.ase_lp64
255 #define INSN_LA_TLS_LD64	      \
256   "pcalau12i %1,%%ld_pc_hi20(%2);"    \
257   "addi.d %1,%1,%%got_pc_lo12(%2);",  \
258   &LARCH_opts.ase_lp64, 0
259 #define INSN_LA_TLS_LD64_LARGE_PCREL  \
260   "pcalau12i %1,%%ld_pc_hi20(%3);"    \
261   "addi.d %2,$r0,%%got_pc_lo12(%3);"  \
262   "lu32i.d %2,%%got64_pc_lo20(%3);"   \
263   "lu52i.d %2,%2,%%got64_pc_hi12(%3);"\
264   "add.d %1,%1,%2;",		      \
265   &LARCH_opts.ase_lp64,		      \
266   &LARCH_opts.ase_gabs
267 #define INSN_LA_TLS_LD64_LARGE_ABS    \
268   "lu12i.w %1,%%ld_hi20(%2);"	      \
269   "ori %1,%1,%%got_lo12(%2);"	      \
270   "lu32i.d %1,%%got64_lo20(%2);"      \
271   "lu52i.d %1,%1,%%got64_hi12(%2);",  \
272   &LARCH_opts.ase_gabs,		      \
273   &LARCH_opts.ase_gpcr
274 
275 #define INSN_LA_TLS_GD32	      \
276   "pcalau12i %1,%%gd_pc_hi20(%2);"    \
277   "addi.w %1,%1,%%got_pc_lo12(%2);",  \
278   &LARCH_opts.ase_ilp32,	      \
279   &LARCH_opts.ase_lp64
280 #define INSN_LA_TLS_GD32_ABS	      \
281   "lu12i.w %1,%%gd_hi20(%2);"	      \
282   "ori %1,%1,%%got_lo12(%2);",	      \
283   &LARCH_opts.ase_gabs,		      \
284   &LARCH_opts.ase_lp64
285 #define INSN_LA_TLS_GD64	      \
286   "pcalau12i %1,%%gd_pc_hi20(%2);"    \
287   "addi.d %1,%1,%%got_pc_lo12(%2);",  \
288   &LARCH_opts.ase_lp64, 0
289 #define INSN_LA_TLS_GD64_LARGE_PCREL  \
290   "pcalau12i %1,%%gd_pc_hi20(%3);"    \
291   "addi.d %2,$r0,%%got_pc_lo12(%3);"  \
292   "lu32i.d %2,%%got64_pc_lo20(%3);"   \
293   "lu52i.d %2,%2,%%got64_pc_hi12(%3);"\
294   "add.d %1,%1,%2;",		      \
295   &LARCH_opts.ase_lp64,		      \
296   &LARCH_opts.ase_gabs
297 #define INSN_LA_TLS_GD64_LARGE_ABS    \
298   "lu12i.w %1,%%gd_hi20(%2);"	      \
299   "ori %1,%1,%%got_lo12(%2);"	      \
300   "lu32i.d %1,%%got64_lo20(%2);"      \
301   "lu52i.d %1,%1,%%got64_hi12(%2);",  \
302   &LARCH_opts.ase_gabs,		      \
303   &LARCH_opts.ase_gpcr
304 
305 #define INSN_LA_CALL		      \
306   "pcaddu18i $ra,%%call36(%1);"    \
307   "jirl $ra,$ra,0;",    \
308   0, 0
309 
310 #define INSN_LA_TAIL		      \
311   "pcaddu18i %1,%%call36(%2);"   \
312   "jirl $zero,%1,0;",   \
313   0, 0
314 
315 /* For TLS_DESC32 pcrel.  */
316 #define INSN_LA_TLS_DESC32		\
317   "pcalau12i $r4,%%desc_pc_hi20(%2);"	\
318   "addi.w $r4,$r4,%%desc_pc_lo12(%2);"	\
319   "ld.w $r1,$r4,%%desc_ld(%2);"		\
320   "jirl $r1,$r1,%%desc_call(%2);",	\
321   &LARCH_opts.ase_ilp32,		\
322   &LARCH_opts.ase_lp64
323 
324 /* For TLS_DESC32 abs.  */
325 #define INSN_LA_TLS_DESC32_ABS		\
326   "lu12i.w $r4,%%desc_hi20(%2);"	\
327   "ori $r4,$r4,%%desc_lo12(%2);"	\
328   "ld.w $r1,$r4,%%desc_ld(%2);"		\
329   "jirl $r1,$r1,%%desc_call(%2);",	\
330   &LARCH_opts.ase_gabs,			\
331   &LARCH_opts.ase_lp64
332 
333 /* For TLS_DESC64 pcrel.  */
334 #define INSN_LA_TLS_DESC64		\
335   "pcalau12i $r4,%%desc_pc_hi20(%2);"	\
336   "addi.d $r4,$r4,%%desc_pc_lo12(%2);"	\
337   "ld.d $r1,$r4,%%desc_ld(%2);"		\
338   "jirl $r1,$r1,%%desc_call(%2);",	\
339   &LARCH_opts.ase_lp64, 0
340 
341 /* For TLS_DESC64 large pcrel.  */
342 #define INSN_LA_TLS_DESC64_LARGE_PCREL	\
343   "pcalau12i $r4,%%desc_pc_hi20(%3);"	\
344   "addi.d %2,$r0,%%desc_pc_lo12(%3);"	\
345   "lu32i.d %2,%%desc64_pc_lo20(%3);"	\
346   "lu52i.d %2,%2,%%desc64_pc_hi12(%3);"	\
347   "add.d $r4,$r4,%2;"			\
348   "ld.d $r1,$r4,%%desc_ld(%3);"		\
349   "jirl $r1,$r1,%%desc_call(%3);",	\
350   &LARCH_opts.ase_lp64,			\
351   &LARCH_opts.ase_gabs
352 
353 /* For TLS_DESC64 large abs.  */
354 #define INSN_LA_TLS_DESC64_LARGE_ABS	\
355   "lu12i.w $r4,%%desc_hi20(%2);"	\
356   "ori $r4,$r4,%%desc_lo12(%2);"	\
357   "lu32i.d $r4,%%desc64_lo20(%2);"	\
358   "lu52i.d $r4,$r4,%%desc64_hi12(%2);"	\
359   "ld.d $r1,$r4,%%desc_ld(%2);"		\
360   "jirl $r1,$r1,%%desc_call(%2);",	\
361   &LARCH_opts.ase_gabs,			\
362   &LARCH_opts.ase_gpcr
363 
364 static struct loongarch_opcode loongarch_macro_opcodes[] =
365 {
366   /* match,    mask,	   name, format, macro, include, exclude, pinfo.  */
367   { 0, 0, "li.w", "r,sc", "%f",	0, 0, 0 },
368   { 0, 0, "li.d", "r,sc", "%f",	0, 0, 0 },
369 
370   { 0, 0, "la",		"r,la",	  "la.global %1,%2",	0,			0, 0 },
371   { 0, 0, "la.global",	"r,la",	  "la.pcrel %1,%2",	&LARCH_opts.ase_gpcr,	0, 0 },
372   { 0, 0, "la.global",	"r,r,la", "la.pcrel %1,%2,%3",	&LARCH_opts.ase_gpcr,	0, 0 },
373   { 0, 0, "la.global",	"r,la",	  "la.abs %1,%2",	&LARCH_opts.ase_gabs,	0, 0 },
374   { 0, 0, "la.global",	"r,r,la", "la.abs %1,%3",	&LARCH_opts.ase_gabs,	0, 0 },
375   { 0, 0, "la.global",	"r,la",	  "la.got %1,%2",	0,			0, 0 },
376   { 0, 0, "la.global",	"r,r,la", "la.got %1,%2,%3",	&LARCH_opts.ase_lp64,	0, 0 },
377 
378   { 0, 0, "la.local",	"r,la",	  "la.abs %1,%2",	&LARCH_opts.ase_labs,	0, 0 },
379   { 0, 0, "la.local",	"r,r,la", "la.abs %1,%3",	&LARCH_opts.ase_labs,	0, 0 },
380   { 0, 0, "la.local",	"r,la",	  "la.pcrel %1,%2",	0,			0, 0 },
381   { 0, 0, "la.local",	"r,r,la", "la.pcrel %1,%2,%3",	&LARCH_opts.ase_lp64,	0, 0 },
382 
383   { 0, 0, "la.abs",	"r,la",	  INSN_LA_ABS32,		0 },
384   { 0, 0, "la.abs",	"r,la",	  INSN_LA_ABS64,		0 },
385   { 0, 0, "la.pcrel",	"r,la",	  INSN_LA_PCREL32,		0 },
386   { 0, 0, "la.pcrel",	"r,la",	  INSN_LA_PCREL64,		0 },
387   { 0, 0, "la.pcrel",	"r,r,la", INSN_LA_PCREL64_LARGE,	0 },
388   { 0, 0, "la.got",	"r,la",	  INSN_LA_GOT32_ABS,		0 },
389   { 0, 0, "la.got",	"r,la",	  INSN_LA_GOT32,		0 },
390   { 0, 0, "la.got",	"r,la",	  INSN_LA_GOT64_LARGE_ABS,	0 },
391   { 0, 0, "la.got",	"r,la",	  INSN_LA_GOT64,		0 },
392   { 0, 0, "la.got",	"r,r,la", INSN_LA_GOT64_LARGE_PCREL,	0 },
393   { 0, 0, "la.tls.le",	"r,l",	  INSN_LA_TLS_LE,		0 },
394   { 0, 0, "la.tls.le",	"r,l",	  INSN_LA_TLS_LE64_LARGE,	0 },
395   { 0, 0, "la.tls.ie",	"r,l",	  INSN_LA_TLS_IE32_ABS,		0 },
396   { 0, 0, "la.tls.ie",	"r,l",	  INSN_LA_TLS_IE32,		0 },
397   { 0, 0, "la.tls.ie",	"r,l",	  INSN_LA_TLS_IE64_LARGE_ABS,	0 },
398   { 0, 0, "la.tls.ie",	"r,l",	  INSN_LA_TLS_IE64,		0 },
399   { 0, 0, "la.tls.ie",	"r,r,l",  INSN_LA_TLS_IE64_LARGE_PCREL,	0 },
400   { 0, 0, "la.tls.ld",	"r,l",	  INSN_LA_TLS_LD32_ABS,		0 },
401   { 0, 0, "la.tls.ld",	"r,l",	  INSN_LA_TLS_LD32,		0 },
402   { 0, 0, "la.tls.ld",	"r,l",	  INSN_LA_TLS_LD64_LARGE_ABS,	0 },
403   { 0, 0, "la.tls.ld",	"r,l",	  INSN_LA_TLS_LD64,		0 },
404   { 0, 0, "la.tls.ld",	"r,r,l",  INSN_LA_TLS_LD64_LARGE_PCREL,	0 },
405   { 0, 0, "la.tls.gd",	"r,l",	  INSN_LA_TLS_GD32_ABS,		0 },
406   { 0, 0, "la.tls.gd",	"r,l",	  INSN_LA_TLS_GD32,		0 },
407   { 0, 0, "la.tls.gd",	"r,l",	  INSN_LA_TLS_GD64_LARGE_ABS,	0 },
408   { 0, 0, "la.tls.gd",	"r,l",	  INSN_LA_TLS_GD64,		0 },
409   { 0, 0, "la.tls.gd",	"r,r,l",  INSN_LA_TLS_GD64_LARGE_PCREL,	0 },
410   { 0, 0, "call36",	"la",	  INSN_LA_CALL,			0 },
411   { 0, 0, "tail36",	"r,la",	  INSN_LA_TAIL,			0 },
412   { 0, 0, "pcaddi",	"r,la",	  "pcaddi %1, %%pcrel_20(%2)",	&LARCH_opts.ase_ilp32, 0, 0 },
413   { 0, 0, "la.tls.desc", "r,l",	  INSN_LA_TLS_DESC32_ABS,	0 },
414   { 0, 0, "la.tls.desc", "r,l",	  INSN_LA_TLS_DESC32,		0 },
415   { 0, 0, "la.tls.desc", "r,l",	  INSN_LA_TLS_DESC64_LARGE_ABS,	0 },
416   { 0, 0, "la.tls.desc", "r,l",	  INSN_LA_TLS_DESC64,		0 },
417   { 0, 0, "la.tls.desc", "r,r,l", INSN_LA_TLS_DESC64_LARGE_PCREL,0 },
418   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
419 };
420 
421 static struct loongarch_opcode loongarch_alias_opcodes[] =
422 {
423   /* match,	mask,		name,		format,				macro,	include, exclude, pinfo.  */
424   { 0x00150000,	0xfffffc00,	"move",		"r0:5,r5:5",			0,	0, 0, INSN_DIS_ALIAS }, /* or rd, rj, zero */
425   { 0x02800000, 0xffc003e0,	"li.w",		"r0:5,s10:12",			0,	0, 0, INSN_DIS_ALIAS }, /* addi.w rd, zero, simm */
426   { 0x02c00000, 0xffc003e0,	"li.d",		"r0:5,s10:12",			0,	0, 0, INSN_DIS_ALIAS }, /* addi.d rd, zero, simm */
427   { 0x03400000,	0xffffffff,	"nop",		"",				0,	0, 0, INSN_DIS_ALIAS }, /* andi zero, zero, 0 */
428   { 0x03800000, 0xffc003e0,	"li.w",		"r0:5,u10:12",			0,	0, 0, INSN_DIS_ALIAS }, /* ori rd, zero, uimm */
429   /* ret must come before jr because it is more specific.  */
430   { 0x4c000020,	0xffffffff,	"ret",		"",				0,	0, 0, INSN_DIS_ALIAS }, /* jirl zero, ra, 0 */
431   { 0x4c000000,	0xfffffc1f,	"jr",		"r5:5",				0,	0, 0, INSN_DIS_ALIAS }, /* jirl zero, rj, 0 */
432   { 0x60000000,	0xfc00001f,	"bltz",		"r5:5,sb10:16<<2",		0,	0, 0, INSN_DIS_ALIAS }, /* blt rj, zero, offset */
433   { 0x60000000,	0xfc0003e0,	"bgtz",		"r0:5,sb10:16<<2",		0,	0, 0, INSN_DIS_ALIAS }, /* blt zero, rd, offset */
434   { 0x64000000,	0xfc00001f,	"bgez",		"r5:5,sb10:16<<2",		0,	0, 0, INSN_DIS_ALIAS }, /* bge rj, zero, offset */
435   { 0x64000000,	0xfc0003e0,	"blez",		"r0:5,sb10:16<<2",		0,	0, 0, INSN_DIS_ALIAS }, /* bge zero, rd, offset */
436   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
437 };
438 
439 
440 static struct loongarch_opcode loongarch_fix_opcodes[] =
441 {
442   /* match,	mask,		name,		format,				macro,			include, exclude, pinfo.  */
443   { 0x0,	0x0,		"move",		"r,r",				"or %1,%2,$r0",		0,	0,	0 },
444   { 0x00001000, 0xfffffc00,	"clo.w",	"r0:5,r5:5",			0,			0,	0,	0 },
445   { 0x00001400, 0xfffffc00,	"clz.w",	"r0:5,r5:5",			0,			0,	0,	0 },
446   { 0x00001800, 0xfffffc00,	"cto.w",	"r0:5,r5:5",			0,			0,	0,	0 },
447   { 0x00001c00, 0xfffffc00,	"ctz.w",	"r0:5,r5:5",			0,			0,	0,	0 },
448   { 0x00002000, 0xfffffc00,	"clo.d",	"r0:5,r5:5",			0,			0,	0,	0 },
449   { 0x00002400, 0xfffffc00,	"clz.d",	"r0:5,r5:5",			0,			0,	0,	0 },
450   { 0x00002800, 0xfffffc00,	"cto.d",	"r0:5,r5:5",			0,			0,	0,	0 },
451   { 0x00002c00, 0xfffffc00,	"ctz.d",	"r0:5,r5:5",			0,			0,	0,	0 },
452   { 0x00003000, 0xfffffc00,	"revb.2h",	"r0:5,r5:5",			0,			0,	0,	0 },
453   { 0x00003400, 0xfffffc00,	"revb.4h",	"r0:5,r5:5",			0,			0,	0,	0 },
454   { 0x00003800, 0xfffffc00,	"revb.2w",	"r0:5,r5:5",			0,			0,	0,	0 },
455   { 0x00003c00, 0xfffffc00,	"revb.d",	"r0:5,r5:5",			0,			0,	0,	0 },
456   { 0x00004000, 0xfffffc00,	"revh.2w",	"r0:5,r5:5",			0,			0,	0,	0 },
457   { 0x00004400, 0xfffffc00,	"revh.d",	"r0:5,r5:5",			0,			0,	0,	0 },
458   { 0x00004800, 0xfffffc00,	"bitrev.4b",	"r0:5,r5:5",			0,			0,	0,	0 },
459   { 0x00004c00, 0xfffffc00,	"bitrev.8b",	"r0:5,r5:5",			0,			0,	0,	0 },
460   { 0x00005000, 0xfffffc00,	"bitrev.w",	"r0:5,r5:5",			0,			0,	0,	0 },
461   { 0x00005400, 0xfffffc00,	"bitrev.d",	"r0:5,r5:5",			0,			0,	0,	0 },
462   { 0x00005800, 0xfffffc00,	"ext.w.h",	"r0:5,r5:5",			0,			0,	0,	0 },
463   { 0x00005c00, 0xfffffc00,	"ext.w.b",	"r0:5,r5:5",			0,			0,	0,	0 },
464   { 0x00006000, 0xfffffc00,	"rdtimel.w",	"r0:5,r5:5",			0,			0,	0,	0 },
465   { 0x00006400, 0xfffffc00,	"rdtimeh.w",	"r0:5,r5:5",			0,			0,	0,	0 },
466   { 0x00006800, 0xfffffc00,	"rdtime.d",	"r0:5,r5:5",			0,			0,	0,	0 },
467   { 0x00006c00, 0xfffffc00,	"cpucfg",	"r0:5,r5:5",			0,			0,	0,	0 },
468   { 0x00010000, 0xffff801f,	"asrtle.d",	"r5:5,r10:5",			0,			0,	0,	0 },
469   { 0x00018000, 0xffff801f,	"asrtgt.d",	"r5:5,r10:5",			0,			0,	0,	0 },
470   { 0x00040000, 0xfffe0000,	"alsl.w",	"r0:5,r5:5,r10:5,u15:2+1",	0,			0,	0,	0 },
471   { 0x00060000, 0xfffe0000,	"alsl.wu",	"r0:5,r5:5,r10:5,u15:2+1",	0,			0,	0,	0 },
472   { 0x00080000, 0xfffe0000,	"bytepick.w",	"r0:5,r5:5,r10:5,u15:2",	0,			0,	0,	0 },
473   { 0x000c0000, 0xfffc0000,	"bytepick.d",	"r0:5,r5:5,r10:5,u15:3",	0,			0,	0,	0 },
474   { 0x00100000, 0xffff8000,	"add.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
475   { 0x00108000, 0xffff8000,	"add.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
476   { 0x00108000, 0xffff8000,	"add.d",	"r0:5,r5:5,r10:5,t",		0,			0,	0,	0 },
477   { 0x00110000, 0xffff8000,	"sub.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
478   { 0x00118000, 0xffff8000,	"sub.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
479   { 0x00120000, 0xffff8000,	"slt",		"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
480   { 0x00128000, 0xffff8000,	"sltu",		"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
481   { 0x00130000, 0xffff8000,	"maskeqz",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
482   { 0x00138000, 0xffff8000,	"masknez",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
483   { 0x00140000, 0xffff8000,	"nor",		"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
484   { 0x00148000, 0xffff8000,	"and",		"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
485   { 0x00150000, 0xffff8000,	"or",		"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
486   { 0x00158000, 0xffff8000,	"xor",		"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
487   { 0x00160000, 0xffff8000,	"orn",		"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
488   { 0x00168000, 0xffff8000,	"andn",		"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
489   { 0x00170000, 0xffff8000,	"sll.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
490   { 0x00178000, 0xffff8000,	"srl.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
491   { 0x00180000, 0xffff8000,	"sra.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
492   { 0x00188000, 0xffff8000,	"sll.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
493   { 0x00190000, 0xffff8000,	"srl.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
494   { 0x00198000, 0xffff8000,	"sra.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
495   { 0x001b0000, 0xffff8000,	"rotr.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
496   { 0x001b8000, 0xffff8000,	"rotr.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
497   { 0x001c0000, 0xffff8000,	"mul.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
498   { 0x001c8000, 0xffff8000,	"mulh.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
499   { 0x001d0000, 0xffff8000,	"mulh.wu",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
500   { 0x001d8000, 0xffff8000,	"mul.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
501   { 0x001e0000, 0xffff8000,	"mulh.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
502   { 0x001e8000, 0xffff8000,	"mulh.du",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
503   { 0x001f0000, 0xffff8000,	"mulw.d.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
504   { 0x001f8000, 0xffff8000,	"mulw.d.wu",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
505   { 0x00200000, 0xffff8000,	"div.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
506   { 0x00208000, 0xffff8000,	"mod.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
507   { 0x00210000, 0xffff8000,	"div.wu",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
508   { 0x00218000, 0xffff8000,	"mod.wu",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
509   { 0x00220000, 0xffff8000,	"div.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
510   { 0x00228000, 0xffff8000,	"mod.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
511   { 0x00230000, 0xffff8000,	"div.du",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
512   { 0x00238000, 0xffff8000,	"mod.du",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
513   { 0x00240000, 0xffff8000,	"crc.w.b.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
514   { 0x00248000, 0xffff8000,	"crc.w.h.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
515   { 0x00250000, 0xffff8000,	"crc.w.w.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
516   { 0x00258000, 0xffff8000,	"crc.w.d.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
517   { 0x00260000, 0xffff8000,	"crcc.w.b.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
518   { 0x00268000, 0xffff8000,	"crcc.w.h.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
519   { 0x00270000, 0xffff8000,	"crcc.w.w.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
520   { 0x00278000, 0xffff8000,	"crcc.w.d.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
521   { 0x002a0000, 0xffff8000,	"break",	"u0:15",			0,			0,	0,	0 },
522   { 0x002a8000, 0xffff8000,	"dbcl",		"u0:15",			0,			0,	0,	0 },
523   { 0x002b0000, 0xffff8000,	"syscall",	"u0:15",			0,			0,	0,	0 },
524   { 0x002c0000, 0xfffe0000,	"alsl.d",	"r0:5,r5:5,r10:5,u15:2+1",	0,			0,	0,	0 },
525   { 0x00408000, 0xffff8000,	"slli.w",	"r0:5,r5:5,u10:5",		0,			0,	0,	0 },
526   { 0x00410000, 0xffff0000,	"slli.d",	"r0:5,r5:5,u10:6",		0,			0,	0,	0 },
527   { 0x00448000, 0xffff8000,	"srli.w",	"r0:5,r5:5,u10:5",		0,			0,	0,	0 },
528   { 0x00450000, 0xffff0000,	"srli.d",	"r0:5,r5:5,u10:6",		0,			0,	0,	0 },
529   { 0x00488000, 0xffff8000,	"srai.w",	"r0:5,r5:5,u10:5",		0,			0,	0,	0 },
530   { 0x00490000, 0xffff0000,	"srai.d",	"r0:5,r5:5,u10:6",		0,			0,	0,	0 },
531   { 0x004c8000, 0xffff8000,	"rotri.w",	"r0:5,r5:5,u10:5",		0,			0,	0,	0 },
532   { 0x004d0000, 0xffff0000,	"rotri.d",	"r0:5,r5:5,u10:6",		0,			0,	0,	0 },
533   { 0x00600000, 0xffe08000,	"bstrins.w",	"r0:5,r5:5,u16:5,u10:5",	0,			0,	0,	0 },
534   { 0x00608000, 0xffe08000,	"bstrpick.w",	"r0:5,r5:5,u16:5,u10:5",	0,			0,	0,	0 },
535   { 0x00800000, 0xffc00000,	"bstrins.d",	"r0:5,r5:5,u16:6,u10:6",	0,			0,	0,	0 },
536   { 0x00c00000, 0xffc00000,	"bstrpick.d",	"r0:5,r5:5,u16:6,u10:6",	0,			0,	0,	0 },
537   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
538 };
539 
540 static struct loongarch_opcode loongarch_single_float_opcodes[] =
541 {
542   /* match,	mask,		name,		format,				macro,			include, exclude, pinfo.  */
543   { 0x01008000, 0xffff8000,	"fadd.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
544   { 0x01028000, 0xffff8000,	"fsub.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
545   { 0x01048000, 0xffff8000,	"fmul.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
546   { 0x01068000, 0xffff8000,	"fdiv.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
547   { 0x01088000, 0xffff8000,	"fmax.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
548   { 0x010a8000, 0xffff8000,	"fmin.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
549   { 0x010c8000, 0xffff8000,	"fmaxa.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
550   { 0x010e8000, 0xffff8000,	"fmina.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
551   { 0x01108000, 0xffff8000,	"fscaleb.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
552   { 0x01128000, 0xffff8000,	"fcopysign.s",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
553   { 0x01140400, 0xfffffc00,	"fabs.s",	"f0:5,f5:5",			0,			0,	0,	0 },
554   { 0x01141400, 0xfffffc00,	"fneg.s",	"f0:5,f5:5",			0,			0,	0,	0 },
555   { 0x01142400, 0xfffffc00,	"flogb.s",	"f0:5,f5:5",			0,			0,	0,	0 },
556   { 0x01143400, 0xfffffc00,	"fclass.s",	"f0:5,f5:5",			0,			0,	0,	0 },
557   { 0x01144400, 0xfffffc00,	"fsqrt.s",	"f0:5,f5:5",			0,			0,	0,	0 },
558   { 0x01145400, 0xfffffc00,	"frecip.s",	"f0:5,f5:5",			0,			0,	0,	0 },
559   { 0x01146400, 0xfffffc00,	"frsqrt.s",	"f0:5,f5:5",			0,			0,	0,	0 },
560   { 0x01147400, 0xfffffc00,	"frecipe.s",	"f0:5,f5:5",			0,			0,	0,	0 },
561   { 0x01148400, 0xfffffc00,	"frsqrte.s",	"f0:5,f5:5",			0,			0,	0,	0 },
562   { 0x01149400, 0xfffffc00,	"fmov.s",	"f0:5,f5:5",			0,			0,	0,	0 },
563   { 0x0114a400, 0xfffffc00,	"movgr2fr.w",	"f0:5,r5:5",			0,			0,	0,	0 },
564   { 0x0114ac00, 0xfffffc00,	"movgr2frh.w",	"f0:5,r5:5",			0,			0,	0,	0 },
565   { 0x0114b400, 0xfffffc00,	"movfr2gr.s",	"r0:5,f5:5",			0,			0,	0,	0 },
566   { 0x0114bc00, 0xfffffc00,	"movfrh2gr.s",	"r0:5,f5:5",			0,			0,	0,	0 },
567   { 0x0114c000, 0xfffffc1c,	"movgr2fcsr",	"fc0:2,r5:5",			0,			0,	0,	0 },
568   { 0x0114c800, 0xffffff80,	"movfcsr2gr",	"r0:5,fc5:2",			0,			0,	0,	0 },
569   { 0x0114d000, 0xfffffc18,	"movfr2cf",	"c0:3,f5:5",			0,			0,	0,	0 },
570   { 0x0114d400, 0xffffff00,	"movcf2fr",	"f0:5,c5:3",			0,			0,	0,	0 },
571   { 0x0114d800, 0xfffffc18,	"movgr2cf",	"c0:3,r5:5",			0,			0,	0,	0 },
572   { 0x0114dc00, 0xffffff00,	"movcf2gr",	"r0:5,c5:3",			0,			0,	0,	0 },
573   { 0x011a0400, 0xfffffc00,	"ftintrm.w.s",	"f0:5,f5:5",			0,			0,	0,	0 },
574   { 0x011a2400, 0xfffffc00,	"ftintrm.l.s",	"f0:5,f5:5",			0,			0,	0,	0 },
575   { 0x011a4400, 0xfffffc00,	"ftintrp.w.s",	"f0:5,f5:5",			0,			0,	0,	0 },
576   { 0x011a6400, 0xfffffc00,	"ftintrp.l.s",	"f0:5,f5:5",			0,			0,	0,	0 },
577   { 0x011a8400, 0xfffffc00,	"ftintrz.w.s",	"f0:5,f5:5",			0,			0,	0,	0 },
578   { 0x011aa400, 0xfffffc00,	"ftintrz.l.s",	"f0:5,f5:5",			0,			0,	0,	0 },
579   { 0x011ac400, 0xfffffc00,	"ftintrne.w.s",	"f0:5,f5:5",			0,			0,	0,	0 },
580   { 0x011ae400, 0xfffffc00,	"ftintrne.l.s",	"f0:5,f5:5",			0,			0,	0,	0 },
581   { 0x011b0400, 0xfffffc00,	"ftint.w.s",	"f0:5,f5:5",			0,			0,	0,	0 },
582   { 0x011b2400, 0xfffffc00,	"ftint.l.s",	"f0:5,f5:5",			0,			0,	0,	0 },
583   { 0x011d1000, 0xfffffc00,	"ffint.s.w",	"f0:5,f5:5",			0,			0,	0,	0 },
584   { 0x011d1800, 0xfffffc00,	"ffint.s.l",	"f0:5,f5:5",			0,			0,	0,	0 },
585   { 0x011e4400, 0xfffffc00,	"frint.s",	"f0:5,f5:5",			0,			0,	0,	0 },
586   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
587 };
588 static struct loongarch_opcode loongarch_double_float_opcodes[] =
589 {
590   /* match,	mask,		name,		format,				macro,			include, exclude, pinfo.  */
591   { 0x01010000, 0xffff8000,	"fadd.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
592   { 0x01030000, 0xffff8000,	"fsub.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
593   { 0x01050000, 0xffff8000,	"fmul.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
594   { 0x01070000, 0xffff8000,	"fdiv.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
595   { 0x01090000, 0xffff8000,	"fmax.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
596   { 0x010b0000, 0xffff8000,	"fmin.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
597   { 0x010d0000, 0xffff8000,	"fmaxa.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
598   { 0x010f0000, 0xffff8000,	"fmina.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
599   { 0x01110000, 0xffff8000,	"fscaleb.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
600   { 0x01130000, 0xffff8000,	"fcopysign.d",	"f0:5,f5:5,f10:5",		0,			0,	0,	0 },
601   { 0x01140800, 0xfffffc00,	"fabs.d",	"f0:5,f5:5",			0,			0,	0,	0 },
602   { 0x01141800, 0xfffffc00,	"fneg.d",	"f0:5,f5:5",			0,			0,	0,	0 },
603   { 0x01142800, 0xfffffc00,	"flogb.d",	"f0:5,f5:5",			0,			0,	0,	0 },
604   { 0x01143800, 0xfffffc00,	"fclass.d",	"f0:5,f5:5",			0,			0,	0,	0 },
605   { 0x01144800, 0xfffffc00,	"fsqrt.d",	"f0:5,f5:5",			0,			0,	0,	0 },
606   { 0x01145800, 0xfffffc00,	"frecip.d",	"f0:5,f5:5",			0,			0,	0,	0 },
607   { 0x01146800, 0xfffffc00,	"frsqrt.d",	"f0:5,f5:5",			0,			0,	0,	0 },
608   { 0x01147800, 0xfffffc00,	"frecipe.d",	"f0:5,f5:5",			0,			0,	0,	0 },
609   { 0x01148800, 0xfffffc00,	"frsqrte.d",	"f0:5,f5:5",			0,			0,	0,	0 },
610   { 0x01149800, 0xfffffc00,	"fmov.d",	"f0:5,f5:5",			0,			0,	0,	0 },
611   { 0x0114a800, 0xfffffc00,	"movgr2fr.d",	"f0:5,r5:5",			0,			0,	0,	0 },
612   { 0x0114b800, 0xfffffc00,	"movfr2gr.d",	"r0:5,f5:5",			0,			0,	0,	0 },
613   { 0x01191800, 0xfffffc00,	"fcvt.s.d",	"f0:5,f5:5",			0,			0,	0,	0 },
614   { 0x01192400, 0xfffffc00,	"fcvt.d.s",	"f0:5,f5:5",			0,			0,	0,	0 },
615   { 0x011a0800, 0xfffffc00,	"ftintrm.w.d",	"f0:5,f5:5",			0,			0,	0,	0 },
616   { 0x011a2800, 0xfffffc00,	"ftintrm.l.d",	"f0:5,f5:5",			0,			0,	0,	0 },
617   { 0x011a4800, 0xfffffc00,	"ftintrp.w.d",	"f0:5,f5:5",			0,			0,	0,	0 },
618   { 0x011a6800, 0xfffffc00,	"ftintrp.l.d",	"f0:5,f5:5",			0,			0,	0,	0 },
619   { 0x011a8800, 0xfffffc00,	"ftintrz.w.d",	"f0:5,f5:5",			0,			0,	0,	0 },
620   { 0x011aa800, 0xfffffc00,	"ftintrz.l.d",	"f0:5,f5:5",			0,			0,	0,	0 },
621   { 0x011ac800, 0xfffffc00,	"ftintrne.w.d",	"f0:5,f5:5",			0,			0,	0,	0 },
622   { 0x011ae800, 0xfffffc00,	"ftintrne.l.d",	"f0:5,f5:5",			0,			0,	0,	0 },
623   { 0x011b0800, 0xfffffc00,	"ftint.w.d",	"f0:5,f5:5",			0,			0,	0,	0 },
624   { 0x011b2800, 0xfffffc00,	"ftint.l.d",	"f0:5,f5:5",			0,			0,	0,	0 },
625   { 0x011d2000, 0xfffffc00,	"ffint.d.w",	"f0:5,f5:5",			0,			0,	0,	0 },
626   { 0x011d2800, 0xfffffc00,	"ffint.d.l",	"f0:5,f5:5",			0,			0,	0,	0 },
627   { 0x011e4800, 0xfffffc00,	"frint.d",	"f0:5,f5:5",			0,			0,	0,	0 },
628   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
629 };
630 
631 static struct loongarch_opcode loongarch_imm_opcodes[] =
632 {
633   /* match,	mask,		name,		format,				macro,			include, exclude, pinfo.  */
634   { 0x02000000, 0xffc00000,	"slti",		"r0:5,r5:5,s10:12",		0,			0,	0,	0 },
635   { 0x02400000, 0xffc00000,	"sltui",	"r0:5,r5:5,s10:12",		0,			0,	0,	0 },
636   { 0x02800000, 0xffc00000,	"addi.w",	"r0:5,r5:5,s10:12",		0,			0,	0,	0 },
637   { 0x02c00000, 0xffc00000,	"addi.d",	"r0:5,r5:5,s10:12",		0,			0,	0,	0 },
638   { 0x03000000, 0xffc00000,	"lu52i.d",	"r0:5,r5:5,s10:12",		0,			0,	0,	0 },
639   { 0x0,	0x0,		"nop",		"",				"andi $r0,$r0,0",	0,	0,	0 },
640   { 0x03400000, 0xffc00000,	"andi",		"r0:5,r5:5,u10:12",		0,			0,	0,	0 },
641   { 0x03800000, 0xffc00000,	"ori",		"r0:5,r5:5,u10:12",		0,			0,	0,	0 },
642   { 0x03c00000, 0xffc00000,	"xori",		"r0:5,r5:5,u10:12",		0,			0,	0,	0 },
643   { 0x10000000, 0xfc000000,	"addu16i.d",	"r0:5,r5:5,s10:16",		0,			0,	0,	0 },
644   { 0x14000000, 0xfe000000,	"lu12i.w",	"r0:5,s5:20",			0,			0,	0,	0 },
645   { 0x16000000, 0xfe000000,	"lu32i.d",	"r0:5,s5:20",			0,			0,	0,	0 },
646   { 0x18000000, 0xfe000000,	"pcaddi",	"r0:5,s5:20",			0,			0,	0,	0 },
647   { 0x1a000000, 0xfe000000,	"pcalau12i",	"r0:5,s5:20",			0,			0,	0,	0 },
648   { 0x1c000000, 0xfe000000,	"pcaddu12i",	"r0:5,s5:20",			0,			0,	0,	0 },
649   { 0x1e000000, 0xfe000000,	"pcaddu18i",	"r0:5,s5:20",			0,			0,	0,	0 },
650   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
651 };
652 
653 static struct loongarch_opcode loongarch_privilege_opcodes[] =
654 {
655   /* match,	mask,		name,		format,				macro,			include, exclude, pinfo.  */
656   { 0x04000000, 0xff0003e0,	"csrrd",	"r0:5,u10:14",			0,			0,	0,	0 },
657   { 0x04000020, 0xff0003e0,	"csrwr",	"r0:5,u10:14",			0,			0,	0,	0 },
658   { 0x04000000, 0xff000000,	"csrxchg",	"r0:5,r5:5,u10:14",		0,			0,	0,	0 },
659   { 0x06000000, 0xffc00000,	"cacop",	"u0:5,r5:5,s10:12",		0,			0,	0,	0 },
660   { 0x06400000, 0xfffc0000,	"lddir",	"r0:5,r5:5,u10:8",		0,			0,	0,	0 },
661   { 0x06440000, 0xfffc001f,	"ldpte",	"r5:5,u10:8",			0,			0,	0,	0 },
662   { 0x06480000, 0xfffffc00,	"iocsrrd.b",	"r0:5,r5:5",			0,			0,	0,	0 },
663   { 0x06480400, 0xfffffc00,	"iocsrrd.h",	"r0:5,r5:5",			0,			0,	0,	0 },
664   { 0x06480800, 0xfffffc00,	"iocsrrd.w",	"r0:5,r5:5",			0,			0,	0,	0 },
665   { 0x06480c00, 0xfffffc00,	"iocsrrd.d",	"r0:5,r5:5",			0,			0,	0,	0 },
666   { 0x06481000, 0xfffffc00,	"iocsrwr.b",	"r0:5,r5:5",			0,			0,	0,	0 },
667   { 0x06481400, 0xfffffc00,	"iocsrwr.h",	"r0:5,r5:5",			0,			0,	0,	0 },
668   { 0x06481800, 0xfffffc00,	"iocsrwr.w",	"r0:5,r5:5",			0,			0,	0,	0 },
669   { 0x06481c00, 0xfffffc00,	"iocsrwr.d",	"r0:5,r5:5",			0,			0,	0,	0 },
670   { 0x06482000, 0xffffffff,	"tlbclr",	"",				0,			0,	0,	0 },
671   { 0x06482400, 0xffffffff,	"tlbflush",	"",				0,			0,	0,	0 },
672   { 0x06482800, 0xffffffff,	"tlbsrch",	"",				0,			0,	0,	0 },
673   { 0x06482c00, 0xffffffff,	"tlbrd",	"",				0,			0,	0,	0 },
674   { 0x06483000, 0xffffffff,	"tlbwr",	"",				0,			0,	0,	0 },
675   { 0x06483400, 0xffffffff,	"tlbfill",	"",				0,			0,	0,	0 },
676   { 0x06483800, 0xffffffff,	"ertn",		"",				0,			0,	0,	0 },
677   { 0x06488000, 0xffff8000,	"idle",		"u0:15",			0,			0,	0,	0 },
678   { 0x06498000, 0xffff8000,	"invtlb",	"u0:5,r5:5,r10:5",		0,			0,	0,	0 },
679   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
680 };
681 
682 static struct loongarch_opcode loongarch_4opt_single_float_opcodes[] =
683 {
684   /* match,	mask,		name,			format,				macro,	include, exclude, pinfo.  */
685   { 0x08100000, 0xfff00000,	"fmadd.s",		"f0:5,f5:5,f10:5,f15:5",	0,	0,	0,	0 },
686   { 0x08500000, 0xfff00000,	"fmsub.s",		"f0:5,f5:5,f10:5,f15:5",	0,	0,	0,	0 },
687   { 0x08900000, 0xfff00000,	"fnmadd.s",		"f0:5,f5:5,f10:5,f15:5",	0,	0,	0,	0 },
688   { 0x08d00000, 0xfff00000,	"fnmsub.s",		"f0:5,f5:5,f10:5,f15:5",	0,	0,	0,	0 },
689   { 0x09100000, 0xfff00000,	"vfmadd.s",		"v0:5,v5:5,v10:5,v15:5",	0,	0,	0,	0 },
690   { 0x09500000, 0xfff00000,	"vfmsub.s",		"v0:5,v5:5,v10:5,v15:5",	0,	0,	0,	0 },
691   { 0x09900000, 0xfff00000,	"vfnmadd.s",		"v0:5,v5:5,v10:5,v15:5",	0,	0,	0,	0 },
692   { 0x09d00000, 0xfff00000,	"vfnmsub.s",		"v0:5,v5:5,v10:5,v15:5",	0,	0,	0,	0 },
693   { 0x0a100000, 0xfff00000,	"xvfmadd.s",		"x0:5,x5:5,x10:5,x15:5",	0,	0,	0,	0 },
694   { 0x0a500000, 0xfff00000,	"xvfmsub.s",		"x0:5,x5:5,x10:5,x15:5",	0,	0,	0,	0 },
695   { 0x0a900000, 0xfff00000,	"xvfnmadd.s",		"x0:5,x5:5,x10:5,x15:5",	0,	0,	0,	0 },
696   { 0x0ad00000, 0xfff00000,	"xvfnmsub.s",		"x0:5,x5:5,x10:5,x15:5",	0,	0,	0,	0 },
697   { 0x0c100000, 0xffff8018,	"fcmp.caf.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
698   { 0x0c108000, 0xffff8018,	"fcmp.saf.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
699   { 0x0c110000, 0xffff8018,	"fcmp.clt.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
700   { 0x0c118000, 0xffff8018,	"fcmp.slt.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
701   { 0x0c118000, 0xffff8018,	"fcmp.sgt.s",		"c0:3,f10:5,f5:5",		0,	0,	0,	0 },
702   { 0x0c120000, 0xffff8018,	"fcmp.ceq.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
703   { 0x0c128000, 0xffff8018,	"fcmp.seq.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
704   { 0x0c130000, 0xffff8018,	"fcmp.cle.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
705   { 0x0c138000, 0xffff8018,	"fcmp.sle.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
706   { 0x0c138000, 0xffff8018,	"fcmp.sge.s",		"c0:3,f10:5,f5:5",		0,	0,	0,	0 },
707   { 0x0c140000, 0xffff8018,	"fcmp.cun.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
708   { 0x0c148000, 0xffff8018,	"fcmp.sun.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
709   { 0x0c150000, 0xffff8018,	"fcmp.cult.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
710   { 0x0c150000, 0xffff8018,	"fcmp.cugt.s",		"c0:3,f10:5,f5:5",		0,	0,	0,	0 },
711   { 0x0c158000, 0xffff8018,	"fcmp.sult.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
712   { 0x0c160000, 0xffff8018,	"fcmp.cueq.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
713   { 0x0c168000, 0xffff8018,	"fcmp.sueq.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
714   { 0x0c170000, 0xffff8018,	"fcmp.cule.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
715   { 0x0c170000, 0xffff8018,	"fcmp.cuge.s",		"c0:3,f10:5,f5:5",		0,	0,	0,	0 },
716   { 0x0c178000, 0xffff8018,	"fcmp.sule.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
717   { 0x0c180000, 0xffff8018,	"fcmp.cne.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
718   { 0x0c188000, 0xffff8018,	"fcmp.sne.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
719   { 0x0c1a0000, 0xffff8018,	"fcmp.cor.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
720   { 0x0c1a8000, 0xffff8018,	"fcmp.sor.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
721   { 0x0c1c0000, 0xffff8018,	"fcmp.cune.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
722   { 0x0c1c8000, 0xffff8018,	"fcmp.sune.s",		"c0:3,f5:5,f10:5",		0,	0,	0,	0 },
723   { 0x0c500000, 0xffff8000,	"vfcmp.caf.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
724   { 0x0c508000, 0xffff8000,	"vfcmp.saf.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
725   { 0x0c510000, 0xffff8000,	"vfcmp.clt.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
726   { 0x0c518000, 0xffff8000,	"vfcmp.slt.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
727   { 0x0c520000, 0xffff8000,	"vfcmp.ceq.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
728   { 0x0c528000, 0xffff8000,	"vfcmp.seq.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
729   { 0x0c530000, 0xffff8000,	"vfcmp.cle.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
730   { 0x0c538000, 0xffff8000,	"vfcmp.sle.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
731   { 0x0c540000, 0xffff8000,	"vfcmp.cun.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
732   { 0x0c548000, 0xffff8000,	"vfcmp.sun.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
733   { 0x0c550000, 0xffff8000,	"vfcmp.cult.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
734   { 0x0c558000, 0xffff8000,	"vfcmp.sult.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
735   { 0x0c560000, 0xffff8000,	"vfcmp.cueq.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
736   { 0x0c568000, 0xffff8000,	"vfcmp.sueq.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
737   { 0x0c570000, 0xffff8000,	"vfcmp.cule.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
738   { 0x0c578000, 0xffff8000,	"vfcmp.sule.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
739   { 0x0c580000, 0xffff8000,	"vfcmp.cne.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
740   { 0x0c588000, 0xffff8000,	"vfcmp.sne.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
741   { 0x0c5a0000, 0xffff8000,	"vfcmp.cor.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
742   { 0x0c5a8000, 0xffff8000,	"vfcmp.sor.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
743   { 0x0c5c0000, 0xffff8000,	"vfcmp.cune.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
744   { 0x0c5c8000, 0xffff8000,	"vfcmp.sune.s",		"v0:5,v5:5,v10:5",		0,	0,	0,	0 },
745   { 0x0c900000, 0xffff8000,	"xvfcmp.caf.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
746   { 0x0c908000, 0xffff8000,	"xvfcmp.saf.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
747   { 0x0c910000, 0xffff8000,	"xvfcmp.clt.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
748   { 0x0c918000, 0xffff8000,	"xvfcmp.slt.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
749   { 0x0c920000, 0xffff8000,	"xvfcmp.ceq.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
750   { 0x0c928000, 0xffff8000,	"xvfcmp.seq.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
751   { 0x0c930000, 0xffff8000,	"xvfcmp.cle.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
752   { 0x0c938000, 0xffff8000,	"xvfcmp.sle.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
753   { 0x0c940000, 0xffff8000,	"xvfcmp.cun.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
754   { 0x0c948000, 0xffff8000,	"xvfcmp.sun.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
755   { 0x0c950000, 0xffff8000,	"xvfcmp.cult.s",	"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
756   { 0x0c958000, 0xffff8000,	"xvfcmp.sult.s",	"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
757   { 0x0c960000, 0xffff8000,	"xvfcmp.cueq.s",	"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
758   { 0x0c968000, 0xffff8000,	"xvfcmp.sueq.s",	"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
759   { 0x0c970000, 0xffff8000,	"xvfcmp.cule.s",	"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
760   { 0x0c978000, 0xffff8000,	"xvfcmp.sule.s",	"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
761   { 0x0c980000, 0xffff8000,	"xvfcmp.cne.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
762   { 0x0c988000, 0xffff8000,	"xvfcmp.sne.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
763   { 0x0c9a0000, 0xffff8000,	"xvfcmp.cor.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
764   { 0x0c9a8000, 0xffff8000,	"xvfcmp.sor.s",		"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
765   { 0x0c9c0000, 0xffff8000,	"xvfcmp.cune.s",	"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
766   { 0x0c9c8000, 0xffff8000,	"xvfcmp.sune.s",	"x0:5,x5:5,x10:5",		0,	0,	0,	0 },
767   { 0x0d000000, 0xfffc0000,	"fsel",			"f0:5,f5:5,f10:5,c15:3",	0,	0,	0,	0 },
768   { 0x0d100000, 0xfff00000,	"vbitsel.v",		"v0:5,v5:5,v10:5,v15:5",	0,	0,	0,	0 },
769   { 0x0d200000, 0xfff00000,	"xvbitsel.v",		"x0:5,x5:5,x10:5,x15:5",	0,	0,	0,	0 },
770   { 0x0d500000, 0xfff00000,	"vshuf.b",		"v0:5,v5:5,v10:5,v15:5",	0,	0,	0,	0 },
771   { 0x0d600000, 0xfff00000,	"xvshuf.b",		"x0:5,x5:5,x10:5,x15:5",	0,	0,	0,	0 },
772   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
773 };
774 
775 static struct loongarch_opcode loongarch_4opt_double_float_opcodes[] =
776 {
777   /* match,	mask,		name,		format,				macro,			include, exclude, pinfo.  */
778   { 0x08200000, 0xfff00000,	"fmadd.d",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
779   { 0x08600000, 0xfff00000,	"fmsub.d",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
780   { 0x08a00000, 0xfff00000,	"fnmadd.d",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
781   { 0x08e00000, 0xfff00000,	"fnmsub.d",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
782   { 0x09200000, 0xfff00000,	"vfmadd.d",	"v0:5,v5:5,v10:5,v15:5",	0,			0,	0,	0 },
783   { 0x09600000, 0xfff00000,	"vfmsub.d",	"v0:5,v5:5,v10:5,v15:5",	0, 			0,	0,	0 },
784   { 0x09a00000, 0xfff00000,	"vfnmadd.d",	"v0:5,v5:5,v10:5,v15:5",	0, 			0,	0,	0 },
785   { 0x09e00000, 0xfff00000,	"vfnmsub.d",	"v0:5,v5:5,v10:5,v15:5",	0, 			0,	0,	0 },
786   { 0x0a200000, 0xfff00000,	"xvfmadd.d",	"x0:5,x5:5,x10:5,x15:5",	0, 			0,	0,	0 },
787   { 0x0a600000, 0xfff00000,	"xvfmsub.d",	"x0:5,x5:5,x10:5,x15:5",	0, 			0,	0,	0 },
788   { 0x0aa00000, 0xfff00000,	"xvfnmadd.d",	"x0:5,x5:5,x10:5,x15:5",	0, 			0,	0,	0 },
789   { 0x0ae00000, 0xfff00000,	"xvfnmsub.d",	"x0:5,x5:5,x10:5,x15:5",	0, 			0,	0,	0 },
790   { 0x0c200000, 0xffff8018,	"fcmp.caf.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
791   { 0x0c208000, 0xffff8018,	"fcmp.saf.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
792   { 0x0c210000, 0xffff8018,	"fcmp.clt.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
793   { 0x0c218000, 0xffff8018,	"fcmp.slt.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
794   { 0x0c218000, 0xffff8018,	"fcmp.sgt.d",	"c0:3,f10:5,f5:5",		0,			0,	0,	0 },
795   { 0x0c220000, 0xffff8018,	"fcmp.ceq.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
796   { 0x0c228000, 0xffff8018,	"fcmp.seq.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
797   { 0x0c230000, 0xffff8018,	"fcmp.cle.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
798   { 0x0c238000, 0xffff8018,	"fcmp.sle.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
799   { 0x0c238000, 0xffff8018,	"fcmp.sge.d",	"c0:3,f10:5,f5:5",		0,			0,	0,	0 },
800   { 0x0c240000, 0xffff8018,	"fcmp.cun.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
801   { 0x0c248000, 0xffff8018,	"fcmp.sun.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
802   { 0x0c250000, 0xffff8018,	"fcmp.cult.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
803   { 0x0c250000, 0xffff8018,	"fcmp.cugt.d",	"c0:3,f10:5,f5:5",		0,			0,	0,	0 },
804   { 0x0c258000, 0xffff8018,	"fcmp.sult.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
805   { 0x0c260000, 0xffff8018,	"fcmp.cueq.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
806   { 0x0c268000, 0xffff8018,	"fcmp.sueq.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
807   { 0x0c270000, 0xffff8018,	"fcmp.cule.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
808   { 0x0c270000, 0xffff8018,	"fcmp.cuge.d",	"c0:3,f10:5,f5:5",		0,			0,	0,	0 },
809   { 0x0c278000, 0xffff8018,	"fcmp.sule.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
810   { 0x0c280000, 0xffff8018,	"fcmp.cne.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
811   { 0x0c288000, 0xffff8018,	"fcmp.sne.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
812   { 0x0c2a0000, 0xffff8018,	"fcmp.cor.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
813   { 0x0c2a8000, 0xffff8018,	"fcmp.sor.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
814   { 0x0c2c0000, 0xffff8018,	"fcmp.cune.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
815   { 0x0c2c8000, 0xffff8018,	"fcmp.sune.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
816   { 0x0c600000, 0xffff8000, "vfcmp.caf.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
817   { 0x0c608000, 0xffff8000, "vfcmp.saf.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
818   { 0x0c610000, 0xffff8000, "vfcmp.clt.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
819   { 0x0c618000, 0xffff8000, "vfcmp.slt.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
820   { 0x0c620000, 0xffff8000, "vfcmp.ceq.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
821   { 0x0c628000, 0xffff8000, "vfcmp.seq.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
822   { 0x0c630000, 0xffff8000, "vfcmp.cle.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
823   { 0x0c638000, 0xffff8000, "vfcmp.sle.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
824   { 0x0c640000, 0xffff8000, "vfcmp.cun.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
825   { 0x0c648000, 0xffff8000, "vfcmp.sun.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
826   { 0x0c650000, 0xffff8000, "vfcmp.cult.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
827   { 0x0c658000, 0xffff8000, "vfcmp.sult.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
828   { 0x0c660000, 0xffff8000, "vfcmp.cueq.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
829   { 0x0c668000, 0xffff8000, "vfcmp.sueq.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
830   { 0x0c670000, 0xffff8000, "vfcmp.cule.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
831   { 0x0c678000, 0xffff8000, "vfcmp.sule.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
832   { 0x0c680000, 0xffff8000, "vfcmp.cne.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
833   { 0x0c688000, 0xffff8000, "vfcmp.sne.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
834   { 0x0c6a0000, 0xffff8000, "vfcmp.cor.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
835   { 0x0c6a8000, 0xffff8000, "vfcmp.sor.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
836   { 0x0c6c0000, 0xffff8000, "vfcmp.cune.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
837   { 0x0c6c8000, 0xffff8000, "vfcmp.sune.d", "v0:5,v5:5,v10:5",			0,			0,	0,	0 },
838   { 0x0ca00000, 0xffff8000, "xvfcmp.caf.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
839   { 0x0ca08000, 0xffff8000, "xvfcmp.saf.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
840   { 0x0ca10000, 0xffff8000, "xvfcmp.clt.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
841   { 0x0ca18000, 0xffff8000, "xvfcmp.slt.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
842   { 0x0ca20000, 0xffff8000, "xvfcmp.ceq.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
843   { 0x0ca28000, 0xffff8000, "xvfcmp.seq.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
844   { 0x0ca30000, 0xffff8000, "xvfcmp.cle.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
845   { 0x0ca38000, 0xffff8000, "xvfcmp.sle.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
846   { 0x0ca40000, 0xffff8000, "xvfcmp.cun.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
847   { 0x0ca48000, 0xffff8000, "xvfcmp.sun.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
848   { 0x0ca50000, 0xffff8000, "xvfcmp.cult.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
849   { 0x0ca58000, 0xffff8000, "xvfcmp.sult.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
850   { 0x0ca60000, 0xffff8000, "xvfcmp.cueq.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
851   { 0x0ca68000, 0xffff8000, "xvfcmp.sueq.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
852   { 0x0ca70000, 0xffff8000, "xvfcmp.cule.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
853   { 0x0ca78000, 0xffff8000, "xvfcmp.sule.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
854   { 0x0ca80000, 0xffff8000, "xvfcmp.cne.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
855   { 0x0ca88000, 0xffff8000, "xvfcmp.sne.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
856   { 0x0caa0000, 0xffff8000, "xvfcmp.cor.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
857   { 0x0caa8000, 0xffff8000, "xvfcmp.sor.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
858   { 0x0cac0000, 0xffff8000, "xvfcmp.cune.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
859   { 0x0cac8000, 0xffff8000, "xvfcmp.sune.d", "x0:5,x5:5,x10:5",			0,			0,	0,	0 },
860   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
861 };
862 
863 static struct loongarch_opcode loongarch_load_store_opcodes[] =
864 {
865   /* match,	mask,		name,		format,				macro,			include, exclude, pinfo.  */
866   { 0x20000000, 0xff000000,	"ll.w",		"r0:5,r5:5,so10:14<<2",		0,			0,	0,	0 },
867   { 0x21000000, 0xff000000,	"sc.w",		"r0:5,r5:5,so10:14<<2",		0,			0,	0,	0 },
868   { 0x22000000, 0xff000000,	"ll.d",		"r0:5,r5:5,so10:14<<2",		0,			0,	0,	0 },
869   { 0x23000000, 0xff000000,	"sc.d",		"r0:5,r5:5,so10:14<<2",		0,			0,	0,	0 },
870   { 0x24000000, 0xff000000,	"ldptr.w",	"r0:5,r5:5,so10:14<<2",		0,			0,	0,	0 },
871   { 0x25000000, 0xff000000,	"stptr.w",	"r0:5,r5:5,so10:14<<2",		0,			0,	0,	0 },
872   { 0x26000000, 0xff000000,	"ldptr.d",	"r0:5,r5:5,so10:14<<2",		0,			0,	0,	0 },
873   { 0x27000000, 0xff000000,	"stptr.d",	"r0:5,r5:5,so10:14<<2",		0,			0,	0,	0 },
874   { 0x28000000, 0xffc00000,	"ld.b",		"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
875   { 0x28400000, 0xffc00000,	"ld.h",		"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
876   { 0x28800000, 0xffc00000,	"ld.w",		"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
877   { 0x28c00000, 0xffc00000,	"ld.d",		"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
878   { 0x29000000, 0xffc00000,	"st.b",		"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
879   { 0x29400000, 0xffc00000,	"st.h",		"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
880   { 0x29800000, 0xffc00000,	"st.w",		"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
881   { 0x29c00000, 0xffc00000,	"st.d",		"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
882   { 0x2a000000, 0xffc00000,	"ld.bu",	"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
883   { 0x2a400000, 0xffc00000,	"ld.hu",	"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
884   { 0x2a800000, 0xffc00000,	"ld.wu",	"r0:5,r5:5,so10:12",		0,			0,	0,	0 },
885   { 0x2ac00000, 0xffc00000,	"preld",	"u0:5,r5:5,so10:12",		0,			0,	0,	0 },
886   { 0x38000000, 0xffff8000,	"ldx.b",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
887   { 0x38040000, 0xffff8000,	"ldx.h",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
888   { 0x38080000, 0xffff8000,	"ldx.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
889   { 0x380c0000, 0xffff8000,	"ldx.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
890   { 0x38100000, 0xffff8000,	"stx.b",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
891   { 0x38140000, 0xffff8000,	"stx.h",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
892   { 0x38180000, 0xffff8000,	"stx.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
893   { 0x381c0000, 0xffff8000,	"stx.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
894   { 0x38200000, 0xffff8000,	"ldx.bu",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
895   { 0x38240000, 0xffff8000,	"ldx.hu",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
896   { 0x38280000, 0xffff8000,	"ldx.wu",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
897   { 0x382c0000, 0xffff8000,	"preldx",	"u0:5,r5:5,r10:5",		0,			0,	0,	0 },
898   { 0x0,	0x0,		"sc.q",		"r,r,r,u0:0",			"sc.q %1,%2,%3",	0,	0,	0 },
899   { 0x38570000, 0xffff8000,	"sc.q",		"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
900   { 0x0,	0x0,		"llacq.w",	"r,r,u0:0",			"llacq.w %1,%2",	0,	0,	0 },
901   { 0x38578000, 0xfffffc00,	"llacq.w",	"r0:5,r5:5",			0,			0,	0,	0 },
902   { 0x0,	0x0,		"screl.w",	"r,r,u0:0",			"screl.w %1,%2",	0,	0,	0 },
903   { 0x38578400, 0xfffffc00,	"screl.w",	"r0:5,r5:5",			0,			0,	0,	0 },
904   { 0x0,	0x0,		"llacq.d",	"r,r,u0:0",			"llacq.d %1,%2",	0,	0,	0 },
905   { 0x38578800, 0xfffffc00,	"llacq.d",	"r0:5,r5:5",			0,			0,	0,	0 },
906   { 0x0,	0x0,		"screl.d",	"r,r,u0:0",			"screl.d %1,%2",	0,	0,	0 },
907   { 0x38578c00, 0xfffffc00,	"screl.d",	"r0:5,r5:5",			0,			0,	0,	0 },
908   { 0x0,	0x0,		"amcas.b",	"r,r,r,u0:0",			"amcas.b %1,%2,%3",	0,	0,	0 },
909   { 0x38580000, 0xffff8000,	"amcas.b",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
910   { 0x0,	0x0,		"amcas.h",	"r,r,r,u0:0",			"amcas.h %1,%2,%3",	0,	0,	0 },
911   { 0x38588000, 0xffff8000,	"amcas.h",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
912   { 0x0,	0x0,		"amcas.w",	"r,r,r,u0:0",			"amcas.w %1,%2,%3",	0,	0,	0 },
913   { 0x38590000, 0xffff8000,	"amcas.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
914   { 0x0,	0x0,		"amcas.d",	"r,r,r,u0:0",			"amcas.d %1,%2,%3",	0,	0,	0 },
915   { 0x38598000, 0xffff8000,	"amcas.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
916   { 0x0,	0x0,		"amcas_db.b",	"r,r,r,u0:0",			"amcas_db.b %1,%2,%3",	0,	0,	0 },
917   { 0x385a0000, 0xffff8000,	"amcas_db.b",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
918   { 0x0,	0x0,		"amcas_db.h",	"r,r,r,u0:0",			"amcas_db.h %1,%2,%3",	0,	0,	0 },
919   { 0x385a8000, 0xffff8000,	"amcas_db.h",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
920   { 0x0,	0x0,		"amcas_db.w",	"r,r,r,u0:0",			"amcas_db.w %1,%2,%3",	0,	0,	0 },
921   { 0x385b0000, 0xffff8000,	"amcas_db.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
922   { 0x0,	0x0,		"amcas_db.d",	"r,r,r,u0:0",			"amcas_db.d %1,%2,%3",	0,	0,	0 },
923   { 0x385b8000, 0xffff8000,	"amcas_db.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
924   { 0x0,	0x0,		"amswap.b",	"r,r,r,u0:0",			"amswap.b %1,%2,%3",	0,	0,	0 },
925   { 0x385c0000, 0xffff8000,	"amswap.b",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
926   { 0x0,	0x0,		"amswap.h",	"r,r,r,u0:0",			"amswap.h %1,%2,%3",	0,	0,	0 },
927   { 0x385c8000, 0xffff8000,	"amswap.h",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
928   { 0x0,	0x0,		"amadd.b",	"r,r,r,u0:0",			"amadd.b %1,%2,%3",	0,	0,	0 },
929   { 0x385d0000, 0xffff8000,	"amadd.b",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
930   { 0x0,	0x0,		"amadd.h",	"r,r,r,u0:0",			"amadd.h %1,%2,%3",	0,	0,	0 },
931   { 0x385d8000, 0xffff8000,	"amadd.h",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
932   { 0x0,	0x0,		"amswap_db.b",	"r,r,r,u0:0",			"amswap_db.b %1,%2,%3",	0,	0,	0 },
933   { 0x385e0000, 0xffff8000,	"amswap_db.b",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
934   { 0x0,	0x0,		"amswap_db.h",	"r,r,r,u0:0",			"amswap_db.h %1,%2,%3",	0,	0,	0 },
935   { 0x385e8000, 0xffff8000,	"amswap_db.h",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
936   { 0x0,	0x0,		"amadd_db.b",	"r,r,r,u0:0",			"amadd_db.b %1,%2,%3",	0,	0,	0 },
937   { 0x385f0000, 0xffff8000,	"amadd_db.b",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
938   { 0x0,	0x0,		"amadd_db.h",	"r,r,r,u0:0",			"amadd_db.h %1,%2,%3",	0,	0,	0 },
939   { 0x385f8000, 0xffff8000,	"amadd_db.h",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
940   { 0x0,	0x0,		"amswap.w",	"r,r,r,u0:0",			"amswap.w %1,%2,%3",	0,	0,	0 },
941   { 0x38600000, 0xffff8000,	"amswap.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
942   { 0x0,	0x0,		"amswap.d",	"r,r,r,u0:0",			"amswap.d %1,%2,%3",	0,	0,	0 },
943   { 0x38608000, 0xffff8000,	"amswap.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
944   { 0x0,	0x0,		"amadd.w",	"r,r,r,u0:0",			"amadd.w %1,%2,%3",	0,	0,	0 },
945   { 0x38610000, 0xffff8000,	"amadd.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
946   { 0x0,	0x0,		"amadd.d",	"r,r,r,u0:0",			"amadd.d %1,%2,%3",	0,	0,	0 },
947   { 0x38618000, 0xffff8000,	"amadd.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
948   { 0x0,	0x0,		"amand.w",	"r,r,r,u0:0",			"amand.w %1,%2,%3",	0,	0,	0 },
949   { 0x38620000, 0xffff8000,	"amand.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
950   { 0x0,	0x0,		"amand.d",	"r,r,r,u0:0",			"amand.d %1,%2,%3",	0,	0,	0 },
951   { 0x38628000, 0xffff8000,	"amand.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
952   { 0x0,	0x0,		"amor.w",	"r,r,r,u0:0",			"amor.w %1,%2,%3",	0,	0,	0 },
953   { 0x38630000, 0xffff8000,	"amor.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
954   { 0x0,	0x0,		"amor.d",	"r,r,r,u0:0",			"amor.d %1,%2,%3",	0,	0,	0 },
955   { 0x38638000, 0xffff8000,	"amor.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
956   { 0x0,	0x0,		"amxor.w",	"r,r,r,u0:0",			"amxor.w %1,%2,%3",	0,	0,	0 },
957   { 0x38640000, 0xffff8000,	"amxor.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
958   { 0x0,	0x0,		"amxor.d",	"r,r,r,u0:0",			"amxor.d %1,%2,%3",	0,	0,	0 },
959   { 0x38648000, 0xffff8000,	"amxor.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
960   { 0x0,	0x0,		"ammax.w",	"r,r,r,u0:0",			"ammax.w %1,%2,%3",	0,	0,	0 },
961   { 0x38650000, 0xffff8000,	"ammax.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
962   { 0x0,	0x0,		"ammax.d",	"r,r,r,u0:0",			"ammax.d %1,%2,%3",	0,	0,	0 },
963   { 0x38658000, 0xffff8000,	"ammax.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
964   { 0x0,	0x0,		"ammin.w",	"r,r,r,u0:0",			"ammin.w %1,%2,%3",	0,	0,	0 },
965   { 0x38660000, 0xffff8000,	"ammin.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
966   { 0x0,	0x0,		"ammin.d",	"r,r,r,u0:0",			"ammin.d %1,%2,%3",	0,	0,	0 },
967   { 0x38668000, 0xffff8000,	"ammin.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
968   { 0x0,	0x0,		"ammax.wu",	"r,r,r,u0:0",			"ammax.wu %1,%2,%3",	0,	0,	0 },
969   { 0x38670000, 0xffff8000,	"ammax.wu",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
970   { 0x0,	0x0,		"ammax.du",	"r,r,r,u0:0",			"ammax.du %1,%2,%3",	0,	0,	0 },
971   { 0x38678000, 0xffff8000,	"ammax.du",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
972   { 0x0,	0x0,		"ammin.wu",	"r,r,r,u0:0",			"ammin.wu %1,%2,%3",	0,	0,	0 },
973   { 0x38680000, 0xffff8000,	"ammin.wu",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
974   { 0x0,	0x0,		"ammin.du",	"r,r,r,u0:0",			"ammin.du %1,%2,%3",	0,	0,	0 },
975   { 0x38688000, 0xffff8000,	"ammin.du",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
976   { 0x0,	0x0,		"amswap_db.w",	"r,r,r,u0:0",			"amswap_db.w %1,%2,%3",	0,	0,	0 },
977   { 0x38690000, 0xffff8000,	"amswap_db.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
978   { 0x0,	0x0,		"amswap_db.d",	"r,r,r,u0:0",			"amswap_db.d %1,%2,%3",	0,	0,	0 },
979   { 0x38698000, 0xffff8000,	"amswap_db.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
980   { 0x0,	0x0,		"amadd_db.w",	"r,r,r,u0:0",			"amadd_db.w %1,%2,%3",	0,	0,	0 },
981   { 0x386a0000, 0xffff8000,	"amadd_db.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
982   { 0x0,	0x0,		"amadd_db.d",	"r,r,r,u0:0",			"amadd_db.d %1,%2,%3",	0,	0,	0 },
983   { 0x386a8000, 0xffff8000,	"amadd_db.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
984   { 0x0,	0x0,		"amand_db.w",	"r,r,r,u0:0",			"amand_db.w %1,%2,%3",	0,	0,	0 },
985   { 0x386b0000, 0xffff8000,	"amand_db.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
986   { 0x0,	0x0,		"amand_db.d",	"r,r,r,u0:0",			"amand_db.d %1,%2,%3",	0,	0,	0 },
987   { 0x386b8000, 0xffff8000,	"amand_db.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
988   { 0x0,	0x0,		"amor_db.w",	"r,r,r,u0:0",			"amor_db.w %1,%2,%3",	0,	0,	0 },
989   { 0x386c0000, 0xffff8000,	"amor_db.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
990   { 0x0,	0x0,		"amor_db.d",	"r,r,r,u0:0",			"amor_db.d %1,%2,%3",	0,	0,	0 },
991   { 0x386c8000, 0xffff8000,	"amor_db.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
992   { 0x0,	0x0,		"amxor_db.w",	"r,r,r,u0:0",			"amxor_db.w %1,%2,%3",	0,	0,	0 },
993   { 0x386d0000, 0xffff8000,	"amxor_db.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
994   { 0x0,	0x0,		"amxor_db.d",	"r,r,r,u0:0",			"amxor_db.d %1,%2,%3",	0,	0,	0 },
995   { 0x386d8000, 0xffff8000,	"amxor_db.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
996   { 0x0,	0x0,		"ammax_db.w",	"r,r,r,u0:0",			"ammax_db.w %1,%2,%3",	0,	0,	0 },
997   { 0x386e0000, 0xffff8000,	"ammax_db.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
998   { 0x0,	0x0,		"ammax_db.d",	"r,r,r,u0:0",			"ammax_db.d %1,%2,%3",	0,	0,	0 },
999   { 0x386e8000, 0xffff8000,	"ammax_db.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
1000   { 0x0,	0x0,		"ammin_db.w",	"r,r,r,u0:0",			"ammin_db.w %1,%2,%3",	0,	0,	0 },
1001   { 0x386f0000, 0xffff8000,	"ammin_db.w",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
1002   { 0x0,	0x0,		"ammin_db.d",	"r,r,r,u0:0",			"ammin_db.d %1,%2,%3",	0,	0,	0 },
1003   { 0x386f8000, 0xffff8000,	"ammin_db.d",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
1004   { 0x0,	0x0,		"ammax_db.wu",	"r,r,r,u0:0",			"ammax_db.wu %1,%2,%3",	0,	0,	0 },
1005   { 0x38700000, 0xffff8000,	"ammax_db.wu",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
1006   { 0x0,	0x0,		"ammax_db.du",	"r,r,r,u0:0",			"ammax_db.du %1,%2,%3",	0,	0,	0 },
1007   { 0x38708000, 0xffff8000,	"ammax_db.du",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
1008   { 0x0,	0x0,		"ammin_db.wu",	"r,r,r,u0:0",			"ammin_db.wu %1,%2,%3",	0,	0,	0 },
1009   { 0x38710000, 0xffff8000,	"ammin_db.wu",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
1010   { 0x0,	0x0,		"ammin_db.du",	"r,r,r,u0:0",			"ammin_db.du %1,%2,%3",	0,	0,	0 },
1011   { 0x38718000, 0xffff8000,	"ammin_db.du",	"r0:5,r10:5,r5:5",		0,			0,	0,	0 },
1012   { 0x38720000, 0xffff8000,	"dbar",		"u0:15",			0,			0,	0,	0 },
1013   { 0x38728000, 0xffff8000,	"ibar",		"u0:15",			0,			0,	0,	0 },
1014   { 0x38780000, 0xffff8000,	"ldgt.b",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1015   { 0x38788000, 0xffff8000,	"ldgt.h",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1016   { 0x38790000, 0xffff8000,	"ldgt.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1017   { 0x38798000, 0xffff8000,	"ldgt.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1018   { 0x387a0000, 0xffff8000,	"ldle.b",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1019   { 0x387a8000, 0xffff8000,	"ldle.h",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1020   { 0x387b0000, 0xffff8000,	"ldle.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1021   { 0x387b8000, 0xffff8000,	"ldle.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1022   { 0x387c0000, 0xffff8000,	"stgt.b",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1023   { 0x387c8000, 0xffff8000,	"stgt.h",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1024   { 0x387d0000, 0xffff8000,	"stgt.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1025   { 0x387d8000, 0xffff8000,	"stgt.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1026   { 0x387e0000, 0xffff8000,	"stle.b",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1027   { 0x387e8000, 0xffff8000,	"stle.h",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1028   { 0x387f0000, 0xffff8000,	"stle.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1029   { 0x387f8000, 0xffff8000,	"stle.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
1030   { 0x2c000000, 0xffc00000,	"vld",		"v0:5,r5:5,so10:12",		0,			0,	0,	0 },
1031   { 0x2c400000, 0xffc00000,	"vst",		"v0:5,r5:5,so10:12",		0,			0,	0,	0 },
1032   { 0x2c800000, 0xffc00000,	"xvld",		"x0:5,r5:5,so10:12",		0,			0,	0,	0 },
1033   { 0x2cc00000, 0xffc00000,	"xvst",		"x0:5,r5:5,so10:12",		0,			0,	0,	0 },
1034   { 0x38400000, 0xffff8000,	"vldx",		"v0:5,r5:5,r10:5",		0,			0,	0,	0 },
1035   { 0x38440000, 0xffff8000,	"vstx",		"v0:5,r5:5,r10:5",		0,			0,	0,	0 },
1036   { 0x38480000, 0xffff8000,	"xvldx",	"x0:5,r5:5,r10:5",		0,			0,	0,	0 },
1037   { 0x384c0000, 0xffff8000,	"xvstx",	"x0:5,r5:5,r10:5",		0,			0,	0,	0 },
1038   { 0x30100000, 0xfff80000,	"vldrepl.d",	"v0:5,r5:5,so10:9<<3",		0,			0,	0,	0 },
1039   { 0x30200000, 0xfff00000,	"vldrepl.w",	"v0:5,r5:5,so10:10<<2",		0,			0,	0,	0 },
1040   { 0x30400000, 0xffe00000,	"vldrepl.h",	"v0:5,r5:5,so10:11<<1",		0,			0,	0,	0 },
1041   { 0x30800000, 0xffc00000,	"vldrepl.b",	"v0:5,r5:5,so10:12",		0,			0,	0,	0 },
1042   { 0x31100000, 0xfff80000,	"vstelm.d",	"v0:5,r5:5,so10:8<<3,u18:1",	0,			0,	0,	0 },
1043   { 0x31200000, 0xfff00000,	"vstelm.w",	"v0:5,r5:5,so10:8<<2,u18:2",	0,			0,	0,	0 },
1044   { 0x31400000, 0xffe00000,	"vstelm.h",	"v0:5,r5:5,so10:8<<1,u18:3",	0,			0,	0,	0 },
1045   { 0x31800000, 0xffc00000,	"vstelm.b",	"v0:5,r5:5,so10:8,u18:4",	0,			0,	0,	0 },
1046   { 0x32100000, 0xfff80000,	"xvldrepl.d",	"x0:5,r5:5,so10:9<<3",		0,			0,	0,	0 },
1047   { 0x32200000, 0xfff00000,	"xvldrepl.w",	"x0:5,r5:5,so10:10<<2",		0,			0,	0,	0 },
1048   { 0x32400000, 0xffe00000,	"xvldrepl.h",	"x0:5,r5:5,so10:11<<1",		0,			0,	0,	0 },
1049   { 0x32800000, 0xffc00000,	"xvldrepl.b",	"x0:5,r5:5,so10:12",		0,			0,	0,	0 },
1050   { 0x33100000, 0xfff00000,	"xvstelm.d",	"x0:5,r5:5,so10:8<<3,u18:2",	0,			0,	0,	0 },
1051   { 0x33200000, 0xffe00000,	"xvstelm.w",	"x0:5,r5:5,so10:8<<2,u18:3",	0,			0,	0,	0 },
1052   { 0x33400000, 0xffc00000,	"xvstelm.h",	"x0:5,r5:5,so10:8<<1,u18:4",	0,			0,	0,	0 },
1053   { 0x33800000, 0xff800000,	"xvstelm.b",	"x0:5,r5:5,so10:8,u18:5",	0,			0,	0,	0 },
1054   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
1055 };
1056 
1057 static struct loongarch_opcode loongarch_single_float_load_store_opcodes[] =
1058 {
1059   /* match,	mask,		name,		format,				macro,	include,		exclude, pinfo.  */
1060   { 0x2b000000, 0xffc00000,	"fld.s",	"f0:5,r5:5,so10:12",		0,	0,			0,	0 },
1061   { 0x2b400000, 0xffc00000,	"fst.s",	"f0:5,r5:5,so10:12",		0,	0,			0,	0 },
1062   { 0x38300000, 0xffff8000,	"fldx.s",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1063   { 0x38380000, 0xffff8000,	"fstx.s",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1064   { 0x38740000, 0xffff8000,	"fldgt.s",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1065   { 0x38750000, 0xffff8000,	"fldle.s",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1066   { 0x38760000, 0xffff8000,	"fstgt.s",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1067   { 0x38770000, 0xffff8000,	"fstle.s",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1068   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
1069 };
1070 
1071 static struct loongarch_opcode loongarch_double_float_load_store_opcodes[] =
1072 {
1073   /* match,	mask,		name,		format,				macro,	include,		exclude, pinfo.  */
1074   { 0x2b800000, 0xffc00000,	"fld.d",	"f0:5,r5:5,so10:12",		0,	0,			0,	0 },
1075   { 0x2bc00000, 0xffc00000,	"fst.d",	"f0:5,r5:5,so10:12",		0,	0,			0,	0 },
1076   { 0x38340000, 0xffff8000,	"fldx.d",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1077   { 0x383c0000, 0xffff8000,	"fstx.d",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1078   { 0x38748000, 0xffff8000,	"fldgt.d",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1079   { 0x38758000, 0xffff8000,	"fldle.d",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1080   { 0x38768000, 0xffff8000,	"fstgt.d",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1081   { 0x38778000, 0xffff8000,	"fstle.d",	"f0:5,r5:5,r10:5",		0,	&LARCH_opts.ase_lp64,	0,	0 },
1082   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
1083 };
1084 
1085 static struct loongarch_opcode loongarch_float_jmp_opcodes[] =
1086 {
1087   { 0x0,	0x0,		"bceqz",	"c,la",				"bceqz %1,%%b21(%2)",		0, 0, 0 },
1088   { 0x48000000, 0xfc000300,	"bceqz",	"c5:3,sb0:5|10:16<<2",		0,				0, 0, 0 },
1089   { 0x0,	0x0,		"bcnez",	"c,la",				"bcnez %1,%%b21(%2)",		0, 0, 0 },
1090   { 0x48000100, 0xfc000300,	"bcnez",	"c5:3,sb0:5|10:16<<2",		0,				0, 0, 0 },
1091   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
1092 };
1093 
1094 static struct loongarch_opcode loongarch_jmp_opcodes[] =
1095 {
1096   /* match,	mask,		name,		format,				macro,			include, exclude, pinfo.  */
1097   { 0x0,	0x0,		"beqz",		"r,la",				"beqz %1,%%b21(%2)",		0, 0, 0 },
1098   { 0x40000000, 0xfc000000,	"beqz",		"r5:5,sb0:5|10:16<<2",		0,				0, 0, 0 },
1099   { 0x0,	0x0,		"bnez",		"r,la",				"bnez %1,%%b21(%2)",		0, 0, 0 },
1100   { 0x44000000, 0xfc000000,	"bnez",		"r5:5,sb0:5|10:16<<2",		0,				0, 0, 0 },
1101   { 0x4c000000, 0xfc000000,	"jirl",		"r0:5,r5:5,so10:16<<2",		0,				0, 0, 0 },
1102   { 0x0,	0x0,		"b",		"la",				"b %%b26(%1)",			0, 0, 0 },
1103   { 0x50000000, 0xfc000000,	"b",		"sb0:10|10:16<<2",		0,				0, 0, 0 },
1104   { 0x0,	0x0,		"bl",		"la",				"bl %%b26(%1)",			0, 0, 0 },
1105   { 0x54000000, 0xfc000000,	"bl",		"sb0:10|10:16<<2",		0,				0, 0, 0 },
1106   { 0x0,	0x0,		"beq",		"r,r,la",			"beq %1,%2,%%b16(%3)",		0, 0, 0 },
1107   { 0x58000000, 0xfc000000,	"beq",		"r5:5,r0:5,sb10:16<<2",		0,				0, 0, 0 },
1108   { 0x0,	0x0,		"bne",		"r,r,la",			"bne %1,%2,%%b16(%3)",		0, 0, 0 },
1109   { 0x5c000000, 0xfc000000,	"bne",		"r5:5,r0:5,sb10:16<<2",		0,				0, 0, 0 },
1110   { 0x0,	0x0,		"blt",		"r,r,la",			"blt %1,%2,%%b16(%3)",		0, 0, 0 },
1111   { 0x60000000, 0xfc000000,	"blt",		"r5:5,r0:5,sb10:16<<2",		0,				0, 0, 0 },
1112   { 0x0,	0x0,		"bge",		"r,r,la",			"bge %1,%2,%%b16(%3)",		0, 0, 0 },
1113   { 0x64000000, 0xfc000000,	"bge",		"r5:5,r0:5,sb10:16<<2",		0,				0, 0, 0 },
1114   { 0x0,	0x0,		"bltu",		"r,r,la",			"bltu %1,%2,%%b16(%3)",		0, 0, 0 },
1115   { 0x68000000, 0xfc000000,	"bltu",		"r5:5,r0:5,sb10:16<<2",		0,				0, 0, 0 },
1116   { 0x0,	0x0,		"bgeu",		"r,r,la",			"bgeu %1,%2,%%b16(%3)",		0, 0, 0 },
1117   { 0x6c000000, 0xfc000000,	"bgeu",		"r5:5,r0:5,sb10:16<<2",		0,				0, 0, 0 },
1118   /* Jumps implemented with macros.  */
1119   { 0x0,	0x0,		"bgt",		"r,r,la",			"blt %2,%1,%%b16(%3)",		0, 0, 0 },
1120   { 0x0,	0x0,		"bltz",		"r,la",				"blt %1,$r0,%%b16(%2)",		0, 0, 0 },
1121   { 0x0,	0x0,		"bgtz",		"r,la",				"blt $r0,%1,%%b16(%2)",		0, 0, 0 },
1122   { 0x0,	0x0,		"ble",		"r,r,la",			"bge %2,%1,%%b16(%3)",		0, 0, 0 },
1123   { 0x0,	0x0,		"bgez",		"r,la",				"bge %1,$r0,%%b16(%2)",		0, 0, 0 },
1124   { 0x0,	0x0,		"blez",		"r,la",				"bge $r0,%1,%%b16(%2)",		0, 0, 0 },
1125   { 0x0,	0x0,		"bgtu",		"r,r,la",			"bltu %2,%1,%%b16(%3)",		0, 0, 0 },
1126   { 0x0,	0x0,		"bleu",		"r,r,la",			"bgeu %2,%1,%%b16(%3)",		0, 0, 0 },
1127   { 0x0,	0x0,		"jr",		"r",				"jirl $r0,%1,0",		0, 0, 0 },
1128   { 0x0,	0x0,		"ret",		"",				"jirl $r0,$r1,0",		0, 0, 0 },
1129   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
1130 };
1131 
1132 static struct loongarch_opcode loongarch_lsx_opcodes[] =
1133 {
1134 /* match,	mask,	    name,		format,			macro, include, exclude, pinfo.	*/
1135   { 0x70000000, 0xffff8000, "vseq.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1136   { 0x70008000, 0xffff8000, "vseq.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1137   { 0x70010000, 0xffff8000, "vseq.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1138   { 0x70018000, 0xffff8000, "vseq.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1139   { 0x70020000, 0xffff8000, "vsle.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1140   { 0x70028000, 0xffff8000, "vsle.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1141   { 0x70030000, 0xffff8000, "vsle.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1142   { 0x70038000, 0xffff8000, "vsle.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1143   { 0x70040000, 0xffff8000, "vsle.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1144   { 0x70048000, 0xffff8000, "vsle.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1145   { 0x70050000, 0xffff8000, "vsle.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1146   { 0x70058000, 0xffff8000, "vsle.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1147   { 0x70060000, 0xffff8000, "vslt.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1148   { 0x70068000, 0xffff8000, "vslt.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1149   { 0x70070000, 0xffff8000, "vslt.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1150   { 0x70078000, 0xffff8000, "vslt.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1151   { 0x70080000, 0xffff8000, "vslt.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1152   { 0x70088000, 0xffff8000, "vslt.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1153   { 0x70090000, 0xffff8000, "vslt.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1154   { 0x70098000, 0xffff8000, "vslt.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1155   { 0x700a0000, 0xffff8000, "vadd.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1156   { 0x700a8000, 0xffff8000, "vadd.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1157   { 0x700b0000, 0xffff8000, "vadd.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1158   { 0x700b8000, 0xffff8000, "vadd.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1159   { 0x700c0000, 0xffff8000, "vsub.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1160   { 0x700c8000, 0xffff8000, "vsub.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1161   { 0x700d0000, 0xffff8000, "vsub.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1162   { 0x700d8000, 0xffff8000, "vsub.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1163   { 0x70460000, 0xffff8000, "vsadd.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1164   { 0x70468000, 0xffff8000, "vsadd.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1165   { 0x70470000, 0xffff8000, "vsadd.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1166   { 0x70478000, 0xffff8000, "vsadd.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1167   { 0x70480000, 0xffff8000, "vssub.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1168   { 0x70488000, 0xffff8000, "vssub.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1169   { 0x70490000, 0xffff8000, "vssub.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1170   { 0x70498000, 0xffff8000, "vssub.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1171   { 0x704a0000, 0xffff8000, "vsadd.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1172   { 0x704a8000, 0xffff8000, "vsadd.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1173   { 0x704b0000, 0xffff8000, "vsadd.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1174   { 0x704b8000, 0xffff8000, "vsadd.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1175   { 0x704c0000, 0xffff8000, "vssub.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1176   { 0x704c8000, 0xffff8000, "vssub.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1177   { 0x704d0000, 0xffff8000, "vssub.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1178   { 0x704d8000, 0xffff8000, "vssub.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1179   { 0x70540000, 0xffff8000, "vhaddw.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1180   { 0x70548000, 0xffff8000, "vhaddw.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1181   { 0x70550000, 0xffff8000, "vhaddw.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1182   { 0x70558000, 0xffff8000, "vhaddw.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1183   { 0x70560000, 0xffff8000, "vhsubw.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1184   { 0x70568000, 0xffff8000, "vhsubw.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1185   { 0x70570000, 0xffff8000, "vhsubw.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1186   { 0x70578000, 0xffff8000, "vhsubw.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1187   { 0x70580000, 0xffff8000, "vhaddw.hu.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1188   { 0x70588000, 0xffff8000, "vhaddw.wu.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1189   { 0x70590000, 0xffff8000, "vhaddw.du.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1190   { 0x70598000, 0xffff8000, "vhaddw.qu.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1191   { 0x705a0000, 0xffff8000, "vhsubw.hu.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1192   { 0x705a8000, 0xffff8000, "vhsubw.wu.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1193   { 0x705b0000, 0xffff8000, "vhsubw.du.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1194   { 0x705b8000, 0xffff8000, "vhsubw.qu.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1195   { 0x705c0000, 0xffff8000, "vadda.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1196   { 0x705c8000, 0xffff8000, "vadda.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1197   { 0x705d0000, 0xffff8000, "vadda.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1198   { 0x705d8000, 0xffff8000, "vadda.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1199   { 0x70600000, 0xffff8000, "vabsd.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1200   { 0x70608000, 0xffff8000, "vabsd.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1201   { 0x70610000, 0xffff8000, "vabsd.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1202   { 0x70618000, 0xffff8000, "vabsd.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1203   { 0x70620000, 0xffff8000, "vabsd.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1204   { 0x70628000, 0xffff8000, "vabsd.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1205   { 0x70630000, 0xffff8000, "vabsd.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1206   { 0x70638000, 0xffff8000, "vabsd.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1207   { 0x70640000, 0xffff8000, "vavg.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1208   { 0x70648000, 0xffff8000, "vavg.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1209   { 0x70650000, 0xffff8000, "vavg.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1210   { 0x70658000, 0xffff8000, "vavg.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1211   { 0x70660000, 0xffff8000, "vavg.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1212   { 0x70668000, 0xffff8000, "vavg.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1213   { 0x70670000, 0xffff8000, "vavg.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1214   { 0x70678000, 0xffff8000, "vavg.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1215   { 0x70680000, 0xffff8000, "vavgr.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1216   { 0x70688000, 0xffff8000, "vavgr.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1217   { 0x70690000, 0xffff8000, "vavgr.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1218   { 0x70698000, 0xffff8000, "vavgr.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1219   { 0x706a0000, 0xffff8000, "vavgr.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1220   { 0x706a8000, 0xffff8000, "vavgr.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1221   { 0x706b0000, 0xffff8000, "vavgr.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1222   { 0x706b8000, 0xffff8000, "vavgr.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1223   { 0x70700000, 0xffff8000, "vmax.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1224   { 0x70708000, 0xffff8000, "vmax.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1225   { 0x70710000, 0xffff8000, "vmax.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1226   { 0x70718000, 0xffff8000, "vmax.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1227   { 0x70720000, 0xffff8000, "vmin.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1228   { 0x70728000, 0xffff8000, "vmin.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1229   { 0x70730000, 0xffff8000, "vmin.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1230   { 0x70738000, 0xffff8000, "vmin.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1231   { 0x70740000, 0xffff8000, "vmax.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1232   { 0x70748000, 0xffff8000, "vmax.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1233   { 0x70750000, 0xffff8000, "vmax.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1234   { 0x70758000, 0xffff8000, "vmax.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1235   { 0x70760000, 0xffff8000, "vmin.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1236   { 0x70768000, 0xffff8000, "vmin.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1237   { 0x70770000, 0xffff8000, "vmin.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1238   { 0x70778000, 0xffff8000, "vmin.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1239   { 0x70840000, 0xffff8000, "vmul.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1240   { 0x70848000, 0xffff8000, "vmul.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1241   { 0x70850000, 0xffff8000, "vmul.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1242   { 0x70858000, 0xffff8000, "vmul.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1243   { 0x70860000, 0xffff8000, "vmuh.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1244   { 0x70868000, 0xffff8000, "vmuh.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1245   { 0x70870000, 0xffff8000, "vmuh.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1246   { 0x70878000, 0xffff8000, "vmuh.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1247   { 0x70880000, 0xffff8000, "vmuh.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1248   { 0x70888000, 0xffff8000, "vmuh.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1249   { 0x70890000, 0xffff8000, "vmuh.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1250   { 0x70898000, 0xffff8000, "vmuh.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1251   { 0x70a80000, 0xffff8000, "vmadd.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1252   { 0x70a88000, 0xffff8000, "vmadd.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1253   { 0x70a90000, 0xffff8000, "vmadd.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1254   { 0x70a98000, 0xffff8000, "vmadd.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1255   { 0x70aa0000, 0xffff8000, "vmsub.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1256   { 0x70aa8000, 0xffff8000, "vmsub.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1257   { 0x70ab0000, 0xffff8000, "vmsub.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1258   { 0x70ab8000, 0xffff8000, "vmsub.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1259   { 0x70e00000, 0xffff8000, "vdiv.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1260   { 0x70e08000, 0xffff8000, "vdiv.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1261   { 0x70e10000, 0xffff8000, "vdiv.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1262   { 0x70e18000, 0xffff8000, "vdiv.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1263   { 0x70e20000, 0xffff8000, "vmod.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1264   { 0x70e28000, 0xffff8000, "vmod.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1265   { 0x70e30000, 0xffff8000, "vmod.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1266   { 0x70e38000, 0xffff8000, "vmod.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1267   { 0x70e40000, 0xffff8000, "vdiv.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1268   { 0x70e48000, 0xffff8000, "vdiv.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1269   { 0x70e50000, 0xffff8000, "vdiv.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1270   { 0x70e58000, 0xffff8000, "vdiv.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1271   { 0x70e60000, 0xffff8000, "vmod.bu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1272   { 0x70e68000, 0xffff8000, "vmod.hu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1273   { 0x70e70000, 0xffff8000, "vmod.wu",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1274   { 0x70e78000, 0xffff8000, "vmod.du",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1275   { 0x70e80000, 0xffff8000, "vsll.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1276   { 0x70e88000, 0xffff8000, "vsll.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1277   { 0x70e90000, 0xffff8000, "vsll.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1278   { 0x70e98000, 0xffff8000, "vsll.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1279   { 0x70ea0000, 0xffff8000, "vsrl.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1280   { 0x70ea8000, 0xffff8000, "vsrl.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1281   { 0x70eb0000, 0xffff8000, "vsrl.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1282   { 0x70eb8000, 0xffff8000, "vsrl.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1283   { 0x70ec0000, 0xffff8000, "vsra.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1284   { 0x70ec8000, 0xffff8000, "vsra.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1285   { 0x70ed0000, 0xffff8000, "vsra.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1286   { 0x70ed8000, 0xffff8000, "vsra.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1287   { 0x70ee0000, 0xffff8000, "vrotr.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1288   { 0x70ee8000, 0xffff8000, "vrotr.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1289   { 0x70ef0000, 0xffff8000, "vrotr.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1290   { 0x70ef8000, 0xffff8000, "vrotr.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1291   { 0x70f00000, 0xffff8000, "vsrlr.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1292   { 0x70f08000, 0xffff8000, "vsrlr.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1293   { 0x70f10000, 0xffff8000, "vsrlr.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1294   { 0x70f18000, 0xffff8000, "vsrlr.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1295   { 0x70f20000, 0xffff8000, "vsrar.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1296   { 0x70f28000, 0xffff8000, "vsrar.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1297   { 0x70f30000, 0xffff8000, "vsrar.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1298   { 0x70f38000, 0xffff8000, "vsrar.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1299   { 0x70f48000, 0xffff8000, "vsrln.b.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1300   { 0x70f50000, 0xffff8000, "vsrln.h.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1301   { 0x70f58000, 0xffff8000, "vsrln.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1302   { 0x70f68000, 0xffff8000, "vsran.b.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1303   { 0x70f70000, 0xffff8000, "vsran.h.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1304   { 0x70f78000, 0xffff8000, "vsran.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1305   { 0x70f88000, 0xffff8000, "vsrlrn.b.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1306   { 0x70f90000, 0xffff8000, "vsrlrn.h.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1307   { 0x70f98000, 0xffff8000, "vsrlrn.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1308   { 0x70fa8000, 0xffff8000, "vsrarn.b.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1309   { 0x70fb0000, 0xffff8000, "vsrarn.h.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1310   { 0x70fb8000, 0xffff8000, "vsrarn.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1311   { 0x70fc8000, 0xffff8000, "vssrln.b.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1312   { 0x70fd0000, 0xffff8000, "vssrln.h.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1313   { 0x70fd8000, 0xffff8000, "vssrln.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1314   { 0x70fe8000, 0xffff8000, "vssran.b.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1315   { 0x70ff0000, 0xffff8000, "vssran.h.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1316   { 0x70ff8000, 0xffff8000, "vssran.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1317   { 0x71008000, 0xffff8000, "vssrlrn.b.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1318   { 0x71010000, 0xffff8000, "vssrlrn.h.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1319   { 0x71018000, 0xffff8000, "vssrlrn.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1320   { 0x71028000, 0xffff8000, "vssrarn.b.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1321   { 0x71030000, 0xffff8000, "vssrarn.h.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1322   { 0x71038000, 0xffff8000, "vssrarn.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1323   { 0x71048000, 0xffff8000, "vssrln.bu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1324   { 0x71050000, 0xffff8000, "vssrln.hu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1325   { 0x71058000, 0xffff8000, "vssrln.wu.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1326   { 0x71068000, 0xffff8000, "vssran.bu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1327   { 0x71070000, 0xffff8000, "vssran.hu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1328   { 0x71078000, 0xffff8000, "vssran.wu.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1329   { 0x71088000, 0xffff8000, "vssrlrn.bu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1330   { 0x71090000, 0xffff8000, "vssrlrn.hu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1331   { 0x71098000, 0xffff8000, "vssrlrn.wu.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1332   { 0x710a8000, 0xffff8000, "vssrarn.bu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1333   { 0x710b0000, 0xffff8000, "vssrarn.hu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1334   { 0x710b8000, 0xffff8000, "vssrarn.wu.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1335   { 0x710c0000, 0xffff8000, "vbitclr.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1336   { 0x710c8000, 0xffff8000, "vbitclr.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1337   { 0x710d0000, 0xffff8000, "vbitclr.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1338   { 0x710d8000, 0xffff8000, "vbitclr.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1339   { 0x710e0000, 0xffff8000, "vbitset.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1340   { 0x710e8000, 0xffff8000, "vbitset.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1341   { 0x710f0000, 0xffff8000, "vbitset.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1342   { 0x710f8000, 0xffff8000, "vbitset.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1343   { 0x71100000, 0xffff8000, "vbitrev.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1344   { 0x71108000, 0xffff8000, "vbitrev.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1345   { 0x71110000, 0xffff8000, "vbitrev.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1346   { 0x71118000, 0xffff8000, "vbitrev.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1347   { 0x71160000, 0xffff8000, "vpackev.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1348   { 0x71168000, 0xffff8000, "vpackev.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1349   { 0x71170000, 0xffff8000, "vpackev.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1350   { 0x71178000, 0xffff8000, "vpackev.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1351   { 0x71180000, 0xffff8000, "vpackod.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1352   { 0x71188000, 0xffff8000, "vpackod.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1353   { 0x71190000, 0xffff8000, "vpackod.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1354   { 0x71198000, 0xffff8000, "vpackod.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1355   { 0x711a0000, 0xffff8000, "vilvl.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1356   { 0x711a8000, 0xffff8000, "vilvl.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1357   { 0x711b0000, 0xffff8000, "vilvl.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1358   { 0x711b8000, 0xffff8000, "vilvl.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1359   { 0x711c0000, 0xffff8000, "vilvh.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1360   { 0x711c8000, 0xffff8000, "vilvh.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1361   { 0x711d0000, 0xffff8000, "vilvh.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1362   { 0x711d8000, 0xffff8000, "vilvh.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1363   { 0x711e0000, 0xffff8000, "vpickev.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1364   { 0x711e8000, 0xffff8000, "vpickev.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1365   { 0x711f0000, 0xffff8000, "vpickev.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1366   { 0x711f8000, 0xffff8000, "vpickev.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1367   { 0x71200000, 0xffff8000, "vpickod.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1368   { 0x71208000, 0xffff8000, "vpickod.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1369   { 0x71210000, 0xffff8000, "vpickod.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1370   { 0x71218000, 0xffff8000, "vpickod.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1371   { 0x71220000, 0xffff8000, "vreplve.b",	"v0:5,v5:5,r10:5",	0, 0, 0, 0},
1372   { 0x71228000, 0xffff8000, "vreplve.h",	"v0:5,v5:5,r10:5",	0, 0, 0, 0},
1373   { 0x71230000, 0xffff8000, "vreplve.w",	"v0:5,v5:5,r10:5",	0, 0, 0, 0},
1374   { 0x71238000, 0xffff8000, "vreplve.d",	"v0:5,v5:5,r10:5",	0, 0, 0, 0},
1375   { 0x71260000, 0xffff8000, "vand.v",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1376   { 0x71268000, 0xffff8000, "vor.v",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1377   { 0x71270000, 0xffff8000, "vxor.v",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1378   { 0x71278000, 0xffff8000, "vnor.v",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1379   { 0x71280000, 0xffff8000, "vandn.v",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1380   { 0x71288000, 0xffff8000, "vorn.v",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1381   { 0x712b0000, 0xffff8000, "vfrstp.b",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1382   { 0x712b8000, 0xffff8000, "vfrstp.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1383   { 0x712d0000, 0xffff8000, "vadd.q",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1384   { 0x712d8000, 0xffff8000, "vsub.q",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1385   { 0x712e0000, 0xffff8000, "vsigncov.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1386   { 0x712e8000, 0xffff8000, "vsigncov.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1387   { 0x712f0000, 0xffff8000, "vsigncov.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1388   { 0x712f8000, 0xffff8000, "vsigncov.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1389   { 0x71308000, 0xffff8000, "vfadd.s",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1390   { 0x71310000, 0xffff8000, "vfadd.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1391   { 0x71328000, 0xffff8000, "vfsub.s",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1392   { 0x71330000, 0xffff8000, "vfsub.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1393   { 0x71388000, 0xffff8000, "vfmul.s",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1394   { 0x71390000, 0xffff8000, "vfmul.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1395   { 0x713a8000, 0xffff8000, "vfdiv.s",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1396   { 0x713b0000, 0xffff8000, "vfdiv.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1397   { 0x713c8000, 0xffff8000, "vfmax.s",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1398   { 0x713d0000, 0xffff8000, "vfmax.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1399   { 0x713e8000, 0xffff8000, "vfmin.s",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1400   { 0x713f0000, 0xffff8000, "vfmin.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1401   { 0x71408000, 0xffff8000, "vfmaxa.s",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1402   { 0x71410000, 0xffff8000, "vfmaxa.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1403   { 0x71428000, 0xffff8000, "vfmina.s",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1404   { 0x71430000, 0xffff8000, "vfmina.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1405   { 0x71460000, 0xffff8000, "vfcvt.h.s",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1406   { 0x71468000, 0xffff8000, "vfcvt.s.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1407   { 0x71480000, 0xffff8000, "vffint.s.l",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1408   { 0x71498000, 0xffff8000, "vftint.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1409   { 0x714a0000, 0xffff8000, "vftintrm.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1410   { 0x714a8000, 0xffff8000, "vftintrp.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1411   { 0x714b0000, 0xffff8000, "vftintrz.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1412   { 0x714b8000, 0xffff8000, "vftintrne.w.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1413   { 0x717a8000, 0xffff8000, "vshuf.h",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1414   { 0x717b0000, 0xffff8000, "vshuf.w",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1415   { 0x717b8000, 0xffff8000, "vshuf.d",		"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1416   { 0x72800000, 0xffff8000, "vseqi.b",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1417   { 0x72808000, 0xffff8000, "vseqi.h",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1418   { 0x72810000, 0xffff8000, "vseqi.w",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1419   { 0x72818000, 0xffff8000, "vseqi.d",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1420   { 0x72820000, 0xffff8000, "vslei.b",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1421   { 0x72828000, 0xffff8000, "vslei.h",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1422   { 0x72830000, 0xffff8000, "vslei.w",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1423   { 0x72838000, 0xffff8000, "vslei.d",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1424   { 0x72840000, 0xffff8000, "vslei.bu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1425   { 0x72848000, 0xffff8000, "vslei.hu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1426   { 0x72850000, 0xffff8000, "vslei.wu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1427   { 0x72858000, 0xffff8000, "vslei.du",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1428   { 0x72860000, 0xffff8000, "vslti.b",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1429   { 0x72868000, 0xffff8000, "vslti.h",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1430   { 0x72870000, 0xffff8000, "vslti.w",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1431   { 0x72878000, 0xffff8000, "vslti.d",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1432   { 0x72880000, 0xffff8000, "vslti.bu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1433   { 0x72888000, 0xffff8000, "vslti.hu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1434   { 0x72890000, 0xffff8000, "vslti.wu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1435   { 0x72898000, 0xffff8000, "vslti.du",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1436   { 0x728a0000, 0xffff8000, "vaddi.bu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1437   { 0x728a8000, 0xffff8000, "vaddi.hu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1438   { 0x728b0000, 0xffff8000, "vaddi.wu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1439   { 0x728b8000, 0xffff8000, "vaddi.du",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1440   { 0x728c0000, 0xffff8000, "vsubi.bu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1441   { 0x728c8000, 0xffff8000, "vsubi.hu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1442   { 0x728d0000, 0xffff8000, "vsubi.wu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1443   { 0x728d8000, 0xffff8000, "vsubi.du",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1444   { 0x728e0000, 0xffff8000, "vbsll.v",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1445   { 0x728e8000, 0xffff8000, "vbsrl.v",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1446   { 0x72900000, 0xffff8000, "vmaxi.b",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1447   { 0x72908000, 0xffff8000, "vmaxi.h",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1448   { 0x72910000, 0xffff8000, "vmaxi.w",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1449   { 0x72918000, 0xffff8000, "vmaxi.d",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1450   { 0x72920000, 0xffff8000, "vmini.b",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1451   { 0x72928000, 0xffff8000, "vmini.h",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1452   { 0x72930000, 0xffff8000, "vmini.w",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1453   { 0x72938000, 0xffff8000, "vmini.d",		"v0:5,v5:5,s10:5",	0, 0, 0, 0},
1454   { 0x72940000, 0xffff8000, "vmaxi.bu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1455   { 0x72948000, 0xffff8000, "vmaxi.hu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1456   { 0x72950000, 0xffff8000, "vmaxi.wu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1457   { 0x72958000, 0xffff8000, "vmaxi.du",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1458   { 0x72960000, 0xffff8000, "vmini.bu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1459   { 0x72968000, 0xffff8000, "vmini.hu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1460   { 0x72970000, 0xffff8000, "vmini.wu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1461   { 0x72978000, 0xffff8000, "vmini.du",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1462   { 0x729a0000, 0xffff8000, "vfrstpi.b",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1463   { 0x729a8000, 0xffff8000, "vfrstpi.h",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1464   { 0x729c0000, 0xfffffc00, "vclo.b",		"v0:5,v5:5",		0, 0, 0, 0},
1465   { 0x729c0400, 0xfffffc00, "vclo.h",		"v0:5,v5:5",		0, 0, 0, 0},
1466   { 0x729c0800, 0xfffffc00, "vclo.w",		"v0:5,v5:5",		0, 0, 0, 0},
1467   { 0x729c0c00, 0xfffffc00, "vclo.d",		"v0:5,v5:5",		0, 0, 0, 0},
1468   { 0x729c1000, 0xfffffc00, "vclz.b",		"v0:5,v5:5",		0, 0, 0, 0},
1469   { 0x729c1400, 0xfffffc00, "vclz.h",		"v0:5,v5:5",		0, 0, 0, 0},
1470   { 0x729c1800, 0xfffffc00, "vclz.w",		"v0:5,v5:5",		0, 0, 0, 0},
1471   { 0x729c1c00, 0xfffffc00, "vclz.d",		"v0:5,v5:5",		0, 0, 0, 0},
1472   { 0x729c2000, 0xfffffc00, "vpcnt.b",		"v0:5,v5:5",		0, 0, 0, 0},
1473   { 0x729c2400, 0xfffffc00, "vpcnt.h",		"v0:5,v5:5",		0, 0, 0, 0},
1474   { 0x729c2800, 0xfffffc00, "vpcnt.w",		"v0:5,v5:5",		0, 0, 0, 0},
1475   { 0x729c2c00, 0xfffffc00, "vpcnt.d",		"v0:5,v5:5",		0, 0, 0, 0},
1476   { 0x729c3000, 0xfffffc00, "vneg.b",		"v0:5,v5:5",		0, 0, 0, 0},
1477   { 0x729c3400, 0xfffffc00, "vneg.h",		"v0:5,v5:5",		0, 0, 0, 0},
1478   { 0x729c3800, 0xfffffc00, "vneg.w",		"v0:5,v5:5",		0, 0, 0, 0},
1479   { 0x729c3c00, 0xfffffc00, "vneg.d",		"v0:5,v5:5",		0, 0, 0, 0},
1480   { 0x729c4000, 0xfffffc00, "vmskltz.b",	"v0:5,v5:5",		0, 0, 0, 0},
1481   { 0x729c4400, 0xfffffc00, "vmskltz.h",	"v0:5,v5:5",		0, 0, 0, 0},
1482   { 0x729c4800, 0xfffffc00, "vmskltz.w",	"v0:5,v5:5",		0, 0, 0, 0},
1483   { 0x729c4c00, 0xfffffc00, "vmskltz.d",	"v0:5,v5:5",		0, 0, 0, 0},
1484   { 0x729c5000, 0xfffffc00, "vmskgez.b",	"v0:5,v5:5",		0, 0, 0, 0},
1485   { 0x729c6000, 0xfffffc00, "vmsknz.b",		"v0:5,v5:5",		0, 0, 0, 0},
1486   { 0x729c9800, 0xfffffc18, "vseteqz.v",	"c0:3,v5:5",		0, 0, 0, 0},
1487   { 0x729c9c00, 0xfffffc18, "vsetnez.v",	"c0:3,v5:5",		0, 0, 0, 0},
1488   { 0x729ca000, 0xfffffc18, "vsetanyeqz.b",	"c0:3,v5:5",		0, 0, 0, 0},
1489   { 0x729ca400, 0xfffffc18, "vsetanyeqz.h",	"c0:3,v5:5",		0, 0, 0, 0},
1490   { 0x729ca800, 0xfffffc18, "vsetanyeqz.w",	"c0:3,v5:5",		0, 0, 0, 0},
1491   { 0x729cac00, 0xfffffc18, "vsetanyeqz.d",	"c0:3,v5:5",		0, 0, 0, 0},
1492   { 0x729cb000, 0xfffffc18, "vsetallnez.b",	"c0:3,v5:5",		0, 0, 0, 0},
1493   { 0x729cb400, 0xfffffc18, "vsetallnez.h",	"c0:3,v5:5",		0, 0, 0, 0},
1494   { 0x729cb800, 0xfffffc18, "vsetallnez.w",	"c0:3,v5:5",		0, 0, 0, 0},
1495   { 0x729cbc00, 0xfffffc18, "vsetallnez.d",	"c0:3,v5:5",		0, 0, 0, 0},
1496   { 0x729cc400, 0xfffffc00, "vflogb.s",		"v0:5,v5:5",		0, 0, 0, 0},
1497   { 0x729cc800, 0xfffffc00, "vflogb.d",		"v0:5,v5:5",		0, 0, 0, 0},
1498   { 0x729cd400, 0xfffffc00, "vfclass.s",	"v0:5,v5:5",		0, 0, 0, 0},
1499   { 0x729cd800, 0xfffffc00, "vfclass.d",	"v0:5,v5:5",		0, 0, 0, 0},
1500   { 0x729ce400, 0xfffffc00, "vfsqrt.s",		"v0:5,v5:5",		0, 0, 0, 0},
1501   { 0x729ce800, 0xfffffc00, "vfsqrt.d",		"v0:5,v5:5",		0, 0, 0, 0},
1502   { 0x729cf400, 0xfffffc00, "vfrecip.s",	"v0:5,v5:5",		0, 0, 0, 0},
1503   { 0x729cf800, 0xfffffc00, "vfrecip.d",	"v0:5,v5:5",		0, 0, 0, 0},
1504   { 0x729d0400, 0xfffffc00, "vfrsqrt.s",	"v0:5,v5:5",		0, 0, 0, 0},
1505   { 0x729d0800, 0xfffffc00, "vfrsqrt.d",	"v0:5,v5:5",		0, 0, 0, 0},
1506   { 0x729d1400, 0xfffffc00, "vfrecipe.s",	"v0:5,v5:5",		0, 0, 0, 0},
1507   { 0x729d1800, 0xfffffc00, "vfrecipe.d",	"v0:5,v5:5",		0, 0, 0, 0},
1508   { 0x729d2400, 0xfffffc00, "vfrsqrte.s",	"v0:5,v5:5",		0, 0, 0, 0},
1509   { 0x729d2800, 0xfffffc00, "vfrsqrte.d",	"v0:5,v5:5",		0, 0, 0, 0},
1510   { 0x729d3400, 0xfffffc00, "vfrint.s",		"v0:5,v5:5",		0, 0, 0, 0},
1511   { 0x729d3800, 0xfffffc00, "vfrint.d",		"v0:5,v5:5",		0, 0, 0, 0},
1512   { 0x729d4400, 0xfffffc00, "vfrintrm.s",	"v0:5,v5:5",		0, 0, 0, 0},
1513   { 0x729d4800, 0xfffffc00, "vfrintrm.d",	"v0:5,v5:5",		0, 0, 0, 0},
1514   { 0x729d5400, 0xfffffc00, "vfrintrp.s",	"v0:5,v5:5",		0, 0, 0, 0},
1515   { 0x729d5800, 0xfffffc00, "vfrintrp.d",	"v0:5,v5:5",		0, 0, 0, 0},
1516   { 0x729d6400, 0xfffffc00, "vfrintrz.s",	"v0:5,v5:5",		0, 0, 0, 0},
1517   { 0x729d6800, 0xfffffc00, "vfrintrz.d",	"v0:5,v5:5",		0, 0, 0, 0},
1518   { 0x729d7400, 0xfffffc00, "vfrintrne.s",	"v0:5,v5:5",		0, 0, 0, 0},
1519   { 0x729d7800, 0xfffffc00, "vfrintrne.d",	"v0:5,v5:5",		0, 0, 0, 0},
1520   { 0x729de800, 0xfffffc00, "vfcvtl.s.h",	"v0:5,v5:5",		0, 0, 0, 0},
1521   { 0x729dec00, 0xfffffc00, "vfcvth.s.h",	"v0:5,v5:5",		0, 0, 0, 0},
1522   { 0x729df000, 0xfffffc00, "vfcvtl.d.s",	"v0:5,v5:5",		0, 0, 0, 0},
1523   { 0x729df400, 0xfffffc00, "vfcvth.d.s",	"v0:5,v5:5",		0, 0, 0, 0},
1524   { 0x729e0000, 0xfffffc00, "vffint.s.w",	"v0:5,v5:5",		0, 0, 0, 0},
1525   { 0x729e0400, 0xfffffc00, "vffint.s.wu",	"v0:5,v5:5",		0, 0, 0, 0},
1526   { 0x729e0800, 0xfffffc00, "vffint.d.l",	"v0:5,v5:5",		0, 0, 0, 0},
1527   { 0x729e0c00, 0xfffffc00, "vffint.d.lu",	"v0:5,v5:5",		0, 0, 0, 0},
1528   { 0x729e1000, 0xfffffc00, "vffintl.d.w",	"v0:5,v5:5",		0, 0, 0, 0},
1529   { 0x729e1400, 0xfffffc00, "vffinth.d.w",	"v0:5,v5:5",		0, 0, 0, 0},
1530   { 0x729e3000, 0xfffffc00, "vftint.w.s",	"v0:5,v5:5",		0, 0, 0, 0},
1531   { 0x729e3400, 0xfffffc00, "vftint.l.d",	"v0:5,v5:5",		0, 0, 0, 0},
1532   { 0x729e3800, 0xfffffc00, "vftintrm.w.s",	"v0:5,v5:5",		0, 0, 0, 0},
1533   { 0x729e3c00, 0xfffffc00, "vftintrm.l.d",	"v0:5,v5:5",		0, 0, 0, 0},
1534   { 0x729e4000, 0xfffffc00, "vftintrp.w.s",	"v0:5,v5:5",		0, 0, 0, 0},
1535   { 0x729e4400, 0xfffffc00, "vftintrp.l.d",	"v0:5,v5:5",		0, 0, 0, 0},
1536   { 0x729e4800, 0xfffffc00, "vftintrz.w.s",	"v0:5,v5:5",		0, 0, 0, 0},
1537   { 0x729e4c00, 0xfffffc00, "vftintrz.l.d",	"v0:5,v5:5",		0, 0, 0, 0},
1538   { 0x729e5000, 0xfffffc00, "vftintrne.w.s",	"v0:5,v5:5",		0, 0, 0, 0},
1539   { 0x729e5400, 0xfffffc00, "vftintrne.l.d",	"v0:5,v5:5",		0, 0, 0, 0},
1540   { 0x729e5800, 0xfffffc00, "vftint.wu.s",	"v0:5,v5:5",		0, 0, 0, 0},
1541   { 0x729e5c00, 0xfffffc00, "vftint.lu.d",	"v0:5,v5:5",		0, 0, 0, 0},
1542   { 0x729e7000, 0xfffffc00, "vftintrz.wu.s",	"v0:5,v5:5",		0, 0, 0, 0},
1543   { 0x729e7400, 0xfffffc00, "vftintrz.lu.d",	"v0:5,v5:5",		0, 0, 0, 0},
1544   { 0x729e8000, 0xfffffc00, "vftintl.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1545   { 0x729e8400, 0xfffffc00, "vftinth.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1546   { 0x729e8800, 0xfffffc00, "vftintrml.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1547   { 0x729e8c00, 0xfffffc00, "vftintrmh.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1548   { 0x729e9000, 0xfffffc00, "vftintrpl.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1549   { 0x729e9400, 0xfffffc00, "vftintrph.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1550   { 0x729e9800, 0xfffffc00, "vftintrzl.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1551   { 0x729e9c00, 0xfffffc00, "vftintrzh.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1552   { 0x729ea000, 0xfffffc00, "vftintrnel.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1553   { 0x729ea400, 0xfffffc00, "vftintrneh.l.s",	"v0:5,v5:5",		0, 0, 0, 0},
1554   { 0x729ee000, 0xfffffc00, "vexth.h.b",	"v0:5,v5:5",		0, 0, 0, 0},
1555   { 0x729ee400, 0xfffffc00, "vexth.w.h",	"v0:5,v5:5",		0, 0, 0, 0},
1556   { 0x729ee800, 0xfffffc00, "vexth.d.w",	"v0:5,v5:5",		0, 0, 0, 0},
1557   { 0x729eec00, 0xfffffc00, "vexth.q.d",	"v0:5,v5:5",		0, 0, 0, 0},
1558   { 0x729ef000, 0xfffffc00, "vexth.hu.bu",	"v0:5,v5:5",		0, 0, 0, 0},
1559   { 0x729ef400, 0xfffffc00, "vexth.wu.hu",	"v0:5,v5:5",		0, 0, 0, 0},
1560   { 0x729ef800, 0xfffffc00, "vexth.du.wu",	"v0:5,v5:5",		0, 0, 0, 0},
1561   { 0x729efc00, 0xfffffc00, "vexth.qu.du",	"v0:5,v5:5",		0, 0, 0, 0},
1562   { 0x729f0000, 0xfffffc00, "vreplgr2vr.b",	"v0:5,r5:5",		0, 0, 0, 0},
1563   { 0x729f0400, 0xfffffc00, "vreplgr2vr.h",	"v0:5,r5:5",		0, 0, 0, 0},
1564   { 0x729f0800, 0xfffffc00, "vreplgr2vr.w",	"v0:5,r5:5",		0, 0, 0, 0},
1565   { 0x729f0c00, 0xfffffc00, "vreplgr2vr.d",	"v0:5,r5:5",		0, 0, 0, 0},
1566   { 0x72a02000, 0xffffe000, "vrotri.b",		"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1567   { 0x72a04000, 0xffffc000, "vrotri.h",		"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1568   { 0x72a08000, 0xffff8000, "vrotri.w",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1569   { 0x72a10000, 0xffff0000, "vrotri.d",		"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1570   { 0x72a42000, 0xffffe000, "vsrlri.b",		"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1571   { 0x72a44000, 0xffffc000, "vsrlri.h",		"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1572   { 0x72a48000, 0xffff8000, "vsrlri.w",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1573   { 0x72a50000, 0xffff0000, "vsrlri.d",		"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1574   { 0x72a82000, 0xffffe000, "vsrari.b",		"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1575   { 0x72a84000, 0xffffc000, "vsrari.h",		"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1576   { 0x72a88000, 0xffff8000, "vsrari.w",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1577   { 0x72a90000, 0xffff0000, "vsrari.d",		"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1578   { 0x72eb8000, 0xffffc000, "vinsgr2vr.b",	"v0:5,r5:5,u10:4",	0, 0, 0, 0},
1579   { 0x72ebc000, 0xffffe000, "vinsgr2vr.h",	"v0:5,r5:5,u10:3",	0, 0, 0, 0},
1580   { 0x72ebe000, 0xfffff000, "vinsgr2vr.w",	"v0:5,r5:5,u10:2",	0, 0, 0, 0},
1581   { 0x72ebf000, 0xfffff800, "vinsgr2vr.d",	"v0:5,r5:5,u10:1",	0, 0, 0, 0},
1582   { 0x72ef8000, 0xffffc000, "vpickve2gr.b",	"r0:5,v5:5,u10:4",	0, 0, 0, 0},
1583   { 0x72efc000, 0xffffe000, "vpickve2gr.h",	"r0:5,v5:5,u10:3",	0, 0, 0, 0},
1584   { 0x72efe000, 0xfffff000, "vpickve2gr.w",	"r0:5,v5:5,u10:2",	0, 0, 0, 0},
1585   { 0x72eff000, 0xfffff800, "vpickve2gr.d",	"r0:5,v5:5,u10:1",	0, 0, 0, 0},
1586   { 0x72f38000, 0xffffc000, "vpickve2gr.bu",	"r0:5,v5:5,u10:4",	0, 0, 0, 0},
1587   { 0x72f3c000, 0xffffe000, "vpickve2gr.hu",	"r0:5,v5:5,u10:3",	0, 0, 0, 0},
1588   { 0x72f3e000, 0xfffff000, "vpickve2gr.wu",	"r0:5,v5:5,u10:2",	0, 0, 0, 0},
1589   { 0x72f3f000, 0xfffff800, "vpickve2gr.du",	"r0:5,v5:5,u10:1",	0, 0, 0, 0},
1590   { 0x72f78000, 0xffffc000, "vreplvei.b",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1591   { 0x72f7c000, 0xffffe000, "vreplvei.h",	"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1592   { 0x72f7e000, 0xfffff000, "vreplvei.w",	"v0:5,v5:5,u10:2",	0, 0, 0, 0},
1593   { 0x72f7f000, 0xfffff800, "vreplvei.d",	"v0:5,v5:5,u10:1",	0, 0, 0, 0},
1594   { 0x73082000, 0xffffe000, "vsllwil.h.b",	"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1595   { 0x73084000, 0xffffc000, "vsllwil.w.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1596   { 0x73088000, 0xffff8000, "vsllwil.d.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1597   { 0x73090000, 0xfffffc00, "vextl.q.d",	"v0:5,v5:5",		0, 0, 0, 0},
1598   { 0x730c2000, 0xffffe000, "vsllwil.hu.bu",	"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1599   { 0x730c4000, 0xffffc000, "vsllwil.wu.hu",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1600   { 0x730c8000, 0xffff8000, "vsllwil.du.wu",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1601   { 0x730d0000, 0xfffffc00, "vextl.qu.du",	"v0:5,v5:5",		0, 0, 0, 0},
1602   { 0x73102000, 0xffffe000, "vbitclri.b",	"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1603   { 0x73104000, 0xffffc000, "vbitclri.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1604   { 0x73108000, 0xffff8000, "vbitclri.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1605   { 0x73110000, 0xffff0000, "vbitclri.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1606   { 0x73142000, 0xffffe000, "vbitseti.b",	"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1607   { 0x73144000, 0xffffc000, "vbitseti.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1608   { 0x73148000, 0xffff8000, "vbitseti.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1609   { 0x73150000, 0xffff0000, "vbitseti.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1610   { 0x73182000, 0xffffe000, "vbitrevi.b",	"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1611   { 0x73184000, 0xffffc000, "vbitrevi.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1612   { 0x73188000, 0xffff8000, "vbitrevi.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1613   { 0x73190000, 0xffff0000, "vbitrevi.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1614   { 0x73242000, 0xffffe000, "vsat.b",		"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1615   { 0x73244000, 0xffffc000, "vsat.h",		"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1616   { 0x73248000, 0xffff8000, "vsat.w",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1617   { 0x73250000, 0xffff0000, "vsat.d",		"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1618   { 0x73282000, 0xffffe000, "vsat.bu",		"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1619   { 0x73284000, 0xffffc000, "vsat.hu",		"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1620   { 0x73288000, 0xffff8000, "vsat.wu",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1621   { 0x73290000, 0xffff0000, "vsat.du",		"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1622   { 0x732c2000, 0xffffe000, "vslli.b",		"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1623   { 0x732c4000, 0xffffc000, "vslli.h",		"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1624   { 0x732c8000, 0xffff8000, "vslli.w",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1625   { 0x732d0000, 0xffff0000, "vslli.d",		"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1626   { 0x73302000, 0xffffe000, "vsrli.b",		"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1627   { 0x73304000, 0xffffc000, "vsrli.h",		"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1628   { 0x73308000, 0xffff8000, "vsrli.w",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1629   { 0x73310000, 0xffff0000, "vsrli.d",		"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1630   { 0x73342000, 0xffffe000, "vsrai.b",		"v0:5,v5:5,u10:3",	0, 0, 0, 0},
1631   { 0x73344000, 0xffffc000, "vsrai.h",		"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1632   { 0x73348000, 0xffff8000, "vsrai.w",		"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1633   { 0x73350000, 0xffff0000, "vsrai.d",		"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1634   { 0x73404000, 0xffffc000, "vsrlni.b.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1635   { 0x73408000, 0xffff8000, "vsrlni.h.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1636   { 0x73410000, 0xffff0000, "vsrlni.w.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1637   { 0x73420000, 0xfffe0000, "vsrlni.d.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1638   { 0x73484000, 0xffffc000, "vssrlni.b.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1639   { 0x73488000, 0xffff8000, "vssrlni.h.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1640   { 0x73490000, 0xffff0000, "vssrlni.w.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1641   { 0x734a0000, 0xfffe0000, "vssrlni.d.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1642   { 0x73444000, 0xffffc000, "vsrlrni.b.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1643   { 0x73448000, 0xffff8000, "vsrlrni.h.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1644   { 0x73450000, 0xffff0000, "vsrlrni.w.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1645   { 0x73460000, 0xfffe0000, "vsrlrni.d.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1646   { 0x734c4000, 0xffffc000, "vssrlni.bu.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1647   { 0x734c8000, 0xffff8000, "vssrlni.hu.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1648   { 0x734d0000, 0xffff0000, "vssrlni.wu.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1649   { 0x734e0000, 0xfffe0000, "vssrlni.du.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1650   { 0x73504000, 0xffffc000, "vssrlrni.b.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1651   { 0x73508000, 0xffff8000, "vssrlrni.h.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1652   { 0x73510000, 0xffff0000, "vssrlrni.w.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1653   { 0x73520000, 0xfffe0000, "vssrlrni.d.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1654   { 0x73544000, 0xffffc000, "vssrlrni.bu.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1655   { 0x73548000, 0xffff8000, "vssrlrni.hu.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1656   { 0x73550000, 0xffff0000, "vssrlrni.wu.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1657   { 0x73560000, 0xfffe0000, "vssrlrni.du.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1658   { 0x73584000, 0xffffc000, "vsrani.b.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1659   { 0x73588000, 0xffff8000, "vsrani.h.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1660   { 0x73590000, 0xffff0000, "vsrani.w.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1661   { 0x735a0000, 0xfffe0000, "vsrani.d.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1662   { 0x735c4000, 0xffffc000, "vsrarni.b.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1663   { 0x735c8000, 0xffff8000, "vsrarni.h.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1664   { 0x735d0000, 0xffff0000, "vsrarni.w.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1665   { 0x735e0000, 0xfffe0000, "vsrarni.d.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1666   { 0x73604000, 0xffffc000, "vssrani.b.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1667   { 0x73608000, 0xffff8000, "vssrani.h.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1668   { 0x73610000, 0xffff0000, "vssrani.w.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1669   { 0x73620000, 0xfffe0000, "vssrani.d.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1670   { 0x73644000, 0xffffc000, "vssrani.bu.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1671   { 0x73648000, 0xffff8000, "vssrani.hu.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1672   { 0x73650000, 0xffff0000, "vssrani.wu.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1673   { 0x73660000, 0xfffe0000, "vssrani.du.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1674   { 0x73684000, 0xffffc000, "vssrarni.b.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1675   { 0x73688000, 0xffff8000, "vssrarni.h.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1676   { 0x73690000, 0xffff0000, "vssrarni.w.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1677   { 0x736a0000, 0xfffe0000, "vssrarni.d.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1678   { 0x736c4000, 0xffffc000, "vssrarni.bu.h",	"v0:5,v5:5,u10:4",	0, 0, 0, 0},
1679   { 0x736c8000, 0xffff8000, "vssrarni.hu.w",	"v0:5,v5:5,u10:5",	0, 0, 0, 0},
1680   { 0x736d0000, 0xffff0000, "vssrarni.wu.d",	"v0:5,v5:5,u10:6",	0, 0, 0, 0},
1681   { 0x736e0000, 0xfffe0000, "vssrarni.du.q",	"v0:5,v5:5,u10:7",	0, 0, 0, 0},
1682   { 0x73800000, 0xfffc0000, "vextrins.d",	"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1683   { 0x73840000, 0xfffc0000, "vextrins.w",	"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1684   { 0x73880000, 0xfffc0000, "vextrins.h",	"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1685   { 0x738c0000, 0xfffc0000, "vextrins.b",	"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1686   { 0x73900000, 0xfffc0000, "vshuf4i.b",	"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1687   { 0x73940000, 0xfffc0000, "vshuf4i.h",	"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1688   { 0x73980000, 0xfffc0000, "vshuf4i.w",	"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1689   { 0x739c0000, 0xfffc0000, "vshuf4i.d",	"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1690   { 0x73c40000, 0xfffc0000, "vbitseli.b",	"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1691   { 0x73d00000, 0xfffc0000, "vandi.b",		"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1692   { 0x73d40000, 0xfffc0000, "vori.b",		"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1693   { 0x73d80000, 0xfffc0000, "vxori.b",		"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1694   { 0x73dc0000, 0xfffc0000, "vnori.b",		"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1695   { 0,		0,	    "vrepli.b",		"v,s0:10",		"vldi %1,(%2)&0x3ff", 0, 0, 0},
1696   { 0x701e0000, 0xffff8000, "vaddwev.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1697   { 0x701e8000, 0xffff8000, "vaddwev.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1698   { 0x701f0000, 0xffff8000, "vaddwev.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1699   { 0x701f8000, 0xffff8000, "vaddwev.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1700   { 0x702e0000, 0xffff8000, "vaddwev.h.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1701   { 0x702e8000, 0xffff8000, "vaddwev.w.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1702   { 0x702f0000, 0xffff8000, "vaddwev.d.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1703   { 0x702f8000, 0xffff8000, "vaddwev.q.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1704   { 0x703e0000, 0xffff8000, "vaddwev.h.bu.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1705   { 0x703e8000, 0xffff8000, "vaddwev.w.hu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1706   { 0x703f0000, 0xffff8000, "vaddwev.d.wu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1707   { 0x703f8000, 0xffff8000, "vaddwev.q.du.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1708   { 0x70220000, 0xffff8000, "vaddwod.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1709   { 0x70228000, 0xffff8000, "vaddwod.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1710   { 0x70230000, 0xffff8000, "vaddwod.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1711   { 0x70238000, 0xffff8000, "vaddwod.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1712   { 0x70320000, 0xffff8000, "vaddwod.h.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1713   { 0x70328000, 0xffff8000, "vaddwod.w.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1714   { 0x70330000, 0xffff8000, "vaddwod.d.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1715   { 0x70338000, 0xffff8000, "vaddwod.q.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1716   { 0x70400000, 0xffff8000, "vaddwod.h.bu.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1717   { 0x70408000, 0xffff8000, "vaddwod.w.hu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1718   { 0x70410000, 0xffff8000, "vaddwod.d.wu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1719   { 0x70418000, 0xffff8000, "vaddwod.q.du.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1720   { 0x70ac0000, 0xffff8000, "vmaddwev.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1721   { 0x70ac8000, 0xffff8000, "vmaddwev.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1722   { 0x70ad0000, 0xffff8000, "vmaddwev.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1723   { 0x70ad8000, 0xffff8000, "vmaddwev.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1724   { 0x70b40000, 0xffff8000, "vmaddwev.h.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1725   { 0x70b48000, 0xffff8000, "vmaddwev.w.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1726   { 0x70b50000, 0xffff8000, "vmaddwev.d.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1727   { 0x70b58000, 0xffff8000, "vmaddwev.q.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1728   { 0x70bc0000, 0xffff8000, "vmaddwev.h.bu.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1729   { 0x70bc8000, 0xffff8000, "vmaddwev.w.hu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1730   { 0x70bd0000, 0xffff8000, "vmaddwev.d.wu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1731   { 0x70bd8000, 0xffff8000, "vmaddwev.q.du.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1732   { 0x70ae0000, 0xffff8000, "vmaddwod.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1733   { 0x70ae8000, 0xffff8000, "vmaddwod.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1734   { 0x70af0000, 0xffff8000, "vmaddwod.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1735   { 0x70af8000, 0xffff8000, "vmaddwod.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1736   { 0x70b60000, 0xffff8000, "vmaddwod.h.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1737   { 0x70b68000, 0xffff8000, "vmaddwod.w.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1738   { 0x70b70000, 0xffff8000, "vmaddwod.d.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1739   { 0x70b78000, 0xffff8000, "vmaddwod.q.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1740   { 0x70be0000, 0xffff8000, "vmaddwod.h.bu.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1741   { 0x70be8000, 0xffff8000, "vmaddwod.w.hu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1742   { 0x70bf0000, 0xffff8000, "vmaddwod.d.wu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1743   { 0x70bf8000, 0xffff8000, "vmaddwod.q.du.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1744   { 0x70900000, 0xffff8000, "vmulwev.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1745   { 0x70908000, 0xffff8000, "vmulwev.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1746   { 0x70910000, 0xffff8000, "vmulwev.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1747   { 0x70918000, 0xffff8000, "vmulwev.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1748   { 0x70980000, 0xffff8000, "vmulwev.h.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1749   { 0x70988000, 0xffff8000, "vmulwev.w.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1750   { 0x70990000, 0xffff8000, "vmulwev.d.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1751   { 0x70998000, 0xffff8000, "vmulwev.q.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1752   { 0x70a00000, 0xffff8000, "vmulwev.h.bu.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1753   { 0x70a08000, 0xffff8000, "vmulwev.w.hu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1754   { 0x70a10000, 0xffff8000, "vmulwev.d.wu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1755   { 0x70a18000, 0xffff8000, "vmulwev.q.du.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1756   { 0x70920000, 0xffff8000, "vmulwod.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1757   { 0x70928000, 0xffff8000, "vmulwod.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1758   { 0x70930000, 0xffff8000, "vmulwod.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1759   { 0x70938000, 0xffff8000, "vmulwod.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1760   { 0x709a0000, 0xffff8000, "vmulwod.h.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1761   { 0x709a8000, 0xffff8000, "vmulwod.w.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1762   { 0x709b0000, 0xffff8000, "vmulwod.d.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1763   { 0x709b8000, 0xffff8000, "vmulwod.q.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1764   { 0x70a20000, 0xffff8000, "vmulwod.h.bu.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1765   { 0x70a28000, 0xffff8000, "vmulwod.w.hu.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1766   { 0x70a30000, 0xffff8000, "vmulwod.d.wu.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1767   { 0x70a38000, 0xffff8000, "vmulwod.q.du.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1768   { 0x70200000, 0xffff8000, "vsubwev.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1769   { 0x70208000, 0xffff8000, "vsubwev.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1770   { 0x70210000, 0xffff8000, "vsubwev.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1771   { 0x70218000, 0xffff8000, "vsubwev.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1772   { 0x70300000, 0xffff8000, "vsubwev.h.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1773   { 0x70308000, 0xffff8000, "vsubwev.w.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1774   { 0x70310000, 0xffff8000, "vsubwev.d.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1775   { 0x70318000, 0xffff8000, "vsubwev.q.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1776   { 0x70240000, 0xffff8000, "vsubwod.h.b",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1777   { 0x70248000, 0xffff8000, "vsubwod.w.h",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1778   { 0x70250000, 0xffff8000, "vsubwod.d.w",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1779   { 0x70258000, 0xffff8000, "vsubwod.q.d",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1780   { 0x70340000, 0xffff8000, "vsubwod.h.bu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1781   { 0x70348000, 0xffff8000, "vsubwod.w.hu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1782   { 0x70350000, 0xffff8000, "vsubwod.d.wu",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1783   { 0x70358000, 0xffff8000, "vsubwod.q.du",	"v0:5,v5:5,v10:5",	0, 0, 0, 0 },
1784   { 0,		0,	    "vrepli.d",		"v,s0:10",		"vldi %1,((%2)&0x3ff)|0xc00", 0, 0, 0},
1785   { 0,		0,	    "vrepli.h",		"v,s0:10",		"vldi %1,((%2)&0x3ff)|0x400", 0, 0, 0},
1786   { 0,		0,	    "vrepli.w",		"v,s0:10",		"vldi %1,((%2)&0x3ff)|0x800", 0, 0, 0},
1787   { 0x73e00000, 0xfffc0000, "vldi",		"v0:5,s5:13",		0, 0, 0, 0},
1788   { 0x73e40000, 0xfffc0000, "vpermi.w",		"v0:5,v5:5,u10:8",	0, 0, 0, 0},
1789   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
1790 };
1791 
1792 static struct loongarch_opcode loongarch_lasx_opcodes[] =
1793 {
1794 /* match,    mask,		name, format, macro, include, exclude, pinfo.	*/
1795   { 0x74000000, 0xffff8000, "xvseq.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1796   { 0x74008000, 0xffff8000, "xvseq.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1797   { 0x74010000, 0xffff8000, "xvseq.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1798   { 0x74018000, 0xffff8000, "xvseq.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1799   { 0x74020000, 0xffff8000, "xvsle.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1800   { 0x74028000, 0xffff8000, "xvsle.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1801   { 0x74030000, 0xffff8000, "xvsle.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1802   { 0x74038000, 0xffff8000, "xvsle.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1803   { 0x74040000, 0xffff8000, "xvsle.bu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1804   { 0x74048000, 0xffff8000, "xvsle.hu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1805   { 0x74050000, 0xffff8000, "xvsle.wu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1806   { 0x74058000, 0xffff8000, "xvsle.du",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1807   { 0x74060000, 0xffff8000, "xvslt.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1808   { 0x74068000, 0xffff8000, "xvslt.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1809   { 0x74070000, 0xffff8000, "xvslt.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1810   { 0x74078000, 0xffff8000, "xvslt.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1811   { 0x74080000, 0xffff8000, "xvslt.bu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1812   { 0x74088000, 0xffff8000, "xvslt.hu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1813   { 0x74090000, 0xffff8000, "xvslt.wu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1814   { 0x74098000, 0xffff8000, "xvslt.du",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1815   { 0x740a0000, 0xffff8000, "xvadd.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1816   { 0x740a8000, 0xffff8000, "xvadd.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1817   { 0x740b0000, 0xffff8000, "xvadd.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1818   { 0x740b8000, 0xffff8000, "xvadd.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1819   { 0x740c0000, 0xffff8000, "xvsub.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1820   { 0x740c8000, 0xffff8000, "xvsub.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1821   { 0x740d0000, 0xffff8000, "xvsub.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1822   { 0x740d8000, 0xffff8000, "xvsub.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1823   { 0x74460000, 0xffff8000, "xvsadd.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1824   { 0x74468000, 0xffff8000, "xvsadd.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1825   { 0x74470000, 0xffff8000, "xvsadd.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1826   { 0x74478000, 0xffff8000, "xvsadd.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1827   { 0x74480000, 0xffff8000, "xvssub.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1828   { 0x74488000, 0xffff8000, "xvssub.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1829   { 0x74490000, 0xffff8000, "xvssub.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1830   { 0x74498000, 0xffff8000, "xvssub.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1831   { 0x744a0000, 0xffff8000, "xvsadd.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1832   { 0x744a8000, 0xffff8000, "xvsadd.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1833   { 0x744b0000, 0xffff8000, "xvsadd.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1834   { 0x744b8000, 0xffff8000, "xvsadd.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1835   { 0x744c0000, 0xffff8000, "xvssub.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1836   { 0x744c8000, 0xffff8000, "xvssub.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1837   { 0x744d0000, 0xffff8000, "xvssub.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1838   { 0x744d8000, 0xffff8000, "xvssub.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1839   { 0x74540000, 0xffff8000, "xvhaddw.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1840   { 0x74548000, 0xffff8000, "xvhaddw.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1841   { 0x74550000, 0xffff8000, "xvhaddw.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1842   { 0x74558000, 0xffff8000, "xvhaddw.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1843   { 0x74560000, 0xffff8000, "xvhsubw.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1844   { 0x74568000, 0xffff8000, "xvhsubw.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1845   { 0x74570000, 0xffff8000, "xvhsubw.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1846   { 0x74578000, 0xffff8000, "xvhsubw.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1847   { 0x74580000, 0xffff8000, "xvhaddw.hu.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1848   { 0x74588000, 0xffff8000, "xvhaddw.wu.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1849   { 0x74590000, 0xffff8000, "xvhaddw.du.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1850   { 0x74598000, 0xffff8000, "xvhaddw.qu.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1851   { 0x745a0000, 0xffff8000, "xvhsubw.hu.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1852   { 0x745a8000, 0xffff8000, "xvhsubw.wu.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1853   { 0x745b0000, 0xffff8000, "xvhsubw.du.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1854   { 0x745b8000, 0xffff8000, "xvhsubw.qu.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1855   { 0x741e0000, 0xffff8000, "xvaddwev.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1856   { 0x741e8000, 0xffff8000, "xvaddwev.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1857   { 0x741f0000, 0xffff8000, "xvaddwev.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1858   { 0x741f8000, 0xffff8000, "xvaddwev.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1859   { 0x742e0000, 0xffff8000, "xvaddwev.h.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1860   { 0x742e8000, 0xffff8000, "xvaddwev.w.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1861   { 0x742f0000, 0xffff8000, "xvaddwev.d.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1862   { 0x742f8000, 0xffff8000, "xvaddwev.q.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1863   { 0x743e0000, 0xffff8000, "xvaddwev.h.bu.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1864   { 0x743e8000, 0xffff8000, "xvaddwev.w.hu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1865   { 0x743f0000, 0xffff8000, "xvaddwev.d.wu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1866   { 0x743f8000, 0xffff8000, "xvaddwev.q.du.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1867   { 0x74220000, 0xffff8000, "xvaddwod.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1868   { 0x74228000, 0xffff8000, "xvaddwod.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1869   { 0x74230000, 0xffff8000, "xvaddwod.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1870   { 0x74238000, 0xffff8000, "xvaddwod.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1871   { 0x74320000, 0xffff8000, "xvaddwod.h.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1872   { 0x74328000, 0xffff8000, "xvaddwod.w.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1873   { 0x74330000, 0xffff8000, "xvaddwod.d.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1874   { 0x74338000, 0xffff8000, "xvaddwod.q.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1875   { 0x74400000, 0xffff8000, "xvaddwod.h.bu.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1876   { 0x74408000, 0xffff8000, "xvaddwod.w.hu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1877   { 0x74410000, 0xffff8000, "xvaddwod.d.wu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1878   { 0x74418000, 0xffff8000, "xvaddwod.q.du.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1879   { 0x74ac0000, 0xffff8000, "xvmaddwev.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1880   { 0x74ac8000, 0xffff8000, "xvmaddwev.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1881   { 0x74ad0000, 0xffff8000, "xvmaddwev.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1882   { 0x74ad8000, 0xffff8000, "xvmaddwev.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1883   { 0x74bc0000, 0xffff8000, "xvmaddwev.h.bu.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1884   { 0x74bc8000, 0xffff8000, "xvmaddwev.w.hu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1885   { 0x74bd0000, 0xffff8000, "xvmaddwev.d.wu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1886   { 0x74bd8000, 0xffff8000, "xvmaddwev.q.du.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1887   { 0x74b40000, 0xffff8000, "xvmaddwev.h.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1888   { 0x74b48000, 0xffff8000, "xvmaddwev.w.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1889   { 0x74b50000, 0xffff8000, "xvmaddwev.d.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1890   { 0x74b58000, 0xffff8000, "xvmaddwev.q.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1891   { 0x74ae0000, 0xffff8000, "xvmaddwod.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1892   { 0x74ae8000, 0xffff8000, "xvmaddwod.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1893   { 0x74af0000, 0xffff8000, "xvmaddwod.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1894   { 0x74af8000, 0xffff8000, "xvmaddwod.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1895   { 0x74b60000, 0xffff8000, "xvmaddwod.h.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1896   { 0x74b68000, 0xffff8000, "xvmaddwod.w.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1897   { 0x74b70000, 0xffff8000, "xvmaddwod.d.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1898   { 0x74b78000, 0xffff8000, "xvmaddwod.q.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1899   { 0x74be0000, 0xffff8000, "xvmaddwod.h.bu.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1900   { 0x74be8000, 0xffff8000, "xvmaddwod.w.hu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1901   { 0x74bf0000, 0xffff8000, "xvmaddwod.d.wu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1902   { 0x74bf8000, 0xffff8000, "xvmaddwod.q.du.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1903   { 0x74900000, 0xffff8000, "xvmulwev.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1904   { 0x74908000, 0xffff8000, "xvmulwev.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1905   { 0x74910000, 0xffff8000, "xvmulwev.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1906   { 0x74918000, 0xffff8000, "xvmulwev.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1907   { 0x74980000, 0xffff8000, "xvmulwev.h.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1908   { 0x74988000, 0xffff8000, "xvmulwev.w.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1909   { 0x74990000, 0xffff8000, "xvmulwev.d.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1910   { 0x74998000, 0xffff8000, "xvmulwev.q.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1911   { 0x74a00000, 0xffff8000, "xvmulwev.h.bu.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1912   { 0x74a08000, 0xffff8000, "xvmulwev.w.hu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1913   { 0x74a10000, 0xffff8000, "xvmulwev.d.wu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1914   { 0x74a18000, 0xffff8000, "xvmulwev.q.du.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1915   { 0x74920000, 0xffff8000, "xvmulwod.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1916   { 0x74928000, 0xffff8000, "xvmulwod.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1917   { 0x74930000, 0xffff8000, "xvmulwod.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1918   { 0x74938000, 0xffff8000, "xvmulwod.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1919   { 0x749a0000, 0xffff8000, "xvmulwod.h.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1920   { 0x749a8000, 0xffff8000, "xvmulwod.w.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1921   { 0x749b0000, 0xffff8000, "xvmulwod.d.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1922   { 0x749b8000, 0xffff8000, "xvmulwod.q.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1923   { 0x74a20000, 0xffff8000, "xvmulwod.h.bu.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1924   { 0x74a28000, 0xffff8000, "xvmulwod.w.hu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1925   { 0x74a30000, 0xffff8000, "xvmulwod.d.wu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1926   { 0x74a38000, 0xffff8000, "xvmulwod.q.du.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1927   { 0x74200000, 0xffff8000, "xvsubwev.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1928   { 0x74208000, 0xffff8000, "xvsubwev.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1929   { 0x74210000, 0xffff8000, "xvsubwev.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1930   { 0x74218000, 0xffff8000, "xvsubwev.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1931   { 0x74300000, 0xffff8000, "xvsubwev.h.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1932   { 0x74308000, 0xffff8000, "xvsubwev.w.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1933   { 0x74310000, 0xffff8000, "xvsubwev.d.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1934   { 0x74318000, 0xffff8000, "xvsubwev.q.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1935   { 0x74240000, 0xffff8000, "xvsubwod.h.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1936   { 0x74248000, 0xffff8000, "xvsubwod.w.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1937   { 0x74250000, 0xffff8000, "xvsubwod.d.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1938   { 0x74258000, 0xffff8000, "xvsubwod.q.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1939   { 0x74340000, 0xffff8000, "xvsubwod.h.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1940   { 0x74348000, 0xffff8000, "xvsubwod.w.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1941   { 0x74350000, 0xffff8000, "xvsubwod.d.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1942   { 0x74358000, 0xffff8000, "xvsubwod.q.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1943   { 0x745c0000, 0xffff8000, "xvadda.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1944   { 0x745c8000, 0xffff8000, "xvadda.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1945   { 0x745d0000, 0xffff8000, "xvadda.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1946   { 0x745d8000, 0xffff8000, "xvadda.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1947   { 0x74600000, 0xffff8000, "xvabsd.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1948   { 0x74608000, 0xffff8000, "xvabsd.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1949   { 0x74610000, 0xffff8000, "xvabsd.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1950   { 0x74618000, 0xffff8000, "xvabsd.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1951   { 0x74620000, 0xffff8000, "xvabsd.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1952   { 0x74628000, 0xffff8000, "xvabsd.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1953   { 0x74630000, 0xffff8000, "xvabsd.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1954   { 0x74638000, 0xffff8000, "xvabsd.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1955   { 0x74640000, 0xffff8000, "xvavg.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1956   { 0x74648000, 0xffff8000, "xvavg.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1957   { 0x74650000, 0xffff8000, "xvavg.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1958   { 0x74658000, 0xffff8000, "xvavg.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1959   { 0x74660000, 0xffff8000, "xvavg.bu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1960   { 0x74668000, 0xffff8000, "xvavg.hu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1961   { 0x74670000, 0xffff8000, "xvavg.wu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1962   { 0x74678000, 0xffff8000, "xvavg.du",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1963   { 0x74680000, 0xffff8000, "xvavgr.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1964   { 0x74688000, 0xffff8000, "xvavgr.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1965   { 0x74690000, 0xffff8000, "xvavgr.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1966   { 0x74698000, 0xffff8000, "xvavgr.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1967   { 0x746a0000, 0xffff8000, "xvavgr.bu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1968   { 0x746a8000, 0xffff8000, "xvavgr.hu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1969   { 0x746b0000, 0xffff8000, "xvavgr.wu",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1970   { 0x746b8000, 0xffff8000, "xvavgr.du",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1971   { 0x74700000, 0xffff8000, "xvmax.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1972   { 0x74708000, 0xffff8000, "xvmax.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1973   { 0x74710000, 0xffff8000, "xvmax.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1974   { 0x74718000, 0xffff8000, "xvmax.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1975   { 0x74720000, 0xffff8000, "xvmin.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1976   { 0x74728000, 0xffff8000, "xvmin.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1977   { 0x74730000, 0xffff8000, "xvmin.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1978   { 0x74738000, 0xffff8000, "xvmin.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1979   { 0x74740000, 0xffff8000, "xvmax.bu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1980   { 0x74748000, 0xffff8000, "xvmax.hu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1981   { 0x74750000, 0xffff8000, "xvmax.wu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1982   { 0x74758000, 0xffff8000, "xvmax.du",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1983   { 0x74760000, 0xffff8000, "xvmin.bu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1984   { 0x74768000, 0xffff8000, "xvmin.hu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1985   { 0x74770000, 0xffff8000, "xvmin.wu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1986   { 0x74778000, 0xffff8000, "xvmin.du",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1987   { 0x74840000, 0xffff8000, "xvmul.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1988   { 0x74848000, 0xffff8000, "xvmul.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1989   { 0x74850000, 0xffff8000, "xvmul.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1990   { 0x74858000, 0xffff8000, "xvmul.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1991   { 0x74860000, 0xffff8000, "xvmuh.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1992   { 0x74868000, 0xffff8000, "xvmuh.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1993   { 0x74870000, 0xffff8000, "xvmuh.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1994   { 0x74878000, 0xffff8000, "xvmuh.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1995   { 0x74880000, 0xffff8000, "xvmuh.bu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1996   { 0x74888000, 0xffff8000, "xvmuh.hu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1997   { 0x74890000, 0xffff8000, "xvmuh.wu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1998   { 0x74898000, 0xffff8000, "xvmuh.du",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
1999   { 0x74a80000, 0xffff8000, "xvmadd.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2000   { 0x74a88000, 0xffff8000, "xvmadd.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2001   { 0x74a90000, 0xffff8000, "xvmadd.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2002   { 0x74a98000, 0xffff8000, "xvmadd.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2003   { 0x74aa0000, 0xffff8000, "xvmsub.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2004   { 0x74aa8000, 0xffff8000, "xvmsub.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2005   { 0x74ab0000, 0xffff8000, "xvmsub.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2006   { 0x74ab8000, 0xffff8000, "xvmsub.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2007   { 0x74e00000, 0xffff8000, "xvdiv.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2008   { 0x74e08000, 0xffff8000, "xvdiv.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2009   { 0x74e10000, 0xffff8000, "xvdiv.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2010   { 0x74e18000, 0xffff8000, "xvdiv.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2011   { 0x74e20000, 0xffff8000, "xvmod.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2012   { 0x74e28000, 0xffff8000, "xvmod.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2013   { 0x74e30000, 0xffff8000, "xvmod.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2014   { 0x74e38000, 0xffff8000, "xvmod.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2015   { 0x74e40000, 0xffff8000, "xvdiv.bu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2016   { 0x74e48000, 0xffff8000, "xvdiv.hu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2017   { 0x74e50000, 0xffff8000, "xvdiv.wu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2018   { 0x74e58000, 0xffff8000, "xvdiv.du",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2019   { 0x74e60000, 0xffff8000, "xvmod.bu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2020   { 0x74e68000, 0xffff8000, "xvmod.hu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2021   { 0x74e70000, 0xffff8000, "xvmod.wu",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2022   { 0x74e78000, 0xffff8000, "xvmod.du",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2023   { 0x74e80000, 0xffff8000, "xvsll.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2024   { 0x74e88000, 0xffff8000, "xvsll.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2025   { 0x74e90000, 0xffff8000, "xvsll.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2026   { 0x74e98000, 0xffff8000, "xvsll.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2027   { 0x74ea0000, 0xffff8000, "xvsrl.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2028   { 0x74ea8000, 0xffff8000, "xvsrl.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2029   { 0x74eb0000, 0xffff8000, "xvsrl.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2030   { 0x74eb8000, 0xffff8000, "xvsrl.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2031   { 0x74ec0000, 0xffff8000, "xvsra.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2032   { 0x74ec8000, 0xffff8000, "xvsra.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2033   { 0x74ed0000, 0xffff8000, "xvsra.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2034   { 0x74ed8000, 0xffff8000, "xvsra.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2035   { 0x74ee0000, 0xffff8000, "xvrotr.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2036   { 0x74ee8000, 0xffff8000, "xvrotr.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2037   { 0x74ef0000, 0xffff8000, "xvrotr.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2038   { 0x74ef8000, 0xffff8000, "xvrotr.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2039   { 0x74f00000, 0xffff8000, "xvsrlr.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2040   { 0x74f08000, 0xffff8000, "xvsrlr.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2041   { 0x74f10000, 0xffff8000, "xvsrlr.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2042   { 0x74f18000, 0xffff8000, "xvsrlr.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2043   { 0x74f20000, 0xffff8000, "xvsrar.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2044   { 0x74f28000, 0xffff8000, "xvsrar.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2045   { 0x74f30000, 0xffff8000, "xvsrar.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2046   { 0x74f38000, 0xffff8000, "xvsrar.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2047   { 0x74f48000, 0xffff8000, "xvsrln.b.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2048   { 0x74f50000, 0xffff8000, "xvsrln.h.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2049   { 0x74f58000, 0xffff8000, "xvsrln.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2050   { 0x74f68000, 0xffff8000, "xvsran.b.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2051   { 0x74f70000, 0xffff8000, "xvsran.h.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2052   { 0x74f78000, 0xffff8000, "xvsran.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2053   { 0x74f88000, 0xffff8000, "xvsrlrn.b.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2054   { 0x74f90000, 0xffff8000, "xvsrlrn.h.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2055   { 0x74f98000, 0xffff8000, "xvsrlrn.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2056   { 0x74fa8000, 0xffff8000, "xvsrarn.b.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2057   { 0x74fb0000, 0xffff8000, "xvsrarn.h.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2058   { 0x74fb8000, 0xffff8000, "xvsrarn.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2059   { 0x74fc8000, 0xffff8000, "xvssrln.b.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2060   { 0x74fd0000, 0xffff8000, "xvssrln.h.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2061   { 0x74fd8000, 0xffff8000, "xvssrln.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2062   { 0x74fe8000, 0xffff8000, "xvssran.b.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2063   { 0x74ff0000, 0xffff8000, "xvssran.h.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2064   { 0x74ff8000, 0xffff8000, "xvssran.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2065   { 0x75008000, 0xffff8000, "xvssrlrn.b.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2066   { 0x75010000, 0xffff8000, "xvssrlrn.h.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2067   { 0x75018000, 0xffff8000, "xvssrlrn.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2068   { 0x75028000, 0xffff8000, "xvssrarn.b.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2069   { 0x75030000, 0xffff8000, "xvssrarn.h.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2070   { 0x75038000, 0xffff8000, "xvssrarn.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2071   { 0x75048000, 0xffff8000, "xvssrln.bu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2072   { 0x75050000, 0xffff8000, "xvssrln.hu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2073   { 0x75058000, 0xffff8000, "xvssrln.wu.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2074   { 0x75068000, 0xffff8000, "xvssran.bu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2075   { 0x75070000, 0xffff8000, "xvssran.hu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2076   { 0x75078000, 0xffff8000, "xvssran.wu.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2077   { 0x75088000, 0xffff8000, "xvssrlrn.bu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2078   { 0x75090000, 0xffff8000, "xvssrlrn.hu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2079   { 0x75098000, 0xffff8000, "xvssrlrn.wu.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2080   { 0x750a8000, 0xffff8000, "xvssrarn.bu.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2081   { 0x750b0000, 0xffff8000, "xvssrarn.hu.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2082   { 0x750b8000, 0xffff8000, "xvssrarn.wu.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2083   { 0x750c0000, 0xffff8000, "xvbitclr.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2084   { 0x750c8000, 0xffff8000, "xvbitclr.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2085   { 0x750d0000, 0xffff8000, "xvbitclr.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2086   { 0x750d8000, 0xffff8000, "xvbitclr.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2087   { 0x750e0000, 0xffff8000, "xvbitset.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2088   { 0x750e8000, 0xffff8000, "xvbitset.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2089   { 0x750f0000, 0xffff8000, "xvbitset.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2090   { 0x750f8000, 0xffff8000, "xvbitset.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2091   { 0x75100000, 0xffff8000, "xvbitrev.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2092   { 0x75108000, 0xffff8000, "xvbitrev.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2093   { 0x75110000, 0xffff8000, "xvbitrev.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2094   { 0x75118000, 0xffff8000, "xvbitrev.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2095   { 0x75160000, 0xffff8000, "xvpackev.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2096   { 0x75168000, 0xffff8000, "xvpackev.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2097   { 0x75170000, 0xffff8000, "xvpackev.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2098   { 0x75178000, 0xffff8000, "xvpackev.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2099   { 0x75180000, 0xffff8000, "xvpackod.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2100   { 0x75188000, 0xffff8000, "xvpackod.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2101   { 0x75190000, 0xffff8000, "xvpackod.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2102   { 0x75198000, 0xffff8000, "xvpackod.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2103   { 0x751a0000, 0xffff8000, "xvilvl.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2104   { 0x751a8000, 0xffff8000, "xvilvl.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2105   { 0x751b0000, 0xffff8000, "xvilvl.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2106   { 0x751b8000, 0xffff8000, "xvilvl.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2107   { 0x751c0000, 0xffff8000, "xvilvh.b",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2108   { 0x751c8000, 0xffff8000, "xvilvh.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2109   { 0x751d0000, 0xffff8000, "xvilvh.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2110   { 0x751d8000, 0xffff8000, "xvilvh.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2111   { 0x751e0000, 0xffff8000, "xvpickev.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2112   { 0x751e8000, 0xffff8000, "xvpickev.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2113   { 0x751f0000, 0xffff8000, "xvpickev.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2114   { 0x751f8000, 0xffff8000, "xvpickev.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2115   { 0x75200000, 0xffff8000, "xvpickod.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2116   { 0x75208000, 0xffff8000, "xvpickod.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2117   { 0x75210000, 0xffff8000, "xvpickod.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2118   { 0x75218000, 0xffff8000, "xvpickod.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2119   { 0x75220000, 0xffff8000, "xvreplve.b",	"x0:5,x5:5,r10:5",	0, 0, 0, 0},
2120   { 0x75228000, 0xffff8000, "xvreplve.h",	"x0:5,x5:5,r10:5",	0, 0, 0, 0},
2121   { 0x75230000, 0xffff8000, "xvreplve.w",	"x0:5,x5:5,r10:5",	0, 0, 0, 0},
2122   { 0x75238000, 0xffff8000, "xvreplve.d",	"x0:5,x5:5,r10:5",	0, 0, 0, 0},
2123   { 0x75260000, 0xffff8000, "xvand.v",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2124   { 0x75268000, 0xffff8000, "xvor.v",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2125   { 0x75270000, 0xffff8000, "xvxor.v",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2126   { 0x75278000, 0xffff8000, "xvnor.v",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2127   { 0x75280000, 0xffff8000, "xvandn.v",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2128   { 0x75288000, 0xffff8000, "xvorn.v",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2129   { 0x752b0000, 0xffff8000, "xvfrstp.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2130   { 0x752b8000, 0xffff8000, "xvfrstp.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2131   { 0x752d0000, 0xffff8000, "xvadd.q",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2132   { 0x752d8000, 0xffff8000, "xvsub.q",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2133   { 0x752e0000, 0xffff8000, "xvsigncov.b",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2134   { 0x752e8000, 0xffff8000, "xvsigncov.h",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2135   { 0x752f0000, 0xffff8000, "xvsigncov.w",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2136   { 0x752f8000, 0xffff8000, "xvsigncov.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2137   { 0x75308000, 0xffff8000, "xvfadd.s",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2138   { 0x75310000, 0xffff8000, "xvfadd.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2139   { 0x75328000, 0xffff8000, "xvfsub.s",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2140   { 0x75330000, 0xffff8000, "xvfsub.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2141   { 0x75388000, 0xffff8000, "xvfmul.s",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2142   { 0x75390000, 0xffff8000, "xvfmul.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2143   { 0x753a8000, 0xffff8000, "xvfdiv.s",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2144   { 0x753b0000, 0xffff8000, "xvfdiv.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2145   { 0x753c8000, 0xffff8000, "xvfmax.s",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2146   { 0x753d0000, 0xffff8000, "xvfmax.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2147   { 0x753e8000, 0xffff8000, "xvfmin.s",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2148   { 0x753f0000, 0xffff8000, "xvfmin.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2149   { 0x75408000, 0xffff8000, "xvfmaxa.s",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2150   { 0x75410000, 0xffff8000, "xvfmaxa.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2151   { 0x75428000, 0xffff8000, "xvfmina.s",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2152   { 0x75430000, 0xffff8000, "xvfmina.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2153   { 0x75460000, 0xffff8000, "xvfcvt.h.s",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2154   { 0x75468000, 0xffff8000, "xvfcvt.s.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2155   { 0x75480000, 0xffff8000, "xvffint.s.l",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2156   { 0x75498000, 0xffff8000, "xvftint.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2157   { 0x754a0000, 0xffff8000, "xvftintrm.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2158   { 0x754a8000, 0xffff8000, "xvftintrp.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2159   { 0x754b0000, 0xffff8000, "xvftintrz.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2160   { 0x754b8000, 0xffff8000, "xvftintrne.w.d",	"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2161   { 0x757a8000, 0xffff8000, "xvshuf.h",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2162   { 0x757b0000, 0xffff8000, "xvshuf.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2163   { 0x757b8000, 0xffff8000, "xvshuf.d",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2164   { 0x757d0000, 0xffff8000, "xvperm.w",		"x0:5,x5:5,x10:5",	0, 0, 0, 0 },
2165   { 0x76800000, 0xffff8000, "xvseqi.b",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2166   { 0x76808000, 0xffff8000, "xvseqi.h",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2167   { 0x76810000, 0xffff8000, "xvseqi.w",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2168   { 0x76818000, 0xffff8000, "xvseqi.d",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2169   { 0x76820000, 0xffff8000, "xvslei.b",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2170   { 0x76828000, 0xffff8000, "xvslei.h",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2171   { 0x76830000, 0xffff8000, "xvslei.w",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2172   { 0x76838000, 0xffff8000, "xvslei.d",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2173   { 0x76840000, 0xffff8000, "xvslei.bu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2174   { 0x76848000, 0xffff8000, "xvslei.hu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2175   { 0x76850000, 0xffff8000, "xvslei.wu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2176   { 0x76858000, 0xffff8000, "xvslei.du",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2177   { 0x76860000, 0xffff8000, "xvslti.b",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2178   { 0x76868000, 0xffff8000, "xvslti.h",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2179   { 0x76870000, 0xffff8000, "xvslti.w",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2180   { 0x76878000, 0xffff8000, "xvslti.d",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2181   { 0x76880000, 0xffff8000, "xvslti.bu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2182   { 0x76888000, 0xffff8000, "xvslti.hu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2183   { 0x76890000, 0xffff8000, "xvslti.wu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2184   { 0x76898000, 0xffff8000, "xvslti.du",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2185   { 0x768a0000, 0xffff8000, "xvaddi.bu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2186   { 0x768a8000, 0xffff8000, "xvaddi.hu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2187   { 0x768b0000, 0xffff8000, "xvaddi.wu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2188   { 0x768b8000, 0xffff8000, "xvaddi.du",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2189   { 0x768c0000, 0xffff8000, "xvsubi.bu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2190   { 0x768c8000, 0xffff8000, "xvsubi.hu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2191   { 0x768d0000, 0xffff8000, "xvsubi.wu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2192   { 0x768d8000, 0xffff8000, "xvsubi.du",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2193   { 0x768e0000, 0xffff8000, "xvbsll.v",		"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2194   { 0x768e8000, 0xffff8000, "xvbsrl.v",		"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2195   { 0x76900000, 0xffff8000, "xvmaxi.b",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2196   { 0x76908000, 0xffff8000, "xvmaxi.h",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2197   { 0x76910000, 0xffff8000, "xvmaxi.w",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2198   { 0x76918000, 0xffff8000, "xvmaxi.d",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2199   { 0x76920000, 0xffff8000, "xvmini.b",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2200   { 0x76928000, 0xffff8000, "xvmini.h",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2201   { 0x76930000, 0xffff8000, "xvmini.w",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2202   { 0x76938000, 0xffff8000, "xvmini.d",		"x0:5,x5:5,s10:5",	0, 0, 0, 0},
2203   { 0x76940000, 0xffff8000, "xvmaxi.bu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2204   { 0x76948000, 0xffff8000, "xvmaxi.hu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2205   { 0x76950000, 0xffff8000, "xvmaxi.wu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2206   { 0x76958000, 0xffff8000, "xvmaxi.du",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2207   { 0x76960000, 0xffff8000, "xvmini.bu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2208   { 0x76968000, 0xffff8000, "xvmini.hu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2209   { 0x76970000, 0xffff8000, "xvmini.wu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2210   { 0x76978000, 0xffff8000, "xvmini.du",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2211   { 0x769a0000, 0xffff8000, "xvfrstpi.b",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2212   { 0x769a8000, 0xffff8000, "xvfrstpi.h",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2213   { 0x769c0000, 0xfffffc00, "xvclo.b",		"x0:5,x5:5",		0, 0, 0, 0},
2214   { 0x769c0400, 0xfffffc00, "xvclo.h",		"x0:5,x5:5",		0, 0, 0, 0},
2215   { 0x769c0800, 0xfffffc00, "xvclo.w",		"x0:5,x5:5",		0, 0, 0, 0},
2216   { 0x769c0c00, 0xfffffc00, "xvclo.d",		"x0:5,x5:5",		0, 0, 0, 0},
2217   { 0x769c1000, 0xfffffc00, "xvclz.b",		"x0:5,x5:5",		0, 0, 0, 0},
2218   { 0x769c1400, 0xfffffc00, "xvclz.h",		"x0:5,x5:5",		0, 0, 0, 0},
2219   { 0x769c1800, 0xfffffc00, "xvclz.w",		"x0:5,x5:5",		0, 0, 0, 0},
2220   { 0x769c1c00, 0xfffffc00, "xvclz.d",		"x0:5,x5:5",		0, 0, 0, 0},
2221   { 0x769c2000, 0xfffffc00, "xvpcnt.b",		"x0:5,x5:5",		0, 0, 0, 0},
2222   { 0x769c2400, 0xfffffc00, "xvpcnt.h",		"x0:5,x5:5",		0, 0, 0, 0},
2223   { 0x769c2800, 0xfffffc00, "xvpcnt.w",		"x0:5,x5:5",		0, 0, 0, 0},
2224   { 0x769c2c00, 0xfffffc00, "xvpcnt.d",		"x0:5,x5:5",		0, 0, 0, 0},
2225   { 0x769c3000, 0xfffffc00, "xvneg.b",		"x0:5,x5:5",		0, 0, 0, 0},
2226   { 0x769c3400, 0xfffffc00, "xvneg.h",		"x0:5,x5:5",		0, 0, 0, 0},
2227   { 0x769c3800, 0xfffffc00, "xvneg.w",		"x0:5,x5:5",		0, 0, 0, 0},
2228   { 0x769c3c00, 0xfffffc00, "xvneg.d",		"x0:5,x5:5",		0, 0, 0, 0},
2229   { 0x769c4000, 0xfffffc00, "xvmskltz.b",	"x0:5,x5:5",		0, 0, 0, 0},
2230   { 0x769c4400, 0xfffffc00, "xvmskltz.h",	"x0:5,x5:5",		0, 0, 0, 0},
2231   { 0x769c4800, 0xfffffc00, "xvmskltz.w",	"x0:5,x5:5",		0, 0, 0, 0},
2232   { 0x769c4c00, 0xfffffc00, "xvmskltz.d",	"x0:5,x5:5",		0, 0, 0, 0},
2233   { 0x769c5000, 0xfffffc00, "xvmskgez.b",	"x0:5,x5:5",		0, 0, 0, 0},
2234   { 0x769c6000, 0xfffffc00, "xvmsknz.b",	"x0:5,x5:5",		0, 0, 0, 0},
2235   { 0x769c9800, 0xfffffc18, "xvseteqz.v",	"c0:3,x5:5",		0, 0, 0, 0},
2236   { 0x769c9c00, 0xfffffc18, "xvsetnez.v",	"c0:3,x5:5",		0, 0, 0, 0},
2237   { 0x769ca000, 0xfffffc18, "xvsetanyeqz.b",	"c0:3,x5:5",		0, 0, 0, 0},
2238   { 0x769ca400, 0xfffffc18, "xvsetanyeqz.h",	"c0:3,x5:5",		0, 0, 0, 0},
2239   { 0x769ca800, 0xfffffc18, "xvsetanyeqz.w",	"c0:3,x5:5",		0, 0, 0, 0},
2240   { 0x769cac00, 0xfffffc18, "xvsetanyeqz.d",	"c0:3,x5:5",		0, 0, 0, 0},
2241   { 0x769cb000, 0xfffffc18, "xvsetallnez.b",	"c0:3,x5:5",		0, 0, 0, 0},
2242   { 0x769cb400, 0xfffffc18, "xvsetallnez.h",	"c0:3,x5:5",		0, 0, 0, 0},
2243   { 0x769cb800, 0xfffffc18, "xvsetallnez.w",	"c0:3,x5:5",		0, 0, 0, 0},
2244   { 0x769cbc00, 0xfffffc18, "xvsetallnez.d",	"c0:3,x5:5",		0, 0, 0, 0},
2245   { 0x769cc400, 0xfffffc00, "xvflogb.s",	"x0:5,x5:5",		0, 0, 0, 0},
2246   { 0x769cc800, 0xfffffc00, "xvflogb.d",	"x0:5,x5:5",		0, 0, 0, 0},
2247   { 0x769cd400, 0xfffffc00, "xvfclass.s",	"x0:5,x5:5",		0, 0, 0, 0},
2248   { 0x769cd800, 0xfffffc00, "xvfclass.d",	"x0:5,x5:5",		0, 0, 0, 0},
2249   { 0x769ce400, 0xfffffc00, "xvfsqrt.s",	"x0:5,x5:5",		0, 0, 0, 0},
2250   { 0x769ce800, 0xfffffc00, "xvfsqrt.d",	"x0:5,x5:5",		0, 0, 0, 0},
2251   { 0x769cf400, 0xfffffc00, "xvfrecip.s",	"x0:5,x5:5",		0, 0, 0, 0},
2252   { 0x769cf800, 0xfffffc00, "xvfrecip.d",	"x0:5,x5:5",		0, 0, 0, 0},
2253   { 0x769d0400, 0xfffffc00, "xvfrsqrt.s",	"x0:5,x5:5",		0, 0, 0, 0},
2254   { 0x769d0800, 0xfffffc00, "xvfrsqrt.d",	"x0:5,x5:5",		0, 0, 0, 0},
2255   { 0x769d1400, 0xfffffc00, "xvfrecipe.s",	"x0:5,x5:5",		0, 0, 0, 0},
2256   { 0x769d1800, 0xfffffc00, "xvfrecipe.d",	"x0:5,x5:5",		0, 0, 0, 0},
2257   { 0x769d2400, 0xfffffc00, "xvfrsqrte.s",	"x0:5,x5:5",		0, 0, 0, 0},
2258   { 0x769d2800, 0xfffffc00, "xvfrsqrte.d",	"x0:5,x5:5",		0, 0, 0, 0},
2259   { 0x769d3400, 0xfffffc00, "xvfrint.s",	"x0:5,x5:5",		0, 0, 0, 0},
2260   { 0x769d3800, 0xfffffc00, "xvfrint.d",	"x0:5,x5:5",		0, 0, 0, 0},
2261   { 0x769d4400, 0xfffffc00, "xvfrintrm.s",	"x0:5,x5:5",		0, 0, 0, 0},
2262   { 0x769d4800, 0xfffffc00, "xvfrintrm.d",	"x0:5,x5:5",		0, 0, 0, 0},
2263   { 0x769d5400, 0xfffffc00, "xvfrintrp.s",	"x0:5,x5:5",		0, 0, 0, 0},
2264   { 0x769d5800, 0xfffffc00, "xvfrintrp.d",	"x0:5,x5:5",		0, 0, 0, 0},
2265   { 0x769d6400, 0xfffffc00, "xvfrintrz.s",	"x0:5,x5:5",		0, 0, 0, 0},
2266   { 0x769d6800, 0xfffffc00, "xvfrintrz.d",	"x0:5,x5:5",		0, 0, 0, 0},
2267   { 0x769d7400, 0xfffffc00, "xvfrintrne.s",	"x0:5,x5:5",		0, 0, 0, 0},
2268   { 0x769d7800, 0xfffffc00, "xvfrintrne.d",	"x0:5,x5:5",		0, 0, 0, 0},
2269   { 0x769de800, 0xfffffc00, "xvfcvtl.s.h",	"x0:5,x5:5",		0, 0, 0, 0},
2270   { 0x769dec00, 0xfffffc00, "xvfcvth.s.h",	"x0:5,x5:5",		0, 0, 0, 0},
2271   { 0x769df000, 0xfffffc00, "xvfcvtl.d.s",	"x0:5,x5:5",		0, 0, 0, 0},
2272   { 0x769df400, 0xfffffc00, "xvfcvth.d.s",	"x0:5,x5:5",		0, 0, 0, 0},
2273   { 0x769e0000, 0xfffffc00, "xvffint.s.w",	"x0:5,x5:5",		0, 0, 0, 0},
2274   { 0x769e0400, 0xfffffc00, "xvffint.s.wu",	"x0:5,x5:5",		0, 0, 0, 0},
2275   { 0x769e0800, 0xfffffc00, "xvffint.d.l",	"x0:5,x5:5",		0, 0, 0, 0},
2276   { 0x769e0c00, 0xfffffc00, "xvffint.d.lu",	"x0:5,x5:5",		0, 0, 0, 0},
2277   { 0x769e1000, 0xfffffc00, "xvffintl.d.w",	"x0:5,x5:5",		0, 0, 0, 0},
2278   { 0x769e1400, 0xfffffc00, "xvffinth.d.w",	"x0:5,x5:5",		0, 0, 0, 0},
2279   { 0x769e3000, 0xfffffc00, "xvftint.w.s",	"x0:5,x5:5",		0, 0, 0, 0},
2280   { 0x769e3400, 0xfffffc00, "xvftint.l.d",	"x0:5,x5:5",		0, 0, 0, 0},
2281   { 0x769e3800, 0xfffffc00, "xvftintrm.w.s",	"x0:5,x5:5",		0, 0, 0, 0},
2282   { 0x769e3c00, 0xfffffc00, "xvftintrm.l.d",	"x0:5,x5:5",		0, 0, 0, 0},
2283   { 0x769e4000, 0xfffffc00, "xvftintrp.w.s",	"x0:5,x5:5",		0, 0, 0, 0},
2284   { 0x769e4400, 0xfffffc00, "xvftintrp.l.d",	"x0:5,x5:5",		0, 0, 0, 0},
2285   { 0x769e4800, 0xfffffc00, "xvftintrz.w.s",	"x0:5,x5:5",		0, 0, 0, 0},
2286   { 0x769e4c00, 0xfffffc00, "xvftintrz.l.d",	"x0:5,x5:5",		0, 0, 0, 0},
2287   { 0x769e5000, 0xfffffc00, "xvftintrne.w.s",	"x0:5,x5:5",		0, 0, 0, 0},
2288   { 0x769e5400, 0xfffffc00, "xvftintrne.l.d",	"x0:5,x5:5",		0, 0, 0, 0},
2289   { 0x769e5800, 0xfffffc00, "xvftint.wu.s",	"x0:5,x5:5",		0, 0, 0, 0},
2290   { 0x769e5c00, 0xfffffc00, "xvftint.lu.d",	"x0:5,x5:5",		0, 0, 0, 0},
2291   { 0x769e7000, 0xfffffc00, "xvftintrz.wu.s",	"x0:5,x5:5",		0, 0, 0, 0},
2292   { 0x769e7400, 0xfffffc00, "xvftintrz.lu.d",	"x0:5,x5:5",		0, 0, 0, 0},
2293   { 0x769e8000, 0xfffffc00, "xvftintl.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2294   { 0x769e8400, 0xfffffc00, "xvftinth.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2295   { 0x769e8800, 0xfffffc00, "xvftintrml.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2296   { 0x769e8c00, 0xfffffc00, "xvftintrmh.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2297   { 0x769e9000, 0xfffffc00, "xvftintrpl.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2298   { 0x769e9400, 0xfffffc00, "xvftintrph.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2299   { 0x769e9800, 0xfffffc00, "xvftintrzl.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2300   { 0x769e9c00, 0xfffffc00, "xvftintrzh.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2301   { 0x769ea000, 0xfffffc00, "xvftintrnel.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2302   { 0x769ea400, 0xfffffc00, "xvftintrneh.l.s",	"x0:5,x5:5",		0, 0, 0, 0},
2303   { 0x769ee000, 0xfffffc00, "xvexth.h.b",	"x0:5,x5:5",		0, 0, 0, 0},
2304   { 0x769ee400, 0xfffffc00, "xvexth.w.h",	"x0:5,x5:5",		0, 0, 0, 0},
2305   { 0x769ee800, 0xfffffc00, "xvexth.d.w",	"x0:5,x5:5",		0, 0, 0, 0},
2306   { 0x769eec00, 0xfffffc00, "xvexth.q.d",	"x0:5,x5:5",		0, 0, 0, 0},
2307   { 0x769ef000, 0xfffffc00, "xvexth.hu.bu",	"x0:5,x5:5",		0, 0, 0, 0},
2308   { 0x769ef400, 0xfffffc00, "xvexth.wu.hu",	"x0:5,x5:5",		0, 0, 0, 0},
2309   { 0x769ef800, 0xfffffc00, "xvexth.du.wu",	"x0:5,x5:5",		0, 0, 0, 0},
2310   { 0x769efc00, 0xfffffc00, "xvexth.qu.du",	"x0:5,x5:5",		0, 0, 0, 0},
2311   { 0x769f0000, 0xfffffc00, "xvreplgr2vr.b",	"x0:5,r5:5",		0, 0, 0, 0},
2312   { 0x769f0400, 0xfffffc00, "xvreplgr2vr.h",	"x0:5,r5:5",		0, 0, 0, 0},
2313   { 0x769f0800, 0xfffffc00, "xvreplgr2vr.w",	"x0:5,r5:5",		0, 0, 0, 0},
2314   { 0x769f0c00, 0xfffffc00, "xvreplgr2vr.d",	"x0:5,r5:5",		0, 0, 0, 0},
2315   { 0x769f1000, 0xfffffc00, "vext2xv.h.b",	"x0:5,x5:5",		0, 0, 0, 0},
2316   { 0x769f1400, 0xfffffc00, "vext2xv.w.b",	"x0:5,x5:5",		0, 0, 0, 0},
2317   { 0x769f1800, 0xfffffc00, "vext2xv.d.b",	"x0:5,x5:5",		0, 0, 0, 0},
2318   { 0x769f1c00, 0xfffffc00, "vext2xv.w.h",	"x0:5,x5:5",		0, 0, 0, 0},
2319   { 0x769f2000, 0xfffffc00, "vext2xv.d.h",	"x0:5,x5:5",		0, 0, 0, 0},
2320   { 0x769f2400, 0xfffffc00, "vext2xv.d.w",	"x0:5,x5:5",		0, 0, 0, 0},
2321   { 0x769f2800, 0xfffffc00, "vext2xv.hu.bu",	"x0:5,x5:5",		0, 0, 0, 0},
2322   { 0x769f2c00, 0xfffffc00, "vext2xv.wu.bu",	"x0:5,x5:5",		0, 0, 0, 0},
2323   { 0x769f3000, 0xfffffc00, "vext2xv.du.bu",	"x0:5,x5:5",		0, 0, 0, 0},
2324   { 0x769f3400, 0xfffffc00, "vext2xv.wu.hu",	"x0:5,x5:5",		0, 0, 0, 0},
2325   { 0x769f3800, 0xfffffc00, "vext2xv.du.hu",	"x0:5,x5:5",		0, 0, 0, 0},
2326   { 0x769f3c00, 0xfffffc00, "vext2xv.du.wu",	"x0:5,x5:5",		0, 0, 0, 0},
2327   { 0x769f8000, 0xffff8000, "xvhseli.d",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2328   { 0x76a02000, 0xffffe000, "xvrotri.b",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2329   { 0x76a04000, 0xffffc000, "xvrotri.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2330   { 0x76a08000, 0xffff8000, "xvrotri.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2331   { 0x76a10000, 0xffff0000, "xvrotri.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2332   { 0x76a42000, 0xffffe000, "xvsrlri.b",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2333   { 0x76a44000, 0xffffc000, "xvsrlri.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2334   { 0x76a48000, 0xffff8000, "xvsrlri.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2335   { 0x76a50000, 0xffff0000, "xvsrlri.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2336   { 0x76a82000, 0xffffe000, "xvsrari.b",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2337   { 0x76a84000, 0xffffc000, "xvsrari.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2338   { 0x76a88000, 0xffff8000, "xvsrari.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2339   { 0x76a90000, 0xffff0000, "xvsrari.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2340   { 0x76ebc000, 0xffffe000, "xvinsgr2vr.w",	"x0:5,r5:5,u10:3",	0, 0, 0, 0},
2341   { 0x76ebe000, 0xfffff000, "xvinsgr2vr.d",	"x0:5,r5:5,u10:2",	0, 0, 0, 0},
2342   { 0x76efc000, 0xffffe000, "xvpickve2gr.w",	"r0:5,x5:5,u10:3",	0, 0, 0, 0},
2343   { 0x76efe000, 0xfffff000, "xvpickve2gr.d",	"r0:5,x5:5,u10:2",	0, 0, 0, 0},
2344   { 0x76f3c000, 0xffffe000, "xvpickve2gr.wu",	"r0:5,x5:5,u10:3",	0, 0, 0, 0},
2345   { 0x76f3e000, 0xfffff000, "xvpickve2gr.du",	"r0:5,x5:5,u10:2",	0, 0, 0, 0},
2346   { 0x76f78000, 0xffffc000, "xvrepl128vei.b",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2347   { 0x76f7c000, 0xffffe000, "xvrepl128vei.h",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2348   { 0x76f7e000, 0xfffff000, "xvrepl128vei.w",	"x0:5,x5:5,u10:2",	0, 0, 0, 0},
2349   { 0x76f7f000, 0xfffff800, "xvrepl128vei.d",	"x0:5,x5:5,u10:1",	0, 0, 0, 0},
2350   { 0x76ffc000, 0xffffe000, "xvinsve0.w",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2351   { 0x76ffe000, 0xfffff000, "xvinsve0.d",	"x0:5,x5:5,u10:2",	0, 0, 0, 0},
2352   { 0x7703c000, 0xffffe000, "xvpickve.w",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2353   { 0x7703e000, 0xfffff000, "xvpickve.d",	"x0:5,x5:5,u10:2",	0, 0, 0, 0},
2354   { 0x77070000, 0xfffffc00, "xvreplve0.b",	"x0:5,x5:5",		0, 0, 0, 0},
2355   { 0x77078000, 0xfffffc00, "xvreplve0.h",	"x0:5,x5:5",		0, 0, 0, 0},
2356   { 0x7707c000, 0xfffffc00, "xvreplve0.w",	"x0:5,x5:5",		0, 0, 0, 0},
2357   { 0x7707e000, 0xfffffc00, "xvreplve0.d",	"x0:5,x5:5",		0, 0, 0, 0},
2358   { 0x7707f000, 0xfffffc00, "xvreplve0.q",	"x0:5,x5:5",		0, 0, 0, 0},
2359   { 0x77082000, 0xffffe000, "xvsllwil.h.b",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2360   { 0x77084000, 0xffffc000, "xvsllwil.w.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2361   { 0x77088000, 0xffff8000, "xvsllwil.d.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2362   { 0x77090000, 0xfffffc00, "xvextl.q.d",	"x0:5,x5:5",		0, 0, 0, 0},
2363   { 0x770c2000, 0xffffe000, "xvsllwil.hu.bu",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2364   { 0x770c4000, 0xffffc000, "xvsllwil.wu.hu",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2365   { 0x770c8000, 0xffff8000, "xvsllwil.du.wu",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2366   { 0x770d0000, 0xfffffc00, "xvextl.qu.du",	"x0:5,x5:5",		0, 0, 0, 0},
2367   { 0x77102000, 0xffffe000, "xvbitclri.b",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2368   { 0x77104000, 0xffffc000, "xvbitclri.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2369   { 0x77108000, 0xffff8000, "xvbitclri.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2370   { 0x77110000, 0xffff0000, "xvbitclri.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2371   { 0x77142000, 0xffffe000, "xvbitseti.b",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2372   { 0x77144000, 0xffffc000, "xvbitseti.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2373   { 0x77148000, 0xffff8000, "xvbitseti.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2374   { 0x77150000, 0xffff0000, "xvbitseti.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2375   { 0x77182000, 0xffffe000, "xvbitrevi.b",	"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2376   { 0x77184000, 0xffffc000, "xvbitrevi.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2377   { 0x77188000, 0xffff8000, "xvbitrevi.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2378   { 0x77190000, 0xffff0000, "xvbitrevi.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2379   { 0x77242000, 0xffffe000, "xvsat.b",		"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2380   { 0x77244000, 0xffffc000, "xvsat.h",		"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2381   { 0x77248000, 0xffff8000, "xvsat.w",		"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2382   { 0x77250000, 0xffff0000, "xvsat.d",		"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2383   { 0x77282000, 0xffffe000, "xvsat.bu",		"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2384   { 0x77284000, 0xffffc000, "xvsat.hu",		"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2385   { 0x77288000, 0xffff8000, "xvsat.wu",		"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2386   { 0x77290000, 0xffff0000, "xvsat.du",		"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2387   { 0x772c2000, 0xffffe000, "xvslli.b",		"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2388   { 0x772c4000, 0xffffc000, "xvslli.h",		"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2389   { 0x772c8000, 0xffff8000, "xvslli.w",		"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2390   { 0x772d0000, 0xffff0000, "xvslli.d",		"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2391   { 0x77302000, 0xffffe000, "xvsrli.b",		"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2392   { 0x77304000, 0xffffc000, "xvsrli.h",		"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2393   { 0x77308000, 0xffff8000, "xvsrli.w",		"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2394   { 0x77310000, 0xffff0000, "xvsrli.d",		"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2395   { 0x77342000, 0xffffe000, "xvsrai.b",		"x0:5,x5:5,u10:3",	0, 0, 0, 0},
2396   { 0x77344000, 0xffffc000, "xvsrai.h",		"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2397   { 0x77348000, 0xffff8000, "xvsrai.w",		"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2398   { 0x77350000, 0xffff0000, "xvsrai.d",		"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2399   { 0x77404000, 0xffffc000, "xvsrlni.b.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2400   { 0x77408000, 0xffff8000, "xvsrlni.h.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2401   { 0x77410000, 0xffff0000, "xvsrlni.w.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2402   { 0x77420000, 0xfffe0000, "xvsrlni.d.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2403   { 0x77444000, 0xffffc000, "xvsrlrni.b.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2404   { 0x77448000, 0xffff8000, "xvsrlrni.h.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2405   { 0x77450000, 0xffff0000, "xvsrlrni.w.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2406   { 0x77460000, 0xfffe0000, "xvsrlrni.d.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2407   { 0x77484000, 0xffffc000, "xvssrlni.b.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2408   { 0x77488000, 0xffff8000, "xvssrlni.h.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2409   { 0x77490000, 0xffff0000, "xvssrlni.w.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2410   { 0x774a0000, 0xfffe0000, "xvssrlni.d.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2411   { 0x774c4000, 0xffffc000, "xvssrlni.bu.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2412   { 0x774c8000, 0xffff8000, "xvssrlni.hu.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2413   { 0x774d0000, 0xffff0000, "xvssrlni.wu.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2414   { 0x774e0000, 0xfffe0000, "xvssrlni.du.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2415   { 0x77504000, 0xffffc000, "xvssrlrni.b.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2416   { 0x77508000, 0xffff8000, "xvssrlrni.h.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2417   { 0x77510000, 0xffff0000, "xvssrlrni.w.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2418   { 0x77520000, 0xfffe0000, "xvssrlrni.d.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2419   { 0x77544000, 0xffffc000, "xvssrlrni.bu.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2420   { 0x77548000, 0xffff8000, "xvssrlrni.hu.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2421   { 0x77550000, 0xffff0000, "xvssrlrni.wu.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2422   { 0x77560000, 0xfffe0000, "xvssrlrni.du.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2423   { 0x77584000, 0xffffc000, "xvsrani.b.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2424   { 0x77588000, 0xffff8000, "xvsrani.h.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2425   { 0x77590000, 0xffff0000, "xvsrani.w.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2426   { 0x775a0000, 0xfffe0000, "xvsrani.d.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2427   { 0x775c4000, 0xffffc000, "xvsrarni.b.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2428   { 0x775c8000, 0xffff8000, "xvsrarni.h.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2429   { 0x775d0000, 0xffff0000, "xvsrarni.w.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2430   { 0x775e0000, 0xfffe0000, "xvsrarni.d.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2431   { 0x77604000, 0xffffc000, "xvssrani.b.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2432   { 0x77608000, 0xffff8000, "xvssrani.h.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2433   { 0x77610000, 0xffff0000, "xvssrani.w.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2434   { 0x77620000, 0xfffe0000, "xvssrani.d.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2435   { 0x77644000, 0xffffc000, "xvssrani.bu.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2436   { 0x77648000, 0xffff8000, "xvssrani.hu.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2437   { 0x77650000, 0xffff0000, "xvssrani.wu.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2438   { 0x77660000, 0xfffe0000, "xvssrani.du.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2439   { 0x77684000, 0xffffc000, "xvssrarni.b.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2440   { 0x77688000, 0xffff8000, "xvssrarni.h.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2441   { 0x77690000, 0xffff0000, "xvssrarni.w.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2442   { 0x776a0000, 0xfffe0000, "xvssrarni.d.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2443   { 0x776c4000, 0xffffc000, "xvssrarni.bu.h",	"x0:5,x5:5,u10:4",	0, 0, 0, 0},
2444   { 0x776c8000, 0xffff8000, "xvssrarni.hu.w",	"x0:5,x5:5,u10:5",	0, 0, 0, 0},
2445   { 0x776d0000, 0xffff0000, "xvssrarni.wu.d",	"x0:5,x5:5,u10:6",	0, 0, 0, 0},
2446   { 0x776e0000, 0xfffe0000, "xvssrarni.du.q",	"x0:5,x5:5,u10:7",	0, 0, 0, 0},
2447   { 0x77800000, 0xfffc0000, "xvextrins.d",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2448   { 0x77840000, 0xfffc0000, "xvextrins.w",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2449   { 0x77880000, 0xfffc0000, "xvextrins.h",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2450   { 0x778c0000, 0xfffc0000, "xvextrins.b",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2451   { 0x77900000, 0xfffc0000, "xvshuf4i.b",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2452   { 0x77940000, 0xfffc0000, "xvshuf4i.h",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2453   { 0x77980000, 0xfffc0000, "xvshuf4i.w",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2454   { 0x779c0000, 0xfffc0000, "xvshuf4i.d",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2455   { 0x77c40000, 0xfffc0000, "xvbitseli.b",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2456   { 0x77d00000, 0xfffc0000, "xvandi.b",		"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2457   { 0x77d40000, 0xfffc0000, "xvori.b",		"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2458   { 0x77d80000, 0xfffc0000, "xvxori.b",		"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2459   { 0x77dc0000, 0xfffc0000, "xvnori.b",		"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2460   { 0,		0,	    "xvrepli.b",	"x,s0:10",		"xvldi %1,(%2)&0x3ff",		0, 0, 0},
2461   { 0,		0,	    "xvrepli.d",	"x,s0:10",		"xvldi %1,((%2)&0x3ff)|0xc00",	0, 0, 0},
2462   { 0,		0,	    "xvrepli.h",	"x,s0:10",		"xvldi %1,((%2)&0x3ff)|0x400",	0, 0, 0},
2463   { 0,		0,	    "xvrepli.w",	"x,s0:10",		"xvldi %1,((%2)&0x3ff)|0x800",	0, 0, 0},
2464   { 0x77e00000, 0xfffc0000, "xvldi",		"x0:5,s5:13",		0, 0, 0, 0},
2465   { 0x77e40000, 0xfffc0000, "xvpermi.w",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2466   { 0x77e80000, 0xfffc0000, "xvpermi.d",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2467   { 0x77ec0000, 0xfffc0000, "xvpermi.q",	"x0:5,x5:5,u10:8",	0, 0, 0, 0},
2468   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list. */
2469 };
2470 
2471 static struct loongarch_opcode loongarch_lvz_opcodes[] =
2472 {
2473   /* match,    mask,	   name,	format,			macro, include, exclude, pinfo.  */
2474   {0x05000000, 0xff0003e0, "gcsrrd",	"r0:5,u10:14",		0, 0, 0, 0},
2475   {0x05000020, 0xff0003e0, "gcsrwr",	"r0:5,u10:14",		0, 0, 0, 0},
2476   {0x05000000, 0xff000000, "gcsrxchg",	"r0:5,r5:5,u10:14",	0, 0, 0, 0},
2477   {0x06482401, 0xffffffff, "gtlbflush",	"",			0, 0, 0, 0},
2478   {0x002b8000, 0xffff8000, "hvcl",	"u0:15",		0, 0, 0, 0},
2479   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
2480 };
2481 
2482 static struct loongarch_opcode loongarch_lbt_opcodes[] =
2483 {
2484   /* match,    mask,	   name,		format,			macro, include, exclude, pinfo.  */
2485   {0x00000800, 0xfffffc1c, "movgr2scr",		"cr0:2,r5:5",		0, 0, 0, 0},
2486   {0x00000c00, 0xffffff80, "movscr2gr",		"r0:5,cr5:2",		0, 0, 0, 0},
2487   {0x48000200, 0xfc0003e0, "jiscr0",		"s0:5|10:16<<2",	0, 0, 0, 0},
2488   {0x48000300, 0xfc0003e0, "jiscr1",		"s0:5|10:16<<2",	0, 0, 0, 0},
2489   {0x00290000, 0xffff8000, "addu12i.w",		"r0:5,r5:5,s10:5",	0, 0, 0, 0},
2490   {0x00298000, 0xffff8000, "addu12i.d",		"r0:5,r5:5,s10:5",	0, 0, 0, 0},
2491   {0x00300000, 0xffff8000, "adc.b",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2492   {0x00308000, 0xffff8000, "adc.h",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2493   {0x00310000, 0xffff8000, "adc.w",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2494   {0x00318000, 0xffff8000, "adc.d",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2495   {0x00320000, 0xffff8000, "sbc.b",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2496   {0x00328000, 0xffff8000, "sbc.h",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2497   {0x00330000, 0xffff8000, "sbc.w",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2498   {0x00338000, 0xffff8000, "sbc.d",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2499   {0x001a0000, 0xffff8000, "rotr.b",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2500   {0x001a8000, 0xffff8000, "rotr.h",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2501   {0x004c2000, 0xffffe000, "rotri.b",		"r0:5,r5:5,u10:3",	0, 0, 0, 0},
2502   {0x004c4000, 0xffffc000, "rotri.h",		"r0:5,r5:5,u10:4",	0, 0, 0, 0},
2503   {0x00340000, 0xffff8000, "rcr.b",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2504   {0x00348000, 0xffff8000, "rcr.h",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2505   {0x00350000, 0xffff8000, "rcr.w",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2506   {0x00358000, 0xffff8000, "rcr.d",		"r0:5,r5:5,r10:5",	0, 0, 0, 0},
2507   {0x00502000, 0xffffe000, "rcri.b",		"r0:5,r5:5,u10:3",	0, 0, 0, 0},
2508   {0x00504000, 0xffffc000, "rcri.h",		"r0:5,r5:5,u10:4",	0, 0, 0, 0},
2509   {0x00508000, 0xffff8000, "rcri.w",		"r0:5,r5:5,u10:5",	0, 0, 0, 0},
2510   {0x00510000, 0xffff0000, "rcri.d",		"r0:5,r5:5,u10:6",	0, 0, 0, 0},
2511   {0x0114e400, 0xfffffc00, "fcvt.ud.d",		"f0:5,f5:5",		0, 0, 0, 0},
2512   {0x0114e000, 0xfffffc00, "fcvt.ld.d",		"f0:5,f5:5",		0, 0, 0, 0},
2513   {0x01150000, 0xffff8000, "fcvt.d.ld",		"f0:5,f5:5,f10:5",	0, 0, 0, 0},
2514   {0x2e800000, 0xffc00000, "ldl.d",		"r0:5,r5:5,so10:12",	0, 0, 0, 0},
2515   {0x2e000000, 0xffc00000, "ldl.w",		"r0:5,r5:5,so10:12",	0, 0, 0, 0},
2516   {0x2e400000, 0xffc00000, "ldr.w",		"r0:5,r5:5,so10:12",	0, 0, 0, 0},
2517   {0x2ec00000, 0xffc00000, "ldr.d",		"r0:5,r5:5,so10:12",	0, 0, 0, 0},
2518   {0x2f000000, 0xffc00000, "stl.w",		"r0:5,r5:5,so10:12",	0, 0, 0, 0},
2519   {0x2f800000, 0xffc00000, "stl.d",		"r0:5,r5:5,so10:12",	0, 0, 0, 0},
2520   {0x2f400000, 0xffc00000, "str.w",		"r0:5,r5:5,so10:12",	0, 0, 0, 0},
2521   {0x2fc00000, 0xffc00000, "str.d",		"r0:5,r5:5,so10:12",	0, 0, 0, 0},
2522   {0x003f000c, 0xffff801f, "x86adc.b",		"r5:5,r10:5",		0, 0, 0, 0},
2523   {0x003f000d, 0xffff801f, "x86adc.h",		"r5:5,r10:5",		0, 0, 0, 0},
2524   {0x003f000e, 0xffff801f, "x86adc.w",		"r5:5,r10:5",		0, 0, 0, 0},
2525   {0x003f000f, 0xffff801f, "x86adc.d",		"r5:5,r10:5",		0, 0, 0, 0},
2526   {0x003f0004, 0xffff801f, "x86add.b",		"r5:5,r10:5",		0, 0, 0, 0},
2527   {0x003f0005, 0xffff801f, "x86add.h",		"r5:5,r10:5",		0, 0, 0, 0},
2528   {0x003f0006, 0xffff801f, "x86add.w",		"r5:5,r10:5",		0, 0, 0, 0},
2529   {0x003f0007, 0xffff801f, "x86add.d",		"r5:5,r10:5",		0, 0, 0, 0},
2530   {0x003f0000, 0xffff801f, "x86add.wu",		"r5:5,r10:5",		0, 0, 0, 0},
2531   {0x003f0001, 0xffff801f, "x86add.du",		"r5:5,r10:5",		0, 0, 0, 0},
2532   {0x00008000, 0xfffffc1f, "x86inc.b",		"r5:5",			0, 0, 0, 0},
2533   {0x00008001, 0xfffffc1f, "x86inc.h",		"r5:5",			0, 0, 0, 0},
2534   {0x00008002, 0xfffffc1f, "x86inc.w",		"r5:5",			0, 0, 0, 0},
2535   {0x00008003, 0xfffffc1f, "x86inc.d",		"r5:5",			0, 0, 0, 0},
2536   {0x003f0010, 0xffff801f, "x86sbc.b",		"r5:5,r10:5",		0, 0, 0, 0},
2537   {0x003f0011, 0xffff801f, "x86sbc.h",		"r5:5,r10:5",		0, 0, 0, 0},
2538   {0x003f0012, 0xffff801f, "x86sbc.w",		"r5:5,r10:5",		0, 0, 0, 0},
2539   {0x003f0013, 0xffff801f, "x86sbc.d",		"r5:5,r10:5",		0, 0, 0, 0},
2540   {0x003f0008, 0xffff801f, "x86sub.b",		"r5:5,r10:5",		0, 0, 0, 0},
2541   {0x003f0009, 0xffff801f, "x86sub.h",		"r5:5,r10:5",		0, 0, 0, 0},
2542   {0x003f000a, 0xffff801f, "x86sub.w",		"r5:5,r10:5",		0, 0, 0, 0},
2543   {0x003f000b, 0xffff801f, "x86sub.d",		"r5:5,r10:5",		0, 0, 0, 0},
2544   {0x003f0002, 0xffff801f, "x86sub.wu",		"r5:5,r10:5",		0, 0, 0, 0},
2545   {0x003f0003, 0xffff801f, "x86sub.du",		"r5:5,r10:5",		0, 0, 0, 0},
2546   {0x00008004, 0xfffffc1f, "x86dec.b",		"r5:5",			0, 0, 0, 0},
2547   {0x00008005, 0xfffffc1f, "x86dec.h",		"r5:5",			0, 0, 0, 0},
2548   {0x00008006, 0xfffffc1f, "x86dec.w",		"r5:5",			0, 0, 0, 0},
2549   {0x00008007, 0xfffffc1f, "x86dec.d",		"r5:5",			0, 0, 0, 0},
2550   {0x003f8010, 0xffff801f, "x86and.b",		"r5:5,r10:5",		0, 0, 0, 0},
2551   {0x003f8011, 0xffff801f, "x86and.h",		"r5:5,r10:5",		0, 0, 0, 0},
2552   {0x003f8012, 0xffff801f, "x86and.w",		"r5:5,r10:5",		0, 0, 0, 0},
2553   {0x003f8013, 0xffff801f, "x86and.d",		"r5:5,r10:5",		0, 0, 0, 0},
2554   {0x003f8014, 0xffff801f, "x86or.b",		"r5:5,r10:5",		0, 0, 0, 0},
2555   {0x003f8015, 0xffff801f, "x86or.h",		"r5:5,r10:5",		0, 0, 0, 0},
2556   {0x003f8016, 0xffff801f, "x86or.w",		"r5:5,r10:5",		0, 0, 0, 0},
2557   {0x003f8017, 0xffff801f, "x86or.d",		"r5:5,r10:5",		0, 0, 0, 0},
2558   {0x003f8018, 0xffff801f, "x86xor.b",		"r5:5,r10:5",		0, 0, 0, 0},
2559   {0x003f8019, 0xffff801f, "x86xor.h",		"r5:5,r10:5",		0, 0, 0, 0},
2560   {0x003f801a, 0xffff801f, "x86xor.w",		"r5:5,r10:5",		0, 0, 0, 0},
2561   {0x003f801b, 0xffff801f, "x86xor.d",		"r5:5,r10:5",		0, 0, 0, 0},
2562   {0x003e8000, 0xffff801f, "x86mul.b",		"r5:5,r10:5",		0, 0, 0, 0},
2563   {0x003e8001, 0xffff801f, "x86mul.h",		"r5:5,r10:5",		0, 0, 0, 0},
2564   {0x003e8002, 0xffff801f, "x86mul.w",		"r5:5,r10:5",		0, 0, 0, 0},
2565   {0x003e8003, 0xffff801f, "x86mul.d",		"r5:5,r10:5",		0, 0, 0, 0},
2566   {0x003e8004, 0xffff801f, "x86mul.bu",		"r5:5,r10:5",		0, 0, 0, 0},
2567   {0x003e8005, 0xffff801f, "x86mul.hu",		"r5:5,r10:5",		0, 0, 0, 0},
2568   {0x003e8006, 0xffff801f, "x86mul.wu",		"r5:5,r10:5",		0, 0, 0, 0},
2569   {0x003e8007, 0xffff801f, "x86mul.du",		"r5:5,r10:5",		0, 0, 0, 0},
2570   {0x003f800c, 0xffff801f, "x86rcl.b",		"r5:5,r10:5",		0, 0, 0, 0},
2571   {0x003f800d, 0xffff801f, "x86rcl.h",		"r5:5,r10:5",		0, 0, 0, 0},
2572   {0x003f800e, 0xffff801f, "x86rcl.w",		"r5:5,r10:5",		0, 0, 0, 0},
2573   {0x003f800f, 0xffff801f, "x86rcl.d",		"r5:5,r10:5",		0, 0, 0, 0},
2574   {0x00542018, 0xffffe01f, "x86rcli.b",		"r5:5,u10:3",		0, 0, 0, 0},
2575   {0x00544019, 0xffffc01f, "x86rcli.h",		"r5:5,u10:4",		0, 0, 0, 0},
2576   {0x0054801a, 0xffff801f, "x86rcli.w",		"r5:5,u10:5",		0, 0, 0, 0},
2577   {0x0055001b, 0xffff001f, "x86rcli.d",		"r5:5,u10:6",		0, 0, 0, 0},
2578   {0x003f8008, 0xffff801f, "x86rcr.b",		"r5:5,r10:5",		0, 0, 0, 0},
2579   {0x003f8009, 0xffff801f, "x86rcr.h",		"r5:5,r10:5",		0, 0, 0, 0},
2580   {0x003f800a, 0xffff801f, "x86rcr.w",		"r5:5,r10:5",		0, 0, 0, 0},
2581   {0x003f800b, 0xffff801f, "x86rcr.d",		"r5:5,r10:5",		0, 0, 0, 0},
2582   {0x00542010, 0xffffe01f, "x86rcri.b",		"r5:5,u10:3",		0, 0, 0, 0},
2583   {0x00544011, 0xffffc01f, "x86rcri.h",		"r5:5,u10:4",		0, 0, 0, 0},
2584   {0x00548012, 0xffff801f, "x86rcri.w",		"r5:5,u10:5",		0, 0, 0, 0},
2585   {0x00550013, 0xffff001f, "x86rcri.d",		"r5:5,u10:6",		0, 0, 0, 0},
2586   {0x003f8004, 0xffff801f, "x86rotl.b",		"r5:5,r10:5",		0, 0, 0, 0},
2587   {0x003f8005, 0xffff801f, "x86rotl.h",		"r5:5,r10:5",		0, 0, 0, 0},
2588   {0x003f8006, 0xffff801f, "x86rotl.w",		"r5:5,r10:5",		0, 0, 0, 0},
2589   {0x003f8007, 0xffff801f, "x86rotl.d",		"r5:5,r10:5",		0, 0, 0, 0},
2590   {0x00542014, 0xffffe01f, "x86rotli.b",	"r5:5,u10:3",		0, 0, 0, 0},
2591   {0x00544015, 0xffffc01f, "x86rotli.h",	"r5:5,u10:4",		0, 0, 0, 0},
2592   {0x00548016, 0xffff801f, "x86rotli.w",	"r5:5,u10:5",		0, 0, 0, 0},
2593   {0x00550017, 0xffff001f, "x86rotli.d",	"r5:5,u10:6",		0, 0, 0, 0},
2594   {0x003f8000, 0xffff801f, "x86rotr.b",		"r5:5,r10:5",		0, 0, 0, 0},
2595   {0x003f8001, 0xffff801f, "x86rotr.h",		"r5:5,r10:5",		0, 0, 0, 0},
2596   {0x003f8002, 0xffff801f, "x86rotr.d",		"r5:5,r10:5",		0, 0, 0, 0},
2597   {0x003f8003, 0xffff801f, "x86rotr.w",		"r5:5,r10:5",		0, 0, 0, 0},
2598   {0x0054200c, 0xffffe01f, "x86rotri.b",	"r5:5,u10:3",		0, 0, 0, 0},
2599   {0x0054400d, 0xffffc01f, "x86rotri.h",	"r5:5,u10:4",		0, 0, 0, 0},
2600   {0x0054800e, 0xffff801f, "x86rotri.w",	"r5:5,u10:5",		0, 0, 0, 0},
2601   {0x0055000f, 0xffff001f, "x86rotri.d",	"r5:5,u10:6",		0, 0, 0, 0},
2602   {0x003f0014, 0xffff801f, "x86sll.b",		"r5:5,r10:5",		0, 0, 0, 0},
2603   {0x003f0015, 0xffff801f, "x86sll.h",		"r5:5,r10:5",		0, 0, 0, 0},
2604   {0x003f0016, 0xffff801f, "x86sll.w",		"r5:5,r10:5",		0, 0, 0, 0},
2605   {0x003f0017, 0xffff801f, "x86sll.d",		"r5:5,r10:5",		0, 0, 0, 0},
2606   {0x00542000, 0xffffe01f, "x86slli.b",		"r5:5,u10:3",		0, 0, 0, 0},
2607   {0x00544001, 0xffffc01f, "x86slli.h",		"r5:5,u10:4",		0, 0, 0, 0},
2608   {0x00548002, 0xffff801f, "x86slli.w",		"r5:5,u10:5",		0, 0, 0, 0},
2609   {0x00550003, 0xffff001f, "x86slli.d",		"r5:5,u10:6",		0, 0, 0, 0},
2610   {0x003f0018, 0xffff801f, "x86srl.b",		"r5:5,r10:5",		0, 0, 0, 0},
2611   {0x003f0019, 0xffff801f, "x86srl.h",		"r5:5,r10:5",		0, 0, 0, 0},
2612   {0x003f001a, 0xffff801f, "x86srl.w",		"r5:5,r10:5",		0, 0, 0, 0},
2613   {0x003f001b, 0xffff801f, "x86srl.d",		"r5:5,r10:5",		0, 0, 0, 0},
2614   {0x00542004, 0xffffe01f, "x86srli.b",		"r5:5,u10:3",		0, 0, 0, 0},
2615   {0x00544005, 0xffffc01f, "x86srli.h",		"r5:5,u10:4",		0, 0, 0, 0},
2616   {0x00548006, 0xffff801f, "x86srli.w",		"r5:5,u10:5",		0, 0, 0, 0},
2617   {0x00550007, 0xffff001f, "x86srli.d",		"r5:5,u10:6",		0, 0, 0, 0},
2618   {0x003f001c, 0xffff801f, "x86sra.b",		"r5:5,r10:5",		0, 0, 0, 0},
2619   {0x003f001d, 0xffff801f, "x86sra.h",		"r5:5,r10:5",		0, 0, 0, 0},
2620   {0x003f001e, 0xffff801f, "x86sra.w",		"r5:5,r10:5",		0, 0, 0, 0},
2621   {0x003f001f, 0xffff801f, "x86sra.d",		"r5:5,r10:5",		0, 0, 0, 0},
2622   {0x00542008, 0xffffe01f, "x86srai.b",		"r5:5,u10:3",		0, 0, 0, 0},
2623   {0x00544009, 0xffffc01f, "x86srai.h",		"r5:5,u10:4",		0, 0, 0, 0},
2624   {0x0054800a, 0xffff801f, "x86srai.w",		"r5:5,u10:5",		0, 0, 0, 0},
2625   {0x0055000b, 0xffff001f, "x86srai.d",		"r5:5,u10:6",		0, 0, 0, 0},
2626   {0x00368000, 0xffffc3e0, "setx86j",		"r0:5,u10:4",		0, 0, 0, 0},
2627   {0x00007800, 0xfffffc00, "setx86loope",	"r0:5,r5:5",		0, 0, 0, 0},
2628   {0x00007c00, 0xfffffc00, "setx86loopne",	"r0:5,r5:5",		0, 0, 0, 0},
2629   {0x005c0000, 0xfffc03e0, "x86mfflag",		"r0:5,u10:8",		0, 0, 0, 0},
2630   {0x005c0020, 0xfffc03e0, "x86mtflag",		"r0:5,u10:8",		0, 0, 0, 0},
2631   {0x00007400, 0xffffffe0, "x86mftop",		"r0:5",			0, 0, 0, 0},
2632   {0x00007000, 0xffffff1f, "x86mttop",		"u5:3",			0, 0, 0, 0},
2633   {0x00008009, 0xffffffff, "x86inctop",		"",			0, 0, 0, 0},
2634   {0x00008029, 0xffffffff, "x86dectop",		"",			0, 0, 0, 0},
2635   {0x00008008, 0xffffffff, "x86settm",		"",			0, 0, 0, 0},
2636   {0x00008028, 0xffffffff, "x86clrtm",		"",			0, 0, 0, 0},
2637   {0x00580000, 0xfffc0000, "x86settag",		"r0:5,u5:5,u10:8",	0, 0, 0, 0},
2638   {0x00370010, 0xffff8010, "armadd.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2639   {0x00378010, 0xffff8010, "armsub.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2640   {0x00380010, 0xffff8010, "armadc.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2641   {0x00388010, 0xffff8010, "armsbc.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2642   {0x00390010, 0xffff8010, "armand.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2643   {0x00398010, 0xffff8010, "armor.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2644   {0x003a0010, 0xffff8010, "armxor.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2645   {0x003fc01c, 0xffffc01f, "armnot.w",		"r5:5,u10:4",		0, 0, 0, 0},
2646   {0x003a8010, 0xffff8010, "armsll.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2647   {0x003b0010, 0xffff8010, "armsrl.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2648   {0x003b8010, 0xffff8010, "armsra.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2649   {0x003c0010, 0xffff8010, "armrotr.w",		"r5:5,r10:5,u0:4",	0, 0, 0, 0},
2650   {0x003c8010, 0xffff8010, "armslli.w",		"r5:5,u10:5,u0:4",	0, 0, 0, 0},
2651   {0x003d0010, 0xffff8010, "armsrli.w",		"r5:5,u10:5,u0:4",	0, 0, 0, 0},
2652   {0x003d8010, 0xffff8010, "armsrai.w",		"r5:5,u10:5,u0:4",	0, 0, 0, 0},
2653   {0x003e0010, 0xffff8010, "armrotri.w",	"r5:5,u10:5,u0:4",	0, 0, 0, 0},
2654   {0x003fc01f, 0xffffc01f, "armrrx.w",		"r5:5,u10:4",		0, 0, 0, 0},
2655   {0x00364000, 0xffffc000, "armmove",		"r0:5,r5:5,u10:4",	0, 0, 0, 0},
2656   {0x003fc01d, 0xffffc01f, "armmov.w",		"r5:5,u10:4",		0, 0, 0, 0},
2657   {0x003fc01e, 0xffffc01f, "armmov.d",		"r5:5,u10:4",		0, 0, 0, 0},
2658   {0x005c0040, 0xfffc03e0, "armmfflag",		"r0:5,u10:8",		0, 0, 0, 0},
2659   {0x005c0060, 0xfffc03e0, "armmtflag",		"r0:5,u10:8",		0, 0, 0, 0},
2660   {0x0036c000, 0xffffc3e0, "setarmj",		"r0:5,u10:4",		0, 0, 0, 0},
2661   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
2662 };
2663 
2664 struct loongarch_ase loongarch_ASEs[] =
2665 {
2666   { &LARCH_opts.ase_ilp32, loongarch_macro_opcodes,		0, 0, { 0 }, 0, 0 },
2667   { &LARCH_opts.ase_ilp32, loongarch_alias_opcodes,		0, 0, { 0 }, 0, 0 },
2668   { &LARCH_opts.ase_ilp32, loongarch_imm_opcodes,		0, 0, { 0 }, 0, 0 },
2669   { &LARCH_opts.ase_ilp32, loongarch_privilege_opcodes,		0, 0, { 0 }, 0, 0 },
2670   { &LARCH_opts.ase_ilp32, loongarch_load_store_opcodes,	0, 0, { 0 }, 0, 0 },
2671   { &LARCH_opts.ase_ilp32, loongarch_fix_opcodes,		0, 0, { 0 }, 0, 0 },
2672   { &LARCH_opts.ase_ilp32, loongarch_jmp_opcodes,		0, 0, { 0 }, 0, 0 },
2673   { &LARCH_opts.ase_sf, loongarch_float_jmp_opcodes,		0, 0, { 0 }, 0, 0 },
2674   { &LARCH_opts.ase_sf, loongarch_single_float_opcodes,		0, 0, { 0 }, 0, 0 },
2675   { &LARCH_opts.ase_df, loongarch_double_float_opcodes,		0, 0, { 0 }, 0, 0 },
2676   { &LARCH_opts.ase_sf, loongarch_4opt_single_float_opcodes,		0, 0, { 0 }, 0, 0 },
2677   { &LARCH_opts.ase_df, loongarch_4opt_double_float_opcodes,		0, 0, { 0 }, 0, 0 },
2678   { &LARCH_opts.ase_sf, loongarch_single_float_load_store_opcodes,	0, 0, { 0 }, 0, 0 },
2679   { &LARCH_opts.ase_df, loongarch_double_float_load_store_opcodes,	0, 0, { 0 }, 0, 0 },
2680   { &LARCH_opts.ase_lsx,  loongarch_lsx_opcodes,  0, 0, { 0 }, 0, 0 },
2681   { &LARCH_opts.ase_lasx, loongarch_lasx_opcodes, 0, 0, { 0 }, 0, 0 },
2682   { &LARCH_opts.ase_lvz,  loongarch_lvz_opcodes,  0, 0, { 0 }, 0, 0 },
2683   { &LARCH_opts.ase_lbt,  loongarch_lbt_opcodes,  0, 0, { 0 }, 0, 0 },
2684   { 0, 0, 0, 0, { 0 }, 0, 0 },
2685 };
2686