]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
x86: templatize binary ALU insns
authorJan Beulich <jbeulich@suse.com>
Thu, 28 Mar 2024 10:49:01 +0000 (11:49 +0100)
committerJan Beulich <jbeulich@suse.com>
Thu, 28 Mar 2024 10:49:01 +0000 (11:49 +0100)
With the multitude of new APX templates, it finally becomes desirable to
further remove redundancy by also templatizing basic arithmetic insns.
Continue with a the more complex binary (two source) cases.

Note how this adds a missing CheckOperandSize to one of the APX sub
forms.

Furthermore since SBB already had a non-NDD APX form, one ends up
being added for the other 6 mnemonics, too.

opcodes/i386-opc.tbl
opcodes/i386-tbl.h

index dbf33ff400eada80c4032b67e7e27b45f6f1eea0..076618564e79816037482d91ea1dafa3c81c7453 100644 (file)
@@ -308,30 +308,29 @@ std, 0xfd, 0, NoSuf, {}
 sti, 0xfb, 0, NoSuf, {}
 
 // Arithmetic.
-add, 0x0, APX_F, D|C|W|CheckOperandSize|Modrm|No_sSuf|DstVVVV|EVexMap4|NF, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-add, 0x0, 0, D|W|CheckOperandSize|Modrm|No_sSuf|HLEPrefixLock, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-add, 0x83/0, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
-add, 0x83/0, 0, Modrm|No_bSuf|No_sSuf|HLEPrefixLock, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-add, 0x4, 0, W|No_sSuf, { Imm8|Imm16|Imm32|Imm32S, Acc|Byte|Word|Dword|Qword }
-add, 0x80/0, APX_F, W|Modrm|CheckOperandSize|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64}
-add, 0x80/0, 0, W|Modrm|No_sSuf|HLEPrefixLock, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-
-sub, 0x28, APX_F, D|W|CheckOperandSize|Modrm|No_sSuf|DstVVVV|EVexMap4|NF|Optimize, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64, }
-sub, 0x28, 0, D|W|CheckOperandSize|Modrm|No_sSuf|HLEPrefixLock|Optimize, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-sub, 0x83/5, APX_F, Modrm|No_bSuf|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
-sub, 0x83/5, 0, Modrm|No_bSuf|No_sSuf|HLEPrefixLock, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-sub, 0x2c, 0, W|No_sSuf, { Imm8|Imm16|Imm32|Imm32S, Acc|Byte|Word|Dword|Qword }
-sub, 0x80/5, APX_F, W|Modrm|CheckOperandSize|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-sub, 0x80/5, 0, W|Modrm|No_sSuf|HLEPrefixLock, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-
-sbb, 0x18, APX_F, D|W|CheckOperandSize|Modrm|No_sSuf|DstVVVV|EVexMap4, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-sbb, 0x18, 0, D|W|CheckOperandSize|Modrm|No_sSuf|HLEPrefixLock, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-sbb, 0x83/3, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
-sbb, 0x83/3, 0, Modrm|No_bSuf|No_sSuf|HLEPrefixLock, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-sbb, 0x1c, 0, W|No_sSuf, { Imm8|Imm16|Imm32|Imm32S, Acc|Byte|Word|Dword|Qword }
-sbb, 0x80/3, APX_F, W|Modrm|CheckOperandSize|No_sSuf|DstVVVV|EVexMap4, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-sbb, 0x80/3, 0, W|Modrm|No_sSuf|HLEPrefixLock, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-sbb, 0x80/3, APX_F, W|Modrm|EVexMap4|No_sSuf, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
+
+<alu2:opc:c:optz:optt:opti:nf, +
+    add:0:C::::NF, +
+    or:1:C::Optimize::NF, +
+    adc:2:C::::, +
+    sbb:3:::::, +
+    and:4:C::Optimize:Optimize:NF, +
+    sub:5::Optimize:::NF, +
+    xor:6:C:Optimize:::NF>
+
+<alu2>, <alu2:opc> << 3, APX_F, D|<alu2:c>|W|CheckOperandSize|Modrm|No_sSuf|DstVVVV|EVexMap4|<alu2:nf>|<alu2:optz>, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
+<alu2>, <alu2:opc> << 3, 0, D|W|CheckOperandSize|Modrm|No_sSuf|HLEPrefixLock|<alu2:optz>|<alu2:optt>, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
+<alu2>, 0x83/<alu2:opc>, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4|<alu2:nf>, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
+<alu2>, 0x83/<alu2:opc>, 0, Modrm|No_bSuf|No_sSuf|HLEPrefixLock|<alu2:opti>, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
+<alu2>, 0x04 | (<alu2:opc> << 3), 0, W|No_sSuf|<alu2:opti>, { Imm8|Imm16|Imm32|Imm32S, Acc|Byte|Word|Dword|Qword }
+<alu2>, 0x80/<alu2:opc>, APX_F, W|Modrm|CheckOperandSize|No_sSuf|DstVVVV|EVexMap4|<alu2:nf>, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
+<alu2>, 0x80/<alu2:opc>, 0, W|Modrm|No_sSuf|HLEPrefixLock|<alu2:opti>, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
+<alu2>, 0x80/<alu2:opc>, APX_F, W|Modrm|EVexMap4|No_sSuf, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
+
+<alu2>
+
+// clr with 1 operand is really xor with 2 operands.
+clr, 0x30, 0, W|Modrm|No_sSuf|RegKludge|Optimize, { Reg8|Reg16|Reg32|Reg64 }
 
 cmp, 0x38, 0, D|W|CheckOperandSize|Modrm|No_sSuf, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
 cmp, 0x83/7, 0, Modrm|No_bSuf|No_sSuf, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
