public inbox for binutils-cvs@sourceware.org
 help / color / mirror / Atom feed
* [binutils-gdb] x86: Restore APX shift-double instructions with omitted shift count
@ 2024-04-04 20:26 H.J. Lu
  0 siblings, 0 replies; only message in thread
From: H.J. Lu @ 2024-04-04 20:26 UTC (permalink / raw)
  To: binutils-cvs

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

commit c2d698fe03a6092d58a07de96068b87836daced0
Author: H.J. Lu <hjl.tools@gmail.com>
Date:   Thu Apr 4 13:12:12 2024 -0700

    x86: Restore APX shift-double instructions with omitted shift count
    
    Restore APX shift-double instructions with omitted shift count since
    they are generated by GCC as shown in:
    
    https://gcc.gnu.org/bugzilla/show_bug.cgi?id=114590
    
    gas/
    
            PR gas/31606
            * testsuite/gas/i386/x86-64-apx-ndd-wig.d: Updated.
            * testsuite/gas/i386/x86-64-apx-ndd.d: Likewise.
            * testsuite/gas/i386/x86-64-apx-ndd.s: Add tests for APX
            shift-double instructions with omitted shift count.
    
    opcodes/
    
            PR gas/31606
            * i386-opc.tbl: Restore APX shift-double instructions with
            omitted shift count.
            * i386-tbl.h: Regenerated.

Diff:
---
 gas/testsuite/gas/i386/x86-64-apx-ndd-wig.d |   6 +
 gas/testsuite/gas/i386/x86-64-apx-ndd.d     |   6 +
 gas/testsuite/gas/i386/x86-64-apx-ndd.s     |   6 +
 opcodes/i386-opc.tbl                        |   1 +
 opcodes/i386-tbl.h                          | 592 +++++++++++++++-------------
 5 files changed, 327 insertions(+), 284 deletions(-)

diff --git a/gas/testsuite/gas/i386/x86-64-apx-ndd-wig.d b/gas/testsuite/gas/i386/x86-64-apx-ndd-wig.d
index 3fbb809bda5..0a80f9e4930 100644
--- a/gas/testsuite/gas/i386/x86-64-apx-ndd-wig.d
+++ b/gas/testsuite/gas/i386/x86-64-apx-ndd-wig.d
@@ -126,8 +126,11 @@ Disassembly of section .text:
 [ 	]*[a-f0-9]+:[ 	]*62 74 04 10 24 38 02 	shld   \$0x2,%r15d,\(%rax\),%r31d
 [ 	]*[a-f0-9]+:[ 	]*62 54 05 10 24 c4 02 	shld   \$0x2,%r8w,%r12w,%r31w
 [ 	]*[a-f0-9]+:[ 	]*62 7c bc 18 a5 e0    	shld   %cl,%r12,%r16,%r8
+[ 	]*[a-f0-9]+:[ 	]*62 7c bc 18 a5 e0    	shld   %cl,%r12,%r16,%r8
+[ 	]*[a-f0-9]+:[ 	]*62 7c 05 10 a5 2c 83 	shld   %cl,%r13w,\(%r19,%rax,4\),%r31w
 [ 	]*[a-f0-9]+:[ 	]*62 7c 05 10 a5 2c 83 	shld   %cl,%r13w,\(%r19,%rax,4\),%r31w
 [ 	]*[a-f0-9]+:[ 	]*62 74 05 10 a5 08    	shld   %cl,%r9w,\(%rax\),%r31w
+[ 	]*[a-f0-9]+:[ 	]*62 74 05 10 a5 08    	shld   %cl,%r9w,\(%rax\),%r31w
 [ 	]*[a-f0-9]+:[ 	]*62 f4 04 10 c1 20 02 	shl    \$0x2,\(%rax\),%r31d
 [ 	]*[a-f0-9]+:[ 	]*62 f4 04 10 c1 20 02 	shl    \$0x2,\(%rax\),%r31d
 [ 	]*[a-f0-9]+:[ 	]*62 f4 05 10 d1 20    	shl    \$1,\(%rax\),%r31w
@@ -141,8 +144,11 @@ Disassembly of section .text:
 [ 	]*[a-f0-9]+:[ 	]*62 74 04 10 2c 38 02 	shrd   \$0x2,%r15d,\(%rax\),%r31d
 [ 	]*[a-f0-9]+:[ 	]*62 54 05 10 2c c4 02 	shrd   \$0x2,%r8w,%r12w,%r31w
 [ 	]*[a-f0-9]+:[ 	]*62 7c bc 18 ad e0    	shrd   %cl,%r12,%r16,%r8
+[ 	]*[a-f0-9]+:[ 	]*62 7c bc 18 ad e0    	shrd   %cl,%r12,%r16,%r8
+[ 	]*[a-f0-9]+:[ 	]*62 7c 05 10 ad 2c 83 	shrd   %cl,%r13w,\(%r19,%rax,4\),%r31w
 [ 	]*[a-f0-9]+:[ 	]*62 7c 05 10 ad 2c 83 	shrd   %cl,%r13w,\(%r19,%rax,4\),%r31w
 [ 	]*[a-f0-9]+:[ 	]*62 74 05 10 ad 08    	shrd   %cl,%r9w,\(%rax\),%r31w
