public inbox for binutils-cvs@sourceware.org
 help / color / mirror / Atom feed
* [binutils-gdb] LoongArch: gas: Add lsx and lasx instructions support
@ 2023-06-28  8:15 liu & zhensong
  0 siblings, 0 replies; only message in thread
From: liu & zhensong @ 2023-06-28  8:15 UTC (permalink / raw)
  To: bfd-cvs

https://sourceware.org/git/gitweb.cgi?p=binutils-gdb.git;h=75b2f521b101d974354f6ce9ed7c054d8b2e3b7a

commit 75b2f521b101d974354f6ce9ed7c054d8b2e3b7a
Author: mengqinggang <mengqinggang@loongson.cn>
Date:   Thu Jun 22 10:35:28 2023 +0800

    LoongArch: gas: Add lsx and lasx instructions support
    
    gas/ChangeLog:
    
            * config/tc-loongarch.c (md_parse_option): Add lsx and lasx option.
            (loongarch_after_parse_args): Add lsx and lasx option.
    
    opcodes/ChangeLog:
    
            * loongarch-opc.c (struct loongarch_ase): Add lsx and lasx
            instructions.

Diff:
---
 gas/config/tc-loongarch.c |    4 +
 opcodes/loongarch-opc.c   | 1465 +++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 1469 insertions(+)

diff --git a/gas/config/tc-loongarch.c b/gas/config/tc-loongarch.c
index 4ea7b87fb79..7366e766a49 100644
--- a/gas/config/tc-loongarch.c
+++ b/gas/config/tc-loongarch.c
@@ -166,6 +166,8 @@ md_parse_option (int c, const char *arg)
 	{
 	  LARCH_opts.ase_ilp32 = 1;
 	  LARCH_opts.ase_lp64 = 1;
+	  LARCH_opts.ase_lsx = 1;
+	  LARCH_opts.ase_lasx = 1;
 	  LARCH_opts.ase_abi = lp64[suf[4]];
 	}
       else if (strncasecmp (arg, "ilp32", 5) == 0 && ilp32[suf[5]] != 0)
@@ -241,6 +243,8 @@ loongarch_after_parse_args ()
 	  LARCH_opts.ase_abi = EF_LOONGARCH_ABI_DOUBLE_FLOAT;
 	  LARCH_opts.ase_ilp32 = 1;
 	  LARCH_opts.ase_lp64 = 1;