@@ -342,41 +341,6 @@ test, 0x84, 0, D|W|C|CheckOperandSize|Modrm|No_sSuf, { Reg8|Reg16|Reg32|Reg64, R
 test, 0xa8, 0, W|No_sSuf|Optimize, { Imm8|Imm16|Imm32|Imm32S, Acc|Byte|Word|Dword|Qword }
 test, 0xf6/0, 0, W|Modrm|No_sSuf|Optimize, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
 
-and, 0x20, APX_F, D|C|W|CheckOperandSize|Modrm|No_sSuf|DstVVVV|EVexMap4|NF, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-and, 0x20, 0, D|W|CheckOperandSize|Modrm|No_sSuf|HLEPrefixLock|Optimize, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-and, 0x83/4, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
-and, 0x83/4, 0, Modrm|No_bSuf|No_sSuf|HLEPrefixLock|Optimize, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-and, 0x24, 0, W|No_sSuf|Optimize, { Imm8|Imm16|Imm32|Imm32S, Acc|Byte|Word|Dword|Qword }
-and, 0x80/4, APX_F, W|Modrm|CheckOperandSize|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-and, 0x80/4, 0, W|Modrm|No_sSuf|HLEPrefixLock|Optimize, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-
-or, 0x8, APX_F, D|C|W|CheckOperandSize|Modrm|No_sSuf|DstVVVV|EVexMap4|NF, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-or, 0x8, 0, D|W|CheckOperandSize|Modrm|No_sSuf|HLEPrefixLock|Optimize, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-or, 0x83/1, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
-or, 0x83/1, 0, Modrm|No_bSuf|No_sSuf|HLEPrefixLock, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-or, 0xc, 0, W|No_sSuf, { Imm8|Imm16|Imm32|Imm32S, Acc|Byte|Word|Dword|Qword }
-or, 0x80/1, APX_F, W|Modrm|CheckOperandSize|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-or, 0x80/1, 0, W|Modrm|No_sSuf|HLEPrefixLock, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-
-xor, 0x30, APX_F, D|C|W|CheckOperandSize|Modrm|No_sSuf|DstVVVV|EVexMap4|NF|Optimize, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-xor, 0x30, 0, D|W|CheckOperandSize|Modrm|No_sSuf|HLEPrefixLock|Optimize, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-xor, 0x83/6, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
-xor, 0x83/6, 0, Modrm|No_bSuf|No_sSuf|HLEPrefixLock, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-xor, 0x34, 0, W|No_sSuf, { Imm8|Imm16|Imm32|Imm32S, Acc|Byte|Word|Dword|Qword }
-xor, 0x80/6, APX_F, W|Modrm|CheckOperandSize|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-xor, 0x80/6, 0, W|Modrm|No_sSuf|HLEPrefixLock, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-
-// clr with 1 operand is really xor with 2 operands.
-clr, 0x30, 0, W|Modrm|No_sSuf|RegKludge|Optimize, { Reg8|Reg16|Reg32|Reg64 }
-
-adc, 0x10, APX_F, D|C|W|CheckOperandSize|Modrm|No_sSuf|DstVVVV|EVexMap4, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-adc, 0x10, 0, D|W|CheckOperandSize|Modrm|No_sSuf|HLEPrefixLock, { Reg8|Reg16|Reg32|Reg64, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-adc, 0x83/2, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
-adc, 0x83/2, 0, Modrm|No_bSuf|No_sSuf|HLEPrefixLock, { Imm8S, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-adc, 0x14, 0, W|No_sSuf, { Imm8|Imm16|Imm32|Imm32S, Acc|Byte|Word|Dword|Qword }
-adc, 0x80/2, APX_F, W|Modrm|CheckOperandSize|No_sSuf|DstVVVV|EVexMap4, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg8|Reg16|Reg32|Reg64 }
-adc, 0x80/2, 0, W|Modrm|No_sSuf|HLEPrefixLock, { Imm8|Imm16|Imm32|Imm32S, Reg8|Reg16|Reg32|Reg64|Unspecified|BaseIndex }
-
 <incdec:opc, inc:0, dec:1>
 
 <incdec>, 0x40 | (<incdec:opc> << 3), No64, No_bSuf|No_sSuf|No_qSuf, { Reg16|Reg32 }
index 0d78437b448ba9d32476edb8878510f7bd4a8444..2bdbac9e95924d6a6bdc12db5c74b8ff9d8cba39 100644 (file)
@@ -792,7 +792,7 @@ static const insn_template i386_optab[] =
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
     { { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_add, 0x00, 3, SPACE_EVEXMAP4, None,
+  { MN_add, 0x00 <<3, 3, SPACE_EVEXMAP4, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1,
       0 },
@@ -804,7 +804,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_add, 0x00, 2, SPACE_BASE, None,
+  { MN_add, 0x00 <<3, 2, SPACE_BASE, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -836,7 +836,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_add, 0x04, 2, SPACE_BASE, None,
+  { MN_add, 0x04 | (0 <<3), 2, SPACE_BASE, None,
     { 0, 1, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -868,9 +868,19 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_sub, 0x28, 3, SPACE_EVEXMAP4, None,
+  { MN_add, 0x80, 2, SPACE_EVEXMAP4, 0,
+    { 0, 1, 0, 1, 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, 2, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
+    { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 0, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_or, 0x01 <<3, 3, SPACE_EVEXMAP4, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
-      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1,
+      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1,
       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 } },
@@ -880,7 +890,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_sub, 0x28, 2, SPACE_BASE, None,
+  { MN_or, 0x01 <<3, 2, SPACE_BASE, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
       0 },
@@ -890,8 +900,8 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_sub, 0x83, 3, SPACE_EVEXMAP4, 5,
-    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+  { MN_or, 0x83, 3, SPACE_EVEXMAP4, 1,
+    { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
       0 },
     { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0 } },
@@ -902,7 +912,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_sub, 0x83, 2, SPACE_BASE, 5,
+  { MN_or, 0x83, 2, SPACE_BASE, 1,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -912,7 +922,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_sub, 0x2c, 2, SPACE_BASE, None,
+  { MN_or, 0x04 | (1 <<3), 2, SPACE_BASE, None,
     { 0, 1, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -922,7 +932,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_sub, 0x80, 3, SPACE_EVEXMAP4, 5,
+  { MN_or, 0x80, 3, SPACE_EVEXMAP4, 1,
     { 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
       0 },
@@ -934,7 +944,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_sub, 0x80, 2, SPACE_BASE, 5,
+  { MN_or, 0x80, 2, SPACE_BASE, 1,
     { 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -944,9 +954,19 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_sbb, 0x18, 3, SPACE_EVEXMAP4, None,
+  { MN_or, 0x80, 2, SPACE_EVEXMAP4, 1,
+    { 0, 1, 0, 1, 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, 2, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
+    { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 0, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_adc, 0x02 <<3, 3, SPACE_EVEXMAP4, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
-      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 0, 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 } },
@@ -956,7 +976,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_sbb, 0x18, 2, SPACE_BASE, None,
+  { MN_adc, 0x02 <<3, 2, SPACE_BASE, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -966,7 +986,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_sbb, 0x83, 3, SPACE_EVEXMAP4, 3,
+  { MN_adc, 0x83, 3, SPACE_EVEXMAP4, 2,
     { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -978,7 +998,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_sbb, 0x83, 2, SPACE_BASE, 3,
+  { MN_adc, 0x83, 2, SPACE_BASE, 2,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -988,7 +1008,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_sbb, 0x1c, 2, SPACE_BASE, None,
+  { MN_adc, 0x04 | (2 <<3), 2, SPACE_BASE, None,
     { 0, 1, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -998,7 +1018,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_sbb, 0x80, 3, SPACE_EVEXMAP4, 3,
+  { MN_adc, 0x80, 3, SPACE_EVEXMAP4, 2,
     { 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -1010,7 +1030,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_sbb, 0x80, 2, SPACE_BASE, 3,
+  { MN_adc, 0x80, 2, SPACE_BASE, 2,
     { 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -1020,7 +1040,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_sbb, 0x80, 2, SPACE_EVEXMAP4, 3,
+  { MN_adc, 0x80, 2, SPACE_EVEXMAP4, 2,
     { 0, 1, 0, 1, 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, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -1030,8 +1050,20 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_cmp, 0x38, 2, SPACE_BASE, None,
+  { MN_sbb, 0x03 <<3, 3, SPACE_EVEXMAP4, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 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, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 0, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 0, 0 } } } },
+  { MN_sbb, 0x03 <<3, 2, SPACE_BASE, None,
+    { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
@@ -1040,8 +1072,20 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_cmp, 0x83, 2, SPACE_BASE, 7,
-    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+  { MN_sbb, 0x83, 3, SPACE_EVEXMAP4, 3,
+    { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
+    { { { 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 0, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 0, 0 } } } },
+  { MN_sbb, 0x83, 2, SPACE_BASE, 3,
+    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
@@ -1050,7 +1094,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_cmp, 0x3c, 2, SPACE_BASE, None,
+  { MN_sbb, 0x04 | (3 <<3), 2, SPACE_BASE, None,
     { 0, 1, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -1060,47 +1104,39 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_cmp, 0x80, 2, SPACE_BASE, 7,
-    { 0, 1, 0, 1, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+  { MN_sbb, 0x80, 3, SPACE_EVEXMAP4, 3,
+    { 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
+      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
-    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
     { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
          0, 0, 0, 0, 0, 0 } },
-      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
-         0, 0, 0, 0, 1, 0 } } } },
-  { MN_test, 0x84, 2, SPACE_BASE, None,
-    { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
-      0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0,
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 0, 0 } } } },
+  { MN_sbb, 0x80, 2, SPACE_BASE, 3,
+    { 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
+      0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 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, 1, 1, 0, 1, 0,
+    { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_test, 0xa8, 2, SPACE_BASE, None,
-    { 0, 1, 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, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0,
-      0 },
-    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
-    { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 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, 1, 1, 1, 0, 1, 0,
-         0, 0, 0, 0, 0, 0 } } } },
-  { MN_test, 0xf6, 2, SPACE_BASE, 0,
+  { MN_sbb, 0x80, 2, SPACE_EVEXMAP4, 3,
     { 0, 1, 0, 1, 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, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
+      0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
-    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
     { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
          0, 0, 0, 0, 0, 0 } },
-      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_and, 0x20, 3, SPACE_EVEXMAP4, None,
+  { MN_and, 0x04 <<3, 3, SPACE_EVEXMAP4, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1,
       0 },
@@ -1112,7 +1148,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_and, 0x20, 2, SPACE_BASE, None,
+  { MN_and, 0x04 <<3, 2, SPACE_BASE, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
       0 },
@@ -1144,7 +1180,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_and, 0x24, 2, SPACE_BASE, None,
+  { MN_and, 0x04 | (4 <<3), 2, SPACE_BASE, None,
     { 0, 1, 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, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
       0 },
@@ -1176,9 +1212,19 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_or, 0x08, 3, SPACE_EVEXMAP4, None,
+  { MN_and, 0x80, 2, SPACE_EVEXMAP4, 4,
+    { 0, 1, 0, 1, 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, 2, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
+    { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 0, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_sub, 0x05 <<3, 3, SPACE_EVEXMAP4, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
-      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1,
+      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1,
       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 } },
@@ -1188,7 +1234,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_or, 0x08, 2, SPACE_BASE, None,
+  { MN_sub, 0x05 <<3, 2, SPACE_BASE, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
       0 },
@@ -1198,7 +1244,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_or, 0x83, 3, SPACE_EVEXMAP4, 1,
+  { MN_sub, 0x83, 3, SPACE_EVEXMAP4, 5,
     { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
       0 },
@@ -1210,7 +1256,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_or, 0x83, 2, SPACE_BASE, 1,
+  { MN_sub, 0x83, 2, SPACE_BASE, 5,
     { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -1220,7 +1266,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_or, 0x0c, 2, SPACE_BASE, None,
+  { MN_sub, 0x04 | (5 <<3), 2, SPACE_BASE, None,
     { 0, 1, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -1230,7 +1276,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_or, 0x80, 3, SPACE_EVEXMAP4, 1,
+  { MN_sub, 0x80, 3, SPACE_EVEXMAP4, 5,
     { 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
       0 },
@@ -1242,7 +1288,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_or, 0x80, 2, SPACE_BASE, 1,
+  { MN_sub, 0x80, 2, SPACE_BASE, 5,
     { 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -1252,7 +1298,17 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_xor, 0x30, 3, SPACE_EVEXMAP4, None,
+  { MN_sub, 0x80, 2, SPACE_EVEXMAP4, 5,
+    { 0, 1, 0, 1, 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, 2, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
+    { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 0, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_xor, 0x06 <<3, 3, SPACE_EVEXMAP4, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 1, 0, 0, 0, 1,
       0 },
@@ -1264,7 +1320,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 1, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_xor, 0x30, 2, SPACE_BASE, None,
+  { MN_xor, 0x06 <<3, 2, SPACE_BASE, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
       0 },
@@ -1296,7 +1352,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_xor, 0x34, 2, SPACE_BASE, None,
+  { MN_xor, 0x04 | (6 <<3), 2, SPACE_BASE, None,
     { 0, 1, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -1328,6 +1384,16 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
+  { MN_xor, 0x80, 2, SPACE_EVEXMAP4, 6,
+    { 0, 1, 0, 1, 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, 2, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
+    { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+         0, 0, 0, 0, 0, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } } } },
   { MN_clr, 0x30, 1, SPACE_BASE, None,
     { 0, 1, 0, 1, 0, 0, 0, 0, 2, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
@@ -1336,20 +1402,8 @@ static const insn_template i386_optab[] =
     { { 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, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_adc, 0x10, 3, SPACE_EVEXMAP4, None,
+  { MN_cmp, 0x38, 2, SPACE_BASE, None,
     { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
-      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0, 0, 0, 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, 1, 1, 0, 1, 0,
-         0, 0, 0, 0, 0, 0 } },
-      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
-         0, 0, 0, 0, 1, 0 } },
-      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
-         0, 0, 0, 0, 0, 0 } } } },
-  { MN_adc, 0x10, 2, SPACE_BASE, None,
-    { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
       0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
@@ -1358,20 +1412,8 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_adc, 0x83, 3, SPACE_EVEXMAP4, 2,
-    { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 0,
-      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
-    { { { 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
-         0, 0, 0, 0, 0, 0 } },
-      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 0, 1, 1, 0, 1, 0,
-         0, 0, 0, 0, 1, 0 } },
-      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 1, 0,
-         0, 0, 0, 0, 0, 0 } } } },
-  { MN_adc, 0x83, 2, SPACE_BASE, 2,
-    { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 0, 5,
+  { MN_cmp, 0x83, 2, SPACE_BASE, 7,
+    { 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
@@ -1380,7 +1422,7 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } } } },
-  { MN_adc, 0x14, 2, SPACE_BASE, None,
+  { MN_cmp, 0x3c, 2, SPACE_BASE, None,
     { 0, 1, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
       0 },
@@ -1390,21 +1432,39 @@ static const insn_template i386_optab[] =
          0, 0, 0, 0, 0, 0 } },
       { { 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_adc, 0x80, 3, SPACE_EVEXMAP4, 2,
-    { 0, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0,
-      0, 0, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+  { MN_cmp, 0x80, 2, SPACE_BASE, 7,
+    { 0, 1, 0, 1, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0, 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 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
     { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
          0, 0, 0, 0, 0, 0 } },
-      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1, 0, 1, 1, 1, 1, 0, 1, 0,
-         0, 0, 0, 0, 1, 0 } },
-      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0,
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_test, 0x84, 2, SPACE_BASE, None,
+    { 1, 1, 0, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0, 0, 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, 0, 0, 0, 0, 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, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 0, 0 } },
+      { { 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 0,
+         0, 0, 0, 0, 1, 0 } } } },
+  { MN_test, 0xa8, 2, SPACE_BASE, None,
+    { 0, 1, 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, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 0,
+      0 },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
+    { { { 0, 0, 0, 1, 0, 1, 1, 1, 0, 0, 0, 0, 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, 1, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 0, 0 } } } },
-  { MN_adc, 0x80, 2, SPACE_BASE, 2,
-    { 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 5,
-      0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
+  { MN_test, 0xf6, 2, SPACE_BASE, 0,
+    { 0, 1, 0, 1, 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, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 0,
       0 },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
     { { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 } },
@@ -41378,295 +41438,295 @@ static const i386_op_off_t i386_op_sets[] =
     48,   49,   50,   52,   56,   60,   61,   62,
     63,   65,   67,   69,   70,   71,   72,   73,
     74,   76,   78,   80,   82,   83,   84,   85,
-    92,   99,  107,  111,  114,  121,  128,  135,
-   136,  143,  146,  149,  151,  153,  154,  155,
-   156,  157,  159,  161,  162,  163,  164,  165,
-   166,  167,  168,  169,  170,  171,  172,  173,
-   174,  181,  183,  185,  192,  199,  210,  221,
-   228,  235,  242,  249,  255,  261,  270,  273,
-   281,  284,  290,  292,  294,  296,  298,  299,
-   300,  301,  302,  303,  304,  305,  306,  307,
-   308,  309,  310,  311,  312,  313,  314,  315,
-   316,  317,  318,  319,  320,  321,  322,  323,
-   324,  325,  326,  327,  328,  329,  330,  331,
-   333,  335,  337,  339,  341,  342,  343,  344,
-   345,  346,  347,  348,  349,  350,  351,  352,
-   353,  354,  355,  356,  357,  358,  359,  360,
-   361,  362,  363,  364,  365,  366,  367,  368,
-   369,  370,  371,  373,  375,  377,  379,  382,
-   385,  387,  389,  392,  395,  398,  401,  403,
-   404,  405,  407,  409,  411,  413,  414,  415,
-   416,  417,  418,  419,  420,  421,  423,  425,
-   427,  429,  431,  433,  434,  436,  438,  440,
-   442,  444,  446,  448,  450,  452,  456,  458,
-   459,  460,  461,  464,  465,  469,  471,  472,
-   473,  474,  476,  480,  481,  485,  486,  487,
-   489,  491,  492,  493,  494,  495,  496,  497,
-   498,  499,  500,  501,  505,  506,  509,  513,
-   514,  520,  524,  525,  531,  535,  536,  539,
-   543,  544,  550,  554,  555,  561,  562,  563,
-   564,  565,  566,  567,  568,  569,  570,  571,
-   572,  573,  574,  575,  576,  577,  578,  579,
-   580,  581,  582,  583,  584,  587,  590,  591,
-   592,  593,  594,  595,  596,  597,  598,  599,
-   600,  601,  602,  603,  604,  605,  606,  607,
-   608,  609,  610,  611,  612,  613,  614,  615,
-   616,  617,  618,  619,  620,  621,  622,  623,
-   624,  625,  626,  627,  628,  629,  630,  631,
-   632,  633,  634,  635,  636,  637,  638,  639,
-   640,  641,  642,  643,  644,  645,  646,  647,
-   648,  649,  650,  651,  652,  653,  654,  655,
-   656,  657,  658,  659,  660,  661,  662,  663,
-   664,  665,  666,  667,  668,  669,  670,  671,
-   672,  673,  674,  675,  676,  677,  678,  679,
-   680,  681,  682,  683,  684,  685,  687,  689,
-   690,  691,  692,  693,  694,  695,  696,  697,
-   698,  699,  701,  703,  705,  707,  709,  711,
-   713,  715,  717,  719,  721,  723,  725,  727,
-   729,  731,  733,  735,  737,  739,  741,  743,
-   745,  747,  749,  751,  753,  755,  757,  759,
-   760,  761,  762,  763,  764,  765,  766,  767,
-   768,  769,  770,  771,  774,  777,  780,  783,
-   786,  789,  790,  791,  792,  793,  794,  795,
-   801,  809,  812,  815,  818,  821,  824,  827,
-   830,  833,  836,  839,  842,  845,  848,  851,
-   854,  857,  860,  863,  866,  869,  872,  875,
-   878,  884,  890,  896,  902,  908,  914,  920,
-   926,  929,  932,  935,  938,  941,  944,  947,
-   950,  953,  956,  959,  962,  965,  968,  971,
-   973,  975,  977,  979,  981,  983,  985,  987,
-   989,  991,  993,  995,  997,  999, 1001, 1003,
-  1005, 1007, 1009, 1011, 1013, 1015, 1017, 1018,
-  1019, 1025, 1027, 1028, 1030, 1032, 1034, 1036,
-  1037, 1039, 1041, 1043, 1045, 1047, 1049, 1052,
-  1054, 1057, 1059, 1061, 1062, 1064, 1067, 1069,
-  1071, 1073, 1075, 1078, 1081, 1088, 1094, 1097,
-  1100, 1103, 1106, 1109, 1112, 1113, 1114, 1115,
-  1116, 1119, 1120, 1122, 1124, 1126, 1128, 1129,
-  1131, 1133, 1135, 1137, 1139, 1141, 1143, 1145,
-  1147, 1149, 1151, 1153, 1155, 1157, 1159, 1161,
-  1163, 1165, 1167, 1169, 1171, 1173, 1175, 1177,
-  1179, 1181, 1183, 1185, 1187, 1189, 1191, 1193,
-  1195, 1198, 1204, 1206, 1208, 1210, 1212, 1214,
-  1216, 1218, 1221, 1224, 1226, 1228, 1231, 1233,
-  1235, 1237, 1239, 1241, 1243, 1245, 1247, 1249,
-  1251, 1253, 1255, 1257, 1259, 1261, 1263, 1264,
-  1266, 1268, 1270, 1272, 1274, 1276, 1277, 1279,
-  1281, 1283, 1285, 1287, 1289, 1290, 1291, 1294,
-  1296, 1298, 1300, 1302, 1304, 1306, 1308, 1310,
-  1312, 1314, 1316, 1318, 1320, 1322, 1324, 1326,
-  1328, 1330, 1331, 1332, 1335, 1337, 1338, 1339,
-  1340, 1341, 1342, 1343, 1345, 1347, 1348, 1349,
-  1350, 1351, 1354, 1357, 1360, 1363, 1366, 1369,
-  1372, 1375, 1378, 1381, 1384, 1387, 1390, 1393,
-  1396, 1399, 1402, 1405, 1408, 1410, 1412, 1416,
-  1420, 1422, 1424, 1428, 1430, 1432, 1434, 1436,
-  1440, 1442, 1444, 1448, 1450, 1452, 1454, 1458,
-  1460, 1462, 1464, 1466, 1468, 1470, 1472, 1474,
-  1476, 1478, 1480, 1482, 1484, 1486, 1488, 1490,
-  1492, 1494, 1496, 1498, 1500, 1502, 1504, 1506,
-  1508, 1510, 1512, 1514, 1516, 1518, 1522, 1526,
-  1528, 1530, 1534, 1535, 1536, 1537, 1538, 1539,
-  1540, 1541, 1542, 1544, 1546, 1548, 1550, 1552,
-  1554, 1556, 1558, 1560, 1562, 1564, 1566, 1568,
-  1570, 1572, 1574, 1576, 1578, 1579, 1580, 1582,
-  1584, 1586, 1588, 1589, 1590, 1591, 1592, 1594,
-  1597, 1599, 1601, 1603, 1605, 1607, 1609, 1611,
-  1613, 1615, 1617, 1619, 1621, 1623, 1625, 1627,
-  1629, 1631, 1633, 1635, 1637, 1639, 1641, 1643,
-  1645, 1647, 1649, 1651, 1653, 1655, 1657, 1659,
-  1661, 1663, 1665, 1667, 1669, 1671, 1673, 1675,
-  1677, 1679, 1681, 1683, 1685, 1687, 1689, 1691,
-  1693, 1695, 1697, 1699, 1701, 1703, 1705, 1707,
-  1709, 1711, 1713, 1715, 1717, 1719, 1721, 1723,
-  1725, 1727, 1729, 1731, 1733, 1735, 1737, 1739,
-  1741, 1743, 1745, 1747, 1749, 1751, 1753, 1755,
-  1757, 1759, 1761, 1763, 1765, 1767, 1769, 1771,
-  1773, 1775, 1777, 1779, 1781, 1783, 1785, 1787,
-  1789, 1791, 1793, 1795, 1797, 1799, 1801, 1803,
-  1805, 1807, 1809, 1811, 1813, 1815, 1817, 1819,
-  1821, 1823, 1825, 1827, 1829, 1831, 1833, 1835,
-  1837, 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,
-  1984, 1986, 1991, 1993, 1995, 2000, 2002, 2004,
-  2006, 2011, 2013, 2015, 2017, 2021, 2027, 2029,
-  2034, 2036, 2038, 2040, 2042, 2044, 2046, 2048,
-  2050, 2052, 2053, 2054, 2056, 2058, 2059, 2060,
-  2061, 2062, 2064, 2066, 2067, 2068, 2069, 2071,
-  2073, 2075, 2077, 2079, 2081, 2083, 2085, 2087,
-  2089, 2091, 2093, 2095, 2099, 2100, 2101, 2103,
-  2107, 2111, 2113, 2117, 2121, 2122, 2123, 2125,
-  2127, 2129, 2131, 2136, 2140, 2144, 2146, 2148,
-  2150, 2152, 2153, 2155, 2157, 2159, 2161, 2163,
-  2165, 2167, 2169, 2171, 2173, 2175, 2177, 2179,
-  2181, 2183, 2185, 2187, 2189, 2191, 2193, 2195,
-  2197, 2198, 2199, 2201, 2203, 2204, 2205, 2208,
-  2211, 2214, 2217, 2219, 2221, 2223, 2225, 2227,
-  2229, 2230, 2231, 2232, 2234, 2238, 2240, 2242,
-  2248, 2252, 2253, 2254, 2255, 2256, 2257, 2258,
-  2259, 2263, 2265, 2267, 2271, 2273, 2275, 2277,
-  2279, 2281, 2283, 2285, 2287, 2289, 2291, 2293,
-  2295, 2297, 2299, 2300, 2303, 2306, 2311, 2316,
-  2319, 2322, 2325, 2328, 2333, 2338, 2341, 2344,
-  2346, 2348, 2350, 2352, 2354, 2356, 2358, 2359,
-  2361, 2363, 2365, 2367, 2369, 2370, 2371, 2372,
-  2376, 2380, 2382, 2386, 2390, 2394, 2398, 2402,
-  2404, 2408, 2410, 2412, 2414, 2416, 2418, 2420,
-  2422, 2424, 2425, 2427, 2429, 2431, 2433, 2435,
-  2437, 2439, 2441, 2442, 2443, 2444, 2446, 2448,
-  2450, 2452, 2453, 2454, 2456, 2458, 2460, 2462,
-  2464, 2466, 2467, 2469, 2471, 2473, 2475, 2476,
-  2477, 2479, 2481, 2483, 2485, 2487, 2489, 2491,
-  2493, 2494, 2495, 2497, 2498, 2501, 2504, 2506,
-  2509, 2510, 2511, 2513, 2514, 2516, 2518, 2520,
-  2522, 2524, 2525, 2526, 2527, 2528, 2529, 2532,
-  2537, 2542, 2547, 2552, 2555, 2560, 2565, 2567,
-  2569, 2571, 2573, 2574, 2575, 2577, 2579, 2581,
-  2583, 2585, 2587, 2589, 2590, 2591, 2592, 2593,
-  2594, 2595, 2600, 2605, 2606, 2607, 2608, 2609,
-  2610, 2611, 2612, 2613, 2614, 2615, 2616, 2617,
-  2618, 2619, 2620, 2621, 2622, 2623, 2624, 2625,
-  2626, 2627, 2628, 2629, 2630, 2631, 2632, 2633,
-  2634, 2635, 2636, 2637, 2638, 2639, 2640, 2641,
-  2642, 2643, 2644, 2645, 2646, 2647, 2648, 2649,
-  2650, 2651, 2652, 2653, 2654, 2655, 2656, 2657,
-  2658, 2659, 2660, 2661, 2662, 2663, 2664, 2665,
-  2666, 2667, 2668, 2669, 2670, 2671, 2672, 2673,
-  2674, 2675, 2676, 2677, 2678, 2679, 2680, 2681,
-  2682, 2683, 2684, 2685, 2686, 2687, 2688, 2689,
-  2690, 2691, 2692, 2693, 2694, 2695, 2696, 2697,
-  2698, 2699, 2700, 2701, 2702, 2703, 2704, 2705,
-  2706, 2707, 2708, 2709, 2710, 2711, 2712, 2713,
-  2714, 2715, 2716, 2717, 2718, 2719, 2720, 2721,
-  2722, 2723, 2724, 2725, 2726, 2727, 2728, 2729,
-  2730, 2731, 2732, 2733, 2734, 2735, 2736, 2737,
-  2738, 2739, 2740, 2741, 2742, 2743, 2744, 2745,
-  2746, 2747, 2748, 2749, 2750, 2751, 2752, 2753,
-  2754, 2755, 2756, 2757, 2758, 2759, 2760, 2761,
-  2762, 2763, 2764, 2765, 2766, 2767, 2768, 2769,
-  2770, 2771, 2772, 2773, 2774, 2775, 2776, 2777,
-  2778, 2779, 2780, 2781, 2782, 2783, 2784, 2785,
-  2786, 2787, 2788, 2789, 2790, 2791, 2792, 2793,
-  2794, 2795, 2796, 2797, 2798, 2799, 2800, 2801,
-  2802, 2803, 2804, 2805, 2806, 2808, 2810, 2811,
-  2812, 2813, 2814, 2815, 2816, 2817, 2818, 2819,
-  2820, 2821, 2822, 2823, 2824, 2825, 2826, 2827,
-  2828, 2829, 2830, 2831, 2832, 2833, 2834, 2835,
-  2836, 2837, 2838, 2840, 2842, 2844, 2846, 2847,
-  2848, 2849, 2850, 2851, 2852, 2853, 2854, 2855,
-  2856, 2857, 2858, 2859, 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, 2908, 2910, 2911, 2912, 2914, 2915,
-  2917, 2919, 2920, 2921, 2923, 2925, 2926, 2927,
-  2928, 2929, 2930, 2931, 2932, 2933, 2934, 2935,
-  2936, 2937, 2938, 2939, 2940, 2941, 2942, 2943,
-  2946, 2949, 2950, 2951, 2952, 2953, 2954, 2955,
-  2957, 2959, 2961, 2962, 2963, 2965, 2967, 2969,
-  2971, 2975, 2977, 2979, 2980, 2981, 2982, 2983,
-  2984, 2985, 2986, 2987, 2988, 2989, 2990, 2991,
-  2992, 2993, 2994, 2995, 2996, 2997, 3000, 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, 3060, 3062,
-  3065, 3068, 3070, 3073, 3076, 3079, 3082, 3083,
-  3086, 3087, 3088, 3089, 3090, 3091, 3095, 3097,
-  3100, 3101, 3102, 3103, 3104, 3105, 3106, 3107,
-  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, 3150, 3151, 3152, 3153, 3154, 3155,
-  3157, 3158, 3159, 3160, 3161, 3162, 3163, 3164,
-  3165, 3166, 3167, 3168, 3169, 3170, 3171, 3172,
-  3173, 3174, 3175, 3176, 3177, 3178, 3179, 3180,
-  3181, 3182, 3183, 3184, 3185, 3186, 3187, 3188,
-  3189, 3190, 3191, 3192, 3193, 3194, 3195, 3196,
-  3199, 3202, 3205, 3208, 3211, 3214, 3217, 3220,
-  3223, 3226, 3229, 3232, 3235, 3238, 3241, 3242,
-  3243, 3244, 3245, 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, 3295, 3296, 3297, 3298, 3299,
-  3300, 3301, 3302, 3303, 3304, 3305, 3306, 3307,
-  3308, 3311, 3314, 3315, 3316, 3317, 3318, 3319,
-  3320, 3321, 3322, 3323, 3324, 3325, 3326, 3327,
-  3328, 3329, 3330, 3331, 3332, 3333, 3334, 3335,
-  3336, 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, 3379, 3382, 3385, 3386, 3387, 3388, 3389,
-  3390, 3391, 3392, 3393, 3394, 3395, 3396, 3397,
-  3398, 3399, 3400, 3401, 3404, 3407, 3408, 3409,
-  3412, 3413, 3414, 3415, 3416, 3419, 3422, 3425,
-  3426, 3427, 3428, 3429, 3430, 3431, 3432, 3433,
-  3434, 3435, 3437, 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, 3464, 3466, 3468, 3469,
-  3470, 3471, 3472, 3473, 3474, 3475, 3476, 3477,
-  3478, 3479, 3480, 3481, 3482, 3483, 3484, 3485,
-  3486, 3487, 3488, 3489, 3490, 3491, 3492, 3493,
-  3495, 3497, 3499, 3501, 3502, 3503, 3504, 3505,
-  3506, 3507, 3508, 3509, 3510, 3511, 3512, 3513,
-  3514, 3515, 3516, 3518, 3519, 3521, 3524, 3526,
-  3527, 3528, 3530, 3532, 3533, 3534, 3535, 3536,
-  3537, 3538, 3540, 3542, 3544, 3546, 3547, 3548,
-  3549, 3550, 3551, 3552, 3553, 3554, 3555, 3557,
-  3559, 3560, 3562, 3564, 3565, 3570, 3572, 3574,
-  3575, 3576, 3577, 3578, 3579, 3580, 3581, 3583,
-  3585, 3586, 3587, 3588, 3590, 3593, 3596, 3599,
-  3601, 3602, 3603, 3604, 3605, 3606, 3607, 3608,
-  3609, 3610, 3611, 3612, 3613, 3614, 3615, 3616,
-  3617, 3618, 3619, 3620, 3621, 3623, 3625, 3627,
-  3629, 3631, 3633, 3635, 3637, 3639, 3641, 3642,
-  3643, 3644, 3645, 3646, 3647, 3648, 3649, 3650,
-  3651, 3652, 3653, 3654, 3655, 3656, 3657, 3658,
-  3659, 3660, 3661, 3662, 3663, 3664, 3665, 3666,
-  3667, 3668, 3669, 3670, 3671, 3672, 3673, 3674,
-  3675, 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, 3702, 3703, 3704, 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,
-  3731, 3732, 3733, 3734, 3735, 3736, 3737, 3738,
-  3739, 3740, 3741, 3742, 3743, 3744, 3745, 3746,
-  3747, 3748, 3749, 3750, 3751, 3752, 3753, 3756,
-  3757, 3758, 3761, 3762, 3763, 3765, 3766, 3767,
-  3768, 3770, 3771, 3772, 3773, 3775, 3776, 3777,
-  3778, 3781, 3782, 3783, 3784, 3785, 3788, 3791,
-  3794, 3797, 3800, 3801, 3802, 3803, 3804, 3806,
-  3808, 3809, 3810, 3811, 3814, 3817, 3820, 3823,
-  3826, 3827, 3828, 3829, 3831, 3832, 3833, 3834,
-  3836, 3837, 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,
-  3877, 3879, 3881, 3883, 3885, 3886, 3887, 3890,
-  3893, 3894, 3895, 3896, 3897
+    93,  101,  109,  117,  125,  133,  141,  142,
+   146,  149,  152,  155,  157,  159,  160,  161,
+   162,  163,  165,  167,  168,  169,  170,  171,
+   172,  173,  174,  175,  176,  177,  178,  179,
+   180,  187,  189,  191,  198,  205,  216,  227,
+   234,  241,  248,  255,  261,  267,  276,  279,
+   287,  290,  296,  298,  300,  302,  304,  305,
+   306,  307,  308,  309,  310,  311,  312,  313,
+   314,  315,  316,  317,  318,  319,  320,  321,
+   322,  323,  324,  325,  326,  327,  328,  329,
+   330,  331,  332,  333,  334,  335,  336,  337,
+   339,  341,  343,  345,  347,  348,  349,  350,
+   351,  352,  353,  354,  355,  356,  357,  358,
+   359,  360,  361,  362,  363,  364,  365,  366,
+   367,  368,  369,  370,  371,  372,  373,  374,
+   375,  376,  377,  379,  381,  383,  385,  388,
+   391,  393,  395,  398,  401,  404,  407,  409,
+   410,  411,  413,  415,  417,  419,  420,  421,
+   422,  423,  424,  425,  426,  427,  429,  431,
+   433,  435,  437,  439,  440,  442,  444,  446,
+   448,  450,  452,  454,  456,  458,  462,  464,
+   465,  466,  467,  470,  471,  475,  477,  478,
+   479,  480,  482,  486,  487,  491,  492,  493,
+   495,  497,  498,  499,  500,  501,  502,  503,
+   504,  505,  506,  507,  511,  512,  515,  519,
+   520,  526,  530,  531,  537,  541,  542,  545,
+   549,  550,  556,  560,  561,  567,  568,  569,
+   570,  571,  572,  573,  574,  575,  576,  577,
+   578,  579,  580,  581,  582,  583,  584,  585,
+   586,  587,  588,  589,  590,  593,  596,  597,
+   598,  599,  600,  601,  602,  603,  604,  605,
+   606,  607,  608,  609,  610,  611,  612,  613,
+   614,  615,  616,  617,  618,  619,  620,  621,
+   622,  623,  624,  625,  626,  627,  628,  629,
+   630,  631,  632,  633,  634,  635,  636,  637,
+   638,  639,  640,  641,  642,  643,  644,  645,
+   646,  647,  648,  649,  650,  651,  652,  653,
+   654,  655,  656,  657,  658,  659,  660,  661,
+   662,  663,  664,  665,  666,  667,  668,  669,
+   670,  671,  672,  673,  674,  675,  676,  677,
+   678,  679,  680,  681,  682,  683,  684,  685,
+   686,  687,  688,  689,  690,  691,  693,  695,
+   696,  697,  698,  699,  700,  701,  702,  703,
+   704,  705,  707,  709,  711,  713,  715,  717,
+   719,  721,  723,  725,  727,  729,  731,  733,
+   735,  737,  739,  741,  743,  745,  747,  749,
+   751,  753,  755,  757,  759,  761,  763,  765,
+   766,  767,  768,  769,  770,  771,  772,  773,
+   774,  775,  776,  777,  780,  783,  786,  789,
+   792,  795,  796,  797,  798,  799,  800,  801,
+   807,  815,  818,  821,  824,  827,  830,  833,
+   836,  839,  842,  845,  848,  851,  854,  857,
+   860,  863,  866,  869,  872,  875,  878,  881,
+   884,  890,  896,  902,  908,  914,  920,  926,
+   932,  935,  938,  941,  944,  947,  950,  953,
+   956,  959,  962,  965,  968,  971,  974,  977,
+   979,  981,  983,  985,  987,  989,  991,  993,
+   995,  997,  999, 1001, 1003, 1005, 1007, 1009,
+  1011, 1013, 1015, 1017, 1019, 1021, 1023, 1024,
+  1025, 1031, 1033, 1034, 1036, 1038, 1040, 1042,
+  1043, 1045, 1047, 1049, 1051, 1053, 1055, 1058,
+  1060, 1063, 1065, 1067, 1068, 1070, 1073, 1075,
+  1077, 1079, 1081, 1084, 1087, 1094, 1100, 1103,
+  1106, 1109, 1112, 1115, 1118, 1119, 1120, 1121,
+  1122, 1125, 1126, 1128, 1130, 1132, 1134, 1135,
+  1137, 1139, 1141, 1143, 1145, 1147, 1149, 1151,
+  1153, 1155, 1157, 1159, 1161, 1163, 1165, 1167,
+  1169, 1171, 1173, 1175, 1177, 1179, 1181, 1183,
+  1185, 1187, 1189, 1191, 1193, 1195, 1197, 1199,
+  1201, 1204, 1210, 1212, 1214, 1216, 1218, 1220,
+  1222, 1224, 1227, 1230, 1232, 1234, 1237, 1239,
+  1241, 1243, 1245, 1247, 1249, 1251, 1253, 1255,
+  1257, 1259, 1261, 1263, 1265, 1267, 1269, 1270,
+  1272, 1274, 1276, 1278, 1280, 1282, 1283, 1285,
+  1287, 1289, 1291, 1293, 1295, 1296, 1297, 1300,
+  1302, 1304, 1306, 1308, 1310, 1312, 1314, 1316,
+  1318, 1320, 1322, 1324, 1326, 1328, 1330, 1332,
+  1334, 1336, 1337, 1338, 1341, 1343, 1344, 1345,
+  1346, 1347, 1348, 1349, 1351, 1353, 1354, 1355,
+  1356, 1357, 1360, 1363, 1366, 1369, 1372, 1375,
+  1378, 1381, 1384, 1387, 1390, 1393, 1396, 1399,
+  1402, 1405, 1408, 1411, 1414, 1416, 1418, 1422,
+  1426, 1428, 1430, 1434, 1436, 1438, 1440, 1442,
+  1446, 1448, 1450, 1454, 1456, 1458, 1460, 1464,
+  1466, 1468, 1470, 1472, 1474, 1476, 1478, 1480,
+  1482, 1484, 1486, 1488, 1490, 1492, 1494, 1496,
+  1498, 1500, 1502, 1504, 1506, 1508, 1510, 1512,
+  1514, 1516, 1518, 1520, 1522, 1524, 1528, 1532,
+  1534, 1536, 1540, 1541, 1542, 1543, 1544, 1545,
+  1546, 1547, 1548, 1550, 1552, 1554, 1556, 1558,
+  1560, 1562, 1564, 1566, 1568, 1570, 1572, 1574,
+  1576, 1578, 1580, 1582, 1584, 1585, 1586, 1588,
+  1590, 1592, 1594, 1595, 1596, 1597, 1598, 1600,
+  1603, 1605, 1607, 1609, 1611, 1613, 1615, 1617,
+  1619, 1621, 1623, 1625, 1627, 1629, 1631, 1633,
+  1635, 1637, 1639, 1641, 1643, 1645, 1647, 1649,
+  1651, 1653, 1655, 1657, 1659, 1661, 1663, 1665,
+  1667, 1669, 1671, 1673, 1675, 1677, 1679, 1681,
+  1683, 1685, 1687, 1689, 1691, 1693, 1695, 1697,
+  1699, 1701, 1703, 1705, 1707, 1709, 1711, 1713,
+  1715, 1717, 1719, 1721, 1723, 1725, 1727, 1729,
+  1731, 1733, 1735, 1737, 1739, 1741, 1743, 1745,
+  1747, 1749, 1751, 1753, 1755, 1757, 1759, 1761,
+  1763, 1765, 1767, 1769, 1771, 1773, 1775, 1777,
+  1779, 1781, 1783, 1785, 1787, 1789, 1791, 1793,
+  1795, 1797, 1799, 1801, 1803, 1805, 1807, 1809,
+  1811, 1813, 1815, 1817, 1819, 1821, 1823, 1825,
+  1827, 1829, 1831, 1833, 1835, 1837, 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,
+  1990, 1992, 1997, 1999, 2001, 2006, 2008, 2010,
+  2012, 2017, 2019, 2021, 2023, 2027, 2033, 2035,
+  2040, 2042, 2044, 2046, 2048, 2050, 2052, 2054,
+  2056, 2058, 2059, 2060, 2062, 2064, 2065, 2066,
+  2067, 2068, 2070, 2072, 2073, 2074, 2075, 2077,
+  2079, 2081, 2083, 2085, 2087, 2089, 2091, 2093,
+  2095, 2097, 2099, 2101, 2105, 2106, 2107, 2109,
+  2113, 2117, 2119, 2123, 2127, 2128, 2129, 2131,
+  2133, 2135, 2137, 2142, 2146, 2150, 2152, 2154,
+  2156, 2158, 2159, 2161, 2163, 2165, 2167, 2169,
+  2171, 2173, 2175, 2177, 2179, 2181, 2183, 2185,
+  2187, 2189, 2191, 2193, 2195, 2197, 2199, 2201,
+  2203, 2204, 2205, 2207, 2209, 2210, 2211, 2214,
+  2217, 2220, 2223, 2225, 2227, 2229, 2231, 2233,
+  2235, 2236, 2237, 2238, 2240, 2244, 2246, 2248,
+  2254, 2258, 2259, 2260, 2261, 2262, 2263, 2264,
+  2265, 2269, 2271, 2273, 2277, 2279, 2281, 2283,
+  2285, 2287, 2289, 2291, 2293, 2295, 2297, 2299,
+  2301, 2303, 2305, 2306, 2309, 2312, 2317, 2322,
+  2325, 2328, 2331, 2334, 2339, 2344, 2347, 2350,
+  2352, 2354, 2356, 2358, 2360, 2362, 2364, 2365,
+  2367, 2369, 2371, 2373, 2375, 2376, 2377, 2378,
+  2382, 2386, 2388, 2392, 2396, 2400, 2404, 2408,
+  2410, 2414, 2416, 2418, 2420, 2422, 2424, 2426,
+  2428, 2430, 2431, 2433, 2435, 2437, 2439, 2441,
+  2443, 2445, 2447, 2448, 2449, 2450, 2452, 2454,
+  2456, 2458, 2459, 2460, 2462, 2464, 2466, 2468,
+  2470, 2472, 2473, 2475, 2477, 2479, 2481, 2482,
+  2483, 2485, 2487, 2489, 2491, 2493, 2495, 2497,
+  2499, 2500, 2501, 2503, 2504, 2507, 2510, 2512,
+  2515, 2516, 2517, 2519, 2520, 2522, 2524, 2526,
+  2528, 2530, 2531, 2532, 2533, 2534, 2535, 2538,
+  2543, 2548, 2553, 2558, 2561, 2566, 2571, 2573,
+  2575, 2577, 2579, 2580, 2581, 2583, 2585, 2587,
+  2589, 2591, 2593, 2595, 2596, 2597, 2598, 2599,
+  2600, 2601, 2606, 2611, 2612, 2613, 2614, 2615,
+  2616, 2617, 2618, 2619, 2620, 2621, 2622, 2623,
+  2624, 2625, 2626, 2627, 2628, 2629, 2630, 2631,
+  2632, 2633, 2634, 2635, 2636, 2637, 2638, 2639,
+  2640, 2641, 2642, 2643, 2644, 2645, 2646, 2647,
+  2648, 2649, 2650, 2651, 2652, 2653, 2654, 2655,
+  2656, 2657, 2658, 2659, 2660, 2661, 2662, 2663,
+  2664, 2665, 2666, 2667, 2668, 2669, 2670, 2671,
+  2672, 2673, 2674, 2675, 2676, 2677, 2678, 2679,
+  2680, 2681, 2682, 2683, 2684, 2685, 2686, 2687,
+  2688, 2689, 2690, 2691, 2692, 2693, 2694, 2695,
+  2696, 2697, 2698, 2699, 2700, 2701, 2702, 2703,
+  2704, 2705, 2706, 2707, 2708, 2709, 2710, 2711,
+  2712, 2713, 2714, 2715, 2716, 2717, 2718, 2719,
+  2720, 2721, 2722, 2723, 2724, 2725, 2726, 2727,
+  2728, 2729, 2730, 2731, 2732, 2733, 2734, 2735,
+  2736, 2737, 2738, 2739, 2740, 2741, 2742, 2743,
+  2744, 2745, 2746, 2747, 2748, 2749, 2750, 2751,
+  2752, 2753, 2754, 2755, 2756, 2757, 2758, 2759,
+  2760, 2761, 2762, 2763, 2764, 2765, 2766, 2767,
+  2768, 2769, 2770, 2771, 2772, 2773, 2774, 2775,
+  2776, 2777, 2778, 2779, 2780, 2781, 2782, 2783,
+  2784, 2785, 2786, 2787, 2788, 2789, 2790, 2791,
+  2792, 2793, 2794, 2795, 2796, 2797, 2798, 2799,
+  2800, 2801, 2802, 2803, 2804, 2805, 2806, 2807,
+  2808, 2809, 2810, 2811, 2812, 2814, 2816, 2817,
+  2818, 2819, 2820, 2821, 2822, 2823, 2824, 2825,
+  2826, 2827, 2828, 2829, 2830, 2831, 2832, 2833,
+  2834, 2835, 2836, 2837, 2838, 2839, 2840, 2841,
+  2842, 2843, 2844, 2846, 2848, 2850, 2852, 2853,
+  2854, 2855, 2856, 2857, 2858, 2859, 2860, 2861,
+  2862, 2863, 2864, 2865, 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, 2914, 2916, 2917, 2918, 2920, 2921,
+  2923, 2925, 2926, 2927, 2929, 2931, 2932, 2933,
+  2934, 2935, 2936, 2937, 2938, 2939, 2940, 2941,
+  2942, 2943, 2944, 2945, 2946, 2947, 2948, 2949,
+  2952, 2955, 2956, 2957, 2958, 2959, 2960, 2961,
+  2963, 2965, 2967, 2968, 2969, 2971, 2973, 2975,
+  2977, 2981, 2983, 2985, 2986, 2987, 2988, 2989,
+  2990, 2991, 2992, 2993, 2994, 2995, 2996, 2997,
+  2998, 2999, 3000, 3001, 3002, 3003, 3006, 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, 3066, 3068,
+  3071, 3074, 3076, 3079, 3082, 3085, 3088, 3089,
+  3092, 3093, 3094, 3095, 3096, 3097, 3101, 3103,
+  3106, 3107, 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, 3150, 3151, 3152, 3153,
+  3154, 3155, 3156, 3157, 3158, 3159, 3160, 3161,
+  3163, 3164, 3165, 3166, 3167, 3168, 3169, 3170,
+  3171, 3172, 3173, 3174, 3175, 3176, 3177, 3178,
+  3179, 3180, 3181, 3182, 3183, 3184, 3185, 3186,
+  3187, 3188, 3189, 3190, 3191, 3192, 3193, 3194,
+  3195, 3196, 3197, 3198, 3199, 3200, 3201, 3202,
+  3205, 3208, 3211, 3214, 3217, 3220, 3223, 3226,
+  3229, 3232, 3235, 3238, 3241, 3244, 3247, 3248,
+  3249, 3250, 3251, 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, 3295, 3296, 3297,
+  3298, 3299, 3300, 3301, 3302, 3303, 3304, 3305,
+  3306, 3307, 3308, 3309, 3310, 3311, 3312, 3313,
+  3314, 3317, 3320, 3321, 3322, 3323, 3324, 3325,
+  3326, 3327, 3328, 3329, 3330, 3331, 3332, 3333,
+  3334, 3335, 3336, 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, 3385, 3388, 3391, 3392, 3393, 3394, 3395,
+  3396, 3397, 3398, 3399, 3400, 3401, 3402, 3403,
+  3404, 3405, 3406, 3407, 3410, 3413, 3414, 3415,
+  3418, 3419, 3420, 3421, 3422, 3425, 3428, 3431,
+  3432, 3433, 3434, 3435, 3436, 3437, 3438, 3439,
+  3440, 3441, 3443, 3445, 3446, 3447, 3448, 3449,
+  3450, 3451, 3452, 3453, 3454, 3455, 3456, 3457,
+  3458, 3459, 3460, 3461, 3462, 3463, 3464, 3465,
+  3466, 3467, 3468, 3469, 3470, 3472, 3474, 3475,
+  3476, 3477, 3478, 3479, 3480, 3481, 3482, 3483,
+  3484, 3485, 3486, 3487, 3488, 3489, 3490, 3491,
+  3492, 3493, 3494, 3495, 3496, 3497, 3498, 3499,
+  3501, 3503, 3505, 3507, 3508, 3509, 3510, 3511,
+  3512, 3513, 3514, 3515, 3516, 3517, 3518, 3519,
+  3520, 3521, 3522, 3524, 3525, 3527, 3530, 3532,
+  3533, 3534, 3536, 3538, 3539, 3540, 3541, 3542,
+  3543, 3544, 3546, 3548, 3550, 3552, 3553, 3554,
+  3555, 3556, 3557, 3558, 3559, 3560, 3561, 3563,
+  3565, 3566, 3568, 3570, 3571, 3576, 3578, 3580,
+  3581, 3582, 3583, 3584, 3585, 3586, 3587, 3589,
+  3591, 3592, 3593, 3594, 3596, 3599, 3602, 3605,
+  3607, 3608, 3609, 3610, 3611, 3612, 3613, 3614,
+  3615, 3616, 3617, 3618, 3619, 3620, 3621, 3622,
+  3623, 3624, 3625, 3626, 3627, 3629, 3631, 3633,
+  3635, 3637, 3639, 3641, 3643, 3645, 3647, 3648,
+  3649, 3650, 3651, 3652, 3653, 3654, 3655, 3656,
+  3657, 3658, 3659, 3660, 3661, 3662, 3663, 3664,
+  3665, 3666, 3667, 3668, 3669, 3670, 3671, 3672,
+  3673, 3674, 3675, 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, 3702, 3703, 3704,
+  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, 3731, 3732, 3733, 3734, 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, 3762,
+  3763, 3764, 3767, 3768, 3769, 3771, 3772, 3773,
+  3774, 3776, 3777, 3778, 3779, 3781, 3782, 3783,
+  3784, 3787, 3788, 3789, 3790, 3791, 3794, 3797,
+  3800, 3803, 3806, 3807, 3808, 3809, 3810, 3812,
+  3814, 3815, 3816, 3817, 3820, 3823, 3826, 3829,
+  3832, 3833, 3834, 3835, 3837, 3838, 3839, 3840,
+  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,
+  3883, 3885, 3887, 3889, 3891, 3892, 3893, 3896,
+  3899, 3900, 3901, 3902, 3903
 };
 
 /* i386 mnemonics table.  */