+[ 	]*[a-f0-9]+:[ 	]*62 74 05 10 ad 08    	shrd   %cl,%r9w,\(%rax\),%r31w
 [ 	]*[a-f0-9]+:[ 	]*62 f4 04 10 c1 28 02 	shr    \$0x2,\(%rax\),%r31d
 [ 	]*[a-f0-9]+:[ 	]*62 f4 05 10 d1 28    	shr    \$1,\(%rax\),%r31w
 [ 	]*[a-f0-9]+:[ 	]*62 fc 05 10 d3 2c 83 	shr    %cl,\(%r19,%rax,4\),%r31w
diff --git a/gas/testsuite/gas/i386/x86-64-apx-ndd.d b/gas/testsuite/gas/i386/x86-64-apx-ndd.d
index e08a2ddd37e..8c5ad231d20 100644
--- a/gas/testsuite/gas/i386/x86-64-apx-ndd.d
+++ b/gas/testsuite/gas/i386/x86-64-apx-ndd.d
@@ -126,8 +126,11 @@ Disassembly of section .text:
 \s*[a-f0-9]+:\s*62 74 04 10 24 38 02 	shld   \$0x2,%r15d,\(%rax\),%r31d
 \s*[a-f0-9]+:\s*62 54 05 10 24 c4 02 	shld   \$0x2,%r8w,%r12w,%r31w
 \s*[a-f0-9]+:\s*62 7c bc 18 a5 e0    	shld   %cl,%r12,%r16,%r8
+\s*[a-f0-9]+:\s*62 7c bc 18 a5 e0    	shld   %cl,%r12,%r16,%r8
+\s*[a-f0-9]+:\s*62 7c 05 10 a5 2c 83 	shld   %cl,%r13w,\(%r19,%rax,4\),%r31w
 \s*[a-f0-9]+:\s*62 7c 05 10 a5 2c 83 	shld   %cl,%r13w,\(%r19,%rax,4\),%r31w
 \s*[a-f0-9]+:\s*62 74 05 10 a5 08    	shld   %cl,%r9w,\(%rax\),%r31w
+\s*[a-f0-9]+:\s*62 74 05 10 a5 08    	shld   %cl,%r9w,\(%rax\),%r31w
 \s*[a-f0-9]+:\s*62 f4 04 10 c1 20 02 	shl    \$0x2,\(%rax\),%r31d
 \s*[a-f0-9]+:\s*62 f4 04 10 c1 20 02 	shl    \$0x2,\(%rax\),%r31d
 \s*[a-f0-9]+:\s*62 f4 05 10 d1 20    	shl    \$1,\(%rax\),%r31w
@@ -141,8 +144,11 @@ Disassembly of section .text:
 \s*[a-f0-9]+:\s*62 74 04 10 2c 38 02 	shrd   \$0x2,%r15d,\(%rax\),%r31d
 \s*[a-f0-9]+:\s*62 54 05 10 2c c4 02 	shrd   \$0x2,%r8w,%r12w,%r31w
 \s*[a-f0-9]+:\s*62 7c bc 18 ad e0    	shrd   %cl,%r12,%r16,%r8
+\s*[a-f0-9]+:\s*62 7c bc 18 ad e0    	shrd   %cl,%r12,%r16,%r8
+\s*[a-f0-9]+:\s*62 7c 05 10 ad 2c 83 	shrd   %cl,%r13w,\(%r19,%rax,4\),%r31w
 \s*[a-f0-9]+:\s*62 7c 05 10 ad 2c 83 	shrd   %cl,%r13w,\(%r19,%rax,4\),%r31w
 \s*[a-f0-9]+:\s*62 74 05 10 ad 08    	shrd   %cl,%r9w,\(%rax\),%r31w
+\s*[a-f0-9]+:\s*62 74 05 10 ad 08    	shrd   %cl,%r9w,\(%rax\),%r31w
 \s*[a-f0-9]+:\s*62 f4 04 10 c1 28 02 	shr    \$0x2,\(%rax\),%r31d
 \s*[a-f0-9]+:\s*62 f4 05 10 d1 28    	shr    \$1,\(%rax\),%r31w
 \s*[a-f0-9]+:\s*62 fc 05 10 d3 2c 83 	shr    %cl,\(%r19,%rax,4\),%r31w
diff --git a/gas/testsuite/gas/i386/x86-64-apx-ndd.s b/gas/testsuite/gas/i386/x86-64-apx-ndd.s
index 4e248f737a9..122b3bc0def 100644
--- a/gas/testsuite/gas/i386/x86-64-apx-ndd.s
+++ b/gas/testsuite/gas/i386/x86-64-apx-ndd.s
@@ -120,8 +120,11 @@ _start:
 	shld   $0x2,%r15d,(%rax),%r31d
 	shld   $0x2,%r8w,%r12w,%r31w
 	shld   %cl,%r12,%r16,%r8
+	shld   %r12,%r16,%r8
 	shld   %cl,%r13w,(%r19,%rax,4),%r31w
+	shld   %r13w,(%r19,%rax,4),%r31w
 	shld   %cl,%r9w,(%rax),%r31w
+	shld   %r9w,(%rax),%r31w
 	shll   $0x2,(%rax),%r31d
 	shll   $0x2,(%rax),%r31d
 	shlw   $0x1,(%rax),%r31w
@@ -135,8 +138,11 @@ _start:
 	shrd   $0x2,%r15d,(%rax),%r31d
 	shrd   $0x2,%r8w,%r12w,%r31w
 	shrd   %cl,%r12,%r16,%r8
