]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
x86: refine UD<n> kind-of-insns
authorJan Beulich <jbeulich@suse.com>
Fri, 13 Jun 2025 06:40:32 +0000 (08:40 +0200)
committerJan Beulich <jbeulich@suse.com>
Fri, 13 Jun 2025 06:40:32 +0000 (08:40 +0200)
While documentation of these continues to be lacking sufficient detail,
it is becoming increasingly clear that in 66f1eba0b7e8 ("x86: correct
UDn") I went too far with requiring operands, to populate a ModR/M byte.
AMD hardware appears to always behave as indicated as "may" in PM 3.36,
which for all practical purposes means there's no ModR/M byte. The SDM
(rev 087) indicates that such behavior can occur on older hardware for
UD0. Re-add an operand-less UD1 form (as well as its UD2B alias), while
newly adding such a form also for UD0. Because of the ambiguity, there's
no good/easy way of handling both possibilities in the disassembler,
which hence remains unaltered.

Further, from all information I'm able to gather, the 0F opcode space
was only introduced with the i286; bump the minimal hardware requirement
for all UD<n> accordingly.

gas/testsuite/gas/i386/arch-4.d
gas/testsuite/gas/i386/arch-4.s
opcodes/i386-opc.tbl
opcodes/i386-tbl.h

index 54fde1584db64b417b33045cdcf45cba4aa8eaf3..6ebd45666854275816cf5f6301fdecb754b60097 100644 (file)
@@ -6,7 +6,9 @@
 Disassembly of section .text:
 
 0+ <.text>:
+[      ]*[a-f0-9]+:    0f ff cc [      ]*ud0    %esp,%ecx
 [      ]*[a-f0-9]+:    0f ff 07 [      ]*ud0    \(%edi\),%eax
+[      ]*[a-f0-9]+:    0f b9 cc [      ]*ud1    %esp,%ecx
 [      ]*[a-f0-9]+:    0f b9 07 [      ]*ud1    \(%edi\),%eax
 [      ]*[a-f0-9]+:    0f 0b                   ud2
 [      ]*[a-f0-9]+:    0f 0b                   ud2
index cf14d736b3614fa4fe93b1d4b7ce9673a81869f6..62c3f8a96ecf91a7d159ed4a9c2916b9c9c91eb4 100644 (file)
@@ -1,5 +1,9 @@
        .text
+       ud0
+       int3
        ud0     (%edi),%eax
+       ud1
+       int3
        ud1     (%edi),%eax
        ud2
        ud2a
index 0a5e8de35d48f76002b2f711eb8d3240fee12901..348b0e94129f8c96540a595003be68998b100919 100644 (file)
@@ -979,15 +979,18 @@ fxrstor, 0xfae/1, FXSR, Modrm|No_bSuf|No_wSuf|No_lSuf|No_sSuf|IntelSuffix, { Uns
 fxrstor64, 0xfae/1, FXSR&x64, Modrm|NoSuf|Size64, { Unspecified|BaseIndex }
 rdpmc, 0xf33, i686, NoSuf, {}
 // official undefined instr.
-ud2, 0xf0b, i186, NoSuf, {}
+ud2, 0xf0b, i286, NoSuf, {}
 // alias for ud2
-ud2a, 0xf0b, i186, NoSuf, {}
-// 2nd. official undefined instr.
-ud1, 0xfb9, i186, Modrm|CheckOperandSize|No_bSuf|No_sSuf, { Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
+ud2a, 0xf0b, i286, NoSuf, {}
+// 2nd official undefined instr (older AMD CPUs don't take a ModR/M byte)
+ud1, 0xfb9, i286, /*Amd|*/NoSuf, {}
+ud1, 0xfb9, i286, Modrm|CheckOperandSize|No_bSuf|No_sSuf, { Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
 // alias for ud1
-ud2b, 0xfb9, i186, Modrm|CheckOperandSize|No_bSuf|No_sSuf, { Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
+ud2b, 0xfb9, i286, /*Amd|*/NoSuf, {}
+ud2b, 0xfb9, i286, Modrm|CheckOperandSize|No_bSuf|No_sSuf, { Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
 // 3rd official undefined instr (older CPUs don't take a ModR/M byte)
-ud0, 0xfff, i186, Modrm|CheckOperandSize|No_bSuf|No_sSuf, { Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
+ud0, 0xfff, i286, NoSuf, {}
+ud0, 0xfff, i286, Modrm|CheckOperandSize|No_bSuf|No_sSuf, { Reg16|Reg32|Reg64|Unspecified|BaseIndex, Reg16|Reg32|Reg64 }
 
 // C (commutative) isn't quite correct here on its own; the condition also
 // needs inverting when source operands are swapped in order to convert to
index 83f7d990f59c5fb49d1c19abbead34d1ec758a79..1711a7bc54ac171c51fb39e8f1b6fc5080b4bfac 100644 (file)
@@ -8958,7 +8958,7 @@ static const insn_template i386_optab[] =
     { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 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, 0,
       0, 0 },
-    { { 1, 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, 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 } } } },
@@ -8966,7 +8966,15 @@ static const insn_template i386_optab[] =
     { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 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, 0,
       0, 0 },
-    { { 1, 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, 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_ud1, 0xb9, 0, SPACE_0F, None,
+    { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 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, 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 } },
     { { { 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 } } } },
@@ -8974,27 +8982,43 @@ static const insn_template i386_optab[] =
     { 0, 0, 0, 1, 0, 0, 0, 1, 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 },
-    { { 1, 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, 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, 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_ud2b, 0xb9, 0, SPACE_0F, None,
+    { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 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, 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 } },
+    { { { 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_ud2b, 0xb9, 2, SPACE_0F, 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, 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 } },
+    { { 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, 0, 0, 0, 0, 1, 1, 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_ud0, 0xff, 0, SPACE_0F, None,
+    { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 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, 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 } },
+    { { { 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_ud0, 0xff, 2, SPACE_0F, 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, 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 } },
+    { { 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, 0, 0, 0, 0, 1, 1, 1, 0, 1, 0, 1, 1, 0, 1, 0,
          0, 0, 0, 0, 1, 0 } },
@@ -47936,274 +47960,274 @@ static const i386_op_off_t i386_op_sets[] =
    967,  968,  969,  970,  971,  972,  973,  974,
    975,  976,  977,  978,  979,  980,  982,  983,
    985,  987,  988,  989,  990,  991,  992,  993,
-   994,  995,  996,  997,  999, 1001, 1003, 1005,
-  1007, 1009, 1011, 1013, 1015, 1017, 1019, 1021,
-  1023, 1025, 1027, 1029, 1031, 1033, 1035, 1037,
-  1039, 1041, 1043, 1045, 1047, 1049, 1051, 1053,
-  1055, 1057, 1059, 1061, 1063, 1065, 1067, 1069,
-  1071, 1073, 1075, 1077, 1079, 1081, 1083, 1085,
-  1087, 1089, 1091, 1093, 1095, 1097, 1099, 1101,
-  1103, 1105, 1107, 1109, 1111, 1113, 1115, 1117,
-  1118, 1119, 1120, 1121, 1122, 1123, 1124, 1125,
-  1126, 1127, 1128, 1129, 1132, 1135, 1138, 1141,
-  1144, 1147, 1148, 1149, 1150, 1151, 1152, 1153,
-  1159, 1169, 1173, 1177, 1181, 1185, 1189, 1192,
-  1196, 1200, 1204, 1208, 1212, 1215, 1218, 1221,
-  1224, 1227, 1230, 1233, 1236, 1240, 1244, 1248,
-  1251, 1259, 1265, 1273, 1281, 1287, 1295, 1301,
-  1309, 1313, 1317, 1320, 1324, 1328, 1332, 1336,
-  1340, 1344, 1348, 1351, 1355, 1359, 1362, 1365,
-  1367, 1369, 1371, 1373, 1375, 1377, 1379, 1381,
-  1383, 1385, 1387, 1389, 1392, 1395, 1398, 1401,
-  1403, 1405, 1407, 1409, 1411, 1413, 1415, 1417,
-  1419, 1421, 1423, 1425, 1427, 1429, 1431, 1433,
-  1435, 1437, 1439, 1440, 1441, 1447, 1449, 1450,
-  1452, 1454, 1455, 1457, 1459, 1462, 1464, 1467,
-  1469, 1471, 1472, 1474, 1477, 1479, 1483, 1487,
-  1496, 1502, 1506, 1510, 1514, 1518, 1521, 1525,
-  1526, 1527, 1528, 1529, 1533, 1534, 1537, 1540,
-  1543, 1546, 1547, 1549, 1551, 1553, 1555, 1557,
-  1559, 1561, 1564, 1567, 1570, 1573, 1576, 1579,
-  1582, 1585, 1588, 1591, 1594, 1597, 1600, 1603,
-  1606, 1609, 1611, 1613, 1615, 1617, 1619, 1621,
-  1623, 1625, 1627, 1629, 1631, 1633, 1635, 1637,
-  1639, 1641, 1643, 1645, 1648, 1651, 1657, 1660,
-  1665, 1670, 1672, 1675, 1680, 1683, 1686, 1689,
-  1692, 1695, 1698, 1701, 1703, 1706, 1708, 1709,
-  1712, 1714, 1716, 1718, 1721, 1723, 1724, 1726,
-  1729, 1731, 1733, 1735, 1737, 1738, 1739, 1743,
-  1745, 1748, 1751, 1754, 1757, 1760, 1763, 1765,
-  1767, 1769, 1771, 1773, 1775, 1778, 1781, 1783,
-  1785, 1787, 1788, 1789, 1792, 1794, 1795, 1796,
-  1797, 1798, 1799, 1800, 1802, 1804, 1805, 1806,
-  1807, 1808, 1811, 1814, 1817, 1820, 1823, 1826,
-  1829, 1832, 1835, 1839, 1843, 1847, 1850, 1853,
-  1856, 1860, 1864, 1868, 1871, 1873, 1875, 1879,
-  1883, 1885, 1887, 1891, 1893, 1895, 1897, 1900,
-  1904, 1906, 1908, 1914, 1917, 1920, 1922, 1928,
-  1931, 1934, 1937, 1939, 1941, 1944, 1947, 1949,
-  1951, 1954, 1957, 1960, 1962, 1964, 1966, 1968,
-  1970, 1972, 1974, 1976, 1978, 1980, 1983, 1985,
-  1987, 1990, 1992, 1995, 1997, 1999, 2003, 2007,
-  2009, 2011, 2015, 2016, 2017, 2018, 2019, 2020,
-  2021, 2022, 2023, 2025, 2027, 2029, 2031, 2033,
-  2035, 2037, 2039, 2041, 2043, 2045, 2047, 2049,
-  2051, 2053, 2055, 2057, 2059, 2061, 2063, 2065,
-  2067, 2069, 2071, 2073, 2075, 2077, 2079, 2081,
-  2083, 2085, 2087, 2089, 2091, 2093, 2095, 2097,
-  2099, 2100, 2101, 2103, 2105, 2107, 2109, 2111,
-  2113, 2115, 2117, 2118, 2119, 2120, 2121, 2122,
-  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, 2487, 2489, 2491,
-  2493, 2495, 2497, 2499, 2501, 2503, 2505, 2507,
-  2512, 2514, 2519, 2521, 2523, 2528, 2530, 2532,
-  2534, 2539, 2541, 2543, 2545, 2549, 2555, 2557,
-  2562, 2564, 2566, 2568, 2570, 2572, 2573, 2574,
-  2575, 2577, 2578, 2579, 2580, 2581, 2582, 2584,
-  2585, 2586, 2587, 2589, 2591, 2593, 2595, 2599,
-  2603, 2604, 2605, 2607, 2611, 2615, 2617, 2621,
-  2625, 2626, 2627, 2629, 2631, 2633, 2635, 2640,
-  2644, 2648, 2650, 2652, 2654, 2656, 2658, 2660,
-  2662, 2664, 2666, 2668, 2670, 2672, 2674, 2676,
-  2678, 2680, 2682, 2684, 2686, 2688, 2690, 2691,
-  2692, 2694, 2696, 2697, 2698, 2701, 2704, 2707,
-  2710, 2712, 2714, 2716, 2718, 2720, 2722, 2723,
-  2724, 2725, 2727, 2731, 2733, 2735, 2741, 2745,
-  2746, 2747, 2748, 2749, 2750, 2751, 2752, 2756,
-  2758, 2760, 2764, 2766, 2768, 2770, 2772, 2774,
-  2776, 2778, 2780, 2782, 2784, 2786, 2788, 2790,
-  2792, 2793, 2796, 2799, 2802, 2805, 2810, 2815,
-  2820, 2825, 2828, 2831, 2834, 2837, 2839, 2841,
-  2843, 2845, 2847, 2849, 2851, 2852, 2854, 2856,
-  2858, 2860, 2862, 2863, 2864, 2865, 2869, 2873,
-  2875, 2879, 2883, 2887, 2891, 2895, 2897, 2901,
-  2903, 2905, 2907, 2909, 2911, 2913, 2915, 2917,
-  2918, 2920, 2922, 2924, 2926, 2928, 2930, 2932,
-  2934, 2935, 2936, 2937, 2938, 2939, 2940, 2941,
-  2942, 2943, 2945, 2947, 2949, 2951, 2953, 2955,
-  2956, 2957, 2958, 2960, 2962, 2964, 2966, 2968,
-  2970, 2971, 2972, 2973, 2974, 2977, 2980, 2982,
-  2985, 2986, 2987, 2989, 2990, 2992, 2993, 2994,
-  2996, 2998, 2999, 3000, 3001, 3002, 3003, 3006,
-  3011, 3016, 3021, 3026, 3029, 3034, 3039, 3041,
-  3043, 3045, 3047, 3048, 3049, 3051, 3053, 3055,
-  3057, 3059, 3061, 3063, 3064, 3065, 3066, 3067,
-  3068, 3069, 3074, 3079, 3080, 3081, 3082, 3083,
-  3084, 3085, 3086, 3087, 3088, 3089, 3090, 3091,
-  3092, 3093, 3094, 3095, 3096, 3097, 3098, 3099,
-  3100, 3101, 3102, 3103, 3104, 3105, 3106, 3107,
-  3108, 3109, 3110, 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, 3282, 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, 3314, 3316, 3318, 3320, 3321,
-  3322, 3323, 3324, 3325, 3326, 3327, 3328, 3329,
-  3330, 3331, 3332, 3333, 3335, 3336, 3337, 3338,
-  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, 3383, 3385, 3386, 3387, 3389, 3390,
-  3392, 3394, 3395, 3396, 3398, 3400, 3402, 3404,
-  3405, 3406, 3407, 3408, 3409, 3410, 3411, 3412,
-  3413, 3414, 3415, 3416, 3417, 3418, 3419, 3420,
-  3421, 3422, 3423, 3424, 3425, 3426, 3427, 3428,
-  3431, 3434, 3435, 3436, 3437, 3438, 3439, 3440,
-  3442, 3444, 3446, 3447, 3448, 3449, 3450, 3451,
-  3452, 3454, 3455, 3456, 3457, 3458, 3459, 3460,
-  3461, 3462, 3464, 3466, 3467, 3468, 3469, 3470,
-  3471, 3472, 3473, 3474, 3475, 3476, 3479, 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, 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, 3543, 3545, 3548, 3551, 3553, 3556,
-  3559, 3562, 3565, 3566, 3569, 3570, 3571, 3572,
-  3573, 3574, 3578, 3580, 3583, 3584, 3585, 3586,
-  3587, 3588, 3589, 3590, 3591, 3592, 3593, 3594,
-  3595, 3596, 3597, 3598, 3599, 3600, 3601, 3602,
-  3603, 3604, 3605, 3606, 3607, 3608, 3609, 3610,
-  3611, 3612, 3613, 3614, 3615, 3616, 3617, 3618,
-  3619, 3620, 3621, 3622, 3623, 3624, 3625, 3626,
-  3627, 3628, 3629, 3630, 3631, 3632, 3633, 3634,
-  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,
-  3678, 3681, 3684, 3687, 3690, 3693, 3696, 3699,
-  3702, 3705, 3708, 3711, 3714, 3717, 3720, 3721,
-  3722, 3723, 3724, 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, 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, 3790, 3793, 3794, 3795, 3796, 3797, 3798,
-  3799, 3800, 3801, 3802, 3803, 3804, 3805, 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, 3858, 3861, 3864, 3865, 3866, 3867, 3868,
-  3869, 3870, 3871, 3872, 3873, 3874, 3875, 3876,
-  3877, 3878, 3879, 3880, 3883, 3886, 3887, 3888,
-  3891, 3892, 3893, 3894, 3895, 3898, 3901, 3904,
-  3905, 3906, 3907, 3908, 3909, 3910, 3911, 3912,
-  3913, 3914, 3916, 3917, 3918, 3919, 3921, 3922,
-  3923, 3924, 3925, 3926, 3927, 3928, 3929, 3930,
-  3931, 3932, 3933, 3934, 3935, 3936, 3937, 3938,
-  3939, 3940, 3941, 3942, 3943, 3945, 3947, 3948,
-  3949, 3950, 3951, 3952, 3953, 3954, 3955, 3956,
-  3957, 3958, 3959, 3960, 3961, 3962, 3963, 3964,
-  3965, 3966, 3967, 3968, 3969, 3970, 3971, 3972,
-  3974, 3976, 3978, 3980, 3982, 3984, 3986, 3988,
-  3990, 3992, 3994, 3996, 3998, 4000, 4002, 4004,
-  4005, 4006, 4007, 4009, 4010, 4012, 4015, 4017,
-  4018, 4019, 4021, 4023, 4024, 4025, 4026, 4027,
-  4028, 4029, 4031, 4033, 4035, 4037, 4038, 4039,
-  4040, 4041, 4042, 4043, 4044, 4045, 4046, 4048,
-  4050, 4051, 4053, 4055, 4056, 4061, 4063, 4065,
-  4066, 4067, 4068, 4069, 4070, 4071, 4072, 4074,
-  4076, 4077, 4078, 4079, 4081, 4084, 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, 4138, 4140, 4142, 4144,
-  4146, 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, 4246, 4247, 4248, 4249, 4250,
-  4251, 4252, 4253, 4254, 4255, 4256, 4257, 4258,
-  4259, 4260, 4261, 4262, 4263, 4264, 4265, 4266,
-  4267, 4268, 4269, 4270, 4271, 4274, 4275, 4276,
-  4279, 4280, 4281, 4283, 4284, 4285, 4286, 4288,
-  4289, 4290, 4291, 4293, 4294, 4295, 4296, 4299,
-  4300, 4301, 4302, 4303, 4306, 4309, 4312, 4315,
-  4318, 4319, 4320, 4321, 4322, 4324, 4326, 4327,
-  4328, 4329, 4332, 4335, 4338, 4341, 4344, 4345,
-  4346, 4347, 4349, 4350, 4351, 4352, 4355, 4356,
-  4357, 4358, 4359, 4360, 4361, 4362, 4363, 4364,
-  4365, 4366, 4367, 4368, 4369, 4370, 4371, 4372,
-  4373, 4374, 4375, 4376, 4377, 4378, 4379, 4380,
-  4381, 4382, 4383, 4384, 4385, 4386, 4387, 4388,
-  4389, 4390, 4391, 4393, 4394, 4395, 4397, 4399,
-  4401, 4403, 4405, 4406, 4407, 4410, 4413, 4414,
-  4415, 4416, 4417, 4418, 4419, 4421, 4423, 4425,
-  4427, 4428, 4429, 4430, 4431, 4434, 4435, 4436,
-  4439, 4440, 4441, 4444, 4445, 4446, 4449, 4450,
-  4451, 4454, 4455, 4456, 4457, 4458, 4459, 4460,
-  4461, 4462, 4463, 4464, 4465, 4466, 4467, 4468,
-  4469, 4470, 4471, 4472, 4473, 4474, 4475, 4476,
-  4477, 4478, 4479, 4480, 4481, 4482, 4483, 4484,
-  4485, 4486, 4487, 4488, 4489, 4490, 4491, 4492,
-  4493, 4494, 4495, 4496, 4497, 4498, 4501, 4502,
-  4503, 4506, 4507, 4508, 4509, 4510, 4511, 4512,
-  4515, 4518, 4519, 4520, 4521, 4522, 4523, 4524,
-  4525, 4526, 4527, 4528, 4529, 4530, 4531, 4532,
-  4533, 4534, 4535, 4536, 4538, 4539, 4540, 4541,
-  4542
+   994,  996,  998, 1000, 1002, 1004, 1006, 1008,
+  1010, 1012, 1014, 1016, 1018, 1020, 1022, 1024,
+  1026, 1028, 1030, 1032, 1034, 1036, 1038, 1040,
+  1042, 1044, 1046, 1048, 1050, 1052, 1054, 1056,
+  1058, 1060, 1062, 1064, 1066, 1068, 1070, 1072,
+  1074, 1076, 1078, 1080, 1082, 1084, 1086, 1088,
+  1090, 1092, 1094, 1096, 1098, 1100, 1102, 1104,
+  1106, 1108, 1110, 1112, 1114, 1116, 1118, 1120,
+  1121, 1122, 1123, 1124, 1125, 1126, 1127, 1128,
+  1129, 1130, 1131, 1132, 1135, 1138, 1141, 1144,
+  1147, 1150, 1151, 1152, 1153, 1154, 1155, 1156,
+  1162, 1172, 1176, 1180, 1184, 1188, 1192, 1195,
+  1199, 1203, 1207, 1211, 1215, 1218, 1221, 1224,
+  1227, 1230, 1233, 1236, 1239, 1243, 1247, 1251,
+  1254, 1262, 1268, 1276, 1284, 1290, 1298, 1304,
+  1312, 1316, 1320, 1323, 1327, 1331, 1335, 1339,
+  1343, 1347, 1351, 1354, 1358, 1362, 1365, 1368,
+  1370, 1372, 1374, 1376, 1378, 1380, 1382, 1384,
+  1386, 1388, 1390, 1392, 1395, 1398, 1401, 1404,
+  1406, 1408, 1410, 1412, 1414, 1416, 1418, 1420,
+  1422, 1424, 1426, 1428, 1430, 1432, 1434, 1436,
+  1438, 1440, 1442, 1443, 1444, 1450, 1452, 1453,
+  1455, 1457, 1458, 1460, 1462, 1465, 1467, 1470,
+  1472, 1474, 1475, 1477, 1480, 1482, 1486, 1490,
+  1499, 1505, 1509, 1513, 1517, 1521, 1524, 1528,
+  1529, 1530, 1531, 1532, 1536, 1537, 1540, 1543,
+  1546, 1549, 1550, 1552, 1554, 1556, 1558, 1560,
+  1562, 1564, 1567, 1570, 1573, 1576, 1579, 1582,
+  1585, 1588, 1591, 1594, 1597, 1600, 1603, 1606,
+  1609, 1612, 1614, 1616, 1618, 1620, 1622, 1624,
+  1626, 1628, 1630, 1632, 1634, 1636, 1638, 1640,
+  1642, 1644, 1646, 1648, 1651, 1654, 1660, 1663,
+  1668, 1673, 1675, 1678, 1683, 1686, 1689, 1692,
+  1695, 1698, 1701, 1704, 1706, 1709, 1711, 1712,
+  1715, 1717, 1719, 1721, 1724, 1726, 1727, 1729,
+  1732, 1734, 1736, 1738, 1740, 1741, 1742, 1746,
+  1748, 1751, 1754, 1757, 1760, 1763, 1766, 1768,
+  1770, 1772, 1774, 1776, 1778, 1781, 1784, 1786,
+  1788, 1790, 1791, 1792, 1795, 1797, 1798, 1799,
+  1800, 1801, 1802, 1803, 1805, 1807, 1808, 1809,
+  1810, 1811, 1814, 1817, 1820, 1823, 1826, 1829,
+  1832, 1835, 1838, 1842, 1846, 1850, 1853, 1856,
+  1859, 1863, 1867, 1871, 1874, 1876, 1878, 1882,
+  1886, 1888, 1890, 1894, 1896, 1898, 1900, 1903,
+  1907, 1909, 1911, 1917, 1920, 1923, 1925, 1931,
+  1934, 1937, 1940, 1942, 1944, 1947, 1950, 1952,
+  1954, 1957, 1960, 1963, 1965, 1967, 1969, 1971,
+  1973, 1975, 1977, 1979, 1981, 1983, 1986, 1988,
+  1990, 1993, 1995, 1998, 2000, 2002, 2006, 2010,
+  2012, 2014, 2018, 2019, 2020, 2021, 2022, 2023,
+  2024, 2025, 2026, 2028, 2030, 2032, 2034, 2036,
+  2038, 2040, 2042, 2044, 2046, 2048, 2050, 2052,
+  2054, 2056, 2058, 2060, 2062, 2064, 2066, 2068,
+  2070, 2072, 2074, 2076, 2078, 2080, 2082, 2084,
+  2086, 2088, 2090, 2092, 2094, 2096, 2098, 2100,
+  2102, 2103, 2104, 2106, 2108, 2110, 2112, 2114,
+  2116, 2118, 2120, 2121, 2122, 2123, 2124, 2125,
+  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, 2488, 2490, 2492, 2494,
+  2496, 2498, 2500, 2502, 2504, 2506, 2508, 2510,
+  2515, 2517, 2522, 2524, 2526, 2531, 2533, 2535,
+  2537, 2542, 2544, 2546, 2548, 2552, 2558, 2560,
+  2565, 2567, 2569, 2571, 2573, 2575, 2576, 2577,
+  2578, 2580, 2581, 2582, 2583, 2584, 2585, 2587,
+  2588, 2589, 2590, 2592, 2594, 2596, 2598, 2602,
+  2606, 2607, 2608, 2610, 2614, 2618, 2620, 2624,
+  2628, 2629, 2630, 2632, 2634, 2636, 2638, 2643,
+  2647, 2651, 2653, 2655, 2657, 2659, 2661, 2663,
+  2665, 2667, 2669, 2671, 2673, 2675, 2677, 2679,
+  2681, 2683, 2685, 2687, 2689, 2691, 2693, 2694,
+  2695, 2697, 2699, 2700, 2701, 2704, 2707, 2710,
+  2713, 2715, 2717, 2719, 2721, 2723, 2725, 2726,
+  2727, 2728, 2730, 2734, 2736, 2738, 2744, 2748,
+  2749, 2750, 2751, 2752, 2753, 2754, 2755, 2759,
+  2761, 2763, 2767, 2769, 2771, 2773, 2775, 2777,
+  2779, 2781, 2783, 2785, 2787, 2789, 2791, 2793,
+  2795, 2796, 2799, 2802, 2805, 2808, 2813, 2818,
+  2823, 2828, 2831, 2834, 2837, 2840, 2842, 2844,
+  2846, 2848, 2850, 2852, 2854, 2855, 2857, 2859,
+  2861, 2863, 2865, 2866, 2867, 2868, 2872, 2876,
+  2878, 2882, 2886, 2890, 2894, 2898, 2900, 2904,
+  2906, 2908, 2910, 2912, 2914, 2916, 2918, 2920,
+  2921, 2923, 2925, 2927, 2929, 2931, 2933, 2935,
+  2937, 2938, 2939, 2940, 2941, 2942, 2943, 2944,
+  2945, 2946, 2948, 2950, 2952, 2954, 2956, 2958,
+  2959, 2960, 2961, 2963, 2965, 2967, 2969, 2971,
+  2973, 2974, 2975, 2976, 2977, 2980, 2983, 2985,
+  2988, 2989, 2990, 2992, 2993, 2995, 2996, 2997,
+  2999, 3001, 3002, 3003, 3004, 3005, 3006, 3009,
+  3014, 3019, 3024, 3029, 3032, 3037, 3042, 3044,
+  3046, 3048, 3050, 3051, 3052, 3054, 3056, 3058,
+  3060, 3062, 3064, 3066, 3067, 3068, 3069, 3070,
+  3071, 3072, 3077, 3082, 3083, 3084, 3085, 3086,
+  3087, 3088, 3089, 3090, 3091, 3092, 3093, 3094,
+  3095, 3096, 3097, 3098, 3099, 3100, 3101, 3102,
+  3103, 3104, 3105, 3106, 3107, 3108, 3109, 3110,
+  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, 3285, 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, 3317, 3319, 3321, 3323, 3324,
+  3325, 3326, 3327, 3328, 3329, 3330, 3331, 3332,
+  3333, 3334, 3335, 3336, 3338, 3339, 3340, 3341,
+  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, 3386, 3388, 3389, 3390, 3392, 3393,
+  3395, 3397, 3398, 3399, 3401, 3403, 3405, 3407,
+  3408, 3409, 3410, 3411, 3412, 3413, 3414, 3415,
+  3416, 3417, 3418, 3419, 3420, 3421, 3422, 3423,
+  3424, 3425, 3426, 3427, 3428, 3429, 3430, 3431,
+  3434, 3437, 3438, 3439, 3440, 3441, 3442, 3443,
+  3445, 3447, 3449, 3450, 3451, 3452, 3453, 3454,
+  3455, 3457, 3458, 3459, 3460, 3461, 3462, 3463,
+  3464, 3465, 3467, 3469, 3470, 3471, 3472, 3473,
+  3474, 3475, 3476, 3477, 3478, 3479, 3482, 3485,
+  3486, 3487, 3488, 3489, 3490, 3491, 3492, 3493,
+  3494, 3495, 3496, 3497, 3498, 3499, 3500, 3501,
+  3502, 3503, 3504, 3505, 3506, 3507, 3508, 3509,
+  3510, 3511, 3512, 3513, 3514, 3515, 3516, 3517,
+  3518, 3519, 3520, 3521, 3522, 3523, 3524, 3525,
+  3526, 3527, 3528, 3529, 3530, 3531, 3532, 3533,
+  3534, 3535, 3536, 3537, 3538, 3539, 3540, 3541,
+  3542, 3543, 3546, 3548, 3551, 3554, 3556, 3559,
+  3562, 3565, 3568, 3569, 3572, 3573, 3574, 3575,
+  3576, 3577, 3581, 3583, 3586, 3587, 3588, 3589,
+  3590, 3591, 3592, 3593, 3594, 3595, 3596, 3597,
+  3598, 3599, 3600, 3601, 3602, 3603, 3604, 3605,
+  3606, 3607, 3608, 3609, 3610, 3611, 3612, 3613,
+  3614, 3615, 3616, 3617, 3618, 3619, 3620, 3621,
+  3622, 3623, 3624, 3625, 3626, 3627, 3628, 3629,
+  3630, 3631, 3632, 3633, 3634, 3635, 3636, 3637,
+  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,
+  3681, 3684, 3687, 3690, 3693, 3696, 3699, 3702,
+  3705, 3708, 3711, 3714, 3717, 3720, 3723, 3724,
+  3725, 3726, 3727, 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, 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, 3793, 3796, 3797, 3798, 3799, 3800, 3801,
+  3802, 3803, 3804, 3805, 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, 3861, 3864, 3867, 3868, 3869, 3870, 3871,
+  3872, 3873, 3874, 3875, 3876, 3877, 3878, 3879,
+  3880, 3881, 3882, 3883, 3886, 3889, 3890, 3891,
+  3894, 3895, 3896, 3897, 3898, 3901, 3904, 3907,
+  3908, 3909, 3910, 3911, 3912, 3913, 3914, 3915,
+  3916, 3917, 3919, 3920, 3921, 3922, 3924, 3925,
+  3926, 3927, 3928, 3929, 3930, 3931, 3932, 3933,
+  3934, 3935, 3936, 3937, 3938, 3939, 3940, 3941,
+  3942, 3943, 3944, 3945, 3946, 3948, 3950, 3951,
+  3952, 3953, 3954, 3955, 3956, 3957, 3958, 3959,
+  3960, 3961, 3962, 3963, 3964, 3965, 3966, 3967,
+  3968, 3969, 3970, 3971, 3972, 3973, 3974, 3975,
+  3977, 3979, 3981, 3983, 3985, 3987, 3989, 3991,
+  3993, 3995, 3997, 3999, 4001, 4003, 4005, 4007,
+  4008, 4009, 4010, 4012, 4013, 4015, 4018, 4020,
+  4021, 4022, 4024, 4026, 4027, 4028, 4029, 4030,
+  4031, 4032, 4034, 4036, 4038, 4040, 4041, 4042,
+  4043, 4044, 4045, 4046, 4047, 4048, 4049, 4051,
+  4053, 4054, 4056, 4058, 4059, 4064, 4066, 4068,
+  4069, 4070, 4071, 4072, 4073, 4074, 4075, 4077,
+  4079, 4080, 4081, 4082, 4084, 4087, 4091, 4094,
+  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, 4141, 4143, 4145, 4147,
+  4149, 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,
+  4246, 4247, 4248, 4249, 4250, 4251, 4252, 4253,
+  4254, 4255, 4256, 4257, 4258, 4259, 4260, 4261,
+  4262, 4263, 4264, 4265, 4266, 4267, 4268, 4269,
+  4270, 4271, 4272, 4273, 4274, 4277, 4278, 4279,
+  4282, 4283, 4284, 4286, 4287, 4288, 4289, 4291,
+  4292, 4293, 4294, 4296, 4297, 4298, 4299, 4302,
+  4303, 4304, 4305, 4306, 4309, 4312, 4315, 4318,
+  4321, 4322, 4323, 4324, 4325, 4327, 4329, 4330,
+  4331, 4332, 4335, 4338, 4341, 4344, 4347, 4348,
+  4349, 4350, 4352, 4353, 4354, 4355, 4358, 4359,
+  4360, 4361, 4362, 4363, 4364, 4365, 4366, 4367,
+  4368, 4369, 4370, 4371, 4372, 4373, 4374, 4375,
+  4376, 4377, 4378, 4379, 4380, 4381, 4382, 4383,
+  4384, 4385, 4386, 4387, 4388, 4389, 4390, 4391,
+  4392, 4393, 4394, 4396, 4397, 4398, 4400, 4402,
+  4404, 4406, 4408, 4409, 4410, 4413, 4416, 4417,
+  4418, 4419, 4420, 4421, 4422, 4424, 4426, 4428,
+  4430, 4431, 4432, 4433, 4434, 4437, 4438, 4439,
+  4442, 4443, 4444, 4447, 4448, 4449, 4452, 4453,
+  4454, 4457, 4458, 4459, 4460, 4461, 4462, 4463,
+  4464, 4465, 4466, 4467, 4468, 4469, 4470, 4471,
+  4472, 4473, 4474, 4475, 4476, 4477, 4478, 4479,
+  4480, 4481, 4482, 4483, 4484, 4485, 4486, 4487,
+  4488, 4489, 4490, 4491, 4492, 4493, 4494, 4495,
+  4496, 4497, 4498, 4499, 4500, 4501, 4504, 4505,
+  4506, 4509, 4510, 4511, 4512, 4513, 4514, 4515,
+  4518, 4521, 4522, 4523, 4524, 4525, 4526, 4527,
+  4528, 4529, 4530, 4531, 4532, 4533, 4534, 4535,
+  4536, 4537, 4538, 4539, 4541, 4542, 4543, 4544,
+  4545
 };
 
 /* i386 mnemonics table.  */