1 /* TILEPro opcode information.
2
3 Copyright (C) 2011-2021 Free Software Foundation, Inc.
4
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 3 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program; if not, write to the Free Software
17 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
18 MA 02110-1301, USA. */
19
20 #include "sysdep.h"
21
22 /* This define is BFD_RELOC_##x for real bfd, or -1 for everyone else. */
23 #define BFD_RELOC(x) BFD_RELOC_##x
24 #include "bfd.h"
25
26 /* Special registers. */
27 #define TREG_LR 55
28 #define TREG_SN 56
29 #define TREG_ZERO 63
30
31 #if defined(__KERNEL__) || defined(_LIBC)
32 /* FIXME: Rename this. */
33 #include <asm/opcode-tile.h>
34 #define DISASM_ONLY
35 #else
36 #include "opcode/tilepro.h"
37 #endif
38
39 #ifdef __KERNEL__
40 #include <linux/stddef.h>
41 #else
42 #include <stddef.h>
43 #endif
44
45 const struct tilepro_opcode tilepro_opcodes[397] =
46 {
47 { "bpt", TILEPRO_OPC_BPT, 0x2, 0, TREG_ZERO, 0,
48 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
49 #ifndef DISASM_ONLY
50 {
51 0ULL,
52 0xfbffffff80000000ULL,
53 0ULL,
54 0ULL,
55 0ULL
56 },
57 {
58 -1ULL,
59 0x400b3cae00000000ULL,
60 -1ULL,
61 -1ULL,
62 -1ULL
63 }
64 #endif
65 },
66 { "info", TILEPRO_OPC_INFO, 0xf, 1, TREG_ZERO, 1,
67 { { 0 }, { 1 }, { 2 }, { 3 }, { 0, } },
68 #ifndef DISASM_ONLY
69 {
70 0x800000007ff00fffULL,
71 0xfff807ff80000000ULL,
72 0x8000000078000fffULL,
73 0xf80007ff80000000ULL,
74 0ULL
75 },
76 {
77 0x0000000050100fffULL,
78 0x302007ff80000000ULL,
79 0x8000000050000fffULL,
80 0xc00007ff80000000ULL,
81 -1ULL
82 }
83 #endif
84 },
85 { "infol", TILEPRO_OPC_INFOL, 0x3, 1, TREG_ZERO, 1,
86 { { 4 }, { 5 }, { 0, }, { 0, }, { 0, } },
87 #ifndef DISASM_ONLY
88 {
89 0x8000000070000fffULL,
90 0xf80007ff80000000ULL,
91 0ULL,
92 0ULL,
93 0ULL
94 },
95 {
96 0x0000000030000fffULL,
97 0x200007ff80000000ULL,
98 -1ULL,
99 -1ULL,
100 -1ULL
101 }
102 #endif
103 },
104 { "j", TILEPRO_OPC_J, 0x2, 1, TREG_ZERO, 1,
105 { { 0, }, { 6 }, { 0, }, { 0, }, { 0, } },
106 #ifndef DISASM_ONLY
107 {
108 0ULL,
109 0xf000000000000000ULL,
110 0ULL,
111 0ULL,
112 0ULL
113 },
114 {
115 -1ULL,
116 0x5000000000000000ULL,
117 -1ULL,
118 -1ULL,
119 -1ULL
120 }
121 #endif
122 },
123 { "jal", TILEPRO_OPC_JAL, 0x2, 1, TREG_LR, 1,
124 { { 0, }, { 6 }, { 0, }, { 0, }, { 0, } },
125 #ifndef DISASM_ONLY
126 {
127 0ULL,
128 0xf000000000000000ULL,
129 0ULL,
130 0ULL,
131 0ULL
132 },
133 {
134 -1ULL,
135 0x6000000000000000ULL,
136 -1ULL,
137 -1ULL,
138 -1ULL
139 }
140 #endif
141 },
142 { "lw_tls", TILEPRO_OPC_LW_TLS, 0x2, 3, TREG_ZERO, 1,
143 { { 0, }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
144 #ifndef DISASM_ONLY
145 {
146 0ULL,
147 0xfffff80000000000ULL,
148 0ULL,
149 0ULL,
150 0ULL
151 },
152 {
153 -1ULL,
154 0x30d0000000000000ULL,
155 -1ULL,
156 -1ULL,
157 -1ULL
158 }
159 #endif
160 },
161 { "lw_tls.sn", TILEPRO_OPC_LW_TLS_SN, 0x2, 3, TREG_SN, 1,
162 { { 0, }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
163 #ifndef DISASM_ONLY
164 {
165 0ULL,
166 0xfffff80000000000ULL,
167 0ULL,
168 0ULL,
169 0ULL
170 },
171 {
172 -1ULL,
173 0x34d0000000000000ULL,
174 -1ULL,
175 -1ULL,
176 -1ULL
177 }
178 #endif
179 },
180 { "move", TILEPRO_OPC_MOVE, 0xf, 2, TREG_ZERO, 1,
181 { { 9, 10 }, { 7, 8 }, { 11, 12 }, { 13, 14 }, { 0, } },
182 #ifndef DISASM_ONLY
183 {
184 0x800000007ffff000ULL,
185 0xfffff80000000000ULL,
186 0x80000000780ff000ULL,
187 0xf807f80000000000ULL,
188 0ULL
189 },
190 {
191 0x0000000000cff000ULL,
192 0x0833f80000000000ULL,
193 0x80000000180bf000ULL,
194 0x9805f80000000000ULL,
195 -1ULL
196 }
197 #endif
198 },
199 { "move.sn", TILEPRO_OPC_MOVE_SN, 0x3, 2, TREG_SN, 1,
200 { { 9, 10 }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
201 #ifndef DISASM_ONLY
202 {
203 0x800000007ffff000ULL,
204 0xfffff80000000000ULL,
205 0ULL,
206 0ULL,
207 0ULL
208 },
209 {
210 0x0000000008cff000ULL,
211 0x0c33f80000000000ULL,
212 -1ULL,
213 -1ULL,
214 -1ULL
215 }
216 #endif
217 },
218 { "movei", TILEPRO_OPC_MOVEI, 0xf, 2, TREG_ZERO, 1,
219 { { 9, 0 }, { 7, 1 }, { 11, 2 }, { 13, 3 }, { 0, } },
220 #ifndef DISASM_ONLY
221 {
222 0x800000007ff00fc0ULL,
223 0xfff807e000000000ULL,
224 0x8000000078000fc0ULL,
225 0xf80007e000000000ULL,
226 0ULL
227 },
228 {
229 0x0000000040800fc0ULL,
230 0x305807e000000000ULL,
231 0x8000000058000fc0ULL,
232 0xc80007e000000000ULL,
233 -1ULL
234 }
235 #endif
236 },
237 { "movei.sn", TILEPRO_OPC_MOVEI_SN, 0x3, 2, TREG_SN, 1,
238 { { 9, 0 }, { 7, 1 }, { 0, }, { 0, }, { 0, } },
239 #ifndef DISASM_ONLY
240 {
241 0x800000007ff00fc0ULL,
242 0xfff807e000000000ULL,
243 0ULL,
244 0ULL,
245 0ULL
246 },
247 {
248 0x0000000048800fc0ULL,
249 0x345807e000000000ULL,
250 -1ULL,
251 -1ULL,
252 -1ULL
253 }
254 #endif
255 },
256 { "moveli", TILEPRO_OPC_MOVELI, 0x3, 2, TREG_ZERO, 1,
257 { { 9, 4 }, { 7, 5 }, { 0, }, { 0, }, { 0, } },
258 #ifndef DISASM_ONLY
259 {
260 0x8000000070000fc0ULL,
261 0xf80007e000000000ULL,
262 0ULL,
263 0ULL,
264 0ULL
265 },
266 {
267 0x0000000020000fc0ULL,
268 0x180007e000000000ULL,
269 -1ULL,
270 -1ULL,
271 -1ULL
272 }
273 #endif
274 },
275 { "moveli.sn", TILEPRO_OPC_MOVELI_SN, 0x3, 2, TREG_SN, 1,
276 { { 9, 4 }, { 7, 5 }, { 0, }, { 0, }, { 0, } },
277 #ifndef DISASM_ONLY
278 {
279 0x8000000070000fc0ULL,
280 0xf80007e000000000ULL,
281 0ULL,
282 0ULL,
283 0ULL
284 },
285 {
286 0x0000000010000fc0ULL,
287 0x100007e000000000ULL,
288 -1ULL,
289 -1ULL,
290 -1ULL
291 }
292 #endif
293 },
294 { "movelis", TILEPRO_OPC_MOVELIS, 0x3, 2, TREG_SN, 1,
295 { { 9, 4 }, { 7, 5 }, { 0, }, { 0, }, { 0, } },
296 #ifndef DISASM_ONLY
297 {
298 0x8000000070000fc0ULL,
299 0xf80007e000000000ULL,
300 0ULL,
301 0ULL,
302 0ULL
303 },
304 {
305 0x0000000010000fc0ULL,
306 0x100007e000000000ULL,
307 -1ULL,
308 -1ULL,
309 -1ULL
310 }
311 #endif
312 },
313 { "prefetch", TILEPRO_OPC_PREFETCH, 0x12, 1, TREG_ZERO, 1,
314 { { 0, }, { 8 }, { 0, }, { 0, }, { 15 } },
315 #ifndef DISASM_ONLY
316 {
317 0ULL,
318 0xfffff81f80000000ULL,
319 0ULL,
320 0ULL,
321 0x8700000003f00000ULL
322 },
323 {
324 -1ULL,
325 0x400b501f80000000ULL,
326 -1ULL,
327 -1ULL,
328 0x8000000003f00000ULL
329 }
330 #endif
331 },
332 { "raise", TILEPRO_OPC_RAISE, 0x2, 0, TREG_ZERO, 1,
333 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
334 #ifndef DISASM_ONLY
335 {
336 0ULL,
337 0xfbffffff80000000ULL,
338 0ULL,
339 0ULL,
340 0ULL
341 },
342 {
343 -1ULL,
344 0x400b3cae80000000ULL,
345 -1ULL,
346 -1ULL,
347 -1ULL
348 }
349 #endif
350 },
351 { "add", TILEPRO_OPC_ADD, 0xf, 3, TREG_ZERO, 1,
352 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
353 #ifndef DISASM_ONLY
354 {
355 0x800000007ffc0000ULL,
356 0xfffe000000000000ULL,
357 0x80000000780c0000ULL,
358 0xf806000000000000ULL,
359 0ULL
360 },
361 {
362 0x00000000000c0000ULL,
363 0x0806000000000000ULL,
364 0x8000000008000000ULL,
365 0x8800000000000000ULL,
366 -1ULL
367 }
368 #endif
369 },
370 { "add.sn", TILEPRO_OPC_ADD_SN, 0x3, 3, TREG_SN, 1,
371 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
372 #ifndef DISASM_ONLY
373 {
374 0x800000007ffc0000ULL,
375 0xfffe000000000000ULL,
376 0ULL,
377 0ULL,
378 0ULL
379 },
380 {
381 0x00000000080c0000ULL,
382 0x0c06000000000000ULL,
383 -1ULL,
384 -1ULL,
385 -1ULL
386 }
387 #endif
388 },
389 { "addb", TILEPRO_OPC_ADDB, 0x3, 3, TREG_ZERO, 1,
390 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
391 #ifndef DISASM_ONLY
392 {
393 0x800000007ffc0000ULL,
394 0xfffe000000000000ULL,
395 0ULL,
396 0ULL,
397 0ULL
398 },
399 {
400 0x0000000000040000ULL,
401 0x0802000000000000ULL,
402 -1ULL,
403 -1ULL,
404 -1ULL
405 }
406 #endif
407 },
408 { "addb.sn", TILEPRO_OPC_ADDB_SN, 0x3, 3, TREG_SN, 1,
409 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
410 #ifndef DISASM_ONLY
411 {
412 0x800000007ffc0000ULL,
413 0xfffe000000000000ULL,
414 0ULL,
415 0ULL,
416 0ULL
417 },
418 {
419 0x0000000008040000ULL,
420 0x0c02000000000000ULL,
421 -1ULL,
422 -1ULL,
423 -1ULL
424 }
425 #endif
426 },
427 { "addbs_u", TILEPRO_OPC_ADDBS_U, 0x3, 3, TREG_ZERO, 1,
428 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
429 #ifndef DISASM_ONLY
430 {
431 0x800000007ffc0000ULL,
432 0xfffe000000000000ULL,
433 0ULL,
434 0ULL,
435 0ULL
436 },
437 {
438 0x0000000001880000ULL,
439 0x0888000000000000ULL,
440 -1ULL,
441 -1ULL,
442 -1ULL
443 }
444 #endif
445 },
446 { "addbs_u.sn", TILEPRO_OPC_ADDBS_U_SN, 0x3, 3, TREG_SN, 1,
447 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
448 #ifndef DISASM_ONLY
449 {
450 0x800000007ffc0000ULL,
451 0xfffe000000000000ULL,
452 0ULL,
453 0ULL,
454 0ULL
455 },
456 {
457 0x0000000009880000ULL,
458 0x0c88000000000000ULL,
459 -1ULL,
460 -1ULL,
461 -1ULL
462 }
463 #endif
464 },
465 { "addh", TILEPRO_OPC_ADDH, 0x3, 3, TREG_ZERO, 1,
466 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
467 #ifndef DISASM_ONLY
468 {
469 0x800000007ffc0000ULL,
470 0xfffe000000000000ULL,
471 0ULL,
472 0ULL,
473 0ULL
474 },
475 {
476 0x0000000000080000ULL,
477 0x0804000000000000ULL,
478 -1ULL,
479 -1ULL,
480 -1ULL
481 }
482 #endif
483 },
484 { "addh.sn", TILEPRO_OPC_ADDH_SN, 0x3, 3, TREG_SN, 1,
485 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
486 #ifndef DISASM_ONLY
487 {
488 0x800000007ffc0000ULL,
489 0xfffe000000000000ULL,
490 0ULL,
491 0ULL,
492 0ULL
493 },
494 {
495 0x0000000008080000ULL,
496 0x0c04000000000000ULL,
497 -1ULL,
498 -1ULL,
499 -1ULL
500 }
501 #endif
502 },
503 { "addhs", TILEPRO_OPC_ADDHS, 0x3, 3, TREG_ZERO, 1,
504 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
505 #ifndef DISASM_ONLY
506 {
507 0x800000007ffc0000ULL,
508 0xfffe000000000000ULL,
509 0ULL,
510 0ULL,
511 0ULL
512 },
513 {
514 0x00000000018c0000ULL,
515 0x088a000000000000ULL,
516 -1ULL,
517 -1ULL,
518 -1ULL
519 }
520 #endif
521 },
522 { "addhs.sn", TILEPRO_OPC_ADDHS_SN, 0x3, 3, TREG_SN, 1,
523 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
524 #ifndef DISASM_ONLY
525 {
526 0x800000007ffc0000ULL,
527 0xfffe000000000000ULL,
528 0ULL,
529 0ULL,
530 0ULL
531 },
532 {
533 0x00000000098c0000ULL,
534 0x0c8a000000000000ULL,
535 -1ULL,
536 -1ULL,
537 -1ULL
538 }
539 #endif
540 },
541 { "addi", TILEPRO_OPC_ADDI, 0xf, 3, TREG_ZERO, 1,
542 { { 9, 10, 0 }, { 7, 8, 1 }, { 11, 12, 2 }, { 13, 14, 3 }, { 0, } },
543 #ifndef DISASM_ONLY
544 {
545 0x800000007ff00000ULL,
546 0xfff8000000000000ULL,
547 0x8000000078000000ULL,
548 0xf800000000000000ULL,
549 0ULL
550 },
551 {
552 0x0000000040300000ULL,
553 0x3018000000000000ULL,
554 0x8000000048000000ULL,
555 0xb800000000000000ULL,
556 -1ULL
557 }
558 #endif
559 },
560 { "addi.sn", TILEPRO_OPC_ADDI_SN, 0x3, 3, TREG_SN, 1,
561 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
562 #ifndef DISASM_ONLY
563 {
564 0x800000007ff00000ULL,
565 0xfff8000000000000ULL,
566 0ULL,
567 0ULL,
568 0ULL
569 },
570 {
571 0x0000000048300000ULL,
572 0x3418000000000000ULL,
573 -1ULL,
574 -1ULL,
575 -1ULL
576 }
577 #endif
578 },
579 { "addib", TILEPRO_OPC_ADDIB, 0x3, 3, TREG_ZERO, 1,
580 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
581 #ifndef DISASM_ONLY
582 {
583 0x800000007ff00000ULL,
584 0xfff8000000000000ULL,
585 0ULL,
586 0ULL,
587 0ULL
588 },
589 {
590 0x0000000040100000ULL,
591 0x3008000000000000ULL,
592 -1ULL,
593 -1ULL,
594 -1ULL
595 }
596 #endif
597 },
598 { "addib.sn", TILEPRO_OPC_ADDIB_SN, 0x3, 3, TREG_SN, 1,
599 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
600 #ifndef DISASM_ONLY
601 {
602 0x800000007ff00000ULL,
603 0xfff8000000000000ULL,
604 0ULL,
605 0ULL,
606 0ULL
607 },
608 {
609 0x0000000048100000ULL,
610 0x3408000000000000ULL,
611 -1ULL,
612 -1ULL,
613 -1ULL
614 }
615 #endif
616 },
617 { "addih", TILEPRO_OPC_ADDIH, 0x3, 3, TREG_ZERO, 1,
618 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
619 #ifndef DISASM_ONLY
620 {
621 0x800000007ff00000ULL,
622 0xfff8000000000000ULL,
623 0ULL,
624 0ULL,
625 0ULL
626 },
627 {
628 0x0000000040200000ULL,
629 0x3010000000000000ULL,
630 -1ULL,
631 -1ULL,
632 -1ULL
633 }
634 #endif
635 },
636 { "addih.sn", TILEPRO_OPC_ADDIH_SN, 0x3, 3, TREG_SN, 1,
637 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
638 #ifndef DISASM_ONLY
639 {
640 0x800000007ff00000ULL,
641 0xfff8000000000000ULL,
642 0ULL,
643 0ULL,
644 0ULL
645 },
646 {
647 0x0000000048200000ULL,
648 0x3410000000000000ULL,
649 -1ULL,
650 -1ULL,
651 -1ULL
652 }
653 #endif
654 },
655 { "addli", TILEPRO_OPC_ADDLI, 0x3, 3, TREG_ZERO, 1,
656 { { 9, 10, 4 }, { 7, 8, 5 }, { 0, }, { 0, }, { 0, } },
657 #ifndef DISASM_ONLY
658 {
659 0x8000000070000000ULL,
660 0xf800000000000000ULL,
661 0ULL,
662 0ULL,
663 0ULL
664 },
665 {
666 0x0000000020000000ULL,
667 0x1800000000000000ULL,
668 -1ULL,
669 -1ULL,
670 -1ULL
671 }
672 #endif
673 },
674 { "addli.sn", TILEPRO_OPC_ADDLI_SN, 0x3, 3, TREG_SN, 1,
675 { { 9, 10, 4 }, { 7, 8, 5 }, { 0, }, { 0, }, { 0, } },
676 #ifndef DISASM_ONLY
677 {
678 0x8000000070000000ULL,
679 0xf800000000000000ULL,
680 0ULL,
681 0ULL,
682 0ULL
683 },
684 {
685 0x0000000010000000ULL,
686 0x1000000000000000ULL,
687 -1ULL,
688 -1ULL,
689 -1ULL
690 }
691 #endif
692 },
693 { "addlis", TILEPRO_OPC_ADDLIS, 0x3, 3, TREG_SN, 1,
694 { { 9, 10, 4 }, { 7, 8, 5 }, { 0, }, { 0, }, { 0, } },
695 #ifndef DISASM_ONLY
696 {
697 0x8000000070000000ULL,
698 0xf800000000000000ULL,
699 0ULL,
700 0ULL,
701 0ULL
702 },
703 {
704 0x0000000010000000ULL,
705 0x1000000000000000ULL,
706 -1ULL,
707 -1ULL,
708 -1ULL
709 }
710 #endif
711 },
712 { "adds", TILEPRO_OPC_ADDS, 0x3, 3, TREG_ZERO, 1,
713 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
714 #ifndef DISASM_ONLY
715 {
716 0x800000007ffc0000ULL,
717 0xfffe000000000000ULL,
718 0ULL,
719 0ULL,
720 0ULL
721 },
722 {
723 0x0000000001800000ULL,
724 0x0884000000000000ULL,
725 -1ULL,
726 -1ULL,
727 -1ULL
728 }
729 #endif
730 },
731 { "adds.sn", TILEPRO_OPC_ADDS_SN, 0x3, 3, TREG_SN, 1,
732 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
733 #ifndef DISASM_ONLY
734 {
735 0x800000007ffc0000ULL,
736 0xfffe000000000000ULL,
737 0ULL,
738 0ULL,
739 0ULL
740 },
741 {
742 0x0000000009800000ULL,
743 0x0c84000000000000ULL,
744 -1ULL,
745 -1ULL,
746 -1ULL
747 }
748 #endif
749 },
750 { "adiffb_u", TILEPRO_OPC_ADIFFB_U, 0x1, 3, TREG_ZERO, 1,
751 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
752 #ifndef DISASM_ONLY
753 {
754 0x800000007ffc0000ULL,
755 0ULL,
756 0ULL,
757 0ULL,
758 0ULL
759 },
760 {
761 0x0000000000100000ULL,
762 -1ULL,
763 -1ULL,
764 -1ULL,
765 -1ULL
766 }
767 #endif
768 },
769 { "adiffb_u.sn", TILEPRO_OPC_ADIFFB_U_SN, 0x1, 3, TREG_SN, 1,
770 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
771 #ifndef DISASM_ONLY
772 {
773 0x800000007ffc0000ULL,
774 0ULL,
775 0ULL,
776 0ULL,
777 0ULL
778 },
779 {
780 0x0000000008100000ULL,
781 -1ULL,
782 -1ULL,
783 -1ULL,
784 -1ULL
785 }
786 #endif
787 },
788 { "adiffh", TILEPRO_OPC_ADIFFH, 0x1, 3, TREG_ZERO, 1,
789 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
790 #ifndef DISASM_ONLY
791 {
792 0x800000007ffc0000ULL,
793 0ULL,
794 0ULL,
795 0ULL,
796 0ULL
797 },
798 {
799 0x0000000000140000ULL,
800 -1ULL,
801 -1ULL,
802 -1ULL,
803 -1ULL
804 }
805 #endif
806 },
807 { "adiffh.sn", TILEPRO_OPC_ADIFFH_SN, 0x1, 3, TREG_SN, 1,
808 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
809 #ifndef DISASM_ONLY
810 {
811 0x800000007ffc0000ULL,
812 0ULL,
813 0ULL,
814 0ULL,
815 0ULL
816 },
817 {
818 0x0000000008140000ULL,
819 -1ULL,
820 -1ULL,
821 -1ULL,
822 -1ULL
823 }
824 #endif
825 },
826 { "and", TILEPRO_OPC_AND, 0xf, 3, TREG_ZERO, 1,
827 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
828 #ifndef DISASM_ONLY
829 {
830 0x800000007ffc0000ULL,
831 0xfffe000000000000ULL,
832 0x80000000780c0000ULL,
833 0xf806000000000000ULL,
834 0ULL
835 },
836 {
837 0x0000000000180000ULL,
838 0x0808000000000000ULL,
839 0x8000000018000000ULL,
840 0x9800000000000000ULL,
841 -1ULL
842 }
843 #endif
844 },
845 { "and.sn", TILEPRO_OPC_AND_SN, 0x3, 3, TREG_SN, 1,
846 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
847 #ifndef DISASM_ONLY
848 {
849 0x800000007ffc0000ULL,
850 0xfffe000000000000ULL,
851 0ULL,
852 0ULL,
853 0ULL
854 },
855 {
856 0x0000000008180000ULL,
857 0x0c08000000000000ULL,
858 -1ULL,
859 -1ULL,
860 -1ULL
861 }
862 #endif
863 },
864 { "andi", TILEPRO_OPC_ANDI, 0xf, 3, TREG_ZERO, 1,
865 { { 9, 10, 0 }, { 7, 8, 1 }, { 11, 12, 2 }, { 13, 14, 3 }, { 0, } },
866 #ifndef DISASM_ONLY
867 {
868 0x800000007ff00000ULL,
869 0xfff8000000000000ULL,
870 0x8000000078000000ULL,
871 0xf800000000000000ULL,
872 0ULL
873 },
874 {
875 0x0000000050100000ULL,
876 0x3020000000000000ULL,
877 0x8000000050000000ULL,
878 0xc000000000000000ULL,
879 -1ULL
880 }
881 #endif
882 },
883 { "andi.sn", TILEPRO_OPC_ANDI_SN, 0x3, 3, TREG_SN, 1,
884 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
885 #ifndef DISASM_ONLY
886 {
887 0x800000007ff00000ULL,
888 0xfff8000000000000ULL,
889 0ULL,
890 0ULL,
891 0ULL
892 },
893 {
894 0x0000000058100000ULL,
895 0x3420000000000000ULL,
896 -1ULL,
897 -1ULL,
898 -1ULL
899 }
900 #endif
901 },
902 { "auli", TILEPRO_OPC_AULI, 0x3, 3, TREG_ZERO, 1,
903 { { 9, 10, 4 }, { 7, 8, 5 }, { 0, }, { 0, }, { 0, } },
904 #ifndef DISASM_ONLY
905 {
906 0x8000000070000000ULL,
907 0xf800000000000000ULL,
908 0ULL,
909 0ULL,
910 0ULL
911 },
912 {
913 0x0000000030000000ULL,
914 0x2000000000000000ULL,
915 -1ULL,
916 -1ULL,
917 -1ULL
918 }
919 #endif
920 },
921 { "avgb_u", TILEPRO_OPC_AVGB_U, 0x1, 3, TREG_ZERO, 1,
922 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
923 #ifndef DISASM_ONLY
924 {
925 0x800000007ffc0000ULL,
926 0ULL,
927 0ULL,
928 0ULL,
929 0ULL
930 },
931 {
932 0x00000000001c0000ULL,
933 -1ULL,
934 -1ULL,
935 -1ULL,
936 -1ULL
937 }
938 #endif
939 },
940 { "avgb_u.sn", TILEPRO_OPC_AVGB_U_SN, 0x1, 3, TREG_SN, 1,
941 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
942 #ifndef DISASM_ONLY
943 {
944 0x800000007ffc0000ULL,
945 0ULL,
946 0ULL,
947 0ULL,
948 0ULL
949 },
950 {
951 0x00000000081c0000ULL,
952 -1ULL,
953 -1ULL,
954 -1ULL,
955 -1ULL
956 }
957 #endif
958 },
959 { "avgh", TILEPRO_OPC_AVGH, 0x1, 3, TREG_ZERO, 1,
960 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
961 #ifndef DISASM_ONLY
962 {
963 0x800000007ffc0000ULL,
964 0ULL,
965 0ULL,
966 0ULL,
967 0ULL
968 },
969 {
970 0x0000000000200000ULL,
971 -1ULL,
972 -1ULL,
973 -1ULL,
974 -1ULL
975 }
976 #endif
977 },
978 { "avgh.sn", TILEPRO_OPC_AVGH_SN, 0x1, 3, TREG_SN, 1,
979 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
980 #ifndef DISASM_ONLY
981 {
982 0x800000007ffc0000ULL,
983 0ULL,
984 0ULL,
985 0ULL,
986 0ULL
987 },
988 {
989 0x0000000008200000ULL,
990 -1ULL,
991 -1ULL,
992 -1ULL,
993 -1ULL
994 }
995 #endif
996 },
997 { "bbns", TILEPRO_OPC_BBNS, 0x2, 2, TREG_ZERO, 1,
998 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
999 #ifndef DISASM_ONLY
1000 {
1001 0ULL,
1002 0xfc00000780000000ULL,
1003 0ULL,
1004 0ULL,
1005 0ULL
1006 },
1007 {
1008 -1ULL,
1009 0x2800000700000000ULL,
1010 -1ULL,
1011 -1ULL,
1012 -1ULL
1013 }
1014 #endif
1015 },
1016 { "bbns.sn", TILEPRO_OPC_BBNS_SN, 0x2, 2, TREG_SN, 1,
1017 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1018 #ifndef DISASM_ONLY
1019 {
1020 0ULL,
1021 0xfc00000780000000ULL,
1022 0ULL,
1023 0ULL,
1024 0ULL
1025 },
1026 {
1027 -1ULL,
1028 0x2c00000700000000ULL,
1029 -1ULL,
1030 -1ULL,
1031 -1ULL
1032 }
1033 #endif
1034 },
1035 { "bbnst", TILEPRO_OPC_BBNST, 0x2, 2, TREG_ZERO, 1,
1036 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1037 #ifndef DISASM_ONLY
1038 {
1039 0ULL,
1040 0xfc00000780000000ULL,
1041 0ULL,
1042 0ULL,
1043 0ULL
1044 },
1045 {
1046 -1ULL,
1047 0x2800000780000000ULL,
1048 -1ULL,
1049 -1ULL,
1050 -1ULL
1051 }
1052 #endif
1053 },
1054 { "bbnst.sn", TILEPRO_OPC_BBNST_SN, 0x2, 2, TREG_SN, 1,
1055 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1056 #ifndef DISASM_ONLY
1057 {
1058 0ULL,
1059 0xfc00000780000000ULL,
1060 0ULL,
1061 0ULL,
1062 0ULL
1063 },
1064 {
1065 -1ULL,
1066 0x2c00000780000000ULL,
1067 -1ULL,
1068 -1ULL,
1069 -1ULL
1070 }
1071 #endif
1072 },
1073 { "bbs", TILEPRO_OPC_BBS, 0x2, 2, TREG_ZERO, 1,
1074 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1075 #ifndef DISASM_ONLY
1076 {
1077 0ULL,
1078 0xfc00000780000000ULL,
1079 0ULL,
1080 0ULL,
1081 0ULL
1082 },
1083 {
1084 -1ULL,
1085 0x2800000600000000ULL,
1086 -1ULL,
1087 -1ULL,
1088 -1ULL
1089 }
1090 #endif
1091 },
1092 { "bbs.sn", TILEPRO_OPC_BBS_SN, 0x2, 2, TREG_SN, 1,
1093 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1094 #ifndef DISASM_ONLY
1095 {
1096 0ULL,
1097 0xfc00000780000000ULL,
1098 0ULL,
1099 0ULL,
1100 0ULL
1101 },
1102 {
1103 -1ULL,
1104 0x2c00000600000000ULL,
1105 -1ULL,
1106 -1ULL,
1107 -1ULL
1108 }
1109 #endif
1110 },
1111 { "bbst", TILEPRO_OPC_BBST, 0x2, 2, TREG_ZERO, 1,
1112 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1113 #ifndef DISASM_ONLY
1114 {
1115 0ULL,
1116 0xfc00000780000000ULL,
1117 0ULL,
1118 0ULL,
1119 0ULL
1120 },
1121 {
1122 -1ULL,
1123 0x2800000680000000ULL,
1124 -1ULL,
1125 -1ULL,
1126 -1ULL
1127 }
1128 #endif
1129 },
1130 { "bbst.sn", TILEPRO_OPC_BBST_SN, 0x2, 2, TREG_SN, 1,
1131 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1132 #ifndef DISASM_ONLY
1133 {
1134 0ULL,
1135 0xfc00000780000000ULL,
1136 0ULL,
1137 0ULL,
1138 0ULL
1139 },
1140 {
1141 -1ULL,
1142 0x2c00000680000000ULL,
1143 -1ULL,
1144 -1ULL,
1145 -1ULL
1146 }
1147 #endif
1148 },
1149 { "bgez", TILEPRO_OPC_BGEZ, 0x2, 2, TREG_ZERO, 1,
1150 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1151 #ifndef DISASM_ONLY
1152 {
1153 0ULL,
1154 0xfc00000780000000ULL,
1155 0ULL,
1156 0ULL,
1157 0ULL
1158 },
1159 {
1160 -1ULL,
1161 0x2800000300000000ULL,
1162 -1ULL,
1163 -1ULL,
1164 -1ULL
1165 }
1166 #endif
1167 },
1168 { "bgez.sn", TILEPRO_OPC_BGEZ_SN, 0x2, 2, TREG_SN, 1,
1169 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1170 #ifndef DISASM_ONLY
1171 {
1172 0ULL,
1173 0xfc00000780000000ULL,
1174 0ULL,
1175 0ULL,
1176 0ULL
1177 },
1178 {
1179 -1ULL,
1180 0x2c00000300000000ULL,
1181 -1ULL,
1182 -1ULL,
1183 -1ULL
1184 }
1185 #endif
1186 },
1187 { "bgezt", TILEPRO_OPC_BGEZT, 0x2, 2, TREG_ZERO, 1,
1188 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1189 #ifndef DISASM_ONLY
1190 {
1191 0ULL,
1192 0xfc00000780000000ULL,
1193 0ULL,
1194 0ULL,
1195 0ULL
1196 },
1197 {
1198 -1ULL,
1199 0x2800000380000000ULL,
1200 -1ULL,
1201 -1ULL,
1202 -1ULL
1203 }
1204 #endif
1205 },
1206 { "bgezt.sn", TILEPRO_OPC_BGEZT_SN, 0x2, 2, TREG_SN, 1,
1207 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1208 #ifndef DISASM_ONLY
1209 {
1210 0ULL,
1211 0xfc00000780000000ULL,
1212 0ULL,
1213 0ULL,
1214 0ULL
1215 },
1216 {
1217 -1ULL,
1218 0x2c00000380000000ULL,
1219 -1ULL,
1220 -1ULL,
1221 -1ULL
1222 }
1223 #endif
1224 },
1225 { "bgz", TILEPRO_OPC_BGZ, 0x2, 2, TREG_ZERO, 1,
1226 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1227 #ifndef DISASM_ONLY
1228 {
1229 0ULL,
1230 0xfc00000780000000ULL,
1231 0ULL,
1232 0ULL,
1233 0ULL
1234 },
1235 {
1236 -1ULL,
1237 0x2800000200000000ULL,
1238 -1ULL,
1239 -1ULL,
1240 -1ULL
1241 }
1242 #endif
1243 },
1244 { "bgz.sn", TILEPRO_OPC_BGZ_SN, 0x2, 2, TREG_SN, 1,
1245 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1246 #ifndef DISASM_ONLY
1247 {
1248 0ULL,
1249 0xfc00000780000000ULL,
1250 0ULL,
1251 0ULL,
1252 0ULL
1253 },
1254 {
1255 -1ULL,
1256 0x2c00000200000000ULL,
1257 -1ULL,
1258 -1ULL,
1259 -1ULL
1260 }
1261 #endif
1262 },
1263 { "bgzt", TILEPRO_OPC_BGZT, 0x2, 2, TREG_ZERO, 1,
1264 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1265 #ifndef DISASM_ONLY
1266 {
1267 0ULL,
1268 0xfc00000780000000ULL,
1269 0ULL,
1270 0ULL,
1271 0ULL
1272 },
1273 {
1274 -1ULL,
1275 0x2800000280000000ULL,
1276 -1ULL,
1277 -1ULL,
1278 -1ULL
1279 }
1280 #endif
1281 },
1282 { "bgzt.sn", TILEPRO_OPC_BGZT_SN, 0x2, 2, TREG_SN, 1,
1283 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1284 #ifndef DISASM_ONLY
1285 {
1286 0ULL,
1287 0xfc00000780000000ULL,
1288 0ULL,
1289 0ULL,
1290 0ULL
1291 },
1292 {
1293 -1ULL,
1294 0x2c00000280000000ULL,
1295 -1ULL,
1296 -1ULL,
1297 -1ULL
1298 }
1299 #endif
1300 },
1301 { "bitx", TILEPRO_OPC_BITX, 0x5, 2, TREG_ZERO, 1,
1302 { { 9, 10 }, { 0, }, { 11, 12 }, { 0, }, { 0, } },
1303 #ifndef DISASM_ONLY
1304 {
1305 0x800000007ffff000ULL,
1306 0ULL,
1307 0x80000000780ff000ULL,
1308 0ULL,
1309 0ULL
1310 },
1311 {
1312 0x0000000070161000ULL,
1313 -1ULL,
1314 0x80000000680a1000ULL,
1315 -1ULL,
1316 -1ULL
1317 }
1318 #endif
1319 },
1320 { "bitx.sn", TILEPRO_OPC_BITX_SN, 0x1, 2, TREG_SN, 1,
1321 { { 9, 10 }, { 0, }, { 0, }, { 0, }, { 0, } },
1322 #ifndef DISASM_ONLY
1323 {
1324 0x800000007ffff000ULL,
1325 0ULL,
1326 0ULL,
1327 0ULL,
1328 0ULL
1329 },
1330 {
1331 0x0000000078161000ULL,
1332 -1ULL,
1333 -1ULL,
1334 -1ULL,
1335 -1ULL
1336 }
1337 #endif
1338 },
1339 { "blez", TILEPRO_OPC_BLEZ, 0x2, 2, TREG_ZERO, 1,
1340 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1341 #ifndef DISASM_ONLY
1342 {
1343 0ULL,
1344 0xfc00000780000000ULL,
1345 0ULL,
1346 0ULL,
1347 0ULL
1348 },
1349 {
1350 -1ULL,
1351 0x2800000500000000ULL,
1352 -1ULL,
1353 -1ULL,
1354 -1ULL
1355 }
1356 #endif
1357 },
1358 { "blez.sn", TILEPRO_OPC_BLEZ_SN, 0x2, 2, TREG_SN, 1,
1359 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1360 #ifndef DISASM_ONLY
1361 {
1362 0ULL,
1363 0xfc00000780000000ULL,
1364 0ULL,
1365 0ULL,
1366 0ULL
1367 },
1368 {
1369 -1ULL,
1370 0x2c00000500000000ULL,
1371 -1ULL,
1372 -1ULL,
1373 -1ULL
1374 }
1375 #endif
1376 },
1377 { "blezt", TILEPRO_OPC_BLEZT, 0x2, 2, TREG_ZERO, 1,
1378 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1379 #ifndef DISASM_ONLY
1380 {
1381 0ULL,
1382 0xfc00000780000000ULL,
1383 0ULL,
1384 0ULL,
1385 0ULL
1386 },
1387 {
1388 -1ULL,
1389 0x2800000580000000ULL,
1390 -1ULL,
1391 -1ULL,
1392 -1ULL
1393 }
1394 #endif
1395 },
1396 { "blezt.sn", TILEPRO_OPC_BLEZT_SN, 0x2, 2, TREG_SN, 1,
1397 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1398 #ifndef DISASM_ONLY
1399 {
1400 0ULL,
1401 0xfc00000780000000ULL,
1402 0ULL,
1403 0ULL,
1404 0ULL
1405 },
1406 {
1407 -1ULL,
1408 0x2c00000580000000ULL,
1409 -1ULL,
1410 -1ULL,
1411 -1ULL
1412 }
1413 #endif
1414 },
1415 { "blz", TILEPRO_OPC_BLZ, 0x2, 2, TREG_ZERO, 1,
1416 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1417 #ifndef DISASM_ONLY
1418 {
1419 0ULL,
1420 0xfc00000780000000ULL,
1421 0ULL,
1422 0ULL,
1423 0ULL
1424 },
1425 {
1426 -1ULL,
1427 0x2800000400000000ULL,
1428 -1ULL,
1429 -1ULL,
1430 -1ULL
1431 }
1432 #endif
1433 },
1434 { "blz.sn", TILEPRO_OPC_BLZ_SN, 0x2, 2, TREG_SN, 1,
1435 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1436 #ifndef DISASM_ONLY
1437 {
1438 0ULL,
1439 0xfc00000780000000ULL,
1440 0ULL,
1441 0ULL,
1442 0ULL
1443 },
1444 {
1445 -1ULL,
1446 0x2c00000400000000ULL,
1447 -1ULL,
1448 -1ULL,
1449 -1ULL
1450 }
1451 #endif
1452 },
1453 { "blzt", TILEPRO_OPC_BLZT, 0x2, 2, TREG_ZERO, 1,
1454 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1455 #ifndef DISASM_ONLY
1456 {
1457 0ULL,
1458 0xfc00000780000000ULL,
1459 0ULL,
1460 0ULL,
1461 0ULL
1462 },
1463 {
1464 -1ULL,
1465 0x2800000480000000ULL,
1466 -1ULL,
1467 -1ULL,
1468 -1ULL
1469 }
1470 #endif
1471 },
1472 { "blzt.sn", TILEPRO_OPC_BLZT_SN, 0x2, 2, TREG_SN, 1,
1473 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1474 #ifndef DISASM_ONLY
1475 {
1476 0ULL,
1477 0xfc00000780000000ULL,
1478 0ULL,
1479 0ULL,
1480 0ULL
1481 },
1482 {
1483 -1ULL,
1484 0x2c00000480000000ULL,
1485 -1ULL,
1486 -1ULL,
1487 -1ULL
1488 }
1489 #endif
1490 },
1491 { "bnz", TILEPRO_OPC_BNZ, 0x2, 2, TREG_ZERO, 1,
1492 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1493 #ifndef DISASM_ONLY
1494 {
1495 0ULL,
1496 0xfc00000780000000ULL,
1497 0ULL,
1498 0ULL,
1499 0ULL
1500 },
1501 {
1502 -1ULL,
1503 0x2800000100000000ULL,
1504 -1ULL,
1505 -1ULL,
1506 -1ULL
1507 }
1508 #endif
1509 },
1510 { "bnz.sn", TILEPRO_OPC_BNZ_SN, 0x2, 2, TREG_SN, 1,
1511 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1512 #ifndef DISASM_ONLY
1513 {
1514 0ULL,
1515 0xfc00000780000000ULL,
1516 0ULL,
1517 0ULL,
1518 0ULL
1519 },
1520 {
1521 -1ULL,
1522 0x2c00000100000000ULL,
1523 -1ULL,
1524 -1ULL,
1525 -1ULL
1526 }
1527 #endif
1528 },
1529 { "bnzt", TILEPRO_OPC_BNZT, 0x2, 2, TREG_ZERO, 1,
1530 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1531 #ifndef DISASM_ONLY
1532 {
1533 0ULL,
1534 0xfc00000780000000ULL,
1535 0ULL,
1536 0ULL,
1537 0ULL
1538 },
1539 {
1540 -1ULL,
1541 0x2800000180000000ULL,
1542 -1ULL,
1543 -1ULL,
1544 -1ULL
1545 }
1546 #endif
1547 },
1548 { "bnzt.sn", TILEPRO_OPC_BNZT_SN, 0x2, 2, TREG_SN, 1,
1549 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1550 #ifndef DISASM_ONLY
1551 {
1552 0ULL,
1553 0xfc00000780000000ULL,
1554 0ULL,
1555 0ULL,
1556 0ULL
1557 },
1558 {
1559 -1ULL,
1560 0x2c00000180000000ULL,
1561 -1ULL,
1562 -1ULL,
1563 -1ULL
1564 }
1565 #endif
1566 },
1567 { "bytex", TILEPRO_OPC_BYTEX, 0x5, 2, TREG_ZERO, 1,
1568 { { 9, 10 }, { 0, }, { 11, 12 }, { 0, }, { 0, } },
1569 #ifndef DISASM_ONLY
1570 {
1571 0x800000007ffff000ULL,
1572 0ULL,
1573 0x80000000780ff000ULL,
1574 0ULL,
1575 0ULL
1576 },
1577 {
1578 0x0000000070162000ULL,
1579 -1ULL,
1580 0x80000000680a2000ULL,
1581 -1ULL,
1582 -1ULL
1583 }
1584 #endif
1585 },
1586 { "bytex.sn", TILEPRO_OPC_BYTEX_SN, 0x1, 2, TREG_SN, 1,
1587 { { 9, 10 }, { 0, }, { 0, }, { 0, }, { 0, } },
1588 #ifndef DISASM_ONLY
1589 {
1590 0x800000007ffff000ULL,
1591 0ULL,
1592 0ULL,
1593 0ULL,
1594 0ULL
1595 },
1596 {
1597 0x0000000078162000ULL,
1598 -1ULL,
1599 -1ULL,
1600 -1ULL,
1601 -1ULL
1602 }
1603 #endif
1604 },
1605 { "bz", TILEPRO_OPC_BZ, 0x2, 2, TREG_ZERO, 1,
1606 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1607 #ifndef DISASM_ONLY
1608 {
1609 0ULL,
1610 0xfc00000780000000ULL,
1611 0ULL,
1612 0ULL,
1613 0ULL
1614 },
1615 {
1616 -1ULL,
1617 0x2800000000000000ULL,
1618 -1ULL,
1619 -1ULL,
1620 -1ULL
1621 }
1622 #endif
1623 },
1624 { "bz.sn", TILEPRO_OPC_BZ_SN, 0x2, 2, TREG_SN, 1,
1625 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1626 #ifndef DISASM_ONLY
1627 {
1628 0ULL,
1629 0xfc00000780000000ULL,
1630 0ULL,
1631 0ULL,
1632 0ULL
1633 },
1634 {
1635 -1ULL,
1636 0x2c00000000000000ULL,
1637 -1ULL,
1638 -1ULL,
1639 -1ULL
1640 }
1641 #endif
1642 },
1643 { "bzt", TILEPRO_OPC_BZT, 0x2, 2, TREG_ZERO, 1,
1644 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1645 #ifndef DISASM_ONLY
1646 {
1647 0ULL,
1648 0xfc00000780000000ULL,
1649 0ULL,
1650 0ULL,
1651 0ULL
1652 },
1653 {
1654 -1ULL,
1655 0x2800000080000000ULL,
1656 -1ULL,
1657 -1ULL,
1658 -1ULL
1659 }
1660 #endif
1661 },
1662 { "bzt.sn", TILEPRO_OPC_BZT_SN, 0x2, 2, TREG_SN, 1,
1663 { { 0, }, { 8, 20 }, { 0, }, { 0, }, { 0, } },
1664 #ifndef DISASM_ONLY
1665 {
1666 0ULL,
1667 0xfc00000780000000ULL,
1668 0ULL,
1669 0ULL,
1670 0ULL
1671 },
1672 {
1673 -1ULL,
1674 0x2c00000080000000ULL,
1675 -1ULL,
1676 -1ULL,
1677 -1ULL
1678 }
1679 #endif
1680 },
1681 { "clz", TILEPRO_OPC_CLZ, 0x5, 2, TREG_ZERO, 1,
1682 { { 9, 10 }, { 0, }, { 11, 12 }, { 0, }, { 0, } },
1683 #ifndef DISASM_ONLY
1684 {
1685 0x800000007ffff000ULL,
1686 0ULL,
1687 0x80000000780ff000ULL,
1688 0ULL,
1689 0ULL
1690 },
1691 {
1692 0x0000000070163000ULL,
1693 -1ULL,
1694 0x80000000680a3000ULL,
1695 -1ULL,
1696 -1ULL
1697 }
1698 #endif
1699 },
1700 { "clz.sn", TILEPRO_OPC_CLZ_SN, 0x1, 2, TREG_SN, 1,
1701 { { 9, 10 }, { 0, }, { 0, }, { 0, }, { 0, } },
1702 #ifndef DISASM_ONLY
1703 {
1704 0x800000007ffff000ULL,
1705 0ULL,
1706 0ULL,
1707 0ULL,
1708 0ULL
1709 },
1710 {
1711 0x0000000078163000ULL,
1712 -1ULL,
1713 -1ULL,
1714 -1ULL,
1715 -1ULL
1716 }
1717 #endif
1718 },
1719 { "crc32_32", TILEPRO_OPC_CRC32_32, 0x1, 3, TREG_ZERO, 1,
1720 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
1721 #ifndef DISASM_ONLY
1722 {
1723 0x800000007ffc0000ULL,
1724 0ULL,
1725 0ULL,
1726 0ULL,
1727 0ULL
1728 },
1729 {
1730 0x0000000000240000ULL,
1731 -1ULL,
1732 -1ULL,
1733 -1ULL,
1734 -1ULL
1735 }
1736 #endif
1737 },
1738 { "crc32_32.sn", TILEPRO_OPC_CRC32_32_SN, 0x1, 3, TREG_SN, 1,
1739 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
1740 #ifndef DISASM_ONLY
1741 {
1742 0x800000007ffc0000ULL,
1743 0ULL,
1744 0ULL,
1745 0ULL,
1746 0ULL
1747 },
1748 {
1749 0x0000000008240000ULL,
1750 -1ULL,
1751 -1ULL,
1752 -1ULL,
1753 -1ULL
1754 }
1755 #endif
1756 },
1757 { "crc32_8", TILEPRO_OPC_CRC32_8, 0x1, 3, TREG_ZERO, 1,
1758 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
1759 #ifndef DISASM_ONLY
1760 {
1761 0x800000007ffc0000ULL,
1762 0ULL,
1763 0ULL,
1764 0ULL,
1765 0ULL
1766 },
1767 {
1768 0x0000000000280000ULL,
1769 -1ULL,
1770 -1ULL,
1771 -1ULL,
1772 -1ULL
1773 }
1774 #endif
1775 },
1776 { "crc32_8.sn", TILEPRO_OPC_CRC32_8_SN, 0x1, 3, TREG_SN, 1,
1777 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
1778 #ifndef DISASM_ONLY
1779 {
1780 0x800000007ffc0000ULL,
1781 0ULL,
1782 0ULL,
1783 0ULL,
1784 0ULL
1785 },
1786 {
1787 0x0000000008280000ULL,
1788 -1ULL,
1789 -1ULL,
1790 -1ULL,
1791 -1ULL
1792 }
1793 #endif
1794 },
1795 { "ctz", TILEPRO_OPC_CTZ, 0x5, 2, TREG_ZERO, 1,
1796 { { 9, 10 }, { 0, }, { 11, 12 }, { 0, }, { 0, } },
1797 #ifndef DISASM_ONLY
1798 {
1799 0x800000007ffff000ULL,
1800 0ULL,
1801 0x80000000780ff000ULL,
1802 0ULL,
1803 0ULL
1804 },
1805 {
1806 0x0000000070164000ULL,
1807 -1ULL,
1808 0x80000000680a4000ULL,
1809 -1ULL,
1810 -1ULL
1811 }
1812 #endif
1813 },
1814 { "ctz.sn", TILEPRO_OPC_CTZ_SN, 0x1, 2, TREG_SN, 1,
1815 { { 9, 10 }, { 0, }, { 0, }, { 0, }, { 0, } },
1816 #ifndef DISASM_ONLY
1817 {
1818 0x800000007ffff000ULL,
1819 0ULL,
1820 0ULL,
1821 0ULL,
1822 0ULL
1823 },
1824 {
1825 0x0000000078164000ULL,
1826 -1ULL,
1827 -1ULL,
1828 -1ULL,
1829 -1ULL
1830 }
1831 #endif
1832 },
1833 { "drain", TILEPRO_OPC_DRAIN, 0x2, 0, TREG_ZERO, 0,
1834 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
1835 #ifndef DISASM_ONLY
1836 {
1837 0ULL,
1838 0xfbfff80000000000ULL,
1839 0ULL,
1840 0ULL,
1841 0ULL
1842 },
1843 {
1844 -1ULL,
1845 0x400b080000000000ULL,
1846 -1ULL,
1847 -1ULL,
1848 -1ULL
1849 }
1850 #endif
1851 },
1852 { "dtlbpr", TILEPRO_OPC_DTLBPR, 0x2, 1, TREG_ZERO, 1,
1853 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
1854 #ifndef DISASM_ONLY
1855 {
1856 0ULL,
1857 0xfbfff80000000000ULL,
1858 0ULL,
1859 0ULL,
1860 0ULL
1861 },
1862 {
1863 -1ULL,
1864 0x400b100000000000ULL,
1865 -1ULL,
1866 -1ULL,
1867 -1ULL
1868 }
1869 #endif
1870 },
1871 { "dword_align", TILEPRO_OPC_DWORD_ALIGN, 0x1, 3, TREG_ZERO, 1,
1872 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
1873 #ifndef DISASM_ONLY
1874 {
1875 0x800000007ffc0000ULL,
1876 0ULL,
1877 0ULL,
1878 0ULL,
1879 0ULL
1880 },
1881 {
1882 0x00000000017c0000ULL,
1883 -1ULL,
1884 -1ULL,
1885 -1ULL,
1886 -1ULL
1887 }
1888 #endif
1889 },
1890 { "dword_align.sn", TILEPRO_OPC_DWORD_ALIGN_SN, 0x1, 3, TREG_SN, 1,
1891 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
1892 #ifndef DISASM_ONLY
1893 {
1894 0x800000007ffc0000ULL,
1895 0ULL,
1896 0ULL,
1897 0ULL,
1898 0ULL
1899 },
1900 {
1901 0x00000000097c0000ULL,
1902 -1ULL,
1903 -1ULL,
1904 -1ULL,
1905 -1ULL
1906 }
1907 #endif
1908 },
1909 { "finv", TILEPRO_OPC_FINV, 0x2, 1, TREG_ZERO, 1,
1910 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
1911 #ifndef DISASM_ONLY
1912 {
1913 0ULL,
1914 0xfbfff80000000000ULL,
1915 0ULL,
1916 0ULL,
1917 0ULL
1918 },
1919 {
1920 -1ULL,
1921 0x400b180000000000ULL,
1922 -1ULL,
1923 -1ULL,
1924 -1ULL
1925 }
1926 #endif
1927 },
1928 { "flush", TILEPRO_OPC_FLUSH, 0x2, 1, TREG_ZERO, 1,
1929 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
1930 #ifndef DISASM_ONLY
1931 {
1932 0ULL,
1933 0xfbfff80000000000ULL,
1934 0ULL,
1935 0ULL,
1936 0ULL
1937 },
1938 {
1939 -1ULL,
1940 0x400b200000000000ULL,
1941 -1ULL,
1942 -1ULL,
1943 -1ULL
1944 }
1945 #endif
1946 },
1947 { "fnop", TILEPRO_OPC_FNOP, 0xf, 0, TREG_ZERO, 1,
1948 { { }, { }, { }, { }, { 0, } },
1949 #ifndef DISASM_ONLY
1950 {
1951 0x8000000077fff000ULL,
1952 0xfbfff80000000000ULL,
1953 0x80000000780ff000ULL,
1954 0xf807f80000000000ULL,
1955 0ULL
1956 },
1957 {
1958 0x0000000070165000ULL,
1959 0x400b280000000000ULL,
1960 0x80000000680a5000ULL,
1961 0xd805080000000000ULL,
1962 -1ULL
1963 }
1964 #endif
1965 },
1966 { "icoh", TILEPRO_OPC_ICOH, 0x2, 1, TREG_ZERO, 1,
1967 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
1968 #ifndef DISASM_ONLY
1969 {
1970 0ULL,
1971 0xfbfff80000000000ULL,
1972 0ULL,
1973 0ULL,
1974 0ULL
1975 },
1976 {
1977 -1ULL,
1978 0x400b300000000000ULL,
1979 -1ULL,
1980 -1ULL,
1981 -1ULL
1982 }
1983 #endif
1984 },
1985 { "ill", TILEPRO_OPC_ILL, 0xa, 0, TREG_ZERO, 1,
1986 { { 0, }, { }, { 0, }, { }, { 0, } },
1987 #ifndef DISASM_ONLY
1988 {
1989 0ULL,
1990 0xfbfff80000000000ULL,
1991 0ULL,
1992 0xf807f80000000000ULL,
1993 0ULL
1994 },
1995 {
1996 -1ULL,
1997 0x400b380000000000ULL,
1998 -1ULL,
1999 0xd805100000000000ULL,
2000 -1ULL
2001 }
2002 #endif
2003 },
2004 { "inthb", TILEPRO_OPC_INTHB, 0x3, 3, TREG_ZERO, 1,
2005 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2006 #ifndef DISASM_ONLY
2007 {
2008 0x800000007ffc0000ULL,
2009 0xfffe000000000000ULL,
2010 0ULL,
2011 0ULL,
2012 0ULL
2013 },
2014 {
2015 0x00000000002c0000ULL,
2016 0x080a000000000000ULL,
2017 -1ULL,
2018 -1ULL,
2019 -1ULL
2020 }
2021 #endif
2022 },
2023 { "inthb.sn", TILEPRO_OPC_INTHB_SN, 0x3, 3, TREG_SN, 1,
2024 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2025 #ifndef DISASM_ONLY
2026 {
2027 0x800000007ffc0000ULL,
2028 0xfffe000000000000ULL,
2029 0ULL,
2030 0ULL,
2031 0ULL
2032 },
2033 {
2034 0x00000000082c0000ULL,
2035 0x0c0a000000000000ULL,
2036 -1ULL,
2037 -1ULL,
2038 -1ULL
2039 }
2040 #endif
2041 },
2042 { "inthh", TILEPRO_OPC_INTHH, 0x3, 3, TREG_ZERO, 1,
2043 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2044 #ifndef DISASM_ONLY
2045 {
2046 0x800000007ffc0000ULL,
2047 0xfffe000000000000ULL,
2048 0ULL,
2049 0ULL,
2050 0ULL
2051 },
2052 {
2053 0x0000000000300000ULL,
2054 0x080c000000000000ULL,
2055 -1ULL,
2056 -1ULL,
2057 -1ULL
2058 }
2059 #endif
2060 },
2061 { "inthh.sn", TILEPRO_OPC_INTHH_SN, 0x3, 3, TREG_SN, 1,
2062 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2063 #ifndef DISASM_ONLY
2064 {
2065 0x800000007ffc0000ULL,
2066 0xfffe000000000000ULL,
2067 0ULL,
2068 0ULL,
2069 0ULL
2070 },
2071 {
2072 0x0000000008300000ULL,
2073 0x0c0c000000000000ULL,
2074 -1ULL,
2075 -1ULL,
2076 -1ULL
2077 }
2078 #endif
2079 },
2080 { "intlb", TILEPRO_OPC_INTLB, 0x3, 3, TREG_ZERO, 1,
2081 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2082 #ifndef DISASM_ONLY
2083 {
2084 0x800000007ffc0000ULL,
2085 0xfffe000000000000ULL,
2086 0ULL,
2087 0ULL,
2088 0ULL
2089 },
2090 {
2091 0x0000000000340000ULL,
2092 0x080e000000000000ULL,
2093 -1ULL,
2094 -1ULL,
2095 -1ULL
2096 }
2097 #endif
2098 },
2099 { "intlb.sn", TILEPRO_OPC_INTLB_SN, 0x3, 3, TREG_SN, 1,
2100 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2101 #ifndef DISASM_ONLY
2102 {
2103 0x800000007ffc0000ULL,
2104 0xfffe000000000000ULL,
2105 0ULL,
2106 0ULL,
2107 0ULL
2108 },
2109 {
2110 0x0000000008340000ULL,
2111 0x0c0e000000000000ULL,
2112 -1ULL,
2113 -1ULL,
2114 -1ULL
2115 }
2116 #endif
2117 },
2118 { "intlh", TILEPRO_OPC_INTLH, 0x3, 3, TREG_ZERO, 1,
2119 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2120 #ifndef DISASM_ONLY
2121 {
2122 0x800000007ffc0000ULL,
2123 0xfffe000000000000ULL,
2124 0ULL,
2125 0ULL,
2126 0ULL
2127 },
2128 {
2129 0x0000000000380000ULL,
2130 0x0810000000000000ULL,
2131 -1ULL,
2132 -1ULL,
2133 -1ULL
2134 }
2135 #endif
2136 },
2137 { "intlh.sn", TILEPRO_OPC_INTLH_SN, 0x3, 3, TREG_SN, 1,
2138 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2139 #ifndef DISASM_ONLY
2140 {
2141 0x800000007ffc0000ULL,
2142 0xfffe000000000000ULL,
2143 0ULL,
2144 0ULL,
2145 0ULL
2146 },
2147 {
2148 0x0000000008380000ULL,
2149 0x0c10000000000000ULL,
2150 -1ULL,
2151 -1ULL,
2152 -1ULL
2153 }
2154 #endif
2155 },
2156 { "inv", TILEPRO_OPC_INV, 0x2, 1, TREG_ZERO, 1,
2157 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
2158 #ifndef DISASM_ONLY
2159 {
2160 0ULL,
2161 0xfbfff80000000000ULL,
2162 0ULL,
2163 0ULL,
2164 0ULL
2165 },
2166 {
2167 -1ULL,
2168 0x400b400000000000ULL,
2169 -1ULL,
2170 -1ULL,
2171 -1ULL
2172 }
2173 #endif
2174 },
2175 { "iret", TILEPRO_OPC_IRET, 0x2, 0, TREG_ZERO, 1,
2176 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
2177 #ifndef DISASM_ONLY
2178 {
2179 0ULL,
2180 0xfbfff80000000000ULL,
2181 0ULL,
2182 0ULL,
2183 0ULL
2184 },
2185 {
2186 -1ULL,
2187 0x400b480000000000ULL,
2188 -1ULL,
2189 -1ULL,
2190 -1ULL
2191 }
2192 #endif
2193 },
2194 { "jalb", TILEPRO_OPC_JALB, 0x2, 1, TREG_LR, 1,
2195 { { 0, }, { 22 }, { 0, }, { 0, }, { 0, } },
2196 #ifndef DISASM_ONLY
2197 {
2198 0ULL,
2199 0xf800000000000000ULL,
2200 0ULL,
2201 0ULL,
2202 0ULL
2203 },
2204 {
2205 -1ULL,
2206 0x6800000000000000ULL,
2207 -1ULL,
2208 -1ULL,
2209 -1ULL
2210 }
2211 #endif
2212 },
2213 { "jalf", TILEPRO_OPC_JALF, 0x2, 1, TREG_LR, 1,
2214 { { 0, }, { 22 }, { 0, }, { 0, }, { 0, } },
2215 #ifndef DISASM_ONLY
2216 {
2217 0ULL,
2218 0xf800000000000000ULL,
2219 0ULL,
2220 0ULL,
2221 0ULL
2222 },
2223 {
2224 -1ULL,
2225 0x6000000000000000ULL,
2226 -1ULL,
2227 -1ULL,
2228 -1ULL
2229 }
2230 #endif
2231 },
2232 { "jalr", TILEPRO_OPC_JALR, 0x2, 1, TREG_LR, 1,
2233 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
2234 #ifndef DISASM_ONLY
2235 {
2236 0ULL,
2237 0xfbfe000000000000ULL,
2238 0ULL,
2239 0ULL,
2240 0ULL
2241 },
2242 {
2243 -1ULL,
2244 0x0814000000000000ULL,
2245 -1ULL,
2246 -1ULL,
2247 -1ULL
2248 }
2249 #endif
2250 },
2251 { "jalrp", TILEPRO_OPC_JALRP, 0x2, 1, TREG_LR, 1,
2252 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
2253 #ifndef DISASM_ONLY
2254 {
2255 0ULL,
2256 0xfbfe000000000000ULL,
2257 0ULL,
2258 0ULL,
2259 0ULL
2260 },
2261 {
2262 -1ULL,
2263 0x0812000000000000ULL,
2264 -1ULL,
2265 -1ULL,
2266 -1ULL
2267 }
2268 #endif
2269 },
2270 { "jb", TILEPRO_OPC_JB, 0x2, 1, TREG_ZERO, 1,
2271 { { 0, }, { 22 }, { 0, }, { 0, }, { 0, } },
2272 #ifndef DISASM_ONLY
2273 {
2274 0ULL,
2275 0xf800000000000000ULL,
2276 0ULL,
2277 0ULL,
2278 0ULL
2279 },
2280 {
2281 -1ULL,
2282 0x5800000000000000ULL,
2283 -1ULL,
2284 -1ULL,
2285 -1ULL
2286 }
2287 #endif
2288 },
2289 { "jf", TILEPRO_OPC_JF, 0x2, 1, TREG_ZERO, 1,
2290 { { 0, }, { 22 }, { 0, }, { 0, }, { 0, } },
2291 #ifndef DISASM_ONLY
2292 {
2293 0ULL,
2294 0xf800000000000000ULL,
2295 0ULL,
2296 0ULL,
2297 0ULL
2298 },
2299 {
2300 -1ULL,
2301 0x5000000000000000ULL,
2302 -1ULL,
2303 -1ULL,
2304 -1ULL
2305 }
2306 #endif
2307 },
2308 { "jr", TILEPRO_OPC_JR, 0x2, 1, TREG_ZERO, 1,
2309 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
2310 #ifndef DISASM_ONLY
2311 {
2312 0ULL,
2313 0xfbfe000000000000ULL,
2314 0ULL,
2315 0ULL,
2316 0ULL
2317 },
2318 {
2319 -1ULL,
2320 0x0818000000000000ULL,
2321 -1ULL,
2322 -1ULL,
2323 -1ULL
2324 }
2325 #endif
2326 },
2327 { "jrp", TILEPRO_OPC_JRP, 0x2, 1, TREG_ZERO, 1,
2328 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
2329 #ifndef DISASM_ONLY
2330 {
2331 0ULL,
2332 0xfbfe000000000000ULL,
2333 0ULL,
2334 0ULL,
2335 0ULL
2336 },
2337 {
2338 -1ULL,
2339 0x0816000000000000ULL,
2340 -1ULL,
2341 -1ULL,
2342 -1ULL
2343 }
2344 #endif
2345 },
2346 { "lb", TILEPRO_OPC_LB, 0x12, 2, TREG_ZERO, 1,
2347 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 23, 15 } },
2348 #ifndef DISASM_ONLY
2349 {
2350 0ULL,
2351 0xfffff80000000000ULL,
2352 0ULL,
2353 0ULL,
2354 0x8700000000000000ULL
2355 },
2356 {
2357 -1ULL,
2358 0x400b500000000000ULL,
2359 -1ULL,
2360 -1ULL,
2361 0x8000000000000000ULL
2362 }
2363 #endif
2364 },
2365 { "lb.sn", TILEPRO_OPC_LB_SN, 0x2, 2, TREG_SN, 1,
2366 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
2367 #ifndef DISASM_ONLY
2368 {
2369 0ULL,
2370 0xfffff80000000000ULL,
2371 0ULL,
2372 0ULL,
2373 0ULL
2374 },
2375 {
2376 -1ULL,
2377 0x440b500000000000ULL,
2378 -1ULL,
2379 -1ULL,
2380 -1ULL
2381 }
2382 #endif
2383 },
2384 { "lb_u", TILEPRO_OPC_LB_U, 0x12, 2, TREG_ZERO, 1,
2385 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 23, 15 } },
2386 #ifndef DISASM_ONLY
2387 {
2388 0ULL,
2389 0xfffff80000000000ULL,
2390 0ULL,
2391 0ULL,
2392 0x8700000000000000ULL
2393 },
2394 {
2395 -1ULL,
2396 0x400b580000000000ULL,
2397 -1ULL,
2398 -1ULL,
2399 0x8100000000000000ULL
2400 }
2401 #endif
2402 },
2403 { "lb_u.sn", TILEPRO_OPC_LB_U_SN, 0x2, 2, TREG_SN, 1,
2404 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
2405 #ifndef DISASM_ONLY
2406 {
2407 0ULL,
2408 0xfffff80000000000ULL,
2409 0ULL,
2410 0ULL,
2411 0ULL
2412 },
2413 {
2414 -1ULL,
2415 0x440b580000000000ULL,
2416 -1ULL,
2417 -1ULL,
2418 -1ULL
2419 }
2420 #endif
2421 },
2422 { "lbadd", TILEPRO_OPC_LBADD, 0x2, 3, TREG_ZERO, 1,
2423 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2424 #ifndef DISASM_ONLY
2425 {
2426 0ULL,
2427 0xfff8000000000000ULL,
2428 0ULL,
2429 0ULL,
2430 0ULL
2431 },
2432 {
2433 -1ULL,
2434 0x30b0000000000000ULL,
2435 -1ULL,
2436 -1ULL,
2437 -1ULL
2438 }
2439 #endif
2440 },
2441 { "lbadd.sn", TILEPRO_OPC_LBADD_SN, 0x2, 3, TREG_SN, 1,
2442 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2443 #ifndef DISASM_ONLY
2444 {
2445 0ULL,
2446 0xfff8000000000000ULL,
2447 0ULL,
2448 0ULL,
2449 0ULL
2450 },
2451 {
2452 -1ULL,
2453 0x34b0000000000000ULL,
2454 -1ULL,
2455 -1ULL,
2456 -1ULL
2457 }
2458 #endif
2459 },
2460 { "lbadd_u", TILEPRO_OPC_LBADD_U, 0x2, 3, TREG_ZERO, 1,
2461 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2462 #ifndef DISASM_ONLY
2463 {
2464 0ULL,
2465 0xfff8000000000000ULL,
2466 0ULL,
2467 0ULL,
2468 0ULL
2469 },
2470 {
2471 -1ULL,
2472 0x30b8000000000000ULL,
2473 -1ULL,
2474 -1ULL,
2475 -1ULL
2476 }
2477 #endif
2478 },
2479 { "lbadd_u.sn", TILEPRO_OPC_LBADD_U_SN, 0x2, 3, TREG_SN, 1,
2480 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2481 #ifndef DISASM_ONLY
2482 {
2483 0ULL,
2484 0xfff8000000000000ULL,
2485 0ULL,
2486 0ULL,
2487 0ULL
2488 },
2489 {
2490 -1ULL,
2491 0x34b8000000000000ULL,
2492 -1ULL,
2493 -1ULL,
2494 -1ULL
2495 }
2496 #endif
2497 },
2498 { "lh", TILEPRO_OPC_LH, 0x12, 2, TREG_ZERO, 1,
2499 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 23, 15 } },
2500 #ifndef DISASM_ONLY
2501 {
2502 0ULL,
2503 0xfffff80000000000ULL,
2504 0ULL,
2505 0ULL,
2506 0x8700000000000000ULL
2507 },
2508 {
2509 -1ULL,
2510 0x400b600000000000ULL,
2511 -1ULL,
2512 -1ULL,
2513 0x8200000000000000ULL
2514 }
2515 #endif
2516 },
2517 { "lh.sn", TILEPRO_OPC_LH_SN, 0x2, 2, TREG_SN, 1,
2518 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
2519 #ifndef DISASM_ONLY
2520 {
2521 0ULL,
2522 0xfffff80000000000ULL,
2523 0ULL,
2524 0ULL,
2525 0ULL
2526 },
2527 {
2528 -1ULL,
2529 0x440b600000000000ULL,
2530 -1ULL,
2531 -1ULL,
2532 -1ULL
2533 }
2534 #endif
2535 },
2536 { "lh_u", TILEPRO_OPC_LH_U, 0x12, 2, TREG_ZERO, 1,
2537 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 23, 15 } },
2538 #ifndef DISASM_ONLY
2539 {
2540 0ULL,
2541 0xfffff80000000000ULL,
2542 0ULL,
2543 0ULL,
2544 0x8700000000000000ULL
2545 },
2546 {
2547 -1ULL,
2548 0x400b680000000000ULL,
2549 -1ULL,
2550 -1ULL,
2551 0x8300000000000000ULL
2552 }
2553 #endif
2554 },
2555 { "lh_u.sn", TILEPRO_OPC_LH_U_SN, 0x2, 2, TREG_SN, 1,
2556 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
2557 #ifndef DISASM_ONLY
2558 {
2559 0ULL,
2560 0xfffff80000000000ULL,
2561 0ULL,
2562 0ULL,
2563 0ULL
2564 },
2565 {
2566 -1ULL,
2567 0x440b680000000000ULL,
2568 -1ULL,
2569 -1ULL,
2570 -1ULL
2571 }
2572 #endif
2573 },
2574 { "lhadd", TILEPRO_OPC_LHADD, 0x2, 3, TREG_ZERO, 1,
2575 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2576 #ifndef DISASM_ONLY
2577 {
2578 0ULL,
2579 0xfff8000000000000ULL,
2580 0ULL,
2581 0ULL,
2582 0ULL
2583 },
2584 {
2585 -1ULL,
2586 0x30c0000000000000ULL,
2587 -1ULL,
2588 -1ULL,
2589 -1ULL
2590 }
2591 #endif
2592 },
2593 { "lhadd.sn", TILEPRO_OPC_LHADD_SN, 0x2, 3, TREG_SN, 1,
2594 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2595 #ifndef DISASM_ONLY
2596 {
2597 0ULL,
2598 0xfff8000000000000ULL,
2599 0ULL,
2600 0ULL,
2601 0ULL
2602 },
2603 {
2604 -1ULL,
2605 0x34c0000000000000ULL,
2606 -1ULL,
2607 -1ULL,
2608 -1ULL
2609 }
2610 #endif
2611 },
2612 { "lhadd_u", TILEPRO_OPC_LHADD_U, 0x2, 3, TREG_ZERO, 1,
2613 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2614 #ifndef DISASM_ONLY
2615 {
2616 0ULL,
2617 0xfff8000000000000ULL,
2618 0ULL,
2619 0ULL,
2620 0ULL
2621 },
2622 {
2623 -1ULL,
2624 0x30c8000000000000ULL,
2625 -1ULL,
2626 -1ULL,
2627 -1ULL
2628 }
2629 #endif
2630 },
2631 { "lhadd_u.sn", TILEPRO_OPC_LHADD_U_SN, 0x2, 3, TREG_SN, 1,
2632 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2633 #ifndef DISASM_ONLY
2634 {
2635 0ULL,
2636 0xfff8000000000000ULL,
2637 0ULL,
2638 0ULL,
2639 0ULL
2640 },
2641 {
2642 -1ULL,
2643 0x34c8000000000000ULL,
2644 -1ULL,
2645 -1ULL,
2646 -1ULL
2647 }
2648 #endif
2649 },
2650 { "lnk", TILEPRO_OPC_LNK, 0x2, 1, TREG_ZERO, 1,
2651 { { 0, }, { 7 }, { 0, }, { 0, }, { 0, } },
2652 #ifndef DISASM_ONLY
2653 {
2654 0ULL,
2655 0xfffe000000000000ULL,
2656 0ULL,
2657 0ULL,
2658 0ULL
2659 },
2660 {
2661 -1ULL,
2662 0x081a000000000000ULL,
2663 -1ULL,
2664 -1ULL,
2665 -1ULL
2666 }
2667 #endif
2668 },
2669 { "lnk.sn", TILEPRO_OPC_LNK_SN, 0x2, 1, TREG_SN, 1,
2670 { { 0, }, { 7 }, { 0, }, { 0, }, { 0, } },
2671 #ifndef DISASM_ONLY
2672 {
2673 0ULL,
2674 0xfffe000000000000ULL,
2675 0ULL,
2676 0ULL,
2677 0ULL
2678 },
2679 {
2680 -1ULL,
2681 0x0c1a000000000000ULL,
2682 -1ULL,
2683 -1ULL,
2684 -1ULL
2685 }
2686 #endif
2687 },
2688 { "lw", TILEPRO_OPC_LW, 0x12, 2, TREG_ZERO, 1,
2689 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 23, 15 } },
2690 #ifndef DISASM_ONLY
2691 {
2692 0ULL,
2693 0xfffff80000000000ULL,
2694 0ULL,
2695 0ULL,
2696 0x8700000000000000ULL
2697 },
2698 {
2699 -1ULL,
2700 0x400b700000000000ULL,
2701 -1ULL,
2702 -1ULL,
2703 0x8400000000000000ULL
2704 }
2705 #endif
2706 },
2707 { "lw.sn", TILEPRO_OPC_LW_SN, 0x2, 2, TREG_SN, 1,
2708 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
2709 #ifndef DISASM_ONLY
2710 {
2711 0ULL,
2712 0xfffff80000000000ULL,
2713 0ULL,
2714 0ULL,
2715 0ULL
2716 },
2717 {
2718 -1ULL,
2719 0x440b700000000000ULL,
2720 -1ULL,
2721 -1ULL,
2722 -1ULL
2723 }
2724 #endif
2725 },
2726 { "lw_na", TILEPRO_OPC_LW_NA, 0x2, 2, TREG_ZERO, 1,
2727 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
2728 #ifndef DISASM_ONLY
2729 {
2730 0ULL,
2731 0xfffff80000000000ULL,
2732 0ULL,
2733 0ULL,
2734 0ULL
2735 },
2736 {
2737 -1ULL,
2738 0x400bc00000000000ULL,
2739 -1ULL,
2740 -1ULL,
2741 -1ULL
2742 }
2743 #endif
2744 },
2745 { "lw_na.sn", TILEPRO_OPC_LW_NA_SN, 0x2, 2, TREG_SN, 1,
2746 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
2747 #ifndef DISASM_ONLY
2748 {
2749 0ULL,
2750 0xfffff80000000000ULL,
2751 0ULL,
2752 0ULL,
2753 0ULL
2754 },
2755 {
2756 -1ULL,
2757 0x440bc00000000000ULL,
2758 -1ULL,
2759 -1ULL,
2760 -1ULL
2761 }
2762 #endif
2763 },
2764 { "lwadd", TILEPRO_OPC_LWADD, 0x2, 3, TREG_ZERO, 1,
2765 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2766 #ifndef DISASM_ONLY
2767 {
2768 0ULL,
2769 0xfff8000000000000ULL,
2770 0ULL,
2771 0ULL,
2772 0ULL
2773 },
2774 {
2775 -1ULL,
2776 0x30d0000000000000ULL,
2777 -1ULL,
2778 -1ULL,
2779 -1ULL
2780 }
2781 #endif
2782 },
2783 { "lwadd.sn", TILEPRO_OPC_LWADD_SN, 0x2, 3, TREG_SN, 1,
2784 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2785 #ifndef DISASM_ONLY
2786 {
2787 0ULL,
2788 0xfff8000000000000ULL,
2789 0ULL,
2790 0ULL,
2791 0ULL
2792 },
2793 {
2794 -1ULL,
2795 0x34d0000000000000ULL,
2796 -1ULL,
2797 -1ULL,
2798 -1ULL
2799 }
2800 #endif
2801 },
2802 { "lwadd_na", TILEPRO_OPC_LWADD_NA, 0x2, 3, TREG_ZERO, 1,
2803 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2804 #ifndef DISASM_ONLY
2805 {
2806 0ULL,
2807 0xfff8000000000000ULL,
2808 0ULL,
2809 0ULL,
2810 0ULL
2811 },
2812 {
2813 -1ULL,
2814 0x30d8000000000000ULL,
2815 -1ULL,
2816 -1ULL,
2817 -1ULL
2818 }
2819 #endif
2820 },
2821 { "lwadd_na.sn", TILEPRO_OPC_LWADD_NA_SN, 0x2, 3, TREG_SN, 1,
2822 { { 0, }, { 7, 24, 1 }, { 0, }, { 0, }, { 0, } },
2823 #ifndef DISASM_ONLY
2824 {
2825 0ULL,
2826 0xfff8000000000000ULL,
2827 0ULL,
2828 0ULL,
2829 0ULL
2830 },
2831 {
2832 -1ULL,
2833 0x34d8000000000000ULL,
2834 -1ULL,
2835 -1ULL,
2836 -1ULL
2837 }
2838 #endif
2839 },
2840 { "maxb_u", TILEPRO_OPC_MAXB_U, 0x3, 3, TREG_ZERO, 1,
2841 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2842 #ifndef DISASM_ONLY
2843 {
2844 0x800000007ffc0000ULL,
2845 0xfffe000000000000ULL,
2846 0ULL,
2847 0ULL,
2848 0ULL
2849 },
2850 {
2851 0x00000000003c0000ULL,
2852 0x081c000000000000ULL,
2853 -1ULL,
2854 -1ULL,
2855 -1ULL
2856 }
2857 #endif
2858 },
2859 { "maxb_u.sn", TILEPRO_OPC_MAXB_U_SN, 0x3, 3, TREG_SN, 1,
2860 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2861 #ifndef DISASM_ONLY
2862 {
2863 0x800000007ffc0000ULL,
2864 0xfffe000000000000ULL,
2865 0ULL,
2866 0ULL,
2867 0ULL
2868 },
2869 {
2870 0x00000000083c0000ULL,
2871 0x0c1c000000000000ULL,
2872 -1ULL,
2873 -1ULL,
2874 -1ULL
2875 }
2876 #endif
2877 },
2878 { "maxh", TILEPRO_OPC_MAXH, 0x3, 3, TREG_ZERO, 1,
2879 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2880 #ifndef DISASM_ONLY
2881 {
2882 0x800000007ffc0000ULL,
2883 0xfffe000000000000ULL,
2884 0ULL,
2885 0ULL,
2886 0ULL
2887 },
2888 {
2889 0x0000000000400000ULL,
2890 0x081e000000000000ULL,
2891 -1ULL,
2892 -1ULL,
2893 -1ULL
2894 }
2895 #endif
2896 },
2897 { "maxh.sn", TILEPRO_OPC_MAXH_SN, 0x3, 3, TREG_SN, 1,
2898 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
2899 #ifndef DISASM_ONLY
2900 {
2901 0x800000007ffc0000ULL,
2902 0xfffe000000000000ULL,
2903 0ULL,
2904 0ULL,
2905 0ULL
2906 },
2907 {
2908 0x0000000008400000ULL,
2909 0x0c1e000000000000ULL,
2910 -1ULL,
2911 -1ULL,
2912 -1ULL
2913 }
2914 #endif
2915 },
2916 { "maxib_u", TILEPRO_OPC_MAXIB_U, 0x3, 3, TREG_ZERO, 1,
2917 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
2918 #ifndef DISASM_ONLY
2919 {
2920 0x800000007ff00000ULL,
2921 0xfff8000000000000ULL,
2922 0ULL,
2923 0ULL,
2924 0ULL
2925 },
2926 {
2927 0x0000000040400000ULL,
2928 0x3028000000000000ULL,
2929 -1ULL,
2930 -1ULL,
2931 -1ULL
2932 }
2933 #endif
2934 },
2935 { "maxib_u.sn", TILEPRO_OPC_MAXIB_U_SN, 0x3, 3, TREG_SN, 1,
2936 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
2937 #ifndef DISASM_ONLY
2938 {
2939 0x800000007ff00000ULL,
2940 0xfff8000000000000ULL,
2941 0ULL,
2942 0ULL,
2943 0ULL
2944 },
2945 {
2946 0x0000000048400000ULL,
2947 0x3428000000000000ULL,
2948 -1ULL,
2949 -1ULL,
2950 -1ULL
2951 }
2952 #endif
2953 },
2954 { "maxih", TILEPRO_OPC_MAXIH, 0x3, 3, TREG_ZERO, 1,
2955 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
2956 #ifndef DISASM_ONLY
2957 {
2958 0x800000007ff00000ULL,
2959 0xfff8000000000000ULL,
2960 0ULL,
2961 0ULL,
2962 0ULL
2963 },
2964 {
2965 0x0000000040500000ULL,
2966 0x3030000000000000ULL,
2967 -1ULL,
2968 -1ULL,
2969 -1ULL
2970 }
2971 #endif
2972 },
2973 { "maxih.sn", TILEPRO_OPC_MAXIH_SN, 0x3, 3, TREG_SN, 1,
2974 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
2975 #ifndef DISASM_ONLY
2976 {
2977 0x800000007ff00000ULL,
2978 0xfff8000000000000ULL,
2979 0ULL,
2980 0ULL,
2981 0ULL
2982 },
2983 {
2984 0x0000000048500000ULL,
2985 0x3430000000000000ULL,
2986 -1ULL,
2987 -1ULL,
2988 -1ULL
2989 }
2990 #endif
2991 },
2992 { "mf", TILEPRO_OPC_MF, 0x2, 0, TREG_ZERO, 1,
2993 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
2994 #ifndef DISASM_ONLY
2995 {
2996 0ULL,
2997 0xfbfff80000000000ULL,
2998 0ULL,
2999 0ULL,
3000 0ULL
3001 },
3002 {
3003 -1ULL,
3004 0x400b780000000000ULL,
3005 -1ULL,
3006 -1ULL,
3007 -1ULL
3008 }
3009 #endif
3010 },
3011 { "mfspr", TILEPRO_OPC_MFSPR, 0x2, 2, TREG_ZERO, 1,
3012 { { 0, }, { 7, 25 }, { 0, }, { 0, }, { 0, } },
3013 #ifndef DISASM_ONLY
3014 {
3015 0ULL,
3016 0xfbf8000000000000ULL,
3017 0ULL,
3018 0ULL,
3019 0ULL
3020 },
3021 {
3022 -1ULL,
3023 0x3038000000000000ULL,
3024 -1ULL,
3025 -1ULL,
3026 -1ULL
3027 }
3028 #endif
3029 },
3030 { "minb_u", TILEPRO_OPC_MINB_U, 0x3, 3, TREG_ZERO, 1,
3031 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
3032 #ifndef DISASM_ONLY
3033 {
3034 0x800000007ffc0000ULL,
3035 0xfffe000000000000ULL,
3036 0ULL,
3037 0ULL,
3038 0ULL
3039 },
3040 {
3041 0x0000000000440000ULL,
3042 0x0820000000000000ULL,
3043 -1ULL,
3044 -1ULL,
3045 -1ULL
3046 }
3047 #endif
3048 },
3049 { "minb_u.sn", TILEPRO_OPC_MINB_U_SN, 0x3, 3, TREG_SN, 1,
3050 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
3051 #ifndef DISASM_ONLY
3052 {
3053 0x800000007ffc0000ULL,
3054 0xfffe000000000000ULL,
3055 0ULL,
3056 0ULL,
3057 0ULL
3058 },
3059 {
3060 0x0000000008440000ULL,
3061 0x0c20000000000000ULL,
3062 -1ULL,
3063 -1ULL,
3064 -1ULL
3065 }
3066 #endif
3067 },
3068 { "minh", TILEPRO_OPC_MINH, 0x3, 3, TREG_ZERO, 1,
3069 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
3070 #ifndef DISASM_ONLY
3071 {
3072 0x800000007ffc0000ULL,
3073 0xfffe000000000000ULL,
3074 0ULL,
3075 0ULL,
3076 0ULL
3077 },
3078 {
3079 0x0000000000480000ULL,
3080 0x0822000000000000ULL,
3081 -1ULL,
3082 -1ULL,
3083 -1ULL
3084 }
3085 #endif
3086 },
3087 { "minh.sn", TILEPRO_OPC_MINH_SN, 0x3, 3, TREG_SN, 1,
3088 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
3089 #ifndef DISASM_ONLY
3090 {
3091 0x800000007ffc0000ULL,
3092 0xfffe000000000000ULL,
3093 0ULL,
3094 0ULL,
3095 0ULL
3096 },
3097 {
3098 0x0000000008480000ULL,
3099 0x0c22000000000000ULL,
3100 -1ULL,
3101 -1ULL,
3102 -1ULL
3103 }
3104 #endif
3105 },
3106 { "minib_u", TILEPRO_OPC_MINIB_U, 0x3, 3, TREG_ZERO, 1,
3107 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
3108 #ifndef DISASM_ONLY
3109 {
3110 0x800000007ff00000ULL,
3111 0xfff8000000000000ULL,
3112 0ULL,
3113 0ULL,
3114 0ULL
3115 },
3116 {
3117 0x0000000040600000ULL,
3118 0x3040000000000000ULL,
3119 -1ULL,
3120 -1ULL,
3121 -1ULL
3122 }
3123 #endif
3124 },
3125 { "minib_u.sn", TILEPRO_OPC_MINIB_U_SN, 0x3, 3, TREG_SN, 1,
3126 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
3127 #ifndef DISASM_ONLY
3128 {
3129 0x800000007ff00000ULL,
3130 0xfff8000000000000ULL,
3131 0ULL,
3132 0ULL,
3133 0ULL
3134 },
3135 {
3136 0x0000000048600000ULL,
3137 0x3440000000000000ULL,
3138 -1ULL,
3139 -1ULL,
3140 -1ULL
3141 }
3142 #endif
3143 },
3144 { "minih", TILEPRO_OPC_MINIH, 0x3, 3, TREG_ZERO, 1,
3145 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
3146 #ifndef DISASM_ONLY
3147 {
3148 0x800000007ff00000ULL,
3149 0xfff8000000000000ULL,
3150 0ULL,
3151 0ULL,
3152 0ULL
3153 },
3154 {
3155 0x0000000040700000ULL,
3156 0x3048000000000000ULL,
3157 -1ULL,
3158 -1ULL,
3159 -1ULL
3160 }
3161 #endif
3162 },
3163 { "minih.sn", TILEPRO_OPC_MINIH_SN, 0x3, 3, TREG_SN, 1,
3164 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
3165 #ifndef DISASM_ONLY
3166 {
3167 0x800000007ff00000ULL,
3168 0xfff8000000000000ULL,
3169 0ULL,
3170 0ULL,
3171 0ULL
3172 },
3173 {
3174 0x0000000048700000ULL,
3175 0x3448000000000000ULL,
3176 -1ULL,
3177 -1ULL,
3178 -1ULL
3179 }
3180 #endif
3181 },
3182 { "mm", TILEPRO_OPC_MM, 0x3, 5, TREG_ZERO, 1,
3183 { { 9, 10, 16, 26, 27 }, { 7, 8, 17, 28, 29 }, { 0, }, { 0, }, { 0, } },
3184 #ifndef DISASM_ONLY
3185 {
3186 0x8000000070000000ULL,
3187 0xf800000000000000ULL,
3188 0ULL,
3189 0ULL,
3190 0ULL
3191 },
3192 {
3193 0x0000000060000000ULL,
3194 0x3800000000000000ULL,
3195 -1ULL,
3196 -1ULL,
3197 -1ULL
3198 }
3199 #endif
3200 },
3201 { "mnz", TILEPRO_OPC_MNZ, 0xf, 3, TREG_ZERO, 1,
3202 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
3203 #ifndef DISASM_ONLY
3204 {
3205 0x800000007ffc0000ULL,
3206 0xfffe000000000000ULL,
3207 0x80000000780c0000ULL,
3208 0xf806000000000000ULL,
3209 0ULL
3210 },
3211 {
3212 0x0000000000540000ULL,
3213 0x0828000000000000ULL,
3214 0x8000000010000000ULL,
3215 0x9002000000000000ULL,
3216 -1ULL
3217 }
3218 #endif
3219 },
3220 { "mnz.sn", TILEPRO_OPC_MNZ_SN, 0x3, 3, TREG_SN, 1,
3221 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
3222 #ifndef DISASM_ONLY
3223 {
3224 0x800000007ffc0000ULL,
3225 0xfffe000000000000ULL,
3226 0ULL,
3227 0ULL,
3228 0ULL
3229 },
3230 {
3231 0x0000000008540000ULL,
3232 0x0c28000000000000ULL,
3233 -1ULL,
3234 -1ULL,
3235 -1ULL
3236 }
3237 #endif
3238 },
3239 { "mnzb", TILEPRO_OPC_MNZB, 0x3, 3, TREG_ZERO, 1,
3240 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
3241 #ifndef DISASM_ONLY
3242 {
3243 0x800000007ffc0000ULL,
3244 0xfffe000000000000ULL,
3245 0ULL,
3246 0ULL,
3247 0ULL
3248 },
3249 {
3250 0x00000000004c0000ULL,
3251 0x0824000000000000ULL,
3252 -1ULL,
3253 -1ULL,
3254 -1ULL
3255 }
3256 #endif
3257 },
3258 { "mnzb.sn", TILEPRO_OPC_MNZB_SN, 0x3, 3, TREG_SN, 1,
3259 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
3260 #ifndef DISASM_ONLY
3261 {
3262 0x800000007ffc0000ULL,
3263 0xfffe000000000000ULL,
3264 0ULL,
3265 0ULL,
3266 0ULL
3267 },
3268 {
3269 0x00000000084c0000ULL,
3270 0x0c24000000000000ULL,
3271 -1ULL,
3272 -1ULL,
3273 -1ULL
3274 }
3275 #endif
3276 },
3277 { "mnzh", TILEPRO_OPC_MNZH, 0x3, 3, TREG_ZERO, 1,
3278 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
3279 #ifndef DISASM_ONLY
3280 {
3281 0x800000007ffc0000ULL,
3282 0xfffe000000000000ULL,
3283 0ULL,
3284 0ULL,
3285 0ULL
3286 },
3287 {
3288 0x0000000000500000ULL,
3289 0x0826000000000000ULL,
3290 -1ULL,
3291 -1ULL,
3292 -1ULL
3293 }
3294 #endif
3295 },
3296 { "mnzh.sn", TILEPRO_OPC_MNZH_SN, 0x3, 3, TREG_SN, 1,
3297 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
3298 #ifndef DISASM_ONLY
3299 {
3300 0x800000007ffc0000ULL,
3301 0xfffe000000000000ULL,
3302 0ULL,
3303 0ULL,
3304 0ULL
3305 },
3306 {
3307 0x0000000008500000ULL,
3308 0x0c26000000000000ULL,
3309 -1ULL,
3310 -1ULL,
3311 -1ULL
3312 }
3313 #endif
3314 },
3315 { "mtspr", TILEPRO_OPC_MTSPR, 0x2, 2, TREG_ZERO, 1,
3316 { { 0, }, { 30, 8 }, { 0, }, { 0, }, { 0, } },
3317 #ifndef DISASM_ONLY
3318 {
3319 0ULL,
3320 0xfbf8000000000000ULL,
3321 0ULL,
3322 0ULL,
3323 0ULL
3324 },
3325 {
3326 -1ULL,
3327 0x3050000000000000ULL,
3328 -1ULL,
3329 -1ULL,
3330 -1ULL
3331 }
3332 #endif
3333 },
3334 { "mulhh_ss", TILEPRO_OPC_MULHH_SS, 0x5, 3, TREG_ZERO, 1,
3335 { { 9, 10, 16 }, { 0, }, { 11, 12, 18 }, { 0, }, { 0, } },
3336 #ifndef DISASM_ONLY
3337 {
3338 0x800000007ffc0000ULL,
3339 0ULL,
3340 0x80000000780c0000ULL,
3341 0ULL,
3342 0ULL
3343 },
3344 {
3345 0x0000000000680000ULL,
3346 -1ULL,
3347 0x8000000038000000ULL,
3348 -1ULL,
3349 -1ULL
3350 }
3351 #endif
3352 },
3353 { "mulhh_ss.sn", TILEPRO_OPC_MULHH_SS_SN, 0x1, 3, TREG_SN, 1,
3354 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3355 #ifndef DISASM_ONLY
3356 {
3357 0x800000007ffc0000ULL,
3358 0ULL,
3359 0ULL,
3360 0ULL,
3361 0ULL
3362 },
3363 {
3364 0x0000000008680000ULL,
3365 -1ULL,
3366 -1ULL,
3367 -1ULL,
3368 -1ULL
3369 }
3370 #endif
3371 },
3372 { "mulhh_su", TILEPRO_OPC_MULHH_SU, 0x1, 3, TREG_ZERO, 1,
3373 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3374 #ifndef DISASM_ONLY
3375 {
3376 0x800000007ffc0000ULL,
3377 0ULL,
3378 0ULL,
3379 0ULL,
3380 0ULL
3381 },
3382 {
3383 0x00000000006c0000ULL,
3384 -1ULL,
3385 -1ULL,
3386 -1ULL,
3387 -1ULL
3388 }
3389 #endif
3390 },
3391 { "mulhh_su.sn", TILEPRO_OPC_MULHH_SU_SN, 0x1, 3, TREG_SN, 1,
3392 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3393 #ifndef DISASM_ONLY
3394 {
3395 0x800000007ffc0000ULL,
3396 0ULL,
3397 0ULL,
3398 0ULL,
3399 0ULL
3400 },
3401 {
3402 0x00000000086c0000ULL,
3403 -1ULL,
3404 -1ULL,
3405 -1ULL,
3406 -1ULL
3407 }
3408 #endif
3409 },
3410 { "mulhh_uu", TILEPRO_OPC_MULHH_UU, 0x5, 3, TREG_ZERO, 1,
3411 { { 9, 10, 16 }, { 0, }, { 11, 12, 18 }, { 0, }, { 0, } },
3412 #ifndef DISASM_ONLY
3413 {
3414 0x800000007ffc0000ULL,
3415 0ULL,
3416 0x80000000780c0000ULL,
3417 0ULL,
3418 0ULL
3419 },
3420 {
3421 0x0000000000700000ULL,
3422 -1ULL,
3423 0x8000000038040000ULL,
3424 -1ULL,
3425 -1ULL
3426 }
3427 #endif
3428 },
3429 { "mulhh_uu.sn", TILEPRO_OPC_MULHH_UU_SN, 0x1, 3, TREG_SN, 1,
3430 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3431 #ifndef DISASM_ONLY
3432 {
3433 0x800000007ffc0000ULL,
3434 0ULL,
3435 0ULL,
3436 0ULL,
3437 0ULL
3438 },
3439 {
3440 0x0000000008700000ULL,
3441 -1ULL,
3442 -1ULL,
3443 -1ULL,
3444 -1ULL
3445 }
3446 #endif
3447 },
3448 { "mulhha_ss", TILEPRO_OPC_MULHHA_SS, 0x5, 3, TREG_ZERO, 1,
3449 { { 21, 10, 16 }, { 0, }, { 31, 12, 18 }, { 0, }, { 0, } },
3450 #ifndef DISASM_ONLY
3451 {
3452 0x800000007ffc0000ULL,
3453 0ULL,
3454 0x80000000780c0000ULL,
3455 0ULL,
3456 0ULL
3457 },
3458 {
3459 0x0000000000580000ULL,
3460 -1ULL,
3461 0x8000000040000000ULL,
3462 -1ULL,
3463 -1ULL
3464 }
3465 #endif
3466 },
3467 { "mulhha_ss.sn", TILEPRO_OPC_MULHHA_SS_SN, 0x1, 3, TREG_SN, 1,
3468 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3469 #ifndef DISASM_ONLY
3470 {
3471 0x800000007ffc0000ULL,
3472 0ULL,
3473 0ULL,
3474 0ULL,
3475 0ULL
3476 },
3477 {
3478 0x0000000008580000ULL,
3479 -1ULL,
3480 -1ULL,
3481 -1ULL,
3482 -1ULL
3483 }
3484 #endif
3485 },
3486 { "mulhha_su", TILEPRO_OPC_MULHHA_SU, 0x1, 3, TREG_ZERO, 1,
3487 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3488 #ifndef DISASM_ONLY
3489 {
3490 0x800000007ffc0000ULL,
3491 0ULL,
3492 0ULL,
3493 0ULL,
3494 0ULL
3495 },
3496 {
3497 0x00000000005c0000ULL,
3498 -1ULL,
3499 -1ULL,
3500 -1ULL,
3501 -1ULL
3502 }
3503 #endif
3504 },
3505 { "mulhha_su.sn", TILEPRO_OPC_MULHHA_SU_SN, 0x1, 3, TREG_SN, 1,
3506 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3507 #ifndef DISASM_ONLY
3508 {
3509 0x800000007ffc0000ULL,
3510 0ULL,
3511 0ULL,
3512 0ULL,
3513 0ULL
3514 },
3515 {
3516 0x00000000085c0000ULL,
3517 -1ULL,
3518 -1ULL,
3519 -1ULL,
3520 -1ULL
3521 }
3522 #endif
3523 },
3524 { "mulhha_uu", TILEPRO_OPC_MULHHA_UU, 0x5, 3, TREG_ZERO, 1,
3525 { { 21, 10, 16 }, { 0, }, { 31, 12, 18 }, { 0, }, { 0, } },
3526 #ifndef DISASM_ONLY
3527 {
3528 0x800000007ffc0000ULL,
3529 0ULL,
3530 0x80000000780c0000ULL,
3531 0ULL,
3532 0ULL
3533 },
3534 {
3535 0x0000000000600000ULL,
3536 -1ULL,
3537 0x8000000040040000ULL,
3538 -1ULL,
3539 -1ULL
3540 }
3541 #endif
3542 },
3543 { "mulhha_uu.sn", TILEPRO_OPC_MULHHA_UU_SN, 0x1, 3, TREG_SN, 1,
3544 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3545 #ifndef DISASM_ONLY
3546 {
3547 0x800000007ffc0000ULL,
3548 0ULL,
3549 0ULL,
3550 0ULL,
3551 0ULL
3552 },
3553 {
3554 0x0000000008600000ULL,
3555 -1ULL,
3556 -1ULL,
3557 -1ULL,
3558 -1ULL
3559 }
3560 #endif
3561 },
3562 { "mulhhsa_uu", TILEPRO_OPC_MULHHSA_UU, 0x1, 3, TREG_ZERO, 1,
3563 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3564 #ifndef DISASM_ONLY
3565 {
3566 0x800000007ffc0000ULL,
3567 0ULL,
3568 0ULL,
3569 0ULL,
3570 0ULL
3571 },
3572 {
3573 0x0000000000640000ULL,
3574 -1ULL,
3575 -1ULL,
3576 -1ULL,
3577 -1ULL
3578 }
3579 #endif
3580 },
3581 { "mulhhsa_uu.sn", TILEPRO_OPC_MULHHSA_UU_SN, 0x1, 3, TREG_SN, 1,
3582 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3583 #ifndef DISASM_ONLY
3584 {
3585 0x800000007ffc0000ULL,
3586 0ULL,
3587 0ULL,
3588 0ULL,
3589 0ULL
3590 },
3591 {
3592 0x0000000008640000ULL,
3593 -1ULL,
3594 -1ULL,
3595 -1ULL,
3596 -1ULL
3597 }
3598 #endif
3599 },
3600 { "mulhl_ss", TILEPRO_OPC_MULHL_SS, 0x1, 3, TREG_ZERO, 1,
3601 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3602 #ifndef DISASM_ONLY
3603 {
3604 0x800000007ffc0000ULL,
3605 0ULL,
3606 0ULL,
3607 0ULL,
3608 0ULL
3609 },
3610 {
3611 0x0000000000880000ULL,
3612 -1ULL,
3613 -1ULL,
3614 -1ULL,
3615 -1ULL
3616 }
3617 #endif
3618 },
3619 { "mulhl_ss.sn", TILEPRO_OPC_MULHL_SS_SN, 0x1, 3, TREG_SN, 1,
3620 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3621 #ifndef DISASM_ONLY
3622 {
3623 0x800000007ffc0000ULL,
3624 0ULL,
3625 0ULL,
3626 0ULL,
3627 0ULL
3628 },
3629 {
3630 0x0000000008880000ULL,
3631 -1ULL,
3632 -1ULL,
3633 -1ULL,
3634 -1ULL
3635 }
3636 #endif
3637 },
3638 { "mulhl_su", TILEPRO_OPC_MULHL_SU, 0x1, 3, TREG_ZERO, 1,
3639 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3640 #ifndef DISASM_ONLY
3641 {
3642 0x800000007ffc0000ULL,
3643 0ULL,
3644 0ULL,
3645 0ULL,
3646 0ULL
3647 },
3648 {
3649 0x00000000008c0000ULL,
3650 -1ULL,
3651 -1ULL,
3652 -1ULL,
3653 -1ULL
3654 }
3655 #endif
3656 },
3657 { "mulhl_su.sn", TILEPRO_OPC_MULHL_SU_SN, 0x1, 3, TREG_SN, 1,
3658 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3659 #ifndef DISASM_ONLY
3660 {
3661 0x800000007ffc0000ULL,
3662 0ULL,
3663 0ULL,
3664 0ULL,
3665 0ULL
3666 },
3667 {
3668 0x00000000088c0000ULL,
3669 -1ULL,
3670 -1ULL,
3671 -1ULL,
3672 -1ULL
3673 }
3674 #endif
3675 },
3676 { "mulhl_us", TILEPRO_OPC_MULHL_US, 0x1, 3, TREG_ZERO, 1,
3677 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3678 #ifndef DISASM_ONLY
3679 {
3680 0x800000007ffc0000ULL,
3681 0ULL,
3682 0ULL,
3683 0ULL,
3684 0ULL
3685 },
3686 {
3687 0x0000000000900000ULL,
3688 -1ULL,
3689 -1ULL,
3690 -1ULL,
3691 -1ULL
3692 }
3693 #endif
3694 },
3695 { "mulhl_us.sn", TILEPRO_OPC_MULHL_US_SN, 0x1, 3, TREG_SN, 1,
3696 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3697 #ifndef DISASM_ONLY
3698 {
3699 0x800000007ffc0000ULL,
3700 0ULL,
3701 0ULL,
3702 0ULL,
3703 0ULL
3704 },
3705 {
3706 0x0000000008900000ULL,
3707 -1ULL,
3708 -1ULL,
3709 -1ULL,
3710 -1ULL
3711 }
3712 #endif
3713 },
3714 { "mulhl_uu", TILEPRO_OPC_MULHL_UU, 0x1, 3, TREG_ZERO, 1,
3715 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3716 #ifndef DISASM_ONLY
3717 {
3718 0x800000007ffc0000ULL,
3719 0ULL,
3720 0ULL,
3721 0ULL,
3722 0ULL
3723 },
3724 {
3725 0x0000000000940000ULL,
3726 -1ULL,
3727 -1ULL,
3728 -1ULL,
3729 -1ULL
3730 }
3731 #endif
3732 },
3733 { "mulhl_uu.sn", TILEPRO_OPC_MULHL_UU_SN, 0x1, 3, TREG_SN, 1,
3734 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3735 #ifndef DISASM_ONLY
3736 {
3737 0x800000007ffc0000ULL,
3738 0ULL,
3739 0ULL,
3740 0ULL,
3741 0ULL
3742 },
3743 {
3744 0x0000000008940000ULL,
3745 -1ULL,
3746 -1ULL,
3747 -1ULL,
3748 -1ULL
3749 }
3750 #endif
3751 },
3752 { "mulhla_ss", TILEPRO_OPC_MULHLA_SS, 0x1, 3, TREG_ZERO, 1,
3753 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3754 #ifndef DISASM_ONLY
3755 {
3756 0x800000007ffc0000ULL,
3757 0ULL,
3758 0ULL,
3759 0ULL,
3760 0ULL
3761 },
3762 {
3763 0x0000000000740000ULL,
3764 -1ULL,
3765 -1ULL,
3766 -1ULL,
3767 -1ULL
3768 }
3769 #endif
3770 },
3771 { "mulhla_ss.sn", TILEPRO_OPC_MULHLA_SS_SN, 0x1, 3, TREG_SN, 1,
3772 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3773 #ifndef DISASM_ONLY
3774 {
3775 0x800000007ffc0000ULL,
3776 0ULL,
3777 0ULL,
3778 0ULL,
3779 0ULL
3780 },
3781 {
3782 0x0000000008740000ULL,
3783 -1ULL,
3784 -1ULL,
3785 -1ULL,
3786 -1ULL
3787 }
3788 #endif
3789 },
3790 { "mulhla_su", TILEPRO_OPC_MULHLA_SU, 0x1, 3, TREG_ZERO, 1,
3791 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3792 #ifndef DISASM_ONLY
3793 {
3794 0x800000007ffc0000ULL,
3795 0ULL,
3796 0ULL,
3797 0ULL,
3798 0ULL
3799 },
3800 {
3801 0x0000000000780000ULL,
3802 -1ULL,
3803 -1ULL,
3804 -1ULL,
3805 -1ULL
3806 }
3807 #endif
3808 },
3809 { "mulhla_su.sn", TILEPRO_OPC_MULHLA_SU_SN, 0x1, 3, TREG_SN, 1,
3810 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3811 #ifndef DISASM_ONLY
3812 {
3813 0x800000007ffc0000ULL,
3814 0ULL,
3815 0ULL,
3816 0ULL,
3817 0ULL
3818 },
3819 {
3820 0x0000000008780000ULL,
3821 -1ULL,
3822 -1ULL,
3823 -1ULL,
3824 -1ULL
3825 }
3826 #endif
3827 },
3828 { "mulhla_us", TILEPRO_OPC_MULHLA_US, 0x1, 3, TREG_ZERO, 1,
3829 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3830 #ifndef DISASM_ONLY
3831 {
3832 0x800000007ffc0000ULL,
3833 0ULL,
3834 0ULL,
3835 0ULL,
3836 0ULL
3837 },
3838 {
3839 0x00000000007c0000ULL,
3840 -1ULL,
3841 -1ULL,
3842 -1ULL,
3843 -1ULL
3844 }
3845 #endif
3846 },
3847 { "mulhla_us.sn", TILEPRO_OPC_MULHLA_US_SN, 0x1, 3, TREG_SN, 1,
3848 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3849 #ifndef DISASM_ONLY
3850 {
3851 0x800000007ffc0000ULL,
3852 0ULL,
3853 0ULL,
3854 0ULL,
3855 0ULL
3856 },
3857 {
3858 0x00000000087c0000ULL,
3859 -1ULL,
3860 -1ULL,
3861 -1ULL,
3862 -1ULL
3863 }
3864 #endif
3865 },
3866 { "mulhla_uu", TILEPRO_OPC_MULHLA_UU, 0x1, 3, TREG_ZERO, 1,
3867 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3868 #ifndef DISASM_ONLY
3869 {
3870 0x800000007ffc0000ULL,
3871 0ULL,
3872 0ULL,
3873 0ULL,
3874 0ULL
3875 },
3876 {
3877 0x0000000000800000ULL,
3878 -1ULL,
3879 -1ULL,
3880 -1ULL,
3881 -1ULL
3882 }
3883 #endif
3884 },
3885 { "mulhla_uu.sn", TILEPRO_OPC_MULHLA_UU_SN, 0x1, 3, TREG_SN, 1,
3886 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3887 #ifndef DISASM_ONLY
3888 {
3889 0x800000007ffc0000ULL,
3890 0ULL,
3891 0ULL,
3892 0ULL,
3893 0ULL
3894 },
3895 {
3896 0x0000000008800000ULL,
3897 -1ULL,
3898 -1ULL,
3899 -1ULL,
3900 -1ULL
3901 }
3902 #endif
3903 },
3904 { "mulhlsa_uu", TILEPRO_OPC_MULHLSA_UU, 0x5, 3, TREG_ZERO, 1,
3905 { { 21, 10, 16 }, { 0, }, { 31, 12, 18 }, { 0, }, { 0, } },
3906 #ifndef DISASM_ONLY
3907 {
3908 0x800000007ffc0000ULL,
3909 0ULL,
3910 0x80000000780c0000ULL,
3911 0ULL,
3912 0ULL
3913 },
3914 {
3915 0x0000000000840000ULL,
3916 -1ULL,
3917 0x8000000030000000ULL,
3918 -1ULL,
3919 -1ULL
3920 }
3921 #endif
3922 },
3923 { "mulhlsa_uu.sn", TILEPRO_OPC_MULHLSA_UU_SN, 0x1, 3, TREG_SN, 1,
3924 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3925 #ifndef DISASM_ONLY
3926 {
3927 0x800000007ffc0000ULL,
3928 0ULL,
3929 0ULL,
3930 0ULL,
3931 0ULL
3932 },
3933 {
3934 0x0000000008840000ULL,
3935 -1ULL,
3936 -1ULL,
3937 -1ULL,
3938 -1ULL
3939 }
3940 #endif
3941 },
3942 { "mulll_ss", TILEPRO_OPC_MULLL_SS, 0x5, 3, TREG_ZERO, 1,
3943 { { 9, 10, 16 }, { 0, }, { 11, 12, 18 }, { 0, }, { 0, } },
3944 #ifndef DISASM_ONLY
3945 {
3946 0x800000007ffc0000ULL,
3947 0ULL,
3948 0x80000000780c0000ULL,
3949 0ULL,
3950 0ULL
3951 },
3952 {
3953 0x0000000000a80000ULL,
3954 -1ULL,
3955 0x8000000038080000ULL,
3956 -1ULL,
3957 -1ULL
3958 }
3959 #endif
3960 },
3961 { "mulll_ss.sn", TILEPRO_OPC_MULLL_SS_SN, 0x1, 3, TREG_SN, 1,
3962 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3963 #ifndef DISASM_ONLY
3964 {
3965 0x800000007ffc0000ULL,
3966 0ULL,
3967 0ULL,
3968 0ULL,
3969 0ULL
3970 },
3971 {
3972 0x0000000008a80000ULL,
3973 -1ULL,
3974 -1ULL,
3975 -1ULL,
3976 -1ULL
3977 }
3978 #endif
3979 },
3980 { "mulll_su", TILEPRO_OPC_MULLL_SU, 0x1, 3, TREG_ZERO, 1,
3981 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
3982 #ifndef DISASM_ONLY
3983 {
3984 0x800000007ffc0000ULL,
3985 0ULL,
3986 0ULL,
3987 0ULL,
3988 0ULL
3989 },
3990 {
3991 0x0000000000ac0000ULL,
3992 -1ULL,
3993 -1ULL,
3994 -1ULL,
3995 -1ULL
3996 }
3997 #endif
3998 },
3999 { "mulll_su.sn", TILEPRO_OPC_MULLL_SU_SN, 0x1, 3, TREG_SN, 1,
4000 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4001 #ifndef DISASM_ONLY
4002 {
4003 0x800000007ffc0000ULL,
4004 0ULL,
4005 0ULL,
4006 0ULL,
4007 0ULL
4008 },
4009 {
4010 0x0000000008ac0000ULL,
4011 -1ULL,
4012 -1ULL,
4013 -1ULL,
4014 -1ULL
4015 }
4016 #endif
4017 },
4018 { "mulll_uu", TILEPRO_OPC_MULLL_UU, 0x5, 3, TREG_ZERO, 1,
4019 { { 9, 10, 16 }, { 0, }, { 11, 12, 18 }, { 0, }, { 0, } },
4020 #ifndef DISASM_ONLY
4021 {
4022 0x800000007ffc0000ULL,
4023 0ULL,
4024 0x80000000780c0000ULL,
4025 0ULL,
4026 0ULL
4027 },
4028 {
4029 0x0000000000b00000ULL,
4030 -1ULL,
4031 0x80000000380c0000ULL,
4032 -1ULL,
4033 -1ULL
4034 }
4035 #endif
4036 },
4037 { "mulll_uu.sn", TILEPRO_OPC_MULLL_UU_SN, 0x1, 3, TREG_SN, 1,
4038 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4039 #ifndef DISASM_ONLY
4040 {
4041 0x800000007ffc0000ULL,
4042 0ULL,
4043 0ULL,
4044 0ULL,
4045 0ULL
4046 },
4047 {
4048 0x0000000008b00000ULL,
4049 -1ULL,
4050 -1ULL,
4051 -1ULL,
4052 -1ULL
4053 }
4054 #endif
4055 },
4056 { "mullla_ss", TILEPRO_OPC_MULLLA_SS, 0x5, 3, TREG_ZERO, 1,
4057 { { 21, 10, 16 }, { 0, }, { 31, 12, 18 }, { 0, }, { 0, } },
4058 #ifndef DISASM_ONLY
4059 {
4060 0x800000007ffc0000ULL,
4061 0ULL,
4062 0x80000000780c0000ULL,
4063 0ULL,
4064 0ULL
4065 },
4066 {
4067 0x0000000000980000ULL,
4068 -1ULL,
4069 0x8000000040080000ULL,
4070 -1ULL,
4071 -1ULL
4072 }
4073 #endif
4074 },
4075 { "mullla_ss.sn", TILEPRO_OPC_MULLLA_SS_SN, 0x1, 3, TREG_SN, 1,
4076 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4077 #ifndef DISASM_ONLY
4078 {
4079 0x800000007ffc0000ULL,
4080 0ULL,
4081 0ULL,
4082 0ULL,
4083 0ULL
4084 },
4085 {
4086 0x0000000008980000ULL,
4087 -1ULL,
4088 -1ULL,
4089 -1ULL,
4090 -1ULL
4091 }
4092 #endif
4093 },
4094 { "mullla_su", TILEPRO_OPC_MULLLA_SU, 0x1, 3, TREG_ZERO, 1,
4095 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4096 #ifndef DISASM_ONLY
4097 {
4098 0x800000007ffc0000ULL,
4099 0ULL,
4100 0ULL,
4101 0ULL,
4102 0ULL
4103 },
4104 {
4105 0x00000000009c0000ULL,
4106 -1ULL,
4107 -1ULL,
4108 -1ULL,
4109 -1ULL
4110 }
4111 #endif
4112 },
4113 { "mullla_su.sn", TILEPRO_OPC_MULLLA_SU_SN, 0x1, 3, TREG_SN, 1,
4114 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4115 #ifndef DISASM_ONLY
4116 {
4117 0x800000007ffc0000ULL,
4118 0ULL,
4119 0ULL,
4120 0ULL,
4121 0ULL
4122 },
4123 {
4124 0x00000000089c0000ULL,
4125 -1ULL,
4126 -1ULL,
4127 -1ULL,
4128 -1ULL
4129 }
4130 #endif
4131 },
4132 { "mullla_uu", TILEPRO_OPC_MULLLA_UU, 0x5, 3, TREG_ZERO, 1,
4133 { { 21, 10, 16 }, { 0, }, { 31, 12, 18 }, { 0, }, { 0, } },
4134 #ifndef DISASM_ONLY
4135 {
4136 0x800000007ffc0000ULL,
4137 0ULL,
4138 0x80000000780c0000ULL,
4139 0ULL,
4140 0ULL
4141 },
4142 {
4143 0x0000000000a00000ULL,
4144 -1ULL,
4145 0x80000000400c0000ULL,
4146 -1ULL,
4147 -1ULL
4148 }
4149 #endif
4150 },
4151 { "mullla_uu.sn", TILEPRO_OPC_MULLLA_UU_SN, 0x1, 3, TREG_SN, 1,
4152 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4153 #ifndef DISASM_ONLY
4154 {
4155 0x800000007ffc0000ULL,
4156 0ULL,
4157 0ULL,
4158 0ULL,
4159 0ULL
4160 },
4161 {
4162 0x0000000008a00000ULL,
4163 -1ULL,
4164 -1ULL,
4165 -1ULL,
4166 -1ULL
4167 }
4168 #endif
4169 },
4170 { "mulllsa_uu", TILEPRO_OPC_MULLLSA_UU, 0x1, 3, TREG_ZERO, 1,
4171 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4172 #ifndef DISASM_ONLY
4173 {
4174 0x800000007ffc0000ULL,
4175 0ULL,
4176 0ULL,
4177 0ULL,
4178 0ULL
4179 },
4180 {
4181 0x0000000000a40000ULL,
4182 -1ULL,
4183 -1ULL,
4184 -1ULL,
4185 -1ULL
4186 }
4187 #endif
4188 },
4189 { "mulllsa_uu.sn", TILEPRO_OPC_MULLLSA_UU_SN, 0x1, 3, TREG_SN, 1,
4190 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4191 #ifndef DISASM_ONLY
4192 {
4193 0x800000007ffc0000ULL,
4194 0ULL,
4195 0ULL,
4196 0ULL,
4197 0ULL
4198 },
4199 {
4200 0x0000000008a40000ULL,
4201 -1ULL,
4202 -1ULL,
4203 -1ULL,
4204 -1ULL
4205 }
4206 #endif
4207 },
4208 { "mvnz", TILEPRO_OPC_MVNZ, 0x5, 3, TREG_ZERO, 1,
4209 { { 21, 10, 16 }, { 0, }, { 31, 12, 18 }, { 0, }, { 0, } },
4210 #ifndef DISASM_ONLY
4211 {
4212 0x800000007ffc0000ULL,
4213 0ULL,
4214 0x80000000780c0000ULL,
4215 0ULL,
4216 0ULL
4217 },
4218 {
4219 0x0000000000b40000ULL,
4220 -1ULL,
4221 0x8000000010040000ULL,
4222 -1ULL,
4223 -1ULL
4224 }
4225 #endif
4226 },
4227 { "mvnz.sn", TILEPRO_OPC_MVNZ_SN, 0x1, 3, TREG_SN, 1,
4228 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4229 #ifndef DISASM_ONLY
4230 {
4231 0x800000007ffc0000ULL,
4232 0ULL,
4233 0ULL,
4234 0ULL,
4235 0ULL
4236 },
4237 {
4238 0x0000000008b40000ULL,
4239 -1ULL,
4240 -1ULL,
4241 -1ULL,
4242 -1ULL
4243 }
4244 #endif
4245 },
4246 { "mvz", TILEPRO_OPC_MVZ, 0x5, 3, TREG_ZERO, 1,
4247 { { 21, 10, 16 }, { 0, }, { 31, 12, 18 }, { 0, }, { 0, } },
4248 #ifndef DISASM_ONLY
4249 {
4250 0x800000007ffc0000ULL,
4251 0ULL,
4252 0x80000000780c0000ULL,
4253 0ULL,
4254 0ULL
4255 },
4256 {
4257 0x0000000000b80000ULL,
4258 -1ULL,
4259 0x8000000010080000ULL,
4260 -1ULL,
4261 -1ULL
4262 }
4263 #endif
4264 },
4265 { "mvz.sn", TILEPRO_OPC_MVZ_SN, 0x1, 3, TREG_SN, 1,
4266 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4267 #ifndef DISASM_ONLY
4268 {
4269 0x800000007ffc0000ULL,
4270 0ULL,
4271 0ULL,
4272 0ULL,
4273 0ULL
4274 },
4275 {
4276 0x0000000008b80000ULL,
4277 -1ULL,
4278 -1ULL,
4279 -1ULL,
4280 -1ULL
4281 }
4282 #endif
4283 },
4284 { "mz", TILEPRO_OPC_MZ, 0xf, 3, TREG_ZERO, 1,
4285 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
4286 #ifndef DISASM_ONLY
4287 {
4288 0x800000007ffc0000ULL,
4289 0xfffe000000000000ULL,
4290 0x80000000780c0000ULL,
4291 0xf806000000000000ULL,
4292 0ULL
4293 },
4294 {
4295 0x0000000000c40000ULL,
4296 0x082e000000000000ULL,
4297 0x80000000100c0000ULL,
4298 0x9004000000000000ULL,
4299 -1ULL
4300 }
4301 #endif
4302 },
4303 { "mz.sn", TILEPRO_OPC_MZ_SN, 0x3, 3, TREG_SN, 1,
4304 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4305 #ifndef DISASM_ONLY
4306 {
4307 0x800000007ffc0000ULL,
4308 0xfffe000000000000ULL,
4309 0ULL,
4310 0ULL,
4311 0ULL
4312 },
4313 {
4314 0x0000000008c40000ULL,
4315 0x0c2e000000000000ULL,
4316 -1ULL,
4317 -1ULL,
4318 -1ULL
4319 }
4320 #endif
4321 },
4322 { "mzb", TILEPRO_OPC_MZB, 0x3, 3, TREG_ZERO, 1,
4323 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4324 #ifndef DISASM_ONLY
4325 {
4326 0x800000007ffc0000ULL,
4327 0xfffe000000000000ULL,
4328 0ULL,
4329 0ULL,
4330 0ULL
4331 },
4332 {
4333 0x0000000000bc0000ULL,
4334 0x082a000000000000ULL,
4335 -1ULL,
4336 -1ULL,
4337 -1ULL
4338 }
4339 #endif
4340 },
4341 { "mzb.sn", TILEPRO_OPC_MZB_SN, 0x3, 3, TREG_SN, 1,
4342 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4343 #ifndef DISASM_ONLY
4344 {
4345 0x800000007ffc0000ULL,
4346 0xfffe000000000000ULL,
4347 0ULL,
4348 0ULL,
4349 0ULL
4350 },
4351 {
4352 0x0000000008bc0000ULL,
4353 0x0c2a000000000000ULL,
4354 -1ULL,
4355 -1ULL,
4356 -1ULL
4357 }
4358 #endif
4359 },
4360 { "mzh", TILEPRO_OPC_MZH, 0x3, 3, TREG_ZERO, 1,
4361 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4362 #ifndef DISASM_ONLY
4363 {
4364 0x800000007ffc0000ULL,
4365 0xfffe000000000000ULL,
4366 0ULL,
4367 0ULL,
4368 0ULL
4369 },
4370 {
4371 0x0000000000c00000ULL,
4372 0x082c000000000000ULL,
4373 -1ULL,
4374 -1ULL,
4375 -1ULL
4376 }
4377 #endif
4378 },
4379 { "mzh.sn", TILEPRO_OPC_MZH_SN, 0x3, 3, TREG_SN, 1,
4380 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4381 #ifndef DISASM_ONLY
4382 {
4383 0x800000007ffc0000ULL,
4384 0xfffe000000000000ULL,
4385 0ULL,
4386 0ULL,
4387 0ULL
4388 },
4389 {
4390 0x0000000008c00000ULL,
4391 0x0c2c000000000000ULL,
4392 -1ULL,
4393 -1ULL,
4394 -1ULL
4395 }
4396 #endif
4397 },
4398 { "nap", TILEPRO_OPC_NAP, 0x2, 0, TREG_ZERO, 0,
4399 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
4400 #ifndef DISASM_ONLY
4401 {
4402 0ULL,
4403 0xfbfff80000000000ULL,
4404 0ULL,
4405 0ULL,
4406 0ULL
4407 },
4408 {
4409 -1ULL,
4410 0x400b800000000000ULL,
4411 -1ULL,
4412 -1ULL,
4413 -1ULL
4414 }
4415 #endif
4416 },
4417 { "nop", TILEPRO_OPC_NOP, 0xf, 0, TREG_ZERO, 1,
4418 { { }, { }, { }, { }, { 0, } },
4419 #ifndef DISASM_ONLY
4420 {
4421 0x8000000077fff000ULL,
4422 0xfbfff80000000000ULL,
4423 0x80000000780ff000ULL,
4424 0xf807f80000000000ULL,
4425 0ULL
4426 },
4427 {
4428 0x0000000070166000ULL,
4429 0x400b880000000000ULL,
4430 0x80000000680a6000ULL,
4431 0xd805180000000000ULL,
4432 -1ULL
4433 }
4434 #endif
4435 },
4436 { "nor", TILEPRO_OPC_NOR, 0xf, 3, TREG_ZERO, 1,
4437 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
4438 #ifndef DISASM_ONLY
4439 {
4440 0x800000007ffc0000ULL,
4441 0xfffe000000000000ULL,
4442 0x80000000780c0000ULL,
4443 0xf806000000000000ULL,
4444 0ULL
4445 },
4446 {
4447 0x0000000000c80000ULL,
4448 0x0830000000000000ULL,
4449 0x8000000018040000ULL,
4450 0x9802000000000000ULL,
4451 -1ULL
4452 }
4453 #endif
4454 },
4455 { "nor.sn", TILEPRO_OPC_NOR_SN, 0x3, 3, TREG_SN, 1,
4456 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4457 #ifndef DISASM_ONLY
4458 {
4459 0x800000007ffc0000ULL,
4460 0xfffe000000000000ULL,
4461 0ULL,
4462 0ULL,
4463 0ULL
4464 },
4465 {
4466 0x0000000008c80000ULL,
4467 0x0c30000000000000ULL,
4468 -1ULL,
4469 -1ULL,
4470 -1ULL
4471 }
4472 #endif
4473 },
4474 { "or", TILEPRO_OPC_OR, 0xf, 3, TREG_ZERO, 1,
4475 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
4476 #ifndef DISASM_ONLY
4477 {
4478 0x800000007ffc0000ULL,
4479 0xfffe000000000000ULL,
4480 0x80000000780c0000ULL,
4481 0xf806000000000000ULL,
4482 0ULL
4483 },
4484 {
4485 0x0000000000cc0000ULL,
4486 0x0832000000000000ULL,
4487 0x8000000018080000ULL,
4488 0x9804000000000000ULL,
4489 -1ULL
4490 }
4491 #endif
4492 },
4493 { "or.sn", TILEPRO_OPC_OR_SN, 0x3, 3, TREG_SN, 1,
4494 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4495 #ifndef DISASM_ONLY
4496 {
4497 0x800000007ffc0000ULL,
4498 0xfffe000000000000ULL,
4499 0ULL,
4500 0ULL,
4501 0ULL
4502 },
4503 {
4504 0x0000000008cc0000ULL,
4505 0x0c32000000000000ULL,
4506 -1ULL,
4507 -1ULL,
4508 -1ULL
4509 }
4510 #endif
4511 },
4512 { "ori", TILEPRO_OPC_ORI, 0xf, 3, TREG_ZERO, 1,
4513 { { 9, 10, 0 }, { 7, 8, 1 }, { 11, 12, 2 }, { 13, 14, 3 }, { 0, } },
4514 #ifndef DISASM_ONLY
4515 {
4516 0x800000007ff00000ULL,
4517 0xfff8000000000000ULL,
4518 0x8000000078000000ULL,
4519 0xf800000000000000ULL,
4520 0ULL
4521 },
4522 {
4523 0x0000000040800000ULL,
4524 0x3058000000000000ULL,
4525 0x8000000058000000ULL,
4526 0xc800000000000000ULL,
4527 -1ULL
4528 }
4529 #endif
4530 },
4531 { "ori.sn", TILEPRO_OPC_ORI_SN, 0x3, 3, TREG_SN, 1,
4532 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
4533 #ifndef DISASM_ONLY
4534 {
4535 0x800000007ff00000ULL,
4536 0xfff8000000000000ULL,
4537 0ULL,
4538 0ULL,
4539 0ULL
4540 },
4541 {
4542 0x0000000048800000ULL,
4543 0x3458000000000000ULL,
4544 -1ULL,
4545 -1ULL,
4546 -1ULL
4547 }
4548 #endif
4549 },
4550 { "packbs_u", TILEPRO_OPC_PACKBS_U, 0x3, 3, TREG_ZERO, 1,
4551 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4552 #ifndef DISASM_ONLY
4553 {
4554 0x800000007ffc0000ULL,
4555 0xfffe000000000000ULL,
4556 0ULL,
4557 0ULL,
4558 0ULL
4559 },
4560 {
4561 0x00000000019c0000ULL,
4562 0x0892000000000000ULL,
4563 -1ULL,
4564 -1ULL,
4565 -1ULL
4566 }
4567 #endif
4568 },
4569 { "packbs_u.sn", TILEPRO_OPC_PACKBS_U_SN, 0x3, 3, TREG_SN, 1,
4570 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4571 #ifndef DISASM_ONLY
4572 {
4573 0x800000007ffc0000ULL,
4574 0xfffe000000000000ULL,
4575 0ULL,
4576 0ULL,
4577 0ULL
4578 },
4579 {
4580 0x00000000099c0000ULL,
4581 0x0c92000000000000ULL,
4582 -1ULL,
4583 -1ULL,
4584 -1ULL
4585 }
4586 #endif
4587 },
4588 { "packhb", TILEPRO_OPC_PACKHB, 0x3, 3, TREG_ZERO, 1,
4589 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4590 #ifndef DISASM_ONLY
4591 {
4592 0x800000007ffc0000ULL,
4593 0xfffe000000000000ULL,
4594 0ULL,
4595 0ULL,
4596 0ULL
4597 },
4598 {
4599 0x0000000000d00000ULL,
4600 0x0834000000000000ULL,
4601 -1ULL,
4602 -1ULL,
4603 -1ULL
4604 }
4605 #endif
4606 },
4607 { "packhb.sn", TILEPRO_OPC_PACKHB_SN, 0x3, 3, TREG_SN, 1,
4608 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4609 #ifndef DISASM_ONLY
4610 {
4611 0x800000007ffc0000ULL,
4612 0xfffe000000000000ULL,
4613 0ULL,
4614 0ULL,
4615 0ULL
4616 },
4617 {
4618 0x0000000008d00000ULL,
4619 0x0c34000000000000ULL,
4620 -1ULL,
4621 -1ULL,
4622 -1ULL
4623 }
4624 #endif
4625 },
4626 { "packhs", TILEPRO_OPC_PACKHS, 0x3, 3, TREG_ZERO, 1,
4627 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4628 #ifndef DISASM_ONLY
4629 {
4630 0x800000007ffc0000ULL,
4631 0xfffe000000000000ULL,
4632 0ULL,
4633 0ULL,
4634 0ULL
4635 },
4636 {
4637 0x0000000001980000ULL,
4638 0x0890000000000000ULL,
4639 -1ULL,
4640 -1ULL,
4641 -1ULL
4642 }
4643 #endif
4644 },
4645 { "packhs.sn", TILEPRO_OPC_PACKHS_SN, 0x3, 3, TREG_SN, 1,
4646 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4647 #ifndef DISASM_ONLY
4648 {
4649 0x800000007ffc0000ULL,
4650 0xfffe000000000000ULL,
4651 0ULL,
4652 0ULL,
4653 0ULL
4654 },
4655 {
4656 0x0000000009980000ULL,
4657 0x0c90000000000000ULL,
4658 -1ULL,
4659 -1ULL,
4660 -1ULL
4661 }
4662 #endif
4663 },
4664 { "packlb", TILEPRO_OPC_PACKLB, 0x3, 3, TREG_ZERO, 1,
4665 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4666 #ifndef DISASM_ONLY
4667 {
4668 0x800000007ffc0000ULL,
4669 0xfffe000000000000ULL,
4670 0ULL,
4671 0ULL,
4672 0ULL
4673 },
4674 {
4675 0x0000000000d40000ULL,
4676 0x0836000000000000ULL,
4677 -1ULL,
4678 -1ULL,
4679 -1ULL
4680 }
4681 #endif
4682 },
4683 { "packlb.sn", TILEPRO_OPC_PACKLB_SN, 0x3, 3, TREG_SN, 1,
4684 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4685 #ifndef DISASM_ONLY
4686 {
4687 0x800000007ffc0000ULL,
4688 0xfffe000000000000ULL,
4689 0ULL,
4690 0ULL,
4691 0ULL
4692 },
4693 {
4694 0x0000000008d40000ULL,
4695 0x0c36000000000000ULL,
4696 -1ULL,
4697 -1ULL,
4698 -1ULL
4699 }
4700 #endif
4701 },
4702 { "pcnt", TILEPRO_OPC_PCNT, 0x5, 2, TREG_ZERO, 1,
4703 { { 9, 10 }, { 0, }, { 11, 12 }, { 0, }, { 0, } },
4704 #ifndef DISASM_ONLY
4705 {
4706 0x800000007ffff000ULL,
4707 0ULL,
4708 0x80000000780ff000ULL,
4709 0ULL,
4710 0ULL
4711 },
4712 {
4713 0x0000000070167000ULL,
4714 -1ULL,
4715 0x80000000680a7000ULL,
4716 -1ULL,
4717 -1ULL
4718 }
4719 #endif
4720 },
4721 { "pcnt.sn", TILEPRO_OPC_PCNT_SN, 0x1, 2, TREG_SN, 1,
4722 { { 9, 10 }, { 0, }, { 0, }, { 0, }, { 0, } },
4723 #ifndef DISASM_ONLY
4724 {
4725 0x800000007ffff000ULL,
4726 0ULL,
4727 0ULL,
4728 0ULL,
4729 0ULL
4730 },
4731 {
4732 0x0000000078167000ULL,
4733 -1ULL,
4734 -1ULL,
4735 -1ULL,
4736 -1ULL
4737 }
4738 #endif
4739 },
4740 { "rl", TILEPRO_OPC_RL, 0xf, 3, TREG_ZERO, 1,
4741 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
4742 #ifndef DISASM_ONLY
4743 {
4744 0x800000007ffc0000ULL,
4745 0xfffe000000000000ULL,
4746 0x80000000780c0000ULL,
4747 0xf806000000000000ULL,
4748 0ULL
4749 },
4750 {
4751 0x0000000000d80000ULL,
4752 0x0838000000000000ULL,
4753 0x8000000020000000ULL,
4754 0xa000000000000000ULL,
4755 -1ULL
4756 }
4757 #endif
4758 },
4759 { "rl.sn", TILEPRO_OPC_RL_SN, 0x3, 3, TREG_SN, 1,
4760 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4761 #ifndef DISASM_ONLY
4762 {
4763 0x800000007ffc0000ULL,
4764 0xfffe000000000000ULL,
4765 0ULL,
4766 0ULL,
4767 0ULL
4768 },
4769 {
4770 0x0000000008d80000ULL,
4771 0x0c38000000000000ULL,
4772 -1ULL,
4773 -1ULL,
4774 -1ULL
4775 }
4776 #endif
4777 },
4778 { "rli", TILEPRO_OPC_RLI, 0xf, 3, TREG_ZERO, 1,
4779 { { 9, 10, 32 }, { 7, 8, 33 }, { 11, 12, 34 }, { 13, 14, 35 }, { 0, } },
4780 #ifndef DISASM_ONLY
4781 {
4782 0x800000007ffe0000ULL,
4783 0xffff000000000000ULL,
4784 0x80000000780e0000ULL,
4785 0xf807000000000000ULL,
4786 0ULL
4787 },
4788 {
4789 0x0000000070020000ULL,
4790 0x4001000000000000ULL,
4791 0x8000000068020000ULL,
4792 0xd801000000000000ULL,
4793 -1ULL
4794 }
4795 #endif
4796 },
4797 { "rli.sn", TILEPRO_OPC_RLI_SN, 0x3, 3, TREG_SN, 1,
4798 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
4799 #ifndef DISASM_ONLY
4800 {
4801 0x800000007ffe0000ULL,
4802 0xffff000000000000ULL,
4803 0ULL,
4804 0ULL,
4805 0ULL
4806 },
4807 {
4808 0x0000000078020000ULL,
4809 0x4401000000000000ULL,
4810 -1ULL,
4811 -1ULL,
4812 -1ULL
4813 }
4814 #endif
4815 },
4816 { "s1a", TILEPRO_OPC_S1A, 0xf, 3, TREG_ZERO, 1,
4817 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
4818 #ifndef DISASM_ONLY
4819 {
4820 0x800000007ffc0000ULL,
4821 0xfffe000000000000ULL,
4822 0x80000000780c0000ULL,
4823 0xf806000000000000ULL,
4824 0ULL
4825 },
4826 {
4827 0x0000000000dc0000ULL,
4828 0x083a000000000000ULL,
4829 0x8000000008040000ULL,
4830 0x8802000000000000ULL,
4831 -1ULL
4832 }
4833 #endif
4834 },
4835 { "s1a.sn", TILEPRO_OPC_S1A_SN, 0x3, 3, TREG_SN, 1,
4836 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4837 #ifndef DISASM_ONLY
4838 {
4839 0x800000007ffc0000ULL,
4840 0xfffe000000000000ULL,
4841 0ULL,
4842 0ULL,
4843 0ULL
4844 },
4845 {
4846 0x0000000008dc0000ULL,
4847 0x0c3a000000000000ULL,
4848 -1ULL,
4849 -1ULL,
4850 -1ULL
4851 }
4852 #endif
4853 },
4854 { "s2a", TILEPRO_OPC_S2A, 0xf, 3, TREG_ZERO, 1,
4855 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
4856 #ifndef DISASM_ONLY
4857 {
4858 0x800000007ffc0000ULL,
4859 0xfffe000000000000ULL,
4860 0x80000000780c0000ULL,
4861 0xf806000000000000ULL,
4862 0ULL
4863 },
4864 {
4865 0x0000000000e00000ULL,
4866 0x083c000000000000ULL,
4867 0x8000000008080000ULL,
4868 0x8804000000000000ULL,
4869 -1ULL
4870 }
4871 #endif
4872 },
4873 { "s2a.sn", TILEPRO_OPC_S2A_SN, 0x3, 3, TREG_SN, 1,
4874 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4875 #ifndef DISASM_ONLY
4876 {
4877 0x800000007ffc0000ULL,
4878 0xfffe000000000000ULL,
4879 0ULL,
4880 0ULL,
4881 0ULL
4882 },
4883 {
4884 0x0000000008e00000ULL,
4885 0x0c3c000000000000ULL,
4886 -1ULL,
4887 -1ULL,
4888 -1ULL
4889 }
4890 #endif
4891 },
4892 { "s3a", TILEPRO_OPC_S3A, 0xf, 3, TREG_ZERO, 1,
4893 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
4894 #ifndef DISASM_ONLY
4895 {
4896 0x800000007ffc0000ULL,
4897 0xfffe000000000000ULL,
4898 0x80000000780c0000ULL,
4899 0xf806000000000000ULL,
4900 0ULL
4901 },
4902 {
4903 0x0000000000e40000ULL,
4904 0x083e000000000000ULL,
4905 0x8000000030040000ULL,
4906 0xb002000000000000ULL,
4907 -1ULL
4908 }
4909 #endif
4910 },
4911 { "s3a.sn", TILEPRO_OPC_S3A_SN, 0x3, 3, TREG_SN, 1,
4912 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
4913 #ifndef DISASM_ONLY
4914 {
4915 0x800000007ffc0000ULL,
4916 0xfffe000000000000ULL,
4917 0ULL,
4918 0ULL,
4919 0ULL
4920 },
4921 {
4922 0x0000000008e40000ULL,
4923 0x0c3e000000000000ULL,
4924 -1ULL,
4925 -1ULL,
4926 -1ULL
4927 }
4928 #endif
4929 },
4930 { "sadab_u", TILEPRO_OPC_SADAB_U, 0x1, 3, TREG_ZERO, 1,
4931 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4932 #ifndef DISASM_ONLY
4933 {
4934 0x800000007ffc0000ULL,
4935 0ULL,
4936 0ULL,
4937 0ULL,
4938 0ULL
4939 },
4940 {
4941 0x0000000000e80000ULL,
4942 -1ULL,
4943 -1ULL,
4944 -1ULL,
4945 -1ULL
4946 }
4947 #endif
4948 },
4949 { "sadab_u.sn", TILEPRO_OPC_SADAB_U_SN, 0x1, 3, TREG_SN, 1,
4950 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4951 #ifndef DISASM_ONLY
4952 {
4953 0x800000007ffc0000ULL,
4954 0ULL,
4955 0ULL,
4956 0ULL,
4957 0ULL
4958 },
4959 {
4960 0x0000000008e80000ULL,
4961 -1ULL,
4962 -1ULL,
4963 -1ULL,
4964 -1ULL
4965 }
4966 #endif
4967 },
4968 { "sadah", TILEPRO_OPC_SADAH, 0x1, 3, TREG_ZERO, 1,
4969 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4970 #ifndef DISASM_ONLY
4971 {
4972 0x800000007ffc0000ULL,
4973 0ULL,
4974 0ULL,
4975 0ULL,
4976 0ULL
4977 },
4978 {
4979 0x0000000000ec0000ULL,
4980 -1ULL,
4981 -1ULL,
4982 -1ULL,
4983 -1ULL
4984 }
4985 #endif
4986 },
4987 { "sadah.sn", TILEPRO_OPC_SADAH_SN, 0x1, 3, TREG_SN, 1,
4988 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
4989 #ifndef DISASM_ONLY
4990 {
4991 0x800000007ffc0000ULL,
4992 0ULL,
4993 0ULL,
4994 0ULL,
4995 0ULL
4996 },
4997 {
4998 0x0000000008ec0000ULL,
4999 -1ULL,
5000 -1ULL,
5001 -1ULL,
5002 -1ULL
5003 }
5004 #endif
5005 },
5006 { "sadah_u", TILEPRO_OPC_SADAH_U, 0x1, 3, TREG_ZERO, 1,
5007 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
5008 #ifndef DISASM_ONLY
5009 {
5010 0x800000007ffc0000ULL,
5011 0ULL,
5012 0ULL,
5013 0ULL,
5014 0ULL
5015 },
5016 {
5017 0x0000000000f00000ULL,
5018 -1ULL,
5019 -1ULL,
5020 -1ULL,
5021 -1ULL
5022 }
5023 #endif
5024 },
5025 { "sadah_u.sn", TILEPRO_OPC_SADAH_U_SN, 0x1, 3, TREG_SN, 1,
5026 { { 21, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
5027 #ifndef DISASM_ONLY
5028 {
5029 0x800000007ffc0000ULL,
5030 0ULL,
5031 0ULL,
5032 0ULL,
5033 0ULL
5034 },
5035 {
5036 0x0000000008f00000ULL,
5037 -1ULL,
5038 -1ULL,
5039 -1ULL,
5040 -1ULL
5041 }
5042 #endif
5043 },
5044 { "sadb_u", TILEPRO_OPC_SADB_U, 0x1, 3, TREG_ZERO, 1,
5045 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
5046 #ifndef DISASM_ONLY
5047 {
5048 0x800000007ffc0000ULL,
5049 0ULL,
5050 0ULL,
5051 0ULL,
5052 0ULL
5053 },
5054 {
5055 0x0000000000f40000ULL,
5056 -1ULL,
5057 -1ULL,
5058 -1ULL,
5059 -1ULL
5060 }
5061 #endif
5062 },
5063 { "sadb_u.sn", TILEPRO_OPC_SADB_U_SN, 0x1, 3, TREG_SN, 1,
5064 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
5065 #ifndef DISASM_ONLY
5066 {
5067 0x800000007ffc0000ULL,
5068 0ULL,
5069 0ULL,
5070 0ULL,
5071 0ULL
5072 },
5073 {
5074 0x0000000008f40000ULL,
5075 -1ULL,
5076 -1ULL,
5077 -1ULL,
5078 -1ULL
5079 }
5080 #endif
5081 },
5082 { "sadh", TILEPRO_OPC_SADH, 0x1, 3, TREG_ZERO, 1,
5083 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
5084 #ifndef DISASM_ONLY
5085 {
5086 0x800000007ffc0000ULL,
5087 0ULL,
5088 0ULL,
5089 0ULL,
5090 0ULL
5091 },
5092 {
5093 0x0000000000f80000ULL,
5094 -1ULL,
5095 -1ULL,
5096 -1ULL,
5097 -1ULL
5098 }
5099 #endif
5100 },
5101 { "sadh.sn", TILEPRO_OPC_SADH_SN, 0x1, 3, TREG_SN, 1,
5102 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
5103 #ifndef DISASM_ONLY
5104 {
5105 0x800000007ffc0000ULL,
5106 0ULL,
5107 0ULL,
5108 0ULL,
5109 0ULL
5110 },
5111 {
5112 0x0000000008f80000ULL,
5113 -1ULL,
5114 -1ULL,
5115 -1ULL,
5116 -1ULL
5117 }
5118 #endif
5119 },
5120 { "sadh_u", TILEPRO_OPC_SADH_U, 0x1, 3, TREG_ZERO, 1,
5121 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
5122 #ifndef DISASM_ONLY
5123 {
5124 0x800000007ffc0000ULL,
5125 0ULL,
5126 0ULL,
5127 0ULL,
5128 0ULL
5129 },
5130 {
5131 0x0000000000fc0000ULL,
5132 -1ULL,
5133 -1ULL,
5134 -1ULL,
5135 -1ULL
5136 }
5137 #endif
5138 },
5139 { "sadh_u.sn", TILEPRO_OPC_SADH_U_SN, 0x1, 3, TREG_SN, 1,
5140 { { 9, 10, 16 }, { 0, }, { 0, }, { 0, }, { 0, } },
5141 #ifndef DISASM_ONLY
5142 {
5143 0x800000007ffc0000ULL,
5144 0ULL,
5145 0ULL,
5146 0ULL,
5147 0ULL
5148 },
5149 {
5150 0x0000000008fc0000ULL,
5151 -1ULL,
5152 -1ULL,
5153 -1ULL,
5154 -1ULL
5155 }
5156 #endif
5157 },
5158 { "sb", TILEPRO_OPC_SB, 0x12, 2, TREG_ZERO, 1,
5159 { { 0, }, { 8, 17 }, { 0, }, { 0, }, { 15, 36 } },
5160 #ifndef DISASM_ONLY
5161 {
5162 0ULL,
5163 0xfbfe000000000000ULL,
5164 0ULL,
5165 0ULL,
5166 0x8700000000000000ULL
5167 },
5168 {
5169 -1ULL,
5170 0x0840000000000000ULL,
5171 -1ULL,
5172 -1ULL,
5173 0x8500000000000000ULL
5174 }
5175 #endif
5176 },
5177 { "sbadd", TILEPRO_OPC_SBADD, 0x2, 3, TREG_ZERO, 1,
5178 { { 0, }, { 24, 17, 37 }, { 0, }, { 0, }, { 0, } },
5179 #ifndef DISASM_ONLY
5180 {
5181 0ULL,
5182 0xfbf8000000000000ULL,
5183 0ULL,
5184 0ULL,
5185 0ULL
5186 },
5187 {
5188 -1ULL,
5189 0x30e0000000000000ULL,
5190 -1ULL,
5191 -1ULL,
5192 -1ULL
5193 }
5194 #endif
5195 },
5196 { "seq", TILEPRO_OPC_SEQ, 0xf, 3, TREG_ZERO, 1,
5197 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
5198 #ifndef DISASM_ONLY
5199 {
5200 0x800000007ffc0000ULL,
5201 0xfffe000000000000ULL,
5202 0x80000000780c0000ULL,
5203 0xf806000000000000ULL,
5204 0ULL
5205 },
5206 {
5207 0x0000000001080000ULL,
5208 0x0846000000000000ULL,
5209 0x8000000030080000ULL,
5210 0xb004000000000000ULL,
5211 -1ULL
5212 }
5213 #endif
5214 },
5215 { "seq.sn", TILEPRO_OPC_SEQ_SN, 0x3, 3, TREG_SN, 1,
5216 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5217 #ifndef DISASM_ONLY
5218 {
5219 0x800000007ffc0000ULL,
5220 0xfffe000000000000ULL,
5221 0ULL,
5222 0ULL,
5223 0ULL
5224 },
5225 {
5226 0x0000000009080000ULL,
5227 0x0c46000000000000ULL,
5228 -1ULL,
5229 -1ULL,
5230 -1ULL
5231 }
5232 #endif
5233 },
5234 { "seqb", TILEPRO_OPC_SEQB, 0x3, 3, TREG_ZERO, 1,
5235 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5236 #ifndef DISASM_ONLY
5237 {
5238 0x800000007ffc0000ULL,
5239 0xfffe000000000000ULL,
5240 0ULL,
5241 0ULL,
5242 0ULL
5243 },
5244 {
5245 0x0000000001000000ULL,
5246 0x0842000000000000ULL,
5247 -1ULL,
5248 -1ULL,
5249 -1ULL
5250 }
5251 #endif
5252 },
5253 { "seqb.sn", TILEPRO_OPC_SEQB_SN, 0x3, 3, TREG_SN, 1,
5254 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5255 #ifndef DISASM_ONLY
5256 {
5257 0x800000007ffc0000ULL,
5258 0xfffe000000000000ULL,
5259 0ULL,
5260 0ULL,
5261 0ULL
5262 },
5263 {
5264 0x0000000009000000ULL,
5265 0x0c42000000000000ULL,
5266 -1ULL,
5267 -1ULL,
5268 -1ULL
5269 }
5270 #endif
5271 },
5272 { "seqh", TILEPRO_OPC_SEQH, 0x3, 3, TREG_ZERO, 1,
5273 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5274 #ifndef DISASM_ONLY
5275 {
5276 0x800000007ffc0000ULL,
5277 0xfffe000000000000ULL,
5278 0ULL,
5279 0ULL,
5280 0ULL
5281 },
5282 {
5283 0x0000000001040000ULL,
5284 0x0844000000000000ULL,
5285 -1ULL,
5286 -1ULL,
5287 -1ULL
5288 }
5289 #endif
5290 },
5291 { "seqh.sn", TILEPRO_OPC_SEQH_SN, 0x3, 3, TREG_SN, 1,
5292 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5293 #ifndef DISASM_ONLY
5294 {
5295 0x800000007ffc0000ULL,
5296 0xfffe000000000000ULL,
5297 0ULL,
5298 0ULL,
5299 0ULL
5300 },
5301 {
5302 0x0000000009040000ULL,
5303 0x0c44000000000000ULL,
5304 -1ULL,
5305 -1ULL,
5306 -1ULL
5307 }
5308 #endif
5309 },
5310 { "seqi", TILEPRO_OPC_SEQI, 0xf, 3, TREG_ZERO, 1,
5311 { { 9, 10, 0 }, { 7, 8, 1 }, { 11, 12, 2 }, { 13, 14, 3 }, { 0, } },
5312 #ifndef DISASM_ONLY
5313 {
5314 0x800000007ff00000ULL,
5315 0xfff8000000000000ULL,
5316 0x8000000078000000ULL,
5317 0xf800000000000000ULL,
5318 0ULL
5319 },
5320 {
5321 0x0000000040b00000ULL,
5322 0x3070000000000000ULL,
5323 0x8000000060000000ULL,
5324 0xd000000000000000ULL,
5325 -1ULL
5326 }
5327 #endif
5328 },
5329 { "seqi.sn", TILEPRO_OPC_SEQI_SN, 0x3, 3, TREG_SN, 1,
5330 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
5331 #ifndef DISASM_ONLY
5332 {
5333 0x800000007ff00000ULL,
5334 0xfff8000000000000ULL,
5335 0ULL,
5336 0ULL,
5337 0ULL
5338 },
5339 {
5340 0x0000000048b00000ULL,
5341 0x3470000000000000ULL,
5342 -1ULL,
5343 -1ULL,
5344 -1ULL
5345 }
5346 #endif
5347 },
5348 { "seqib", TILEPRO_OPC_SEQIB, 0x3, 3, TREG_ZERO, 1,
5349 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
5350 #ifndef DISASM_ONLY
5351 {
5352 0x800000007ff00000ULL,
5353 0xfff8000000000000ULL,
5354 0ULL,
5355 0ULL,
5356 0ULL
5357 },
5358 {
5359 0x0000000040900000ULL,
5360 0x3060000000000000ULL,
5361 -1ULL,
5362 -1ULL,
5363 -1ULL
5364 }
5365 #endif
5366 },
5367 { "seqib.sn", TILEPRO_OPC_SEQIB_SN, 0x3, 3, TREG_SN, 1,
5368 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
5369 #ifndef DISASM_ONLY
5370 {
5371 0x800000007ff00000ULL,
5372 0xfff8000000000000ULL,
5373 0ULL,
5374 0ULL,
5375 0ULL
5376 },
5377 {
5378 0x0000000048900000ULL,
5379 0x3460000000000000ULL,
5380 -1ULL,
5381 -1ULL,
5382 -1ULL
5383 }
5384 #endif
5385 },
5386 { "seqih", TILEPRO_OPC_SEQIH, 0x3, 3, TREG_ZERO, 1,
5387 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
5388 #ifndef DISASM_ONLY
5389 {
5390 0x800000007ff00000ULL,
5391 0xfff8000000000000ULL,
5392 0ULL,
5393 0ULL,
5394 0ULL
5395 },
5396 {
5397 0x0000000040a00000ULL,
5398 0x3068000000000000ULL,
5399 -1ULL,
5400 -1ULL,
5401 -1ULL
5402 }
5403 #endif
5404 },
5405 { "seqih.sn", TILEPRO_OPC_SEQIH_SN, 0x3, 3, TREG_SN, 1,
5406 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
5407 #ifndef DISASM_ONLY
5408 {
5409 0x800000007ff00000ULL,
5410 0xfff8000000000000ULL,
5411 0ULL,
5412 0ULL,
5413 0ULL
5414 },
5415 {
5416 0x0000000048a00000ULL,
5417 0x3468000000000000ULL,
5418 -1ULL,
5419 -1ULL,
5420 -1ULL
5421 }
5422 #endif
5423 },
5424 { "sh", TILEPRO_OPC_SH, 0x12, 2, TREG_ZERO, 1,
5425 { { 0, }, { 8, 17 }, { 0, }, { 0, }, { 15, 36 } },
5426 #ifndef DISASM_ONLY
5427 {
5428 0ULL,
5429 0xfbfe000000000000ULL,
5430 0ULL,
5431 0ULL,
5432 0x8700000000000000ULL
5433 },
5434 {
5435 -1ULL,
5436 0x0854000000000000ULL,
5437 -1ULL,
5438 -1ULL,
5439 0x8600000000000000ULL
5440 }
5441 #endif
5442 },
5443 { "shadd", TILEPRO_OPC_SHADD, 0x2, 3, TREG_ZERO, 1,
5444 { { 0, }, { 24, 17, 37 }, { 0, }, { 0, }, { 0, } },
5445 #ifndef DISASM_ONLY
5446 {
5447 0ULL,
5448 0xfbf8000000000000ULL,
5449 0ULL,
5450 0ULL,
5451 0ULL
5452 },
5453 {
5454 -1ULL,
5455 0x30e8000000000000ULL,
5456 -1ULL,
5457 -1ULL,
5458 -1ULL
5459 }
5460 #endif
5461 },
5462 { "shl", TILEPRO_OPC_SHL, 0xf, 3, TREG_ZERO, 1,
5463 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
5464 #ifndef DISASM_ONLY
5465 {
5466 0x800000007ffc0000ULL,
5467 0xfffe000000000000ULL,
5468 0x80000000780c0000ULL,
5469 0xf806000000000000ULL,
5470 0ULL
5471 },
5472 {
5473 0x0000000001140000ULL,
5474 0x084c000000000000ULL,
5475 0x8000000020040000ULL,
5476 0xa002000000000000ULL,
5477 -1ULL
5478 }
5479 #endif
5480 },
5481 { "shl.sn", TILEPRO_OPC_SHL_SN, 0x3, 3, TREG_SN, 1,
5482 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5483 #ifndef DISASM_ONLY
5484 {
5485 0x800000007ffc0000ULL,
5486 0xfffe000000000000ULL,
5487 0ULL,
5488 0ULL,
5489 0ULL
5490 },
5491 {
5492 0x0000000009140000ULL,
5493 0x0c4c000000000000ULL,
5494 -1ULL,
5495 -1ULL,
5496 -1ULL
5497 }
5498 #endif
5499 },
5500 { "shlb", TILEPRO_OPC_SHLB, 0x3, 3, TREG_ZERO, 1,
5501 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5502 #ifndef DISASM_ONLY
5503 {
5504 0x800000007ffc0000ULL,
5505 0xfffe000000000000ULL,
5506 0ULL,
5507 0ULL,
5508 0ULL
5509 },
5510 {
5511 0x00000000010c0000ULL,
5512 0x0848000000000000ULL,
5513 -1ULL,
5514 -1ULL,
5515 -1ULL
5516 }
5517 #endif
5518 },
5519 { "shlb.sn", TILEPRO_OPC_SHLB_SN, 0x3, 3, TREG_SN, 1,
5520 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5521 #ifndef DISASM_ONLY
5522 {
5523 0x800000007ffc0000ULL,
5524 0xfffe000000000000ULL,
5525 0ULL,
5526 0ULL,
5527 0ULL
5528 },
5529 {
5530 0x00000000090c0000ULL,
5531 0x0c48000000000000ULL,
5532 -1ULL,
5533 -1ULL,
5534 -1ULL
5535 }
5536 #endif
5537 },
5538 { "shlh", TILEPRO_OPC_SHLH, 0x3, 3, TREG_ZERO, 1,
5539 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5540 #ifndef DISASM_ONLY
5541 {
5542 0x800000007ffc0000ULL,
5543 0xfffe000000000000ULL,
5544 0ULL,
5545 0ULL,
5546 0ULL
5547 },
5548 {
5549 0x0000000001100000ULL,
5550 0x084a000000000000ULL,
5551 -1ULL,
5552 -1ULL,
5553 -1ULL
5554 }
5555 #endif
5556 },
5557 { "shlh.sn", TILEPRO_OPC_SHLH_SN, 0x3, 3, TREG_SN, 1,
5558 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5559 #ifndef DISASM_ONLY
5560 {
5561 0x800000007ffc0000ULL,
5562 0xfffe000000000000ULL,
5563 0ULL,
5564 0ULL,
5565 0ULL
5566 },
5567 {
5568 0x0000000009100000ULL,
5569 0x0c4a000000000000ULL,
5570 -1ULL,
5571 -1ULL,
5572 -1ULL
5573 }
5574 #endif
5575 },
5576 { "shli", TILEPRO_OPC_SHLI, 0xf, 3, TREG_ZERO, 1,
5577 { { 9, 10, 32 }, { 7, 8, 33 }, { 11, 12, 34 }, { 13, 14, 35 }, { 0, } },
5578 #ifndef DISASM_ONLY
5579 {
5580 0x800000007ffe0000ULL,
5581 0xffff000000000000ULL,
5582 0x80000000780e0000ULL,
5583 0xf807000000000000ULL,
5584 0ULL
5585 },
5586 {
5587 0x0000000070080000ULL,
5588 0x4004000000000000ULL,
5589 0x8000000068040000ULL,
5590 0xd802000000000000ULL,
5591 -1ULL
5592 }
5593 #endif
5594 },
5595 { "shli.sn", TILEPRO_OPC_SHLI_SN, 0x3, 3, TREG_SN, 1,
5596 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5597 #ifndef DISASM_ONLY
5598 {
5599 0x800000007ffe0000ULL,
5600 0xffff000000000000ULL,
5601 0ULL,
5602 0ULL,
5603 0ULL
5604 },
5605 {
5606 0x0000000078080000ULL,
5607 0x4404000000000000ULL,
5608 -1ULL,
5609 -1ULL,
5610 -1ULL
5611 }
5612 #endif
5613 },
5614 { "shlib", TILEPRO_OPC_SHLIB, 0x3, 3, TREG_ZERO, 1,
5615 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5616 #ifndef DISASM_ONLY
5617 {
5618 0x800000007ffe0000ULL,
5619 0xffff000000000000ULL,
5620 0ULL,
5621 0ULL,
5622 0ULL
5623 },
5624 {
5625 0x0000000070040000ULL,
5626 0x4002000000000000ULL,
5627 -1ULL,
5628 -1ULL,
5629 -1ULL
5630 }
5631 #endif
5632 },
5633 { "shlib.sn", TILEPRO_OPC_SHLIB_SN, 0x3, 3, TREG_SN, 1,
5634 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5635 #ifndef DISASM_ONLY
5636 {
5637 0x800000007ffe0000ULL,
5638 0xffff000000000000ULL,
5639 0ULL,
5640 0ULL,
5641 0ULL
5642 },
5643 {
5644 0x0000000078040000ULL,
5645 0x4402000000000000ULL,
5646 -1ULL,
5647 -1ULL,
5648 -1ULL
5649 }
5650 #endif
5651 },
5652 { "shlih", TILEPRO_OPC_SHLIH, 0x3, 3, TREG_ZERO, 1,
5653 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5654 #ifndef DISASM_ONLY
5655 {
5656 0x800000007ffe0000ULL,
5657 0xffff000000000000ULL,
5658 0ULL,
5659 0ULL,
5660 0ULL
5661 },
5662 {
5663 0x0000000070060000ULL,
5664 0x4003000000000000ULL,
5665 -1ULL,
5666 -1ULL,
5667 -1ULL
5668 }
5669 #endif
5670 },
5671 { "shlih.sn", TILEPRO_OPC_SHLIH_SN, 0x3, 3, TREG_SN, 1,
5672 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5673 #ifndef DISASM_ONLY
5674 {
5675 0x800000007ffe0000ULL,
5676 0xffff000000000000ULL,
5677 0ULL,
5678 0ULL,
5679 0ULL
5680 },
5681 {
5682 0x0000000078060000ULL,
5683 0x4403000000000000ULL,
5684 -1ULL,
5685 -1ULL,
5686 -1ULL
5687 }
5688 #endif
5689 },
5690 { "shr", TILEPRO_OPC_SHR, 0xf, 3, TREG_ZERO, 1,
5691 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
5692 #ifndef DISASM_ONLY
5693 {
5694 0x800000007ffc0000ULL,
5695 0xfffe000000000000ULL,
5696 0x80000000780c0000ULL,
5697 0xf806000000000000ULL,
5698 0ULL
5699 },
5700 {
5701 0x0000000001200000ULL,
5702 0x0852000000000000ULL,
5703 0x8000000020080000ULL,
5704 0xa004000000000000ULL,
5705 -1ULL
5706 }
5707 #endif
5708 },
5709 { "shr.sn", TILEPRO_OPC_SHR_SN, 0x3, 3, TREG_SN, 1,
5710 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5711 #ifndef DISASM_ONLY
5712 {
5713 0x800000007ffc0000ULL,
5714 0xfffe000000000000ULL,
5715 0ULL,
5716 0ULL,
5717 0ULL
5718 },
5719 {
5720 0x0000000009200000ULL,
5721 0x0c52000000000000ULL,
5722 -1ULL,
5723 -1ULL,
5724 -1ULL
5725 }
5726 #endif
5727 },
5728 { "shrb", TILEPRO_OPC_SHRB, 0x3, 3, TREG_ZERO, 1,
5729 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5730 #ifndef DISASM_ONLY
5731 {
5732 0x800000007ffc0000ULL,
5733 0xfffe000000000000ULL,
5734 0ULL,
5735 0ULL,
5736 0ULL
5737 },
5738 {
5739 0x0000000001180000ULL,
5740 0x084e000000000000ULL,
5741 -1ULL,
5742 -1ULL,
5743 -1ULL
5744 }
5745 #endif
5746 },
5747 { "shrb.sn", TILEPRO_OPC_SHRB_SN, 0x3, 3, TREG_SN, 1,
5748 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5749 #ifndef DISASM_ONLY
5750 {
5751 0x800000007ffc0000ULL,
5752 0xfffe000000000000ULL,
5753 0ULL,
5754 0ULL,
5755 0ULL
5756 },
5757 {
5758 0x0000000009180000ULL,
5759 0x0c4e000000000000ULL,
5760 -1ULL,
5761 -1ULL,
5762 -1ULL
5763 }
5764 #endif
5765 },
5766 { "shrh", TILEPRO_OPC_SHRH, 0x3, 3, TREG_ZERO, 1,
5767 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5768 #ifndef DISASM_ONLY
5769 {
5770 0x800000007ffc0000ULL,
5771 0xfffe000000000000ULL,
5772 0ULL,
5773 0ULL,
5774 0ULL
5775 },
5776 {
5777 0x00000000011c0000ULL,
5778 0x0850000000000000ULL,
5779 -1ULL,
5780 -1ULL,
5781 -1ULL
5782 }
5783 #endif
5784 },
5785 { "shrh.sn", TILEPRO_OPC_SHRH_SN, 0x3, 3, TREG_SN, 1,
5786 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5787 #ifndef DISASM_ONLY
5788 {
5789 0x800000007ffc0000ULL,
5790 0xfffe000000000000ULL,
5791 0ULL,
5792 0ULL,
5793 0ULL
5794 },
5795 {
5796 0x00000000091c0000ULL,
5797 0x0c50000000000000ULL,
5798 -1ULL,
5799 -1ULL,
5800 -1ULL
5801 }
5802 #endif
5803 },
5804 { "shri", TILEPRO_OPC_SHRI, 0xf, 3, TREG_ZERO, 1,
5805 { { 9, 10, 32 }, { 7, 8, 33 }, { 11, 12, 34 }, { 13, 14, 35 }, { 0, } },
5806 #ifndef DISASM_ONLY
5807 {
5808 0x800000007ffe0000ULL,
5809 0xffff000000000000ULL,
5810 0x80000000780e0000ULL,
5811 0xf807000000000000ULL,
5812 0ULL
5813 },
5814 {
5815 0x00000000700e0000ULL,
5816 0x4007000000000000ULL,
5817 0x8000000068060000ULL,
5818 0xd803000000000000ULL,
5819 -1ULL
5820 }
5821 #endif
5822 },
5823 { "shri.sn", TILEPRO_OPC_SHRI_SN, 0x3, 3, TREG_SN, 1,
5824 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5825 #ifndef DISASM_ONLY
5826 {
5827 0x800000007ffe0000ULL,
5828 0xffff000000000000ULL,
5829 0ULL,
5830 0ULL,
5831 0ULL
5832 },
5833 {
5834 0x00000000780e0000ULL,
5835 0x4407000000000000ULL,
5836 -1ULL,
5837 -1ULL,
5838 -1ULL
5839 }
5840 #endif
5841 },
5842 { "shrib", TILEPRO_OPC_SHRIB, 0x3, 3, TREG_ZERO, 1,
5843 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5844 #ifndef DISASM_ONLY
5845 {
5846 0x800000007ffe0000ULL,
5847 0xffff000000000000ULL,
5848 0ULL,
5849 0ULL,
5850 0ULL
5851 },
5852 {
5853 0x00000000700a0000ULL,
5854 0x4005000000000000ULL,
5855 -1ULL,
5856 -1ULL,
5857 -1ULL
5858 }
5859 #endif
5860 },
5861 { "shrib.sn", TILEPRO_OPC_SHRIB_SN, 0x3, 3, TREG_SN, 1,
5862 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5863 #ifndef DISASM_ONLY
5864 {
5865 0x800000007ffe0000ULL,
5866 0xffff000000000000ULL,
5867 0ULL,
5868 0ULL,
5869 0ULL
5870 },
5871 {
5872 0x00000000780a0000ULL,
5873 0x4405000000000000ULL,
5874 -1ULL,
5875 -1ULL,
5876 -1ULL
5877 }
5878 #endif
5879 },
5880 { "shrih", TILEPRO_OPC_SHRIH, 0x3, 3, TREG_ZERO, 1,
5881 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5882 #ifndef DISASM_ONLY
5883 {
5884 0x800000007ffe0000ULL,
5885 0xffff000000000000ULL,
5886 0ULL,
5887 0ULL,
5888 0ULL
5889 },
5890 {
5891 0x00000000700c0000ULL,
5892 0x4006000000000000ULL,
5893 -1ULL,
5894 -1ULL,
5895 -1ULL
5896 }
5897 #endif
5898 },
5899 { "shrih.sn", TILEPRO_OPC_SHRIH_SN, 0x3, 3, TREG_SN, 1,
5900 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
5901 #ifndef DISASM_ONLY
5902 {
5903 0x800000007ffe0000ULL,
5904 0xffff000000000000ULL,
5905 0ULL,
5906 0ULL,
5907 0ULL
5908 },
5909 {
5910 0x00000000780c0000ULL,
5911 0x4406000000000000ULL,
5912 -1ULL,
5913 -1ULL,
5914 -1ULL
5915 }
5916 #endif
5917 },
5918 { "slt", TILEPRO_OPC_SLT, 0xf, 3, TREG_ZERO, 1,
5919 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
5920 #ifndef DISASM_ONLY
5921 {
5922 0x800000007ffc0000ULL,
5923 0xfffe000000000000ULL,
5924 0x80000000780c0000ULL,
5925 0xf806000000000000ULL,
5926 0ULL
5927 },
5928 {
5929 0x00000000014c0000ULL,
5930 0x086a000000000000ULL,
5931 0x8000000028080000ULL,
5932 0xa804000000000000ULL,
5933 -1ULL
5934 }
5935 #endif
5936 },
5937 { "slt.sn", TILEPRO_OPC_SLT_SN, 0x3, 3, TREG_SN, 1,
5938 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5939 #ifndef DISASM_ONLY
5940 {
5941 0x800000007ffc0000ULL,
5942 0xfffe000000000000ULL,
5943 0ULL,
5944 0ULL,
5945 0ULL
5946 },
5947 {
5948 0x00000000094c0000ULL,
5949 0x0c6a000000000000ULL,
5950 -1ULL,
5951 -1ULL,
5952 -1ULL
5953 }
5954 #endif
5955 },
5956 { "slt_u", TILEPRO_OPC_SLT_U, 0xf, 3, TREG_ZERO, 1,
5957 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
5958 #ifndef DISASM_ONLY
5959 {
5960 0x800000007ffc0000ULL,
5961 0xfffe000000000000ULL,
5962 0x80000000780c0000ULL,
5963 0xf806000000000000ULL,
5964 0ULL
5965 },
5966 {
5967 0x0000000001500000ULL,
5968 0x086c000000000000ULL,
5969 0x80000000280c0000ULL,
5970 0xa806000000000000ULL,
5971 -1ULL
5972 }
5973 #endif
5974 },
5975 { "slt_u.sn", TILEPRO_OPC_SLT_U_SN, 0x3, 3, TREG_SN, 1,
5976 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5977 #ifndef DISASM_ONLY
5978 {
5979 0x800000007ffc0000ULL,
5980 0xfffe000000000000ULL,
5981 0ULL,
5982 0ULL,
5983 0ULL
5984 },
5985 {
5986 0x0000000009500000ULL,
5987 0x0c6c000000000000ULL,
5988 -1ULL,
5989 -1ULL,
5990 -1ULL
5991 }
5992 #endif
5993 },
5994 { "sltb", TILEPRO_OPC_SLTB, 0x3, 3, TREG_ZERO, 1,
5995 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
5996 #ifndef DISASM_ONLY
5997 {
5998 0x800000007ffc0000ULL,
5999 0xfffe000000000000ULL,
6000 0ULL,
6001 0ULL,
6002 0ULL
6003 },
6004 {
6005 0x0000000001240000ULL,
6006 0x0856000000000000ULL,
6007 -1ULL,
6008 -1ULL,
6009 -1ULL
6010 }
6011 #endif
6012 },
6013 { "sltb.sn", TILEPRO_OPC_SLTB_SN, 0x3, 3, TREG_SN, 1,
6014 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6015 #ifndef DISASM_ONLY
6016 {
6017 0x800000007ffc0000ULL,
6018 0xfffe000000000000ULL,
6019 0ULL,
6020 0ULL,
6021 0ULL
6022 },
6023 {
6024 0x0000000009240000ULL,
6025 0x0c56000000000000ULL,
6026 -1ULL,
6027 -1ULL,
6028 -1ULL
6029 }
6030 #endif
6031 },
6032 { "sltb_u", TILEPRO_OPC_SLTB_U, 0x3, 3, TREG_ZERO, 1,
6033 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6034 #ifndef DISASM_ONLY
6035 {
6036 0x800000007ffc0000ULL,
6037 0xfffe000000000000ULL,
6038 0ULL,
6039 0ULL,
6040 0ULL
6041 },
6042 {
6043 0x0000000001280000ULL,
6044 0x0858000000000000ULL,
6045 -1ULL,
6046 -1ULL,
6047 -1ULL
6048 }
6049 #endif
6050 },
6051 { "sltb_u.sn", TILEPRO_OPC_SLTB_U_SN, 0x3, 3, TREG_SN, 1,
6052 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6053 #ifndef DISASM_ONLY
6054 {
6055 0x800000007ffc0000ULL,
6056 0xfffe000000000000ULL,
6057 0ULL,
6058 0ULL,
6059 0ULL
6060 },
6061 {
6062 0x0000000009280000ULL,
6063 0x0c58000000000000ULL,
6064 -1ULL,
6065 -1ULL,
6066 -1ULL
6067 }
6068 #endif
6069 },
6070 { "slte", TILEPRO_OPC_SLTE, 0xf, 3, TREG_ZERO, 1,
6071 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
6072 #ifndef DISASM_ONLY
6073 {
6074 0x800000007ffc0000ULL,
6075 0xfffe000000000000ULL,
6076 0x80000000780c0000ULL,
6077 0xf806000000000000ULL,
6078 0ULL
6079 },
6080 {
6081 0x00000000013c0000ULL,
6082 0x0862000000000000ULL,
6083 0x8000000028000000ULL,
6084 0xa800000000000000ULL,
6085 -1ULL
6086 }
6087 #endif
6088 },
6089 { "slte.sn", TILEPRO_OPC_SLTE_SN, 0x3, 3, TREG_SN, 1,
6090 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6091 #ifndef DISASM_ONLY
6092 {
6093 0x800000007ffc0000ULL,
6094 0xfffe000000000000ULL,
6095 0ULL,
6096 0ULL,
6097 0ULL
6098 },
6099 {
6100 0x00000000093c0000ULL,
6101 0x0c62000000000000ULL,
6102 -1ULL,
6103 -1ULL,
6104 -1ULL
6105 }
6106 #endif
6107 },
6108 { "slte_u", TILEPRO_OPC_SLTE_U, 0xf, 3, TREG_ZERO, 1,
6109 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
6110 #ifndef DISASM_ONLY
6111 {
6112 0x800000007ffc0000ULL,
6113 0xfffe000000000000ULL,
6114 0x80000000780c0000ULL,
6115 0xf806000000000000ULL,
6116 0ULL
6117 },
6118 {
6119 0x0000000001400000ULL,
6120 0x0864000000000000ULL,
6121 0x8000000028040000ULL,
6122 0xa802000000000000ULL,
6123 -1ULL
6124 }
6125 #endif
6126 },
6127 { "slte_u.sn", TILEPRO_OPC_SLTE_U_SN, 0x3, 3, TREG_SN, 1,
6128 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6129 #ifndef DISASM_ONLY
6130 {
6131 0x800000007ffc0000ULL,
6132 0xfffe000000000000ULL,
6133 0ULL,
6134 0ULL,
6135 0ULL
6136 },
6137 {
6138 0x0000000009400000ULL,
6139 0x0c64000000000000ULL,
6140 -1ULL,
6141 -1ULL,
6142 -1ULL
6143 }
6144 #endif
6145 },
6146 { "slteb", TILEPRO_OPC_SLTEB, 0x3, 3, TREG_ZERO, 1,
6147 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6148 #ifndef DISASM_ONLY
6149 {
6150 0x800000007ffc0000ULL,
6151 0xfffe000000000000ULL,
6152 0ULL,
6153 0ULL,
6154 0ULL
6155 },
6156 {
6157 0x00000000012c0000ULL,
6158 0x085a000000000000ULL,
6159 -1ULL,
6160 -1ULL,
6161 -1ULL
6162 }
6163 #endif
6164 },
6165 { "slteb.sn", TILEPRO_OPC_SLTEB_SN, 0x3, 3, TREG_SN, 1,
6166 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6167 #ifndef DISASM_ONLY
6168 {
6169 0x800000007ffc0000ULL,
6170 0xfffe000000000000ULL,
6171 0ULL,
6172 0ULL,
6173 0ULL
6174 },
6175 {
6176 0x00000000092c0000ULL,
6177 0x0c5a000000000000ULL,
6178 -1ULL,
6179 -1ULL,
6180 -1ULL
6181 }
6182 #endif
6183 },
6184 { "slteb_u", TILEPRO_OPC_SLTEB_U, 0x3, 3, TREG_ZERO, 1,
6185 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6186 #ifndef DISASM_ONLY
6187 {
6188 0x800000007ffc0000ULL,
6189 0xfffe000000000000ULL,
6190 0ULL,
6191 0ULL,
6192 0ULL
6193 },
6194 {
6195 0x0000000001300000ULL,
6196 0x085c000000000000ULL,
6197 -1ULL,
6198 -1ULL,
6199 -1ULL
6200 }
6201 #endif
6202 },
6203 { "slteb_u.sn", TILEPRO_OPC_SLTEB_U_SN, 0x3, 3, TREG_SN, 1,
6204 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6205 #ifndef DISASM_ONLY
6206 {
6207 0x800000007ffc0000ULL,
6208 0xfffe000000000000ULL,
6209 0ULL,
6210 0ULL,
6211 0ULL
6212 },
6213 {
6214 0x0000000009300000ULL,
6215 0x0c5c000000000000ULL,
6216 -1ULL,
6217 -1ULL,
6218 -1ULL
6219 }
6220 #endif
6221 },
6222 { "slteh", TILEPRO_OPC_SLTEH, 0x3, 3, TREG_ZERO, 1,
6223 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6224 #ifndef DISASM_ONLY
6225 {
6226 0x800000007ffc0000ULL,
6227 0xfffe000000000000ULL,
6228 0ULL,
6229 0ULL,
6230 0ULL
6231 },
6232 {
6233 0x0000000001340000ULL,
6234 0x085e000000000000ULL,
6235 -1ULL,
6236 -1ULL,
6237 -1ULL
6238 }
6239 #endif
6240 },
6241 { "slteh.sn", TILEPRO_OPC_SLTEH_SN, 0x3, 3, TREG_SN, 1,
6242 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6243 #ifndef DISASM_ONLY
6244 {
6245 0x800000007ffc0000ULL,
6246 0xfffe000000000000ULL,
6247 0ULL,
6248 0ULL,
6249 0ULL
6250 },
6251 {
6252 0x0000000009340000ULL,
6253 0x0c5e000000000000ULL,
6254 -1ULL,
6255 -1ULL,
6256 -1ULL
6257 }
6258 #endif
6259 },
6260 { "slteh_u", TILEPRO_OPC_SLTEH_U, 0x3, 3, TREG_ZERO, 1,
6261 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6262 #ifndef DISASM_ONLY
6263 {
6264 0x800000007ffc0000ULL,
6265 0xfffe000000000000ULL,
6266 0ULL,
6267 0ULL,
6268 0ULL
6269 },
6270 {
6271 0x0000000001380000ULL,
6272 0x0860000000000000ULL,
6273 -1ULL,
6274 -1ULL,
6275 -1ULL
6276 }
6277 #endif
6278 },
6279 { "slteh_u.sn", TILEPRO_OPC_SLTEH_U_SN, 0x3, 3, TREG_SN, 1,
6280 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6281 #ifndef DISASM_ONLY
6282 {
6283 0x800000007ffc0000ULL,
6284 0xfffe000000000000ULL,
6285 0ULL,
6286 0ULL,
6287 0ULL
6288 },
6289 {
6290 0x0000000009380000ULL,
6291 0x0c60000000000000ULL,
6292 -1ULL,
6293 -1ULL,
6294 -1ULL
6295 }
6296 #endif
6297 },
6298 { "slth", TILEPRO_OPC_SLTH, 0x3, 3, TREG_ZERO, 1,
6299 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6300 #ifndef DISASM_ONLY
6301 {
6302 0x800000007ffc0000ULL,
6303 0xfffe000000000000ULL,
6304 0ULL,
6305 0ULL,
6306 0ULL
6307 },
6308 {
6309 0x0000000001440000ULL,
6310 0x0866000000000000ULL,
6311 -1ULL,
6312 -1ULL,
6313 -1ULL
6314 }
6315 #endif
6316 },
6317 { "slth.sn", TILEPRO_OPC_SLTH_SN, 0x3, 3, TREG_SN, 1,
6318 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6319 #ifndef DISASM_ONLY
6320 {
6321 0x800000007ffc0000ULL,
6322 0xfffe000000000000ULL,
6323 0ULL,
6324 0ULL,
6325 0ULL
6326 },
6327 {
6328 0x0000000009440000ULL,
6329 0x0c66000000000000ULL,
6330 -1ULL,
6331 -1ULL,
6332 -1ULL
6333 }
6334 #endif
6335 },
6336 { "slth_u", TILEPRO_OPC_SLTH_U, 0x3, 3, TREG_ZERO, 1,
6337 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6338 #ifndef DISASM_ONLY
6339 {
6340 0x800000007ffc0000ULL,
6341 0xfffe000000000000ULL,
6342 0ULL,
6343 0ULL,
6344 0ULL
6345 },
6346 {
6347 0x0000000001480000ULL,
6348 0x0868000000000000ULL,
6349 -1ULL,
6350 -1ULL,
6351 -1ULL
6352 }
6353 #endif
6354 },
6355 { "slth_u.sn", TILEPRO_OPC_SLTH_U_SN, 0x3, 3, TREG_SN, 1,
6356 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6357 #ifndef DISASM_ONLY
6358 {
6359 0x800000007ffc0000ULL,
6360 0xfffe000000000000ULL,
6361 0ULL,
6362 0ULL,
6363 0ULL
6364 },
6365 {
6366 0x0000000009480000ULL,
6367 0x0c68000000000000ULL,
6368 -1ULL,
6369 -1ULL,
6370 -1ULL
6371 }
6372 #endif
6373 },
6374 { "slti", TILEPRO_OPC_SLTI, 0xf, 3, TREG_ZERO, 1,
6375 { { 9, 10, 0 }, { 7, 8, 1 }, { 11, 12, 2 }, { 13, 14, 3 }, { 0, } },
6376 #ifndef DISASM_ONLY
6377 {
6378 0x800000007ff00000ULL,
6379 0xfff8000000000000ULL,
6380 0x8000000078000000ULL,
6381 0xf800000000000000ULL,
6382 0ULL
6383 },
6384 {
6385 0x0000000041000000ULL,
6386 0x3098000000000000ULL,
6387 0x8000000070000000ULL,
6388 0xe000000000000000ULL,
6389 -1ULL
6390 }
6391 #endif
6392 },
6393 { "slti.sn", TILEPRO_OPC_SLTI_SN, 0x3, 3, TREG_SN, 1,
6394 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6395 #ifndef DISASM_ONLY
6396 {
6397 0x800000007ff00000ULL,
6398 0xfff8000000000000ULL,
6399 0ULL,
6400 0ULL,
6401 0ULL
6402 },
6403 {
6404 0x0000000049000000ULL,
6405 0x3498000000000000ULL,
6406 -1ULL,
6407 -1ULL,
6408 -1ULL
6409 }
6410 #endif
6411 },
6412 { "slti_u", TILEPRO_OPC_SLTI_U, 0xf, 3, TREG_ZERO, 1,
6413 { { 9, 10, 0 }, { 7, 8, 1 }, { 11, 12, 2 }, { 13, 14, 3 }, { 0, } },
6414 #ifndef DISASM_ONLY
6415 {
6416 0x800000007ff00000ULL,
6417 0xfff8000000000000ULL,
6418 0x8000000078000000ULL,
6419 0xf800000000000000ULL,
6420 0ULL
6421 },
6422 {
6423 0x0000000041100000ULL,
6424 0x30a0000000000000ULL,
6425 0x8000000078000000ULL,
6426 0xe800000000000000ULL,
6427 -1ULL
6428 }
6429 #endif
6430 },
6431 { "slti_u.sn", TILEPRO_OPC_SLTI_U_SN, 0x3, 3, TREG_SN, 1,
6432 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6433 #ifndef DISASM_ONLY
6434 {
6435 0x800000007ff00000ULL,
6436 0xfff8000000000000ULL,
6437 0ULL,
6438 0ULL,
6439 0ULL
6440 },
6441 {
6442 0x0000000049100000ULL,
6443 0x34a0000000000000ULL,
6444 -1ULL,
6445 -1ULL,
6446 -1ULL
6447 }
6448 #endif
6449 },
6450 { "sltib", TILEPRO_OPC_SLTIB, 0x3, 3, TREG_ZERO, 1,
6451 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6452 #ifndef DISASM_ONLY
6453 {
6454 0x800000007ff00000ULL,
6455 0xfff8000000000000ULL,
6456 0ULL,
6457 0ULL,
6458 0ULL
6459 },
6460 {
6461 0x0000000040c00000ULL,
6462 0x3078000000000000ULL,
6463 -1ULL,
6464 -1ULL,
6465 -1ULL
6466 }
6467 #endif
6468 },
6469 { "sltib.sn", TILEPRO_OPC_SLTIB_SN, 0x3, 3, TREG_SN, 1,
6470 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6471 #ifndef DISASM_ONLY
6472 {
6473 0x800000007ff00000ULL,
6474 0xfff8000000000000ULL,
6475 0ULL,
6476 0ULL,
6477 0ULL
6478 },
6479 {
6480 0x0000000048c00000ULL,
6481 0x3478000000000000ULL,
6482 -1ULL,
6483 -1ULL,
6484 -1ULL
6485 }
6486 #endif
6487 },
6488 { "sltib_u", TILEPRO_OPC_SLTIB_U, 0x3, 3, TREG_ZERO, 1,
6489 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6490 #ifndef DISASM_ONLY
6491 {
6492 0x800000007ff00000ULL,
6493 0xfff8000000000000ULL,
6494 0ULL,
6495 0ULL,
6496 0ULL
6497 },
6498 {
6499 0x0000000040d00000ULL,
6500 0x3080000000000000ULL,
6501 -1ULL,
6502 -1ULL,
6503 -1ULL
6504 }
6505 #endif
6506 },
6507 { "sltib_u.sn", TILEPRO_OPC_SLTIB_U_SN, 0x3, 3, TREG_SN, 1,
6508 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6509 #ifndef DISASM_ONLY
6510 {
6511 0x800000007ff00000ULL,
6512 0xfff8000000000000ULL,
6513 0ULL,
6514 0ULL,
6515 0ULL
6516 },
6517 {
6518 0x0000000048d00000ULL,
6519 0x3480000000000000ULL,
6520 -1ULL,
6521 -1ULL,
6522 -1ULL
6523 }
6524 #endif
6525 },
6526 { "sltih", TILEPRO_OPC_SLTIH, 0x3, 3, TREG_ZERO, 1,
6527 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6528 #ifndef DISASM_ONLY
6529 {
6530 0x800000007ff00000ULL,
6531 0xfff8000000000000ULL,
6532 0ULL,
6533 0ULL,
6534 0ULL
6535 },
6536 {
6537 0x0000000040e00000ULL,
6538 0x3088000000000000ULL,
6539 -1ULL,
6540 -1ULL,
6541 -1ULL
6542 }
6543 #endif
6544 },
6545 { "sltih.sn", TILEPRO_OPC_SLTIH_SN, 0x3, 3, TREG_SN, 1,
6546 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6547 #ifndef DISASM_ONLY
6548 {
6549 0x800000007ff00000ULL,
6550 0xfff8000000000000ULL,
6551 0ULL,
6552 0ULL,
6553 0ULL
6554 },
6555 {
6556 0x0000000048e00000ULL,
6557 0x3488000000000000ULL,
6558 -1ULL,
6559 -1ULL,
6560 -1ULL
6561 }
6562 #endif
6563 },
6564 { "sltih_u", TILEPRO_OPC_SLTIH_U, 0x3, 3, TREG_ZERO, 1,
6565 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6566 #ifndef DISASM_ONLY
6567 {
6568 0x800000007ff00000ULL,
6569 0xfff8000000000000ULL,
6570 0ULL,
6571 0ULL,
6572 0ULL
6573 },
6574 {
6575 0x0000000040f00000ULL,
6576 0x3090000000000000ULL,
6577 -1ULL,
6578 -1ULL,
6579 -1ULL
6580 }
6581 #endif
6582 },
6583 { "sltih_u.sn", TILEPRO_OPC_SLTIH_U_SN, 0x3, 3, TREG_SN, 1,
6584 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
6585 #ifndef DISASM_ONLY
6586 {
6587 0x800000007ff00000ULL,
6588 0xfff8000000000000ULL,
6589 0ULL,
6590 0ULL,
6591 0ULL
6592 },
6593 {
6594 0x0000000048f00000ULL,
6595 0x3490000000000000ULL,
6596 -1ULL,
6597 -1ULL,
6598 -1ULL
6599 }
6600 #endif
6601 },
6602 { "sne", TILEPRO_OPC_SNE, 0xf, 3, TREG_ZERO, 1,
6603 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
6604 #ifndef DISASM_ONLY
6605 {
6606 0x800000007ffc0000ULL,
6607 0xfffe000000000000ULL,
6608 0x80000000780c0000ULL,
6609 0xf806000000000000ULL,
6610 0ULL
6611 },
6612 {
6613 0x00000000015c0000ULL,
6614 0x0872000000000000ULL,
6615 0x80000000300c0000ULL,
6616 0xb006000000000000ULL,
6617 -1ULL
6618 }
6619 #endif
6620 },
6621 { "sne.sn", TILEPRO_OPC_SNE_SN, 0x3, 3, TREG_SN, 1,
6622 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6623 #ifndef DISASM_ONLY
6624 {
6625 0x800000007ffc0000ULL,
6626 0xfffe000000000000ULL,
6627 0ULL,
6628 0ULL,
6629 0ULL
6630 },
6631 {
6632 0x00000000095c0000ULL,
6633 0x0c72000000000000ULL,
6634 -1ULL,
6635 -1ULL,
6636 -1ULL
6637 }
6638 #endif
6639 },
6640 { "sneb", TILEPRO_OPC_SNEB, 0x3, 3, TREG_ZERO, 1,
6641 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6642 #ifndef DISASM_ONLY
6643 {
6644 0x800000007ffc0000ULL,
6645 0xfffe000000000000ULL,
6646 0ULL,
6647 0ULL,
6648 0ULL
6649 },
6650 {
6651 0x0000000001540000ULL,
6652 0x086e000000000000ULL,
6653 -1ULL,
6654 -1ULL,
6655 -1ULL
6656 }
6657 #endif
6658 },
6659 { "sneb.sn", TILEPRO_OPC_SNEB_SN, 0x3, 3, TREG_SN, 1,
6660 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6661 #ifndef DISASM_ONLY
6662 {
6663 0x800000007ffc0000ULL,
6664 0xfffe000000000000ULL,
6665 0ULL,
6666 0ULL,
6667 0ULL
6668 },
6669 {
6670 0x0000000009540000ULL,
6671 0x0c6e000000000000ULL,
6672 -1ULL,
6673 -1ULL,
6674 -1ULL
6675 }
6676 #endif
6677 },
6678 { "sneh", TILEPRO_OPC_SNEH, 0x3, 3, TREG_ZERO, 1,
6679 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6680 #ifndef DISASM_ONLY
6681 {
6682 0x800000007ffc0000ULL,
6683 0xfffe000000000000ULL,
6684 0ULL,
6685 0ULL,
6686 0ULL
6687 },
6688 {
6689 0x0000000001580000ULL,
6690 0x0870000000000000ULL,
6691 -1ULL,
6692 -1ULL,
6693 -1ULL
6694 }
6695 #endif
6696 },
6697 { "sneh.sn", TILEPRO_OPC_SNEH_SN, 0x3, 3, TREG_SN, 1,
6698 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6699 #ifndef DISASM_ONLY
6700 {
6701 0x800000007ffc0000ULL,
6702 0xfffe000000000000ULL,
6703 0ULL,
6704 0ULL,
6705 0ULL
6706 },
6707 {
6708 0x0000000009580000ULL,
6709 0x0c70000000000000ULL,
6710 -1ULL,
6711 -1ULL,
6712 -1ULL
6713 }
6714 #endif
6715 },
6716 { "sra", TILEPRO_OPC_SRA, 0xf, 3, TREG_ZERO, 1,
6717 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
6718 #ifndef DISASM_ONLY
6719 {
6720 0x800000007ffc0000ULL,
6721 0xfffe000000000000ULL,
6722 0x80000000780c0000ULL,
6723 0xf806000000000000ULL,
6724 0ULL
6725 },
6726 {
6727 0x0000000001680000ULL,
6728 0x0878000000000000ULL,
6729 0x80000000200c0000ULL,
6730 0xa006000000000000ULL,
6731 -1ULL
6732 }
6733 #endif
6734 },
6735 { "sra.sn", TILEPRO_OPC_SRA_SN, 0x3, 3, TREG_SN, 1,
6736 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6737 #ifndef DISASM_ONLY
6738 {
6739 0x800000007ffc0000ULL,
6740 0xfffe000000000000ULL,
6741 0ULL,
6742 0ULL,
6743 0ULL
6744 },
6745 {
6746 0x0000000009680000ULL,
6747 0x0c78000000000000ULL,
6748 -1ULL,
6749 -1ULL,
6750 -1ULL
6751 }
6752 #endif
6753 },
6754 { "srab", TILEPRO_OPC_SRAB, 0x3, 3, TREG_ZERO, 1,
6755 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6756 #ifndef DISASM_ONLY
6757 {
6758 0x800000007ffc0000ULL,
6759 0xfffe000000000000ULL,
6760 0ULL,
6761 0ULL,
6762 0ULL
6763 },
6764 {
6765 0x0000000001600000ULL,
6766 0x0874000000000000ULL,
6767 -1ULL,
6768 -1ULL,
6769 -1ULL
6770 }
6771 #endif
6772 },
6773 { "srab.sn", TILEPRO_OPC_SRAB_SN, 0x3, 3, TREG_SN, 1,
6774 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6775 #ifndef DISASM_ONLY
6776 {
6777 0x800000007ffc0000ULL,
6778 0xfffe000000000000ULL,
6779 0ULL,
6780 0ULL,
6781 0ULL
6782 },
6783 {
6784 0x0000000009600000ULL,
6785 0x0c74000000000000ULL,
6786 -1ULL,
6787 -1ULL,
6788 -1ULL
6789 }
6790 #endif
6791 },
6792 { "srah", TILEPRO_OPC_SRAH, 0x3, 3, TREG_ZERO, 1,
6793 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6794 #ifndef DISASM_ONLY
6795 {
6796 0x800000007ffc0000ULL,
6797 0xfffe000000000000ULL,
6798 0ULL,
6799 0ULL,
6800 0ULL
6801 },
6802 {
6803 0x0000000001640000ULL,
6804 0x0876000000000000ULL,
6805 -1ULL,
6806 -1ULL,
6807 -1ULL
6808 }
6809 #endif
6810 },
6811 { "srah.sn", TILEPRO_OPC_SRAH_SN, 0x3, 3, TREG_SN, 1,
6812 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6813 #ifndef DISASM_ONLY
6814 {
6815 0x800000007ffc0000ULL,
6816 0xfffe000000000000ULL,
6817 0ULL,
6818 0ULL,
6819 0ULL
6820 },
6821 {
6822 0x0000000009640000ULL,
6823 0x0c76000000000000ULL,
6824 -1ULL,
6825 -1ULL,
6826 -1ULL
6827 }
6828 #endif
6829 },
6830 { "srai", TILEPRO_OPC_SRAI, 0xf, 3, TREG_ZERO, 1,
6831 { { 9, 10, 32 }, { 7, 8, 33 }, { 11, 12, 34 }, { 13, 14, 35 }, { 0, } },
6832 #ifndef DISASM_ONLY
6833 {
6834 0x800000007ffe0000ULL,
6835 0xffff000000000000ULL,
6836 0x80000000780e0000ULL,
6837 0xf807000000000000ULL,
6838 0ULL
6839 },
6840 {
6841 0x0000000070140000ULL,
6842 0x400a000000000000ULL,
6843 0x8000000068080000ULL,
6844 0xd804000000000000ULL,
6845 -1ULL
6846 }
6847 #endif
6848 },
6849 { "srai.sn", TILEPRO_OPC_SRAI_SN, 0x3, 3, TREG_SN, 1,
6850 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
6851 #ifndef DISASM_ONLY
6852 {
6853 0x800000007ffe0000ULL,
6854 0xffff000000000000ULL,
6855 0ULL,
6856 0ULL,
6857 0ULL
6858 },
6859 {
6860 0x0000000078140000ULL,
6861 0x440a000000000000ULL,
6862 -1ULL,
6863 -1ULL,
6864 -1ULL
6865 }
6866 #endif
6867 },
6868 { "sraib", TILEPRO_OPC_SRAIB, 0x3, 3, TREG_ZERO, 1,
6869 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
6870 #ifndef DISASM_ONLY
6871 {
6872 0x800000007ffe0000ULL,
6873 0xffff000000000000ULL,
6874 0ULL,
6875 0ULL,
6876 0ULL
6877 },
6878 {
6879 0x0000000070100000ULL,
6880 0x4008000000000000ULL,
6881 -1ULL,
6882 -1ULL,
6883 -1ULL
6884 }
6885 #endif
6886 },
6887 { "sraib.sn", TILEPRO_OPC_SRAIB_SN, 0x3, 3, TREG_SN, 1,
6888 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
6889 #ifndef DISASM_ONLY
6890 {
6891 0x800000007ffe0000ULL,
6892 0xffff000000000000ULL,
6893 0ULL,
6894 0ULL,
6895 0ULL
6896 },
6897 {
6898 0x0000000078100000ULL,
6899 0x4408000000000000ULL,
6900 -1ULL,
6901 -1ULL,
6902 -1ULL
6903 }
6904 #endif
6905 },
6906 { "sraih", TILEPRO_OPC_SRAIH, 0x3, 3, TREG_ZERO, 1,
6907 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
6908 #ifndef DISASM_ONLY
6909 {
6910 0x800000007ffe0000ULL,
6911 0xffff000000000000ULL,
6912 0ULL,
6913 0ULL,
6914 0ULL
6915 },
6916 {
6917 0x0000000070120000ULL,
6918 0x4009000000000000ULL,
6919 -1ULL,
6920 -1ULL,
6921 -1ULL
6922 }
6923 #endif
6924 },
6925 { "sraih.sn", TILEPRO_OPC_SRAIH_SN, 0x3, 3, TREG_SN, 1,
6926 { { 9, 10, 32 }, { 7, 8, 33 }, { 0, }, { 0, }, { 0, } },
6927 #ifndef DISASM_ONLY
6928 {
6929 0x800000007ffe0000ULL,
6930 0xffff000000000000ULL,
6931 0ULL,
6932 0ULL,
6933 0ULL
6934 },
6935 {
6936 0x0000000078120000ULL,
6937 0x4409000000000000ULL,
6938 -1ULL,
6939 -1ULL,
6940 -1ULL
6941 }
6942 #endif
6943 },
6944 { "sub", TILEPRO_OPC_SUB, 0xf, 3, TREG_ZERO, 1,
6945 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
6946 #ifndef DISASM_ONLY
6947 {
6948 0x800000007ffc0000ULL,
6949 0xfffe000000000000ULL,
6950 0x80000000780c0000ULL,
6951 0xf806000000000000ULL,
6952 0ULL
6953 },
6954 {
6955 0x0000000001740000ULL,
6956 0x087e000000000000ULL,
6957 0x80000000080c0000ULL,
6958 0x8806000000000000ULL,
6959 -1ULL
6960 }
6961 #endif
6962 },
6963 { "sub.sn", TILEPRO_OPC_SUB_SN, 0x3, 3, TREG_SN, 1,
6964 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6965 #ifndef DISASM_ONLY
6966 {
6967 0x800000007ffc0000ULL,
6968 0xfffe000000000000ULL,
6969 0ULL,
6970 0ULL,
6971 0ULL
6972 },
6973 {
6974 0x0000000009740000ULL,
6975 0x0c7e000000000000ULL,
6976 -1ULL,
6977 -1ULL,
6978 -1ULL
6979 }
6980 #endif
6981 },
6982 { "subb", TILEPRO_OPC_SUBB, 0x3, 3, TREG_ZERO, 1,
6983 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
6984 #ifndef DISASM_ONLY
6985 {
6986 0x800000007ffc0000ULL,
6987 0xfffe000000000000ULL,
6988 0ULL,
6989 0ULL,
6990 0ULL
6991 },
6992 {
6993 0x00000000016c0000ULL,
6994 0x087a000000000000ULL,
6995 -1ULL,
6996 -1ULL,
6997 -1ULL
6998 }
6999 #endif
7000 },
7001 { "subb.sn", TILEPRO_OPC_SUBB_SN, 0x3, 3, TREG_SN, 1,
7002 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7003 #ifndef DISASM_ONLY
7004 {
7005 0x800000007ffc0000ULL,
7006 0xfffe000000000000ULL,
7007 0ULL,
7008 0ULL,
7009 0ULL
7010 },
7011 {
7012 0x00000000096c0000ULL,
7013 0x0c7a000000000000ULL,
7014 -1ULL,
7015 -1ULL,
7016 -1ULL
7017 }
7018 #endif
7019 },
7020 { "subbs_u", TILEPRO_OPC_SUBBS_U, 0x3, 3, TREG_ZERO, 1,
7021 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7022 #ifndef DISASM_ONLY
7023 {
7024 0x800000007ffc0000ULL,
7025 0xfffe000000000000ULL,
7026 0ULL,
7027 0ULL,
7028 0ULL
7029 },
7030 {
7031 0x0000000001900000ULL,
7032 0x088c000000000000ULL,
7033 -1ULL,
7034 -1ULL,
7035 -1ULL
7036 }
7037 #endif
7038 },
7039 { "subbs_u.sn", TILEPRO_OPC_SUBBS_U_SN, 0x3, 3, TREG_SN, 1,
7040 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7041 #ifndef DISASM_ONLY
7042 {
7043 0x800000007ffc0000ULL,
7044 0xfffe000000000000ULL,
7045 0ULL,
7046 0ULL,
7047 0ULL
7048 },
7049 {
7050 0x0000000009900000ULL,
7051 0x0c8c000000000000ULL,
7052 -1ULL,
7053 -1ULL,
7054 -1ULL
7055 }
7056 #endif
7057 },
7058 { "subh", TILEPRO_OPC_SUBH, 0x3, 3, TREG_ZERO, 1,
7059 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7060 #ifndef DISASM_ONLY
7061 {
7062 0x800000007ffc0000ULL,
7063 0xfffe000000000000ULL,
7064 0ULL,
7065 0ULL,
7066 0ULL
7067 },
7068 {
7069 0x0000000001700000ULL,
7070 0x087c000000000000ULL,
7071 -1ULL,
7072 -1ULL,
7073 -1ULL
7074 }
7075 #endif
7076 },
7077 { "subh.sn", TILEPRO_OPC_SUBH_SN, 0x3, 3, TREG_SN, 1,
7078 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7079 #ifndef DISASM_ONLY
7080 {
7081 0x800000007ffc0000ULL,
7082 0xfffe000000000000ULL,
7083 0ULL,
7084 0ULL,
7085 0ULL
7086 },
7087 {
7088 0x0000000009700000ULL,
7089 0x0c7c000000000000ULL,
7090 -1ULL,
7091 -1ULL,
7092 -1ULL
7093 }
7094 #endif
7095 },
7096 { "subhs", TILEPRO_OPC_SUBHS, 0x3, 3, TREG_ZERO, 1,
7097 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7098 #ifndef DISASM_ONLY
7099 {
7100 0x800000007ffc0000ULL,
7101 0xfffe000000000000ULL,
7102 0ULL,
7103 0ULL,
7104 0ULL
7105 },
7106 {
7107 0x0000000001940000ULL,
7108 0x088e000000000000ULL,
7109 -1ULL,
7110 -1ULL,
7111 -1ULL
7112 }
7113 #endif
7114 },
7115 { "subhs.sn", TILEPRO_OPC_SUBHS_SN, 0x3, 3, TREG_SN, 1,
7116 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7117 #ifndef DISASM_ONLY
7118 {
7119 0x800000007ffc0000ULL,
7120 0xfffe000000000000ULL,
7121 0ULL,
7122 0ULL,
7123 0ULL
7124 },
7125 {
7126 0x0000000009940000ULL,
7127 0x0c8e000000000000ULL,
7128 -1ULL,
7129 -1ULL,
7130 -1ULL
7131 }
7132 #endif
7133 },
7134 { "subs", TILEPRO_OPC_SUBS, 0x3, 3, TREG_ZERO, 1,
7135 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7136 #ifndef DISASM_ONLY
7137 {
7138 0x800000007ffc0000ULL,
7139 0xfffe000000000000ULL,
7140 0ULL,
7141 0ULL,
7142 0ULL
7143 },
7144 {
7145 0x0000000001840000ULL,
7146 0x0886000000000000ULL,
7147 -1ULL,
7148 -1ULL,
7149 -1ULL
7150 }
7151 #endif
7152 },
7153 { "subs.sn", TILEPRO_OPC_SUBS_SN, 0x3, 3, TREG_SN, 1,
7154 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7155 #ifndef DISASM_ONLY
7156 {
7157 0x800000007ffc0000ULL,
7158 0xfffe000000000000ULL,
7159 0ULL,
7160 0ULL,
7161 0ULL
7162 },
7163 {
7164 0x0000000009840000ULL,
7165 0x0c86000000000000ULL,
7166 -1ULL,
7167 -1ULL,
7168 -1ULL
7169 }
7170 #endif
7171 },
7172 { "sw", TILEPRO_OPC_SW, 0x12, 2, TREG_ZERO, 1,
7173 { { 0, }, { 8, 17 }, { 0, }, { 0, }, { 15, 36 } },
7174 #ifndef DISASM_ONLY
7175 {
7176 0ULL,
7177 0xfbfe000000000000ULL,
7178 0ULL,
7179 0ULL,
7180 0x8700000000000000ULL
7181 },
7182 {
7183 -1ULL,
7184 0x0880000000000000ULL,
7185 -1ULL,
7186 -1ULL,
7187 0x8700000000000000ULL
7188 }
7189 #endif
7190 },
7191 { "swadd", TILEPRO_OPC_SWADD, 0x2, 3, TREG_ZERO, 1,
7192 { { 0, }, { 24, 17, 37 }, { 0, }, { 0, }, { 0, } },
7193 #ifndef DISASM_ONLY
7194 {
7195 0ULL,
7196 0xfbf8000000000000ULL,
7197 0ULL,
7198 0ULL,
7199 0ULL
7200 },
7201 {
7202 -1ULL,
7203 0x30f0000000000000ULL,
7204 -1ULL,
7205 -1ULL,
7206 -1ULL
7207 }
7208 #endif
7209 },
7210 { "swint0", TILEPRO_OPC_SWINT0, 0x2, 0, TREG_ZERO, 0,
7211 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
7212 #ifndef DISASM_ONLY
7213 {
7214 0ULL,
7215 0xfbfff80000000000ULL,
7216 0ULL,
7217 0ULL,
7218 0ULL
7219 },
7220 {
7221 -1ULL,
7222 0x400b900000000000ULL,
7223 -1ULL,
7224 -1ULL,
7225 -1ULL
7226 }
7227 #endif
7228 },
7229 { "swint1", TILEPRO_OPC_SWINT1, 0x2, 0, TREG_ZERO, 0,
7230 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
7231 #ifndef DISASM_ONLY
7232 {
7233 0ULL,
7234 0xfbfff80000000000ULL,
7235 0ULL,
7236 0ULL,
7237 0ULL
7238 },
7239 {
7240 -1ULL,
7241 0x400b980000000000ULL,
7242 -1ULL,
7243 -1ULL,
7244 -1ULL
7245 }
7246 #endif
7247 },
7248 { "swint2", TILEPRO_OPC_SWINT2, 0x2, 0, TREG_ZERO, 0,
7249 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
7250 #ifndef DISASM_ONLY
7251 {
7252 0ULL,
7253 0xfbfff80000000000ULL,
7254 0ULL,
7255 0ULL,
7256 0ULL
7257 },
7258 {
7259 -1ULL,
7260 0x400ba00000000000ULL,
7261 -1ULL,
7262 -1ULL,
7263 -1ULL
7264 }
7265 #endif
7266 },
7267 { "swint3", TILEPRO_OPC_SWINT3, 0x2, 0, TREG_ZERO, 0,
7268 { { 0, }, { }, { 0, }, { 0, }, { 0, } },
7269 #ifndef DISASM_ONLY
7270 {
7271 0ULL,
7272 0xfbfff80000000000ULL,
7273 0ULL,
7274 0ULL,
7275 0ULL
7276 },
7277 {
7278 -1ULL,
7279 0x400ba80000000000ULL,
7280 -1ULL,
7281 -1ULL,
7282 -1ULL
7283 }
7284 #endif
7285 },
7286 { "tblidxb0", TILEPRO_OPC_TBLIDXB0, 0x5, 2, TREG_ZERO, 1,
7287 { { 21, 10 }, { 0, }, { 31, 12 }, { 0, }, { 0, } },
7288 #ifndef DISASM_ONLY
7289 {
7290 0x800000007ffff000ULL,
7291 0ULL,
7292 0x80000000780ff000ULL,
7293 0ULL,
7294 0ULL
7295 },
7296 {
7297 0x0000000070168000ULL,
7298 -1ULL,
7299 0x80000000680a8000ULL,
7300 -1ULL,
7301 -1ULL
7302 }
7303 #endif
7304 },
7305 { "tblidxb0.sn", TILEPRO_OPC_TBLIDXB0_SN, 0x1, 2, TREG_SN, 1,
7306 { { 21, 10 }, { 0, }, { 0, }, { 0, }, { 0, } },
7307 #ifndef DISASM_ONLY
7308 {
7309 0x800000007ffff000ULL,
7310 0ULL,
7311 0ULL,
7312 0ULL,
7313 0ULL
7314 },
7315 {
7316 0x0000000078168000ULL,
7317 -1ULL,
7318 -1ULL,
7319 -1ULL,
7320 -1ULL
7321 }
7322 #endif
7323 },
7324 { "tblidxb1", TILEPRO_OPC_TBLIDXB1, 0x5, 2, TREG_ZERO, 1,
7325 { { 21, 10 }, { 0, }, { 31, 12 }, { 0, }, { 0, } },
7326 #ifndef DISASM_ONLY
7327 {
7328 0x800000007ffff000ULL,
7329 0ULL,
7330 0x80000000780ff000ULL,
7331 0ULL,
7332 0ULL
7333 },
7334 {
7335 0x0000000070169000ULL,
7336 -1ULL,
7337 0x80000000680a9000ULL,
7338 -1ULL,
7339 -1ULL
7340 }
7341 #endif
7342 },
7343 { "tblidxb1.sn", TILEPRO_OPC_TBLIDXB1_SN, 0x1, 2, TREG_SN, 1,
7344 { { 21, 10 }, { 0, }, { 0, }, { 0, }, { 0, } },
7345 #ifndef DISASM_ONLY
7346 {
7347 0x800000007ffff000ULL,
7348 0ULL,
7349 0ULL,
7350 0ULL,
7351 0ULL
7352 },
7353 {
7354 0x0000000078169000ULL,
7355 -1ULL,
7356 -1ULL,
7357 -1ULL,
7358 -1ULL
7359 }
7360 #endif
7361 },
7362 { "tblidxb2", TILEPRO_OPC_TBLIDXB2, 0x5, 2, TREG_ZERO, 1,
7363 { { 21, 10 }, { 0, }, { 31, 12 }, { 0, }, { 0, } },
7364 #ifndef DISASM_ONLY
7365 {
7366 0x800000007ffff000ULL,
7367 0ULL,
7368 0x80000000780ff000ULL,
7369 0ULL,
7370 0ULL
7371 },
7372 {
7373 0x000000007016a000ULL,
7374 -1ULL,
7375 0x80000000680aa000ULL,
7376 -1ULL,
7377 -1ULL
7378 }
7379 #endif
7380 },
7381 { "tblidxb2.sn", TILEPRO_OPC_TBLIDXB2_SN, 0x1, 2, TREG_SN, 1,
7382 { { 21, 10 }, { 0, }, { 0, }, { 0, }, { 0, } },
7383 #ifndef DISASM_ONLY
7384 {
7385 0x800000007ffff000ULL,
7386 0ULL,
7387 0ULL,
7388 0ULL,
7389 0ULL
7390 },
7391 {
7392 0x000000007816a000ULL,
7393 -1ULL,
7394 -1ULL,
7395 -1ULL,
7396 -1ULL
7397 }
7398 #endif
7399 },
7400 { "tblidxb3", TILEPRO_OPC_TBLIDXB3, 0x5, 2, TREG_ZERO, 1,
7401 { { 21, 10 }, { 0, }, { 31, 12 }, { 0, }, { 0, } },
7402 #ifndef DISASM_ONLY
7403 {
7404 0x800000007ffff000ULL,
7405 0ULL,
7406 0x80000000780ff000ULL,
7407 0ULL,
7408 0ULL
7409 },
7410 {
7411 0x000000007016b000ULL,
7412 -1ULL,
7413 0x80000000680ab000ULL,
7414 -1ULL,
7415 -1ULL
7416 }
7417 #endif
7418 },
7419 { "tblidxb3.sn", TILEPRO_OPC_TBLIDXB3_SN, 0x1, 2, TREG_SN, 1,
7420 { { 21, 10 }, { 0, }, { 0, }, { 0, }, { 0, } },
7421 #ifndef DISASM_ONLY
7422 {
7423 0x800000007ffff000ULL,
7424 0ULL,
7425 0ULL,
7426 0ULL,
7427 0ULL
7428 },
7429 {
7430 0x000000007816b000ULL,
7431 -1ULL,
7432 -1ULL,
7433 -1ULL,
7434 -1ULL
7435 }
7436 #endif
7437 },
7438 { "tns", TILEPRO_OPC_TNS, 0x2, 2, TREG_ZERO, 1,
7439 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
7440 #ifndef DISASM_ONLY
7441 {
7442 0ULL,
7443 0xfffff80000000000ULL,
7444 0ULL,
7445 0ULL,
7446 0ULL
7447 },
7448 {
7449 -1ULL,
7450 0x400bb00000000000ULL,
7451 -1ULL,
7452 -1ULL,
7453 -1ULL
7454 }
7455 #endif
7456 },
7457 { "tns.sn", TILEPRO_OPC_TNS_SN, 0x2, 2, TREG_SN, 1,
7458 { { 0, }, { 7, 8 }, { 0, }, { 0, }, { 0, } },
7459 #ifndef DISASM_ONLY
7460 {
7461 0ULL,
7462 0xfffff80000000000ULL,
7463 0ULL,
7464 0ULL,
7465 0ULL
7466 },
7467 {
7468 -1ULL,
7469 0x440bb00000000000ULL,
7470 -1ULL,
7471 -1ULL,
7472 -1ULL
7473 }
7474 #endif
7475 },
7476 { "wh64", TILEPRO_OPC_WH64, 0x2, 1, TREG_ZERO, 1,
7477 { { 0, }, { 8 }, { 0, }, { 0, }, { 0, } },
7478 #ifndef DISASM_ONLY
7479 {
7480 0ULL,
7481 0xfbfff80000000000ULL,
7482 0ULL,
7483 0ULL,
7484 0ULL
7485 },
7486 {
7487 -1ULL,
7488 0x400bb80000000000ULL,
7489 -1ULL,
7490 -1ULL,
7491 -1ULL
7492 }
7493 #endif
7494 },
7495 { "xor", TILEPRO_OPC_XOR, 0xf, 3, TREG_ZERO, 1,
7496 { { 9, 10, 16 }, { 7, 8, 17 }, { 11, 12, 18 }, { 13, 14, 19 }, { 0, } },
7497 #ifndef DISASM_ONLY
7498 {
7499 0x800000007ffc0000ULL,
7500 0xfffe000000000000ULL,
7501 0x80000000780c0000ULL,
7502 0xf806000000000000ULL,
7503 0ULL
7504 },
7505 {
7506 0x0000000001780000ULL,
7507 0x0882000000000000ULL,
7508 0x80000000180c0000ULL,
7509 0x9806000000000000ULL,
7510 -1ULL
7511 }
7512 #endif
7513 },
7514 { "xor.sn", TILEPRO_OPC_XOR_SN, 0x3, 3, TREG_SN, 1,
7515 { { 9, 10, 16 }, { 7, 8, 17 }, { 0, }, { 0, }, { 0, } },
7516 #ifndef DISASM_ONLY
7517 {
7518 0x800000007ffc0000ULL,
7519 0xfffe000000000000ULL,
7520 0ULL,
7521 0ULL,
7522 0ULL
7523 },
7524 {
7525 0x0000000009780000ULL,
7526 0x0c82000000000000ULL,
7527 -1ULL,
7528 -1ULL,
7529 -1ULL
7530 }
7531 #endif
7532 },
7533 { "xori", TILEPRO_OPC_XORI, 0x3, 3, TREG_ZERO, 1,
7534 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
7535 #ifndef DISASM_ONLY
7536 {
7537 0x800000007ff00000ULL,
7538 0xfff8000000000000ULL,
7539 0ULL,
7540 0ULL,
7541 0ULL
7542 },
7543 {
7544 0x0000000050200000ULL,
7545 0x30a8000000000000ULL,
7546 -1ULL,
7547 -1ULL,
7548 -1ULL
7549 }
7550 #endif
7551 },
7552 { "xori.sn", TILEPRO_OPC_XORI_SN, 0x3, 3, TREG_SN, 1,
7553 { { 9, 10, 0 }, { 7, 8, 1 }, { 0, }, { 0, }, { 0, } },
7554 #ifndef DISASM_ONLY
7555 {
7556 0x800000007ff00000ULL,
7557 0xfff8000000000000ULL,
7558 0ULL,
7559 0ULL,
7560 0ULL
7561 },
7562 {
7563 0x0000000058200000ULL,
7564 0x34a8000000000000ULL,
7565 -1ULL,
7566 -1ULL,
7567 -1ULL
7568 }
7569 #endif
7570 },
7571 { NULL, TILEPRO_OPC_NONE, 0, 0, TREG_ZERO, 0, { { 0, } },
7572 #ifndef DISASM_ONLY
7573 { 0, }, { 0, }
7574 #endif
7575 }
7576 };
7577
7578 #define BITFIELD(start, size) ((start) | (((1 << (size)) - 1) << 6))
7579 #define CHILD(array_index) (TILEPRO_OPC_NONE + (array_index))
7580
7581 static const unsigned short decode_X0_fsm[1153] =
7582 {
7583 BITFIELD(22, 9) /* index 0 */,
7584 CHILD(513), CHILD(530), CHILD(547), CHILD(564), CHILD(596), CHILD(613),
7585 CHILD(630), TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7586 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7587 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7588 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7589 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7590 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7591 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, CHILD(663), CHILD(680), CHILD(697),
7592 CHILD(714), CHILD(746), CHILD(763), CHILD(780), TILEPRO_OPC_NONE,
7593 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7594 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7595 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7596 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7597 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7598 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7599 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7600 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7601 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7602 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7603 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7604 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7605 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7606 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7607 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7608 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(813),
7609 CHILD(813), CHILD(813), CHILD(813), CHILD(813), CHILD(828), CHILD(828),
7610 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7611 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7612 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7613 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7614 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7615 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7616 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7617 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7618 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7619 CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828), CHILD(828),
7620 CHILD(828), CHILD(828), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7621 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7622 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7623 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7624 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7625 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7626 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7627 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7628 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7629 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7630 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
7631 CHILD(873), CHILD(878), CHILD(883), CHILD(903), CHILD(908),
7632 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7633 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7634 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7635 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7636 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7637 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7638 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, CHILD(913),
7639 CHILD(918), CHILD(923), CHILD(943), CHILD(948), TILEPRO_OPC_NONE,
7640 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7641 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7642 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7643 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7644 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7645 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7646 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, CHILD(953), TILEPRO_OPC_NONE,
7647 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7648 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7649 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7650 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7651 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7652 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7653 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7654 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, CHILD(988), TILEPRO_OPC_NONE,
7655 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7656 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7657 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7658 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7659 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7660 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7661 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7662 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7663 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7664 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7665 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7666 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7667 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7668 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7669 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7670 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7671 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7672 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7673 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7674 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7675 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7676 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7677 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
7678 TILEPRO_OPC_MM, TILEPRO_OPC_MM, CHILD(993), TILEPRO_OPC_NONE,
7679 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7680 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7681 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7682 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7683 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7684 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7685 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7686 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, CHILD(1076), TILEPRO_OPC_NONE,
7687 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7688 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7689 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7690 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7691 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7692 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7693 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7694 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7695 BITFIELD(18, 4) /* index 513 */,
7696 TILEPRO_OPC_NONE, TILEPRO_OPC_ADDB, TILEPRO_OPC_ADDH, TILEPRO_OPC_ADD,
7697 TILEPRO_OPC_ADIFFB_U, TILEPRO_OPC_ADIFFH, TILEPRO_OPC_AND,
7698 TILEPRO_OPC_AVGB_U, TILEPRO_OPC_AVGH, TILEPRO_OPC_CRC32_32,
7699 TILEPRO_OPC_CRC32_8, TILEPRO_OPC_INTHB, TILEPRO_OPC_INTHH,
7700 TILEPRO_OPC_INTLB, TILEPRO_OPC_INTLH, TILEPRO_OPC_MAXB_U,
7701 BITFIELD(18, 4) /* index 530 */,
7702 TILEPRO_OPC_MAXH, TILEPRO_OPC_MINB_U, TILEPRO_OPC_MINH, TILEPRO_OPC_MNZB,
7703 TILEPRO_OPC_MNZH, TILEPRO_OPC_MNZ, TILEPRO_OPC_MULHHA_SS,
7704 TILEPRO_OPC_MULHHA_SU, TILEPRO_OPC_MULHHA_UU, TILEPRO_OPC_MULHHSA_UU,
7705 TILEPRO_OPC_MULHH_SS, TILEPRO_OPC_MULHH_SU, TILEPRO_OPC_MULHH_UU,
7706 TILEPRO_OPC_MULHLA_SS, TILEPRO_OPC_MULHLA_SU, TILEPRO_OPC_MULHLA_US,
7707 BITFIELD(18, 4) /* index 547 */,
7708 TILEPRO_OPC_MULHLA_UU, TILEPRO_OPC_MULHLSA_UU, TILEPRO_OPC_MULHL_SS,
7709 TILEPRO_OPC_MULHL_SU, TILEPRO_OPC_MULHL_US, TILEPRO_OPC_MULHL_UU,
7710 TILEPRO_OPC_MULLLA_SS, TILEPRO_OPC_MULLLA_SU, TILEPRO_OPC_MULLLA_UU,
7711 TILEPRO_OPC_MULLLSA_UU, TILEPRO_OPC_MULLL_SS, TILEPRO_OPC_MULLL_SU,
7712 TILEPRO_OPC_MULLL_UU, TILEPRO_OPC_MVNZ, TILEPRO_OPC_MVZ, TILEPRO_OPC_MZB,
7713 BITFIELD(18, 4) /* index 564 */,
7714 TILEPRO_OPC_MZH, TILEPRO_OPC_MZ, TILEPRO_OPC_NOR, CHILD(581),
7715 TILEPRO_OPC_PACKHB, TILEPRO_OPC_PACKLB, TILEPRO_OPC_RL, TILEPRO_OPC_S1A,
7716 TILEPRO_OPC_S2A, TILEPRO_OPC_S3A, TILEPRO_OPC_SADAB_U, TILEPRO_OPC_SADAH,
7717 TILEPRO_OPC_SADAH_U, TILEPRO_OPC_SADB_U, TILEPRO_OPC_SADH,
7718 TILEPRO_OPC_SADH_U,
7719 BITFIELD(12, 2) /* index 581 */,
7720 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, CHILD(586),
7721 BITFIELD(14, 2) /* index 586 */,
7722 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, CHILD(591),
7723 BITFIELD(16, 2) /* index 591 */,
7724 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_MOVE,
7725 BITFIELD(18, 4) /* index 596 */,
7726 TILEPRO_OPC_SEQB, TILEPRO_OPC_SEQH, TILEPRO_OPC_SEQ, TILEPRO_OPC_SHLB,
7727 TILEPRO_OPC_SHLH, TILEPRO_OPC_SHL, TILEPRO_OPC_SHRB, TILEPRO_OPC_SHRH,
7728 TILEPRO_OPC_SHR, TILEPRO_OPC_SLTB, TILEPRO_OPC_SLTB_U, TILEPRO_OPC_SLTEB,
7729 TILEPRO_OPC_SLTEB_U, TILEPRO_OPC_SLTEH, TILEPRO_OPC_SLTEH_U,
7730 TILEPRO_OPC_SLTE,
7731 BITFIELD(18, 4) /* index 613 */,
7732 TILEPRO_OPC_SLTE_U, TILEPRO_OPC_SLTH, TILEPRO_OPC_SLTH_U, TILEPRO_OPC_SLT,
7733 TILEPRO_OPC_SLT_U, TILEPRO_OPC_SNEB, TILEPRO_OPC_SNEH, TILEPRO_OPC_SNE,
7734 TILEPRO_OPC_SRAB, TILEPRO_OPC_SRAH, TILEPRO_OPC_SRA, TILEPRO_OPC_SUBB,
7735 TILEPRO_OPC_SUBH, TILEPRO_OPC_SUB, TILEPRO_OPC_XOR, TILEPRO_OPC_DWORD_ALIGN,
7736 BITFIELD(18, 3) /* index 630 */,
7737 CHILD(639), CHILD(642), CHILD(645), CHILD(648), CHILD(651), CHILD(654),
7738 CHILD(657), CHILD(660),
7739 BITFIELD(21, 1) /* index 639 */,
7740 TILEPRO_OPC_ADDS, TILEPRO_OPC_NONE,
7741 BITFIELD(21, 1) /* index 642 */,
7742 TILEPRO_OPC_SUBS, TILEPRO_OPC_NONE,
7743 BITFIELD(21, 1) /* index 645 */,
7744 TILEPRO_OPC_ADDBS_U, TILEPRO_OPC_NONE,
7745 BITFIELD(21, 1) /* index 648 */,
7746 TILEPRO_OPC_ADDHS, TILEPRO_OPC_NONE,
7747 BITFIELD(21, 1) /* index 651 */,
7748 TILEPRO_OPC_SUBBS_U, TILEPRO_OPC_NONE,
7749 BITFIELD(21, 1) /* index 654 */,
7750 TILEPRO_OPC_SUBHS, TILEPRO_OPC_NONE,
7751 BITFIELD(21, 1) /* index 657 */,
7752 TILEPRO_OPC_PACKHS, TILEPRO_OPC_NONE,
7753 BITFIELD(21, 1) /* index 660 */,
7754 TILEPRO_OPC_PACKBS_U, TILEPRO_OPC_NONE,
7755 BITFIELD(18, 4) /* index 663 */,
7756 TILEPRO_OPC_NONE, TILEPRO_OPC_ADDB_SN, TILEPRO_OPC_ADDH_SN,
7757 TILEPRO_OPC_ADD_SN, TILEPRO_OPC_ADIFFB_U_SN, TILEPRO_OPC_ADIFFH_SN,
7758 TILEPRO_OPC_AND_SN, TILEPRO_OPC_AVGB_U_SN, TILEPRO_OPC_AVGH_SN,
7759 TILEPRO_OPC_CRC32_32_SN, TILEPRO_OPC_CRC32_8_SN, TILEPRO_OPC_INTHB_SN,
7760 TILEPRO_OPC_INTHH_SN, TILEPRO_OPC_INTLB_SN, TILEPRO_OPC_INTLH_SN,
7761 TILEPRO_OPC_MAXB_U_SN,
7762 BITFIELD(18, 4) /* index 680 */,
7763 TILEPRO_OPC_MAXH_SN, TILEPRO_OPC_MINB_U_SN, TILEPRO_OPC_MINH_SN,
7764 TILEPRO_OPC_MNZB_SN, TILEPRO_OPC_MNZH_SN, TILEPRO_OPC_MNZ_SN,
7765 TILEPRO_OPC_MULHHA_SS_SN, TILEPRO_OPC_MULHHA_SU_SN,
7766 TILEPRO_OPC_MULHHA_UU_SN, TILEPRO_OPC_MULHHSA_UU_SN,
7767 TILEPRO_OPC_MULHH_SS_SN, TILEPRO_OPC_MULHH_SU_SN, TILEPRO_OPC_MULHH_UU_SN,
7768 TILEPRO_OPC_MULHLA_SS_SN, TILEPRO_OPC_MULHLA_SU_SN,
7769 TILEPRO_OPC_MULHLA_US_SN,
7770 BITFIELD(18, 4) /* index 697 */,
7771 TILEPRO_OPC_MULHLA_UU_SN, TILEPRO_OPC_MULHLSA_UU_SN,
7772 TILEPRO_OPC_MULHL_SS_SN, TILEPRO_OPC_MULHL_SU_SN, TILEPRO_OPC_MULHL_US_SN,
7773 TILEPRO_OPC_MULHL_UU_SN, TILEPRO_OPC_MULLLA_SS_SN, TILEPRO_OPC_MULLLA_SU_SN,
7774 TILEPRO_OPC_MULLLA_UU_SN, TILEPRO_OPC_MULLLSA_UU_SN,
7775 TILEPRO_OPC_MULLL_SS_SN, TILEPRO_OPC_MULLL_SU_SN, TILEPRO_OPC_MULLL_UU_SN,
7776 TILEPRO_OPC_MVNZ_SN, TILEPRO_OPC_MVZ_SN, TILEPRO_OPC_MZB_SN,
7777 BITFIELD(18, 4) /* index 714 */,
7778 TILEPRO_OPC_MZH_SN, TILEPRO_OPC_MZ_SN, TILEPRO_OPC_NOR_SN, CHILD(731),
7779 TILEPRO_OPC_PACKHB_SN, TILEPRO_OPC_PACKLB_SN, TILEPRO_OPC_RL_SN,
7780 TILEPRO_OPC_S1A_SN, TILEPRO_OPC_S2A_SN, TILEPRO_OPC_S3A_SN,
7781 TILEPRO_OPC_SADAB_U_SN, TILEPRO_OPC_SADAH_SN, TILEPRO_OPC_SADAH_U_SN,
7782 TILEPRO_OPC_SADB_U_SN, TILEPRO_OPC_SADH_SN, TILEPRO_OPC_SADH_U_SN,
7783 BITFIELD(12, 2) /* index 731 */,
7784 TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, CHILD(736),
7785 BITFIELD(14, 2) /* index 736 */,
7786 TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, CHILD(741),
7787 BITFIELD(16, 2) /* index 741 */,
7788 TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN,
7789 TILEPRO_OPC_MOVE_SN,
7790 BITFIELD(18, 4) /* index 746 */,
7791 TILEPRO_OPC_SEQB_SN, TILEPRO_OPC_SEQH_SN, TILEPRO_OPC_SEQ_SN,
7792 TILEPRO_OPC_SHLB_SN, TILEPRO_OPC_SHLH_SN, TILEPRO_OPC_SHL_SN,
7793 TILEPRO_OPC_SHRB_SN, TILEPRO_OPC_SHRH_SN, TILEPRO_OPC_SHR_SN,
7794 TILEPRO_OPC_SLTB_SN, TILEPRO_OPC_SLTB_U_SN, TILEPRO_OPC_SLTEB_SN,
7795 TILEPRO_OPC_SLTEB_U_SN, TILEPRO_OPC_SLTEH_SN, TILEPRO_OPC_SLTEH_U_SN,
7796 TILEPRO_OPC_SLTE_SN,
7797 BITFIELD(18, 4) /* index 763 */,
7798 TILEPRO_OPC_SLTE_U_SN, TILEPRO_OPC_SLTH_SN, TILEPRO_OPC_SLTH_U_SN,
7799 TILEPRO_OPC_SLT_SN, TILEPRO_OPC_SLT_U_SN, TILEPRO_OPC_SNEB_SN,
7800 TILEPRO_OPC_SNEH_SN, TILEPRO_OPC_SNE_SN, TILEPRO_OPC_SRAB_SN,
7801 TILEPRO_OPC_SRAH_SN, TILEPRO_OPC_SRA_SN, TILEPRO_OPC_SUBB_SN,
7802 TILEPRO_OPC_SUBH_SN, TILEPRO_OPC_SUB_SN, TILEPRO_OPC_XOR_SN,
7803 TILEPRO_OPC_DWORD_ALIGN_SN,
7804 BITFIELD(18, 3) /* index 780 */,
7805 CHILD(789), CHILD(792), CHILD(795), CHILD(798), CHILD(801), CHILD(804),
7806 CHILD(807), CHILD(810),
7807 BITFIELD(21, 1) /* index 789 */,
7808 TILEPRO_OPC_ADDS_SN, TILEPRO_OPC_NONE,
7809 BITFIELD(21, 1) /* index 792 */,
7810 TILEPRO_OPC_SUBS_SN, TILEPRO_OPC_NONE,
7811 BITFIELD(21, 1) /* index 795 */,
7812 TILEPRO_OPC_ADDBS_U_SN, TILEPRO_OPC_NONE,
7813 BITFIELD(21, 1) /* index 798 */,
7814 TILEPRO_OPC_ADDHS_SN, TILEPRO_OPC_NONE,
7815 BITFIELD(21, 1) /* index 801 */,
7816 TILEPRO_OPC_SUBBS_U_SN, TILEPRO_OPC_NONE,
7817 BITFIELD(21, 1) /* index 804 */,
7818 TILEPRO_OPC_SUBHS_SN, TILEPRO_OPC_NONE,
7819 BITFIELD(21, 1) /* index 807 */,
7820 TILEPRO_OPC_PACKHS_SN, TILEPRO_OPC_NONE,
7821 BITFIELD(21, 1) /* index 810 */,
7822 TILEPRO_OPC_PACKBS_U_SN, TILEPRO_OPC_NONE,
7823 BITFIELD(6, 2) /* index 813 */,
7824 TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN,
7825 CHILD(818),
7826 BITFIELD(8, 2) /* index 818 */,
7827 TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN,
7828 CHILD(823),
7829 BITFIELD(10, 2) /* index 823 */,
7830 TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN,
7831 TILEPRO_OPC_MOVELI_SN,
7832 BITFIELD(6, 2) /* index 828 */,
7833 TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, CHILD(833),
7834 BITFIELD(8, 2) /* index 833 */,
7835 TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, CHILD(838),
7836 BITFIELD(10, 2) /* index 838 */,
7837 TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, TILEPRO_OPC_MOVELI,
7838 BITFIELD(0, 2) /* index 843 */,
7839 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(848),
7840 BITFIELD(2, 2) /* index 848 */,
7841 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(853),
7842 BITFIELD(4, 2) /* index 853 */,
7843 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(858),
7844 BITFIELD(6, 2) /* index 858 */,
7845 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(863),
7846 BITFIELD(8, 2) /* index 863 */,
7847 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(868),
7848 BITFIELD(10, 2) /* index 868 */,
7849 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_INFOL,
7850 BITFIELD(20, 2) /* index 873 */,
7851 TILEPRO_OPC_NONE, TILEPRO_OPC_ADDIB, TILEPRO_OPC_ADDIH, TILEPRO_OPC_ADDI,
7852 BITFIELD(20, 2) /* index 878 */,
7853 TILEPRO_OPC_MAXIB_U, TILEPRO_OPC_MAXIH, TILEPRO_OPC_MINIB_U,
7854 TILEPRO_OPC_MINIH,
7855 BITFIELD(20, 2) /* index 883 */,
7856 CHILD(888), TILEPRO_OPC_SEQIB, TILEPRO_OPC_SEQIH, TILEPRO_OPC_SEQI,
7857 BITFIELD(6, 2) /* index 888 */,
7858 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, CHILD(893),
7859 BITFIELD(8, 2) /* index 893 */,
7860 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, CHILD(898),
7861 BITFIELD(10, 2) /* index 898 */,
7862 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_MOVEI,
7863 BITFIELD(20, 2) /* index 903 */,
7864 TILEPRO_OPC_SLTIB, TILEPRO_OPC_SLTIB_U, TILEPRO_OPC_SLTIH,
7865 TILEPRO_OPC_SLTIH_U,
7866 BITFIELD(20, 2) /* index 908 */,
7867 TILEPRO_OPC_SLTI, TILEPRO_OPC_SLTI_U, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7868 BITFIELD(20, 2) /* index 913 */,
7869 TILEPRO_OPC_NONE, TILEPRO_OPC_ADDIB_SN, TILEPRO_OPC_ADDIH_SN,
7870 TILEPRO_OPC_ADDI_SN,
7871 BITFIELD(20, 2) /* index 918 */,
7872 TILEPRO_OPC_MAXIB_U_SN, TILEPRO_OPC_MAXIH_SN, TILEPRO_OPC_MINIB_U_SN,
7873 TILEPRO_OPC_MINIH_SN,
7874 BITFIELD(20, 2) /* index 923 */,
7875 CHILD(928), TILEPRO_OPC_SEQIB_SN, TILEPRO_OPC_SEQIH_SN, TILEPRO_OPC_SEQI_SN,
7876 BITFIELD(6, 2) /* index 928 */,
7877 TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, CHILD(933),
7878 BITFIELD(8, 2) /* index 933 */,
7879 TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, CHILD(938),
7880 BITFIELD(10, 2) /* index 938 */,
7881 TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN,
7882 TILEPRO_OPC_MOVEI_SN,
7883 BITFIELD(20, 2) /* index 943 */,
7884 TILEPRO_OPC_SLTIB_SN, TILEPRO_OPC_SLTIB_U_SN, TILEPRO_OPC_SLTIH_SN,
7885 TILEPRO_OPC_SLTIH_U_SN,
7886 BITFIELD(20, 2) /* index 948 */,
7887 TILEPRO_OPC_SLTI_SN, TILEPRO_OPC_SLTI_U_SN, TILEPRO_OPC_NONE,
7888 TILEPRO_OPC_NONE,
7889 BITFIELD(20, 2) /* index 953 */,
7890 TILEPRO_OPC_NONE, CHILD(958), TILEPRO_OPC_XORI, TILEPRO_OPC_NONE,
7891 BITFIELD(0, 2) /* index 958 */,
7892 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(963),
7893 BITFIELD(2, 2) /* index 963 */,
7894 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(968),
7895 BITFIELD(4, 2) /* index 968 */,
7896 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(973),
7897 BITFIELD(6, 2) /* index 973 */,
7898 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(978),
7899 BITFIELD(8, 2) /* index 978 */,
7900 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(983),
7901 BITFIELD(10, 2) /* index 983 */,
7902 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_INFO,
7903 BITFIELD(20, 2) /* index 988 */,
7904 TILEPRO_OPC_NONE, TILEPRO_OPC_ANDI_SN, TILEPRO_OPC_XORI_SN,
7905 TILEPRO_OPC_NONE,
7906 BITFIELD(17, 5) /* index 993 */,
7907 TILEPRO_OPC_NONE, TILEPRO_OPC_RLI, TILEPRO_OPC_SHLIB, TILEPRO_OPC_SHLIH,
7908 TILEPRO_OPC_SHLI, TILEPRO_OPC_SHRIB, TILEPRO_OPC_SHRIH, TILEPRO_OPC_SHRI,
7909 TILEPRO_OPC_SRAIB, TILEPRO_OPC_SRAIH, TILEPRO_OPC_SRAI, CHILD(1026),
7910 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7911 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7912 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7913 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7914 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7915 BITFIELD(12, 4) /* index 1026 */,
7916 TILEPRO_OPC_NONE, CHILD(1043), CHILD(1046), CHILD(1049), CHILD(1052),
7917 CHILD(1055), CHILD(1058), CHILD(1061), CHILD(1064), CHILD(1067),
7918 CHILD(1070), CHILD(1073), TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7919 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7920 BITFIELD(16, 1) /* index 1043 */,
7921 TILEPRO_OPC_BITX, TILEPRO_OPC_NONE,
7922 BITFIELD(16, 1) /* index 1046 */,
7923 TILEPRO_OPC_BYTEX, TILEPRO_OPC_NONE,
7924 BITFIELD(16, 1) /* index 1049 */,
7925 TILEPRO_OPC_CLZ, TILEPRO_OPC_NONE,
7926 BITFIELD(16, 1) /* index 1052 */,
7927 TILEPRO_OPC_CTZ, TILEPRO_OPC_NONE,
7928 BITFIELD(16, 1) /* index 1055 */,
7929 TILEPRO_OPC_FNOP, TILEPRO_OPC_NONE,
7930 BITFIELD(16, 1) /* index 1058 */,
7931 TILEPRO_OPC_NOP, TILEPRO_OPC_NONE,
7932 BITFIELD(16, 1) /* index 1061 */,
7933 TILEPRO_OPC_PCNT, TILEPRO_OPC_NONE,
7934 BITFIELD(16, 1) /* index 1064 */,
7935 TILEPRO_OPC_TBLIDXB0, TILEPRO_OPC_NONE,
7936 BITFIELD(16, 1) /* index 1067 */,
7937 TILEPRO_OPC_TBLIDXB1, TILEPRO_OPC_NONE,
7938 BITFIELD(16, 1) /* index 1070 */,
7939 TILEPRO_OPC_TBLIDXB2, TILEPRO_OPC_NONE,
7940 BITFIELD(16, 1) /* index 1073 */,
7941 TILEPRO_OPC_TBLIDXB3, TILEPRO_OPC_NONE,
7942 BITFIELD(17, 5) /* index 1076 */,
7943 TILEPRO_OPC_NONE, TILEPRO_OPC_RLI_SN, TILEPRO_OPC_SHLIB_SN,
7944 TILEPRO_OPC_SHLIH_SN, TILEPRO_OPC_SHLI_SN, TILEPRO_OPC_SHRIB_SN,
7945 TILEPRO_OPC_SHRIH_SN, TILEPRO_OPC_SHRI_SN, TILEPRO_OPC_SRAIB_SN,
7946 TILEPRO_OPC_SRAIH_SN, TILEPRO_OPC_SRAI_SN, CHILD(1109), TILEPRO_OPC_NONE,
7947 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7948 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7949 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7950 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7951 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7952 BITFIELD(12, 4) /* index 1109 */,
7953 TILEPRO_OPC_NONE, CHILD(1126), CHILD(1129), CHILD(1132), CHILD(1135),
7954 CHILD(1055), CHILD(1058), CHILD(1138), CHILD(1141), CHILD(1144),
7955 CHILD(1147), CHILD(1150), TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7956 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7957 BITFIELD(16, 1) /* index 1126 */,
7958 TILEPRO_OPC_BITX_SN, TILEPRO_OPC_NONE,
7959 BITFIELD(16, 1) /* index 1129 */,
7960 TILEPRO_OPC_BYTEX_SN, TILEPRO_OPC_NONE,
7961 BITFIELD(16, 1) /* index 1132 */,
7962 TILEPRO_OPC_CLZ_SN, TILEPRO_OPC_NONE,
7963 BITFIELD(16, 1) /* index 1135 */,
7964 TILEPRO_OPC_CTZ_SN, TILEPRO_OPC_NONE,
7965 BITFIELD(16, 1) /* index 1138 */,
7966 TILEPRO_OPC_PCNT_SN, TILEPRO_OPC_NONE,
7967 BITFIELD(16, 1) /* index 1141 */,
7968 TILEPRO_OPC_TBLIDXB0_SN, TILEPRO_OPC_NONE,
7969 BITFIELD(16, 1) /* index 1144 */,
7970 TILEPRO_OPC_TBLIDXB1_SN, TILEPRO_OPC_NONE,
7971 BITFIELD(16, 1) /* index 1147 */,
7972 TILEPRO_OPC_TBLIDXB2_SN, TILEPRO_OPC_NONE,
7973 BITFIELD(16, 1) /* index 1150 */,
7974 TILEPRO_OPC_TBLIDXB3_SN, TILEPRO_OPC_NONE,
7975 };
7976
7977 static const unsigned short decode_X1_fsm[1580] =
7978 {
7979 BITFIELD(54, 9) /* index 0 */,
7980 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7981 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7982 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7983 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7984 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7985 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7986 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7987 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7988 CHILD(513), CHILD(561), CHILD(594), TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7989 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7990 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7991 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, CHILD(641),
7992 CHILD(689), CHILD(722), TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7993 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7994 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
7995 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, CHILD(766),
7996 CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
7997 CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
7998 CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
7999 CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
8000 CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766), CHILD(766),
8001 CHILD(766), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
8002 CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
8003 CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
8004 CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
8005 CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781), CHILD(781),
8006 CHILD(781), CHILD(781), CHILD(781), CHILD(796), CHILD(796), CHILD(796),
8007 CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796),
8008 CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796),
8009 CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796),
8010 CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796),
8011 CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(796), CHILD(826),
8012 CHILD(826), CHILD(826), CHILD(826), CHILD(826), CHILD(826), CHILD(826),
8013 CHILD(826), CHILD(826), CHILD(826), CHILD(826), CHILD(826), CHILD(826),
8014 CHILD(826), CHILD(826), CHILD(826), CHILD(843), CHILD(843), CHILD(843),
8015 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
8016 CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843), CHILD(843),
8017 CHILD(843), CHILD(860), CHILD(899), CHILD(923), CHILD(932),
8018 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8019 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8020 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8021 CHILD(961), CHILD(970), CHILD(994), CHILD(1003), TILEPRO_OPC_NONE,
8022 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8023 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8024 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_MM,
8025 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
8026 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
8027 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
8028 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
8029 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
8030 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
8031 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM,
8032 TILEPRO_OPC_MM, TILEPRO_OPC_MM, TILEPRO_OPC_MM, CHILD(1032),
8033 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8034 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8035 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8036 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, CHILD(1374),
8037 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8038 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8039 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8040 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8041 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8042 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8043 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8044 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8045 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8046 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8047 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8048 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_J,
8049 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8050 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8051 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8052 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8053 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8054 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8055 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8056 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8057 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8058 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8059 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8060 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J,
8061 TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_J, TILEPRO_OPC_JAL,
8062 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8063 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8064 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8065 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8066 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8067 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8068 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8069 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8070 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8071 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8072 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8073 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8074 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8075 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8076 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL,
8077 TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_JAL, TILEPRO_OPC_NONE,
8078 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8079 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8080 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8081 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8082 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8083 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8084 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8085 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8086 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8087 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8088 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8089 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8090 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8091 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8092 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8093 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8094 BITFIELD(49, 5) /* index 513 */,
8095 TILEPRO_OPC_NONE, TILEPRO_OPC_ADDB, TILEPRO_OPC_ADDH, TILEPRO_OPC_ADD,
8096 TILEPRO_OPC_AND, TILEPRO_OPC_INTHB, TILEPRO_OPC_INTHH, TILEPRO_OPC_INTLB,
8097 TILEPRO_OPC_INTLH, TILEPRO_OPC_JALRP, TILEPRO_OPC_JALR, TILEPRO_OPC_JRP,
8098 TILEPRO_OPC_JR, TILEPRO_OPC_LNK, TILEPRO_OPC_MAXB_U, TILEPRO_OPC_MAXH,
8099 TILEPRO_OPC_MINB_U, TILEPRO_OPC_MINH, TILEPRO_OPC_MNZB, TILEPRO_OPC_MNZH,
8100 TILEPRO_OPC_MNZ, TILEPRO_OPC_MZB, TILEPRO_OPC_MZH, TILEPRO_OPC_MZ,
8101 TILEPRO_OPC_NOR, CHILD(546), TILEPRO_OPC_PACKHB, TILEPRO_OPC_PACKLB,
8102 TILEPRO_OPC_RL, TILEPRO_OPC_S1A, TILEPRO_OPC_S2A, TILEPRO_OPC_S3A,
8103 BITFIELD(43, 2) /* index 546 */,
8104 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, CHILD(551),
8105 BITFIELD(45, 2) /* index 551 */,
8106 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, CHILD(556),
8107 BITFIELD(47, 2) /* index 556 */,
8108 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_MOVE,
8109 BITFIELD(49, 5) /* index 561 */,
8110 TILEPRO_OPC_SB, TILEPRO_OPC_SEQB, TILEPRO_OPC_SEQH, TILEPRO_OPC_SEQ,
8111 TILEPRO_OPC_SHLB, TILEPRO_OPC_SHLH, TILEPRO_OPC_SHL, TILEPRO_OPC_SHRB,
8112 TILEPRO_OPC_SHRH, TILEPRO_OPC_SHR, TILEPRO_OPC_SH, TILEPRO_OPC_SLTB,
8113 TILEPRO_OPC_SLTB_U, TILEPRO_OPC_SLTEB, TILEPRO_OPC_SLTEB_U,
8114 TILEPRO_OPC_SLTEH, TILEPRO_OPC_SLTEH_U, TILEPRO_OPC_SLTE,
8115 TILEPRO_OPC_SLTE_U, TILEPRO_OPC_SLTH, TILEPRO_OPC_SLTH_U, TILEPRO_OPC_SLT,
8116 TILEPRO_OPC_SLT_U, TILEPRO_OPC_SNEB, TILEPRO_OPC_SNEH, TILEPRO_OPC_SNE,
8117 TILEPRO_OPC_SRAB, TILEPRO_OPC_SRAH, TILEPRO_OPC_SRA, TILEPRO_OPC_SUBB,
8118 TILEPRO_OPC_SUBH, TILEPRO_OPC_SUB,
8119 BITFIELD(49, 4) /* index 594 */,
8120 CHILD(611), CHILD(614), CHILD(617), CHILD(620), CHILD(623), CHILD(626),
8121 CHILD(629), CHILD(632), CHILD(635), CHILD(638), TILEPRO_OPC_NONE,
8122 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8123 TILEPRO_OPC_NONE,
8124 BITFIELD(53, 1) /* index 611 */,
8125 TILEPRO_OPC_SW, TILEPRO_OPC_NONE,
8126 BITFIELD(53, 1) /* index 614 */,
8127 TILEPRO_OPC_XOR, TILEPRO_OPC_NONE,
8128 BITFIELD(53, 1) /* index 617 */,
8129 TILEPRO_OPC_ADDS, TILEPRO_OPC_NONE,
8130 BITFIELD(53, 1) /* index 620 */,
8131 TILEPRO_OPC_SUBS, TILEPRO_OPC_NONE,
8132 BITFIELD(53, 1) /* index 623 */,
8133 TILEPRO_OPC_ADDBS_U, TILEPRO_OPC_NONE,
8134 BITFIELD(53, 1) /* index 626 */,
8135 TILEPRO_OPC_ADDHS, TILEPRO_OPC_NONE,
8136 BITFIELD(53, 1) /* index 629 */,
8137 TILEPRO_OPC_SUBBS_U, TILEPRO_OPC_NONE,
8138 BITFIELD(53, 1) /* index 632 */,
8139 TILEPRO_OPC_SUBHS, TILEPRO_OPC_NONE,
8140 BITFIELD(53, 1) /* index 635 */,
8141 TILEPRO_OPC_PACKHS, TILEPRO_OPC_NONE,
8142 BITFIELD(53, 1) /* index 638 */,
8143 TILEPRO_OPC_PACKBS_U, TILEPRO_OPC_NONE,
8144 BITFIELD(49, 5) /* index 641 */,
8145 TILEPRO_OPC_NONE, TILEPRO_OPC_ADDB_SN, TILEPRO_OPC_ADDH_SN,
8146 TILEPRO_OPC_ADD_SN, TILEPRO_OPC_AND_SN, TILEPRO_OPC_INTHB_SN,
8147 TILEPRO_OPC_INTHH_SN, TILEPRO_OPC_INTLB_SN, TILEPRO_OPC_INTLH_SN,
8148 TILEPRO_OPC_JALRP, TILEPRO_OPC_JALR, TILEPRO_OPC_JRP, TILEPRO_OPC_JR,
8149 TILEPRO_OPC_LNK_SN, TILEPRO_OPC_MAXB_U_SN, TILEPRO_OPC_MAXH_SN,
8150 TILEPRO_OPC_MINB_U_SN, TILEPRO_OPC_MINH_SN, TILEPRO_OPC_MNZB_SN,
8151 TILEPRO_OPC_MNZH_SN, TILEPRO_OPC_MNZ_SN, TILEPRO_OPC_MZB_SN,
8152 TILEPRO_OPC_MZH_SN, TILEPRO_OPC_MZ_SN, TILEPRO_OPC_NOR_SN, CHILD(674),
8153 TILEPRO_OPC_PACKHB_SN, TILEPRO_OPC_PACKLB_SN, TILEPRO_OPC_RL_SN,
8154 TILEPRO_OPC_S1A_SN, TILEPRO_OPC_S2A_SN, TILEPRO_OPC_S3A_SN,
8155 BITFIELD(43, 2) /* index 674 */,
8156 TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, CHILD(679),
8157 BITFIELD(45, 2) /* index 679 */,
8158 TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, CHILD(684),
8159 BITFIELD(47, 2) /* index 684 */,
8160 TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN, TILEPRO_OPC_OR_SN,
8161 TILEPRO_OPC_MOVE_SN,
8162 BITFIELD(49, 5) /* index 689 */,
8163 TILEPRO_OPC_SB, TILEPRO_OPC_SEQB_SN, TILEPRO_OPC_SEQH_SN,
8164 TILEPRO_OPC_SEQ_SN, TILEPRO_OPC_SHLB_SN, TILEPRO_OPC_SHLH_SN,
8165 TILEPRO_OPC_SHL_SN, TILEPRO_OPC_SHRB_SN, TILEPRO_OPC_SHRH_SN,
8166 TILEPRO_OPC_SHR_SN, TILEPRO_OPC_SH, TILEPRO_OPC_SLTB_SN,
8167 TILEPRO_OPC_SLTB_U_SN, TILEPRO_OPC_SLTEB_SN, TILEPRO_OPC_SLTEB_U_SN,
8168 TILEPRO_OPC_SLTEH_SN, TILEPRO_OPC_SLTEH_U_SN, TILEPRO_OPC_SLTE_SN,
8169 TILEPRO_OPC_SLTE_U_SN, TILEPRO_OPC_SLTH_SN, TILEPRO_OPC_SLTH_U_SN,
8170 TILEPRO_OPC_SLT_SN, TILEPRO_OPC_SLT_U_SN, TILEPRO_OPC_SNEB_SN,
8171 TILEPRO_OPC_SNEH_SN, TILEPRO_OPC_SNE_SN, TILEPRO_OPC_SRAB_SN,
8172 TILEPRO_OPC_SRAH_SN, TILEPRO_OPC_SRA_SN, TILEPRO_OPC_SUBB_SN,
8173 TILEPRO_OPC_SUBH_SN, TILEPRO_OPC_SUB_SN,
8174 BITFIELD(49, 4) /* index 722 */,
8175 CHILD(611), CHILD(739), CHILD(742), CHILD(745), CHILD(748), CHILD(751),
8176 CHILD(754), CHILD(757), CHILD(760), CHILD(763), TILEPRO_OPC_NONE,
8177 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8178 TILEPRO_OPC_NONE,
8179 BITFIELD(53, 1) /* index 739 */,
8180 TILEPRO_OPC_XOR_SN, TILEPRO_OPC_NONE,
8181 BITFIELD(53, 1) /* index 742 */,
8182 TILEPRO_OPC_ADDS_SN, TILEPRO_OPC_NONE,
8183 BITFIELD(53, 1) /* index 745 */,
8184 TILEPRO_OPC_SUBS_SN, TILEPRO_OPC_NONE,
8185 BITFIELD(53, 1) /* index 748 */,
8186 TILEPRO_OPC_ADDBS_U_SN, TILEPRO_OPC_NONE,
8187 BITFIELD(53, 1) /* index 751 */,
8188 TILEPRO_OPC_ADDHS_SN, TILEPRO_OPC_NONE,
8189 BITFIELD(53, 1) /* index 754 */,
8190 TILEPRO_OPC_SUBBS_U_SN, TILEPRO_OPC_NONE,
8191 BITFIELD(53, 1) /* index 757 */,
8192 TILEPRO_OPC_SUBHS_SN, TILEPRO_OPC_NONE,
8193 BITFIELD(53, 1) /* index 760 */,
8194 TILEPRO_OPC_PACKHS_SN, TILEPRO_OPC_NONE,
8195 BITFIELD(53, 1) /* index 763 */,
8196 TILEPRO_OPC_PACKBS_U_SN, TILEPRO_OPC_NONE,
8197 BITFIELD(37, 2) /* index 766 */,
8198 TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN,
8199 CHILD(771),
8200 BITFIELD(39, 2) /* index 771 */,
8201 TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN,
8202 CHILD(776),
8203 BITFIELD(41, 2) /* index 776 */,
8204 TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN, TILEPRO_OPC_ADDLI_SN,
8205 TILEPRO_OPC_MOVELI_SN,
8206 BITFIELD(37, 2) /* index 781 */,
8207 TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, CHILD(786),
8208 BITFIELD(39, 2) /* index 786 */,
8209 TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, CHILD(791),
8210 BITFIELD(41, 2) /* index 791 */,
8211 TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, TILEPRO_OPC_ADDLI, TILEPRO_OPC_MOVELI,
8212 BITFIELD(31, 2) /* index 796 */,
8213 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(801),
8214 BITFIELD(33, 2) /* index 801 */,
8215 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(806),
8216 BITFIELD(35, 2) /* index 806 */,
8217 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(811),
8218 BITFIELD(37, 2) /* index 811 */,
8219 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(816),
8220 BITFIELD(39, 2) /* index 816 */,
8221 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, CHILD(821),
8222 BITFIELD(41, 2) /* index 821 */,
8223 TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_AULI, TILEPRO_OPC_INFOL,
8224 BITFIELD(31, 4) /* index 826 */,
8225 TILEPRO_OPC_BZ, TILEPRO_OPC_BZT, TILEPRO_OPC_BNZ, TILEPRO_OPC_BNZT,
8226 TILEPRO_OPC_BGZ, TILEPRO_OPC_BGZT, TILEPRO_OPC_BGEZ, TILEPRO_OPC_BGEZT,
8227 TILEPRO_OPC_BLZ, TILEPRO_OPC_BLZT, TILEPRO_OPC_BLEZ, TILEPRO_OPC_BLEZT,
8228 TILEPRO_OPC_BBS, TILEPRO_OPC_BBST, TILEPRO_OPC_BBNS, TILEPRO_OPC_BBNST,
8229 BITFIELD(31, 4) /* index 843 */,
8230 TILEPRO_OPC_BZ_SN, TILEPRO_OPC_BZT_SN, TILEPRO_OPC_BNZ_SN,
8231 TILEPRO_OPC_BNZT_SN, TILEPRO_OPC_BGZ_SN, TILEPRO_OPC_BGZT_SN,
8232 TILEPRO_OPC_BGEZ_SN, TILEPRO_OPC_BGEZT_SN, TILEPRO_OPC_BLZ_SN,
8233 TILEPRO_OPC_BLZT_SN, TILEPRO_OPC_BLEZ_SN, TILEPRO_OPC_BLEZT_SN,
8234 TILEPRO_OPC_BBS_SN, TILEPRO_OPC_BBST_SN, TILEPRO_OPC_BBNS_SN,
8235 TILEPRO_OPC_BBNST_SN,
8236 BITFIELD(51, 3) /* index 860 */,
8237 TILEPRO_OPC_NONE, TILEPRO_OPC_ADDIB, TILEPRO_OPC_ADDIH, TILEPRO_OPC_ADDI,
8238 CHILD(869), TILEPRO_OPC_MAXIB_U, TILEPRO_OPC_MAXIH, TILEPRO_OPC_MFSPR,
8239 BITFIELD(31, 2) /* index 869 */,
8240 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(874),
8241 BITFIELD(33, 2) /* index 874 */,
8242 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(879),
8243 BITFIELD(35, 2) /* index 879 */,
8244 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(884),
8245 BITFIELD(37, 2) /* index 884 */,
8246 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(889),
8247 BITFIELD(39, 2) /* index 889 */,
8248 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(894),
8249 BITFIELD(41, 2) /* index 894 */,
8250 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_INFO,
8251 BITFIELD(51, 3) /* index 899 */,
8252 TILEPRO_OPC_MINIB_U, TILEPRO_OPC_MINIH, TILEPRO_OPC_MTSPR, CHILD(908),
8253 TILEPRO_OPC_SEQIB, TILEPRO_OPC_SEQIH, TILEPRO_OPC_SEQI, TILEPRO_OPC_SLTIB,
8254 BITFIELD(37, 2) /* index 908 */,
8255 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, CHILD(913),
8256 BITFIELD(39, 2) /* index 913 */,
8257 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, CHILD(918),
8258 BITFIELD(41, 2) /* index 918 */,
8259 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_MOVEI,
8260 BITFIELD(51, 3) /* index 923 */,
8261 TILEPRO_OPC_SLTIB_U, TILEPRO_OPC_SLTIH, TILEPRO_OPC_SLTIH_U,
8262 TILEPRO_OPC_SLTI, TILEPRO_OPC_SLTI_U, TILEPRO_OPC_XORI, TILEPRO_OPC_LBADD,
8263 TILEPRO_OPC_LBADD_U,
8264 BITFIELD(51, 3) /* index 932 */,
8265 TILEPRO_OPC_LHADD, TILEPRO_OPC_LHADD_U, CHILD(941), TILEPRO_OPC_LWADD_NA,
8266 TILEPRO_OPC_SBADD, TILEPRO_OPC_SHADD, TILEPRO_OPC_SWADD, TILEPRO_OPC_NONE,
8267 BITFIELD(43, 2) /* index 941 */,
8268 CHILD(946), TILEPRO_OPC_LWADD, TILEPRO_OPC_LWADD, TILEPRO_OPC_LWADD,
8269 BITFIELD(45, 2) /* index 946 */,
8270 CHILD(951), TILEPRO_OPC_LWADD, TILEPRO_OPC_LWADD, TILEPRO_OPC_LWADD,
8271 BITFIELD(47, 2) /* index 951 */,
8272 CHILD(956), TILEPRO_OPC_LWADD, TILEPRO_OPC_LWADD, TILEPRO_OPC_LWADD,
8273 BITFIELD(49, 2) /* index 956 */,
8274 TILEPRO_OPC_LW_TLS, TILEPRO_OPC_LWADD, TILEPRO_OPC_LWADD, TILEPRO_OPC_LWADD,
8275 BITFIELD(51, 3) /* index 961 */,
8276 TILEPRO_OPC_NONE, TILEPRO_OPC_ADDIB_SN, TILEPRO_OPC_ADDIH_SN,
8277 TILEPRO_OPC_ADDI_SN, TILEPRO_OPC_ANDI_SN, TILEPRO_OPC_MAXIB_U_SN,
8278 TILEPRO_OPC_MAXIH_SN, TILEPRO_OPC_MFSPR,
8279 BITFIELD(51, 3) /* index 970 */,
8280 TILEPRO_OPC_MINIB_U_SN, TILEPRO_OPC_MINIH_SN, TILEPRO_OPC_MTSPR, CHILD(979),
8281 TILEPRO_OPC_SEQIB_SN, TILEPRO_OPC_SEQIH_SN, TILEPRO_OPC_SEQI_SN,
8282 TILEPRO_OPC_SLTIB_SN,
8283 BITFIELD(37, 2) /* index 979 */,
8284 TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, CHILD(984),
8285 BITFIELD(39, 2) /* index 984 */,
8286 TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, CHILD(989),
8287 BITFIELD(41, 2) /* index 989 */,
8288 TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN, TILEPRO_OPC_ORI_SN,
8289 TILEPRO_OPC_MOVEI_SN,
8290 BITFIELD(51, 3) /* index 994 */,
8291 TILEPRO_OPC_SLTIB_U_SN, TILEPRO_OPC_SLTIH_SN, TILEPRO_OPC_SLTIH_U_SN,
8292 TILEPRO_OPC_SLTI_SN, TILEPRO_OPC_SLTI_U_SN, TILEPRO_OPC_XORI_SN,
8293 TILEPRO_OPC_LBADD_SN, TILEPRO_OPC_LBADD_U_SN,
8294 BITFIELD(51, 3) /* index 1003 */,
8295 TILEPRO_OPC_LHADD_SN, TILEPRO_OPC_LHADD_U_SN, CHILD(1012),
8296 TILEPRO_OPC_LWADD_NA_SN, TILEPRO_OPC_SBADD, TILEPRO_OPC_SHADD,
8297 TILEPRO_OPC_SWADD, TILEPRO_OPC_NONE,
8298 BITFIELD(43, 2) /* index 1012 */,
8299 CHILD(1017), TILEPRO_OPC_LWADD_SN, TILEPRO_OPC_LWADD_SN,
8300 TILEPRO_OPC_LWADD_SN,
8301 BITFIELD(45, 2) /* index 1017 */,
8302 CHILD(1022), TILEPRO_OPC_LWADD_SN, TILEPRO_OPC_LWADD_SN,
8303 TILEPRO_OPC_LWADD_SN,
8304 BITFIELD(47, 2) /* index 1022 */,
8305 CHILD(1027), TILEPRO_OPC_LWADD_SN, TILEPRO_OPC_LWADD_SN,
8306 TILEPRO_OPC_LWADD_SN,
8307 BITFIELD(49, 2) /* index 1027 */,
8308 TILEPRO_OPC_LW_TLS_SN, TILEPRO_OPC_LWADD_SN, TILEPRO_OPC_LWADD_SN,
8309 TILEPRO_OPC_LWADD_SN,
8310 BITFIELD(46, 7) /* index 1032 */,
8311 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8312 CHILD(1161), CHILD(1161), CHILD(1161), CHILD(1161), CHILD(1164),
8313 CHILD(1164), CHILD(1164), CHILD(1164), CHILD(1167), CHILD(1167),
8314 CHILD(1167), CHILD(1167), CHILD(1170), CHILD(1170), CHILD(1170),
8315 CHILD(1170), CHILD(1173), CHILD(1173), CHILD(1173), CHILD(1173),
8316 CHILD(1176), CHILD(1176), CHILD(1176), CHILD(1176), CHILD(1179),
8317 CHILD(1179), CHILD(1179), CHILD(1179), CHILD(1182), CHILD(1182),
8318 CHILD(1182), CHILD(1182), CHILD(1185), CHILD(1185), CHILD(1185),
8319 CHILD(1185), CHILD(1188), CHILD(1188), CHILD(1188), CHILD(1188),
8320 CHILD(1191), CHILD(1282), CHILD(1330), CHILD(1363), TILEPRO_OPC_NONE,
8321 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8322 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8323 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8324 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8325 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8326 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8327 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8328 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8329 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8330 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8331 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8332 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8333 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8334 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8335 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8336 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8337 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8338 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8339 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8340 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8341 BITFIELD(53, 1) /* index 1161 */,
8342 TILEPRO_OPC_RLI, TILEPRO_OPC_NONE,
8343 BITFIELD(53, 1) /* index 1164 */,
8344 TILEPRO_OPC_SHLIB, TILEPRO_OPC_NONE,
8345 BITFIELD(53, 1) /* index 1167 */,
8346 TILEPRO_OPC_SHLIH, TILEPRO_OPC_NONE,
8347 BITFIELD(53, 1) /* index 1170 */,
8348 TILEPRO_OPC_SHLI, TILEPRO_OPC_NONE,
8349 BITFIELD(53, 1) /* index 1173 */,
8350 TILEPRO_OPC_SHRIB, TILEPRO_OPC_NONE,
8351 BITFIELD(53, 1) /* index 1176 */,
8352 TILEPRO_OPC_SHRIH, TILEPRO_OPC_NONE,
8353 BITFIELD(53, 1) /* index 1179 */,
8354 TILEPRO_OPC_SHRI, TILEPRO_OPC_NONE,
8355 BITFIELD(53, 1) /* index 1182 */,
8356 TILEPRO_OPC_SRAIB, TILEPRO_OPC_NONE,
8357 BITFIELD(53, 1) /* index 1185 */,
8358 TILEPRO_OPC_SRAIH, TILEPRO_OPC_NONE,
8359 BITFIELD(53, 1) /* index 1188 */,
8360 TILEPRO_OPC_SRAI, TILEPRO_OPC_NONE,
8361 BITFIELD(43, 3) /* index 1191 */,
8362 TILEPRO_OPC_NONE, CHILD(1200), CHILD(1203), CHILD(1206), CHILD(1209),
8363 CHILD(1212), CHILD(1215), CHILD(1218),
8364 BITFIELD(53, 1) /* index 1200 */,
8365 TILEPRO_OPC_DRAIN, TILEPRO_OPC_NONE,
8366 BITFIELD(53, 1) /* index 1203 */,
8367 TILEPRO_OPC_DTLBPR, TILEPRO_OPC_NONE,
8368 BITFIELD(53, 1) /* index 1206 */,
8369 TILEPRO_OPC_FINV, TILEPRO_OPC_NONE,
8370 BITFIELD(53, 1) /* index 1209 */,
8371 TILEPRO_OPC_FLUSH, TILEPRO_OPC_NONE,
8372 BITFIELD(53, 1) /* index 1212 */,
8373 TILEPRO_OPC_FNOP, TILEPRO_OPC_NONE,
8374 BITFIELD(53, 1) /* index 1215 */,
8375 TILEPRO_OPC_ICOH, TILEPRO_OPC_NONE,
8376 BITFIELD(31, 2) /* index 1218 */,
8377 CHILD(1223), CHILD(1251), CHILD(1279), CHILD(1279),
8378 BITFIELD(53, 1) /* index 1223 */,
8379 CHILD(1226), TILEPRO_OPC_NONE,
8380 BITFIELD(33, 2) /* index 1226 */,
8381 TILEPRO_OPC_ILL, TILEPRO_OPC_ILL, TILEPRO_OPC_ILL, CHILD(1231),
8382 BITFIELD(35, 2) /* index 1231 */,
8383 TILEPRO_OPC_ILL, CHILD(1236), TILEPRO_OPC_ILL, TILEPRO_OPC_ILL,
8384 BITFIELD(37, 2) /* index 1236 */,
8385 TILEPRO_OPC_ILL, CHILD(1241), TILEPRO_OPC_ILL, TILEPRO_OPC_ILL,
8386 BITFIELD(39, 2) /* index 1241 */,
8387 TILEPRO_OPC_ILL, CHILD(1246), TILEPRO_OPC_ILL, TILEPRO_OPC_ILL,
8388 BITFIELD(41, 2) /* index 1246 */,
8389 TILEPRO_OPC_ILL, TILEPRO_OPC_ILL, TILEPRO_OPC_BPT, TILEPRO_OPC_ILL,
8390 BITFIELD(53, 1) /* index 1251 */,
8391 CHILD(1254), TILEPRO_OPC_NONE,
8392 BITFIELD(33, 2) /* index 1254 */,
8393 TILEPRO_OPC_ILL, TILEPRO_OPC_ILL, TILEPRO_OPC_ILL, CHILD(1259),
8394 BITFIELD(35, 2) /* index 1259 */,
8395 TILEPRO_OPC_ILL, CHILD(1264), TILEPRO_OPC_ILL, TILEPRO_OPC_ILL,
8396 BITFIELD(37, 2) /* index 1264 */,
8397 TILEPRO_OPC_ILL, CHILD(1269), TILEPRO_OPC_ILL, TILEPRO_OPC_ILL,
8398 BITFIELD(39, 2) /* index 1269 */,
8399 TILEPRO_OPC_ILL, CHILD(1274), TILEPRO_OPC_ILL, TILEPRO_OPC_ILL,
8400 BITFIELD(41, 2) /* index 1274 */,
8401 TILEPRO_OPC_ILL, TILEPRO_OPC_ILL, TILEPRO_OPC_RAISE, TILEPRO_OPC_ILL,
8402 BITFIELD(53, 1) /* index 1279 */,
8403 TILEPRO_OPC_ILL, TILEPRO_OPC_NONE,
8404 BITFIELD(43, 3) /* index 1282 */,
8405 CHILD(1291), CHILD(1294), CHILD(1297), CHILD(1315), CHILD(1318),
8406 CHILD(1321), CHILD(1324), CHILD(1327),
8407 BITFIELD(53, 1) /* index 1291 */,
8408 TILEPRO_OPC_INV, TILEPRO_OPC_NONE,
8409 BITFIELD(53, 1) /* index 1294 */,
8410 TILEPRO_OPC_IRET, TILEPRO_OPC_NONE,
8411 BITFIELD(53, 1) /* index 1297 */,
8412 CHILD(1300), TILEPRO_OPC_NONE,
8413 BITFIELD(31, 2) /* index 1300 */,
8414 TILEPRO_OPC_LB, TILEPRO_OPC_LB, TILEPRO_OPC_LB, CHILD(1305),
8415 BITFIELD(33, 2) /* index 1305 */,
8416 TILEPRO_OPC_LB, TILEPRO_OPC_LB, TILEPRO_OPC_LB, CHILD(1310),
8417 BITFIELD(35, 2) /* index 1310 */,
8418 TILEPRO_OPC_LB, TILEPRO_OPC_LB, TILEPRO_OPC_LB, TILEPRO_OPC_PREFETCH,
8419 BITFIELD(53, 1) /* index 1315 */,
8420 TILEPRO_OPC_LB_U, TILEPRO_OPC_NONE,
8421 BITFIELD(53, 1) /* index 1318 */,
8422 TILEPRO_OPC_LH, TILEPRO_OPC_NONE,
8423 BITFIELD(53, 1) /* index 1321 */,
8424 TILEPRO_OPC_LH_U, TILEPRO_OPC_NONE,
8425 BITFIELD(53, 1) /* index 1324 */,
8426 TILEPRO_OPC_LW, TILEPRO_OPC_NONE,
8427 BITFIELD(53, 1) /* index 1327 */,
8428 TILEPRO_OPC_MF, TILEPRO_OPC_NONE,
8429 BITFIELD(43, 3) /* index 1330 */,
8430 CHILD(1339), CHILD(1342), CHILD(1345), CHILD(1348), CHILD(1351),
8431 CHILD(1354), CHILD(1357), CHILD(1360),
8432 BITFIELD(53, 1) /* index 1339 */,
8433 TILEPRO_OPC_NAP, TILEPRO_OPC_NONE,
8434 BITFIELD(53, 1) /* index 1342 */,
8435 TILEPRO_OPC_NOP, TILEPRO_OPC_NONE,
8436 BITFIELD(53, 1) /* index 1345 */,
8437 TILEPRO_OPC_SWINT0, TILEPRO_OPC_NONE,
8438 BITFIELD(53, 1) /* index 1348 */,
8439 TILEPRO_OPC_SWINT1, TILEPRO_OPC_NONE,
8440 BITFIELD(53, 1) /* index 1351 */,
8441 TILEPRO_OPC_SWINT2, TILEPRO_OPC_NONE,
8442 BITFIELD(53, 1) /* index 1354 */,
8443 TILEPRO_OPC_SWINT3, TILEPRO_OPC_NONE,
8444 BITFIELD(53, 1) /* index 1357 */,
8445 TILEPRO_OPC_TNS, TILEPRO_OPC_NONE,
8446 BITFIELD(53, 1) /* index 1360 */,
8447 TILEPRO_OPC_WH64, TILEPRO_OPC_NONE,
8448 BITFIELD(43, 2) /* index 1363 */,
8449 CHILD(1368), TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8450 BITFIELD(45, 1) /* index 1368 */,
8451 CHILD(1371), TILEPRO_OPC_NONE,
8452 BITFIELD(53, 1) /* index 1371 */,
8453 TILEPRO_OPC_LW_NA, TILEPRO_OPC_NONE,
8454 BITFIELD(46, 7) /* index 1374 */,
8455 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8456 CHILD(1503), CHILD(1503), CHILD(1503), CHILD(1503), CHILD(1506),
8457 CHILD(1506), CHILD(1506), CHILD(1506), CHILD(1509), CHILD(1509),
8458 CHILD(1509), CHILD(1509), CHILD(1512), CHILD(1512), CHILD(1512),
8459 CHILD(1512), CHILD(1515), CHILD(1515), CHILD(1515), CHILD(1515),
8460 CHILD(1518), CHILD(1518), CHILD(1518), CHILD(1518), CHILD(1521),
8461 CHILD(1521), CHILD(1521), CHILD(1521), CHILD(1524), CHILD(1524),
8462 CHILD(1524), CHILD(1524), CHILD(1527), CHILD(1527), CHILD(1527),
8463 CHILD(1527), CHILD(1530), CHILD(1530), CHILD(1530), CHILD(1530),
8464 CHILD(1191), CHILD(1533), CHILD(1557), CHILD(1569), TILEPRO_OPC_NONE,
8465 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8466 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8467 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8468 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8469 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8470 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8471 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8472 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8473 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8474 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8475 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8476 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8477 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8478 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8479 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8480 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8481 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8482 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8483 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8484 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8485 BITFIELD(53, 1) /* index 1503 */,
8486 TILEPRO_OPC_RLI_SN, TILEPRO_OPC_NONE,
8487 BITFIELD(53, 1) /* index 1506 */,
8488 TILEPRO_OPC_SHLIB_SN, TILEPRO_OPC_NONE,
8489 BITFIELD(53, 1) /* index 1509 */,
8490 TILEPRO_OPC_SHLIH_SN, TILEPRO_OPC_NONE,
8491 BITFIELD(53, 1) /* index 1512 */,
8492 TILEPRO_OPC_SHLI_SN, TILEPRO_OPC_NONE,
8493 BITFIELD(53, 1) /* index 1515 */,
8494 TILEPRO_OPC_SHRIB_SN, TILEPRO_OPC_NONE,
8495 BITFIELD(53, 1) /* index 1518 */,
8496 TILEPRO_OPC_SHRIH_SN, TILEPRO_OPC_NONE,
8497 BITFIELD(53, 1) /* index 1521 */,
8498 TILEPRO_OPC_SHRI_SN, TILEPRO_OPC_NONE,
8499 BITFIELD(53, 1) /* index 1524 */,
8500 TILEPRO_OPC_SRAIB_SN, TILEPRO_OPC_NONE,
8501 BITFIELD(53, 1) /* index 1527 */,
8502 TILEPRO_OPC_SRAIH_SN, TILEPRO_OPC_NONE,
8503 BITFIELD(53, 1) /* index 1530 */,
8504 TILEPRO_OPC_SRAI_SN, TILEPRO_OPC_NONE,
8505 BITFIELD(43, 3) /* index 1533 */,
8506 CHILD(1291), CHILD(1294), CHILD(1542), CHILD(1545), CHILD(1548),
8507 CHILD(1551), CHILD(1554), CHILD(1327),
8508 BITFIELD(53, 1) /* index 1542 */,
8509 TILEPRO_OPC_LB_SN, TILEPRO_OPC_NONE,
8510 BITFIELD(53, 1) /* index 1545 */,
8511 TILEPRO_OPC_LB_U_SN, TILEPRO_OPC_NONE,
8512 BITFIELD(53, 1) /* index 1548 */,
8513 TILEPRO_OPC_LH_SN, TILEPRO_OPC_NONE,
8514 BITFIELD(53, 1) /* index 1551 */,
8515 TILEPRO_OPC_LH_U_SN, TILEPRO_OPC_NONE,
8516 BITFIELD(53, 1) /* index 1554 */,
8517 TILEPRO_OPC_LW_SN, TILEPRO_OPC_NONE,
8518 BITFIELD(43, 3) /* index 1557 */,
8519 CHILD(1339), CHILD(1342), CHILD(1345), CHILD(1348), CHILD(1351),
8520 CHILD(1354), CHILD(1566), CHILD(1360),
8521 BITFIELD(53, 1) /* index 1566 */,
8522 TILEPRO_OPC_TNS_SN, TILEPRO_OPC_NONE,
8523 BITFIELD(43, 2) /* index 1569 */,
8524 CHILD(1574), TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8525 BITFIELD(45, 1) /* index 1574 */,
8526 CHILD(1577), TILEPRO_OPC_NONE,
8527 BITFIELD(53, 1) /* index 1577 */,
8528 TILEPRO_OPC_LW_NA_SN, TILEPRO_OPC_NONE,
8529 };
8530
8531 static const unsigned short decode_Y0_fsm[168] =
8532 {
8533 BITFIELD(27, 4) /* index 0 */,
8534 TILEPRO_OPC_NONE, CHILD(17), CHILD(22), CHILD(27), CHILD(47), CHILD(52),
8535 CHILD(57), CHILD(62), CHILD(67), TILEPRO_OPC_ADDI, CHILD(72), CHILD(102),
8536 TILEPRO_OPC_SEQI, CHILD(117), TILEPRO_OPC_SLTI, TILEPRO_OPC_SLTI_U,
8537 BITFIELD(18, 2) /* index 17 */,
8538 TILEPRO_OPC_ADD, TILEPRO_OPC_S1A, TILEPRO_OPC_S2A, TILEPRO_OPC_SUB,
8539 BITFIELD(18, 2) /* index 22 */,
8540 TILEPRO_OPC_MNZ, TILEPRO_OPC_MVNZ, TILEPRO_OPC_MVZ, TILEPRO_OPC_MZ,
8541 BITFIELD(18, 2) /* index 27 */,
8542 TILEPRO_OPC_AND, TILEPRO_OPC_NOR, CHILD(32), TILEPRO_OPC_XOR,
8543 BITFIELD(12, 2) /* index 32 */,
8544 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, CHILD(37),
8545 BITFIELD(14, 2) /* index 37 */,
8546 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, CHILD(42),
8547 BITFIELD(16, 2) /* index 42 */,
8548 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_MOVE,
8549 BITFIELD(18, 2) /* index 47 */,
8550 TILEPRO_OPC_RL, TILEPRO_OPC_SHL, TILEPRO_OPC_SHR, TILEPRO_OPC_SRA,
8551 BITFIELD(18, 2) /* index 52 */,
8552 TILEPRO_OPC_SLTE, TILEPRO_OPC_SLTE_U, TILEPRO_OPC_SLT, TILEPRO_OPC_SLT_U,
8553 BITFIELD(18, 2) /* index 57 */,
8554 TILEPRO_OPC_MULHLSA_UU, TILEPRO_OPC_S3A, TILEPRO_OPC_SEQ, TILEPRO_OPC_SNE,
8555 BITFIELD(18, 2) /* index 62 */,
8556 TILEPRO_OPC_MULHH_SS, TILEPRO_OPC_MULHH_UU, TILEPRO_OPC_MULLL_SS,
8557 TILEPRO_OPC_MULLL_UU,
8558 BITFIELD(18, 2) /* index 67 */,
8559 TILEPRO_OPC_MULHHA_SS, TILEPRO_OPC_MULHHA_UU, TILEPRO_OPC_MULLLA_SS,
8560 TILEPRO_OPC_MULLLA_UU,
8561 BITFIELD(0, 2) /* index 72 */,
8562 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(77),
8563 BITFIELD(2, 2) /* index 77 */,
8564 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(82),
8565 BITFIELD(4, 2) /* index 82 */,
8566 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(87),
8567 BITFIELD(6, 2) /* index 87 */,
8568 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(92),
8569 BITFIELD(8, 2) /* index 92 */,
8570 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(97),
8571 BITFIELD(10, 2) /* index 97 */,
8572 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_INFO,
8573 BITFIELD(6, 2) /* index 102 */,
8574 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, CHILD(107),
8575 BITFIELD(8, 2) /* index 107 */,
8576 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, CHILD(112),
8577 BITFIELD(10, 2) /* index 112 */,
8578 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_MOVEI,
8579 BITFIELD(15, 5) /* index 117 */,
8580 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8581 TILEPRO_OPC_RLI, TILEPRO_OPC_RLI, TILEPRO_OPC_RLI, TILEPRO_OPC_RLI,
8582 TILEPRO_OPC_SHLI, TILEPRO_OPC_SHLI, TILEPRO_OPC_SHLI, TILEPRO_OPC_SHLI,
8583 TILEPRO_OPC_SHRI, TILEPRO_OPC_SHRI, TILEPRO_OPC_SHRI, TILEPRO_OPC_SHRI,
8584 TILEPRO_OPC_SRAI, TILEPRO_OPC_SRAI, TILEPRO_OPC_SRAI, TILEPRO_OPC_SRAI,
8585 CHILD(150), CHILD(159), TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8586 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8587 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8588 BITFIELD(12, 3) /* index 150 */,
8589 TILEPRO_OPC_NONE, TILEPRO_OPC_BITX, TILEPRO_OPC_BYTEX, TILEPRO_OPC_CLZ,
8590 TILEPRO_OPC_CTZ, TILEPRO_OPC_FNOP, TILEPRO_OPC_NOP, TILEPRO_OPC_PCNT,
8591 BITFIELD(12, 3) /* index 159 */,
8592 TILEPRO_OPC_TBLIDXB0, TILEPRO_OPC_TBLIDXB1, TILEPRO_OPC_TBLIDXB2,
8593 TILEPRO_OPC_TBLIDXB3, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8594 TILEPRO_OPC_NONE,
8595 };
8596
8597 static const unsigned short decode_Y1_fsm[140] =
8598 {
8599 BITFIELD(59, 4) /* index 0 */,
8600 TILEPRO_OPC_NONE, CHILD(17), CHILD(22), CHILD(27), CHILD(47), CHILD(52),
8601 CHILD(57), TILEPRO_OPC_ADDI, CHILD(62), CHILD(92), TILEPRO_OPC_SEQI,
8602 CHILD(107), TILEPRO_OPC_SLTI, TILEPRO_OPC_SLTI_U, TILEPRO_OPC_NONE,
8603 TILEPRO_OPC_NONE,
8604 BITFIELD(49, 2) /* index 17 */,
8605 TILEPRO_OPC_ADD, TILEPRO_OPC_S1A, TILEPRO_OPC_S2A, TILEPRO_OPC_SUB,
8606 BITFIELD(49, 2) /* index 22 */,
8607 TILEPRO_OPC_NONE, TILEPRO_OPC_MNZ, TILEPRO_OPC_MZ, TILEPRO_OPC_NONE,
8608 BITFIELD(49, 2) /* index 27 */,
8609 TILEPRO_OPC_AND, TILEPRO_OPC_NOR, CHILD(32), TILEPRO_OPC_XOR,
8610 BITFIELD(43, 2) /* index 32 */,
8611 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, CHILD(37),
8612 BITFIELD(45, 2) /* index 37 */,
8613 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, CHILD(42),
8614 BITFIELD(47, 2) /* index 42 */,
8615 TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_OR, TILEPRO_OPC_MOVE,
8616 BITFIELD(49, 2) /* index 47 */,
8617 TILEPRO_OPC_RL, TILEPRO_OPC_SHL, TILEPRO_OPC_SHR, TILEPRO_OPC_SRA,
8618 BITFIELD(49, 2) /* index 52 */,
8619 TILEPRO_OPC_SLTE, TILEPRO_OPC_SLTE_U, TILEPRO_OPC_SLT, TILEPRO_OPC_SLT_U,
8620 BITFIELD(49, 2) /* index 57 */,
8621 TILEPRO_OPC_NONE, TILEPRO_OPC_S3A, TILEPRO_OPC_SEQ, TILEPRO_OPC_SNE,
8622 BITFIELD(31, 2) /* index 62 */,
8623 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(67),
8624 BITFIELD(33, 2) /* index 67 */,
8625 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(72),
8626 BITFIELD(35, 2) /* index 72 */,
8627 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(77),
8628 BITFIELD(37, 2) /* index 77 */,
8629 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(82),
8630 BITFIELD(39, 2) /* index 82 */,
8631 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, CHILD(87),
8632 BITFIELD(41, 2) /* index 87 */,
8633 TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_ANDI, TILEPRO_OPC_INFO,
8634 BITFIELD(37, 2) /* index 92 */,
8635 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, CHILD(97),
8636 BITFIELD(39, 2) /* index 97 */,
8637 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, CHILD(102),
8638 BITFIELD(41, 2) /* index 102 */,
8639 TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_ORI, TILEPRO_OPC_MOVEI,
8640 BITFIELD(48, 3) /* index 107 */,
8641 TILEPRO_OPC_NONE, TILEPRO_OPC_RLI, TILEPRO_OPC_SHLI, TILEPRO_OPC_SHRI,
8642 TILEPRO_OPC_SRAI, CHILD(116), TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8643 BITFIELD(43, 3) /* index 116 */,
8644 TILEPRO_OPC_NONE, CHILD(125), CHILD(130), CHILD(135), TILEPRO_OPC_NONE,
8645 TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8646 BITFIELD(46, 2) /* index 125 */,
8647 TILEPRO_OPC_FNOP, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8648 BITFIELD(46, 2) /* index 130 */,
8649 TILEPRO_OPC_ILL, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8650 BITFIELD(46, 2) /* index 135 */,
8651 TILEPRO_OPC_NOP, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE, TILEPRO_OPC_NONE,
8652 };
8653
8654 static const unsigned short decode_Y2_fsm[24] =
8655 {
8656 BITFIELD(56, 3) /* index 0 */,
8657 CHILD(9), TILEPRO_OPC_LB_U, TILEPRO_OPC_LH, TILEPRO_OPC_LH_U,
8658 TILEPRO_OPC_LW, TILEPRO_OPC_SB, TILEPRO_OPC_SH, TILEPRO_OPC_SW,
8659 BITFIELD(20, 2) /* index 9 */,
8660 TILEPRO_OPC_LB, TILEPRO_OPC_LB, TILEPRO_OPC_LB, CHILD(14),
8661 BITFIELD(22, 2) /* index 14 */,
8662 TILEPRO_OPC_LB, TILEPRO_OPC_LB, TILEPRO_OPC_LB, CHILD(19),
8663 BITFIELD(24, 2) /* index 19 */,
8664 TILEPRO_OPC_LB, TILEPRO_OPC_LB, TILEPRO_OPC_LB, TILEPRO_OPC_PREFETCH,
8665 };
8666
8667 #undef BITFIELD
8668 #undef CHILD
8669
8670 const unsigned short * const
8671 tilepro_bundle_decoder_fsms[TILEPRO_NUM_PIPELINE_ENCODINGS] =
8672 {
8673 decode_X0_fsm,
8674 decode_X1_fsm,
8675 decode_Y0_fsm,
8676 decode_Y1_fsm,
8677 decode_Y2_fsm
8678 };
8679
8680 #ifndef DISASM_ONLY
8681 const struct tilepro_sn_opcode tilepro_sn_opcodes[23] =
8682 {
8683 { "bz", TILEPRO_SN_OPC_BZ,
8684 1 /* num_operands */,
8685 /* operands */
8686 { 38 },
8687 /* fixed_bit_mask */
8688 0xfc00,
8689 /* fixed_bit_value */
8690 0xe000
8691 },
8692 { "bnz", TILEPRO_SN_OPC_BNZ,
8693 1 /* num_operands */,
8694 /* operands */
8695 { 38 },
8696 /* fixed_bit_mask */
8697 0xfc00,
8698 /* fixed_bit_value */
8699 0xe400
8700 },
8701 { "jrr", TILEPRO_SN_OPC_JRR,
8702 1 /* num_operands */,
8703 /* operands */
8704 { 39 },
8705 /* fixed_bit_mask */
8706 0xff00,
8707 /* fixed_bit_value */
8708 0x0600
8709 },
8710 { "fnop", TILEPRO_SN_OPC_FNOP,
8711 0 /* num_operands */,
8712 /* operands */
8713 { 0, },
8714 /* fixed_bit_mask */
8715 0xffff,
8716 /* fixed_bit_value */
8717 0x0003
8718 },
8719 { "blz", TILEPRO_SN_OPC_BLZ,
8720 1 /* num_operands */,
8721 /* operands */
8722 { 38 },
8723 /* fixed_bit_mask */
8724 0xfc00,
8725 /* fixed_bit_value */
8726 0xf000
8727 },
8728 { "nop", TILEPRO_SN_OPC_NOP,
8729 0 /* num_operands */,
8730 /* operands */
8731 { 0, },
8732 /* fixed_bit_mask */
8733 0xffff,
8734 /* fixed_bit_value */
8735 0x0002
8736 },
8737 { "movei", TILEPRO_SN_OPC_MOVEI,
8738 1 /* num_operands */,
8739 /* operands */
8740 { 40 },
8741 /* fixed_bit_mask */
8742 0xff00,
8743 /* fixed_bit_value */
8744 0x0400
8745 },
8746 { "move", TILEPRO_SN_OPC_MOVE,
8747 2 /* num_operands */,
8748 /* operands */
8749 { 41, 42 },
8750 /* fixed_bit_mask */
8751 0xfff0,
8752 /* fixed_bit_value */
8753 0x0080
8754 },
8755 { "bgez", TILEPRO_SN_OPC_BGEZ,
8756 1 /* num_operands */,
8757 /* operands */
8758 { 38 },
8759 /* fixed_bit_mask */
8760 0xfc00,
8761 /* fixed_bit_value */
8762 0xf400
8763 },
8764 { "jr", TILEPRO_SN_OPC_JR,
8765 1 /* num_operands */,
8766 /* operands */
8767 { 42 },
8768 /* fixed_bit_mask */
8769 0xfff0,
8770 /* fixed_bit_value */
8771 0x0040
8772 },
8773 { "blez", TILEPRO_SN_OPC_BLEZ,
8774 1 /* num_operands */,
8775 /* operands */
8776 { 38 },
8777 /* fixed_bit_mask */
8778 0xfc00,
8779 /* fixed_bit_value */
8780 0xec00
8781 },
8782 { "bbns", TILEPRO_SN_OPC_BBNS,
8783 1 /* num_operands */,
8784 /* operands */
8785 { 38 },
8786 /* fixed_bit_mask */
8787 0xfc00,
8788 /* fixed_bit_value */
8789 0xfc00
8790 },
8791 { "jalrr", TILEPRO_SN_OPC_JALRR,
8792 1 /* num_operands */,
8793 /* operands */
8794 { 39 },
8795 /* fixed_bit_mask */
8796 0xff00,
8797 /* fixed_bit_value */
8798 0x0700
8799 },
8800 { "bpt", TILEPRO_SN_OPC_BPT,
8801 0 /* num_operands */,
8802 /* operands */
8803 { 0, },
8804 /* fixed_bit_mask */
8805 0xffff,
8806 /* fixed_bit_value */
8807 0x0001
8808 },
8809 { "jalr", TILEPRO_SN_OPC_JALR,
8810 1 /* num_operands */,
8811 /* operands */
8812 { 42 },
8813 /* fixed_bit_mask */
8814 0xfff0,
8815 /* fixed_bit_value */
8816 0x0050
8817 },
8818 { "shr1", TILEPRO_SN_OPC_SHR1,
8819 2 /* num_operands */,
8820 /* operands */
8821 { 41, 42 },
8822 /* fixed_bit_mask */
8823 0xfff0,
8824 /* fixed_bit_value */
8825 0x0090
8826 },
8827 { "bgz", TILEPRO_SN_OPC_BGZ,
8828 1 /* num_operands */,
8829 /* operands */
8830 { 38 },
8831 /* fixed_bit_mask */
8832 0xfc00,
8833 /* fixed_bit_value */
8834 0xe800
8835 },
8836 { "bbs", TILEPRO_SN_OPC_BBS,
8837 1 /* num_operands */,
8838 /* operands */
8839 { 38 },
8840 /* fixed_bit_mask */
8841 0xfc00,
8842 /* fixed_bit_value */
8843 0xf800
8844 },
8845 { "shl8ii", TILEPRO_SN_OPC_SHL8II,
8846 1 /* num_operands */,
8847 /* operands */
8848 { 39 },
8849 /* fixed_bit_mask */
8850 0xff00,
8851 /* fixed_bit_value */
8852 0x0300
8853 },
8854 { "addi", TILEPRO_SN_OPC_ADDI,
8855 1 /* num_operands */,
8856 /* operands */
8857 { 40 },
8858 /* fixed_bit_mask */
8859 0xff00,
8860 /* fixed_bit_value */
8861 0x0500
8862 },
8863 { "halt", TILEPRO_SN_OPC_HALT,
8864 0 /* num_operands */,
8865 /* operands */
8866 { 0, },
8867 /* fixed_bit_mask */
8868 0xffff,
8869 /* fixed_bit_value */
8870 0x0000
8871 },
8872 { "route", TILEPRO_SN_OPC_ROUTE, 0, { 0, }, 0, 0,
8873 },
8874 { 0, TILEPRO_SN_OPC_NONE, 0, { 0, }, 0, 0,
8875 }
8876 };
8877
8878 const unsigned char tilepro_sn_route_encode[6 * 6 * 6] =
8879 {
8880 0xdf,
8881 0xde,
8882 0xdd,
8883 0xdc,
8884 0xdb,
8885 0xda,
8886 0xb9,
8887 0xb8,
8888 0xa1,
8889 0xa0,
8890 0x11,
8891 0x10,
8892 0x9f,
8893 0x9e,
8894 0x9d,
8895 0x9c,
8896 0x9b,
8897 0x9a,
8898 0x79,
8899 0x78,
8900 0x61,
8901 0x60,
8902 0xb,
8903 0xa,
8904 0x5f,
8905 0x5e,
8906 0x5d,
8907 0x5c,
8908 0x5b,
8909 0x5a,
8910 0x1f,
8911 0x1e,
8912 0x1d,
8913 0x1c,
8914 0x1b,
8915 0x1a,
8916 0xd7,
8917 0xd6,
8918 0xd5,
8919 0xd4,
8920 0xd3,
8921 0xd2,
8922 0xa7,
8923 0xa6,
8924 0xb1,
8925 0xb0,
8926 0x13,
8927 0x12,
8928 0x97,
8929 0x96,
8930 0x95,
8931 0x94,
8932 0x93,
8933 0x92,
8934 0x67,
8935 0x66,
8936 0x71,
8937 0x70,
8938 0x9,
8939 0x8,
8940 0x57,
8941 0x56,
8942 0x55,
8943 0x54,
8944 0x53,
8945 0x52,
8946 0x17,
8947 0x16,
8948 0x15,
8949 0x14,
8950 0x19,
8951 0x18,
8952 0xcf,
8953 0xce,
8954 0xcd,
8955 0xcc,
8956 0xcb,
8957 0xca,
8958 0xaf,
8959 0xae,
8960 0xad,
8961 0xac,
8962 0xab,
8963 0xaa,
8964 0x8f,
8965 0x8e,
8966 0x8d,
8967 0x8c,
8968 0x8b,
8969 0x8a,
8970 0x6f,
8971 0x6e,
8972 0x6d,
8973 0x6c,
8974 0x6b,
8975 0x6a,
8976 0x4f,
8977 0x4e,
8978 0x4d,
8979 0x4c,
8980 0x4b,
8981 0x4a,
8982 0x2f,
8983 0x2e,
8984 0x2d,
8985 0x2c,
8986 0x2b,
8987 0x2a,
8988 0xc9,
8989 0xc8,
8990 0xc5,
8991 0xc4,
8992 0xc3,
8993 0xc2,
8994 0xa9,
8995 0xa8,
8996 0xa5,
8997 0xa4,
8998 0xa3,
8999 0xa2,
9000 0x89,
9001 0x88,
9002 0x85,
9003 0x84,
9004 0x83,
9005 0x82,
9006 0x69,
9007 0x68,
9008 0x65,
9009 0x64,
9010 0x63,
9011 0x62,
9012 0x47,
9013 0x46,
9014 0x45,
9015 0x44,
9016 0x43,
9017 0x42,
9018 0x27,
9019 0x26,
9020 0x25,
9021 0x24,
9022 0x23,
9023 0x22,
9024 0xd9,
9025 0xd8,
9026 0xc1,
9027 0xc0,
9028 0x3b,
9029 0x3a,
9030 0xbf,
9031 0xbe,
9032 0xbd,
9033 0xbc,
9034 0xbb,
9035 0xba,
9036 0x99,
9037 0x98,
9038 0x81,
9039 0x80,
9040 0x31,
9041 0x30,
9042 0x7f,
9043 0x7e,
9044 0x7d,
9045 0x7c,
9046 0x7b,
9047 0x7a,
9048 0x59,
9049 0x58,
9050 0x3d,
9051 0x3c,
9052 0x49,
9053 0x48,
9054 0xf,
9055 0xe,
9056 0xd,
9057 0xc,
9058 0x29,
9059 0x28,
9060 0xc7,
9061 0xc6,
9062 0xd1,
9063 0xd0,
9064 0x39,
9065 0x38,
9066 0xb7,
9067 0xb6,
9068 0xb5,
9069 0xb4,
9070 0xb3,
9071 0xb2,
9072 0x87,
9073 0x86,
9074 0x91,
9075 0x90,
9076 0x33,
9077 0x32,
9078 0x77,
9079 0x76,
9080 0x75,
9081 0x74,
9082 0x73,
9083 0x72,
9084 0x3f,
9085 0x3e,
9086 0x51,
9087 0x50,
9088 0x41,
9089 0x40,
9090 0x37,
9091 0x36,
9092 0x35,
9093 0x34,
9094 0x21,
9095 0x20
9096 };
9097
9098 const signed char tilepro_sn_route_decode[256][3] =
9099 {
9100 { -1, -1, -1 },
9101 { -1, -1, -1 },
9102 { -1, -1, -1 },
9103 { -1, -1, -1 },
9104 { -1, -1, -1 },
9105 { -1, -1, -1 },
9106 { -1, -1, -1 },
9107 { -1, -1, -1 },
9108 { 5, 3, 1 },
9109 { 4, 3, 1 },
9110 { 5, 3, 0 },
9111 { 4, 3, 0 },
9112 { 3, 5, 4 },
9113 { 2, 5, 4 },
9114 { 1, 5, 4 },
9115 { 0, 5, 4 },
9116 { 5, 1, 0 },
9117 { 4, 1, 0 },
9118 { 5, 1, 1 },
9119 { 4, 1, 1 },
9120 { 3, 5, 1 },
9121 { 2, 5, 1 },
9122 { 1, 5, 1 },
9123 { 0, 5, 1 },
9124 { 5, 5, 1 },
9125 { 4, 5, 1 },
9126 { 5, 5, 0 },
9127 { 4, 5, 0 },
9128 { 3, 5, 0 },
9129 { 2, 5, 0 },
9130 { 1, 5, 0 },
9131 { 0, 5, 0 },
9132 { 5, 5, 5 },
9133 { 4, 5, 5 },
9134 { 5, 5, 3 },
9135 { 4, 5, 3 },
9136 { 3, 5, 3 },
9137 { 2, 5, 3 },
9138 { 1, 5, 3 },
9139 { 0, 5, 3 },
9140 { 5, 5, 4 },
9141 { 4, 5, 4 },
9142 { 5, 5, 2 },
9143 { 4, 5, 2 },
9144 { 3, 5, 2 },
9145 { 2, 5, 2 },
9146 { 1, 5, 2 },
9147 { 0, 5, 2 },
9148 { 5, 2, 4 },
9149 { 4, 2, 4 },
9150 { 5, 2, 5 },
9151 { 4, 2, 5 },
9152 { 3, 5, 5 },
9153 { 2, 5, 5 },
9154 { 1, 5, 5 },
9155 { 0, 5, 5 },
9156 { 5, 0, 5 },
9157 { 4, 0, 5 },
9158 { 5, 0, 4 },
9159 { 4, 0, 4 },
9160 { 3, 4, 4 },
9161 { 2, 4, 4 },
9162 { 1, 4, 5 },
9163 { 0, 4, 5 },
9164 { 5, 4, 5 },
9165 { 4, 4, 5 },
9166 { 5, 4, 3 },
9167 { 4, 4, 3 },
9168 { 3, 4, 3 },
9169 { 2, 4, 3 },
9170 { 1, 4, 3 },
9171 { 0, 4, 3 },
9172 { 5, 4, 4 },
9173 { 4, 4, 4 },
9174 { 5, 4, 2 },
9175 { 4, 4, 2 },
9176 { 3, 4, 2 },
9177 { 2, 4, 2 },
9178 { 1, 4, 2 },
9179 { 0, 4, 2 },
9180 { 3, 4, 5 },
9181 { 2, 4, 5 },
9182 { 5, 4, 1 },
9183 { 4, 4, 1 },
9184 { 3, 4, 1 },
9185 { 2, 4, 1 },
9186 { 1, 4, 1 },
9187 { 0, 4, 1 },
9188 { 1, 4, 4 },
9189 { 0, 4, 4 },
9190 { 5, 4, 0 },
9191 { 4, 4, 0 },
9192 { 3, 4, 0 },
9193 { 2, 4, 0 },
9194 { 1, 4, 0 },
9195 { 0, 4, 0 },
9196 { 3, 3, 0 },
9197 { 2, 3, 0 },
9198 { 5, 3, 3 },
9199 { 4, 3, 3 },
9200 { 3, 3, 3 },
9201 { 2, 3, 3 },
9202 { 1, 3, 1 },
9203 { 0, 3, 1 },
9204 { 1, 3, 3 },
9205 { 0, 3, 3 },
9206 { 5, 3, 2 },
9207 { 4, 3, 2 },
9208 { 3, 3, 2 },
9209 { 2, 3, 2 },
9210 { 1, 3, 2 },
9211 { 0, 3, 2 },
9212 { 3, 3, 1 },
9213 { 2, 3, 1 },
9214 { 5, 3, 5 },
9215 { 4, 3, 5 },
9216 { 3, 3, 5 },
9217 { 2, 3, 5 },
9218 { 1, 3, 5 },
9219 { 0, 3, 5 },
9220 { 1, 3, 0 },
9221 { 0, 3, 0 },
9222 { 5, 3, 4 },
9223 { 4, 3, 4 },
9224 { 3, 3, 4 },
9225 { 2, 3, 4 },
9226 { 1, 3, 4 },
9227 { 0, 3, 4 },
9228 { 3, 2, 4 },
9229 { 2, 2, 4 },
9230 { 5, 2, 3 },
9231 { 4, 2, 3 },
9232 { 3, 2, 3 },
9233 { 2, 2, 3 },
9234 { 1, 2, 5 },
9235 { 0, 2, 5 },
9236 { 1, 2, 3 },
9237 { 0, 2, 3 },
9238 { 5, 2, 2 },
9239 { 4, 2, 2 },
9240 { 3, 2, 2 },
9241 { 2, 2, 2 },
9242 { 1, 2, 2 },
9243 { 0, 2, 2 },
9244 { 3, 2, 5 },
9245 { 2, 2, 5 },
9246 { 5, 2, 1 },
9247 { 4, 2, 1 },
9248 { 3, 2, 1 },
9249 { 2, 2, 1 },
9250 { 1, 2, 1 },
9251 { 0, 2, 1 },
9252 { 1, 2, 4 },
9253 { 0, 2, 4 },
9254 { 5, 2, 0 },
9255 { 4, 2, 0 },
9256 { 3, 2, 0 },
9257 { 2, 2, 0 },
9258 { 1, 2, 0 },
9259 { 0, 2, 0 },
9260 { 3, 1, 0 },
9261 { 2, 1, 0 },
9262 { 5, 1, 3 },
9263 { 4, 1, 3 },
9264 { 3, 1, 3 },
9265 { 2, 1, 3 },
9266 { 1, 1, 1 },
9267 { 0, 1, 1 },
9268 { 1, 1, 3 },
9269 { 0, 1, 3 },
9270 { 5, 1, 2 },
9271 { 4, 1, 2 },
9272 { 3, 1, 2 },
9273 { 2, 1, 2 },
9274 { 1, 1, 2 },
9275 { 0, 1, 2 },
9276 { 3, 1, 1 },
9277 { 2, 1, 1 },
9278 { 5, 1, 5 },
9279 { 4, 1, 5 },
9280 { 3, 1, 5 },
9281 { 2, 1, 5 },
9282 { 1, 1, 5 },
9283 { 0, 1, 5 },
9284 { 1, 1, 0 },
9285 { 0, 1, 0 },
9286 { 5, 1, 4 },
9287 { 4, 1, 4 },
9288 { 3, 1, 4 },
9289 { 2, 1, 4 },
9290 { 1, 1, 4 },
9291 { 0, 1, 4 },
9292 { 3, 0, 4 },
9293 { 2, 0, 4 },
9294 { 5, 0, 3 },
9295 { 4, 0, 3 },
9296 { 3, 0, 3 },
9297 { 2, 0, 3 },
9298 { 1, 0, 5 },
9299 { 0, 0, 5 },
9300 { 1, 0, 3 },
9301 { 0, 0, 3 },
9302 { 5, 0, 2 },
9303 { 4, 0, 2 },
9304 { 3, 0, 2 },
9305 { 2, 0, 2 },
9306 { 1, 0, 2 },
9307 { 0, 0, 2 },
9308 { 3, 0, 5 },
9309 { 2, 0, 5 },
9310 { 5, 0, 1 },
9311 { 4, 0, 1 },
9312 { 3, 0, 1 },
9313 { 2, 0, 1 },
9314 { 1, 0, 1 },
9315 { 0, 0, 1 },
9316 { 1, 0, 4 },
9317 { 0, 0, 4 },
9318 { 5, 0, 0 },
9319 { 4, 0, 0 },
9320 { 3, 0, 0 },
9321 { 2, 0, 0 },
9322 { 1, 0, 0 },
9323 { 0, 0, 0 },
9324 { -1, -1, -1 },
9325 { -1, -1, -1 },
9326 { -1, -1, -1 },
9327 { -1, -1, -1 },
9328 { -1, -1, -1 },
9329 { -1, -1, -1 },
9330 { -1, -1, -1 },
9331 { -1, -1, -1 },
9332 { -1, -1, -1 },
9333 { -1, -1, -1 },
9334 { -1, -1, -1 },
9335 { -1, -1, -1 },
9336 { -1, -1, -1 },
9337 { -1, -1, -1 },
9338 { -1, -1, -1 },
9339 { -1, -1, -1 },
9340 { -1, -1, -1 },
9341 { -1, -1, -1 },
9342 { -1, -1, -1 },
9343 { -1, -1, -1 },
9344 { -1, -1, -1 },
9345 { -1, -1, -1 },
9346 { -1, -1, -1 },
9347 { -1, -1, -1 },
9348 { -1, -1, -1 },
9349 { -1, -1, -1 },
9350 { -1, -1, -1 },
9351 { -1, -1, -1 },
9352 { -1, -1, -1 },
9353 { -1, -1, -1 },
9354 { -1, -1, -1 },
9355 { -1, -1, -1 }
9356 };
9357
9358 const char tilepro_sn_direction_names[6][5] =
9359 {
9360 "w",
9361 "c",
9362 "acc",
9363 "n",
9364 "e",
9365 "s"
9366 };
9367
9368 const signed char tilepro_sn_dest_map[6][6] =
9369 {
9370 { -1, 3, 4, 5, 1, 2 } /* val -> w */,
9371 { -1, 3, 4, 5, 0, 2 } /* val -> c */,
9372 { -1, 3, 4, 5, 0, 1 } /* val -> acc */,
9373 { -1, 4, 5, 0, 1, 2 } /* val -> n */,
9374 { -1, 3, 5, 0, 1, 2 } /* val -> e */,
9375 { -1, 3, 4, 0, 1, 2 } /* val -> s */
9376 };
9377 #endif /* DISASM_ONLY */
9378
9379 const struct tilepro_operand tilepro_operands[43] =
9380 {
9381 {
9382 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_IMM8_X0),
9383 8, 1, 0, 0, 0, 0,
9384 create_Imm8_X0, get_Imm8_X0
9385 },
9386 {
9387 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_IMM8_X1),
9388 8, 1, 0, 0, 0, 0,
9389 create_Imm8_X1, get_Imm8_X1
9390 },
9391 {
9392 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_IMM8_Y0),
9393 8, 1, 0, 0, 0, 0,
9394 create_Imm8_Y0, get_Imm8_Y0
9395 },
9396 {
9397 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_IMM8_Y1),
9398 8, 1, 0, 0, 0, 0,
9399 create_Imm8_Y1, get_Imm8_Y1
9400 },
9401 {
9402 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_IMM16_X0),
9403 16, 1, 0, 0, 0, 0,
9404 create_Imm16_X0, get_Imm16_X0
9405 },
9406 {
9407 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_IMM16_X1),
9408 16, 1, 0, 0, 0, 0,
9409 create_Imm16_X1, get_Imm16_X1
9410 },
9411 {
9412 TILEPRO_OP_TYPE_ADDRESS, BFD_RELOC(TILEPRO_JOFFLONG_X1),
9413 29, 1, 0, 0, 1, TILEPRO_LOG2_BUNDLE_ALIGNMENT_IN_BYTES,
9414 create_JOffLong_X1, get_JOffLong_X1
9415 },
9416 {
9417 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9418 6, 0, 0, 1, 0, 0,
9419 create_Dest_X1, get_Dest_X1
9420 },
9421 {
9422 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9423 6, 0, 1, 0, 0, 0,
9424 create_SrcA_X1, get_SrcA_X1
9425 },
9426 {
9427 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9428 6, 0, 0, 1, 0, 0,
9429 create_Dest_X0, get_Dest_X0
9430 },
9431 {
9432 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9433 6, 0, 1, 0, 0, 0,
9434 create_SrcA_X0, get_SrcA_X0
9435 },
9436 {
9437 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9438 6, 0, 0, 1, 0, 0,
9439 create_Dest_Y0, get_Dest_Y0
9440 },
9441 {
9442 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9443 6, 0, 1, 0, 0, 0,
9444 create_SrcA_Y0, get_SrcA_Y0
9445 },
9446 {
9447 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9448 6, 0, 0, 1, 0, 0,
9449 create_Dest_Y1, get_Dest_Y1
9450 },
9451 {
9452 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9453 6, 0, 1, 0, 0, 0,
9454 create_SrcA_Y1, get_SrcA_Y1
9455 },
9456 {
9457 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9458 6, 0, 1, 0, 0, 0,
9459 create_SrcA_Y2, get_SrcA_Y2
9460 },
9461 {
9462 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9463 6, 0, 1, 0, 0, 0,
9464 create_SrcB_X0, get_SrcB_X0
9465 },
9466 {
9467 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9468 6, 0, 1, 0, 0, 0,
9469 create_SrcB_X1, get_SrcB_X1
9470 },
9471 {
9472 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9473 6, 0, 1, 0, 0, 0,
9474 create_SrcB_Y0, get_SrcB_Y0
9475 },
9476 {
9477 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9478 6, 0, 1, 0, 0, 0,
9479 create_SrcB_Y1, get_SrcB_Y1
9480 },
9481 {
9482 TILEPRO_OP_TYPE_ADDRESS, BFD_RELOC(TILEPRO_BROFF_X1),
9483 17, 1, 0, 0, 1, TILEPRO_LOG2_BUNDLE_ALIGNMENT_IN_BYTES,
9484 create_BrOff_X1, get_BrOff_X1
9485 },
9486 {
9487 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9488 6, 0, 1, 1, 0, 0,
9489 create_Dest_X0, get_Dest_X0
9490 },
9491 {
9492 TILEPRO_OP_TYPE_ADDRESS, BFD_RELOC(NONE),
9493 28, 1, 0, 0, 1, TILEPRO_LOG2_BUNDLE_ALIGNMENT_IN_BYTES,
9494 create_JOff_X1, get_JOff_X1
9495 },
9496 {
9497 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9498 6, 0, 0, 1, 0, 0,
9499 create_SrcBDest_Y2, get_SrcBDest_Y2
9500 },
9501 {
9502 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9503 6, 0, 1, 1, 0, 0,
9504 create_SrcA_X1, get_SrcA_X1
9505 },
9506 {
9507 TILEPRO_OP_TYPE_SPR, BFD_RELOC(TILEPRO_MF_IMM15_X1),
9508 15, 0, 0, 0, 0, 0,
9509 create_MF_Imm15_X1, get_MF_Imm15_X1
9510 },
9511 {
9512 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_MMSTART_X0),
9513 5, 0, 0, 0, 0, 0,
9514 create_MMStart_X0, get_MMStart_X0
9515 },
9516 {
9517 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_MMEND_X0),
9518 5, 0, 0, 0, 0, 0,
9519 create_MMEnd_X0, get_MMEnd_X0
9520 },
9521 {
9522 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_MMSTART_X1),
9523 5, 0, 0, 0, 0, 0,
9524 create_MMStart_X1, get_MMStart_X1
9525 },
9526 {
9527 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_MMEND_X1),
9528 5, 0, 0, 0, 0, 0,
9529 create_MMEnd_X1, get_MMEnd_X1
9530 },
9531 {
9532 TILEPRO_OP_TYPE_SPR, BFD_RELOC(TILEPRO_MT_IMM15_X1),
9533 15, 0, 0, 0, 0, 0,
9534 create_MT_Imm15_X1, get_MT_Imm15_X1
9535 },
9536 {
9537 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9538 6, 0, 1, 1, 0, 0,
9539 create_Dest_Y0, get_Dest_Y0
9540 },
9541 {
9542 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_SHAMT_X0),
9543 5, 0, 0, 0, 0, 0,
9544 create_ShAmt_X0, get_ShAmt_X0
9545 },
9546 {
9547 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_SHAMT_X1),
9548 5, 0, 0, 0, 0, 0,
9549 create_ShAmt_X1, get_ShAmt_X1
9550 },
9551 {
9552 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_SHAMT_Y0),
9553 5, 0, 0, 0, 0, 0,
9554 create_ShAmt_Y0, get_ShAmt_Y0
9555 },
9556 {
9557 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_SHAMT_Y1),
9558 5, 0, 0, 0, 0, 0,
9559 create_ShAmt_Y1, get_ShAmt_Y1
9560 },
9561 {
9562 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9563 6, 0, 1, 0, 0, 0,
9564 create_SrcBDest_Y2, get_SrcBDest_Y2
9565 },
9566 {
9567 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(TILEPRO_DEST_IMM8_X1),
9568 8, 1, 0, 0, 0, 0,
9569 create_Dest_Imm8_X1, get_Dest_Imm8_X1
9570 },
9571 {
9572 TILEPRO_OP_TYPE_ADDRESS, BFD_RELOC(NONE),
9573 10, 1, 0, 0, 1, TILEPRO_LOG2_SN_INSTRUCTION_SIZE_IN_BYTES,
9574 create_BrOff_SN, get_BrOff_SN
9575 },
9576 {
9577 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(NONE),
9578 8, 0, 0, 0, 0, 0,
9579 create_Imm8_SN, get_Imm8_SN
9580 },
9581 {
9582 TILEPRO_OP_TYPE_IMMEDIATE, BFD_RELOC(NONE),
9583 8, 1, 0, 0, 0, 0,
9584 create_Imm8_SN, get_Imm8_SN
9585 },
9586 {
9587 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9588 2, 0, 0, 1, 0, 0,
9589 create_Dest_SN, get_Dest_SN
9590 },
9591 {
9592 TILEPRO_OP_TYPE_REGISTER, BFD_RELOC(NONE),
9593 2, 0, 1, 0, 0, 0,
9594 create_Src_SN, get_Src_SN
9595 }
9596 };
9597
9598 #ifndef DISASM_ONLY
9599 const struct tilepro_spr tilepro_sprs[] =
9600 {
9601 { 0, "MPL_ITLB_MISS_SET_0" },
9602 { 1, "MPL_ITLB_MISS_SET_1" },
9603 { 2, "MPL_ITLB_MISS_SET_2" },
9604 { 3, "MPL_ITLB_MISS_SET_3" },
9605 { 4, "MPL_ITLB_MISS" },
9606 { 256, "ITLB_CURRENT_0" },
9607 { 257, "ITLB_CURRENT_1" },
9608 { 258, "ITLB_CURRENT_2" },
9609 { 259, "ITLB_CURRENT_3" },
9610 { 260, "ITLB_INDEX" },
9611 { 261, "ITLB_MATCH_0" },
9612 { 262, "ITLB_PR" },
9613 { 263, "NUMBER_ITLB" },
9614 { 264, "REPLACEMENT_ITLB" },
9615 { 265, "WIRED_ITLB" },
9616 { 266, "ITLB_PERF" },
9617 { 512, "MPL_MEM_ERROR_SET_0" },
9618 { 513, "MPL_MEM_ERROR_SET_1" },
9619 { 514, "MPL_MEM_ERROR_SET_2" },
9620 { 515, "MPL_MEM_ERROR_SET_3" },
9621 { 516, "MPL_MEM_ERROR" },
9622 { 517, "L1_I_ERROR" },
9623 { 518, "MEM_ERROR_CBOX_ADDR" },
9624 { 519, "MEM_ERROR_CBOX_STATUS" },
9625 { 520, "MEM_ERROR_ENABLE" },
9626 { 521, "MEM_ERROR_MBOX_ADDR" },
9627 { 522, "MEM_ERROR_MBOX_STATUS" },
9628 { 523, "SNIC_ERROR_LOG_STATUS" },
9629 { 524, "SNIC_ERROR_LOG_VA" },
9630 { 525, "XDN_DEMUX_ERROR" },
9631 { 1024, "MPL_ILL_SET_0" },
9632 { 1025, "MPL_ILL_SET_1" },
9633 { 1026, "MPL_ILL_SET_2" },
9634 { 1027, "MPL_ILL_SET_3" },
9635 { 1028, "MPL_ILL" },
9636 { 1536, "MPL_GPV_SET_0" },
9637 { 1537, "MPL_GPV_SET_1" },
9638 { 1538, "MPL_GPV_SET_2" },
9639 { 1539, "MPL_GPV_SET_3" },
9640 { 1540, "MPL_GPV" },
9641 { 1541, "GPV_REASON" },
9642 { 2048, "MPL_SN_ACCESS_SET_0" },
9643 { 2049, "MPL_SN_ACCESS_SET_1" },
9644 { 2050, "MPL_SN_ACCESS_SET_2" },
9645 { 2051, "MPL_SN_ACCESS_SET_3" },
9646 { 2052, "MPL_SN_ACCESS" },
9647 { 2053, "SNCTL" },
9648 { 2054, "SNFIFO_DATA" },
9649 { 2055, "SNFIFO_SEL" },
9650 { 2056, "SNIC_INVADDR" },
9651 { 2057, "SNISTATE" },
9652 { 2058, "SNOSTATE" },
9653 { 2059, "SNPC" },
9654 { 2060, "SNSTATIC" },
9655 { 2304, "SN_DATA_AVAIL" },
9656 { 2560, "MPL_IDN_ACCESS_SET_0" },
9657 { 2561, "MPL_IDN_ACCESS_SET_1" },
9658 { 2562, "MPL_IDN_ACCESS_SET_2" },
9659 { 2563, "MPL_IDN_ACCESS_SET_3" },
9660 { 2564, "MPL_IDN_ACCESS" },
9661 { 2565, "IDN_DEMUX_CA_COUNT" },
9662 { 2566, "IDN_DEMUX_COUNT_0" },
9663 { 2567, "IDN_DEMUX_COUNT_1" },
9664 { 2568, "IDN_DEMUX_CTL" },
9665 { 2569, "IDN_DEMUX_CURR_TAG" },
9666 { 2570, "IDN_DEMUX_QUEUE_SEL" },
9667 { 2571, "IDN_DEMUX_STATUS" },
9668 { 2572, "IDN_DEMUX_WRITE_FIFO" },
9669 { 2573, "IDN_DEMUX_WRITE_QUEUE" },
9670 { 2574, "IDN_PENDING" },
9671 { 2575, "IDN_SP_FIFO_DATA" },
9672 { 2576, "IDN_SP_FIFO_SEL" },
9673 { 2577, "IDN_SP_FREEZE" },
9674 { 2578, "IDN_SP_STATE" },
9675 { 2579, "IDN_TAG_0" },
9676 { 2580, "IDN_TAG_1" },
9677 { 2581, "IDN_TAG_VALID" },
9678 { 2582, "IDN_TILE_COORD" },
9679 { 2816, "IDN_CA_DATA" },
9680 { 2817, "IDN_CA_REM" },
9681 { 2818, "IDN_CA_TAG" },
9682 { 2819, "IDN_DATA_AVAIL" },
9683 { 3072, "MPL_UDN_ACCESS_SET_0" },
9684 { 3073, "MPL_UDN_ACCESS_SET_1" },
9685 { 3074, "MPL_UDN_ACCESS_SET_2" },
9686 { 3075, "MPL_UDN_ACCESS_SET_3" },
9687 { 3076, "MPL_UDN_ACCESS" },
9688 { 3077, "UDN_DEMUX_CA_COUNT" },
9689 { 3078, "UDN_DEMUX_COUNT_0" },
9690 { 3079, "UDN_DEMUX_COUNT_1" },
9691 { 3080, "UDN_DEMUX_COUNT_2" },
9692 { 3081, "UDN_DEMUX_COUNT_3" },
9693 { 3082, "UDN_DEMUX_CTL" },
9694 { 3083, "UDN_DEMUX_CURR_TAG" },
9695 { 3084, "UDN_DEMUX_QUEUE_SEL" },
9696 { 3085, "UDN_DEMUX_STATUS" },
9697 { 3086, "UDN_DEMUX_WRITE_FIFO" },
9698 { 3087, "UDN_DEMUX_WRITE_QUEUE" },
9699 { 3088, "UDN_PENDING" },
9700 { 3089, "UDN_SP_FIFO_DATA" },
9701 { 3090, "UDN_SP_FIFO_SEL" },
9702 { 3091, "UDN_SP_FREEZE" },
9703 { 3092, "UDN_SP_STATE" },
9704 { 3093, "UDN_TAG_0" },
9705 { 3094, "UDN_TAG_1" },
9706 { 3095, "UDN_TAG_2" },
9707 { 3096, "UDN_TAG_3" },
9708 { 3097, "UDN_TAG_VALID" },
9709 { 3098, "UDN_TILE_COORD" },
9710 { 3328, "UDN_CA_DATA" },
9711 { 3329, "UDN_CA_REM" },
9712 { 3330, "UDN_CA_TAG" },
9713 { 3331, "UDN_DATA_AVAIL" },
9714 { 3584, "MPL_IDN_REFILL_SET_0" },
9715 { 3585, "MPL_IDN_REFILL_SET_1" },
9716 { 3586, "MPL_IDN_REFILL_SET_2" },
9717 { 3587, "MPL_IDN_REFILL_SET_3" },
9718 { 3588, "MPL_IDN_REFILL" },
9719 { 3589, "IDN_REFILL_EN" },
9720 { 4096, "MPL_UDN_REFILL_SET_0" },
9721 { 4097, "MPL_UDN_REFILL_SET_1" },
9722 { 4098, "MPL_UDN_REFILL_SET_2" },
9723 { 4099, "MPL_UDN_REFILL_SET_3" },
9724 { 4100, "MPL_UDN_REFILL" },
9725 { 4101, "UDN_REFILL_EN" },
9726 { 4608, "MPL_IDN_COMPLETE_SET_0" },
9727 { 4609, "MPL_IDN_COMPLETE_SET_1" },
9728 { 4610, "MPL_IDN_COMPLETE_SET_2" },
9729 { 4611, "MPL_IDN_COMPLETE_SET_3" },
9730 { 4612, "MPL_IDN_COMPLETE" },
9731 { 4613, "IDN_REMAINING" },
9732 { 5120, "MPL_UDN_COMPLETE_SET_0" },
9733 { 5121, "MPL_UDN_COMPLETE_SET_1" },
9734 { 5122, "MPL_UDN_COMPLETE_SET_2" },
9735 { 5123, "MPL_UDN_COMPLETE_SET_3" },
9736 { 5124, "MPL_UDN_COMPLETE" },
9737 { 5125, "UDN_REMAINING" },
9738 { 5632, "MPL_SWINT_3_SET_0" },
9739 { 5633, "MPL_SWINT_3_SET_1" },
9740 { 5634, "MPL_SWINT_3_SET_2" },
9741 { 5635, "MPL_SWINT_3_SET_3" },
9742 { 5636, "MPL_SWINT_3" },
9743 { 6144, "MPL_SWINT_2_SET_0" },
9744 { 6145, "MPL_SWINT_2_SET_1" },
9745 { 6146, "MPL_SWINT_2_SET_2" },
9746 { 6147, "MPL_SWINT_2_SET_3" },
9747 { 6148, "MPL_SWINT_2" },
9748 { 6656, "MPL_SWINT_1_SET_0" },
9749 { 6657, "MPL_SWINT_1_SET_1" },
9750 { 6658, "MPL_SWINT_1_SET_2" },
9751 { 6659, "MPL_SWINT_1_SET_3" },
9752 { 6660, "MPL_SWINT_1" },
9753 { 7168, "MPL_SWINT_0_SET_0" },
9754 { 7169, "MPL_SWINT_0_SET_1" },
9755 { 7170, "MPL_SWINT_0_SET_2" },
9756 { 7171, "MPL_SWINT_0_SET_3" },
9757 { 7172, "MPL_SWINT_0" },
9758 { 7680, "MPL_UNALIGN_DATA_SET_0" },
9759 { 7681, "MPL_UNALIGN_DATA_SET_1" },
9760 { 7682, "MPL_UNALIGN_DATA_SET_2" },
9761 { 7683, "MPL_UNALIGN_DATA_SET_3" },
9762 { 7684, "MPL_UNALIGN_DATA" },
9763 { 8192, "MPL_DTLB_MISS_SET_0" },
9764 { 8193, "MPL_DTLB_MISS_SET_1" },
9765 { 8194, "MPL_DTLB_MISS_SET_2" },
9766 { 8195, "MPL_DTLB_MISS_SET_3" },
9767 { 8196, "MPL_DTLB_MISS" },
9768 { 8448, "AER_0" },
9769 { 8449, "AER_1" },
9770 { 8450, "DTLB_BAD_ADDR" },
9771 { 8451, "DTLB_BAD_ADDR_REASON" },
9772 { 8452, "DTLB_CURRENT_0" },
9773 { 8453, "DTLB_CURRENT_1" },
9774 { 8454, "DTLB_CURRENT_2" },
9775 { 8455, "DTLB_CURRENT_3" },
9776 { 8456, "DTLB_INDEX" },
9777 { 8457, "DTLB_MATCH_0" },
9778 { 8458, "NUMBER_DTLB" },
9779 { 8459, "PHYSICAL_MEMORY_MODE" },
9780 { 8460, "REPLACEMENT_DTLB" },
9781 { 8461, "WIRED_DTLB" },
9782 { 8462, "CACHE_RED_WAY_OVERRIDDEN" },
9783 { 8463, "DTLB_PERF" },
9784 { 8704, "MPL_DTLB_ACCESS_SET_0" },
9785 { 8705, "MPL_DTLB_ACCESS_SET_1" },
9786 { 8706, "MPL_DTLB_ACCESS_SET_2" },
9787 { 8707, "MPL_DTLB_ACCESS_SET_3" },
9788 { 8708, "MPL_DTLB_ACCESS" },
9789 { 9216, "MPL_DMATLB_MISS_SET_0" },
9790 { 9217, "MPL_DMATLB_MISS_SET_1" },
9791 { 9218, "MPL_DMATLB_MISS_SET_2" },
9792 { 9219, "MPL_DMATLB_MISS_SET_3" },
9793 { 9220, "MPL_DMATLB_MISS" },
9794 { 9472, "DMA_BAD_ADDR" },
9795 { 9473, "DMA_STATUS" },
9796 { 9728, "MPL_DMATLB_ACCESS_SET_0" },
9797 { 9729, "MPL_DMATLB_ACCESS_SET_1" },
9798 { 9730, "MPL_DMATLB_ACCESS_SET_2" },
9799 { 9731, "MPL_DMATLB_ACCESS_SET_3" },
9800 { 9732, "MPL_DMATLB_ACCESS" },
9801 { 10240, "MPL_SNITLB_MISS_SET_0" },
9802 { 10241, "MPL_SNITLB_MISS_SET_1" },
9803 { 10242, "MPL_SNITLB_MISS_SET_2" },
9804 { 10243, "MPL_SNITLB_MISS_SET_3" },
9805 { 10244, "MPL_SNITLB_MISS" },
9806 { 10245, "NUMBER_SNITLB" },
9807 { 10246, "REPLACEMENT_SNITLB" },
9808 { 10247, "SNITLB_CURRENT_0" },
9809 { 10248, "SNITLB_CURRENT_1" },
9810 { 10249, "SNITLB_CURRENT_2" },
9811 { 10250, "SNITLB_CURRENT_3" },
9812 { 10251, "SNITLB_INDEX" },
9813 { 10252, "SNITLB_MATCH_0" },
9814 { 10253, "SNITLB_PR" },
9815 { 10254, "WIRED_SNITLB" },
9816 { 10255, "SNITLB_STATUS" },
9817 { 10752, "MPL_SN_NOTIFY_SET_0" },
9818 { 10753, "MPL_SN_NOTIFY_SET_1" },
9819 { 10754, "MPL_SN_NOTIFY_SET_2" },
9820 { 10755, "MPL_SN_NOTIFY_SET_3" },
9821 { 10756, "MPL_SN_NOTIFY" },
9822 { 10757, "SN_NOTIFY_STATUS" },
9823 { 11264, "MPL_SN_FIREWALL_SET_0" },
9824 { 11265, "MPL_SN_FIREWALL_SET_1" },
9825 { 11266, "MPL_SN_FIREWALL_SET_2" },
9826 { 11267, "MPL_SN_FIREWALL_SET_3" },
9827 { 11268, "MPL_SN_FIREWALL" },
9828 { 11269, "SN_DIRECTION_PROTECT" },
9829 { 11776, "MPL_IDN_FIREWALL_SET_0" },
9830 { 11777, "MPL_IDN_FIREWALL_SET_1" },
9831 { 11778, "MPL_IDN_FIREWALL_SET_2" },
9832 { 11779, "MPL_IDN_FIREWALL_SET_3" },
9833 { 11780, "MPL_IDN_FIREWALL" },
9834 { 11781, "IDN_DIRECTION_PROTECT" },
9835 { 12288, "MPL_UDN_FIREWALL_SET_0" },
9836 { 12289, "MPL_UDN_FIREWALL_SET_1" },
9837 { 12290, "MPL_UDN_FIREWALL_SET_2" },
9838 { 12291, "MPL_UDN_FIREWALL_SET_3" },
9839 { 12292, "MPL_UDN_FIREWALL" },
9840 { 12293, "UDN_DIRECTION_PROTECT" },
9841 { 12800, "MPL_TILE_TIMER_SET_0" },
9842 { 12801, "MPL_TILE_TIMER_SET_1" },
9843 { 12802, "MPL_TILE_TIMER_SET_2" },
9844 { 12803, "MPL_TILE_TIMER_SET_3" },
9845 { 12804, "MPL_TILE_TIMER" },
9846 { 12805, "TILE_TIMER_CONTROL" },
9847 { 13312, "MPL_IDN_TIMER_SET_0" },
9848 { 13313, "MPL_IDN_TIMER_SET_1" },
9849 { 13314, "MPL_IDN_TIMER_SET_2" },
9850 { 13315, "MPL_IDN_TIMER_SET_3" },
9851 { 13316, "MPL_IDN_TIMER" },
9852 { 13317, "IDN_DEADLOCK_COUNT" },
9853 { 13318, "IDN_DEADLOCK_TIMEOUT" },
9854 { 13824, "MPL_UDN_TIMER_SET_0" },
9855 { 13825, "MPL_UDN_TIMER_SET_1" },
9856 { 13826, "MPL_UDN_TIMER_SET_2" },
9857 { 13827, "MPL_UDN_TIMER_SET_3" },
9858 { 13828, "MPL_UDN_TIMER" },
9859 { 13829, "UDN_DEADLOCK_COUNT" },
9860 { 13830, "UDN_DEADLOCK_TIMEOUT" },
9861 { 14336, "MPL_DMA_NOTIFY_SET_0" },
9862 { 14337, "MPL_DMA_NOTIFY_SET_1" },
9863 { 14338, "MPL_DMA_NOTIFY_SET_2" },
9864 { 14339, "MPL_DMA_NOTIFY_SET_3" },
9865 { 14340, "MPL_DMA_NOTIFY" },
9866 { 14592, "DMA_BYTE" },
9867 { 14593, "DMA_CHUNK_SIZE" },
9868 { 14594, "DMA_CTR" },
9869 { 14595, "DMA_DST_ADDR" },
9870 { 14596, "DMA_DST_CHUNK_ADDR" },
9871 { 14597, "DMA_SRC_ADDR" },
9872 { 14598, "DMA_SRC_CHUNK_ADDR" },
9873 { 14599, "DMA_STRIDE" },
9874 { 14600, "DMA_USER_STATUS" },
9875 { 14848, "MPL_IDN_CA_SET_0" },
9876 { 14849, "MPL_IDN_CA_SET_1" },
9877 { 14850, "MPL_IDN_CA_SET_2" },
9878 { 14851, "MPL_IDN_CA_SET_3" },
9879 { 14852, "MPL_IDN_CA" },
9880 { 15360, "MPL_UDN_CA_SET_0" },
9881 { 15361, "MPL_UDN_CA_SET_1" },
9882 { 15362, "MPL_UDN_CA_SET_2" },
9883 { 15363, "MPL_UDN_CA_SET_3" },
9884 { 15364, "MPL_UDN_CA" },
9885 { 15872, "MPL_IDN_AVAIL_SET_0" },
9886 { 15873, "MPL_IDN_AVAIL_SET_1" },
9887 { 15874, "MPL_IDN_AVAIL_SET_2" },
9888 { 15875, "MPL_IDN_AVAIL_SET_3" },
9889 { 15876, "MPL_IDN_AVAIL" },
9890 { 15877, "IDN_AVAIL_EN" },
9891 { 16384, "MPL_UDN_AVAIL_SET_0" },
9892 { 16385, "MPL_UDN_AVAIL_SET_1" },
9893 { 16386, "MPL_UDN_AVAIL_SET_2" },
9894 { 16387, "MPL_UDN_AVAIL_SET_3" },
9895 { 16388, "MPL_UDN_AVAIL" },
9896 { 16389, "UDN_AVAIL_EN" },
9897 { 16896, "MPL_PERF_COUNT_SET_0" },
9898 { 16897, "MPL_PERF_COUNT_SET_1" },
9899 { 16898, "MPL_PERF_COUNT_SET_2" },
9900 { 16899, "MPL_PERF_COUNT_SET_3" },
9901 { 16900, "MPL_PERF_COUNT" },
9902 { 16901, "PERF_COUNT_0" },
9903 { 16902, "PERF_COUNT_1" },
9904 { 16903, "PERF_COUNT_CTL" },
9905 { 16904, "PERF_COUNT_STS" },
9906 { 16905, "WATCH_CTL" },
9907 { 16906, "WATCH_MASK" },
9908 { 16907, "WATCH_VAL" },
9909 { 16912, "PERF_COUNT_DN_CTL" },
9910 { 17408, "MPL_INTCTRL_3_SET_0" },
9911 { 17409, "MPL_INTCTRL_3_SET_1" },
9912 { 17410, "MPL_INTCTRL_3_SET_2" },
9913 { 17411, "MPL_INTCTRL_3_SET_3" },
9914 { 17412, "MPL_INTCTRL_3" },
9915 { 17413, "EX_CONTEXT_3_0" },
9916 { 17414, "EX_CONTEXT_3_1" },
9917 { 17415, "INTERRUPT_MASK_3_0" },
9918 { 17416, "INTERRUPT_MASK_3_1" },
9919 { 17417, "INTERRUPT_MASK_RESET_3_0" },
9920 { 17418, "INTERRUPT_MASK_RESET_3_1" },
9921 { 17419, "INTERRUPT_MASK_SET_3_0" },
9922 { 17420, "INTERRUPT_MASK_SET_3_1" },
9923 { 17432, "INTCTRL_3_STATUS" },
9924 { 17664, "SYSTEM_SAVE_3_0" },
9925 { 17665, "SYSTEM_SAVE_3_1" },
9926 { 17666, "SYSTEM_SAVE_3_2" },
9927 { 17667, "SYSTEM_SAVE_3_3" },
9928 { 17920, "MPL_INTCTRL_2_SET_0" },
9929 { 17921, "MPL_INTCTRL_2_SET_1" },
9930 { 17922, "MPL_INTCTRL_2_SET_2" },
9931 { 17923, "MPL_INTCTRL_2_SET_3" },
9932 { 17924, "MPL_INTCTRL_2" },
9933 { 17925, "EX_CONTEXT_2_0" },
9934 { 17926, "EX_CONTEXT_2_1" },
9935 { 17927, "INTCTRL_2_STATUS" },
9936 { 17928, "INTERRUPT_MASK_2_0" },
9937 { 17929, "INTERRUPT_MASK_2_1" },
9938 { 17930, "INTERRUPT_MASK_RESET_2_0" },
9939 { 17931, "INTERRUPT_MASK_RESET_2_1" },
9940 { 17932, "INTERRUPT_MASK_SET_2_0" },
9941 { 17933, "INTERRUPT_MASK_SET_2_1" },
9942 { 18176, "SYSTEM_SAVE_2_0" },
9943 { 18177, "SYSTEM_SAVE_2_1" },
9944 { 18178, "SYSTEM_SAVE_2_2" },
9945 { 18179, "SYSTEM_SAVE_2_3" },
9946 { 18432, "MPL_INTCTRL_1_SET_0" },
9947 { 18433, "MPL_INTCTRL_1_SET_1" },
9948 { 18434, "MPL_INTCTRL_1_SET_2" },
9949 { 18435, "MPL_INTCTRL_1_SET_3" },
9950 { 18436, "MPL_INTCTRL_1" },
9951 { 18437, "EX_CONTEXT_1_0" },
9952 { 18438, "EX_CONTEXT_1_1" },
9953 { 18439, "INTCTRL_1_STATUS" },
9954 { 18440, "INTCTRL_3_STATUS_REV0" },
9955 { 18441, "INTERRUPT_MASK_1_0" },
9956 { 18442, "INTERRUPT_MASK_1_1" },
9957 { 18443, "INTERRUPT_MASK_RESET_1_0" },
9958 { 18444, "INTERRUPT_MASK_RESET_1_1" },
9959 { 18445, "INTERRUPT_MASK_SET_1_0" },
9960 { 18446, "INTERRUPT_MASK_SET_1_1" },
9961 { 18688, "SYSTEM_SAVE_1_0" },
9962 { 18689, "SYSTEM_SAVE_1_1" },
9963 { 18690, "SYSTEM_SAVE_1_2" },
9964 { 18691, "SYSTEM_SAVE_1_3" },
9965 { 18944, "MPL_INTCTRL_0_SET_0" },
9966 { 18945, "MPL_INTCTRL_0_SET_1" },
9967 { 18946, "MPL_INTCTRL_0_SET_2" },
9968 { 18947, "MPL_INTCTRL_0_SET_3" },
9969 { 18948, "MPL_INTCTRL_0" },
9970 { 18949, "EX_CONTEXT_0_0" },
9971 { 18950, "EX_CONTEXT_0_1" },
9972 { 18951, "INTCTRL_0_STATUS" },
9973 { 18952, "INTERRUPT_MASK_0_0" },
9974 { 18953, "INTERRUPT_MASK_0_1" },
9975 { 18954, "INTERRUPT_MASK_RESET_0_0" },
9976 { 18955, "INTERRUPT_MASK_RESET_0_1" },
9977 { 18956, "INTERRUPT_MASK_SET_0_0" },
9978 { 18957, "INTERRUPT_MASK_SET_0_1" },
9979 { 19200, "SYSTEM_SAVE_0_0" },
9980 { 19201, "SYSTEM_SAVE_0_1" },
9981 { 19202, "SYSTEM_SAVE_0_2" },
9982 { 19203, "SYSTEM_SAVE_0_3" },
9983 { 19456, "MPL_BOOT_ACCESS_SET_0" },
9984 { 19457, "MPL_BOOT_ACCESS_SET_1" },
9985 { 19458, "MPL_BOOT_ACCESS_SET_2" },
9986 { 19459, "MPL_BOOT_ACCESS_SET_3" },
9987 { 19460, "MPL_BOOT_ACCESS" },
9988 { 19461, "CBOX_CACHEASRAM_CONFIG" },
9989 { 19462, "CBOX_CACHE_CONFIG" },
9990 { 19463, "CBOX_MMAP_0" },
9991 { 19464, "CBOX_MMAP_1" },
9992 { 19465, "CBOX_MMAP_2" },
9993 { 19466, "CBOX_MMAP_3" },
9994 { 19467, "CBOX_MSR" },
9995 { 19468, "CBOX_SRC_ID" },
9996 { 19469, "CYCLE_HIGH_MODIFY" },
9997 { 19470, "CYCLE_LOW_MODIFY" },
9998 { 19471, "DIAG_BCST_CTL" },
9999 { 19472, "DIAG_BCST_MASK" },
10000 { 19473, "DIAG_BCST_TRIGGER" },
10001 { 19474, "DIAG_MUX_CTL" },
10002 { 19475, "DIAG_TRACE_CTL" },
10003 { 19476, "DIAG_TRACE_STS" },
10004 { 19477, "IDN_DEMUX_BUF_THRESH" },
10005 { 19478, "SBOX_CONFIG" },
10006 { 19479, "TILE_COORD" },
10007 { 19480, "UDN_DEMUX_BUF_THRESH" },
10008 { 19481, "CBOX_HOME_MAP_ADDR" },
10009 { 19482, "CBOX_HOME_MAP_DATA" },
10010 { 19483, "CBOX_MSR1" },
10011 { 19484, "BIG_ENDIAN_CONFIG" },
10012 { 19485, "MEM_STRIPE_CONFIG" },
10013 { 19486, "DIAG_TRACE_WAY" },
10014 { 19487, "VDN_SNOOP_SHIM_CTL" },
10015 { 19488, "PERF_COUNT_PLS" },
10016 { 19489, "DIAG_TRACE_DATA" },
10017 { 19712, "I_AER_0" },
10018 { 19713, "I_AER_1" },
10019 { 19714, "I_PHYSICAL_MEMORY_MODE" },
10020 { 19968, "MPL_WORLD_ACCESS_SET_0" },
10021 { 19969, "MPL_WORLD_ACCESS_SET_1" },
10022 { 19970, "MPL_WORLD_ACCESS_SET_2" },
10023 { 19971, "MPL_WORLD_ACCESS_SET_3" },
10024 { 19972, "MPL_WORLD_ACCESS" },
10025 { 19973, "SIM_SOCKET" },
10026 { 19974, "CYCLE_HIGH" },
10027 { 19975, "CYCLE_LOW" },
10028 { 19976, "DONE" },
10029 { 19977, "FAIL" },
10030 { 19978, "INTERRUPT_CRITICAL_SECTION" },
10031 { 19979, "PASS" },
10032 { 19980, "SIM_CONTROL" },
10033 { 19981, "EVENT_BEGIN" },
10034 { 19982, "EVENT_END" },
10035 { 19983, "TILE_WRITE_PENDING" },
10036 { 19984, "TILE_RTF_HWM" },
10037 { 20224, "PROC_STATUS" },
10038 { 20225, "STATUS_SATURATE" },
10039 { 20480, "MPL_I_ASID_SET_0" },
10040 { 20481, "MPL_I_ASID_SET_1" },
10041 { 20482, "MPL_I_ASID_SET_2" },
10042 { 20483, "MPL_I_ASID_SET_3" },
10043 { 20484, "MPL_I_ASID" },
10044 { 20485, "I_ASID" },
10045 { 20992, "MPL_D_ASID_SET_0" },
10046 { 20993, "MPL_D_ASID_SET_1" },
10047 { 20994, "MPL_D_ASID_SET_2" },
10048 { 20995, "MPL_D_ASID_SET_3" },
10049 { 20996, "MPL_D_ASID" },
10050 { 20997, "D_ASID" },
10051 { 21504, "MPL_DMA_ASID_SET_0" },
10052 { 21505, "MPL_DMA_ASID_SET_1" },
10053 { 21506, "MPL_DMA_ASID_SET_2" },
10054 { 21507, "MPL_DMA_ASID_SET_3" },
10055 { 21508, "MPL_DMA_ASID" },
10056 { 21509, "DMA_ASID" },
10057 { 22016, "MPL_SNI_ASID_SET_0" },
10058 { 22017, "MPL_SNI_ASID_SET_1" },
10059 { 22018, "MPL_SNI_ASID_SET_2" },
10060 { 22019, "MPL_SNI_ASID_SET_3" },
10061 { 22020, "MPL_SNI_ASID" },
10062 { 22021, "SNI_ASID" },
10063 { 22528, "MPL_DMA_CPL_SET_0" },
10064 { 22529, "MPL_DMA_CPL_SET_1" },
10065 { 22530, "MPL_DMA_CPL_SET_2" },
10066 { 22531, "MPL_DMA_CPL_SET_3" },
10067 { 22532, "MPL_DMA_CPL" },
10068 { 23040, "MPL_SN_CPL_SET_0" },
10069 { 23041, "MPL_SN_CPL_SET_1" },
10070 { 23042, "MPL_SN_CPL_SET_2" },
10071 { 23043, "MPL_SN_CPL_SET_3" },
10072 { 23044, "MPL_SN_CPL" },
10073 { 23552, "MPL_DOUBLE_FAULT_SET_0" },
10074 { 23553, "MPL_DOUBLE_FAULT_SET_1" },
10075 { 23554, "MPL_DOUBLE_FAULT_SET_2" },
10076 { 23555, "MPL_DOUBLE_FAULT_SET_3" },
10077 { 23556, "MPL_DOUBLE_FAULT" },
10078 { 23557, "LAST_INTERRUPT_REASON" },
10079 { 24064, "MPL_SN_STATIC_ACCESS_SET_0" },
10080 { 24065, "MPL_SN_STATIC_ACCESS_SET_1" },
10081 { 24066, "MPL_SN_STATIC_ACCESS_SET_2" },
10082 { 24067, "MPL_SN_STATIC_ACCESS_SET_3" },
10083 { 24068, "MPL_SN_STATIC_ACCESS" },
10084 { 24069, "SN_STATIC_CTL" },
10085 { 24070, "SN_STATIC_FIFO_DATA" },
10086 { 24071, "SN_STATIC_FIFO_SEL" },
10087 { 24073, "SN_STATIC_ISTATE" },
10088 { 24074, "SN_STATIC_OSTATE" },
10089 { 24076, "SN_STATIC_STATIC" },
10090 { 24320, "SN_STATIC_DATA_AVAIL" },
10091 { 24576, "MPL_AUX_PERF_COUNT_SET_0" },
10092 { 24577, "MPL_AUX_PERF_COUNT_SET_1" },
10093 { 24578, "MPL_AUX_PERF_COUNT_SET_2" },
10094 { 24579, "MPL_AUX_PERF_COUNT_SET_3" },
10095 { 24580, "MPL_AUX_PERF_COUNT" },
10096 { 24581, "AUX_PERF_COUNT_0" },
10097 { 24582, "AUX_PERF_COUNT_1" },
10098 { 24583, "AUX_PERF_COUNT_CTL" },
10099 { 24584, "AUX_PERF_COUNT_STS" },
10100 };
10101
10102 const int tilepro_num_sprs = 499;
10103
10104 #endif /* DISASM_ONLY */
10105
10106 #ifndef DISASM_ONLY
10107
10108 #include <stdlib.h>
10109
10110 static int
tilepro_spr_compare(const void * a_ptr,const void * b_ptr)10111 tilepro_spr_compare (const void *a_ptr, const void *b_ptr)
10112 {
10113 const struct tilepro_spr *a = (const struct tilepro_spr *) a_ptr;
10114 const struct tilepro_spr *b = (const struct tilepro_spr *) b_ptr;
10115
10116 return a->number - b->number;
10117 }
10118
10119 const char *
get_tilepro_spr_name(int num)10120 get_tilepro_spr_name (int num)
10121 {
10122 void *result;
10123 struct tilepro_spr key;
10124
10125 key.number = num;
10126 result = bsearch ((const void *) &key, (const void *) tilepro_sprs,
10127 tilepro_num_sprs, sizeof (struct tilepro_spr),
10128 tilepro_spr_compare);
10129
10130 if (result == NULL)
10131 return NULL;
10132
10133 {
10134 struct tilepro_spr *result_ptr = (struct tilepro_spr *) result;
10135
10136 return result_ptr->name;
10137 }
10138 }
10139
10140
10141 /* Canonical name of each register. */
10142 const char * const tilepro_register_names[] =
10143 {
10144 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
10145 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
10146 "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
10147 "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31",
10148 "r32", "r33", "r34", "r35", "r36", "r37", "r38", "r39",
10149 "r40", "r41", "r42", "r43", "r44", "r45", "r46", "r47",
10150 "r48", "r49", "r50", "r51", "r52", "tp", "sp", "lr",
10151 "sn", "idn0", "idn1", "udn0", "udn1", "udn2", "udn3", "zero"
10152 };
10153
10154 #endif /* not DISASM_ONLY */
10155
10156
10157 /* Given a set of bundle bits and a specific pipe, returns which
10158 instruction the bundle contains in that pipe. */
10159
10160 const struct tilepro_opcode *
find_opcode(tilepro_bundle_bits bits,tilepro_pipeline pipe)10161 find_opcode (tilepro_bundle_bits bits, tilepro_pipeline pipe)
10162 {
10163 const unsigned short *table = tilepro_bundle_decoder_fsms[pipe];
10164 int i = 0;
10165
10166 while (1)
10167 {
10168 unsigned short bitspec = table[i];
10169 unsigned int bitfield =
10170 ((unsigned int) (bits >> (bitspec & 63))) & (bitspec >> 6);
10171 unsigned short next = table[i + 1 + bitfield];
10172
10173 if (next <= TILEPRO_OPC_NONE)
10174 return &tilepro_opcodes[next];
10175
10176 i = next - TILEPRO_OPC_NONE;
10177 }
10178 }
10179
10180
10181 int
parse_insn_tilepro(tilepro_bundle_bits bits,unsigned int pc,struct tilepro_decoded_instruction decoded[TILEPRO_MAX_INSTRUCTIONS_PER_BUNDLE])10182 parse_insn_tilepro (tilepro_bundle_bits bits,
10183 unsigned int pc,
10184 struct tilepro_decoded_instruction
10185 decoded[TILEPRO_MAX_INSTRUCTIONS_PER_BUNDLE])
10186 {
10187 int num_instructions = 0;
10188 int pipe;
10189 int min_pipe, max_pipe;
10190
10191 if ((bits & TILEPRO_BUNDLE_Y_ENCODING_MASK) == 0)
10192 {
10193 min_pipe = TILEPRO_PIPELINE_X0;
10194 max_pipe = TILEPRO_PIPELINE_X1;
10195 }
10196 else
10197 {
10198 min_pipe = TILEPRO_PIPELINE_Y0;
10199 max_pipe = TILEPRO_PIPELINE_Y2;
10200 }
10201
10202 /* For each pipe, find an instruction that fits. */
10203 for (pipe = min_pipe; pipe <= max_pipe; pipe++)
10204 {
10205 const struct tilepro_opcode *opc;
10206 struct tilepro_decoded_instruction *d;
10207 int i;
10208
10209 d = &decoded[num_instructions++];
10210 opc = find_opcode (bits, (tilepro_pipeline)pipe);
10211 d->opcode = opc;
10212
10213 /* Decode each operand, sign extending, etc. as appropriate. */
10214 for (i = 0; i < opc->num_operands; i++)
10215 {
10216 const struct tilepro_operand *op =
10217 &tilepro_operands[opc->operands[pipe][i]];
10218 unsigned int opval = op->extract (bits);
10219
10220 if (op->is_signed)
10221 {
10222 /* Sign-extend the operand. */
10223 unsigned int sign = 1u << (op->num_bits - 1);
10224 opval = ((opval & (sign + sign - 1)) ^ sign) - sign;
10225 }
10226
10227 /* Adjust PC-relative scaled branch offsets. */
10228 if (op->type == TILEPRO_OP_TYPE_ADDRESS)
10229 opval = opval * TILEPRO_BUNDLE_SIZE_IN_BYTES + pc;
10230
10231 /* Record the final value. */
10232 d->operands[i] = op;
10233 d->operand_values[i] = opval;
10234 }
10235 }
10236
10237 return num_instructions;
10238 }
10239