From d77d08180d195a60193e9b35b6d08036caa55c70 Mon Sep 17 00:00:00 2001 From: "H.J. Lu" Date: Mon, 16 Sep 2024 07:11:39 +0800 Subject: [PATCH] x86/APX: Don't promote AVX/AVX2 instructions out of APX spec V{BROADCAST,EXTRACT,INSERT}{F,I}128 and VROUND{P,S}{S,D} aren't promoted to support EGPR in APX spec. Don't promote them out of APX spec. This commit effectively reverted: ec3babb8c10 x86/APX: V{BROADCAST,EXTRACT,INSERT}{F,I}128 can also be expressed 5a635f1f59a x86/APX: VROUND{P,S}{S,D} encodings require AVX512{F,VL} eea4357967b x86/APX: VROUND{P,S}{S,D} can generally be encoded gas/ PR gas/32171 * testsuite/gas/i386/x86-64-apx-egpr-promote-inval.s: Add V{BROADCAST,EXTRACT,INSERT}{F,I}128 tests with EGPR. * testsuite/gas/i386/x86-64-apx-evex-promoted.s: Remove V{BROADCAST,EXTRACT,INSERT}{F,I}128 and VROUND{P,S}{S,D} tests with EGPR. * testsuite/gas/i386/x86-64-apx-egpr-inval.l: Updated. * testsuite/gas/i386/x86-64-apx-egpr-promote-inval.l: Likewise. * testsuite/gas/i386/x86-64-apx-evex-promoted-intel.d: Likewise. * testsuite/gas/i386/x86-64-apx-evex-promoted-wig.d: Likewise. * testsuite/gas/i386/x86-64-apx-evex-promoted.d: Likewise. opcodes/ PR gas/32171 * i386-opc.tbl: Remove V{BROADCAST,EXTRACT,INSERT}{F,I}128 and VROUND{P,S}{S,D} entries with EGPR. * i386-tbl.h: Regenerated. Signed-off-by: H.J. Lu (cherry picked from commit 2963d7d80dffc9feb391ce7b5f3bc1c87e932b9d) --- .../gas/i386/x86-64-apx-egpr-inval.l | 8 +- .../gas/i386/x86-64-apx-egpr-promote-inval.l | 6 + .../gas/i386/x86-64-apx-egpr-promote-inval.s | 8 + .../gas/i386/x86-64-apx-evex-promoted-intel.d | 10 - .../gas/i386/x86-64-apx-evex-promoted-wig.d | 10 - .../gas/i386/x86-64-apx-evex-promoted.d | 10 - .../gas/i386/x86-64-apx-evex-promoted.s | 10 - opcodes/i386-opc.tbl | 16 - opcodes/i386-tbl.h | 518 +++++++----------- 9 files changed, 215 insertions(+), 381 deletions(-) diff --git a/gas/testsuite/gas/i386/x86-64-apx-egpr-inval.l b/gas/testsuite/gas/i386/x86-64-apx-egpr-inval.l index b018b3f7795..2525565284e 100644 --- a/gas/testsuite/gas/i386/x86-64-apx-egpr-inval.l +++ b/gas/testsuite/gas/i386/x86-64-apx-egpr-inval.l @@ -187,10 +187,10 @@ .*:195: Error: no EVEX encoding for `vrcpps' .*:196: Error: no EVEX encoding for `vrcpps' .*:197: Error: no EVEX encoding for `vrcpss' -.*:198: Error: .* 4 bits for `vroundpd' -.*:199: Error: .* 4 bits for `vroundps' -.*:200: Error: .* 4 bits for `vroundsd' -.*:201: Error: .* 4 bits for `vroundss' +.*:198: Error: no EVEX encoding for `vroundpd' +.*:199: Error: no EVEX encoding for `vroundps' +.*:200: Error: no EVEX encoding for `vroundsd' +.*:201: Error: no EVEX encoding for `vroundss' .*:202: Error: no EVEX encoding for `vrsqrtps' .*:203: Error: no EVEX encoding for `vrsqrtps' .*:204: Error: no EVEX encoding for `vrsqrtss' diff --git a/gas/testsuite/gas/i386/x86-64-apx-egpr-promote-inval.l b/gas/testsuite/gas/i386/x86-64-apx-egpr-promote-inval.l index 6f06df91905..9c0b81860e9 100644 --- a/gas/testsuite/gas/i386/x86-64-apx-egpr-promote-inval.l +++ b/gas/testsuite/gas/i386/x86-64-apx-egpr-promote-inval.l @@ -20,6 +20,12 @@ .*:37: Error: .*`kmovb'.* .*:38: Error: .*`ldtilecfg'.* .*:39: Error: .*`cmpexadd'.* +.*:42: Error: no EVEX encoding for `vbroadcastf128' +.*:43: Error: no EVEX encoding for `vbroadcasti128' +.*:44: Error: no EVEX encoding for `vextractf128' +.*:45: Error: no EVEX encoding for `vextracti128' +.*:46: Error: no EVEX encoding for `vinsertf128' +.*:47: Error: no EVEX encoding for `vinserti128' GAS LISTING .* #... [ ]*1[ ]+\# Check illegal 64bit APX EVEX promoted instructions diff --git a/gas/testsuite/gas/i386/x86-64-apx-egpr-promote-inval.s b/gas/testsuite/gas/i386/x86-64-apx-egpr-promote-inval.s index 5e4e08fa2fd..d23dbd3f2ca 100644 --- a/gas/testsuite/gas/i386/x86-64-apx-egpr-promote-inval.s +++ b/gas/testsuite/gas/i386/x86-64-apx-egpr-promote-inval.s @@ -37,3 +37,11 @@ {evex} kmovb %k1, %r8d {evex} ldtilecfg (%r8) {evex} cmpexadd %rax, %rcx, (%r8) + + .arch default + vbroadcastf128 (%r16),%ymm3 + vbroadcasti128 (%r16),%ymm3 + vextractf128 $1,%ymm3,(%r16) + vextracti128 $1,%ymm3,(%r16) + vinsertf128 $1,(%r16),%ymm3,%ymm8 + vinserti128 $1,(%r16),%ymm3,%ymm8 diff --git a/gas/testsuite/gas/i386/x86-64-apx-evex-promoted-intel.d b/gas/testsuite/gas/i386/x86-64-apx-evex-promoted-intel.d index 76664548d80..54195179172 100644 --- a/gas/testsuite/gas/i386/x86-64-apx-evex-promoted-intel.d +++ b/gas/testsuite/gas/i386/x86-64-apx-evex-promoted-intel.d @@ -138,16 +138,6 @@ Disassembly of section \.text: [ ]*[a-f0-9]+:[ ]*62 da 7f 08 4b b4 87 23 01 00 00[ ]+tileloadd tmm6,\[r31\+rax\*4\+0x123\] [ ]*[a-f0-9]+:[ ]*62 da 7d 08 4b b4 87 23 01 00 00[ ]+tileloaddt1 tmm6,\[r31\+rax\*4\+0x123\] [ ]*[a-f0-9]+:[ ]*62 da 7e 08 4b b4 87 23 01 00 00[ ]+tilestored[ ]+\[r31\+rax\*4\+0x123\],tmm6 -[ ]*[a-f0-9]+:[ ]*62 fa 7d 28 1a 18[ ]+vbroadcastf32x4 ymm3,XMMWORD PTR \[r16\] -[ ]*[a-f0-9]+:[ ]*62 fa 7d 28 5a 18[ ]+vbroadcasti32x4 ymm3,XMMWORD PTR \[r16\] -[ ]*[a-f0-9]+:[ ]*62 fb 7d 28 19 18 01[ ]+vextractf32x4 XMMWORD PTR \[r16\],ymm3,(0x)?1 -[ ]*[a-f0-9]+:[ ]*62 fb 7d 28 39 18 01[ ]+vextracti32x4 XMMWORD PTR \[r16\],ymm3,(0x)?1 -[ ]*[a-f0-9]+:[ ]*62 7b 65 28 18 00 01[ ]+vinsertf32x4 ymm8,ymm3,XMMWORD PTR \[r16\],(0x)?1 -[ ]*[a-f0-9]+:[ ]*62 7b 65 28 38 00 01[ ]+vinserti32x4 ymm8,ymm3,XMMWORD PTR \[r16\],(0x)?1 -[ ]*[a-f0-9]+:[ ]*62 db fd 08 09 30 01[ ]+vrndscalepd xmm6,XMMWORD PTR \[r24\],(0x)?1 -[ ]*[a-f0-9]+:[ ]*62 db 7d 08 08 30 02[ ]+vrndscaleps xmm6,XMMWORD PTR \[r24\],(0x)?2 -[ ]*[a-f0-9]+:[ ]*62 db cd 08 0b 18 03[ ]+vrndscalesd xmm3,xmm6,QWORD PTR \[r24\],(0x)?3 -[ ]*[a-f0-9]+:[ ]*62 db 4d 08 0a 18 04[ ]+vrndscaless xmm3,xmm6,DWORD PTR \[r24\],(0x)?4 [ ]*[a-f0-9]+:[ ]*62 4c 7c 08 66 8c 87 23 01 00 00[ ]+wrssd[ ]+\[r31\+rax\*4\+0x123\],r25d [ ]*[a-f0-9]+:[ ]*62 4c fc 08 66 bc 87 23 01 00 00[ ]+wrssq[ ]+\[r31\+rax\*4\+0x123\],r31 [ ]*[a-f0-9]+:[ ]*62 4c 7d 08 65 8c 87 23 01 00 00[ ]+wrussd[ ]+\[r31\+rax\*4\+0x123\],r25d diff --git a/gas/testsuite/gas/i386/x86-64-apx-evex-promoted-wig.d b/gas/testsuite/gas/i386/x86-64-apx-evex-promoted-wig.d index e800205c0e3..bcdc43ec2a8 100644 --- a/gas/testsuite/gas/i386/x86-64-apx-evex-promoted-wig.d +++ b/gas/testsuite/gas/i386/x86-64-apx-evex-promoted-wig.d @@ -138,16 +138,6 @@ Disassembly of section \.text: [ ]*[a-f0-9]+:[ ]*62 da 7f 08 4b b4 87 23 01 00 00[ ]+tileloadd[ ]+0x123\(%r31,%rax,4\),%tmm6 [ ]*[a-f0-9]+:[ ]*62 da 7d 08 4b b4 87 23 01 00 00[ ]+tileloaddt1[ ]+0x123\(%r31,%rax,4\),%tmm6 [ ]*[a-f0-9]+:[ ]*62 da 7e 08 4b b4 87 23 01 00 00[ ]+tilestored[ ]+%tmm6,0x123\(%r31,%rax,4\) -[ ]*[a-f0-9]+:[ ]*62 fa 7d 28 1a 18[ ]+vbroadcastf32x4 \(%r16\),%ymm3 -[ ]*[a-f0-9]+:[ ]*62 fa 7d 28 5a 18[ ]+vbroadcasti32x4 \(%r16\),%ymm3 -[ ]*[a-f0-9]+:[ ]*62 fb 7d 28 19 18 01[ ]+vextractf32x4 \$(0x)?1,%ymm3,\(%r16\) -[ ]*[a-f0-9]+:[ ]*62 fb 7d 28 39 18 01[ ]+vextracti32x4 \$(0x)?1,%ymm3,\(%r16\) -[ ]*[a-f0-9]+:[ ]*62 7b 65 28 18 00 01[ ]+vinsertf32x4 \$(0x)?1,\(%r16\),%ymm3,%ymm8 -[ ]*[a-f0-9]+:[ ]*62 7b 65 28 38 00 01[ ]+vinserti32x4 \$(0x)?1,\(%r16\),%ymm3,%ymm8 -[ ]*[a-f0-9]+:[ ]*62 db fd 08 09 30 01[ ]+vrndscalepd \$0x1,\(%r24\),%xmm6 -[ ]*[a-f0-9]+:[ ]*62 db 7d 08 08 30 02[ ]+vrndscaleps \$0x2,\(%r24\),%xmm6 -[ ]*[a-f0-9]+:[ ]*62 db cd 08 0b 18 03[ ]+vrndscalesd \$0x3,\(%r24\),%xmm6,%xmm3 -[ ]*[a-f0-9]+:[ ]*62 db 4d 08 0a 18 04[ ]+vrndscaless \$0x4,\(%r24\),%xmm6,%xmm3 [ ]*[a-f0-9]+:[ ]*62 4c 7c 08 66 8c 87 23 01 00 00[ ]+wrssd[ ]+%r25d,0x123\(%r31,%rax,4\) [ ]*[a-f0-9]+:[ ]*62 4c fc 08 66 bc 87 23 01 00 00[ ]+wrssq[ ]+%r31,0x123\(%r31,%rax,4\) [ ]*[a-f0-9]+:[ ]*62 4c 7d 08 65 8c 87 23 01 00 00[ ]+wrussd[ ]+%r25d,0x123\(%r31,%rax,4\) diff --git a/gas/testsuite/gas/i386/x86-64-apx-evex-promoted.d b/gas/testsuite/gas/i386/x86-64-apx-evex-promoted.d index a8f9231b5b0..c72f7012c0e 100644 --- a/gas/testsuite/gas/i386/x86-64-apx-evex-promoted.d +++ b/gas/testsuite/gas/i386/x86-64-apx-evex-promoted.d @@ -138,16 +138,6 @@ Disassembly of section \.text: [ ]*[a-f0-9]+:[ ]*62 da 7f 08 4b b4 87 23 01 00 00[ ]+tileloadd[ ]+0x123\(%r31,%rax,4\),%tmm6 [ ]*[a-f0-9]+:[ ]*62 da 7d 08 4b b4 87 23 01 00 00[ ]+tileloaddt1[ ]+0x123\(%r31,%rax,4\),%tmm6 [ ]*[a-f0-9]+:[ ]*62 da 7e 08 4b b4 87 23 01 00 00[ ]+tilestored[ ]+%tmm6,0x123\(%r31,%rax,4\) -[ ]*[a-f0-9]+:[ ]*62 fa 7d 28 1a 18[ ]+vbroadcastf32x4 \(%r16\),%ymm3 -[ ]*[a-f0-9]+:[ ]*62 fa 7d 28 5a 18[ ]+vbroadcasti32x4 \(%r16\),%ymm3 -[ ]*[a-f0-9]+:[ ]*62 fb 7d 28 19 18 01[ ]+vextractf32x4 \$(0x)?1,%ymm3,\(%r16\) -[ ]*[a-f0-9]+:[ ]*62 fb 7d 28 39 18 01[ ]+vextracti32x4 \$(0x)?1,%ymm3,\(%r16\) -[ ]*[a-f0-9]+:[ ]*62 7b 65 28 18 00 01[ ]+vinsertf32x4 \$(0x)?1,\(%r16\),%ymm3,%ymm8 -[ ]*[a-f0-9]+:[ ]*62 7b 65 28 38 00 01[ ]+vinserti32x4 \$(0x)?1,\(%r16\),%ymm3,%ymm8 -[ ]*[a-f0-9]+:[ ]*62 db fd 08 09 30 01[ ]+vrndscalepd \$0x1,\(%r24\),%xmm6 -[ ]*[a-f0-9]+:[ ]*62 db 7d 08 08 30 02[ ]+vrndscaleps \$0x2,\(%r24\),%xmm6 -[ ]*[a-f0-9]+:[ ]*62 db cd 08 0b 18 03[ ]+vrndscalesd \$0x3,\(%r24\),%xmm6,%xmm3 -[ ]*[a-f0-9]+:[ ]*62 db 4d 08 0a 18 04[ ]+vrndscaless \$0x4,\(%r24\),%xmm6,%xmm3 [ ]*[a-f0-9]+:[ ]*62 4c 7c 08 66 8c 87 23 01 00 00[ ]+wrssd[ ]+%r25d,0x123\(%r31,%rax,4\) [ ]*[a-f0-9]+:[ ]*62 4c fc 08 66 bc 87 23 01 00 00[ ]+wrssq[ ]+%r31,0x123\(%r31,%rax,4\) [ ]*[a-f0-9]+:[ ]*62 4c 7d 08 65 8c 87 23 01 00 00[ ]+wrussd[ ]+%r25d,0x123\(%r31,%rax,4\) diff --git a/gas/testsuite/gas/i386/x86-64-apx-evex-promoted.s b/gas/testsuite/gas/i386/x86-64-apx-evex-promoted.s index 1ba7d72cf9e..b66ee19df69 100644 --- a/gas/testsuite/gas/i386/x86-64-apx-evex-promoted.s +++ b/gas/testsuite/gas/i386/x86-64-apx-evex-promoted.s @@ -132,16 +132,6 @@ _start: tileloadd 0x123(%r31,%rax,4),%tmm6 tileloaddt1 0x123(%r31,%rax,4),%tmm6 tilestored %tmm6,0x123(%r31,%rax,4) - vbroadcastf128 (%r16),%ymm3 - vbroadcasti128 (%r16),%ymm3 - vextractf128 $1,%ymm3,(%r16) - vextracti128 $1,%ymm3,(%r16) - vinsertf128 $1,(%r16),%ymm3,%ymm8 - vinserti128 $1,(%r16),%ymm3,%ymm8 - vroundpd $1,(%r24),%xmm6 - vroundps $2,(%r24),%xmm6 - vroundsd $3,(%r24),%xmm6,%xmm3 - vroundss $4,(%r24),%xmm6,%xmm3 wrssd %r25d,0x123(%r31,%rax,4) wrssq %r31,0x123(%r31,%rax,4) wrussd %r25d,0x123(%r31,%rax,4) diff --git a/opcodes/i386-opc.tbl b/opcodes/i386-opc.tbl index 8c0d93402b5..fdb52ac2f51 100644 --- a/opcodes/i386-opc.tbl +++ b/opcodes/i386-opc.tbl @@ -1664,8 +1664,6 @@ vandp, 0x54, AVX, Modrm|C|Vex|Space0F|Src1VVVV|VexWIG|CheckOperandS vblendp, 0x660c | , AVX, Modrm|Vex|Space0F3A|Src1VVVV|VexWIG|CheckOperandSize|NoSuf, { Imm8|Imm8S, Unspecified|BaseIndex|RegXMM|RegYMM, RegXMM|RegYMM, RegXMM|RegYMM } vblendvp, 0x664a | , AVX, Modrm|Vex|Space0F3A|Src1VVVV|VexW0|CheckOperandSize|NoSuf, { RegXMM|RegYMM, Unspecified|BaseIndex|RegXMM|RegYMM, RegXMM|RegYMM, RegXMM|RegYMM } vbroadcastf128, 0x661a, AVX, Modrm|Vex256|Space0F38|VexW0|NoSuf, { Xmmword|Unspecified|BaseIndex, RegYMM } -// vbroadcastf32x4 in disguise (see vround{p,s}{s,d} comment) -vbroadcastf128, 0x661a, APX_F&AVX512VL, Modrm|EVex256|Space0F38|VexW0|Disp8MemShift=4|NoSuf, { Xmmword|Unspecified|BaseIndex, RegYMM } vbroadcastsd, 0x6619, AVX, Modrm|Vex256|Space0F38|VexW0|NoSuf, { Qword|Unspecified|BaseIndex, RegYMM } vbroadcastss, 0x6618, AVX, Modrm|Vex128|Space0F38|VexW0|NoSuf, { Dword|Unspecified|BaseIndex, RegXMM|RegYMM } vcmpp, 0xc2/0x, AVX, Modrm||Vex|Space0F|Src1VVVV|VexWIG|CheckOperandSize|NoSuf|ImmExt, { RegXMM|RegYMM|Unspecified|BaseIndex, RegXMM|RegYMM, RegXMM|RegYMM } @@ -1694,8 +1692,6 @@ vdivs, 0x5e, AVX, Modrm|VexLIG|Space0F|Src1VVVV|VexWIG|NoSuf, { , 0x6608 | , AVX, Modrm|Vex|Space0F3A|VexWIG|CheckOperandSize|NoSuf, { Imm8, Unspecified|BaseIndex|RegXMM|RegYMM, RegXMM|RegYMM } vrounds, 0x660a | , AVX, Modrm|VexLIG|Space0F3A|Src1VVVV|VexWIG|NoSuf, { Imm8, |Unspecified|BaseIndex|RegXMM, RegXMM, RegXMM } -// These are really clones of VRNDSCALE{P,S}{S,D}, with broadcast, masking, SAE, -// 512-bit operand size, and register sources dropped. -vroundp, 0x6608 | , APX_F&AVX512VL, Modrm|Space0F3A||Disp8ShiftVL|CheckOperandSize|NoSuf, { Imm8, Xmmword|Ymmword|Unspecified|BaseIndex, RegXMM|RegYMM } -vrounds, 0x660a | , APX_F&AVX512F, Modrm|EVexLIG|Space0F3A|Src1VVVV||Disp8MemShift|NoSuf, { Imm8, |Unspecified|BaseIndex, RegXMM, RegXMM } vrsqrtps, 0x52, AVX, Modrm|Vex|Space0F|VexWIG|CheckOperandSize|NoSuf, { Unspecified|BaseIndex|RegXMM|RegYMM, RegXMM|RegYMM } vrsqrtss, 0xf352, AVX, Modrm|Vex=3|Space0F|Src1VVVV|VexWIG|NoSuf, { Dword|Unspecified|BaseIndex|RegXMM, RegXMM, RegXMM } vshufp, 0xc6, AVX, Modrm|Vex|Space0F|Src1VVVV|VexWIG|CheckOperandSize|NoSuf, { Imm8|Imm8S, Unspecified|BaseIndex|RegXMM|RegYMM, RegXMM|RegYMM, RegXMM|RegYMM } @@ -1912,8 +1902,6 @@ vpmovzxwq, 0x6634, AVX2|AVX512VL, Modrm|Vex256|EVex256|Masking|Space0F38|VexWIG| // New AVX2 instructions. vbroadcasti128, 0x665A, AVX2, Modrm|Vex256|Space0F38|VexW0|NoSuf, { Xmmword|Unspecified|BaseIndex, RegYMM } -// vbroadcasti32x4 in disguise (see vround{p,s}{s,d} comment) -vbroadcasti128, 0x665a, APX_F&AVX512VL, Modrm|EVex256|Space0F38|VexW0|Disp8MemShift=4|NoSuf, { Xmmword|Unspecified|BaseIndex, RegYMM } vbroadcastsd, 0x6619, AVX2, Modrm|Vex=2|Space0F38|VexW=1|NoSuf, { RegXMM, RegYMM } vbroadcastss, 0x6618, AVX2|AVX512F, Modrm|Vex|EVexDYN|Masking|Space0F38|VexW0|Disp8MemShift=2|NoSuf, { RegXMM|Dword|Unspecified|BaseIndex, RegXMM|RegYMM|RegZMM } vpblendd, 0x6602, AVX2, Modrm|Vex|Space0F3A|Src1VVVV|VexW0|CheckOperandSize|NoSuf, { Imm8|Imm8S, Unspecified|BaseIndex|RegXMM|RegYMM, RegXMM|RegYMM, RegXMM|RegYMM } @@ -1926,11 +1914,7 @@ vpermpd, 0x6601, AVX2|AVX512F, Modrm|Vex256|EVexDYN|Masking|Space0F3A|VexW1|Broa vpermps, 0x6616, AVX2|AVX512F, Modrm|Vex256|EVexDYN|Masking|Space0F38|Src1VVVV|VexW0|Broadcast|Disp8ShiftVL|CheckOperandSize|NoSuf, { RegYMM|RegZMM|Dword|Unspecified|BaseIndex, RegYMM|RegZMM, RegYMM|RegZMM } vpermq, 0x6600, AVX2|AVX512F, Modrm|Vex256|EVexDYN|Masking|Space0F3A|VexW1|Broadcast|Disp8ShiftVL|CheckOperandSize|NoSuf, { Imm8|Imm8S, RegYMM|RegZMM|Qword|Unspecified|BaseIndex, RegYMM|RegZMM } vextracti128, 0x6639, AVX2, Modrm|Vex256|Space0F3A|VexW0|NoSuf, { Imm8, RegYMM, Unspecified|BaseIndex|RegXMM } -// vextracti32x4 in disguise (see vround{p,s}{s,d} comment) -vextracti128, 0x6639, APX_F&AVX512VL, Modrm|EVex256|Space0F3A|VexW0|Disp8MemShift=4|NoSuf, { Imm8, RegYMM, Xmmword|Unspecified|BaseIndex } vinserti128, 0x6638, AVX2, Modrm|Vex256|Space0F3A|Src1VVVV|VexW0|NoSuf, { Imm8, Unspecified|BaseIndex|RegXMM, RegYMM, RegYMM } -// vinserti32x4 in disguise (see vround{p,s}{s,d} comment) -vinserti128, 0x6638, APX_F&AVX512VL, Modrm|EVex256|Space0F3A|Src1VVVV|VexW0|Disp8MemShift=4|NoSuf, { Imm8, Xmmword|Unspecified|BaseIndex, RegYMM, RegYMM } vpmaskmov, 0x668e, AVX2, Modrm|Vex|Space0F38|Src1VVVV||CheckOperandSize|NoSuf, { RegXMM|RegYMM, RegXMM|RegYMM, Xmmword|Ymmword|Unspecified|BaseIndex } vpmaskmov, 0x668c, AVX2, Modrm|Vex|Space0F38|Src1VVVV||CheckOperandSize|NoSuf, { Xmmword|Ymmword|Unspecified|BaseIndex, RegXMM|RegYMM, RegXMM|RegYMM } vpsllv, 0x6647, AVX2|AVX512F, Modrm|Vex|EVexDYN|Masking|Space0F38|Src1VVVV||Broadcast|Disp8ShiftVL|CheckOperandSize|NoSuf, { RegXMM|RegYMM|RegZMM||Unspecified|BaseIndex, RegXMM|RegYMM|RegZMM, RegXMM|RegYMM|RegZMM } diff --git a/opcodes/i386-tbl.h b/opcodes/i386-tbl.h index 0e5e603a153..ba69e39f853 100644 --- a/opcodes/i386-tbl.h +++ b/opcodes/i386-tbl.h @@ -20350,16 +20350,6 @@ static const insn_template i386_optab[] = 1, 0, 0, 0, 1, 0 } }, { { 7, 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 } } } }, - { MN_vbroadcastf128, 0x1a, 2, SPACE_0F38, None, - { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1, 1, 0, 0, 3, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 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, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, - 1, 0, 0, 0, 1, 0 } }, - { { 7, 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 } } } }, { MN_vbroadcastsd, 0x19, 2, SPACE_0F38, None, { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2, 0, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, @@ -25792,18 +25782,6 @@ static const insn_template i386_optab[] = 0, 1, 0, 0, 0, 0 } }, { { 7, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0 } } } }, - { MN_vextractf128, 0x19, 3, SPACE_0F3A, None, - { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1, 1, 0, 0, 3, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 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, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0 } }, - { { 7, 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, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, - 1, 0, 0, 0, 1, 0 } } } }, { MN_vextractps, 0x17, 3, SPACE_0F3A, None, { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 1, 0, 0, 2, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, @@ -25890,20 +25868,6 @@ static const insn_template i386_optab[] = 0, 1, 0, 0, 0, 0 } }, { { 7, 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 } } } }, - { MN_vinsertf128, 0x18, 4, SPACE_0F3A, None, - { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1, 1, 1, 0, 0, 3, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 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, 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, 0, 1, 0, 0, 0, 0, 0, 0, - 1, 0, 0, 0, 1, 0 } }, - { { 7, 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 } }, - { { 7, 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 } } } }, { MN_vinsertps, 0x21, 4, SPACE_0F3A, None, { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, @@ -30306,18 +30270,6 @@ static const insn_template i386_optab[] = 1, 1, 0, 0, 1, 0 } }, { { 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0 } } } }, - { MN_vroundps, 0x08 | 0, 3, SPACE_0F3A, None, - { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1, 1, 0, 0, 5, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 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, 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, 0, 1, 0, 0, 0, 0, 0, 0, - 1, 1, 0, 0, 1, 0 } }, - { { 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1, 1, 0, 0, 0, 0 } } } }, { MN_vroundpd, 0x08 | 1, 3, SPACE_0F3A, None, { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, @@ -30330,18 +30282,6 @@ static const insn_template i386_optab[] = 1, 1, 0, 0, 1, 0 } }, { { 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 0, 0, 0, 0 } } } }, - { MN_vroundpd, 0x08 | 1, 3, SPACE_0F3A, None, - { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 2, 1, 0, 0, 5, 0, 0, 0, 0, 7, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 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, 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, 0, 1, 0, 0, 0, 0, 0, 0, - 1, 1, 0, 0, 1, 0 } }, - { { 7, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, - 1, 1, 0, 0, 0, 0 } } } }, { MN_vroundss, 0x0a | 0, 4, SPACE_0F3A, None, { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 3, 1, 3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, @@ -30356,20 +30296,6 @@ static const insn_template i386_optab[] = 1, 0, 0, 0, 0, 0 } }, { { 7, 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 } } } }, - { MN_vroundss, 0x0a | 0, 4, SPACE_0F3A, None, - { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1, 1, 1, 0, 0, 4, 0, 0, 0, 0, 2, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 1, 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, 1, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, - 0, 0, 0, 0, 1, 0 } }, - { { 7, 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 } }, - { { 7, 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 } } } }, { MN_vroundsd, 0x0a | 1, 4, SPACE_0F3A, None, { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 3, 1, 3, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, @@ -30384,20 +30310,6 @@ static const insn_template i386_optab[] = 1, 0, 0, 0, 0, 0 } }, { { 7, 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 } } } }, - { MN_vroundsd, 0x0a | 1, 4, SPACE_0F3A, None, - { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1, 2, 1, 0, 0, 4, 0, 0, 0, 0, 3, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 1, 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, 1, 0, 1, 0, 1, 0, 0, 0, 0, 1, 0, - 0, 0, 0, 0, 1, 0 } }, - { { 7, 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 } }, - { { 7, 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 } } } }, { MN_vrsqrtps, 0x52, 2, SPACE_0F, None, { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, @@ -30898,16 +30810,6 @@ static const insn_template i386_optab[] = 1, 0, 0, 0, 1, 0 } }, { { 7, 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 } } } }, - { MN_vbroadcasti128, 0x5a, 2, SPACE_0F38, None, - { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1, 1, 0, 0, 3, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 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, 1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, - 1, 0, 0, 0, 1, 0 } }, - { { 7, 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 } } } }, { MN_vpblendd, 0x02, 4, SPACE_0F3A, None, { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, @@ -31130,18 +31032,6 @@ static const insn_template i386_optab[] = 0, 1, 0, 0, 0, 0 } }, { { 7, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0 } } } }, - { MN_vextracti128, 0x39, 3, SPACE_0F3A, None, - { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 1, 1, 0, 0, 3, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 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, 0, 0, 0, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 0, 0 } }, - { { 7, 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, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, - 1, 0, 0, 0, 1, 0 } } } }, { MN_vinserti128, 0x38, 4, SPACE_0F3A, None, { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 2, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, @@ -31156,20 +31046,6 @@ static const insn_template i386_optab[] = 0, 1, 0, 0, 0, 0 } }, { { 7, 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 } } } }, - { MN_vinserti128, 0x38, 4, SPACE_0F3A, None, - { 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, - 0, 0, 0, 0, 1, 1, 1, 0, 0, 3, 0, 0, 0, 0, 4, 0, 0, 0, 0, 0, - 0, 0 }, - { { 0, 0, 0, 0, 0, 1, 0, 0, 0, 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, 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, 0, 1, 0, 0, 0, 0, 0, 0, - 1, 0, 0, 0, 1, 0 } }, - { { 7, 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 } }, - { { 7, 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 } } } }, { MN_vpmaskmovd, 0x8e, 3, SPACE_0F38, None, { 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, @@ -46317,203 +46193,203 @@ static const i386_op_off_t i386_op_sets[] = 2049, 2051, 2053, 2055, 2057, 2059, 2061, 2063, 2065, 2067, 2069, 2071, 2073, 2075, 2077, 2079, 2081, 2083, 2085, 2086, 2087, 2089, 2091, 2093, - 2095, 2096, 2097, 2098, 2099, 2101, 2104, 2106, - 2108, 2110, 2112, 2114, 2116, 2118, 2120, 2122, - 2124, 2126, 2128, 2130, 2132, 2134, 2136, 2138, - 2140, 2142, 2144, 2146, 2148, 2150, 2152, 2154, - 2156, 2158, 2160, 2162, 2164, 2166, 2168, 2170, - 2172, 2174, 2176, 2178, 2180, 2182, 2184, 2186, - 2188, 2190, 2192, 2194, 2196, 2198, 2200, 2202, - 2204, 2206, 2208, 2210, 2212, 2214, 2216, 2218, - 2220, 2222, 2224, 2226, 2228, 2230, 2232, 2234, - 2236, 2238, 2240, 2242, 2244, 2246, 2248, 2250, - 2252, 2254, 2256, 2258, 2260, 2262, 2264, 2266, - 2268, 2270, 2272, 2274, 2276, 2278, 2280, 2282, - 2284, 2286, 2288, 2290, 2292, 2294, 2296, 2298, - 2300, 2302, 2304, 2306, 2308, 2310, 2312, 2314, - 2316, 2318, 2320, 2322, 2324, 2326, 2328, 2330, - 2332, 2334, 2336, 2338, 2340, 2342, 2344, 2346, - 2348, 2350, 2352, 2354, 2356, 2358, 2360, 2362, - 2364, 2366, 2368, 2370, 2372, 2374, 2376, 2378, - 2380, 2382, 2384, 2386, 2388, 2390, 2392, 2394, - 2396, 2398, 2400, 2402, 2404, 2406, 2408, 2410, - 2412, 2414, 2416, 2418, 2420, 2422, 2424, 2426, - 2428, 2430, 2432, 2434, 2436, 2438, 2440, 2442, - 2444, 2446, 2448, 2450, 2452, 2454, 2456, 2458, - 2460, 2462, 2464, 2466, 2468, 2470, 2472, 2474, - 2476, 2478, 2480, 2482, 2484, 2486, 2491, 2493, - 2498, 2500, 2502, 2507, 2509, 2511, 2513, 2518, - 2520, 2522, 2524, 2528, 2534, 2536, 2541, 2543, - 2545, 2547, 2549, 2551, 2553, 2555, 2557, 2559, - 2560, 2561, 2563, 2565, 2566, 2567, 2568, 2569, - 2571, 2573, 2574, 2575, 2576, 2578, 2580, 2582, - 2584, 2586, 2588, 2590, 2592, 2594, 2596, 2598, - 2600, 2602, 2606, 2607, 2608, 2610, 2614, 2618, - 2620, 2624, 2628, 2629, 2630, 2632, 2634, 2636, - 2638, 2643, 2647, 2651, 2653, 2655, 2657, 2659, - 2660, 2662, 2664, 2666, 2668, 2670, 2672, 2674, - 2676, 2678, 2680, 2682, 2684, 2686, 2688, 2690, - 2692, 2694, 2696, 2698, 2700, 2702, 2704, 2705, - 2706, 2708, 2710, 2711, 2712, 2715, 2718, 2721, - 2724, 2726, 2728, 2730, 2732, 2734, 2736, 2737, - 2738, 2739, 2741, 2745, 2747, 2749, 2755, 2759, - 2760, 2761, 2762, 2763, 2764, 2765, 2766, 2770, - 2772, 2774, 2778, 2780, 2782, 2784, 2786, 2788, - 2790, 2792, 2794, 2796, 2798, 2800, 2802, 2804, - 2806, 2807, 2810, 2813, 2818, 2823, 2826, 2829, - 2832, 2835, 2840, 2845, 2848, 2851, 2853, 2855, - 2857, 2859, 2861, 2863, 2865, 2866, 2868, 2870, - 2872, 2874, 2876, 2877, 2878, 2879, 2883, 2887, - 2889, 2893, 2897, 2901, 2905, 2909, 2911, 2915, - 2917, 2919, 2921, 2923, 2925, 2927, 2929, 2931, - 2932, 2934, 2936, 2938, 2940, 2942, 2944, 2946, - 2948, 2949, 2950, 2951, 2953, 2955, 2957, 2959, - 2960, 2961, 2963, 2965, 2967, 2969, 2971, 2973, - 2974, 2976, 2978, 2980, 2982, 2983, 2984, 2986, - 2988, 2990, 2992, 2994, 2996, 2998, 3000, 3001, - 3002, 3004, 3005, 3008, 3011, 3013, 3016, 3017, - 3018, 3020, 3021, 3023, 3025, 3027, 3029, 3031, - 3032, 3033, 3034, 3035, 3036, 3039, 3044, 3049, - 3054, 3059, 3062, 3067, 3072, 3074, 3076, 3078, - 3080, 3081, 3082, 3084, 3086, 3088, 3090, 3092, - 3094, 3096, 3097, 3098, 3099, 3100, 3101, 3102, - 3107, 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, 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, 3197, 3198, - 3199, 3200, 3201, 3202, 3203, 3204, 3205, 3206, - 3207, 3208, 3209, 3210, 3211, 3212, 3213, 3214, - 3215, 3216, 3217, 3218, 3219, 3220, 3221, 3222, - 3223, 3224, 3225, 3226, 3227, 3228, 3229, 3230, - 3231, 3232, 3233, 3234, 3235, 3236, 3237, 3238, - 3239, 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, - 3295, 3296, 3297, 3298, 3299, 3300, 3301, 3302, - 3303, 3304, 3305, 3306, 3307, 3308, 3309, 3310, - 3311, 3312, 3313, 3315, 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, 3347, 3349, 3351, 3353, 3354, 3355, 3356, - 3357, 3358, 3359, 3360, 3361, 3362, 3363, 3364, - 3365, 3366, 3368, 3369, 3370, 3371, 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, - 3416, 3418, 3419, 3420, 3422, 3423, 3425, 3427, - 3428, 3429, 3431, 3433, 3435, 3437, 3438, 3439, - 3440, 3441, 3442, 3443, 3444, 3445, 3446, 3447, - 3448, 3449, 3450, 3451, 3452, 3453, 3456, 3459, - 3460, 3461, 3462, 3463, 3464, 3465, 3467, 3469, - 3471, 3472, 3473, 3474, 3475, 3476, 3477, 3479, - 3480, 3481, 3482, 3483, 3484, 3485, 3486, 3487, - 3488, 3489, 3490, 3491, 3492, 3493, 3494, 3495, - 3496, 3497, 3498, 3499, 3502, 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, 3546, 3547, - 3548, 3549, 3550, 3551, 3552, 3553, 3554, 3555, - 3556, 3557, 3558, 3559, 3562, 3564, 3567, 3570, - 3572, 3575, 3578, 3581, 3584, 3585, 3588, 3589, - 3590, 3591, 3592, 3593, 3597, 3599, 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, 3639, 3640, 3641, 3642, 3643, - 3644, 3645, 3646, 3647, 3648, 3649, 3650, 3651, - 3652, 3653, 3654, 3655, 3656, 3657, 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, 3701, 3704, - 3707, 3710, 3713, 3716, 3719, 3722, 3725, 3728, - 3731, 3734, 3737, 3740, 3743, 3744, 3745, 3746, - 3747, 3749, 3750, 3751, 3752, 3753, 3754, 3755, - 3756, 3757, 3758, 3759, 3760, 3761, 3762, 3763, - 3764, 3765, 3766, 3767, 3768, 3769, 3770, 3771, - 3772, 3773, 3774, 3775, 3776, 3777, 3778, 3779, - 3780, 3781, 3782, 3783, 3784, 3785, 3786, 3787, - 3788, 3789, 3790, 3791, 3792, 3793, 3794, 3795, - 3796, 3797, 3798, 3799, 3800, 3801, 3802, 3803, - 3804, 3805, 3806, 3807, 3808, 3809, 3810, 3813, - 3816, 3817, 3818, 3819, 3820, 3821, 3822, 3823, - 3824, 3825, 3826, 3827, 3828, 3829, 3830, 3831, - 3832, 3833, 3834, 3835, 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, 3876, 3877, 3878, 3881, - 3884, 3887, 3888, 3889, 3890, 3891, 3892, 3893, - 3894, 3895, 3896, 3897, 3898, 3899, 3900, 3901, - 3902, 3903, 3906, 3909, 3910, 3911, 3914, 3915, - 3916, 3917, 3918, 3921, 3924, 3927, 3928, 3929, - 3930, 3931, 3932, 3933, 3934, 3935, 3936, 3937, - 3939, 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, 3968, 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, 3997, 3999, - 4001, 4003, 4004, 4005, 4006, 4007, 4008, 4009, - 4010, 4011, 4012, 4013, 4014, 4015, 4016, 4017, - 4018, 4020, 4021, 4023, 4026, 4028, 4029, 4030, - 4032, 4034, 4035, 4036, 4037, 4038, 4039, 4040, - 4042, 4044, 4046, 4048, 4049, 4050, 4051, 4052, - 4053, 4054, 4055, 4056, 4057, 4059, 4061, 4062, - 4064, 4066, 4067, 4072, 4074, 4076, 4077, 4078, - 4079, 4080, 4081, 4082, 4083, 4085, 4087, 4088, - 4089, 4090, 4092, 4095, 4098, 4101, 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, 4133, 4134, 4135, 4136, - 4137, 4138, 4139, 4140, 4141, 4142, 4143, 4144, - 4145, 4146, 4147, 4148, 4149, 4150, 4151, 4152, - 4153, 4154, 4155, 4156, 4157, 4158, 4159, 4160, - 4161, 4162, 4163, 4164, 4165, 4166, 4167, 4168, - 4169, 4170, 4171, 4172, 4173, 4174, 4175, 4176, - 4177, 4178, 4179, 4180, 4181, 4182, 4183, 4184, - 4185, 4186, 4187, 4188, 4189, 4190, 4191, 4192, - 4193, 4194, 4195, 4196, 4197, 4198, 4199, 4200, - 4201, 4202, 4203, 4204, 4205, 4206, 4207, 4208, - 4209, 4210, 4211, 4212, 4213, 4214, 4215, 4216, - 4217, 4218, 4219, 4220, 4221, 4222, 4223, 4224, - 4225, 4226, 4227, 4228, 4229, 4230, 4231, 4232, - 4233, 4234, 4235, 4236, 4237, 4238, 4239, 4240, - 4241, 4242, 4243, 4244, 4245, 4248, 4249, 4250, - 4253, 4254, 4255, 4257, 4258, 4259, 4260, 4262, - 4263, 4264, 4265, 4267, 4268, 4269, 4270, 4273, - 4274, 4275, 4276, 4277, 4280, 4283, 4286, 4289, - 4292, 4293, 4294, 4295, 4296, 4298, 4300, 4301, - 4302, 4303, 4306, 4309, 4312, 4315, 4318, 4319, - 4320, 4321, 4323, 4324, 4325, 4326, 4328, 4329, - 4330, 4331, 4332, 4333, 4334, 4335, 4336, 4337, - 4338, 4339, 4340, 4341, 4342, 4343, 4344, 4345, - 4346, 4347, 4348, 4349, 4350, 4351, 4352, 4353, - 4354, 4355, 4356, 4357, 4358, 4359, 4360, 4361, - 4362, 4363, 4364, 4365, 4366, 4367, 4369, 4371, - 4373, 4375, 4377, 4378, 4379, 4382, 4385, 4386, - 4387, 4388, 4389 + 2095, 2096, 2097, 2098, 2099, 2100, 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, 2253, 2255, 2257, 2259, 2261, 2263, 2265, + 2267, 2269, 2271, 2273, 2275, 2277, 2279, 2281, + 2283, 2285, 2287, 2289, 2291, 2293, 2295, 2297, + 2299, 2301, 2303, 2305, 2307, 2309, 2311, 2313, + 2315, 2317, 2319, 2321, 2323, 2325, 2327, 2329, + 2331, 2333, 2335, 2337, 2339, 2341, 2343, 2345, + 2347, 2349, 2351, 2353, 2355, 2357, 2359, 2361, + 2363, 2365, 2367, 2369, 2371, 2373, 2375, 2377, + 2379, 2381, 2383, 2385, 2387, 2389, 2391, 2393, + 2395, 2397, 2399, 2401, 2403, 2405, 2407, 2409, + 2411, 2413, 2415, 2417, 2419, 2421, 2423, 2425, + 2427, 2429, 2431, 2433, 2435, 2437, 2439, 2441, + 2443, 2445, 2447, 2449, 2451, 2453, 2455, 2457, + 2459, 2461, 2463, 2465, 2467, 2469, 2471, 2473, + 2475, 2477, 2479, 2481, 2483, 2485, 2490, 2492, + 2497, 2499, 2501, 2506, 2508, 2510, 2512, 2517, + 2519, 2521, 2523, 2527, 2533, 2535, 2540, 2542, + 2544, 2546, 2548, 2550, 2552, 2554, 2556, 2558, + 2559, 2560, 2561, 2563, 2564, 2565, 2566, 2567, + 2568, 2570, 2571, 2572, 2573, 2575, 2577, 2579, + 2581, 2583, 2585, 2587, 2589, 2591, 2593, 2595, + 2597, 2599, 2603, 2604, 2605, 2607, 2611, 2615, + 2617, 2621, 2625, 2626, 2627, 2629, 2631, 2633, + 2635, 2640, 2644, 2648, 2650, 2652, 2654, 2656, + 2657, 2659, 2661, 2663, 2665, 2667, 2669, 2671, + 2673, 2675, 2677, 2679, 2681, 2683, 2685, 2687, + 2689, 2691, 2693, 2695, 2697, 2699, 2701, 2702, + 2703, 2705, 2707, 2708, 2709, 2712, 2715, 2718, + 2721, 2723, 2725, 2727, 2729, 2731, 2733, 2734, + 2735, 2736, 2738, 2742, 2744, 2746, 2752, 2756, + 2757, 2758, 2759, 2760, 2761, 2762, 2763, 2767, + 2769, 2771, 2775, 2777, 2779, 2781, 2783, 2785, + 2787, 2789, 2791, 2793, 2795, 2797, 2799, 2801, + 2803, 2804, 2807, 2810, 2815, 2820, 2823, 2826, + 2829, 2832, 2837, 2842, 2845, 2848, 2850, 2852, + 2854, 2856, 2858, 2860, 2862, 2863, 2865, 2867, + 2869, 2871, 2873, 2874, 2875, 2876, 2880, 2884, + 2886, 2890, 2894, 2898, 2902, 2906, 2908, 2912, + 2914, 2916, 2918, 2920, 2922, 2924, 2926, 2928, + 2929, 2931, 2933, 2935, 2937, 2939, 2941, 2943, + 2945, 2946, 2947, 2948, 2949, 2950, 2951, 2952, + 2953, 2954, 2956, 2958, 2960, 2962, 2964, 2966, + 2967, 2969, 2971, 2973, 2975, 2976, 2977, 2979, + 2981, 2983, 2985, 2987, 2989, 2991, 2993, 2994, + 2995, 2996, 2997, 3000, 3003, 3005, 3008, 3009, + 3010, 3012, 3013, 3015, 3016, 3017, 3019, 3021, + 3022, 3023, 3024, 3025, 3026, 3029, 3034, 3039, + 3044, 3049, 3052, 3057, 3062, 3064, 3066, 3068, + 3070, 3071, 3072, 3074, 3076, 3078, 3080, 3082, + 3084, 3086, 3087, 3088, 3089, 3090, 3091, 3092, + 3097, 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, 3156, + 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, + 3197, 3198, 3199, 3200, 3201, 3202, 3203, 3204, + 3205, 3206, 3207, 3208, 3209, 3210, 3211, 3212, + 3213, 3214, 3215, 3216, 3217, 3218, 3219, 3220, + 3221, 3222, 3223, 3224, 3225, 3226, 3227, 3228, + 3229, 3230, 3231, 3232, 3233, 3234, 3235, 3236, + 3237, 3238, 3239, 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, 3295, 3296, 3297, 3298, 3299, 3300, + 3301, 3302, 3303, 3305, 3307, 3308, 3309, 3310, + 3311, 3312, 3313, 3314, 3315, 3316, 3317, 3318, + 3319, 3320, 3321, 3322, 3323, 3324, 3325, 3326, + 3327, 3328, 3329, 3330, 3331, 3332, 3333, 3334, + 3335, 3337, 3339, 3341, 3343, 3344, 3345, 3346, + 3347, 3348, 3349, 3350, 3351, 3352, 3353, 3354, + 3355, 3356, 3358, 3359, 3360, 3361, 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, 3393, 3394, 3395, 3396, + 3397, 3398, 3399, 3400, 3401, 3402, 3403, 3404, + 3406, 3408, 3409, 3410, 3412, 3413, 3415, 3417, + 3418, 3419, 3421, 3423, 3425, 3427, 3428, 3429, + 3430, 3431, 3432, 3433, 3434, 3435, 3436, 3437, + 3438, 3439, 3440, 3441, 3442, 3443, 3446, 3449, + 3450, 3451, 3452, 3453, 3454, 3455, 3457, 3459, + 3461, 3462, 3463, 3464, 3465, 3466, 3467, 3469, + 3470, 3471, 3472, 3473, 3474, 3475, 3476, 3477, + 3478, 3479, 3480, 3481, 3482, 3483, 3484, 3485, + 3486, 3487, 3488, 3489, 3492, 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, + 3546, 3547, 3548, 3549, 3552, 3554, 3557, 3560, + 3562, 3565, 3568, 3571, 3574, 3575, 3578, 3579, + 3580, 3581, 3582, 3583, 3587, 3589, 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, 3639, 3640, 3641, + 3642, 3643, 3644, 3645, 3646, 3647, 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, 3691, 3694, + 3697, 3700, 3703, 3706, 3709, 3712, 3715, 3718, + 3721, 3724, 3727, 3730, 3733, 3734, 3735, 3736, + 3737, 3739, 3740, 3741, 3742, 3743, 3744, 3745, + 3746, 3747, 3748, 3749, 3750, 3751, 3752, 3753, + 3754, 3755, 3756, 3757, 3758, 3759, 3760, 3761, + 3762, 3763, 3764, 3765, 3766, 3767, 3768, 3769, + 3770, 3771, 3772, 3773, 3774, 3775, 3776, 3777, + 3778, 3779, 3780, 3781, 3782, 3783, 3784, 3785, + 3786, 3787, 3788, 3789, 3790, 3791, 3792, 3793, + 3794, 3795, 3796, 3797, 3798, 3799, 3800, 3803, + 3806, 3807, 3808, 3809, 3810, 3811, 3812, 3813, + 3814, 3815, 3816, 3817, 3818, 3819, 3820, 3821, + 3822, 3823, 3824, 3825, 3826, 3827, 3828, 3829, + 3830, 3831, 3832, 3833, 3834, 3835, 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, 3871, + 3874, 3877, 3878, 3879, 3880, 3881, 3882, 3883, + 3884, 3885, 3886, 3887, 3888, 3889, 3890, 3891, + 3892, 3893, 3896, 3899, 3900, 3901, 3904, 3905, + 3906, 3907, 3908, 3911, 3914, 3917, 3918, 3919, + 3920, 3921, 3922, 3923, 3924, 3925, 3926, 3927, + 3929, 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, 3958, 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, 3987, 3989, + 3991, 3993, 3994, 3995, 3996, 3997, 3998, 3999, + 4000, 4001, 4002, 4003, 4004, 4005, 4006, 4007, + 4008, 4010, 4011, 4013, 4016, 4018, 4019, 4020, + 4022, 4024, 4025, 4026, 4027, 4028, 4029, 4030, + 4032, 4034, 4036, 4038, 4039, 4040, 4041, 4042, + 4043, 4044, 4045, 4046, 4047, 4049, 4051, 4052, + 4054, 4056, 4057, 4062, 4064, 4066, 4067, 4068, + 4069, 4070, 4071, 4072, 4073, 4075, 4077, 4078, + 4079, 4080, 4082, 4085, 4088, 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, 4133, 4134, + 4135, 4136, 4137, 4138, 4139, 4140, 4141, 4142, + 4143, 4144, 4145, 4146, 4147, 4148, 4149, 4150, + 4151, 4152, 4153, 4154, 4155, 4156, 4157, 4158, + 4159, 4160, 4161, 4162, 4163, 4164, 4165, 4166, + 4167, 4168, 4169, 4170, 4171, 4172, 4173, 4174, + 4175, 4176, 4177, 4178, 4179, 4180, 4181, 4182, + 4183, 4184, 4185, 4186, 4187, 4188, 4189, 4190, + 4191, 4192, 4193, 4194, 4195, 4196, 4197, 4198, + 4199, 4200, 4201, 4202, 4203, 4204, 4205, 4206, + 4207, 4208, 4209, 4210, 4211, 4212, 4213, 4214, + 4215, 4216, 4217, 4218, 4219, 4220, 4221, 4222, + 4223, 4224, 4225, 4226, 4227, 4228, 4229, 4230, + 4231, 4232, 4233, 4234, 4235, 4238, 4239, 4240, + 4243, 4244, 4245, 4247, 4248, 4249, 4250, 4252, + 4253, 4254, 4255, 4257, 4258, 4259, 4260, 4263, + 4264, 4265, 4266, 4267, 4270, 4273, 4276, 4279, + 4282, 4283, 4284, 4285, 4286, 4288, 4290, 4291, + 4292, 4293, 4296, 4299, 4302, 4305, 4308, 4309, + 4310, 4311, 4313, 4314, 4315, 4316, 4318, 4319, + 4320, 4321, 4322, 4323, 4324, 4325, 4326, 4327, + 4328, 4329, 4330, 4331, 4332, 4333, 4334, 4335, + 4336, 4337, 4338, 4339, 4340, 4341, 4342, 4343, + 4344, 4345, 4346, 4347, 4348, 4349, 4350, 4351, + 4352, 4353, 4354, 4355, 4356, 4357, 4359, 4361, + 4363, 4365, 4367, 4368, 4369, 4372, 4375, 4376, + 4377, 4378, 4379 }; /* i386 mnemonics table. */