]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
x86/APX: support extended SETcc form
authorJan Beulich <jbeulich@suse.com>
Mon, 10 Jun 2024 08:45:16 +0000 (10:45 +0200)
committerJan Beulich <jbeulich@suse.com>
Mon, 10 Jun 2024 08:45:16 +0000 (10:45 +0200)
As indicated during review, spelling/readability-wise

setz %eax

is easier than

setzuz %al

_and_ properly specifies the full register that's being modified. Permit
that form to be used, even if the spec writers are unwilling to formally
mention it.

While there also correct the non-ZU EVEX form: That ought to also permit
memory operands.

gas/testsuite/gas/i386/x86-64-apx-zu-intel.d
gas/testsuite/gas/i386/x86-64-apx-zu.d
gas/testsuite/gas/i386/x86-64-apx-zu.s
opcodes/i386-opc.tbl
opcodes/i386-tbl.h

index 9b61d50fd2f12b6957a20e367f03981a9c004009..8985503d35f38194045f9b0e08bef37b3b23687a 100644 (file)
@@ -42,6 +42,9 @@ Disassembly of section .text:
 \s*[a-f0-9]+:\s*62 dc 7f 18 4f c1[     ]+setzug r25b
 \s*[a-f0-9]+:\s*d5 91 9f c1[   ]+setg   r25b
 \s*[a-f0-9]+:\s*62 f4 7f 08 4f c0[     ]+\{evex\} setg al
+\s*[a-f0-9]+:\s*62 f4 7f 08 4f 00[     ]+\{evex\} setg (BYTE PTR )?\[rax\]
+\s*[a-f0-9]+:\s*62 f4 7f 18 4a c0[     ]+setzup al
+\s*[a-f0-9]+:\s*62 f4 ff 18 4b c0[     ]+setzunp al
 \s*[a-f0-9]+:\s*62 f4 7d 18 6b c3 0a[  ]+imulzu ax,bx,0xa
 \s*[a-f0-9]+:\s*67 62 f4 7d 18 6b 00 0a[       ]+imulzu ax,WORD PTR \[eax\],0xa
 \s*[a-f0-9]+:\s*62 ec 7d 18 6b c1 0a[  ]+imulzu r16w,r17w,0xa
index c6b0cc45d7648a159d4414a9192700310847ee37..e30ee475ef593d174b111292ec8866e51a9bd129 100644 (file)
@@ -42,6 +42,9 @@ Disassembly of section .text:
 \s*[a-f0-9]+:\s*62 dc 7f 18 4f c1[     ]+setzug %r25b
 \s*[a-f0-9]+:\s*d5 91 9f c1[   ]+setg   %r25b
 \s*[a-f0-9]+:\s*62 f4 7f 08 4f c0[     ]+\{evex\} setg %al
+\s*[a-f0-9]+:\s*62 f4 7f 08 4f 00[     ]+\{evex\} setg \(%rax\)
+\s*[a-f0-9]+:\s*62 f4 7f 18 4a c0[     ]+setzup %al
+\s*[a-f0-9]+:\s*62 f4 ff 18 4b c0[     ]+setzunp %al
 \s*[a-f0-9]+:\s*62 f4 7d 18 6b c3 0a[  ]+imulzu \$0xa,%bx,%ax
 \s*[a-f0-9]+:\s*67 62 f4 7d 18 6b 00 0a[       ]+imulzu \$0xa,\(%eax\),%ax
 \s*[a-f0-9]+:\s*62 ec 7d 18 6b c1 0a[  ]+imulzu \$0xa,%r17w,%r16w
index 0c287b8aa89eb72abf02b5287c4205b43c9a600b..6e2892750e95af4d65a14753f0c9646417add2e1 100644 (file)
@@ -36,6 +36,9 @@ _start:
        setzug   %r25b
        setg     %r25b
        {evex} setg  %al
+       {evex} setg  (%rax)
+       setpe    %eax
+       setpo    %rax
 
        .intel_syntax noprefix
        imulzu ax,bx, 10