+	  LARCH_opts.ase_lsx = 1;
+	  LARCH_opts.ase_lasx = 1;
 	}
       else if (strcmp (default_arch, "loongarch32") == 0)
 	{
diff --git a/opcodes/loongarch-opc.c b/opcodes/loongarch-opc.c
index e557b23105c..bd104465ca7 100644
--- a/opcodes/loongarch-opc.c
+++ b/opcodes/loongarch-opc.c
@@ -589,6 +589,14 @@ static struct loongarch_opcode loongarch_4opt_single_float_opcodes[] =
   { 0x08500000, 0xfff00000,	"fmsub.s",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
   { 0x08900000, 0xfff00000,	"fnmadd.s",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
   { 0x08d00000, 0xfff00000,	"fnmsub.s",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
+  { 0x09100000, 0xfff00000,     "vfmadd.s",     "v0:5,v5:5,v10:5,v15:5",        0,                      0,      0,      0 },
+  { 0x09500000, 0xfff00000,     "vfmsub.s",     "v0:5,v5:5,v10:5,v15:5",        0,                      0,      0,      0 },
+  { 0x09900000, 0xfff00000,     "vfnmadd.s",    "v0:5,v5:5,v10:5,v15:5",        0,                      0,      0,      0 },
+  { 0x09d00000, 0xfff00000,     "vfnmsub.s",    "v0:5,v5:5,v10:5,v15:5",        0,                      0,      0,      0 },
+  { 0x0a100000, 0xfff00000,     "xvfmadd.s",    "x0:5,x5:5,x10:5,x15:5",        0,                      0,      0,      0 },
+  { 0x0a500000, 0xfff00000,     "xvfmsub.s",    "x0:5,x5:5,x10:5,x15:5",        0,                      0,      0,      0 },
+  { 0x0a900000, 0xfff00000,     "xvfnmadd.s",   "x0:5,x5:5,x10:5,x15:5",        0,                      0,      0,      0 },
+  { 0x0ad00000, 0xfff00000,     "xvfnmsub.s",   "x0:5,x5:5,x10:5,x15:5",        0,                      0,      0,      0 },
   { 0x0c100000, 0xffff8018,	"fcmp.caf.s",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
   { 0x0c108000, 0xffff8018,	"fcmp.saf.s",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
   { 0x0c110000, 0xffff8018,	"fcmp.clt.s",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
@@ -615,7 +623,55 @@ static struct loongarch_opcode loongarch_4opt_single_float_opcodes[] =
   { 0x0c1a8000, 0xffff8018,	"fcmp.sor.s",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
   { 0x0c1c0000, 0xffff8018,	"fcmp.cune.s",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
   { 0x0c1c8000, 0xffff8018,	"fcmp.sune.s",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
+  { 0x0c500000, 0xffff8000,     "vfcmp.caf.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c508000, 0xffff8000,     "vfcmp.saf.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c510000, 0xffff8000,     "vfcmp.clt.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c518000, 0xffff8000,     "vfcmp.slt.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c520000, 0xffff8000,     "vfcmp.ceq.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c528000, 0xffff8000,     "vfcmp.seq.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c530000, 0xffff8000,     "vfcmp.cle.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c538000, 0xffff8000,     "vfcmp.sle.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c540000, 0xffff8000,     "vfcmp.cun.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c548000, 0xffff8000,     "vfcmp.sun.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c550000, 0xffff8000,     "vfcmp.cult.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c558000, 0xffff8000,     "vfcmp.sult.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c560000, 0xffff8000,     "vfcmp.cueq.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c568000, 0xffff8000,     "vfcmp.sueq.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c570000, 0xffff8000,     "vfcmp.cule.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c578000, 0xffff8000,     "vfcmp.sule.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c580000, 0xffff8000,     "vfcmp.cne.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c588000, 0xffff8000,     "vfcmp.sne.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c5a0000, 0xffff8000,     "vfcmp.cor.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c5a8000, 0xffff8000,     "vfcmp.sor.s",  "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c5c0000, 0xffff8000,     "vfcmp.cune.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c5c8000, 0xffff8000,     "vfcmp.sune.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c900000, 0xffff8000,     "xvfcmp.caf.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c908000, 0xffff8000,     "xvfcmp.saf.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c910000, 0xffff8000,     "xvfcmp.clt.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c918000, 0xffff8000,     "xvfcmp.slt.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c920000, 0xffff8000,     "xvfcmp.ceq.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c928000, 0xffff8000,     "xvfcmp.seq.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c930000, 0xffff8000,     "xvfcmp.cle.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c938000, 0xffff8000,     "xvfcmp.sle.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c940000, 0xffff8000,     "xvfcmp.cun.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c948000, 0xffff8000,     "xvfcmp.sun.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c950000, 0xffff8000,     "xvfcmp.cult.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c958000, 0xffff8000,     "xvfcmp.sult.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c960000, 0xffff8000,     "xvfcmp.cueq.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c968000, 0xffff8000,     "xvfcmp.sueq.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c970000, 0xffff8000,     "xvfcmp.cule.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c978000, 0xffff8000,     "xvfcmp.sule.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c980000, 0xffff8000,     "xvfcmp.cne.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c988000, 0xffff8000,     "xvfcmp.sne.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c9a0000, 0xffff8000,     "xvfcmp.cor.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c9a8000, 0xffff8000,     "xvfcmp.sor.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c9c0000, 0xffff8000,     "xvfcmp.cune.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0c9c8000, 0xffff8000,     "xvfcmp.sune.s", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
   { 0x0d000000, 0xfffc0000,	"fsel",		"f0:5,f5:5,f10:5,c15:3",	0,			0,	0,	0 },
+  { 0x0d100000, 0xfff00000, "vbitsel.v", "v0:5,v5:5,v10:5,v15:5", 0, 0, 0, 0},
+  { 0x0d200000, 0xfff00000, "xvbitsel.v", "x0:5,x5:5,x10:5,x15:5", 0, 0, 0, 0},
+  { 0x0d500000, 0xfff00000, "vshuf.b", "v0:5,v5:5,v10:5,v15:5", 0, 0, 0, 0},
+  { 0x0d600000, 0xfff00000, "xvshuf.b", "x0:5,x5:5,x10:5,x15:5", 0, 0, 0, 0},
   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
 };
 
@@ -626,6 +682,14 @@ static struct loongarch_opcode loongarch_4opt_double_float_opcodes[] =
   { 0x08600000, 0xfff00000,	"fmsub.d",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
   { 0x08a00000, 0xfff00000,	"fnmadd.d",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
   { 0x08e00000, 0xfff00000,	"fnmsub.d",	"f0:5,f5:5,f10:5,f15:5",	0,			0,	0,	0 },
+  { 0x09200000, 0xfff00000, "vfmadd.d", "v0:5,v5:5,v10:5,v15:5", 0, 0, 0, 0},
+  { 0x09600000, 0xfff00000, "vfmsub.d", "v0:5,v5:5,v10:5,v15:5", 0, 0, 0, 0},
+  { 0x09a00000, 0xfff00000, "vfnmadd.d", "v0:5,v5:5,v10:5,v15:5", 0, 0, 0, 0},
+  { 0x09e00000, 0xfff00000, "vfnmsub.d", "v0:5,v5:5,v10:5,v15:5", 0, 0, 0, 0},
+  { 0x0a200000, 0xfff00000, "xvfmadd.d", "x0:5,x5:5,x10:5,x15:5", 0, 0, 0, 0},
+  { 0x0a600000, 0xfff00000, "xvfmsub.d", "x0:5,x5:5,x10:5,x15:5", 0, 0, 0, 0},
+  { 0x0aa00000, 0xfff00000, "xvfnmadd.d", "x0:5,x5:5,x10:5,x15:5", 0, 0, 0, 0},
+  { 0x0ae00000, 0xfff00000, "xvfnmsub.d", "x0:5,x5:5,x10:5,x15:5", 0, 0, 0, 0},
   { 0x0c200000, 0xffff8018,	"fcmp.caf.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
   { 0x0c208000, 0xffff8018,	"fcmp.saf.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
   { 0x0c210000, 0xffff8018,	"fcmp.clt.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
@@ -652,6 +716,50 @@ static struct loongarch_opcode loongarch_4opt_double_float_opcodes[] =
   { 0x0c2a8000, 0xffff8018,	"fcmp.sor.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
   { 0x0c2c0000, 0xffff8018,	"fcmp.cune.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
   { 0x0c2c8000, 0xffff8018,	"fcmp.sune.d",	"c0:3,f5:5,f10:5",		0,			0,	0,	0 },
+  { 0x0c600000, 0xffff8000, "vfcmp.caf.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c608000, 0xffff8000, "vfcmp.saf.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c610000, 0xffff8000, "vfcmp.clt.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c618000, 0xffff8000, "vfcmp.slt.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c620000, 0xffff8000, "vfcmp.ceq.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c628000, 0xffff8000, "vfcmp.seq.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c630000, 0xffff8000, "vfcmp.cle.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c638000, 0xffff8000, "vfcmp.sle.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c640000, 0xffff8000, "vfcmp.cun.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c648000, 0xffff8000, "vfcmp.sun.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c650000, 0xffff8000, "vfcmp.cult.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c658000, 0xffff8000, "vfcmp.sult.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c660000, 0xffff8000, "vfcmp.cueq.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c668000, 0xffff8000, "vfcmp.sueq.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c670000, 0xffff8000, "vfcmp.cule.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c678000, 0xffff8000, "vfcmp.sule.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c680000, 0xffff8000, "vfcmp.cne.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c688000, 0xffff8000, "vfcmp.sne.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c6a0000, 0xffff8000, "vfcmp.cor.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c6a8000, 0xffff8000, "vfcmp.sor.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c6c0000, 0xffff8000, "vfcmp.cune.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0c6c8000, 0xffff8000, "vfcmp.sune.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x0ca00000, 0xffff8000, "xvfcmp.caf.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca08000, 0xffff8000, "xvfcmp.saf.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca10000, 0xffff8000, "xvfcmp.clt.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca18000, 0xffff8000, "xvfcmp.slt.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca20000, 0xffff8000, "xvfcmp.ceq.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca28000, 0xffff8000, "xvfcmp.seq.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca30000, 0xffff8000, "xvfcmp.cle.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca38000, 0xffff8000, "xvfcmp.sle.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca40000, 0xffff8000, "xvfcmp.cun.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca48000, 0xffff8000, "xvfcmp.sun.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca50000, 0xffff8000, "xvfcmp.cult.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca58000, 0xffff8000, "xvfcmp.sult.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca60000, 0xffff8000, "xvfcmp.cueq.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca68000, 0xffff8000, "xvfcmp.sueq.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca70000, 0xffff8000, "xvfcmp.cule.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca78000, 0xffff8000, "xvfcmp.sule.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca80000, 0xffff8000, "xvfcmp.cne.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0ca88000, 0xffff8000, "xvfcmp.sne.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0caa0000, 0xffff8000, "xvfcmp.cor.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0caa8000, 0xffff8000, "xvfcmp.sor.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0cac0000, 0xffff8000, "xvfcmp.cune.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x0cac8000, 0xffff8000, "xvfcmp.sune.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
 };
 
@@ -780,6 +888,30 @@ static struct loongarch_opcode loongarch_load_store_opcodes[] =
   { 0x387e8000, 0xffff8000,	"stle.h",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
   { 0x387f0000, 0xffff8000,	"stle.w",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
   { 0x387f8000, 0xffff8000,	"stle.d",	"r0:5,r5:5,r10:5",		0,			0,	0,	0 },
+  { 0x2c000000, 0xffc00000, "vld", "v0:5,r5:5,s10:12", 0, 0, 0, 0},
+  { 0x2c400000, 0xffc00000, "vst", "v0:5,r5:5,s10:12", 0, 0, 0, 0},
+  { 0x2c800000, 0xffc00000, "xvld", "x0:5,r5:5,s10:12", 0, 0, 0, 0},
+  { 0x2cc00000, 0xffc00000, "xvst", "x0:5,r5:5,s10:12", 0, 0, 0, 0},
+  { 0x38400000, 0xffff8000, "vldx", "v0:5,r5:5,r10:5", 0, 0, 0, 0},
+  { 0x38440000, 0xffff8000, "vstx", "v0:5,r5:5,r10:5", 0, 0, 0, 0},
+  { 0x38480000, 0xffff8000, "xvldx", "x0:5,r5:5,r10:5", 0, 0, 0, 0},
+  { 0x384c0000, 0xffff8000, "xvstx", "x0:5,r5:5,r10:5", 0, 0, 0, 0},
+  { 0x30100000, 0xfff80000, "vldrepl.d", "v0:5,r5:5,s10:9<<3", 0, 0, 0, 0},
+  { 0x30200000, 0xfff00000, "vldrepl.w", "v0:5,r5:5,s10:10<<2", 0, 0, 0, 0},
+  { 0x30400000, 0xffe00000, "vldrepl.h", "v0:5,r5:5,s10:11<<1", 0, 0, 0, 0},
+  { 0x30800000, 0xffc00000, "vldrepl.b", "v0:5,r5:5,s10:12", 0, 0, 0, 0},
+  { 0x31100000, 0xfff80000, "vstelm.d", "v0:5,r5:5,s10:8<<3,u18:1", 0, 0, 0, 0},
+  { 0x31200000, 0xfff00000, "vstelm.w", "v0:5,r5:5,s10:8<<2,u18:2", 0, 0, 0, 0},
+  { 0x31400000, 0xffe00000, "vstelm.h", "v0:5,r5:5,s10:8<<1,u18:3", 0, 0, 0, 0},
+  { 0x31800000, 0xffc00000, "vstelm.b", "v0:5,r5:5,s10:8,u18:4", 0, 0, 0, 0},
+  { 0x32100000, 0xfff80000, "xvldrepl.d", "x0:5,r5:5,s10:9<<3", 0, 0, 0, 0},
+  { 0x32200000, 0xfff00000, "xvldrepl.w", "x0:5,r5:5,s10:10<<2", 0, 0, 0, 0},
+  { 0x32400000, 0xffe00000, "xvldrepl.h", "x0:5,r5:5,s10:11<<1", 0, 0, 0, 0},
+  { 0x32800000, 0xffc00000, "xvldrepl.b", "x0:5,r5:5,s10:12", 0, 0, 0, 0},
+  { 0x33100000, 0xfff00000, "xvstelm.d", "x0:5,r5:5,s10:8<<3,u18:2", 0, 0, 0, 0},
+  { 0x33200000, 0xffe00000, "xvstelm.w", "x0:5,r5:5,s10:8<<2,u18:3", 0, 0, 0, 0},
+  { 0x33400000, 0xffc00000, "xvstelm.h", "x0:5,r5:5,s10:8<<1,u18:4", 0, 0, 0, 0},
+  { 0x33800000, 0xff800000, "xvstelm.b", "x0:5,r5:5,s10:8,u18:5", 0, 0, 0, 0},
   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
 };
 
@@ -858,6 +990,1337 @@ static struct loongarch_opcode loongarch_jmp_opcodes[] =
   { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
 };
 
+static struct loongarch_opcode loongarch_lsx_opcodes[] =
+{
+/* match,    mask,       name, format, macro, include, exclude, pinfo.  */
+  { 0x70000000, 0xffff8000, "vseq.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70008000, 0xffff8000, "vseq.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70010000, 0xffff8000, "vseq.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70018000, 0xffff8000, "vseq.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70020000, 0xffff8000, "vsle.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70028000, 0xffff8000, "vsle.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70030000, 0xffff8000, "vsle.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70038000, 0xffff8000, "vsle.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70040000, 0xffff8000, "vsle.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70048000, 0xffff8000, "vsle.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70050000, 0xffff8000, "vsle.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70058000, 0xffff8000, "vsle.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70060000, 0xffff8000, "vslt.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70068000, 0xffff8000, "vslt.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70070000, 0xffff8000, "vslt.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70078000, 0xffff8000, "vslt.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70080000, 0xffff8000, "vslt.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70088000, 0xffff8000, "vslt.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70090000, 0xffff8000, "vslt.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70098000, 0xffff8000, "vslt.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x700a0000, 0xffff8000, "vadd.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x700a8000, 0xffff8000, "vadd.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x700b0000, 0xffff8000, "vadd.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x700b8000, 0xffff8000, "vadd.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x700c0000, 0xffff8000, "vsub.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x700c8000, 0xffff8000, "vsub.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x700d0000, 0xffff8000, "vsub.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x700d8000, 0xffff8000, "vsub.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70460000, 0xffff8000, "vsadd.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70468000, 0xffff8000, "vsadd.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70470000, 0xffff8000, "vsadd.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70478000, 0xffff8000, "vsadd.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70480000, 0xffff8000, "vssub.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70488000, 0xffff8000, "vssub.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70490000, 0xffff8000, "vssub.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70498000, 0xffff8000, "vssub.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x704a0000, 0xffff8000, "vsadd.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x704a8000, 0xffff8000, "vsadd.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x704b0000, 0xffff8000, "vsadd.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x704b8000, 0xffff8000, "vsadd.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x704c0000, 0xffff8000, "vssub.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x704c8000, 0xffff8000, "vssub.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x704d0000, 0xffff8000, "vssub.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x704d8000, 0xffff8000, "vssub.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70540000, 0xffff8000, "vhaddw.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70548000, 0xffff8000, "vhaddw.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70550000, 0xffff8000, "vhaddw.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70558000, 0xffff8000, "vhaddw.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70560000, 0xffff8000, "vhsubw.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70568000, 0xffff8000, "vhsubw.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70570000, 0xffff8000, "vhsubw.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70578000, 0xffff8000, "vhsubw.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70580000, 0xffff8000, "vhaddw.hu.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70588000, 0xffff8000, "vhaddw.wu.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70590000, 0xffff8000, "vhaddw.du.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70598000, 0xffff8000, "vhaddw.qu.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x705a0000, 0xffff8000, "vhsubw.hu.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x705a8000, 0xffff8000, "vhsubw.wu.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x705b0000, 0xffff8000, "vhsubw.du.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x705b8000, 0xffff8000, "vhsubw.qu.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x705c0000, 0xffff8000, "vadda.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x705c8000, 0xffff8000, "vadda.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x705d0000, 0xffff8000, "vadda.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x705d8000, 0xffff8000, "vadda.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70600000, 0xffff8000, "vabsd.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70608000, 0xffff8000, "vabsd.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70610000, 0xffff8000, "vabsd.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70618000, 0xffff8000, "vabsd.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70620000, 0xffff8000, "vabsd.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70628000, 0xffff8000, "vabsd.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70630000, 0xffff8000, "vabsd.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70638000, 0xffff8000, "vabsd.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70640000, 0xffff8000, "vavg.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70648000, 0xffff8000, "vavg.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70650000, 0xffff8000, "vavg.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70658000, 0xffff8000, "vavg.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70660000, 0xffff8000, "vavg.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70668000, 0xffff8000, "vavg.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70670000, 0xffff8000, "vavg.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70678000, 0xffff8000, "vavg.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70680000, 0xffff8000, "vavgr.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70688000, 0xffff8000, "vavgr.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70690000, 0xffff8000, "vavgr.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70698000, 0xffff8000, "vavgr.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x706a0000, 0xffff8000, "vavgr.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x706a8000, 0xffff8000, "vavgr.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x706b0000, 0xffff8000, "vavgr.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x706b8000, 0xffff8000, "vavgr.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70700000, 0xffff8000, "vmax.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70708000, 0xffff8000, "vmax.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70710000, 0xffff8000, "vmax.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70718000, 0xffff8000, "vmax.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70720000, 0xffff8000, "vmin.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70728000, 0xffff8000, "vmin.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70730000, 0xffff8000, "vmin.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70738000, 0xffff8000, "vmin.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70740000, 0xffff8000, "vmax.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70748000, 0xffff8000, "vmax.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70750000, 0xffff8000, "vmax.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70758000, 0xffff8000, "vmax.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70760000, 0xffff8000, "vmin.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70768000, 0xffff8000, "vmin.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70770000, 0xffff8000, "vmin.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70778000, 0xffff8000, "vmin.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70840000, 0xffff8000, "vmul.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70848000, 0xffff8000, "vmul.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70850000, 0xffff8000, "vmul.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70858000, 0xffff8000, "vmul.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70860000, 0xffff8000, "vmuh.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70868000, 0xffff8000, "vmuh.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70870000, 0xffff8000, "vmuh.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70878000, 0xffff8000, "vmuh.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70880000, 0xffff8000, "vmuh.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70888000, 0xffff8000, "vmuh.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70890000, 0xffff8000, "vmuh.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70898000, 0xffff8000, "vmuh.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a80000, 0xffff8000, "vmadd.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a88000, 0xffff8000, "vmadd.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a90000, 0xffff8000, "vmadd.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a98000, 0xffff8000, "vmadd.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70aa0000, 0xffff8000, "vmsub.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70aa8000, 0xffff8000, "vmsub.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ab0000, 0xffff8000, "vmsub.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ab8000, 0xffff8000, "vmsub.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e00000, 0xffff8000, "vdiv.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e08000, 0xffff8000, "vdiv.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e10000, 0xffff8000, "vdiv.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e18000, 0xffff8000, "vdiv.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e20000, 0xffff8000, "vmod.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e28000, 0xffff8000, "vmod.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e30000, 0xffff8000, "vmod.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e38000, 0xffff8000, "vmod.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e40000, 0xffff8000, "vdiv.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e48000, 0xffff8000, "vdiv.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e50000, 0xffff8000, "vdiv.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e58000, 0xffff8000, "vdiv.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e60000, 0xffff8000, "vmod.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e68000, 0xffff8000, "vmod.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e70000, 0xffff8000, "vmod.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e78000, 0xffff8000, "vmod.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e80000, 0xffff8000, "vsll.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e88000, 0xffff8000, "vsll.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e90000, 0xffff8000, "vsll.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70e98000, 0xffff8000, "vsll.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ea0000, 0xffff8000, "vsrl.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ea8000, 0xffff8000, "vsrl.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70eb0000, 0xffff8000, "vsrl.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70eb8000, 0xffff8000, "vsrl.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ec0000, 0xffff8000, "vsra.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ec8000, 0xffff8000, "vsra.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ed0000, 0xffff8000, "vsra.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ed8000, 0xffff8000, "vsra.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ee0000, 0xffff8000, "vrotr.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ee8000, 0xffff8000, "vrotr.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ef0000, 0xffff8000, "vrotr.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ef8000, 0xffff8000, "vrotr.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f00000, 0xffff8000, "vsrlr.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f08000, 0xffff8000, "vsrlr.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f10000, 0xffff8000, "vsrlr.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f18000, 0xffff8000, "vsrlr.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f20000, 0xffff8000, "vsrar.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f28000, 0xffff8000, "vsrar.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f30000, 0xffff8000, "vsrar.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f38000, 0xffff8000, "vsrar.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f48000, 0xffff8000, "vsrln.b.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f50000, 0xffff8000, "vsrln.h.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f58000, 0xffff8000, "vsrln.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f68000, 0xffff8000, "vsran.b.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f70000, 0xffff8000, "vsran.h.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f78000, 0xffff8000, "vsran.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f88000, 0xffff8000, "vsrlrn.b.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f90000, 0xffff8000, "vsrlrn.h.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70f98000, 0xffff8000, "vsrlrn.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70fa8000, 0xffff8000, "vsrarn.b.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70fb0000, 0xffff8000, "vsrarn.h.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70fb8000, 0xffff8000, "vsrarn.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70fc8000, 0xffff8000, "vssrln.b.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70fd0000, 0xffff8000, "vssrln.h.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70fd8000, 0xffff8000, "vssrln.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70fe8000, 0xffff8000, "vssran.b.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ff0000, 0xffff8000, "vssran.h.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ff8000, 0xffff8000, "vssran.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71008000, 0xffff8000, "vssrlrn.b.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71010000, 0xffff8000, "vssrlrn.h.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71018000, 0xffff8000, "vssrlrn.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71028000, 0xffff8000, "vssrarn.b.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71030000, 0xffff8000, "vssrarn.h.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71038000, 0xffff8000, "vssrarn.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71048000, 0xffff8000, "vssrln.bu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71050000, 0xffff8000, "vssrln.hu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71058000, 0xffff8000, "vssrln.wu.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71068000, 0xffff8000, "vssran.bu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71070000, 0xffff8000, "vssran.hu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71078000, 0xffff8000, "vssran.wu.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71088000, 0xffff8000, "vssrlrn.bu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71090000, 0xffff8000, "vssrlrn.hu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71098000, 0xffff8000, "vssrlrn.wu.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710a8000, 0xffff8000, "vssrarn.bu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710b0000, 0xffff8000, "vssrarn.hu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710b8000, 0xffff8000, "vssrarn.wu.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710c0000, 0xffff8000, "vbitclr.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710c8000, 0xffff8000, "vbitclr.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710d0000, 0xffff8000, "vbitclr.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710d8000, 0xffff8000, "vbitclr.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710e0000, 0xffff8000, "vbitset.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710e8000, 0xffff8000, "vbitset.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710f0000, 0xffff8000, "vbitset.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x710f8000, 0xffff8000, "vbitset.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71100000, 0xffff8000, "vbitrev.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71108000, 0xffff8000, "vbitrev.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71110000, 0xffff8000, "vbitrev.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71118000, 0xffff8000, "vbitrev.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71160000, 0xffff8000, "vpackev.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71168000, 0xffff8000, "vpackev.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71170000, 0xffff8000, "vpackev.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71178000, 0xffff8000, "vpackev.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71180000, 0xffff8000, "vpackod.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71188000, 0xffff8000, "vpackod.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71190000, 0xffff8000, "vpackod.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71198000, 0xffff8000, "vpackod.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711a0000, 0xffff8000, "vilvl.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711a8000, 0xffff8000, "vilvl.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711b0000, 0xffff8000, "vilvl.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711b8000, 0xffff8000, "vilvl.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711c0000, 0xffff8000, "vilvh.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711c8000, 0xffff8000, "vilvh.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711d0000, 0xffff8000, "vilvh.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711d8000, 0xffff8000, "vilvh.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711e0000, 0xffff8000, "vpickev.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711e8000, 0xffff8000, "vpickev.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711f0000, 0xffff8000, "vpickev.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x711f8000, 0xffff8000, "vpickev.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71200000, 0xffff8000, "vpickod.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71208000, 0xffff8000, "vpickod.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71210000, 0xffff8000, "vpickod.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71218000, 0xffff8000, "vpickod.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71220000, 0xffff8000, "vreplve.b", "v0:5,v5:5,r10:5", 0, 0, 0, 0},
+  { 0x71228000, 0xffff8000, "vreplve.h", "v0:5,v5:5,r10:5", 0, 0, 0, 0},
+  { 0x71230000, 0xffff8000, "vreplve.w", "v0:5,v5:5,r10:5", 0, 0, 0, 0},
+  { 0x71238000, 0xffff8000, "vreplve.d", "v0:5,v5:5,r10:5", 0, 0, 0, 0},
+  { 0x71260000, 0xffff8000, "vand.v", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71268000, 0xffff8000, "vor.v", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71270000, 0xffff8000, "vxor.v", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71278000, 0xffff8000, "vnor.v", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71280000, 0xffff8000, "vandn.v", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71288000, 0xffff8000, "vorn.v", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x712b0000, 0xffff8000, "vfrstp.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x712b8000, 0xffff8000, "vfrstp.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x712d0000, 0xffff8000, "vadd.q", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x712d8000, 0xffff8000, "vsub.q", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x712e0000, 0xffff8000, "vsigncov.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x712e8000, 0xffff8000, "vsigncov.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x712f0000, 0xffff8000, "vsigncov.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x712f8000, 0xffff8000, "vsigncov.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71308000, 0xffff8000, "vfadd.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71310000, 0xffff8000, "vfadd.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71328000, 0xffff8000, "vfsub.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71330000, 0xffff8000, "vfsub.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71388000, 0xffff8000, "vfmul.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71390000, 0xffff8000, "vfmul.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x713a8000, 0xffff8000, "vfdiv.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x713b0000, 0xffff8000, "vfdiv.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x713c8000, 0xffff8000, "vfmax.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x713d0000, 0xffff8000, "vfmax.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x713e8000, 0xffff8000, "vfmin.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x713f0000, 0xffff8000, "vfmin.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71408000, 0xffff8000, "vfmaxa.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71410000, 0xffff8000, "vfmaxa.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71428000, 0xffff8000, "vfmina.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71430000, 0xffff8000, "vfmina.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71460000, 0xffff8000, "vfcvt.h.s", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71468000, 0xffff8000, "vfcvt.s.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71480000, 0xffff8000, "vffint.s.l", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x71498000, 0xffff8000, "vftint.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x714a0000, 0xffff8000, "vftintrm.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x714a8000, 0xffff8000, "vftintrp.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x714b0000, 0xffff8000, "vftintrz.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x714b8000, 0xffff8000, "vftintrne.w.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x717a8000, 0xffff8000, "vshuf.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x717b0000, 0xffff8000, "vshuf.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x717b8000, 0xffff8000, "vshuf.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x72800000, 0xffff8000, "vseqi.b", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72808000, 0xffff8000, "vseqi.h", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72810000, 0xffff8000, "vseqi.w", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72818000, 0xffff8000, "vseqi.d", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72820000, 0xffff8000, "vslei.b", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72828000, 0xffff8000, "vslei.h", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72830000, 0xffff8000, "vslei.w", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72838000, 0xffff8000, "vslei.d", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72840000, 0xffff8000, "vslei.bu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72848000, 0xffff8000, "vslei.hu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72850000, 0xffff8000, "vslei.wu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72858000, 0xffff8000, "vslei.du", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72860000, 0xffff8000, "vslti.b", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72868000, 0xffff8000, "vslti.h", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72870000, 0xffff8000, "vslti.w", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72878000, 0xffff8000, "vslti.d", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72880000, 0xffff8000, "vslti.bu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72888000, 0xffff8000, "vslti.hu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72890000, 0xffff8000, "vslti.wu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72898000, 0xffff8000, "vslti.du", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728a0000, 0xffff8000, "vaddi.bu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728a8000, 0xffff8000, "vaddi.hu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728b0000, 0xffff8000, "vaddi.wu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728b8000, 0xffff8000, "vaddi.du", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728c0000, 0xffff8000, "vsubi.bu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728c8000, 0xffff8000, "vsubi.hu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728d0000, 0xffff8000, "vsubi.wu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728d8000, 0xffff8000, "vsubi.du", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728e0000, 0xffff8000, "vbsll.v", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x728e8000, 0xffff8000, "vbsrl.v", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72900000, 0xffff8000, "vmaxi.b", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72908000, 0xffff8000, "vmaxi.h", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72910000, 0xffff8000, "vmaxi.w", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72918000, 0xffff8000, "vmaxi.d", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72920000, 0xffff8000, "vmini.b", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72928000, 0xffff8000, "vmini.h", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72930000, 0xffff8000, "vmini.w", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72938000, 0xffff8000, "vmini.d", "v0:5,v5:5,s10:5", 0, 0, 0, 0},
+  { 0x72940000, 0xffff8000, "vmaxi.bu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72948000, 0xffff8000, "vmaxi.hu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72950000, 0xffff8000, "vmaxi.wu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72958000, 0xffff8000, "vmaxi.du", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72960000, 0xffff8000, "vmini.bu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72968000, 0xffff8000, "vmini.hu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72970000, 0xffff8000, "vmini.wu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72978000, 0xffff8000, "vmini.du", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x729a0000, 0xffff8000, "vfrstpi.b", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x729a8000, 0xffff8000, "vfrstpi.h", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x729c0000, 0xfffffc00, "vclo.b", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c0400, 0xfffffc00, "vclo.h", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c0800, 0xfffffc00, "vclo.w", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c0c00, 0xfffffc00, "vclo.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c1000, 0xfffffc00, "vclz.b", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c1400, 0xfffffc00, "vclz.h", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c1800, 0xfffffc00, "vclz.w", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c1c00, 0xfffffc00, "vclz.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c2000, 0xfffffc00, "vpcnt.b", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c2400, 0xfffffc00, "vpcnt.h", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c2800, 0xfffffc00, "vpcnt.w", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c2c00, 0xfffffc00, "vpcnt.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c3000, 0xfffffc00, "vneg.b", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c3400, 0xfffffc00, "vneg.h", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c3800, 0xfffffc00, "vneg.w", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c3c00, 0xfffffc00, "vneg.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c4000, 0xfffffc00, "vmskltz.b", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c4400, 0xfffffc00, "vmskltz.h", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c4800, 0xfffffc00, "vmskltz.w", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c4c00, 0xfffffc00, "vmskltz.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c5000, 0xfffffc00, "vmskgez.b", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c6000, 0xfffffc00, "vmsknz.b", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729c9800, 0xfffffc18, "vseteqz.v", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729c9c00, 0xfffffc18, "vsetnez.v", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729ca000, 0xfffffc18, "vsetanyeqz.b", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729ca400, 0xfffffc18, "vsetanyeqz.h", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729ca800, 0xfffffc18, "vsetanyeqz.w", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729cac00, 0xfffffc18, "vsetanyeqz.d", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729cb000, 0xfffffc18, "vsetallnez.b", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729cb400, 0xfffffc18, "vsetallnez.h", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729cb800, 0xfffffc18, "vsetallnez.w", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729cbc00, 0xfffffc18, "vsetallnez.d", "c0:3,v5:5", 0, 0, 0, 0},
+  { 0x729cc400, 0xfffffc00, "vflogb.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729cc800, 0xfffffc00, "vflogb.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729cd400, 0xfffffc00, "vfclass.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729cd800, 0xfffffc00, "vfclass.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ce400, 0xfffffc00, "vfsqrt.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ce800, 0xfffffc00, "vfsqrt.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729cf400, 0xfffffc00, "vfrecip.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729cf800, 0xfffffc00, "vfrecip.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d0400, 0xfffffc00, "vfrsqrt.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d0800, 0xfffffc00, "vfrsqrt.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d3400, 0xfffffc00, "vfrint.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d3800, 0xfffffc00, "vfrint.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d4400, 0xfffffc00, "vfrintrm.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d4800, 0xfffffc00, "vfrintrm.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d5400, 0xfffffc00, "vfrintrp.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d5800, 0xfffffc00, "vfrintrp.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d6400, 0xfffffc00, "vfrintrz.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d6800, 0xfffffc00, "vfrintrz.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d7400, 0xfffffc00, "vfrintrne.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729d7800, 0xfffffc00, "vfrintrne.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729de800, 0xfffffc00, "vfcvtl.s.h", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729dec00, 0xfffffc00, "vfcvth.s.h", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729df000, 0xfffffc00, "vfcvtl.d.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729df400, 0xfffffc00, "vfcvth.d.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e0000, 0xfffffc00, "vffint.s.w", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e0400, 0xfffffc00, "vffint.s.wu", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e0800, 0xfffffc00, "vffint.d.l", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e0c00, 0xfffffc00, "vffint.d.lu", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e1000, 0xfffffc00, "vffintl.d.w", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e1400, 0xfffffc00, "vffinth.d.w", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e3000, 0xfffffc00, "vftint.w.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e3400, 0xfffffc00, "vftint.l.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e3800, 0xfffffc00, "vftintrm.w.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e3c00, 0xfffffc00, "vftintrm.l.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e4000, 0xfffffc00, "vftintrp.w.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e4400, 0xfffffc00, "vftintrp.l.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e4800, 0xfffffc00, "vftintrz.w.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e4c00, 0xfffffc00, "vftintrz.l.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e5000, 0xfffffc00, "vftintrne.w.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e5400, 0xfffffc00, "vftintrne.l.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e5800, 0xfffffc00, "vftint.wu.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e5c00, 0xfffffc00, "vftint.lu.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e7000, 0xfffffc00, "vftintrz.wu.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e7400, 0xfffffc00, "vftintrz.lu.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e8000, 0xfffffc00, "vftintl.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e8400, 0xfffffc00, "vftinth.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e8800, 0xfffffc00, "vftintrml.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e8c00, 0xfffffc00, "vftintrmh.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e9000, 0xfffffc00, "vftintrpl.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e9400, 0xfffffc00, "vftintrph.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e9800, 0xfffffc00, "vftintrzl.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729e9c00, 0xfffffc00, "vftintrzh.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ea000, 0xfffffc00, "vftintrnel.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ea400, 0xfffffc00, "vftintrneh.l.s", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ee000, 0xfffffc00, "vexth.h.b", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ee400, 0xfffffc00, "vexth.w.h", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ee800, 0xfffffc00, "vexth.d.w", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729eec00, 0xfffffc00, "vexth.q.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ef000, 0xfffffc00, "vexth.hu.bu", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ef400, 0xfffffc00, "vexth.wu.hu", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729ef800, 0xfffffc00, "vexth.du.wu", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729efc00, 0xfffffc00, "vexth.qu.du", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x729f0000, 0xfffffc00, "vreplgr2vr.b", "v0:5,r5:5", 0, 0, 0, 0},
+  { 0x729f0400, 0xfffffc00, "vreplgr2vr.h", "v0:5,r5:5", 0, 0, 0, 0},
+  { 0x729f0800, 0xfffffc00, "vreplgr2vr.w", "v0:5,r5:5", 0, 0, 0, 0},
+  { 0x729f0c00, 0xfffffc00, "vreplgr2vr.d", "v0:5,r5:5", 0, 0, 0, 0},
+  { 0x72a02000, 0xffffe000, "vrotri.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x72a04000, 0xffffc000, "vrotri.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x72a08000, 0xffff8000, "vrotri.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72a10000, 0xffff0000, "vrotri.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x72a42000, 0xffffe000, "vsrlri.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x72a44000, 0xffffc000, "vsrlri.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x72a48000, 0xffff8000, "vsrlri.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72a50000, 0xffff0000, "vsrlri.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x72a82000, 0xffffe000, "vsrari.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x72a84000, 0xffffc000, "vsrari.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x72a88000, 0xffff8000, "vsrari.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x72a90000, 0xffff0000, "vsrari.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x72eb8000, 0xffffc000, "vinsgr2vr.b", "v0:5,r5:5,u10:4", 0, 0, 0, 0},
+  { 0x72ebc000, 0xffffe000, "vinsgr2vr.h", "v0:5,r5:5,u10:3", 0, 0, 0, 0},
+  { 0x72ebe000, 0xfffff000, "vinsgr2vr.w", "v0:5,r5:5,u10:2", 0, 0, 0, 0},
+  { 0x72ebf000, 0xfffff800, "vinsgr2vr.d", "v0:5,r5:5,u10:1", 0, 0, 0, 0},
+  { 0x72ef8000, 0xffffc000, "vpickve2gr.b", "r0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x72efc000, 0xffffe000, "vpickve2gr.h", "r0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x72efe000, 0xfffff000, "vpickve2gr.w", "r0:5,v5:5,u10:2", 0, 0, 0, 0},
+  { 0x72eff000, 0xfffff800, "vpickve2gr.d", "r0:5,v5:5,u10:1", 0, 0, 0, 0},
+  { 0x72f38000, 0xffffc000, "vpickve2gr.bu", "r0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x72f3c000, 0xffffe000, "vpickve2gr.hu", "r0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x72f3e000, 0xfffff000, "vpickve2gr.wu", "r0:5,v5:5,u10:2", 0, 0, 0, 0},
+  { 0x72f3f000, 0xfffff800, "vpickve2gr.du", "r0:5,v5:5,u10:1", 0, 0, 0, 0},
+  { 0x72f78000, 0xffffc000, "vreplvei.b", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x72f7c000, 0xffffe000, "vreplvei.h", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x72f7e000, 0xfffff000, "vreplvei.w", "v0:5,v5:5,u10:2", 0, 0, 0, 0},
+  { 0x72f7f000, 0xfffff800, "vreplvei.d", "v0:5,v5:5,u10:1", 0, 0, 0, 0},
+  { 0x73082000, 0xffffe000, "vsllwil.h.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x73084000, 0xffffc000, "vsllwil.w.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73088000, 0xffff8000, "vsllwil.d.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73090000, 0xfffffc00, "vextl.q.d", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x730c2000, 0xffffe000, "vsllwil.hu.bu", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x730c4000, 0xffffc000, "vsllwil.wu.hu", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x730c8000, 0xffff8000, "vsllwil.du.wu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x730d0000, 0xfffffc00, "vextl.qu.du", "v0:5,v5:5", 0, 0, 0, 0},
+  { 0x73102000, 0xffffe000, "vbitclri.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x73104000, 0xffffc000, "vbitclri.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73108000, 0xffff8000, "vbitclri.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73110000, 0xffff0000, "vbitclri.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73142000, 0xffffe000, "vbitseti.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x73144000, 0xffffc000, "vbitseti.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73148000, 0xffff8000, "vbitseti.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73150000, 0xffff0000, "vbitseti.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73182000, 0xffffe000, "vbitrevi.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x73184000, 0xffffc000, "vbitrevi.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73188000, 0xffff8000, "vbitrevi.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73190000, 0xffff0000, "vbitrevi.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73242000, 0xffffe000, "vsat.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x73244000, 0xffffc000, "vsat.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73248000, 0xffff8000, "vsat.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73250000, 0xffff0000, "vsat.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73282000, 0xffffe000, "vsat.bu", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x73284000, 0xffffc000, "vsat.hu", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73288000, 0xffff8000, "vsat.wu", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73290000, 0xffff0000, "vsat.du", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x732c2000, 0xffffe000, "vslli.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x732c4000, 0xffffc000, "vslli.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x732c8000, 0xffff8000, "vslli.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x732d0000, 0xffff0000, "vslli.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73302000, 0xffffe000, "vsrli.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x73304000, 0xffffc000, "vsrli.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73308000, 0xffff8000, "vsrli.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73310000, 0xffff0000, "vsrli.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73342000, 0xffffe000, "vsrai.b", "v0:5,v5:5,u10:3", 0, 0, 0, 0},
+  { 0x73344000, 0xffffc000, "vsrai.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73348000, 0xffff8000, "vsrai.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73350000, 0xffff0000, "vsrai.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73404000, 0xffffc000, "vsrlni.b.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73408000, 0xffff8000, "vsrlni.h.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73410000, 0xffff0000, "vsrlni.w.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73420000, 0xfffe0000, "vsrlni.d.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x73484000, 0xffffc000, "vssrlni.b.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73488000, 0xffff8000, "vssrlni.h.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73490000, 0xffff0000, "vssrlni.w.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x734a0000, 0xfffe0000, "vssrlni.d.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x73444000, 0xffffc000, "vsrlrni.b.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73448000, 0xffff8000, "vsrlrni.h.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73450000, 0xffff0000, "vsrlrni.w.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73460000, 0xfffe0000, "vsrlrni.d.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x734c4000, 0xffffc000, "vssrlni.bu.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x734c8000, 0xffff8000, "vssrlni.hu.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x734d0000, 0xffff0000, "vssrlni.wu.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x734e0000, 0xfffe0000, "vssrlni.du.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x73504000, 0xffffc000, "vssrlrni.b.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73508000, 0xffff8000, "vssrlrni.h.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73510000, 0xffff0000, "vssrlrni.w.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73520000, 0xfffe0000, "vssrlrni.d.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x73544000, 0xffffc000, "vssrlrni.bu.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73548000, 0xffff8000, "vssrlrni.hu.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73550000, 0xffff0000, "vssrlrni.wu.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73560000, 0xfffe0000, "vssrlrni.du.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x73584000, 0xffffc000, "vsrani.b.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73588000, 0xffff8000, "vsrani.h.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73590000, 0xffff0000, "vsrani.w.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x735a0000, 0xfffe0000, "vsrani.d.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x735c4000, 0xffffc000, "vsrarni.b.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x735c8000, 0xffff8000, "vsrarni.h.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x735d0000, 0xffff0000, "vsrarni.w.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x735e0000, 0xfffe0000, "vsrarni.d.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x73604000, 0xffffc000, "vssrani.b.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73608000, 0xffff8000, "vssrani.h.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73610000, 0xffff0000, "vssrani.w.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73620000, 0xfffe0000, "vssrani.d.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x73644000, 0xffffc000, "vssrani.bu.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73648000, 0xffff8000, "vssrani.hu.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73650000, 0xffff0000, "vssrani.wu.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x73660000, 0xfffe0000, "vssrani.du.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x73684000, 0xffffc000, "vssrarni.b.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x73688000, 0xffff8000, "vssrarni.h.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x73690000, 0xffff0000, "vssrarni.w.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x736a0000, 0xfffe0000, "vssrarni.d.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x736c4000, 0xffffc000, "vssrarni.bu.h", "v0:5,v5:5,u10:4", 0, 0, 0, 0},
+  { 0x736c8000, 0xffff8000, "vssrarni.hu.w", "v0:5,v5:5,u10:5", 0, 0, 0, 0},
+  { 0x736d0000, 0xffff0000, "vssrarni.wu.d", "v0:5,v5:5,u10:6", 0, 0, 0, 0},
+  { 0x736e0000, 0xfffe0000, "vssrarni.du.q", "v0:5,v5:5,u10:7", 0, 0, 0, 0},
+  { 0x73800000, 0xfffc0000, "vextrins.d", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73840000, 0xfffc0000, "vextrins.w", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73880000, 0xfffc0000, "vextrins.h", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x738c0000, 0xfffc0000, "vextrins.b", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73900000, 0xfffc0000, "vshuf4i.b", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73940000, 0xfffc0000, "vshuf4i.h", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73980000, 0xfffc0000, "vshuf4i.w", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x739c0000, 0xfffc0000, "vshuf4i.d", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73c40000, 0xfffc0000, "vbitseli.b", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73d00000, 0xfffc0000, "vandi.b", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73d40000, 0xfffc0000, "vori.b", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73d80000, 0xfffc0000, "vxori.b", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0x73dc0000, 0xfffc0000, "vnori.b", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0, 0, "vrepli.b", "v,s0:10", "vldi %1,(%2)&0x3ff", 0, 0, 0},
+
+  { 0x701e0000, 0xffff8000, "vaddwev.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x701e8000, 0xffff8000, "vaddwev.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x701f0000, 0xffff8000, "vaddwev.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x701f8000, 0xffff8000, "vaddwev.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x702e0000, 0xffff8000, "vaddwev.h.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x702e8000, 0xffff8000, "vaddwev.w.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x702f0000, 0xffff8000, "vaddwev.d.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x702f8000, 0xffff8000, "vaddwev.q.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x703e0000, 0xffff8000, "vaddwev.h.bu.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x703e8000, 0xffff8000, "vaddwev.w.hu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x703f0000, 0xffff8000, "vaddwev.d.wu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x703f8000, 0xffff8000, "vaddwev.q.du.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70220000, 0xffff8000, "vaddwod.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70228000, 0xffff8000, "vaddwod.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70230000, 0xffff8000, "vaddwod.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70238000, 0xffff8000, "vaddwod.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70320000, 0xffff8000, "vaddwod.h.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70328000, 0xffff8000, "vaddwod.w.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70330000, 0xffff8000, "vaddwod.d.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70338000, 0xffff8000, "vaddwod.q.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70400000, 0xffff8000, "vaddwod.h.bu.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70408000, 0xffff8000, "vaddwod.w.hu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70410000, 0xffff8000, "vaddwod.d.wu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70418000, 0xffff8000, "vaddwod.q.du.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ac0000, 0xffff8000, "vmaddwev.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ac8000, 0xffff8000, "vmaddwev.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ad0000, 0xffff8000, "vmaddwev.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ad8000, 0xffff8000, "vmaddwev.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70b40000, 0xffff8000, "vmaddwev.h.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70b48000, 0xffff8000, "vmaddwev.w.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70b50000, 0xffff8000, "vmaddwev.d.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70b58000, 0xffff8000, "vmaddwev.q.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70bc0000, 0xffff8000, "vmaddwev.h.bu.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70bc8000, 0xffff8000, "vmaddwev.w.hu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70bd0000, 0xffff8000, "vmaddwev.d.wu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70bd8000, 0xffff8000, "vmaddwev.q.du.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ae0000, 0xffff8000, "vmaddwod.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70ae8000, 0xffff8000, "vmaddwod.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70af0000, 0xffff8000, "vmaddwod.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70af8000, 0xffff8000, "vmaddwod.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70b60000, 0xffff8000, "vmaddwod.h.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70b68000, 0xffff8000, "vmaddwod.w.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70b70000, 0xffff8000, "vmaddwod.d.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70b78000, 0xffff8000, "vmaddwod.q.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70be0000, 0xffff8000, "vmaddwod.h.bu.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70be8000, 0xffff8000, "vmaddwod.w.hu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70bf0000, 0xffff8000, "vmaddwod.d.wu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70bf8000, 0xffff8000, "vmaddwod.q.du.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70900000, 0xffff8000, "vmulwev.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70908000, 0xffff8000, "vmulwev.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70910000, 0xffff8000, "vmulwev.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70918000, 0xffff8000, "vmulwev.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70980000, 0xffff8000, "vmulwev.h.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70988000, 0xffff8000, "vmulwev.w.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70990000, 0xffff8000, "vmulwev.d.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70998000, 0xffff8000, "vmulwev.q.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a00000, 0xffff8000, "vmulwev.h.bu.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a08000, 0xffff8000, "vmulwev.w.hu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a10000, 0xffff8000, "vmulwev.d.wu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a18000, 0xffff8000, "vmulwev.q.du.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70920000, 0xffff8000, "vmulwod.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70928000, 0xffff8000, "vmulwod.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70930000, 0xffff8000, "vmulwod.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70938000, 0xffff8000, "vmulwod.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x709a0000, 0xffff8000, "vmulwod.h.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x709a8000, 0xffff8000, "vmulwod.w.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x709b0000, 0xffff8000, "vmulwod.d.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x709b8000, 0xffff8000, "vmulwod.q.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a20000, 0xffff8000, "vmulwod.h.bu.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a28000, 0xffff8000, "vmulwod.w.hu.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a30000, 0xffff8000, "vmulwod.d.wu.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70a38000, 0xffff8000, "vmulwod.q.du.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70200000, 0xffff8000, "vsubwev.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70208000, 0xffff8000, "vsubwev.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70210000, 0xffff8000, "vsubwev.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70218000, 0xffff8000, "vsubwev.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70300000, 0xffff8000, "vsubwev.h.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70308000, 0xffff8000, "vsubwev.w.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70310000, 0xffff8000, "vsubwev.d.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70318000, 0xffff8000, "vsubwev.q.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70240000, 0xffff8000, "vsubwod.h.b", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70248000, 0xffff8000, "vsubwod.w.h", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70250000, 0xffff8000, "vsubwod.d.w", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70258000, 0xffff8000, "vsubwod.q.d", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70340000, 0xffff8000, "vsubwod.h.bu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70348000, 0xffff8000, "vsubwod.w.hu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70350000, 0xffff8000, "vsubwod.d.wu", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0x70358000, 0xffff8000, "vsubwod.q.du", "v0:5,v5:5,v10:5",              0,                      0,      0,      0 },
+  { 0, 0, "vrepli.d", "v,s0:10", "vldi %1,((%2)&0x3ff)|0xc00", 0, 0, 0},
+  { 0, 0, "vrepli.h", "v,s0:10", "vldi %1,((%2)&0x3ff)|0x400", 0, 0, 0},
+  { 0, 0, "vrepli.w", "v,s0:10", "vldi %1,((%2)&0x3ff)|0x800", 0, 0, 0},
+  { 0x73e00000, 0xfffc0000, "vldi", "v0:5,s5:13", 0, 0, 0, 0},
+  { 0x73e40000, 0xfffc0000, "vpermi.w", "v0:5,v5:5,u10:8", 0, 0, 0, 0},
+  { 0, 0, 0, 0, 0, 0, 0, 0 } /* Terminate the list.  */
+};
+static struct loongarch_opcode loongarch_lasx_opcodes[] =
+{
+/* match,    mask,       name, format, macro, include, exclude, pinfo.  */
+  { 0x74000000, 0xffff8000, "xvseq.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74008000, 0xffff8000, "xvseq.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74010000, 0xffff8000, "xvseq.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74018000, 0xffff8000, "xvseq.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74020000, 0xffff8000, "xvsle.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74028000, 0xffff8000, "xvsle.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74030000, 0xffff8000, "xvsle.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74038000, 0xffff8000, "xvsle.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74040000, 0xffff8000, "xvsle.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74048000, 0xffff8000, "xvsle.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74050000, 0xffff8000, "xvsle.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74058000, 0xffff8000, "xvsle.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74060000, 0xffff8000, "xvslt.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74068000, 0xffff8000, "xvslt.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74070000, 0xffff8000, "xvslt.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74078000, 0xffff8000, "xvslt.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74080000, 0xffff8000, "xvslt.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74088000, 0xffff8000, "xvslt.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74090000, 0xffff8000, "xvslt.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74098000, 0xffff8000, "xvslt.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x740a0000, 0xffff8000, "xvadd.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x740a8000, 0xffff8000, "xvadd.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x740b0000, 0xffff8000, "xvadd.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x740b8000, 0xffff8000, "xvadd.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x740c0000, 0xffff8000, "xvsub.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x740c8000, 0xffff8000, "xvsub.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x740d0000, 0xffff8000, "xvsub.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x740d8000, 0xffff8000, "xvsub.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74460000, 0xffff8000, "xvsadd.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74468000, 0xffff8000, "xvsadd.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74470000, 0xffff8000, "xvsadd.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74478000, 0xffff8000, "xvsadd.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74480000, 0xffff8000, "xvssub.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74488000, 0xffff8000, "xvssub.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74490000, 0xffff8000, "xvssub.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74498000, 0xffff8000, "xvssub.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x744a0000, 0xffff8000, "xvsadd.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x744a8000, 0xffff8000, "xvsadd.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x744b0000, 0xffff8000, "xvsadd.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x744b8000, 0xffff8000, "xvsadd.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x744c0000, 0xffff8000, "xvssub.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x744c8000, 0xffff8000, "xvssub.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x744d0000, 0xffff8000, "xvssub.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x744d8000, 0xffff8000, "xvssub.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74540000, 0xffff8000, "xvhaddw.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74548000, 0xffff8000, "xvhaddw.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74550000, 0xffff8000, "xvhaddw.d.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74558000, 0xffff8000, "xvhaddw.q.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74560000, 0xffff8000, "xvhsubw.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74568000, 0xffff8000, "xvhsubw.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74570000, 0xffff8000, "xvhsubw.d.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74578000, 0xffff8000, "xvhsubw.q.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74580000, 0xffff8000, "xvhaddw.hu.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74588000, 0xffff8000, "xvhaddw.wu.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74590000, 0xffff8000, "xvhaddw.du.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74598000, 0xffff8000, "xvhaddw.qu.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x745a0000, 0xffff8000, "xvhsubw.hu.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x745a8000, 0xffff8000, "xvhsubw.wu.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x745b0000, 0xffff8000, "xvhsubw.du.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x745b8000, 0xffff8000, "xvhsubw.qu.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x741e0000, 0xffff8000, "xvaddwev.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x741e8000, 0xffff8000, "xvaddwev.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x741f0000, 0xffff8000, "xvaddwev.d.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x741f8000, 0xffff8000, "xvaddwev.q.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x742e0000, 0xffff8000, "xvaddwev.h.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x742e8000, 0xffff8000, "xvaddwev.w.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x742f0000, 0xffff8000, "xvaddwev.d.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x742f8000, 0xffff8000, "xvaddwev.q.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x743e0000, 0xffff8000, "xvaddwev.h.bu.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x743e8000, 0xffff8000, "xvaddwev.w.hu.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x743f0000, 0xffff8000, "xvaddwev.d.wu.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x743f8000, 0xffff8000, "xvaddwev.q.du.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74220000, 0xffff8000, "xvaddwod.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74228000, 0xffff8000, "xvaddwod.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74230000, 0xffff8000, "xvaddwod.d.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74238000, 0xffff8000, "xvaddwod.q.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74320000, 0xffff8000, "xvaddwod.h.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74328000, 0xffff8000, "xvaddwod.w.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74330000, 0xffff8000, "xvaddwod.d.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74338000, 0xffff8000, "xvaddwod.q.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74400000, 0xffff8000, "xvaddwod.h.bu.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74408000, 0xffff8000, "xvaddwod.w.hu.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74410000, 0xffff8000, "xvaddwod.d.wu.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74418000, 0xffff8000, "xvaddwod.q.du.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74ac0000, 0xffff8000, "xvmaddwev.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74ac8000, 0xffff8000, "xvmaddwev.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74ad0000, 0xffff8000, "xvmaddwev.d.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74ad8000, 0xffff8000, "xvmaddwev.q.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74bc0000, 0xffff8000, "xvmaddwev.h.bu.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74bc8000, 0xffff8000, "xvmaddwev.w.hu.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74bd0000, 0xffff8000, "xvmaddwev.d.wu.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74bd8000, 0xffff8000, "xvmaddwev.q.du.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74b40000, 0xffff8000, "xvmaddwev.h.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74b48000, 0xffff8000, "xvmaddwev.w.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74b50000, 0xffff8000, "xvmaddwev.d.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74b58000, 0xffff8000, "xvmaddwev.q.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74ae0000, 0xffff8000, "xvmaddwod.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74ae8000, 0xffff8000, "xvmaddwod.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74af0000, 0xffff8000, "xvmaddwod.d.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74af8000, 0xffff8000, "xvmaddwod.q.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74b60000, 0xffff8000, "xvmaddwod.h.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74b68000, 0xffff8000, "xvmaddwod.w.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74b70000, 0xffff8000, "xvmaddwod.d.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74b78000, 0xffff8000, "xvmaddwod.q.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74be0000, 0xffff8000, "xvmaddwod.h.bu.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74be8000, 0xffff8000, "xvmaddwod.w.hu.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74bf0000, 0xffff8000, "xvmaddwod.d.wu.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74bf8000, 0xffff8000, "xvmaddwod.q.du.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74900000, 0xffff8000, "xvmulwev.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74908000, 0xffff8000, "xvmulwev.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74910000, 0xffff8000, "xvmulwev.d.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74918000, 0xffff8000, "xvmulwev.q.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74980000, 0xffff8000, "xvmulwev.h.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74988000, 0xffff8000, "xvmulwev.w.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74990000, 0xffff8000, "xvmulwev.d.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74998000, 0xffff8000, "xvmulwev.q.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74a00000, 0xffff8000, "xvmulwev.h.bu.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74a08000, 0xffff8000, "xvmulwev.w.hu.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74a10000, 0xffff8000, "xvmulwev.d.wu.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74a18000, 0xffff8000, "xvmulwev.q.du.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74920000, 0xffff8000, "xvmulwod.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74928000, 0xffff8000, "xvmulwod.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74930000, 0xffff8000, "xvmulwod.d.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74938000, 0xffff8000, "xvmulwod.q.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x749a0000, 0xffff8000, "xvmulwod.h.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x749a8000, 0xffff8000, "xvmulwod.w.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x749b0000, 0xffff8000, "xvmulwod.d.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x749b8000, 0xffff8000, "xvmulwod.q.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74a20000, 0xffff8000, "xvmulwod.h.bu.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74a28000, 0xffff8000, "xvmulwod.w.hu.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74a30000, 0xffff8000, "xvmulwod.d.wu.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74a38000, 0xffff8000, "xvmulwod.q.du.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74200000, 0xffff8000, "xvsubwev.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74208000, 0xffff8000, "xvsubwev.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74210000, 0xffff8000, "xvsubwev.d.w", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74218000, 0xffff8000, "xvsubwev.q.d", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74300000, 0xffff8000, "xvsubwev.h.bu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74308000, 0xffff8000, "xvsubwev.w.hu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74310000, 0xffff8000, "xvsubwev.d.wu", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74318000, 0xffff8000, "xvsubwev.q.du", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74240000, 0xffff8000, "xvsubwod.h.b", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74248000, 0xffff8000, "xvsubwod.w.h", "x0:5,x5:5,x10:5",              0,                      0,      0,      0 },
+  { 0x74250000, 0xffff8000,[...]

[diff truncated at 100000 bytes]

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2023-06-28  8:15 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-06-28  8:15 [binutils-gdb] LoongArch: gas: Add lsx and lasx instructions support liu & zhensong

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).