+	shrd   %r12,%r16,%r8
 	shrd   %cl,%r13w,(%r19,%rax,4),%r31w
+	shrd   %r13w,(%r19,%rax,4),%r31w
 	shrd   %cl,%r9w,(%rax),%r31w
+	shrd   %r9w,(%rax),%r31w
 	shrl   $0x2,(%rax),%r31d
 	shrw   $0x1,(%rax),%r31w
 	shrw   %cl,(%r19,%rax,4),%r31w
diff --git a/opcodes/i386-opc.tbl b/opcodes/i386-opc.tbl
index 5d0c81b8853..fc689d4d0d9 100644
--- a/opcodes/i386-opc.tbl
+++ b/opcodes/i386-opc.tbl
@@ -434,6 +434,7 @@ imul, 0x69, i186, Modrm|No_bSuf|No_sSuf|RegKludge, { Imm16|Imm32|Imm32S, Reg16|R
 
 sh<shd>d, 0x24 | <shd:opc>, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4|NF, { Imm8, Reg16|Reg32|Reg64, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
 sh<shd>d, 0x0fa4 | <shd:opc>, i386, Modrm|CheckOperandSize|No_bSuf|No_sSuf, { Imm8, Reg16|Reg32|Reg64, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
+sh<shd>d, 0xa5 | <shd:opc>, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4|NF, { Reg16|Reg32|Reg64, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
 sh<shd>d, 0xa5 | <shd:opc>, APX_F, Modrm|CheckOperandSize|No_bSuf|No_sSuf|DstVVVV|EVexMap4|NF, { ShiftCount, Reg16|Reg32|Reg64, Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
 sh<shd>d, 0x0fa5 | <shd:opc>, i386, Modrm|CheckOperandSize|No_bSuf|No_sSuf, { ShiftCount, Reg16|Reg32|Reg64, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
 sh<shd>d, 0x0fa5 | <shd:opc>, i386, Modrm|CheckOperandSize|No_bSuf|No_sSuf, { Reg16|Reg32|Reg64, Reg16|Reg32|Reg64|Unspecified|BaseIndex }
diff --git a/opcodes/i386-tbl.h b/opcodes/i386-tbl.h
index bc98f5df3cb..5520402061d 100644
--- a/opcodes/i386-tbl.h
+++ b/opcodes/i386-tbl.h
@@ -2696,6 +2696,18 @@ 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_shld, 0xa5 | 0, 3, SPACE_EVEXMAP4, None,
+    { 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 } },
+    { { 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, 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, 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_shld, 0xa5 | 0, 4, SPACE_EVEXMAP4, None,
     { 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,
@@ -2758,6 +2770,18 @@ 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_shrd, 0xa5 | 8, 3, SPACE_EVEXMAP4, None,
+    { 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 } },
+    { { 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, 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, 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_shrd, 0xa5 | 8, 4, SPACE_EVEXMAP4, None,
     { 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,
@@ -41407,290 +41431,290 @@ static const i386_op_off_t i386_op_sets[] =
    162,  163,  165,  167,  168,  169,  170,  171,
    172,  173,  174,  175,  176,  177,  178,  179,
    180,  187,  189,  191,  201,  211,  221,  231,
-   241,  251,  261,  271,  276,  281,  290,  293,
-   301,  304,  310,  312,  314,  316,  318,  319,
-   320,  321,  322,  323,  324,  325,  326,  327,
-   328,  329,  330,  331,  332,  333,  334,  335,
-   336,  337,  338,  339,  340,  341,  342,  343,
-   344,  345,  346,  347,  348,  349,  350,  351,
-   353,  355,  357,  359,  361,  362,  363,  364,
-   365,  366,  367,  368,  369,  370,  371,  372,
-   373,  374,  375,  376,  377,  378,  379,  380,
-   381,  382,  383,  384,  385,  386,  387,  388,
-   389,  390,  391,  393,  395,  397,  399,  402,
-   405,  407,  409,  412,  415,  418,  421,  423,
-   424,  425,  427,  429,  431,  433,  434,  435,
-   436,  437,  438,  439,  440,  441,  443,  445,
-   447,  449,  451,  453,  454,  456,  458,  460,
-   462,  464,  466,  468,  470,  472,  476,  478,
-   479,  480,  481,  484,  485,  489,  491,  492,
-   493,  494,  496,  500,  501,  505,  506,  507,
-   509,  511,  512,  513,  514,  515,  516,  517,
-   518,  519,  520,  521,  525,  526,  529,  533,
-   534,  540,  544,  545,  551,  555,  556,  559,
-   563,  564,  570,  574,  575,  581,  582,  583,
-   584,  585,  586,  587,  588,  589,  590,  591,
-   592,  593,  594,  595,  596,  597,  598,  599,
-   600,  601,  602,  603,  604,  607,  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,
-   692,  693,  694,  695,  696,  697,  698,  699,
-   700,  701,  702,  703,  704,  705,  707,  709,
-   710,  711,  712,  713,  714,  715,  716,  717,
-   718,  719,  721,  723,  725,  727,  729,  731,
-   733,  735,  737,  739,  741,  743,  745,  747,
-   749,  751,  753,  755,  757,  759,  761,  763,
-   765,  767,  769,  771,  773,  775,  777,  779,
-   780,  781,  782,  783,  784,  785,  786,  787,
-   788,  789,  790,  791,  794,  797,  800,  803,
-   806,  809,  810,  811,  812,  813,  814,  815,
-   821,  829,  832,  835,  838,  841,  844,  847,
-   850,  853,  856,  859,  862,  865,  868,  871,
-   874,  877,  880,  883,  886,  889,  892,  895,
-   898,  904,  910,  916,  922,  928,  934,  940,
-   946,  949,  952,  955,  958,  961,  964,  967,
-   970,  973,  976,  979,  982,  985,  988,  991,
-   993,  995,  997,  999, 1001, 1003, 1005, 1007,
-  1009, 1011, 1013, 1015, 1017, 1019, 1021, 1023,
-  1025, 1027, 1029, 1031, 1033, 1035, 1037, 1038,
-  1039, 1045, 1047, 1048, 1050, 1052, 1054, 1056,
-  1057, 1059, 1061, 1063, 1065, 1067, 1069, 1072,
-  1074, 1077, 1079, 1081, 1082, 1084, 1087, 1089,
-  1091, 1093, 1095, 1098, 1101, 1108, 1114, 1117,
-  1120, 1123, 1126, 1129, 1132, 1133, 1134, 1135,
-  1136, 1139, 1140, 1142, 1144, 1146, 1148, 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, 1203, 1205, 1207, 1209, 1211, 1213,
-  1215, 1218, 1224, 1226, 1228, 1230, 1232, 1234,
-  1236, 1238, 1241, 1244, 1246, 1248, 1251, 1253,
-  1255, 1257, 1259, 1261, 1263, 1265, 1267, 1269,
-  1271, 1273, 1275, 1277, 1279, 1281, 1283, 1284,
-  1286, 1288, 1290, 1292, 1294, 1296, 1297, 1299,
-  1301, 1303, 1305, 1307, 1309, 1310, 1311, 1314,
-  1316, 1318, 1320, 1322, 1324, 1326, 1328, 1330,
-  1332, 1334, 1336, 1338, 1340, 1342, 1344, 1346,
-  1348, 1350, 1351, 1352, 1355, 1357, 1358, 1359,
-  1360, 1361, 1362, 1363, 1365, 1367, 1368, 1369,
-  1370, 1371, 1374, 1377, 1380, 1383, 1386, 1389,
-  1392, 1395, 1398, 1401, 1404, 1407, 1410, 1413,
-  1416, 1419, 1422, 1425, 1428, 1430, 1432, 1436,
-  1440, 1442, 1444, 1448, 1450, 1452, 1454, 1456,
-  1460, 1462, 1464, 1468, 1470, 1472, 1474, 1478,
-  1480, 1482, 1484, 1486, 1488, 1490, 1492, 1494,
-  1496, 1498, 1500, 1502, 1504, 1506, 1508, 1510,
-  1512, 1514, 1516, 1518, 1520, 1522, 1524, 1526,
-  1528, 1530, 1532, 1534, 1536, 1538, 1542, 1546,
-  1548, 1550, 1554, 1555, 1556, 1557, 1558, 1559,
-  1560, 1561, 1562, 1564, 1566, 1568, 1570, 1572,
-  1574, 1576, 1578, 1580, 1582, 1584, 1586, 1588,
-  1590, 1592, 1594, 1596, 1598, 1599, 1600, 1602,
-  1604, 1606, 1608, 1609, 1610, 1611, 1612, 1614,
-  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, 1987, 1989, 1991, 1993, 1995, 1997, 1999,
-  2004, 2006, 2011, 2013, 2015, 2020, 2022, 2024,
-  2026, 2031, 2033, 2035, 2037, 2041, 2047, 2049,
-  2054, 2056, 2058, 2060, 2062, 2064, 2066, 2068,
-  2070, 2072, 2073, 2074, 2076, 2078, 2079, 2080,
-  2081, 2082, 2084, 2086, 2087, 2088, 2089, 2091,
-  2093, 2095, 2097, 2099, 2101, 2103, 2105, 2107,
-  2109, 2111, 2113, 2115, 2119, 2120, 2121, 2123,
-  2127, 2131, 2133, 2137, 2141, 2142, 2143, 2145,
-  2147, 2149, 2151, 2156, 2160, 2164, 2166, 2168,
-  2170, 2172, 2173, 2175, 2177, 2179, 2181, 2183,
-  2185, 2187, 2189, 2191, 2193, 2195, 2197, 2199,
-  2201, 2203, 2205, 2207, 2209, 2211, 2213, 2215,
-  2217, 2218, 2219, 2221, 2223, 2224, 2225, 2228,
-  2231, 2234, 2237, 2239, 2241, 2243, 2245, 2247,
-  2249, 2250, 2251, 2252, 2254, 2258, 2260, 2262,
-  2268, 2272, 2273, 2274, 2275, 2276, 2277, 2278,
-  2279, 2283, 2285, 2287, 2291, 2293, 2295, 2297,
-  2299, 2301, 2303, 2305, 2307, 2309, 2311, 2313,
-  2315, 2317, 2319, 2320, 2323, 2326, 2331, 2336,
-  2339, 2342, 2345, 2348, 2353, 2358, 2361, 2364,
-  2366, 2368, 2370, 2372, 2374, 2376, 2378, 2379,
-  2381, 2383, 2385, 2387, 2389, 2390, 2391, 2392,
-  2396, 2400, 2402, 2406, 2410, 2414, 2418, 2422,
-  2424, 2428, 2430, 2432, 2434, 2436, 2438, 2440,
-  2442, 2444, 2445, 2447, 2449, 2451, 2453, 2455,
-  2457, 2459, 2461, 2462, 2463, 2464, 2466, 2468,
-  2470, 2472, 2473, 2474, 2476, 2478, 2480, 2482,
-  2484, 2486, 2487, 2489, 2491, 2493, 2495, 2496,
-  2497, 2499, 2501, 2503, 2505, 2507, 2509, 2511,
-  2513, 2514, 2515, 2517, 2518, 2521, 2524, 2526,
-  2529, 2530, 2531, 2533, 2534, 2536, 2538, 2540,
-  2542, 2544, 2545, 2546, 2547, 2548, 2549, 2552,
-  2557, 2562, 2567, 2572, 2575, 2580, 2585, 2587,
-  2589, 2591, 2593, 2594, 2595, 2597, 2599, 2601,
-  2603, 2605, 2607, 2609, 2610, 2611, 2612, 2613,
-  2614, 2615, 2620, 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, 2813,
-  2814, 2815, 2816, 2817, 2818, 2819, 2820, 2821,
-  2822, 2823, 2824, 2825, 2826, 2828, 2830, 2831,
-  2832, 2833, 2834, 2835, 2836, 2837, 2838, 2839,
-  2840, 2841, 2842, 2843, 2844, 2845, 2846, 2847,
-  2848, 2849, 2850, 2851, 2852, 2853, 2854, 2855,
-  2856, 2857, 2858, 2860, 2862, 2864, 2866, 2867,
-  2868, 2869, 2870, 2871, 2872, 2873, 2874, 2875,
-  2876, 2877, 2878, 2879, 2881, 2882, 2883, 2884,
-  2885, 2886, 2887, 2888, 2889, 2890, 2891, 2892,
-  2893, 2894, 2895, 2896, 2897, 2898, 2899, 2900,
-  2901, 2902, 2903, 2904, 2905, 2906, 2907, 2908,
-  2909, 2910, 2911, 2912, 2913, 2914, 2915, 2916,
-  2917, 2918, 2919, 2920, 2921, 2922, 2923, 2924,
-  2925, 2926, 2928, 2930, 2931, 2932, 2934, 2935,
-  2937, 2939, 2940, 2941, 2943, 2945, 2946, 2947,
-  2948, 2949, 2950, 2951, 2952, 2953, 2954, 2955,
-  2956, 2957, 2958, 2959, 2960, 2961, 2962, 2963,
-  2966, 2969, 2970, 2971, 2972, 2973, 2974, 2975,
-  2977, 2979, 2981, 2982, 2983, 2984, 2985, 2986,
-  2987, 2989, 2990, 2991, 2992, 2993, 2994, 2995,
-  2996, 2997, 2998, 2999, 3000, 3001, 3002, 3003,
-  3004, 3005, 3006, 3007, 3008, 3009, 3012, 3015,
-  3016, 3017, 3018, 3019, 3020, 3021, 3022, 3023,
-  3024, 3025, 3026, 3027, 3028, 3029, 3030, 3031,
-  3032, 3033, 3034, 3035, 3036, 3037, 3038, 3039,
-  3040, 3041, 3042, 3043, 3044, 3045, 3046, 3047,
-  3048, 3049, 3050, 3051, 3052, 3053, 3054, 3055,
-  3056, 3057, 3058, 3059, 3060, 3061, 3062, 3063,
-  3064, 3065, 3066, 3067, 3068, 3069, 3072, 3074,
-  3077, 3080, 3082, 3085, 3088, 3091, 3094, 3095,
-  3098, 3099, 3100, 3101, 3102, 3103, 3107, 3109,
-  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,
-  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,
-  3211, 3214, 3217, 3220, 3223, 3226, 3229, 3232,
-  3235, 3238, 3241, 3244, 3247, 3250, 3253, 3254,
-  3255, 3256, 3257, 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, 3315, 3316, 3317, 3318, 3319,
-  3320, 3323, 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, 3383, 3384, 3385, 3386, 3387,
-  3388, 3391, 3394, 3397, 3398, 3399, 3400, 3401,
-  3402, 3403, 3404, 3405, 3406, 3407, 3408, 3409,
-  3410, 3411, 3412, 3413, 3416, 3419, 3420, 3421,
-  3424, 3425, 3426, 3427, 3428, 3431, 3434, 3437,
-  3438, 3439, 3440, 3441, 3442, 3443, 3444, 3445,
-  3446, 3447, 3449, 3451, 3452, 3453, 3454, 3455,
-  3456, 3457, 3458, 3459, 3460, 3461, 3462, 3463,
-  3464, 3465, 3466, 3467, 3468, 3469, 3470, 3471,
-  3472, 3473, 3474, 3475, 3476, 3478, 3480, 3481,
-  3482, 3483, 3484, 3485, 3486, 3487, 3488, 3489,
-  3490, 3491, 3492, 3493, 3494, 3495, 3496, 3497,
-  3498, 3499, 3500, 3501, 3502, 3503, 3504, 3505,
-  3507, 3509, 3511, 3513, 3514, 3515, 3516, 3517,
-  3518, 3519, 3520, 3521, 3522, 3523, 3524, 3525,
-  3526, 3527, 3528, 3530, 3531, 3533, 3536, 3538,
-  3539, 3540, 3542, 3544, 3545, 3546, 3547, 3548,
-  3549, 3550, 3552, 3554, 3556, 3558, 3559, 3560,
-  3561, 3562, 3563, 3564, 3565, 3566, 3567, 3569,
-  3571, 3572, 3574, 3576, 3577, 3582, 3584, 3586,
-  3587, 3588, 3589, 3590, 3591, 3592, 3593, 3595,
-  3597, 3598, 3599, 3600, 3602, 3605, 3608, 3611,
-  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, 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, 3758,
-  3759, 3760, 3763, 3764, 3765, 3767, 3768, 3769,
-  3770, 3772, 3773, 3774, 3775, 3777, 3778, 3779,
-  3780, 3783, 3784, 3785, 3786, 3787, 3790, 3793,
-  3796, 3799, 3802, 3803, 3804, 3805, 3806, 3808,
-  3810, 3811, 3812, 3813, 3816, 3819, 3822, 3825,
-  3828, 3829, 3830, 3831, 3833, 3834, 3835, 3836,
-  3838, 3839, 3840, 3841, 3842, 3843, 3844, 3845,
-  3846, 3847, 3848, 3849, 3850, 3851, 3852, 3853,
-  3854, 3855, 3856, 3857, 3858, 3859, 3860, 3861,
-  3862, 3863, 3864, 3865, 3866, 3867, 3868, 3869,
-  3870, 3871, 3872, 3873, 3874, 3875, 3876, 3877,
-  3879, 3881, 3883, 3885, 3887, 3888, 3889, 3892,
-  3895, 3896, 3897, 3898, 3899
+   241,  251,  261,  271,  277,  283,  292,  295,
+   303,  306,  312,  314,  316,  318,  320,  321,
+   322,  323,  324,  325,  326,  327,  328,  329,
+   330,  331,  332,  333,  334,  335,  336,  337,
+   338,  339,  340,  341,  342,  343,  344,  345,
+   346,  347,  348,  349,  350,  351,  352,  353,
+   355,  357,  359,  361,  363,  364,  365,  366,
+   367,  368,  369,  370,  371,  372,  373,  374,
+   375,  376,  377,  378,  379,  380,  381,  382,
+   383,  384,  385,  386,  387,  388,  389,  390,
+   391,  392,  393,  395,  397,  399,  401,  404,
+   407,  409,  411,  414,  417,  420,  423,  425,
+   426,  427,  429,  431,  433,  435,  436,  437,
+   438,  439,  440,  441,  442,  443,  445,  447,
+   449,  451,  453,  455,  456,  458,  460,  462,
+   464,  466,  468,  470,  472,  474,  478,  480,
+   481,  482,  483,  486,  487,  491,  493,  494,
+   495,  496,  498,  502,  503,  507,  508,  509,
+   511,  513,  514,  515,  516,  517,  518,  519,
+   520,  521,  522,  523,  527,  528,  531,  535,
+   536,  542,  546,  547,  553,  557,  558,  561,
+   565,  566,  572,  576,  577,  583,  584,  585,
+   586,  587,  588,  589,  590,  591,  592,  593,
+   594,  595,  596,  597,  598,  599,  600,  601,
+   602,  603,  604,  605,  606,  609,  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,  692,  693,
+   694,  695,  696,  697,  698,  699,  700,  701,
+   702,  703,  704,  705,  706,  707,  709,  711,
+   712,  713,  714,  715,  716,  717,  718,  719,
+   720,  721,  723,  725,  727,  729,  731,  733,
+   735,  737,  739,  741,  743,  745,  747,  749,
+   751,  753,  755,  757,  759,  761,  763,  765,
+   767,  769,  771,  773,  775,  777,  779,  781,
+   782,  783,  784,  785,  786,  787,  788,  789,
+   790,  791,  792,  793,  796,  799,  802,  805,
+   808,  811,  812,  813,  814,  815,  816,  817,
+   823,  831,  834,  837,  840,  843,  846,  849,
+   852,  855,  858,  861,  864,  867,  870,  873,
+   876,  879,  882,  885,  888,  891,  894,  897,
+   900,  906,  912,  918,  924,  930,  936,  942,
+   948,  951,  954,  957,  960,  963,  966,  969,
+   972,  975,  978,  981,  984,  987,  990,  993,
+   995,  997,  999, 1001, 1003, 1005, 1007, 1009,
+  1011, 1013, 1015, 1017, 1019, 1021, 1023, 1025,
+  1027, 1029, 1031, 1033, 1035, 1037, 1039, 1040,
+  1041, 1047, 1049, 1050, 1052, 1054, 1056, 1058,
+  1059, 1061, 1063, 1065, 1067, 1069, 1071, 1074,
+  1076, 1079, 1081, 1083, 1084, 1086, 1089, 1091,
+  1093, 1095, 1097, 1100, 1103, 1110, 1116, 1119,
+  1122, 1125, 1128, 1131, 1134, 1135, 1136, 1137,
+  1138, 1141, 1142, 1144, 1146, 1148, 1150, 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, 1203, 1205, 1207, 1209, 1211, 1213, 1215,
+  1217, 1220, 1226, 1228, 1230, 1232, 1234, 1236,
+  1238, 1240, 1243, 1246, 1248, 1250, 1253, 1255,
+  1257, 1259, 1261, 1263, 1265, 1267, 1269, 1271,
+  1273, 1275, 1277, 1279, 1281, 1283, 1285, 1286,
+  1288, 1290, 1292, 1294, 1296, 1298, 1299, 1301,
+  1303, 1305, 1307, 1309, 1311, 1312, 1313, 1316,
+  1318, 1320, 1322, 1324, 1326, 1328, 1330, 1332,
+  1334, 1336, 1338, 1340, 1342, 1344, 1346, 1348,
+  1350, 1352, 1353, 1354, 1357, 1359, 1360, 1361,
+  1362, 1363, 1364, 1365, 1367, 1369, 1370, 1371,
+  1372, 1373, 1376, 1379, 1382, 1385, 1388, 1391,
+  1394, 1397, 1400, 1403, 1406, 1409, 1412, 1415,
+  1418, 1421, 1424, 1427, 1430, 1432, 1434, 1438,
+  1442, 1444, 1446, 1450, 1452, 1454, 1456, 1458,
+  1462, 1464, 1466, 1470, 1472, 1474, 1476, 1480,
+  1482, 1484, 1486, 1488, 1490, 1492, 1494, 1496,
+  1498, 1500, 1502, 1504, 1506, 1508, 1510, 1512,
+  1514, 1516, 1518, 1520, 1522, 1524, 1526, 1528,
+  1530, 1532, 1534, 1536, 1538, 1540, 1544, 1548,
+  1550, 1552, 1556, 1557, 1558, 1559, 1560, 1561,
+  1562, 1563, 1564, 1566, 1568, 1570, 1572, 1574,
+  1576, 1578, 1580, 1582, 1584, 1586, 1588, 1590,
+  1592, 1594, 1596, 1598, 1600, 1601, 1602, 1604,
+  1606, 1608, 1610, 1611, 1612, 1613, 1614, 1616,
+  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,
+  1987, 1989, 1991, 1993, 1995, 1997, 1999, 2001,
+  2006, 2008, 2013, 2015, 2017, 2022, 2024, 2026,
+  2028, 2033, 2035, 2037, 2039, 2043, 2049, 2051,
+  2056, 2058, 2060, 2062, 2064, 2066, 2068, 2070,
+  2072, 2074, 2075, 2076, 2078, 2080, 2081, 2082,
+  2083, 2084, 2086, 2088, 2089, 2090, 2091, 2093,
+  2095, 2097, 2099, 2101, 2103, 2105, 2107, 2109,
+  2111, 2113, 2115, 2117, 2121, 2122, 2123, 2125,
+  2129, 2133, 2135, 2139, 2143, 2144, 2145, 2147,
+  2149, 2151, 2153, 2158, 2162, 2166, 2168, 2170,
+  2172, 2174, 2175, 2177, 2179, 2181, 2183, 2185,
+  2187, 2189, 2191, 2193, 2195, 2197, 2199, 2201,
+  2203, 2205, 2207, 2209, 2211, 2213, 2215, 2217,
+  2219, 2220, 2221, 2223, 2225, 2226, 2227, 2230,
+  2233, 2236, 2239, 2241, 2243, 2245, 2247, 2249,
+  2251, 2252, 2253, 2254, 2256, 2260, 2262, 2264,
+  2270, 2274, 2275, 2276, 2277, 2278, 2279, 2280,
+  2281, 2285, 2287, 2289, 2293, 2295, 2297, 2299,
+  2301, 2303, 2305, 2307, 2309, 2311, 2313, 2315,
+  2317, 2319, 2321, 2322, 2325, 2328, 2333, 2338,
+  2341, 2344, 2347, 2350, 2355, 2360, 2363, 2366,
+  2368, 2370, 2372, 2374, 2376, 2378, 2380, 2381,
+  2383, 2385, 2387, 2389, 2391, 2392, 2393, 2394,
+  2398, 2402, 2404, 2408, 2412, 2416, 2420, 2424,
+  2426, 2430, 2432, 2434, 2436, 2438, 2440, 2442,
+  2444, 2446, 2447, 2449, 2451, 2453, 2455, 2457,
+  2459, 2461, 2463, 2464, 2465, 2466, 2468, 2470,
+  2472, 2474, 2475, 2476, 2478, 2480, 2482, 2484,
+  2486, 2488, 2489, 2491, 2493, 2495, 2497, 2498,
+  2499, 2501, 2503, 2505, 2507, 2509, 2511, 2513,
+  2515, 2516, 2517, 2519, 2520, 2523, 2526, 2528,
+  2531, 2532, 2533, 2535, 2536, 2538, 2540, 2542,
+  2544, 2546, 2547, 2548, 2549, 2550, 2551, 2554,
+  2559, 2564, 2569, 2574, 2577, 2582, 2587, 2589,
+  2591, 2593, 2595, 2596, 2597, 2599, 2601, 2603,
+  2605, 2607, 2609, 2611, 2612, 2613, 2614, 2615,
+  2616, 2617, 2622, 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, 2813, 2814, 2815,
+  2816, 2817, 2818, 2819, 2820, 2821, 2822, 2823,
+  2824, 2825, 2826, 2827, 2828, 2830, 2832, 2833,
+  2834, 2835, 2836, 2837, 2838, 2839, 2840, 2841,
+  2842, 2843, 2844, 2845, 2846, 2847, 2848, 2849,
+  2850, 2851, 2852, 2853, 2854, 2855, 2856, 2857,
+  2858, 2859, 2860, 2862, 2864, 2866, 2868, 2869,
+  2870, 2871, 2872, 2873, 2874, 2875, 2876, 2877,
+  2878, 2879, 2880, 2881, 2883, 2884, 2885, 2886,
+  2887, 2888, 2889, 2890, 2891, 2892, 2893, 2894,
+  2895, 2896, 2897, 2898, 2899, 2900, 2901, 2902,
+  2903, 2904, 2905, 2906, 2907, 2908, 2909, 2910,
+  2911, 2912, 2913, 2914, 2915, 2916, 2917, 2918,
+  2919, 2920, 2921, 2922, 2923, 2924, 2925, 2926,
+  2927, 2928, 2930, 2932, 2933, 2934, 2936, 2937,
+  2939, 2941, 2942, 2943, 2945, 2947, 2948, 2949,
+  2950, 2951, 2952, 2953, 2954, 2955, 2956, 2957,
+  2958, 2959, 2960, 2961, 2962, 2963, 2964, 2965,
+  2968, 2971, 2972, 2973, 2974, 2975, 2976, 2977,
+  2979, 2981, 2983, 2984, 2985, 2986, 2987, 2988,
+  2989, 2991, 2992, 2993, 2994, 2995, 2996, 2997,
+  2998, 2999, 3000, 3001, 3002, 3003, 3004, 3005,
+  3006, 3007, 3008, 3009, 3010, 3011, 3014, 3017,
+  3018, 3019, 3020, 3021, 3022, 3023, 3024, 3025,
+  3026, 3027, 3028, 3029, 3030, 3031, 3032, 3033,
+  3034, 3035, 3036, 3037, 3038, 3039, 3040, 3041,
+  3042, 3043, 3044, 3045, 3046, 3047, 3048, 3049,
+  3050, 3051, 3052, 3053, 3054, 3055, 3056, 3057,
+  3058, 3059, 3060, 3061, 3062, 3063, 3064, 3065,
+  3066, 3067, 3068, 3069, 3070, 3071, 3074, 3076,
+  3079, 3082, 3084, 3087, 3090, 3093, 3096, 3097,
+  3100, 3101, 3102, 3103, 3104, 3105, 3109, 3111,
+  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,
+  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,
+  3213, 3216, 3219, 3222, 3225, 3228, 3231, 3234,
+  3237, 3240, 3243, 3246, 3249, 3252, 3255, 3256,
+  3257, 3258, 3259, 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, 3315, 3316, 3317, 3318, 3319, 3320, 3321,
+  3322, 3325, 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, 3383, 3384, 3385, 3386, 3387, 3388, 3389,
+  3390, 3393, 3396, 3399, 3400, 3401, 3402, 3403,
+  3404, 3405, 3406, 3407, 3408, 3409, 3410, 3411,
+  3412, 3413, 3414, 3415, 3418, 3421, 3422, 3423,
+  3426, 3427, 3428, 3429, 3430, 3433, 3436, 3439,
+  3440, 3441, 3442, 3443, 3444, 3445, 3446, 3447,
+  3448, 3449, 3451, 3453, 3454, 3455, 3456, 3457,
+  3458, 3459, 3460, 3461, 3462, 3463, 3464, 3465,
+  3466, 3467, 3468, 3469, 3470, 3471, 3472, 3473,
+  3474, 3475, 3476, 3477, 3478, 3480, 3482, 3483,
+  3484, 3485, 3486, 3487, 3488, 3489, 3490, 3491,
+  3492, 3493, 3494, 3495, 3496, 3497, 3498, 3499,
+  3500, 3501, 3502, 3503, 3504, 3505, 3506, 3507,
+  3509, 3511, 3513, 3515, 3516, 3517, 3518, 3519,
+  3520, 3521, 3522, 3523, 3524, 3525, 3526, 3527,
+  3528, 3529, 3530, 3532, 3533, 3535, 3538, 3540,
+  3541, 3542, 3544, 3546, 3547, 3548, 3549, 3550,
+  3551, 3552, 3554, 3556, 3558, 3560, 3561, 3562,
+  3563, 3564, 3565, 3566, 3567, 3568, 3569, 3571,
+  3573, 3574, 3576, 3578, 3579, 3584, 3586, 3588,
+  3589, 3590, 3591, 3592, 3593, 3594, 3595, 3597,
+  3599, 3600, 3601, 3602, 3604, 3607, 3610, 3613,
+  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, 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, 3760,
+  3761, 3762, 3765, 3766, 3767, 3769, 3770, 3771,
+  3772, 3774, 3775, 3776, 3777, 3779, 3780, 3781,
+  3782, 3785, 3786, 3787, 3788, 3789, 3792, 3795,
+  3798, 3801, 3804, 3805, 3806, 3807, 3808, 3810,
+  3812, 3813, 3814, 3815, 3818, 3821, 3824, 3827,
+  3830, 3831, 3832, 3833, 3835, 3836, 3837, 3838,
+  3840, 3841, 3842, 3843, 3844, 3845, 3846, 3847,
+  3848, 3849, 3850, 3851, 3852, 3853, 3854, 3855,
+  3856, 3857, 3858, 3859, 3860, 3861, 3862, 3863,
+  3864, 3865, 3866, 3867, 3868, 3869, 3870, 3871,
+  3872, 3873, 3874, 3875, 3876, 3877, 3878, 3879,
+  3881, 3883, 3885, 3887, 3889, 3890, 3891, 3894,
+  3897, 3898, 3899, 3900, 3901
 };
 
 /* i386 mnemonics table.  */

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

only message in thread, other threads:[~2024-04-04 20:26 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2024-04-04 20:26 [binutils-gdb] x86: Restore APX shift-double instructions with omitted shift count H.J. Lu

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