index ac14bee83c8d191eb8e84de60d9907e110264873..43ee785ae58f5ce2eba047492f43ba641fbd3526 100644 (file)
@@ -533,8 +533,11 @@ loopne, 0xe0, x64, JumpByte|No_bSuf|No_wSuf|No_sSuf|NoRex64|IntelSuffix, { Disp8
 
 // Set byte on flag instructions.
 set<cc>, 0xf9<cc:opc>/0, i386, Modrm|No_wSuf|No_lSuf|No_sSuf|No_qSuf, { Reg8|Unspecified|BaseIndex }
-set<cc>, 0xf24<cc:opc>/0, APX_F, Modrm|No_wSuf|No_lSuf|No_sSuf|No_qSuf|VexWIG|EVexMap4, { Reg8 }
+set<cc>, 0xf24<cc:opc>/0, APX_F, Modrm|No_wSuf|No_lSuf|No_sSuf|No_qSuf|VexWIG|EVexMap4, { Reg8|Unspecified|BaseIndex }
 setzu<cc>, 0xf24<cc:opc>/0, APX_F, Modrm|No_wSuf|No_lSuf|No_sSuf|No_qSuf|VexWIG|EVexMap4|ZU, { Reg8 }
+// As an extension, allow SETcc without the ZU infix, instead taking the full
+// register as operand.
+set<cc>, 0xf24<cc:opc>/0, APX_F, Modrm|No_bSuf|No_sSuf|EVexMap4|ZU, { Reg32|Reg64 }
 
 // String manipulation.
 cmps, 0xa6, 0, W|No_sSuf|RepPrefixOk|IntelSuffix, {}
index 372074d7f53a50f96d244dd0a747195f01ef40cd..5017534f528fd5c7e13add23a0754bfdbf576c6e 100644 (file)
@@ -3838,7 +3838,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_seto, 0x40, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setno, 0x91, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3854,7 +3862,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setno, 0x41, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setb, 0x92, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3870,7 +3886,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setb, 0x42, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setc, 0x92, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3886,7 +3910,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setc, 0x42, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setnae, 0x92, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3902,7 +3934,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setnae, 0x42, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setnb, 0x93, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3918,7 +3958,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setnb, 0x43, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setnc, 0x93, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3934,7 +3982,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setnc, 0x43, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setae, 0x93, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3950,7 +4006,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setae, 0x43, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_sete, 0x94, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3966,7 +4030,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_sete, 0x44, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setz, 0x94, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3982,7 +4054,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setz, 0x44, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setne, 0x95, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -3998,7 +4078,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setne, 0x45, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setnz, 0x95, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4014,7 +4102,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setnz, 0x45, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setbe, 0x96, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4030,7 +4126,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setbe, 0x46, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setna, 0x96, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4046,7 +4150,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setna, 0x46, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setnbe, 0x97, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4062,7 +4174,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setnbe, 0x47, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_seta, 0x97, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4078,7 +4198,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_seta, 0x47, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_sets, 0x98, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4094,7 +4222,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_sets, 0x48, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setns, 0x99, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4110,7 +4246,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setns, 0x49, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setp, 0x9a, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4126,7 +4270,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setp, 0x4a, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setpe, 0x9a, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4142,7 +4294,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setpe, 0x4a, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setnp, 0x9b, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4158,7 +4318,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setnp, 0x4b, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setpo, 0x9b, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4174,7 +4342,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setpo, 0x4b, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setl, 0x9c, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4190,7 +4366,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setl, 0x4c, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setnge, 0x9c, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4206,7 +4390,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setnge, 0x4c, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setnl, 0x9d, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4222,7 +4414,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setnl, 0x4d, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setge, 0x9d, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4238,7 +4438,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setge, 0x4d, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setle, 0x9e, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4254,7 +4462,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setle, 0x4e, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setng, 0x9e, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4270,7 +4486,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setng, 0x4e, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setnle, 0x9f, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4286,7 +4510,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setnle, 0x4f, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setg, 0x9f, 1, SPACE_0F, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -4302,7 +4534,15 @@ static const insn_template i386_optab[] =
       0, 0, 0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0,
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_setg, 0x4f, 1, SPACE_EVEXMAP4, 0,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 3, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 1 },
+    { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
   { MN_setzuo, 0x40, 1, SPACE_EVEXMAP4, 0,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0,
@@ -43571,288 +43811,288 @@ static const i386_op_off_t i386_op_sets[] =
    365,  366,  367,  368,  369,  370,  371,  372,
    373,  374,  375,  376,  377,  378,  379,  380,
    381,  382,  383,  384,  385,  386,  387,  388,
-   389,  391,  393,  395,  397,  399,  401,  403,
-   405,  407,  409,  411,  413,  415,  417,  419,
-   421,  423,  425,  427,  429,  431,  433,  435,
-   437,  439,  441,  443,  445,  447,  449,  451,
-   453,  455,  457,  459,  460,  461,  462,  463,
-   464,  465,  466,  467,  468,  469,  470,  471,
-   472,  473,  474,  475,  476,  477,  478,  479,
-   480,  481,  482,  483,  484,  485,  486,  487,
-   488,  489,  491,  493,  495,  497,  500,  503,
-   505,  507,  510,  513,  516,  519,  521,  522,
-   523,  525,  527,  529,  531,  532,  533,  534,
-   535,  536,  537,  538,  539,  541,  543,  545,
-   547,  549,  551,  552,  554,  556,  558,  560,
-   562,  564,  566,  568,  570,  574,  576,  577,
-   578,  579,  582,  583,  587,  589,  590,  591,
-   592,  594,  598,  599,  603,  604,  605,  607,
-   609,  610,  611,  612,  613,  614,  615,  616,
-   617,  618,  619,  623,  624,  627,  631,  632,
-   638,  642,  643,  649,  653,  654,  657,  661,
-   662,  668,  672,  673,  679,  680,  681,  682,
-   683,  684,  685,  686,  687,  688,  689,  690,
-   691,  692,  693,  694,  695,  696,  697,  698,
-   699,  700,  701,  702,  705,  708,  709,  710,
-   711,  712,  713,  714,  715,  716,  717,  718,
-   719,  720,  721,  722,  723,  724,  725,  726,
-   727,  728,  729,  730,  731,  732,  733,  734,
-   735,  736,  737,  738,  739,  740,  741,  742,
-   743,  744,  745,  746,  747,  748,  749,  750,
-   751,  752,  753,  754,  755,  756,  757,  758,
-   759,  760,  761,  762,  763,  764,  765,  766,
-   767,  768,  769,  770,  771,  772,  773,  774,
-   775,  776,  777,  778,  779,  780,  781,  782,
-   783,  784,  785,  786,  787,  788,  789,  790,
-   791,  792,  793,  794,  795,  796,  797,  798,
-   799,  800,  801,  802,  803,  804,  806,  808,
-   809,  810,  811,  812,  813,  814,  815,  816,
-   817,  818,  820,  822,  824,  826,  828,  830,
-   832,  834,  836,  838,  840,  842,  844,  846,
-   848,  850,  852,  854,  856,  858,  860,  862,
-   864,  866,  868,  870,  872,  874,  876,  878,
-   879,  880,  881,  882,  883,  884,  885,  886,
-   887,  888,  889,  890,  893,  896,  899,  902,
-   905,  908,  909,  910,  911,  912,  913,  914,
-   920,  930,  934,  938,  942,  946,  950,  953,
-   957,  961,  965,  969,  973,  976,  979,  982,
-   985,  988,  991,  994,  997, 1001, 1005, 1009,
-  1012, 1020, 1026, 1034, 1042, 1048, 1056, 1062,
-  1070, 1074, 1078, 1081, 1085, 1089, 1093, 1097,
-  1101, 1105, 1109, 1112, 1116, 1120, 1123, 1126,
-  1128, 1130, 1133, 1136, 1138, 1140, 1142, 1144,
-  1146, 1148, 1150, 1152, 1154, 1156, 1158, 1160,
-  1162, 1164, 1166, 1168, 1170, 1172, 1174, 1175,
-  1176, 1182, 1184, 1185, 1187, 1189, 1191, 1193,
-  1194, 1196, 1198, 1200, 1202, 1204, 1206, 1209,
-  1211, 1214, 1216, 1218, 1219, 1221, 1224, 1226,
-  1228, 1230, 1233, 1237, 1241, 1250, 1256, 1260,
-  1264, 1268, 1272, 1275, 1279, 1280, 1281, 1282,
-  1283, 1287, 1288, 1291, 1294, 1297, 1300, 1301,
-  1303, 1305, 1307, 1309, 1311, 1313, 1315, 1317,
-  1319, 1322, 1325, 1328, 1331, 1334, 1336, 1338,
-  1340, 1342, 1344, 1346, 1348, 1350, 1352, 1354,
-  1356, 1358, 1360, 1362, 1364, 1366, 1368, 1370,
-  1373, 1376, 1382, 1385, 1388, 1391, 1394, 1397,
-  1400, 1403, 1408, 1413, 1415, 1418, 1423, 1426,
-  1429, 1432, 1435, 1438, 1441, 1444, 1447, 1450,
-  1453, 1456, 1459, 1462, 1464, 1467, 1469, 1470,
-  1473, 1475, 1477, 1479, 1482, 1484, 1485, 1487,
-  1490, 1492, 1494, 1496, 1498, 1499, 1500, 1504,
-  1506, 1509, 1512, 1515, 1518, 1521, 1524, 1526,
-  1528, 1530, 1532, 1534, 1536, 1539, 1542, 1544,
-  1546, 1548, 1549, 1550, 1553, 1555, 1556, 1557,
-  1558, 1559, 1560, 1561, 1563, 1565, 1566, 1567,
-  1568, 1569, 1572, 1575, 1578, 1581, 1584, 1587,
-  1590, 1593, 1596, 1600, 1604, 1608, 1611, 1614,
-  1617, 1621, 1625, 1629, 1632, 1634, 1636, 1640,
-  1644, 1646, 1648, 1652, 1654, 1656, 1658, 1661,
-  1665, 1667, 1669, 1675, 1678, 1681, 1683, 1689,
-  1692, 1695, 1698, 1700, 1702, 1705, 1708, 1710,
-  1712, 1715, 1718, 1720, 1722, 1724, 1726, 1728,
-  1731, 1733, 1735, 1737, 1739, 1741, 1744, 1746,
-  1748, 1751, 1753, 1756, 1758, 1760, 1764, 1768,
-  1770, 1772, 1776, 1777, 1778, 1779, 1780, 1781,
-  1782, 1783, 1784, 1786, 1788, 1790, 1792, 1794,
-  1796, 1798, 1800, 1802, 1804, 1806, 1808, 1810,
-  1812, 1814, 1816, 1818, 1820, 1821, 1822, 1824,
-  1826, 1828, 1830, 1831, 1832, 1833, 1834, 1836,
-  1839, 1841, 1843, 1845, 1847, 1849, 1851, 1853,
-  1855, 1857, 1859, 1861, 1863, 1865, 1867, 1869,
-  1871, 1873, 1875, 1877, 1879, 1881, 1883, 1885,
-  1887, 1889, 1891, 1893, 1895, 1897, 1899, 1901,
-  1903, 1905, 1907, 1909, 1911, 1913, 1915, 1917,
-  1919, 1921, 1923, 1925, 1927, 1929, 1931, 1933,
-  1935, 1937, 1939, 1941, 1943, 1945, 1947, 1949,
-  1951, 1953, 1955, 1957, 1959, 1961, 1963, 1965,
-  1967, 1969, 1971, 1973, 1975, 1977, 1979, 1981,
-  1983, 1985, 1987, 1989, 1991, 1993, 1995, 1997,
-  1999, 2001, 2003, 2005, 2007, 2009, 2011, 2013,
-  2015, 2017, 2019, 2021, 2023, 2025, 2027, 2029,
-  2031, 2033, 2035, 2037, 2039, 2041, 2043, 2045,
-  2047, 2049, 2051, 2053, 2055, 2057, 2059, 2061,
-  2063, 2065, 2067, 2069, 2071, 2073, 2075, 2077,
-  2079, 2081, 2083, 2085, 2087, 2089, 2091, 2093,
-  2095, 2097, 2099, 2101, 2103, 2105, 2107, 2109,
-  2111, 2113, 2115, 2117, 2119, 2121, 2123, 2125,
-  2127, 2129, 2131, 2133, 2135, 2137, 2139, 2141,
-  2143, 2145, 2147, 2149, 2151, 2153, 2155, 2157,
-  2159, 2161, 2163, 2165, 2167, 2169, 2171, 2173,
-  2175, 2177, 2179, 2181, 2183, 2185, 2187, 2189,
-  2191, 2193, 2195, 2197, 2199, 2201, 2203, 2205,
-  2207, 2209, 2211, 2213, 2215, 2217, 2219, 2221,
-  2226, 2228, 2233, 2235, 2237, 2242, 2244, 2246,
-  2248, 2253, 2255, 2257, 2259, 2263, 2269, 2271,
-  2276, 2278, 2280, 2282, 2284, 2286, 2288, 2290,
-  2292, 2294, 2295, 2296, 2298, 2300, 2301, 2302,
-  2303, 2304, 2306, 2308, 2309, 2310, 2311, 2313,
-  2315, 2317, 2319, 2321, 2323, 2325, 2327, 2329,
-  2331, 2333, 2335, 2337, 2341, 2342, 2343, 2345,
-  2349, 2353, 2355, 2359, 2363, 2364, 2365, 2367,
-  2369, 2371, 2373, 2378, 2382, 2386, 2388, 2390,
-  2392, 2394, 2395, 2397, 2399, 2401, 2403, 2405,
-  2407, 2409, 2411, 2413, 2415, 2417, 2419, 2421,
-  2423, 2425, 2427, 2429, 2431, 2433, 2435, 2437,
-  2439, 2440, 2441, 2443, 2445, 2446, 2447, 2450,
-  2453, 2456, 2459, 2461, 2463, 2465, 2467, 2469,
-  2471, 2472, 2473, 2474, 2476, 2480, 2482, 2484,
-  2490, 2494, 2495, 2496, 2497, 2498, 2499, 2500,
-  2501, 2505, 2507, 2509, 2513, 2515, 2517, 2519,
-  2521, 2523, 2525, 2527, 2529, 2531, 2533, 2535,
-  2537, 2539, 2541, 2542, 2545, 2548, 2553, 2558,
-  2561, 2564, 2567, 2570, 2575, 2580, 2583, 2586,
-  2588, 2590, 2592, 2594, 2596, 2598, 2600, 2601,
-  2603, 2605, 2607, 2609, 2611, 2612, 2613, 2614,
-  2618, 2622, 2624, 2628, 2632, 2636, 2640, 2644,
-  2646, 2650, 2652, 2654, 2656, 2658, 2660, 2662,
-  2664, 2666, 2667, 2669, 2671, 2673, 2675, 2677,
-  2679, 2681, 2683, 2684, 2685, 2686, 2688, 2690,
-  2692, 2694, 2695, 2696, 2698, 2700, 2702, 2704,
-  2706, 2708, 2709, 2711, 2713, 2715, 2717, 2718,
-  2719, 2721, 2723, 2725, 2727, 2729, 2731, 2733,
-  2735, 2736, 2737, 2739, 2740, 2743, 2746, 2748,
-  2751, 2752, 2753, 2755, 2756, 2758, 2760, 2762,
-  2764, 2766, 2767, 2768, 2769, 2770, 2771, 2774,
-  2779, 2784, 2789, 2794, 2797, 2802, 2807, 2809,
-  2811, 2813, 2815, 2816, 2817, 2819, 2821, 2823,
-  2825, 2827, 2829, 2831, 2832, 2833, 2834, 2835,
-  2836, 2837, 2842, 2847, 2848, 2849, 2850, 2851,
-  2852, 2853, 2854, 2855, 2856, 2857, 2858, 2859,
-  2860, 2861, 2862, 2863, 2864, 2865, 2866, 2867,
-  2868, 2869, 2870, 2871, 2872, 2873, 2874, 2875,
-  2876, 2877, 2878, 2879, 2880, 2881, 2882, 2883,
-  2884, 2885, 2886, 2887, 2888, 2889, 2890, 2891,
-  2892, 2893, 2894, 2895, 2896, 2897, 2898, 2899,
-  2900, 2901, 2902, 2903, 2904, 2905, 2906, 2907,
-  2908, 2909, 2910, 2911, 2912, 2913, 2914, 2915,
-  2916, 2917, 2918, 2919, 2920, 2921, 2922, 2923,
-  2924, 2925, 2926, 2927, 2928, 2929, 2930, 2931,
-  2932, 2933, 2934, 2935, 2936, 2937, 2938, 2939,
-  2940, 2941, 2942, 2943, 2944, 2945, 2946, 2947,
-  2948, 2949, 2950, 2951, 2952, 2953, 2954, 2955,
-  2956, 2957, 2958, 2959, 2960, 2961, 2962, 2963,
-  2964, 2965, 2966, 2967, 2968, 2969, 2970, 2971,
-  2972, 2973, 2974, 2975, 2976, 2977, 2978, 2979,
-  2980, 2981, 2982, 2983, 2984, 2985, 2986, 2987,
-  2988, 2989, 2990, 2991, 2992, 2993, 2994, 2995,
-  2996, 2997, 2998, 2999, 3000, 3001, 3002, 3003,
-  3004, 3005, 3006, 3007, 3008, 3009, 3010, 3011,
-  3012, 3013, 3014, 3015, 3016, 3017, 3018, 3019,
-  3020, 3021, 3022, 3023, 3024, 3025, 3026, 3027,
-  3028, 3029, 3030, 3031, 3032, 3033, 3034, 3035,
-  3036, 3037, 3038, 3039, 3040, 3041, 3042, 3043,
-  3044, 3045, 3046, 3047, 3048, 3050, 3052, 3053,
-  3054, 3055, 3056, 3057, 3058, 3059, 3060, 3061,
-  3062, 3063, 3064, 3065, 3066, 3067, 3068, 3069,
-  3070, 3071, 3072, 3073, 3074, 3075, 3076, 3077,
-  3078, 3079, 3080, 3082, 3084, 3086, 3088, 3089,
-  3090, 3091, 3092, 3093, 3094, 3095, 3096, 3097,
-  3098, 3099, 3100, 3101, 3103, 3104, 3105, 3106,
-  3108, 3109, 3110, 3111, 3112, 3113, 3114, 3115,
-  3116, 3117, 3118, 3119, 3120, 3121, 3122, 3123,
-  3124, 3125, 3126, 3127, 3128, 3129, 3130, 3131,
-  3132, 3133, 3134, 3135, 3136, 3137, 3138, 3139,
-  3140, 3141, 3142, 3143, 3144, 3145, 3146, 3147,
-  3148, 3149, 3151, 3153, 3154, 3155, 3157, 3158,
-  3160, 3162, 3163, 3164, 3166, 3168, 3170, 3172,
-  3173, 3174, 3175, 3176, 3177, 3178, 3179, 3180,
-  3181, 3182, 3183, 3184, 3185, 3186, 3187, 3188,
-  3191, 3194, 3195, 3196, 3197, 3198, 3199, 3200,
-  3202, 3204, 3206, 3207, 3208, 3209, 3210, 3211,
-  3212, 3214, 3215, 3216, 3217, 3218, 3219, 3220,
-  3221, 3222, 3223, 3224, 3225, 3226, 3227, 3228,
-  3229, 3230, 3231, 3232, 3233, 3234, 3237, 3240,
-  3241, 3242, 3243, 3244, 3245, 3246, 3247, 3248,
-  3249, 3250, 3251, 3252, 3253, 3254, 3255, 3256,
-  3257, 3258, 3259, 3260, 3261, 3262, 3263, 3264,
-  3265, 3266, 3267, 3268, 3269, 3270, 3271, 3272,
-  3273, 3274, 3275, 3276, 3277, 3278, 3279, 3280,
-  3281, 3282, 3283, 3284, 3285, 3286, 3287, 3288,
-  3289, 3290, 3291, 3292, 3293, 3294, 3297, 3299,
-  3302, 3305, 3307, 3310, 3313, 3316, 3319, 3320,
-  3323, 3324, 3325, 3326, 3327, 3328, 3332, 3334,
-  3337, 3338, 3339, 3340, 3341, 3342, 3343, 3344,
-  3345, 3346, 3347, 3348, 3349, 3350, 3351, 3352,
-  3353, 3354, 3355, 3356, 3357, 3358, 3359, 3360,
-  3361, 3362, 3363, 3364, 3365, 3366, 3367, 3368,
-  3369, 3370, 3371, 3372, 3373, 3374, 3375, 3376,
-  3377, 3378, 3379, 3380, 3381, 3382, 3383, 3384,
-  3385, 3386, 3387, 3388, 3389, 3390, 3391, 3392,
-  3394, 3395, 3396, 3397, 3398, 3399, 3400, 3401,
-  3402, 3403, 3404, 3405, 3406, 3407, 3408, 3409,
-  3410, 3411, 3412, 3413, 3414, 3415, 3416, 3417,
-  3418, 3419, 3420, 3421, 3422, 3423, 3424, 3425,
-  3426, 3427, 3428, 3429, 3430, 3431, 3432, 3433,
-  3436, 3439, 3442, 3445, 3448, 3451, 3454, 3457,
-  3460, 3463, 3466, 3469, 3472, 3475, 3478, 3479,
-  3480, 3481, 3482, 3484, 3485, 3486, 3487, 3488,
-  3489, 3490, 3491, 3492, 3493, 3494, 3495, 3496,
-  3497, 3498, 3499, 3500, 3501, 3502, 3503, 3504,
-  3505, 3506, 3507, 3508, 3509, 3510, 3511, 3512,
-  3513, 3514, 3515, 3516, 3517, 3518, 3519, 3520,
-  3521, 3522, 3523, 3524, 3525, 3526, 3527, 3528,
-  3529, 3530, 3531, 3532, 3533, 3534, 3535, 3536,
-  3537, 3538, 3539, 3540, 3541, 3542, 3543, 3544,
-  3545, 3548, 3551, 3552, 3553, 3554, 3555, 3556,
-  3557, 3558, 3559, 3560, 3561, 3562, 3563, 3564,
-  3565, 3566, 3567, 3568, 3569, 3570, 3571, 3572,
-  3573, 3574, 3575, 3576, 3577, 3578, 3579, 3580,
-  3581, 3582, 3583, 3584, 3585, 3586, 3587, 3588,
-  3589, 3590, 3591, 3592, 3593, 3594, 3595, 3596,
-  3597, 3598, 3599, 3600, 3601, 3602, 3603, 3604,
-  3605, 3606, 3607, 3608, 3609, 3610, 3611, 3612,
-  3613, 3616, 3619, 3622, 3623, 3624, 3625, 3626,
+   389,  391,  393,  395,  397,  399,  402,  405,
+   408,  411,  414,  417,  420,  423,  426,  429,
+   432,  435,  438,  441,  444,  447,  450,  453,
+   456,  459,  462,  465,  468,  471,  474,  477,
+   480,  483,  486,  489,  490,  491,  492,  493,
+   494,  495,  496,  497,  498,  499,  500,  501,
+   502,  503,  504,  505,  506,  507,  508,  509,
+   510,  511,  512,  513,  514,  515,  516,  517,
+   518,  519,  521,  523,  525,  527,  530,  533,
+   535,  537,  540,  543,  546,  549,  551,  552,
+   553,  555,  557,  559,  561,  562,  563,  564,
+   565,  566,  567,  568,  569,  571,  573,  575,
+   577,  579,  581,  582,  584,  586,  588,  590,
+   592,  594,  596,  598,  600,  604,  606,  607,
+   608,  609,  612,  613,  617,  619,  620,  621,
+   622,  624,  628,  629,  633,  634,  635,  637,
+   639,  640,  641,  642,  643,  644,  645,  646,
+   647,  648,  649,  653,  654,  657,  661,  662,
+   668,  672,  673,  679,  683,  684,  687,  691,
+   692,  698,  702,  703,  709,  710,  711,  712,
+   713,  714,  715,  716,  717,  718,  719,  720,
+   721,  722,  723,  724,  725,  726,  727,  728,
+   729,  730,  731,  732,  735,  738,  739,  740,
+   741,  742,  743,  744,  745,  746,  747,  748,
+   749,  750,  751,  752,  753,  754,  755,  756,
+   757,  758,  759,  760,  761,  762,  763,  764,
+   765,  766,  767,  768,  769,  770,  771,  772,
+   773,  774,  775,  776,  777,  778,  779,  780,
+   781,  782,  783,  784,  785,  786,  787,  788,
+   789,  790,  791,  792,  793,  794,  795,  796,
+   797,  798,  799,  800,  801,  802,  803,  804,
+   805,  806,  807,  808,  809,  810,  811,  812,
+   813,  814,  815,  816,  817,  818,  819,  820,
+   821,  822,  823,  824,  825,  826,  827,  828,
+   829,  830,  831,  832,  833,  834,  836,  838,
+   839,  840,  841,  842,  843,  844,  845,  846,
+   847,  848,  850,  852,  854,  856,  858,  860,
+   862,  864,  866,  868,  870,  872,  874,  876,
+   878,  880,  882,  884,  886,  888,  890,  892,
+   894,  896,  898,  900,  902,  904,  906,  908,
+   909,  910,  911,  912,  913,  914,  915,  916,
+   917,  918,  919,  920,  923,  926,  929,  932,
+   935,  938,  939,  940,  941,  942,  943,  944,
+   950,  960,  964,  968,  972,  976,  980,  983,
+   987,  991,  995,  999, 1003, 1006, 1009, 1012,
+  1015, 1018, 1021, 1024, 1027, 1031, 1035, 1039,
+  1042, 1050, 1056, 1064, 1072, 1078, 1086, 1092,
+  1100, 1104, 1108, 1111, 1115, 1119, 1123, 1127,
+  1131, 1135, 1139, 1142, 1146, 1150, 1153, 1156,
+  1158, 1160, 1163, 1166, 1168, 1170, 1172, 1174,
+  1176, 1178, 1180, 1182, 1184, 1186, 1188, 1190,
+  1192, 1194, 1196, 1198, 1200, 1202, 1204, 1205,
+  1206, 1212, 1214, 1215, 1217, 1219, 1221, 1223,
+  1224, 1226, 1228, 1230, 1232, 1234, 1236, 1239,
+  1241, 1244, 1246, 1248, 1249, 1251, 1254, 1256,
+  1258, 1260, 1263, 1267, 1271, 1280, 1286, 1290,
+  1294, 1298, 1302, 1305, 1309, 1310, 1311, 1312,
+  1313, 1317, 1318, 1321, 1324, 1327, 1330, 1331,
+  1333, 1335, 1337, 1339, 1341, 1343, 1345, 1347,
+  1349, 1352, 1355, 1358, 1361, 1364, 1366, 1368,
+  1370, 1372, 1374, 1376, 1378, 1380, 1382, 1384,
+  1386, 1388, 1390, 1392, 1394, 1396, 1398, 1400,
+  1403, 1406, 1412, 1415, 1418, 1421, 1424, 1427,
+  1430, 1433, 1438, 1443, 1445, 1448, 1453, 1456,
+  1459, 1462, 1465, 1468, 1471, 1474, 1477, 1480,
+  1483, 1486, 1489, 1492, 1494, 1497, 1499, 1500,
+  1503, 1505, 1507, 1509, 1512, 1514, 1515, 1517,
+  1520, 1522, 1524, 1526, 1528, 1529, 1530, 1534,
+  1536, 1539, 1542, 1545, 1548, 1551, 1554, 1556,
+  1558, 1560, 1562, 1564, 1566, 1569, 1572, 1574,
+  1576, 1578, 1579, 1580, 1583, 1585, 1586, 1587,
+  1588, 1589, 1590, 1591, 1593, 1595, 1596, 1597,
+  1598, 1599, 1602, 1605, 1608, 1611, 1614, 1617,
+  1620, 1623, 1626, 1630, 1634, 1638, 1641, 1644,
+  1647, 1651, 1655, 1659, 1662, 1664, 1666, 1670,
+  1674, 1676, 1678, 1682, 1684, 1686, 1688, 1691,
+  1695, 1697, 1699, 1705, 1708, 1711, 1713, 1719,
+  1722, 1725, 1728, 1730, 1732, 1735, 1738, 1740,
+  1742, 1745, 1748, 1750, 1752, 1754, 1756, 1758,
+  1761, 1763, 1765, 1767, 1769, 1771, 1774, 1776,
+  1778, 1781, 1783, 1786, 1788, 1790, 1794, 1798,
+  1800, 1802, 1806, 1807, 1808, 1809, 1810, 1811,
+  1812, 1813, 1814, 1816, 1818, 1820, 1822, 1824,
+  1826, 1828, 1830, 1832, 1834, 1836, 1838, 1840,
+  1842, 1844, 1846, 1848, 1850, 1851, 1852, 1854,
+  1856, 1858, 1860, 1861, 1862, 1863, 1864, 1866,
+  1869, 1871, 1873, 1875, 1877, 1879, 1881, 1883,
+  1885, 1887, 1889, 1891, 1893, 1895, 1897, 1899,
+  1901, 1903, 1905, 1907, 1909, 1911, 1913, 1915,
+  1917, 1919, 1921, 1923, 1925, 1927, 1929, 1931,
+  1933, 1935, 1937, 1939, 1941, 1943, 1945, 1947,
+  1949, 1951, 1953, 1955, 1957, 1959, 1961, 1963,
+  1965, 1967, 1969, 1971, 1973, 1975, 1977, 1979,
+  1981, 1983, 1985, 1987, 1989, 1991, 1993, 1995,
+  1997, 1999, 2001, 2003, 2005, 2007, 2009, 2011,
+  2013, 2015, 2017, 2019, 2021, 2023, 2025, 2027,
+  2029, 2031, 2033, 2035, 2037, 2039, 2041, 2043,
+  2045, 2047, 2049, 2051, 2053, 2055, 2057, 2059,
+  2061, 2063, 2065, 2067, 2069, 2071, 2073, 2075,
+  2077, 2079, 2081, 2083, 2085, 2087, 2089, 2091,
+  2093, 2095, 2097, 2099, 2101, 2103, 2105, 2107,
+  2109, 2111, 2113, 2115, 2117, 2119, 2121, 2123,
+  2125, 2127, 2129, 2131, 2133, 2135, 2137, 2139,
+  2141, 2143, 2145, 2147, 2149, 2151, 2153, 2155,
+  2157, 2159, 2161, 2163, 2165, 2167, 2169, 2171,
+  2173, 2175, 2177, 2179, 2181, 2183, 2185, 2187,
+  2189, 2191, 2193, 2195, 2197, 2199, 2201, 2203,
+  2205, 2207, 2209, 2211, 2213, 2215, 2217, 2219,
+  2221, 2223, 2225, 2227, 2229, 2231, 2233, 2235,
+  2237, 2239, 2241, 2243, 2245, 2247, 2249, 2251,
+  2256, 2258, 2263, 2265, 2267, 2272, 2274, 2276,
+  2278, 2283, 2285, 2287, 2289, 2293, 2299, 2301,
+  2306, 2308, 2310, 2312, 2314, 2316, 2318, 2320,
+  2322, 2324, 2325, 2326, 2328, 2330, 2331, 2332,
+  2333, 2334, 2336, 2338, 2339, 2340, 2341, 2343,
+  2345, 2347, 2349, 2351, 2353, 2355, 2357, 2359,
+  2361, 2363, 2365, 2367, 2371, 2372, 2373, 2375,
+  2379, 2383, 2385, 2389, 2393, 2394, 2395, 2397,
+  2399, 2401, 2403, 2408, 2412, 2416, 2418, 2420,
+  2422, 2424, 2425, 2427, 2429, 2431, 2433, 2435,
+  2437, 2439, 2441, 2443, 2445, 2447, 2449, 2451,
+  2453, 2455, 2457, 2459, 2461, 2463, 2465, 2467,
+  2469, 2470, 2471, 2473, 2475, 2476, 2477, 2480,
+  2483, 2486, 2489, 2491, 2493, 2495, 2497, 2499,
+  2501, 2502, 2503, 2504, 2506, 2510, 2512, 2514,
+  2520, 2524, 2525, 2526, 2527, 2528, 2529, 2530,
+  2531, 2535, 2537, 2539, 2543, 2545, 2547, 2549,
+  2551, 2553, 2555, 2557, 2559, 2561, 2563, 2565,
+  2567, 2569, 2571, 2572, 2575, 2578, 2583, 2588,
+  2591, 2594, 2597, 2600, 2605, 2610, 2613, 2616,
+  2618, 2620, 2622, 2624, 2626, 2628, 2630, 2631,
+  2633, 2635, 2637, 2639, 2641, 2642, 2643, 2644,
+  2648, 2652, 2654, 2658, 2662, 2666, 2670, 2674,
+  2676, 2680, 2682, 2684, 2686, 2688, 2690, 2692,
+  2694, 2696, 2697, 2699, 2701, 2703, 2705, 2707,
+  2709, 2711, 2713, 2714, 2715, 2716, 2718, 2720,
+  2722, 2724, 2725, 2726, 2728, 2730, 2732, 2734,
+  2736, 2738, 2739, 2741, 2743, 2745, 2747, 2748,
+  2749, 2751, 2753, 2755, 2757, 2759, 2761, 2763,
+  2765, 2766, 2767, 2769, 2770, 2773, 2776, 2778,
+  2781, 2782, 2783, 2785, 2786, 2788, 2790, 2792,
+  2794, 2796, 2797, 2798, 2799, 2800, 2801, 2804,
+  2809, 2814, 2819, 2824, 2827, 2832, 2837, 2839,
+  2841, 2843, 2845, 2846, 2847, 2849, 2851, 2853,
+  2855, 2857, 2859, 2861, 2862, 2863, 2864, 2865,
+  2866, 2867, 2872, 2877, 2878, 2879, 2880, 2881,
+  2882, 2883, 2884, 2885, 2886, 2887, 2888, 2889,
+  2890, 2891, 2892, 2893, 2894, 2895, 2896, 2897,
+  2898, 2899, 2900, 2901, 2902, 2903, 2904, 2905,
+  2906, 2907, 2908, 2909, 2910, 2911, 2912, 2913,
+  2914, 2915, 2916, 2917, 2918, 2919, 2920, 2921,
+  2922, 2923, 2924, 2925, 2926, 2927, 2928, 2929,
+  2930, 2931, 2932, 2933, 2934, 2935, 2936, 2937,
+  2938, 2939, 2940, 2941, 2942, 2943, 2944, 2945,
+  2946, 2947, 2948, 2949, 2950, 2951, 2952, 2953,
+  2954, 2955, 2956, 2957, 2958, 2959, 2960, 2961,
+  2962, 2963, 2964, 2965, 2966, 2967, 2968, 2969,
+  2970, 2971, 2972, 2973, 2974, 2975, 2976, 2977,
+  2978, 2979, 2980, 2981, 2982, 2983, 2984, 2985,
+  2986, 2987, 2988, 2989, 2990, 2991, 2992, 2993,
+  2994, 2995, 2996, 2997, 2998, 2999, 3000, 3001,
+  3002, 3003, 3004, 3005, 3006, 3007, 3008, 3009,
+  3010, 3011, 3012, 3013, 3014, 3015, 3016, 3017,
+  3018, 3019, 3020, 3021, 3022, 3023, 3024, 3025,
+  3026, 3027, 3028, 3029, 3030, 3031, 3032, 3033,
+  3034, 3035, 3036, 3037, 3038, 3039, 3040, 3041,
+  3042, 3043, 3044, 3045, 3046, 3047, 3048, 3049,
+  3050, 3051, 3052, 3053, 3054, 3055, 3056, 3057,
+  3058, 3059, 3060, 3061, 3062, 3063, 3064, 3065,
+  3066, 3067, 3068, 3069, 3070, 3071, 3072, 3073,
+  3074, 3075, 3076, 3077, 3078, 3080, 3082, 3083,
+  3084, 3085, 3086, 3087, 3088, 3089, 3090, 3091,
+  3092, 3093, 3094, 3095, 3096, 3097, 3098, 3099,
+  3100, 3101, 3102, 3103, 3104, 3105, 3106, 3107,
+  3108, 3109, 3110, 3112, 3114, 3116, 3118, 3119,
+  3120, 3121, 3122, 3123, 3124, 3125, 3126, 3127,
+  3128, 3129, 3130, 3131, 3133, 3134, 3135, 3136,
+  3138, 3139, 3140, 3141, 3142, 3143, 3144, 3145,
+  3146, 3147, 3148, 3149, 3150, 3151, 3152, 3153,
+  3154, 3155, 3156, 3157, 3158, 3159, 3160, 3161,
+  3162, 3163, 3164, 3165, 3166, 3167, 3168, 3169,
+  3170, 3171, 3172, 3173, 3174, 3175, 3176, 3177,
+  3178, 3179, 3181, 3183, 3184, 3185, 3187, 3188,
+  3190, 3192, 3193, 3194, 3196, 3198, 3200, 3202,
+  3203, 3204, 3205, 3206, 3207, 3208, 3209, 3210,
+  3211, 3212, 3213, 3214, 3215, 3216, 3217, 3218,
+  3221, 3224, 3225, 3226, 3227, 3228, 3229, 3230,
+  3232, 3234, 3236, 3237, 3238, 3239, 3240, 3241,
+  3242, 3244, 3245, 3246, 3247, 3248, 3249, 3250,
+  3251, 3252, 3253, 3254, 3255, 3256, 3257, 3258,
+  3259, 3260, 3261, 3262, 3263, 3264, 3267, 3270,
+  3271, 3272, 3273, 3274, 3275, 3276, 3277, 3278,
+  3279, 3280, 3281, 3282, 3283, 3284, 3285, 3286,
+  3287, 3288, 3289, 3290, 3291, 3292, 3293, 3294,
+  3295, 3296, 3297, 3298, 3299, 3300, 3301, 3302,
+  3303, 3304, 3305, 3306, 3307, 3308, 3309, 3310,
+  3311, 3312, 3313, 3314, 3315, 3316, 3317, 3318,
+  3319, 3320, 3321, 3322, 3323, 3324, 3327, 3329,
+  3332, 3335, 3337, 3340, 3343, 3346, 3349, 3350,
+  3353, 3354, 3355, 3356, 3357, 3358, 3362, 3364,
+  3367, 3368, 3369, 3370, 3371, 3372, 3373, 3374,
+  3375, 3376, 3377, 3378, 3379, 3380, 3381, 3382,
+  3383, 3384, 3385, 3386, 3387, 3388, 3389, 3390,
+  3391, 3392, 3393, 3394, 3395, 3396, 3397, 3398,
+  3399, 3400, 3401, 3402, 3403, 3404, 3405, 3406,
+  3407, 3408, 3409, 3410, 3411, 3412, 3413, 3414,
+  3415, 3416, 3417, 3418, 3419, 3420, 3421, 3422,
+  3424, 3425, 3426, 3427, 3428, 3429, 3430, 3431,
+  3432, 3433, 3434, 3435, 3436, 3437, 3438, 3439,
+  3440, 3441, 3442, 3443, 3444, 3445, 3446, 3447,
+  3448, 3449, 3450, 3451, 3452, 3453, 3454, 3455,
+  3456, 3457, 3458, 3459, 3460, 3461, 3462, 3463,
+  3466, 3469, 3472, 3475, 3478, 3481, 3484, 3487,
+  3490, 3493, 3496, 3499, 3502, 3505, 3508, 3509,
+  3510, 3511, 3512, 3514, 3515, 3516, 3517, 3518,
+  3519, 3520, 3521, 3522, 3523, 3524, 3525, 3526,
+  3527, 3528, 3529, 3530, 3531, 3532, 3533, 3534,
+  3535, 3536, 3537, 3538, 3539, 3540, 3541, 3542,
+  3543, 3544, 3545, 3546, 3547, 3548, 3549, 3550,
+  3551, 3552, 3553, 3554, 3555, 3556, 3557, 3558,
+  3559, 3560, 3561, 3562, 3563, 3564, 3565, 3566,
+  3567, 3568, 3569, 3570, 3571, 3572, 3573, 3574,
+  3575, 3578, 3581, 3582, 3583, 3584, 3585, 3586,
+  3587, 3588, 3589, 3590, 3591, 3592, 3593, 3594,
+  3595, 3596, 3597, 3598, 3599, 3600, 3601, 3602,
+  3603, 3604, 3605, 3606, 3607, 3608, 3609, 3610,
+  3611, 3612, 3613, 3614, 3615, 3616, 3617, 3618,
+  3619, 3620, 3621, 3622, 3623, 3624, 3625, 3626,
   3627, 3628, 3629, 3630, 3631, 3632, 3633, 3634,
-  3635, 3636, 3637, 3638, 3641, 3644, 3645, 3646,
-  3649, 3650, 3651, 3652, 3653, 3656, 3659, 3662,
-  3663, 3664, 3665, 3666, 3667, 3668, 3669, 3670,
-  3671, 3672, 3674, 3676, 3677, 3678, 3679, 3680,
-  3681, 3682, 3683, 3684, 3685, 3686, 3687, 3688,
-  3689, 3690, 3691, 3692, 3693, 3694, 3695, 3696,
-  3697, 3698, 3699, 3700, 3701, 3703, 3705, 3706,
-  3707, 3708, 3709, 3710, 3711, 3712, 3713, 3714,
-  3715, 3716, 3717, 3718, 3719, 3720, 3721, 3722,
-  3723, 3724, 3725, 3726, 3727, 3728, 3729, 3730,
-  3732, 3734, 3736, 3738, 3739, 3740, 3741, 3742,
-  3743, 3744, 3745, 3746, 3747, 3748, 3749, 3750,
-  3751, 3752, 3753, 3755, 3756, 3758, 3761, 3763,
-  3764, 3765, 3767, 3769, 3770, 3771, 3772, 3773,
-  3774, 3775, 3777, 3779, 3781, 3783, 3784, 3785,
-  3786, 3787, 3788, 3789, 3790, 3791, 3792, 3794,
-  3796, 3797, 3799, 3801, 3802, 3807, 3809, 3811,
-  3812, 3813, 3814, 3815, 3816, 3817, 3818, 3820,
-  3822, 3823, 3824, 3825, 3827, 3830, 3833, 3836,
-  3838, 3839, 3840, 3841, 3842, 3843, 3844, 3845,
-  3846, 3847, 3848, 3849, 3850, 3851, 3852, 3853,
-  3854, 3855, 3856, 3857, 3858, 3859, 3860, 3861,
-  3862, 3863, 3864, 3865, 3866, 3867, 3868, 3869,
-  3870, 3871, 3872, 3873, 3874, 3875, 3876, 3877,
-  3878, 3879, 3880, 3881, 3882, 3883, 3884, 3885,
-  3886, 3887, 3888, 3889, 3890, 3891, 3892, 3893,
-  3894, 3895, 3896, 3897, 3898, 3899, 3900, 3901,
-  3902, 3903, 3904, 3905, 3906, 3907, 3908, 3909,
-  3910, 3911, 3912, 3913, 3914, 3915, 3916, 3917,
-  3918, 3919, 3920, 3921, 3922, 3923, 3924, 3925,
-  3926, 3927, 3928, 3929, 3930, 3931, 3932, 3933,
-  3934, 3935, 3936, 3937, 3938, 3939, 3940, 3941,
-  3942, 3943, 3944, 3945, 3946, 3947, 3948, 3949,
-  3950, 3951, 3952, 3953, 3954, 3955, 3956, 3957,
-  3958, 3959, 3960, 3961, 3962, 3963, 3964, 3965,
-  3966, 3967, 3968, 3969, 3970, 3971, 3972, 3973,
-  3974, 3975, 3976, 3977, 3978, 3979, 3980, 3983,
-  3984, 3985, 3988, 3989, 3990, 3992, 3993, 3994,
-  3995, 3997, 3998, 3999, 4000, 4002, 4003, 4004,
-  4005, 4008, 4009, 4010, 4011, 4012, 4015, 4018,
-  4021, 4024, 4027, 4028, 4029, 4030, 4031, 4033,
-  4035, 4036, 4037, 4038, 4041, 4044, 4047, 4050,
-  4053, 4054, 4055, 4056, 4058, 4059, 4060, 4061,
-  4063, 4064, 4065, 4066, 4067, 4068, 4069, 4070,
-  4071, 4072, 4073, 4074, 4075, 4076, 4077, 4078,
-  4079, 4080, 4081, 4082, 4083, 4084, 4085, 4086,
-  4087, 4088, 4089, 4090, 4091, 4092, 4093, 4094,
-  4095, 4096, 4097, 4098, 4099, 4100, 4101, 4102,
-  4104, 4106, 4108, 4110, 4112, 4113, 4114, 4117,
-  4120, 4121, 4122, 4123, 4124
+  3635, 3636, 3637, 3638, 3639, 3640, 3641, 3642,
+  3643, 3646, 3649, 3652, 3653, 3654, 3655, 3656,
+  3657, 3658, 3659, 3660, 3661, 3662, 3663, 3664,
+  3665, 3666, 3667, 3668, 3671, 3674, 3675, 3676,
+  3679, 3680, 3681, 3682, 3683, 3686, 3689, 3692,
+  3693, 3694, 3695, 3696, 3697, 3698, 3699, 3700,
+  3701, 3702, 3704, 3706, 3707, 3708, 3709, 3710,
+  3711, 3712, 3713, 3714, 3715, 3716, 3717, 3718,
+  3719, 3720, 3721, 3722, 3723, 3724, 3725, 3726,
+  3727, 3728, 3729, 3730, 3731, 3733, 3735, 3736,
+  3737, 3738, 3739, 3740, 3741, 3742, 3743, 3744,
+  3745, 3746, 3747, 3748, 3749, 3750, 3751, 3752,
+  3753, 3754, 3755, 3756, 3757, 3758, 3759, 3760,
+  3762, 3764, 3766, 3768, 3769, 3770, 3771, 3772,
+  3773, 3774, 3775, 3776, 3777, 3778, 3779, 3780,
+  3781, 3782, 3783, 3785, 3786, 3788, 3791, 3793,
+  3794, 3795, 3797, 3799, 3800, 3801, 3802, 3803,
+  3804, 3805, 3807, 3809, 3811, 3813, 3814, 3815,
+  3816, 3817, 3818, 3819, 3820, 3821, 3822, 3824,
+  3826, 3827, 3829, 3831, 3832, 3837, 3839, 3841,
+  3842, 3843, 3844, 3845, 3846, 3847, 3848, 3850,
+  3852, 3853, 3854, 3855, 3857, 3860, 3863, 3866,
+  3868, 3869, 3870, 3871, 3872, 3873, 3874, 3875,
+  3876, 3877, 3878, 3879, 3880, 3881, 3882, 3883,
+  3884, 3885, 3886, 3887, 3888, 3889, 3890, 3891,
+  3892, 3893, 3894, 3895, 3896, 3897, 3898, 3899,
+  3900, 3901, 3902, 3903, 3904, 3905, 3906, 3907,
+  3908, 3909, 3910, 3911, 3912, 3913, 3914, 3915,
+  3916, 3917, 3918, 3919, 3920, 3921, 3922, 3923,
+  3924, 3925, 3926, 3927, 3928, 3929, 3930, 3931,
+  3932, 3933, 3934, 3935, 3936, 3937, 3938, 3939,
+  3940, 3941, 3942, 3943, 3944, 3945, 3946, 3947,
+  3948, 3949, 3950, 3951, 3952, 3953, 3954, 3955,
+  3956, 3957, 3958, 3959, 3960, 3961, 3962, 3963,
+  3964, 3965, 3966, 3967, 3968, 3969, 3970, 3971,
+  3972, 3973, 3974, 3975, 3976, 3977, 3978, 3979,
+  3980, 3981, 3982, 3983, 3984, 3985, 3986, 3987,
+  3988, 3989, 3990, 3991, 3992, 3993, 3994, 3995,
+  3996, 3997, 3998, 3999, 4000, 4001, 4002, 4003,
+  4004, 4005, 4006, 4007, 4008, 4009, 4010, 4013,
+  4014, 4015, 4018, 4019, 4020, 4022, 4023, 4024,
+  4025, 4027, 4028, 4029, 4030, 4032, 4033, 4034,
+  4035, 4038, 4039, 4040, 4041, 4042, 4045, 4048,
+  4051, 4054, 4057, 4058, 4059, 4060, 4061, 4063,
+  4065, 4066, 4067, 4068, 4071, 4074, 4077, 4080,
+  4083, 4084, 4085, 4086, 4088, 4089, 4090, 4091,
+  4093, 4094, 4095, 4096, 4097, 4098, 4099, 4100,
+  4101, 4102, 4103, 4104, 4105, 4106, 4107, 4108,
+  4109, 4110, 4111, 4112, 4113, 4114, 4115, 4116,
+  4117, 4118, 4119, 4120, 4121, 4122, 4123, 4124,
+  4125, 4126, 4127, 4128, 4129, 4130, 4131, 4132,
+  4134, 4136, 4138, 4140, 4142, 4143, 4144, 4147,
+  4150, 4151, 4152, 4153, 4154
 };
 
 /* i386 mnemonics table.  */