1 /* alpha-opc.c -- Alpha AXP opcode list
2 Copyright 1996 Free Software Foundation, Inc.
4 patterned after the PPC opcode handling written by Ian Lance Taylor.
6 This file is part of GDB, GAS, and the GNU binutils.
8 GDB, GAS, and the GNU binutils are free software; you can redistribute
9 them and/or modify them under the terms of the GNU General Public
10 License as published by the Free Software Foundation; either version
11 2, or (at your option) any later version.
13 GDB, GAS, and the GNU binutils are distributed in the hope that they
14 will be useful, but WITHOUT ANY WARRANTY; without even the implied
15 warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See
16 the GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this file; see the file COPYING. If not, write to the
20 Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA
25 #include "opcode/alpha.h"
27 /* This file holds the Alpha AXP opcode table. The opcode table
28 includes almost all of the extended instruction mnemonics. This
29 permits the disassembler to use them, and simplifies the assembler
30 logic, at the cost of increasing the table size. The table is
31 strictly constant data, so the compiler should be able to put it in
34 This file also holds the operand table. All knowledge about
35 inserting operands into instructions and vice-versa is kept in this
38 /* Local insertion and extraction functions */
40 static unsigned insert_rba PARAMS((unsigned, int, const char **));
41 static unsigned insert_rca PARAMS((unsigned, int, const char **));
42 static unsigned insert_za PARAMS((unsigned, int, const char **));
43 static unsigned insert_zb PARAMS((unsigned, int, const char **));
44 static unsigned insert_zc PARAMS((unsigned, int, const char **));
45 static unsigned insert_bdisp PARAMS((unsigned, int, const char **));
46 static unsigned insert_jhint PARAMS((unsigned, int, const char **));
48 static int extract_rba PARAMS((unsigned, int *));
49 static int extract_rca PARAMS((unsigned, int *));
50 static int extract_za PARAMS((unsigned, int *));
51 static int extract_zb PARAMS((unsigned, int *));
52 static int extract_zc PARAMS((unsigned, int *));
53 static int extract_bdisp PARAMS((unsigned, int *));
54 static int extract_jhint PARAMS((unsigned, int *));
57 /* The operands table */
59 const struct alpha_operand alpha_operands[] =
61 /* The fields are bits, shift, insert, extract, flags */
62 /* The zero index is used to indicate end-of-list */
64 { 0, 0, BFD_RELOC_UNUSED, 0, 0 },
66 /* The plain integer register fields */
67 #define RA (UNUSED + 1)
68 { 5, 21, BFD_RELOC_UNUSED, 0, 0, AXP_OPERAND_IR },
70 { 5, 16, BFD_RELOC_UNUSED, 0, 0, AXP_OPERAND_IR },
72 { 5, 0, BFD_RELOC_UNUSED, 0, 0, AXP_OPERAND_IR },
74 /* The plain fp register fields */
76 { 5, 21, BFD_RELOC_UNUSED, 0, 0, AXP_OPERAND_FPR },
78 { 5, 16, BFD_RELOC_UNUSED, 0, 0, AXP_OPERAND_FPR },
80 { 5, 0, BFD_RELOC_UNUSED, 0, 0, AXP_OPERAND_FPR },
82 /* The integer registers when they are ZERO */
84 { 5, 21, BFD_RELOC_UNUSED, insert_za, extract_za, AXP_OPERAND_FAKE },
86 { 5, 16, BFD_RELOC_UNUSED, insert_zb, extract_zb, AXP_OPERAND_FAKE },
88 { 5, 0, BFD_RELOC_UNUSED, insert_zc, extract_zc, AXP_OPERAND_FAKE },
90 /* The RB field when it needs parentheses */
92 { 5, 16, BFD_RELOC_UNUSED, 0, 0, AXP_OPERAND_IR|AXP_OPERAND_PARENS },
94 /* The RB field when it needs parentheses _and_ a preceding comma */
95 #define CPRB (PRB + 1)
96 { 5, 16, BFD_RELOC_UNUSED, 0, 0,
97 AXP_OPERAND_IR|AXP_OPERAND_PARENS|AXP_OPERAND_COMMA },
99 /* The RB field when it must be the same as the RA field */
100 #define RBA (CPRB + 1)
101 { 5, 16, BFD_RELOC_UNUSED, insert_rba, extract_rba, AXP_OPERAND_FAKE },
103 /* The RC field when it must be the same as the RB field */
104 #define RCA (RBA + 1)
105 { 5, 0, BFD_RELOC_UNUSED, insert_rca, extract_rca, AXP_OPERAND_FAKE },
107 /* The RC field when it can *default* to RA */
108 #define DRC1 (RCA + 1)
109 { 5, 0, BFD_RELOC_UNUSED, 0, 0,
110 AXP_OPERAND_IR|AXP_OPERAND_DEFAULT_FIRST },
112 /* The RC field when it can *default* to RB */
113 #define DRC2 (DRC1 + 1)
114 { 5, 0, BFD_RELOC_UNUSED, 0, 0,
115 AXP_OPERAND_IR|AXP_OPERAND_DEFAULT_SECOND },
117 /* The FC field when it can *default* to RA */
118 #define DFC1 (DRC2 + 1)
119 { 5, 0, BFD_RELOC_UNUSED, 0, 0,
120 AXP_OPERAND_FPR|AXP_OPERAND_DEFAULT_FIRST },
122 /* The FC field when it can *default* to RB */
123 #define DFC2 (DFC1 + 1)
124 { 5, 0, BFD_RELOC_UNUSED, 0, 0,
125 AXP_OPERAND_FPR|AXP_OPERAND_DEFAULT_SECOND },
127 /* The unsigned 8-bit literal of Operate format insns */
128 #define LIT (DFC2 + 1)
129 { 8, 13, BFD_RELOC_UNUSED+LIT, 0, 0, AXP_OPERAND_UNSIGNED },
131 /* The signed 16-bit displacement of Memory format insns. From here
132 we can't tell what relocation should be used, so don't use a default. */
133 #define MDISP (LIT + 1)
134 { 16, 0, BFD_RELOC_UNUSED+MDISP, 0, 0, AXP_OPERAND_SIGNED },
136 /* The signed "23-bit" aligned displacement of Branch format insns */
137 #define BDISP (MDISP + 1)
138 { 21, 0, BFD_RELOC_23_PCREL_S2, insert_bdisp, extract_bdisp,
139 AXP_OPERAND_RELATIVE },
141 /* The 26-bit PALcode function */
142 #define PALFN (BDISP + 1)
143 { 26, 0, BFD_RELOC_UNUSED+PALFN, 0, 0, AXP_OPERAND_UNSIGNED },
145 /* The optional signed "16-bit" aligned displacement of the JMP/JSR hint */
146 #define JMPHINT (PALFN + 1)
147 { 14, 0, BFD_RELOC_ALPHA_HINT, insert_jhint, extract_jhint,
148 AXP_OPERAND_RELATIVE|AXP_OPERAND_DEFAULT_ZERO|AXP_OPERAND_NOOVERFLOW },
150 /* The optional hint to RET/JSR_COROUTINE */
151 #define RETHINT (JMPHINT + 1)
152 { 14, 0, BFD_RELOC_UNUSED+RETHINT, 0, 0,
153 AXP_OPERAND_UNSIGNED|AXP_OPERAND_DEFAULT_ZERO },
155 /* The 12-bit displacement for the ev4 hw_{ld,st} (pal1b/pal1f) insns */
156 #define EV4HWDISP (RETHINT + 1)
157 { 12, 0, BFD_RELOC_UNUSED+EV4HWDISP, 0, 0, AXP_OPERAND_SIGNED },
159 /* The 5-bit index for the ev4 hw_m[ft]pr (pal19/pal1d) insns */
160 #define EV4HWINDEX (EV4HWDISP + 1)
161 { 5, 0, BFD_RELOC_UNUSED+EV4HWINDEX, 0, 0, AXP_OPERAND_UNSIGNED },
163 /* The 8-bit index for the oddly unqualified hw_m[tf]pr insns
164 that occur in DEC PALcode. */
165 #define EV4EXTHWINDEX (EV4HWINDEX + 1)
166 { 5, 0, BFD_RELOC_UNUSED+EV4EXTHWINDEX, 0, 0, AXP_OPERAND_UNSIGNED },
168 /* The 10-bit displacement for the ev5 hw_{ld,st} (pal1b/pal1f) insns */
169 #define EV5HWDISP (EV4EXTHWINDEX + 1)
170 { 10, 0, BFD_RELOC_UNUSED+EV5HWDISP, 0, 0, AXP_OPERAND_SIGNED },
172 /* The 16-bit index for the ev5 hw_m[ft]pr (pal19/pal1d) insns */
173 #define EV5HWINDEX (EV5HWDISP + 1)
174 { 16, 0, BFD_RELOC_UNUSED+EV5HWINDEX, 0, 0, AXP_OPERAND_UNSIGNED },
177 const int alpha_num_operands = sizeof(alpha_operands)/sizeof(*alpha_operands);
179 /* The RB field when it is the same as the RA field in the same insn.
180 This operand is marked fake. The insertion function just copies
181 the RA field into the RB field, and the extraction function just
182 checks that the fields are the same. */
186 insert_rba(insn, value, errmsg)
191 return insn | (((insn >> 21) & 0x1f) << 16);
195 extract_rba(insn, invalid)
199 if (invalid != (int *) NULL
200 && ((insn >> 21) & 0x1f) != ((insn >> 16) & 0x1f))
206 /* The same for the RC field */
210 insert_rca(insn, value, errmsg)
215 return insn | ((insn >> 21) & 0x1f);
219 extract_rca(insn, invalid)
223 if (invalid != (int *) NULL
224 && ((insn >> 21) & 0x1f) != (insn & 0x1f))
230 /* Fake arguments in which the registers must be set to ZERO */
234 insert_za(insn, value, errmsg)
239 return insn | (31 << 21);
243 extract_za(insn, invalid)
247 if (invalid != (int *) NULL && ((insn >> 21) & 0x1f) != 31)
254 insert_zb(insn, value, errmsg)
259 return insn | (31 << 16);
263 extract_zb(insn, invalid)
267 if (invalid != (int *) NULL && ((insn >> 16) & 0x1f) != 31)
274 insert_zc(insn, value, errmsg)
283 extract_zc(insn, invalid)
287 if (invalid != (int *) NULL && (insn & 0x1f) != 31)
293 /* The displacement field of a Branch format insn. */
296 insert_bdisp(insn, value, errmsg)
301 if (errmsg != (const char **)NULL && (value & 3))
302 *errmsg = "branch operand unaligned";
303 return insn | ((value / 4) & 0x1FFFFF);
308 extract_bdisp(insn, invalid)
312 return 4 * (((insn & 0x1FFFFF) ^ 0x100000) - 0x100000);
316 /* The hint field of a JMP/JSR insn. */
319 insert_jhint(insn, value, errmsg)
324 if (errmsg != (const char **)NULL && (value & 3))
325 *errmsg = "jump hint unaligned";
326 return insn | ((value / 4) & 0xFFFF);
331 extract_jhint(insn, invalid)
335 return 4 * (((insn & 0x3FFF) ^ 0x2000) - 0x2000);
339 /* Macros used to form opcodes */
341 /* The main opcode */
342 #define OP(x) (((x) & 0x3F) << 26)
343 #define OP_MASK 0xFC000000
345 /* Branch format instructions */
346 #define BRA_(oo) OP(oo)
347 #define BRA_MASK OP_MASK
348 #define BRA(oo) BRA_(oo), BRA_MASK
350 /* Floating point format instructions */
351 #define FP_(oo,fff) (OP(oo) | (((fff) & 0x7FF) << 5))
352 #define FP_MASK (OP_MASK | 0xFFE0)
353 #define FP(oo,fff) FP_(oo,fff), FP_MASK
355 /* Memory format instructions */
356 #define MEM_(oo) OP(oo)
357 #define MEM_MASK OP_MASK
358 #define MEM(oo) MEM_(oo), MEM_MASK
360 /* Memory/Func Code format instructions */
361 #define MFC_(oo,ffff) (OP(oo) | ((ffff) & 0xFFFF))
362 #define MFC_MASK (OP_MASK | 0xFFFF)
363 #define MFC(oo,ffff) MFC_(oo,ffff), MFC_MASK
365 /* Memory/Branch format instructions */
366 #define MBR_(oo,h) (OP(oo) | (((h) & 3) << 14))
367 #define MBR_MASK (OP_MASK | 0xC000)
368 #define MBR(oo,h) MBR_(oo,h), MBR_MASK
370 /* Operate format instructions. The OPRL variant specifies a
371 literal second argument. */
372 #define OPR_(oo,ff) (OP(oo) | (((ff) & 0x7F) << 5))
373 #define OPRL_(oo,ff) (OPR_((oo),(ff)) | 0x1000)
374 #define OPR_MASK (OP_MASK | 0x1FE0)
375 #define OPR(oo,ff) OPR_(oo,ff), OPR_MASK
376 #define OPRL(oo,ff) OPRL_(oo,ff), OPR_MASK
378 /* Generic PALcode format instructions */
379 #define PCD_(oo) OP(oo)
380 #define PCD_MASK OP_MASK
381 #define PCD(oo) PCD_(oo), PCD_MASK
383 /* Specific PALcode instructions */
384 #define SPCD_(oo,ffff) (OP(oo) | ((ffff) & 0x3FFFFFF))
385 #define SPCD_MASK 0xFFFFFFFF
386 #define SPCD(oo,ffff) SPCD_(oo,ffff), SPCD_MASK
388 /* Hardware memory (hw_{ld,st}) instructions */
389 #define EV4HWMEM_(oo,f) (OP(oo) | (((f) & 0xF) << 12))
390 #define EV4HWMEM_MASK (OP_MASK | 0xF000)
391 #define EV4HWMEM(oo,f) EV4HWMEM_(oo,f), EV4HWMEM_MASK
393 #define EV5HWMEM_(oo,f) (OP(oo) | (((f) & 0x3F) << 10))
394 #define EV5HWMEM_MASK (OP_MASK | 0xF800)
395 #define EV5HWMEM(oo,f) EV5HWMEM_(oo,f), EV5HWMEM_MASK
397 /* Common combinations of flags and arguments */
398 #define ALL AXP_OPCODE_ALL
399 #define EV4 AXP_OPCODE_EV4
400 #define EV5 AXP_OPCODE_EV5
401 #define EV56 AXP_OPCODE_EV56
402 #define EV5x EV5|EV56
404 #define ARG_NONE { 0 }
405 #define ARG_BRA { RA, BDISP }
406 #define ARG_FBRA { FA, BDISP }
407 #define ARG_FP { FA, FB, DFC1 }
408 #define ARG_FPZ1 { ZA, FB, DFC1 }
409 #define ARG_MEM { RA, MDISP, PRB }
410 #define ARG_FMEM { FA, MDISP, PRB }
411 #define ARG_OPR { RA, RB, DRC1 }
412 #define ARG_OPRL { RA, LIT, DRC1 }
413 #define ARG_OPRZ1 { ZA, RB, DRC1 }
414 #define ARG_OPRLZ1 { ZA, LIT, RC }
415 #define ARG_PCD { PALFN }
416 #define ARG_EV4HWMEM { RA, EV4HWDISP, PRB }
417 #define ARG_EV4HWMPR { RA, RBA, EV4HWINDEX }
418 #define ARG_EV5HWMEM { RA, EV5HWDISP, PRB }
423 The format of the opcode table is:
425 NAME OPCODE MASK { OPERANDS }
427 NAME is the name of the instruction.
429 OPCODE is the instruction opcode.
431 MASK is the opcode mask; this is used to tell the disassembler
432 which bits in the actual opcode must match OPCODE.
434 OPERANDS is the list of operands.
436 The preceding macros merge the text of the OPCODE and MASK fields.
438 The disassembler reads the table in order and prints the first
439 instruction which matches, so this table is sorted to put more
440 specific instructions before more general instructions.
442 Otherwise, it is sorted by major opcode and minor function code.
444 There are three classes of not-really-instructions in this table:
446 ALIAS is another name for another instruction. Some of
447 these come from the Architecture Handbook, some
448 come from the original gas opcode tables. In all
449 cases, the functionality of the opcode is unchanged.
451 PSEUDO a stylized code form endorsed by Chapter A.4 of the
452 Architecture Handbook.
454 EXTRA a stylized code form found in the original gas tables.
456 XXX: Can anyone shed light on the pal{19,1b,1d,1e,1f} opcodes?
457 XXX: Do we want to conditionally compile complete sets of the
458 PALcodes described in the Architecture Handbook?
461 const struct alpha_opcode alpha_opcodes[] = {
462 { "halt", SPCD(0x00,0x0000), ALL, ARG_NONE },
463 { "draina", SPCD(0x00,0x0002), ALL, ARG_NONE },
464 { "bpt", SPCD(0x00,0x0080), ALL, ARG_NONE },
465 { "callsys", SPCD(0x00,0x0083), ALL, ARG_NONE },
466 { "chmk", SPCD(0x00,0x0083), ALL, ARG_NONE },
467 { "imb", SPCD(0x00,0x0086), ALL, ARG_NONE },
468 { "call_pal", PCD(0x00), ALL, ARG_PCD },
469 { "pal", PCD(0x00), ALL, ARG_PCD }, /* alias */
471 { "lda", MEM(0x08), ALL, ARG_MEM },
472 { "ldah", MEM(0x09), ALL, ARG_MEM },
473 { "unop", MEM(0x0B), ALL, { ZA } }, /* pseudo */
474 { "ldq_u", MEM(0x0B), ALL, ARG_MEM },
475 { "stq_u", MEM(0x0F), ALL, ARG_MEM },
477 { "sextl", OPR(0x10,0x00), ALL, ARG_OPRZ1 }, /* pseudo */
478 { "sextl", OPRL(0x10,0x00), ALL, ARG_OPRLZ1 }, /* pseudo */
479 { "addl", OPR(0x10,0x00), ALL, ARG_OPR },
480 { "addl", OPRL(0x10,0x00), ALL, ARG_OPRL },
481 { "s4addl", OPR(0x10,0x02), ALL, ARG_OPR },
482 { "s4addl", OPRL(0x10,0x02), ALL, ARG_OPRL },
483 { "negl", OPR(0x10,0x09), ALL, ARG_OPRZ1 }, /* pseudo */
484 { "negl", OPRL(0x10,0x09), ALL, ARG_OPRLZ1 }, /* pseudo */
485 { "subl", OPR(0x10,0x09), ALL, ARG_OPR },
486 { "subl", OPRL(0x10,0x09), ALL, ARG_OPRL },
487 { "s4subl", OPR(0x10,0x0B), ALL, ARG_OPR },
488 { "s4subl", OPRL(0x10,0x0B), ALL, ARG_OPRL },
489 { "cmpbge", OPR(0x10,0x0F), ALL, ARG_OPR },
490 { "cmpbge", OPRL(0x10,0x0F), ALL, ARG_OPRL },
491 { "s8addl", OPR(0x10,0x12), ALL, ARG_OPR },
492 { "s8addl", OPRL(0x10,0x12), ALL, ARG_OPRL },
493 { "s8subl", OPR(0x10,0x1B), ALL, ARG_OPR },
494 { "s8subl", OPRL(0x10,0x1B), ALL, ARG_OPRL },
495 { "cmpult", OPR(0x10,0x1D), ALL, ARG_OPR },
496 { "cmpult", OPRL(0x10,0x1D), ALL, ARG_OPRL },
497 { "addq", OPR(0x10,0x20), ALL, ARG_OPR },
498 { "addq", OPRL(0x10,0x20), ALL, ARG_OPRL },
499 { "s4addq", OPR(0x10,0x22), ALL, ARG_OPR },
500 { "s4addq", OPRL(0x10,0x22), ALL, ARG_OPRL },
501 { "negq", OPR(0x10,0x29), ALL, ARG_OPRZ1 }, /* pseudo */
502 { "negq", OPRL(0x10,0x29), ALL, ARG_OPRLZ1 }, /* pseudo */
503 { "subq", OPR(0x10,0x29), ALL, ARG_OPR },
504 { "subq", OPRL(0x10,0x29), ALL, ARG_OPRL },
505 { "s4subq", OPR(0x10,0x2B), ALL, ARG_OPR },
506 { "s4subq", OPRL(0x10,0x2B), ALL, ARG_OPRL },
507 { "cmpeq", OPR(0x10,0x2D), ALL, ARG_OPR },
508 { "cmpeq", OPRL(0x10,0x2D), ALL, ARG_OPRL },
509 { "s8addq", OPR(0x10,0x32), ALL, ARG_OPR },
510 { "s8addq", OPRL(0x10,0x32), ALL, ARG_OPRL },
511 { "s8subq", OPR(0x10,0x3B), ALL, ARG_OPR },
512 { "s8subq", OPRL(0x10,0x3B), ALL, ARG_OPRL },
513 { "cmpule", OPR(0x10,0x3D), ALL, ARG_OPR },
514 { "cmpule", OPRL(0x10,0x3D), ALL, ARG_OPRL },
515 { "addl/v", OPR(0x10,0x40), ALL, ARG_OPR },
516 { "addl/v", OPRL(0x10,0x40), ALL, ARG_OPRL },
517 { "negl/v", OPR(0x10,0x49), ALL, ARG_OPRZ1 }, /* pseudo */
518 { "negl/v", OPRL(0x10,0x49), ALL, ARG_OPRLZ1 }, /* pseudo */
519 { "subl/v", OPR(0x10,0x49), ALL, ARG_OPR },
520 { "subl/v", OPRL(0x10,0x49), ALL, ARG_OPRL },
521 { "cmplt", OPR(0x10,0x4D), ALL, ARG_OPR },
522 { "cmplt", OPRL(0x10,0x4D), ALL, ARG_OPRL },
523 { "addq/v", OPR(0x10,0x60), ALL, ARG_OPR },
524 { "addq/v", OPRL(0x10,0x60), ALL, ARG_OPRL },
525 { "negq/v", OPR(0x10,0x69), ALL, ARG_OPRZ1 }, /* pseudo */
526 { "negq/v", OPRL(0x10,0x69), ALL, ARG_OPRLZ1 }, /* pseudo */
527 { "subq/v", OPR(0x10,0x69), ALL, ARG_OPR },
528 { "subq/v", OPRL(0x10,0x69), ALL, ARG_OPRL },
529 { "cmple", OPR(0x10,0x6D), ALL, ARG_OPR },
530 { "cmple", OPRL(0x10,0x6D), ALL, ARG_OPRL },
532 { "and", OPR(0x11,0x00), ALL, ARG_OPR },
533 { "and", OPRL(0x11,0x00), ALL, ARG_OPRL },
534 { "andnot", OPR(0x11,0x08), ALL, ARG_OPR }, /* alias */
535 { "andnot", OPRL(0x11,0x08), ALL, ARG_OPRL }, /* alias */
536 { "bic", OPR(0x11,0x08), ALL, ARG_OPR },
537 { "bic", OPRL(0x11,0x08), ALL, ARG_OPRL },
538 { "cmovlbs", OPR(0x11,0x14), ALL, ARG_OPR },
539 { "cmovlbs", OPRL(0x11,0x14), ALL, ARG_OPRL },
540 { "cmovlbc", OPR(0x11,0x16), ALL, ARG_OPR },
541 { "cmovlbc", OPRL(0x11,0x16), ALL, ARG_OPRL },
542 { "nop", OPR(0x11,0x20), ALL, { ZA, ZB, ZC } }, /* pseudo */
543 { "clr", OPR(0x11,0x20), ALL, { ZA, ZB, RC } }, /* pseudo */
544 { "mov", OPR(0x11,0x20), ALL, { ZA, RB, RC } }, /* pseudo */
545 { "mov", OPR(0x11,0x20), ALL, { RA, RBA, RC } }, /* pseudo */
546 { "mov", OPRL(0x11,0x20), ALL, { ZA, LIT, RC } }, /* pseudo */
547 { "or", OPR(0x11,0x20), ALL, ARG_OPR }, /* alias */
548 { "or", OPRL(0x11,0x20), ALL, ARG_OPRL }, /* alias */
549 { "bis", OPR(0x11,0x20), ALL, ARG_OPR },
550 { "bis", OPRL(0x11,0x20), ALL, ARG_OPRL },
551 { "cmoveq", OPR(0x11,0x24), ALL, ARG_OPR },
552 { "cmoveq", OPRL(0x11,0x24), ALL, ARG_OPRL },
553 { "cmovne", OPR(0x11,0x26), ALL, ARG_OPR },
554 { "cmovne", OPRL(0x11,0x26), ALL, ARG_OPRL },
555 { "not", OPR(0x11,0x28), ALL, ARG_OPRZ1 }, /* pseudo */
556 { "not", OPRL(0x11,0x28), ALL, ARG_OPRLZ1 }, /* pseudo */
557 { "ornot", OPR(0x11,0x28), ALL, ARG_OPR },
558 { "ornot", OPRL(0x11,0x28), ALL, ARG_OPRL },
559 { "xor", OPR(0x11,0x40), ALL, ARG_OPR },
560 { "xor", OPRL(0x11,0x40), ALL, ARG_OPRL },
561 { "cmovlt", OPR(0x11,0x44), ALL, ARG_OPR },
562 { "cmovlt", OPRL(0x11,0x44), ALL, ARG_OPRL },
563 { "cmovge", OPR(0x11,0x46), ALL, ARG_OPR },
564 { "cmovge", OPRL(0x11,0x46), ALL, ARG_OPRL },
565 { "eqv", OPR(0x11,0x48), ALL, ARG_OPR },
566 { "eqv", OPRL(0x11,0x48), ALL, ARG_OPRL },
567 { "xornot", OPR(0x11,0x48), ALL, ARG_OPR }, /* alias */
568 { "xornot", OPRL(0x11,0x48), ALL, ARG_OPRL }, /* alias */
569 { "amask", OPR(0x11,0x61), EV56, ARG_OPRZ1 }, /* ev56 */
570 { "amask", OPRL(0x11,0x61), EV56, ARG_OPRLZ1 }, /* ev56 */
571 { "cmovle", OPR(0x11,0x64), ALL, ARG_OPR },
572 { "cmovle", OPRL(0x11,0x64), ALL, ARG_OPRL },
573 { "cmovgt", OPR(0x11,0x66), ALL, ARG_OPR },
574 { "cmovgt", OPRL(0x11,0x66), ALL, ARG_OPRL },
575 { "implver", OPR(0x11,0x6C), ALL, ARG_OPRZ1 }, /* ev56 */
576 { "implver", OPRL(0x11,0x6C), ALL, ARG_OPRLZ1 }, /* ev56 */
578 { "mskbl", OPR(0x12,0x02), ALL, ARG_OPR },
579 { "mskbl", OPRL(0x12,0x02), ALL, ARG_OPRL },
580 { "extbl", OPR(0x12,0x06), ALL, ARG_OPR },
581 { "extbl", OPRL(0x12,0x06), ALL, ARG_OPRL },
582 { "insbl", OPR(0x12,0x0B), ALL, ARG_OPR },
583 { "insbl", OPRL(0x12,0x0B), ALL, ARG_OPRL },
584 { "mskwl", OPR(0x12,0x12), ALL, ARG_OPR },
585 { "mskwl", OPRL(0x12,0x12), ALL, ARG_OPRL },
586 { "extwl", OPR(0x12,0x16), ALL, ARG_OPR },
587 { "extwl", OPRL(0x12,0x16), ALL, ARG_OPRL },
588 { "inswl", OPR(0x12,0x1B), ALL, ARG_OPR },
589 { "inswl", OPRL(0x12,0x1B), ALL, ARG_OPRL },
590 { "mskll", OPR(0x12,0x22), ALL, ARG_OPR },
591 { "mskll", OPRL(0x12,0x22), ALL, ARG_OPRL },
592 { "extll", OPR(0x12,0x26), ALL, ARG_OPR },
593 { "extll", OPRL(0x12,0x26), ALL, ARG_OPRL },
594 { "insll", OPR(0x12,0x2B), ALL, ARG_OPR },
595 { "insll", OPRL(0x12,0x2B), ALL, ARG_OPRL },
596 { "zap", OPR(0x12,0x30), ALL, ARG_OPR },
597 { "zap", OPRL(0x12,0x30), ALL, ARG_OPRL },
598 { "zapnot", OPR(0x12,0x31), ALL, ARG_OPR },
599 { "zapnot", OPRL(0x12,0x31), ALL, ARG_OPRL },
600 { "mskql", OPR(0x12,0x32), ALL, ARG_OPR },
601 { "mskql", OPRL(0x12,0x32), ALL, ARG_OPRL },
602 { "srl", OPR(0x12,0x34), ALL, ARG_OPR },
603 { "srl", OPRL(0x12,0x34), ALL, ARG_OPRL },
604 { "extql", OPR(0x12,0x36), ALL, ARG_OPR },
605 { "extql", OPRL(0x12,0x36), ALL, ARG_OPRL },
606 { "sll", OPR(0x12,0x39), ALL, ARG_OPR },
607 { "sll", OPRL(0x12,0x39), ALL, ARG_OPRL },
608 { "insql", OPR(0x12,0x3B), ALL, ARG_OPR },
609 { "insql", OPRL(0x12,0x3B), ALL, ARG_OPRL },
610 { "sra", OPR(0x12,0x3C), ALL, ARG_OPR },
611 { "sra", OPRL(0x12,0x3C), ALL, ARG_OPRL },
612 { "mskwh", OPR(0x12,0x52), ALL, ARG_OPR },
613 { "mskwh", OPRL(0x12,0x52), ALL, ARG_OPRL },
614 { "inswh", OPR(0x12,0x57), ALL, ARG_OPR },
615 { "inswh", OPRL(0x12,0x57), ALL, ARG_OPRL },
616 { "extwh", OPR(0x12,0x5A), ALL, ARG_OPR },
617 { "extwh", OPRL(0x12,0x5A), ALL, ARG_OPRL },
618 { "msklh", OPR(0x12,0x62), ALL, ARG_OPR },
619 { "msklh", OPRL(0x12,0x62), ALL, ARG_OPRL },
620 { "inslh", OPR(0x12,0x67), ALL, ARG_OPR },
621 { "inslh", OPRL(0x12,0x67), ALL, ARG_OPRL },
622 { "extlh", OPR(0x12,0x6A), ALL, ARG_OPR },
623 { "extlh", OPRL(0x12,0x6A), ALL, ARG_OPRL },
624 { "mskqh", OPR(0x12,0x72), ALL, ARG_OPR },
625 { "mskqh", OPRL(0x12,0x72), ALL, ARG_OPRL },
626 { "insqh", OPR(0x12,0x77), ALL, ARG_OPR },
627 { "insqh", OPRL(0x12,0x77), ALL, ARG_OPRL },
628 { "extqh", OPR(0x12,0x7A), ALL, ARG_OPR },
629 { "extqh", OPRL(0x12,0x7A), ALL, ARG_OPRL },
631 { "mull", OPR(0x13,0x00), ALL, ARG_OPR },
632 { "mull", OPRL(0x13,0x00), ALL, ARG_OPRL },
633 { "mulq", OPR(0x13,0x20), ALL, ARG_OPR },
634 { "mulq", OPRL(0x13,0x20), ALL, ARG_OPRL },
635 { "umulh", OPR(0x13,0x30), ALL, ARG_OPR },
636 { "umulh", OPRL(0x13,0x30), ALL, ARG_OPRL },
637 { "mull/v", OPR(0x13,0x40), ALL, ARG_OPR },
638 { "mull/v", OPRL(0x13,0x40), ALL, ARG_OPRL },
639 { "mulq/v", OPR(0x13,0x60), ALL, ARG_OPR },
640 { "mulq/v", OPRL(0x13,0x60), ALL, ARG_OPRL },
642 { "addf/c", FP(0x15,0x000), ALL, ARG_FP },
643 { "subf/c", FP(0x15,0x001), ALL, ARG_FP },
644 { "mulf/c", FP(0x15,0x002), ALL, ARG_FP },
645 { "divf/c", FP(0x15,0x003), ALL, ARG_FP },
646 { "cvtdg/c", FP(0x15,0x01E), ALL, ARG_FPZ1 },
647 { "addg/c", FP(0x15,0x020), ALL, ARG_FP },
648 { "subg/c", FP(0x15,0x021), ALL, ARG_FP },
649 { "mulg/c", FP(0x15,0x022), ALL, ARG_FP },
650 { "divg/c", FP(0x15,0x023), ALL, ARG_FP },
651 { "cvtgf/c", FP(0x15,0x02C), ALL, ARG_FPZ1 },
652 { "cvtgd/c", FP(0x15,0x02D), ALL, ARG_FPZ1 },
653 { "cvtgq/c", FP(0x15,0x02F), ALL, ARG_FPZ1 },
654 { "cvtqf/c", FP(0x15,0x03C), ALL, ARG_FPZ1 },
655 { "cvtqg/c", FP(0x15,0x03E), ALL, ARG_FPZ1 },
656 { "addf", FP(0x15,0x080), ALL, ARG_FP },
657 { "negf", FP(0x15,0x081), ALL, ARG_FPZ1 }, /* pseudo */
658 { "subf", FP(0x15,0x081), ALL, ARG_FP },
659 { "mulf", FP(0x15,0x082), ALL, ARG_FP },
660 { "divf", FP(0x15,0x083), ALL, ARG_FP },
661 { "cvtdg", FP(0x15,0x09E), ALL, ARG_FPZ1 },
662 { "addg", FP(0x15,0x0A0), ALL, ARG_FP },
663 { "negg", FP(0x15,0x0A1), ALL, ARG_FPZ1 }, /* pseudo */
664 { "subg", FP(0x15,0x0A1), ALL, ARG_FP },
665 { "mulg", FP(0x15,0x0A2), ALL, ARG_FP },
666 { "divg", FP(0x15,0x0A3), ALL, ARG_FP },
667 { "cmpgeq", FP(0x15,0x0A5), ALL, ARG_FP },
668 { "cmpglt", FP(0x15,0x0A6), ALL, ARG_FP },
669 { "cmpgle", FP(0x15,0x0A7), ALL, ARG_FP },
670 { "cvtgf", FP(0x15,0x0AC), ALL, ARG_FPZ1 },
671 { "cvtgd", FP(0x15,0x0AD), ALL, ARG_FPZ1 },
672 { "cvtgq", FP(0x15,0x0AF), ALL, ARG_FPZ1 },
673 { "cvtqf", FP(0x15,0x0BC), ALL, ARG_FPZ1 },
674 { "cvtqg", FP(0x15,0x0BE), ALL, ARG_FPZ1 },
675 { "addf/uc", FP(0x15,0x100), ALL, ARG_FP },
676 { "subf/uc", FP(0x15,0x101), ALL, ARG_FP },
677 { "mulf/uc", FP(0x15,0x102), ALL, ARG_FP },
678 { "divf/uc", FP(0x15,0x103), ALL, ARG_FP },
679 { "cvtdg/uc", FP(0x15,0x11E), ALL, ARG_FPZ1 },
680 { "addg/uc", FP(0x15,0x120), ALL, ARG_FP },
681 { "subg/uc", FP(0x15,0x121), ALL, ARG_FP },
682 { "mulg/uc", FP(0x15,0x122), ALL, ARG_FP },
683 { "divg/uc", FP(0x15,0x123), ALL, ARG_FP },
684 { "cvtgf/uc", FP(0x15,0x12C), ALL, ARG_FPZ1 },
685 { "cvtgd/uc", FP(0x15,0x12D), ALL, ARG_FPZ1 },
686 { "cvtgq/vc", FP(0x15,0x12F), ALL, ARG_FPZ1 },
687 { "addf/u", FP(0x15,0x180), ALL, ARG_FP },
688 { "subf/u", FP(0x15,0x181), ALL, ARG_FP },
689 { "mulf/u", FP(0x15,0x182), ALL, ARG_FP },
690 { "divf/u", FP(0x15,0x183), ALL, ARG_FP },
691 { "cvtdg/u", FP(0x15,0x19E), ALL, ARG_FPZ1 },
692 { "addg/u", FP(0x15,0x1A0), ALL, ARG_FP },
693 { "subg/u", FP(0x15,0x1A1), ALL, ARG_FP },
694 { "mulg/u", FP(0x15,0x1A2), ALL, ARG_FP },
695 { "divg/u", FP(0x15,0x1A3), ALL, ARG_FP },
696 { "cvtgf/u", FP(0x15,0x1AC), ALL, ARG_FPZ1 },
697 { "cvtgd/u", FP(0x15,0x1AD), ALL, ARG_FPZ1 },
698 { "cvtgq/v", FP(0x15,0x1AF), ALL, ARG_FPZ1 },
699 { "addf/sc", FP(0x15,0x400), ALL, ARG_FP },
700 { "subf/sc", FP(0x15,0x401), ALL, ARG_FP },
701 { "mulf/sc", FP(0x15,0x402), ALL, ARG_FP },
702 { "divf/sc", FP(0x15,0x403), ALL, ARG_FP },
703 { "cvtdg/sc", FP(0x15,0x41E), ALL, ARG_FPZ1 },
704 { "addg/sc", FP(0x15,0x420), ALL, ARG_FP },
705 { "subg/sc", FP(0x15,0x421), ALL, ARG_FP },
706 { "mulg/sc", FP(0x15,0x422), ALL, ARG_FP },
707 { "divg/sc", FP(0x15,0x423), ALL, ARG_FP },
708 { "cvtgf/sc", FP(0x15,0x42C), ALL, ARG_FPZ1 },
709 { "cvtgd/sc", FP(0x15,0x42D), ALL, ARG_FPZ1 },
710 { "cvtgq/sc", FP(0x15,0x42F), ALL, ARG_FPZ1 },
711 { "addf/s", FP(0x15,0x480), ALL, ARG_FP },
712 { "negf/s", FP(0x15,0x481), ALL, ARG_FPZ1 }, /* pseudo */
713 { "subf/s", FP(0x15,0x481), ALL, ARG_FP },
714 { "mulf/s", FP(0x15,0x482), ALL, ARG_FP },
715 { "divf/s", FP(0x15,0x483), ALL, ARG_FP },
716 { "cvtdg/s", FP(0x15,0x49E), ALL, ARG_FPZ1 },
717 { "addg/s", FP(0x15,0x4A0), ALL, ARG_FP },
718 { "negg/s", FP(0x15,0x4A1), ALL, ARG_FPZ1 }, /* pseudo */
719 { "subg/s", FP(0x15,0x4A1), ALL, ARG_FP },
720 { "mulg/s", FP(0x15,0x4A2), ALL, ARG_FP },
721 { "divg/s", FP(0x15,0x4A3), ALL, ARG_FP },
722 { "cmpgeq/s", FP(0x15,0x4A5), ALL, ARG_FP },
723 { "cmpglt/s", FP(0x15,0x4A6), ALL, ARG_FP },
724 { "cmpgle/s", FP(0x15,0x4A7), ALL, ARG_FP },
725 { "cvtgf/s", FP(0x15,0x4AC), ALL, ARG_FPZ1 },
726 { "cvtgd/s", FP(0x15,0x4AD), ALL, ARG_FPZ1 },
727 { "cvtgq/s", FP(0x15,0x4AF), ALL, ARG_FPZ1 },
728 { "addf/suc", FP(0x15,0x500), ALL, ARG_FP },
729 { "subf/suc", FP(0x15,0x501), ALL, ARG_FP },
730 { "mulf/suc", FP(0x15,0x502), ALL, ARG_FP },
731 { "divf/suc", FP(0x15,0x503), ALL, ARG_FP },
732 { "cvtdg/suc", FP(0x15,0x51E), ALL, ARG_FPZ1 },
733 { "addg/suc", FP(0x15,0x520), ALL, ARG_FP },
734 { "subg/suc", FP(0x15,0x521), ALL, ARG_FP },
735 { "mulg/suc", FP(0x15,0x522), ALL, ARG_FP },
736 { "divg/suc", FP(0x15,0x523), ALL, ARG_FP },
737 { "cvtgf/suc", FP(0x15,0x52C), ALL, ARG_FPZ1 },
738 { "cvtgd/suc", FP(0x15,0x52D), ALL, ARG_FPZ1 },
739 { "cvtgq/svc", FP(0x15,0x52F), ALL, ARG_FPZ1 },
740 { "addf/su", FP(0x15,0x580), ALL, ARG_FP },
741 { "subf/su", FP(0x15,0x581), ALL, ARG_FP },
742 { "mulf/su", FP(0x15,0x582), ALL, ARG_FP },
743 { "divf/su", FP(0x15,0x583), ALL, ARG_FP },
744 { "cvtdg/su", FP(0x15,0x59E), ALL, ARG_FPZ1 },
745 { "addg/su", FP(0x15,0x5A0), ALL, ARG_FP },
746 { "subg/su", FP(0x15,0x5A1), ALL, ARG_FP },
747 { "mulg/su", FP(0x15,0x5A2), ALL, ARG_FP },
748 { "divg/su", FP(0x15,0x5A3), ALL, ARG_FP },
749 { "cvtgf/su", FP(0x15,0x5AC), ALL, ARG_FPZ1 },
750 { "cvtgd/su", FP(0x15,0x5AD), ALL, ARG_FPZ1 },
751 { "cvtgq/sv", FP(0x15,0x5AF), ALL, ARG_FPZ1 },
753 { "adds/c", FP(0x16,0x000), ALL, ARG_FP },
754 { "subs/c", FP(0x16,0x001), ALL, ARG_FP },
755 { "muls/c", FP(0x16,0x002), ALL, ARG_FP },
756 { "divs/c", FP(0x16,0x003), ALL, ARG_FP },
757 { "addt/c", FP(0x16,0x020), ALL, ARG_FP },
758 { "subt/c", FP(0x16,0x021), ALL, ARG_FP },
759 { "mult/c", FP(0x16,0x022), ALL, ARG_FP },
760 { "divt/c", FP(0x16,0x023), ALL, ARG_FP },
761 { "cvtts/c", FP(0x16,0x02C), ALL, ARG_FPZ1 },
762 { "cvttq/c", FP(0x16,0x02F), ALL, ARG_FPZ1 },
763 { "cvtqs/c", FP(0x16,0x03C), ALL, ARG_FPZ1 },
764 { "cvtqt/c", FP(0x16,0x03E), ALL, ARG_FPZ1 },
765 { "adds/m", FP(0x16,0x040), ALL, ARG_FP },
766 { "subs/m", FP(0x16,0x041), ALL, ARG_FP },
767 { "muls/m", FP(0x16,0x042), ALL, ARG_FP },
768 { "divs/m", FP(0x16,0x043), ALL, ARG_FP },
769 { "addt/m", FP(0x16,0x060), ALL, ARG_FP },
770 { "subt/m", FP(0x16,0x061), ALL, ARG_FP },
771 { "mult/m", FP(0x16,0x062), ALL, ARG_FP },
772 { "divt/m", FP(0x16,0x063), ALL, ARG_FP },
773 { "cvtts/m", FP(0x16,0x06C), ALL, ARG_FPZ1 },
774 { "cvttq/m", FP(0x16,0x06F), ALL, ARG_FPZ1 },
775 { "cvtqs/m", FP(0x16,0x07C), ALL, ARG_FPZ1 },
776 { "cvtqt/m", FP(0x16,0x07E), ALL, ARG_FPZ1 },
777 { "adds", FP(0x16,0x080), ALL, ARG_FP },
778 { "negs", FP(0x16,0x081), ALL, ARG_FPZ1 }, /* pseudo */
779 { "subs", FP(0x16,0x081), ALL, ARG_FP },
780 { "muls", FP(0x16,0x082), ALL, ARG_FP },
781 { "divs", FP(0x16,0x083), ALL, ARG_FP },
782 { "addt", FP(0x16,0x0A0), ALL, ARG_FP },
783 { "negt", FP(0x16,0x0A1), ALL, ARG_FPZ1 }, /* pseudo */
784 { "subt", FP(0x16,0x0A1), ALL, ARG_FP },
785 { "mult", FP(0x16,0x0A2), ALL, ARG_FP },
786 { "divt", FP(0x16,0x0A3), ALL, ARG_FP },
787 { "cmptun", FP(0x16,0x0A4), ALL, ARG_FP },
788 { "cmpteq", FP(0x16,0x0A5), ALL, ARG_FP },
789 { "cmptlt", FP(0x16,0x0A6), ALL, ARG_FP },
790 { "cmptle", FP(0x16,0x0A7), ALL, ARG_FP },
791 { "cvtts", FP(0x16,0x0AC), ALL, ARG_FPZ1 },
792 { "cvttq", FP(0x16,0x0AF), ALL, ARG_FPZ1 },
793 { "cvtqs", FP(0x16,0x0BC), ALL, ARG_FPZ1 },
794 { "cvtqt", FP(0x16,0x0BE), ALL, ARG_FPZ1 },
795 { "adds/d", FP(0x16,0x0C0), ALL, ARG_FP },
796 { "subs/d", FP(0x16,0x0C1), ALL, ARG_FP },
797 { "muls/d", FP(0x16,0x0C2), ALL, ARG_FP },
798 { "divs/d", FP(0x16,0x0C3), ALL, ARG_FP },
799 { "addt/d", FP(0x16,0x0E0), ALL, ARG_FP },
800 { "subt/d", FP(0x16,0x0E1), ALL, ARG_FP },
801 { "mult/d", FP(0x16,0x0E2), ALL, ARG_FP },
802 { "divt/d", FP(0x16,0x0E3), ALL, ARG_FP },
803 { "cvtts/d", FP(0x16,0x0EC), ALL, ARG_FPZ1 },
804 { "cvttq/d", FP(0x16,0x0EF), ALL, ARG_FPZ1 },
805 { "cvtqs/d", FP(0x16,0x0FC), ALL, ARG_FPZ1 },
806 { "cvtqt/d", FP(0x16,0x0FE), ALL, ARG_FPZ1 },
807 { "adds/uc", FP(0x16,0x100), ALL, ARG_FP },
808 { "subs/uc", FP(0x16,0x101), ALL, ARG_FP },
809 { "muls/uc", FP(0x16,0x102), ALL, ARG_FP },
810 { "divs/uc", FP(0x16,0x103), ALL, ARG_FP },
811 { "addt/uc", FP(0x16,0x120), ALL, ARG_FP },
812 { "subt/uc", FP(0x16,0x121), ALL, ARG_FP },
813 { "mult/uc", FP(0x16,0x122), ALL, ARG_FP },
814 { "divt/uc", FP(0x16,0x123), ALL, ARG_FP },
815 { "cvtts/uc", FP(0x16,0x12C), ALL, ARG_FPZ1 },
816 { "cvttq/vc", FP(0x16,0x12F), ALL, ARG_FPZ1 },
817 { "adds/um", FP(0x16,0x140), ALL, ARG_FP },
818 { "subs/um", FP(0x16,0x141), ALL, ARG_FP },
819 { "muls/um", FP(0x16,0x142), ALL, ARG_FP },
820 { "divs/um", FP(0x16,0x143), ALL, ARG_FP },
821 { "addt/um", FP(0x16,0x160), ALL, ARG_FP },
822 { "subt/um", FP(0x16,0x161), ALL, ARG_FP },
823 { "mult/um", FP(0x16,0x162), ALL, ARG_FP },
824 { "divt/um", FP(0x16,0x163), ALL, ARG_FP },
825 { "cvtts/um", FP(0x16,0x16C), ALL, ARG_FPZ1 },
826 { "cvttq/um", FP(0x16,0x16F), ALL, ARG_FPZ1 },
827 { "cvtqs/um", FP(0x16,0x17C), ALL, ARG_FPZ1 },
828 { "adds/u", FP(0x16,0x180), ALL, ARG_FP },
829 { "subs/u", FP(0x16,0x181), ALL, ARG_FP },
830 { "muls/u", FP(0x16,0x182), ALL, ARG_FP },
831 { "divs/u", FP(0x16,0x183), ALL, ARG_FP },
832 { "addt/u", FP(0x16,0x1A0), ALL, ARG_FP },
833 { "subt/u", FP(0x16,0x1A1), ALL, ARG_FP },
834 { "mult/u", FP(0x16,0x1A2), ALL, ARG_FP },
835 { "divt/u", FP(0x16,0x1A3), ALL, ARG_FP },
836 { "cvtts/u", FP(0x16,0x1AC), ALL, ARG_FPZ1 },
837 { "cvttq/v", FP(0x16,0x1AF), ALL, ARG_FPZ1 },
838 { "adds/ud", FP(0x16,0x1C0), ALL, ARG_FP },
839 { "subs/ud", FP(0x16,0x1C1), ALL, ARG_FP },
840 { "muls/ud", FP(0x16,0x1C2), ALL, ARG_FP },
841 { "divs/ud", FP(0x16,0x1C3), ALL, ARG_FP },
842 { "addt/ud", FP(0x16,0x1E0), ALL, ARG_FP },
843 { "subt/ud", FP(0x16,0x1E1), ALL, ARG_FP },
844 { "mult/ud", FP(0x16,0x1E2), ALL, ARG_FP },
845 { "divt/ud", FP(0x16,0x1E3), ALL, ARG_FP },
846 { "cvtts/ud", FP(0x16,0x1EC), ALL, ARG_FPZ1 },
847 { "cvttq/ud", FP(0x16,0x1EF), ALL, ARG_FPZ1 },
848 { "cvtst", FP(0x16,0x2AC), ALL, ARG_FPZ1 },
849 { "adds/suc", FP(0x16,0x500), ALL, ARG_FP },
850 { "subs/suc", FP(0x16,0x501), ALL, ARG_FP },
851 { "muls/suc", FP(0x16,0x502), ALL, ARG_FP },
852 { "divs/suc", FP(0x16,0x503), ALL, ARG_FP },
853 { "addt/suc", FP(0x16,0x520), ALL, ARG_FP },
854 { "subt/suc", FP(0x16,0x521), ALL, ARG_FP },
855 { "mult/suc", FP(0x16,0x522), ALL, ARG_FP },
856 { "divt/suc", FP(0x16,0x523), ALL, ARG_FP },
857 { "cvtts/suc", FP(0x16,0x52C), ALL, ARG_FPZ1 },
858 { "cvttq/svc", FP(0x16,0x52F), ALL, ARG_FPZ1 },
859 { "adds/sum", FP(0x16,0x540), ALL, ARG_FP },
860 { "subs/sum", FP(0x16,0x541), ALL, ARG_FP },
861 { "muls/sum", FP(0x16,0x542), ALL, ARG_FP },
862 { "divs/sum", FP(0x16,0x543), ALL, ARG_FP },
863 { "addt/sum", FP(0x16,0x560), ALL, ARG_FP },
864 { "subt/sum", FP(0x16,0x561), ALL, ARG_FP },
865 { "mult/sum", FP(0x16,0x562), ALL, ARG_FP },
866 { "divt/sum", FP(0x16,0x563), ALL, ARG_FP },
867 { "cvtts/sum", FP(0x16,0x56C), ALL, ARG_FPZ1 },
868 { "cvttq/sum", FP(0x16,0x56F), ALL, ARG_FPZ1 },
869 { "cvtqs/sum", FP(0x16,0x57C), ALL, ARG_FPZ1 },
870 { "adds/su", FP(0x16,0x580), ALL, ARG_FP },
871 { "negs/su", FP(0x16,0x581), ALL, ARG_FPZ1 }, /* pseudo */
872 { "subs/su", FP(0x16,0x581), ALL, ARG_FP },
873 { "muls/su", FP(0x16,0x582), ALL, ARG_FP },
874 { "divs/su", FP(0x16,0x583), ALL, ARG_FP },
875 { "addt/su", FP(0x16,0x5A0), ALL, ARG_FP },
876 { "negt/su", FP(0x16,0x5A1), ALL, ARG_FPZ1 }, /* pseudo */
877 { "subt/su", FP(0x16,0x5A1), ALL, ARG_FP },
878 { "mult/su", FP(0x16,0x5A2), ALL, ARG_FP },
879 { "divt/su", FP(0x16,0x5A3), ALL, ARG_FP },
880 { "cmptun/su", FP(0x16,0x5A4), ALL, ARG_FP },
881 { "cmpteq/su", FP(0x16,0x5A5), ALL, ARG_FP },
882 { "cmptlt/su", FP(0x16,0x5A6), ALL, ARG_FP },
883 { "cmptle/su", FP(0x16,0x5A7), ALL, ARG_FP },
884 { "cvtts/su", FP(0x16,0x5AC), ALL, ARG_FPZ1 },
885 { "cvttq/sv", FP(0x16,0x5AF), ALL, ARG_FPZ1 },
886 { "adds/sud", FP(0x16,0x5C0), ALL, ARG_FP },
887 { "subs/sud", FP(0x16,0x5C1), ALL, ARG_FP },
888 { "muls/sud", FP(0x16,0x5C2), ALL, ARG_FP },
889 { "divs/sud", FP(0x16,0x5C3), ALL, ARG_FP },
890 { "addt/sud", FP(0x16,0x5E0), ALL, ARG_FP },
891 { "subt/sud", FP(0x16,0x5E1), ALL, ARG_FP },
892 { "mult/sud", FP(0x16,0x5E2), ALL, ARG_FP },
893 { "divt/sud", FP(0x16,0x5E3), ALL, ARG_FP },
894 { "cvtts/sud", FP(0x16,0x5EC), ALL, ARG_FPZ1 },
895 { "cvttq/sud", FP(0x16,0x5EF), ALL, ARG_FPZ1 },
896 { "cvtst/s", FP(0x16,0x6AC), ALL, ARG_FPZ1 },
897 { "adds/suic", FP(0x16,0x700), ALL, ARG_FP },
898 { "subs/suic", FP(0x16,0x701), ALL, ARG_FP },
899 { "muls/suic", FP(0x16,0x702), ALL, ARG_FP },
900 { "divs/suic", FP(0x16,0x703), ALL, ARG_FP },
901 { "addt/suic", FP(0x16,0x720), ALL, ARG_FP },
902 { "subt/suic", FP(0x16,0x721), ALL, ARG_FP },
903 { "mult/suic", FP(0x16,0x722), ALL, ARG_FP },
904 { "divt/suic", FP(0x16,0x723), ALL, ARG_FP },
905 { "cvtts/suic", FP(0x16,0x72C), ALL, ARG_FPZ1 },
906 { "cvttq/svic", FP(0x16,0x72F), ALL, ARG_FPZ1 },
907 { "cvtqs/suic", FP(0x16,0x73C), ALL, ARG_FPZ1 },
908 { "cvtqt/suic", FP(0x16,0x73E), ALL, ARG_FPZ1 },
909 { "adds/suim", FP(0x16,0x740), ALL, ARG_FP },
910 { "subs/suim", FP(0x16,0x741), ALL, ARG_FP },
911 { "muls/suim", FP(0x16,0x742), ALL, ARG_FP },
912 { "divs/suim", FP(0x16,0x743), ALL, ARG_FP },
913 { "addt/suim", FP(0x16,0x760), ALL, ARG_FP },
914 { "subt/suim", FP(0x16,0x761), ALL, ARG_FP },
915 { "mult/suim", FP(0x16,0x762), ALL, ARG_FP },
916 { "divt/suim", FP(0x16,0x763), ALL, ARG_FP },
917 { "cvtts/suim", FP(0x16,0x76C), ALL, ARG_FPZ1 },
918 { "cvttq/suim", FP(0x16,0x76F), ALL, ARG_FPZ1 },
919 { "cvtqs/suim", FP(0x16,0x77C), ALL, ARG_FPZ1 },
920 { "cvtqt/suim", FP(0x16,0x77E), ALL, ARG_FPZ1 },
921 { "adds/sui", FP(0x16,0x780), ALL, ARG_FP },
922 { "negs/sui", FP(0x16,0x781), ALL, ARG_FPZ1 }, /* pseudo */
923 { "subs/sui", FP(0x16,0x781), ALL, ARG_FP },
924 { "muls/sui", FP(0x16,0x782), ALL, ARG_FP },
925 { "divs/sui", FP(0x16,0x783), ALL, ARG_FP },
926 { "addt/sui", FP(0x16,0x7A0), ALL, ARG_FP },
927 { "negt/sui", FP(0x16,0x7A1), ALL, ARG_FPZ1 }, /* pseudo */
928 { "subt/sui", FP(0x16,0x7A1), ALL, ARG_FP },
929 { "mult/sui", FP(0x16,0x7A2), ALL, ARG_FP },
930 { "divt/sui", FP(0x16,0x7A3), ALL, ARG_FP },
931 { "cvtts/sui", FP(0x16,0x7AC), ALL, ARG_FPZ1 },
932 { "cvttq/svi", FP(0x16,0x7AF), ALL, ARG_FPZ1 },
933 { "cvtqs/sui", FP(0x16,0x7BC), ALL, ARG_FPZ1 },
934 { "cvtqt/sui", FP(0x16,0x7BE), ALL, ARG_FPZ1 },
935 { "adds/suid", FP(0x16,0x7C0), ALL, ARG_FP },
936 { "subs/suid", FP(0x16,0x7C1), ALL, ARG_FP },
937 { "muls/suid", FP(0x16,0x7C2), ALL, ARG_FP },
938 { "divs/suid", FP(0x16,0x7C3), ALL, ARG_FP },
939 { "addt/suid", FP(0x16,0x7E0), ALL, ARG_FP },
940 { "subt/suid", FP(0x16,0x7E1), ALL, ARG_FP },
941 { "mult/suid", FP(0x16,0x7E2), ALL, ARG_FP },
942 { "divt/suid", FP(0x16,0x7E3), ALL, ARG_FP },
943 { "cvtts/suid", FP(0x16,0x7EC), ALL, ARG_FPZ1 },
944 { "cvttq/suid", FP(0x16,0x7EF), ALL, ARG_FPZ1 },
945 { "cvtqs/suid", FP(0x16,0x7FC), ALL, ARG_FPZ1 },
946 { "cvtqt/suid", FP(0x16,0x7FE), ALL, ARG_FPZ1 },
948 { "cvtlq", FP(0x17,0x010), ALL, ARG_FPZ1 },
949 { "fnop", FP(0x17,0x020), ALL, { ZA, ZB, ZC } }, /* pseudo */
950 { "fclr", FP(0x17,0x020), ALL, { ZA, ZB, FC } }, /* pseudo */
951 { "fabs", FP(0x17,0x020), ALL, ARG_FPZ1 }, /* pseudo */
952 { "fmov", FP(0x17,0x020), ALL, { FA, RBA, FC } }, /* pseudo */
953 { "cpys", FP(0x17,0x020), ALL, ARG_FP },
954 { "fneg", FP(0x17,0x021), ALL, { FA, RBA, FC } }, /* pseudo */
955 { "cpysn", FP(0x17,0x021), ALL, ARG_FP },
956 { "cpyse", FP(0x17,0x022), ALL, ARG_FP },
957 { "mt_fpcr", FP(0x17,0x024), ALL, { FA, RBA, RCA } },
958 { "mf_fpcr", FP(0x17,0x025), ALL, { FA, RBA, RCA } },
959 { "fcmoveq", FP(0x17,0x02A), ALL, ARG_FP },
960 { "fcmovne", FP(0x17,0x02B), ALL, ARG_FP },
961 { "fcmovlt", FP(0x17,0x02C), ALL, ARG_FP },
962 { "fcmovge", FP(0x17,0x02D), ALL, ARG_FP },
963 { "fcmovle", FP(0x17,0x02E), ALL, ARG_FP },
964 { "fcmovgt", FP(0x17,0x02F), ALL, ARG_FP },
965 { "cvtql", FP(0x17,0x030), ALL, ARG_FPZ1 },
966 { "cvtql/v", FP(0x17,0x130), ALL, ARG_FPZ1 },
967 { "cvtql/sv", FP(0x17,0x530), ALL, ARG_FPZ1 },
969 { "trapb", MFC(0x18,0x0000), ALL, ARG_NONE },
970 { "draint", MFC(0x18,0x0000), ALL, ARG_NONE }, /* alias */
971 { "excb", MFC(0x18,0x0400), ALL, ARG_NONE },
972 { "mb", MFC(0x18,0x4000), ALL, ARG_NONE },
973 { "wmb", MFC(0x18,0x4400), ALL, ARG_NONE },
974 { "fetch", MFC(0x18,0x8000), ALL, { MDISP, RB } },
975 { "fetch_m", MFC(0x18,0xA000), ALL, { MDISP, RB } },
976 { "rpcc", MFC(0x18,0xC000), ALL, { RA } },
977 { "rc", MFC(0x18,0xE000), ALL, { RA } },
978 { "rs", MFC(0x18,0xF000), ALL, { RA } },
980 { "hw_mfpr", OPR(0x19,0x00), EV4, { RA, RBA, EV4EXTHWINDEX } },
981 { "hw_mfpr", OP(0x19), OP_MASK, EV5x, { RA, RBA, EV5HWINDEX } },
982 { "hw_mfpr/i", OPR(0x19,0x01), EV4, ARG_EV4HWMPR },
983 { "hw_mfpr/a", OPR(0x19,0x02), EV4, ARG_EV4HWMPR },
984 { "hw_mfpr/ai", OPR(0x19,0x03), EV4, ARG_EV4HWMPR },
985 { "hw_mfpr/p", OPR(0x19,0x04), EV4, ARG_EV4HWMPR },
986 { "hw_mfpr/pi", OPR(0x19,0x05), EV4, ARG_EV4HWMPR },
987 { "hw_mfpr/pa", OPR(0x19,0x06), EV4, ARG_EV4HWMPR },
988 { "hw_mfpr/pai", OPR(0x19,0x07), EV4, ARG_EV4HWMPR },
989 { "pal19", PCD(0x19), ALL, ARG_PCD },
991 { "jmp", MBR(0x1A,0), ALL, { RA, CPRB, JMPHINT } },
992 { "jsr", MBR(0x1A,1), ALL, { RA, CPRB, JMPHINT } },
993 { "ret", MBR(0x1A,2), ALL, { RA, CPRB, RETHINT } },
994 { "jcr", MBR(0x1A,3), ALL, { RA, CPRB, RETHINT } }, /* alias */
995 { "jsr_coroutine", MBR(0x1A,3), ALL, { RA, CPRB, RETHINT } },
997 { "hw_ldl", EV4HWMEM(0x1B,0x0), EV4, ARG_EV4HWMEM },
998 { "hw_ldl", EV5HWMEM(0x1B,0x00), EV5x, ARG_EV5HWMEM },
999 { "hw_ldl/a", EV4HWMEM(0x1B,0x4), EV4, ARG_EV4HWMEM },
1000 { "hw_ldl/a", EV5HWMEM(0x1B,0x10), EV5x, ARG_EV5HWMEM },
1001 { "hw_ldl/al", EV5HWMEM(0x1B,0x11), EV5x, ARG_EV5HWMEM },
1002 { "hw_ldl/ar", EV4HWMEM(0x1B,0x6), EV4, ARG_EV4HWMEM },
1003 { "hw_ldl/av", EV5HWMEM(0x1B,0x12), EV5x, ARG_EV5HWMEM },
1004 { "hw_ldl/avl", EV5HWMEM(0x1B,0x13), EV5x, ARG_EV5HWMEM },
1005 { "hw_ldl/aw", EV5HWMEM(0x1B,0x18), EV5x, ARG_EV5HWMEM },
1006 { "hw_ldl/awl", EV5HWMEM(0x1B,0x19), EV5x, ARG_EV5HWMEM },
1007 { "hw_ldl/awv", EV5HWMEM(0x1B,0x1a), EV5x, ARG_EV5HWMEM },
1008 { "hw_ldl/awvl", EV5HWMEM(0x1B,0x1b), EV5x, ARG_EV5HWMEM },
1009 { "hw_ldl/l", EV5HWMEM(0x1B,0x01), EV5x, ARG_EV5HWMEM },
1010 { "hw_ldl/p", EV4HWMEM(0x1B,0x8), EV4, ARG_EV4HWMEM },
1011 { "hw_ldl/p", EV5HWMEM(0x1B,0x20), EV5x, ARG_EV5HWMEM },
1012 { "hw_ldl/pa", EV4HWMEM(0x1B,0xC), EV4, ARG_EV4HWMEM },
1013 { "hw_ldl/pa", EV5HWMEM(0x1B,0x30), EV5x, ARG_EV5HWMEM },
1014 { "hw_ldl/pal", EV5HWMEM(0x1B,0x31), EV5x, ARG_EV5HWMEM },
1015 { "hw_ldl/par", EV4HWMEM(0x1B,0xE), EV4, ARG_EV4HWMEM },
1016 { "hw_ldl/pav", EV5HWMEM(0x1B,0x32), EV5x, ARG_EV5HWMEM },
1017 { "hw_ldl/pavl", EV5HWMEM(0x1B,0x33), EV5x, ARG_EV5HWMEM },
1018 { "hw_ldl/paw", EV5HWMEM(0x1B,0x38), EV5x, ARG_EV5HWMEM },
1019 { "hw_ldl/pawl", EV5HWMEM(0x1B,0x39), EV5x, ARG_EV5HWMEM },
1020 { "hw_ldl/pawv", EV5HWMEM(0x1B,0x3a), EV5x, ARG_EV5HWMEM },
1021 { "hw_ldl/pawvl", EV5HWMEM(0x1B,0x3b), EV5x, ARG_EV5HWMEM },
1022 { "hw_ldl/pl", EV5HWMEM(0x1B,0x21), EV5x, ARG_EV5HWMEM },
1023 { "hw_ldl/pr", EV4HWMEM(0x1B,0xA), EV4, ARG_EV4HWMEM },
1024 { "hw_ldl/pv", EV5HWMEM(0x1B,0x22), EV5x, ARG_EV5HWMEM },
1025 { "hw_ldl/pvl", EV5HWMEM(0x1B,0x23), EV5x, ARG_EV5HWMEM },
1026 { "hw_ldl/pw", EV5HWMEM(0x1B,0x28), EV5x, ARG_EV5HWMEM },
1027 { "hw_ldl/pwl", EV5HWMEM(0x1B,0x29), EV5x, ARG_EV5HWMEM },
1028 { "hw_ldl/pwv", EV5HWMEM(0x1B,0x2a), EV5x, ARG_EV5HWMEM },
1029 { "hw_ldl/pwvl", EV5HWMEM(0x1B,0x2b), EV5x, ARG_EV5HWMEM },
1030 { "hw_ldl/r", EV4HWMEM(0x1B,0x2), EV4, ARG_EV4HWMEM },
1031 { "hw_ldl/v", EV5HWMEM(0x1B,0x02), EV5x, ARG_EV5HWMEM },
1032 { "hw_ldl/vl", EV5HWMEM(0x1B,0x03), EV5x, ARG_EV5HWMEM },
1033 { "hw_ldl/w", EV5HWMEM(0x1B,0x08), EV5x, ARG_EV5HWMEM },
1034 { "hw_ldl/wl", EV5HWMEM(0x1B,0x09), EV5x, ARG_EV5HWMEM },
1035 { "hw_ldl/wv", EV5HWMEM(0x1B,0x0a), EV5x, ARG_EV5HWMEM },
1036 { "hw_ldl/wvl", EV5HWMEM(0x1B,0x0b), EV5x, ARG_EV5HWMEM },
1037 { "hw_ldl_l", EV5HWMEM(0x1B,0x01), EV5x, ARG_EV5HWMEM },
1038 { "hw_ldl_l/a", EV5HWMEM(0x1B,0x11), EV5x, ARG_EV5HWMEM },
1039 { "hw_ldl_l/av", EV5HWMEM(0x1B,0x13), EV5x, ARG_EV5HWMEM },
1040 { "hw_ldl_l/aw", EV5HWMEM(0x1B,0x19), EV5x, ARG_EV5HWMEM },
1041 { "hw_ldl_l/awv", EV5HWMEM(0x1B,0x1b), EV5x, ARG_EV5HWMEM },
1042 { "hw_ldl_l/p", EV5HWMEM(0x1B,0x21), EV5x, ARG_EV5HWMEM },
1043 { "hw_ldl_l/pa", EV5HWMEM(0x1B,0x31), EV5x, ARG_EV5HWMEM },
1044 { "hw_ldl_l/pav", EV5HWMEM(0x1B,0x33), EV5x, ARG_EV5HWMEM },
1045 { "hw_ldl_l/paw", EV5HWMEM(0x1B,0x39), EV5x, ARG_EV5HWMEM },
1046 { "hw_ldl_l/pawv", EV5HWMEM(0x1B,0x3b), EV5x, ARG_EV5HWMEM },
1047 { "hw_ldl_l/pv", EV5HWMEM(0x1B,0x23), EV5x, ARG_EV5HWMEM },
1048 { "hw_ldl_l/pw", EV5HWMEM(0x1B,0x29), EV5x, ARG_EV5HWMEM },
1049 { "hw_ldl_l/pwv", EV5HWMEM(0x1B,0x2b), EV5x, ARG_EV5HWMEM },
1050 { "hw_ldl_l/v", EV5HWMEM(0x1B,0x03), EV5x, ARG_EV5HWMEM },
1051 { "hw_ldl_l/w", EV5HWMEM(0x1B,0x09), EV5x, ARG_EV5HWMEM },
1052 { "hw_ldl_l/wv", EV5HWMEM(0x1B,0x0b), EV5x, ARG_EV5HWMEM },
1053 { "hw_ldq", EV4HWMEM(0x1B,0x1), EV4, ARG_EV4HWMEM },
1054 { "hw_ldq", EV5HWMEM(0x1B,0x04), EV5x, ARG_EV5HWMEM },
1055 { "hw_ldq/a", EV4HWMEM(0x1B,0x5), EV4, ARG_EV4HWMEM },
1056 { "hw_ldq/a", EV5HWMEM(0x1B,0x14), EV5x, ARG_EV5HWMEM },
1057 { "hw_ldq/al", EV5HWMEM(0x1B,0x15), EV5x, ARG_EV5HWMEM },
1058 { "hw_ldq/ar", EV4HWMEM(0x1B,0x7), EV4, ARG_EV4HWMEM },
1059 { "hw_ldq/av", EV5HWMEM(0x1B,0x16), EV5x, ARG_EV5HWMEM },
1060 { "hw_ldq/avl", EV5HWMEM(0x1B,0x17), EV5x, ARG_EV5HWMEM },
1061 { "hw_ldq/aw", EV5HWMEM(0x1B,0x1c), EV5x, ARG_EV5HWMEM },
1062 { "hw_ldq/awl", EV5HWMEM(0x1B,0x1d), EV5x, ARG_EV5HWMEM },
1063 { "hw_ldq/awv", EV5HWMEM(0x1B,0x1e), EV5x, ARG_EV5HWMEM },
1064 { "hw_ldq/awvl", EV5HWMEM(0x1B,0x1f), EV5x, ARG_EV5HWMEM },
1065 { "hw_ldq/l", EV5HWMEM(0x1B,0x05), EV5x, ARG_EV5HWMEM },
1066 { "hw_ldq/p", EV4HWMEM(0x1B,0x9), EV4, ARG_EV4HWMEM },
1067 { "hw_ldq/p", EV5HWMEM(0x1B,0x24), EV5x, ARG_EV5HWMEM },
1068 { "hw_ldq/pa", EV4HWMEM(0x1B,0xD), EV4, ARG_EV4HWMEM },
1069 { "hw_ldq/pa", EV5HWMEM(0x1B,0x34), EV5x, ARG_EV5HWMEM },
1070 { "hw_ldq/pal", EV5HWMEM(0x1B,0x35), EV5x, ARG_EV5HWMEM },
1071 { "hw_ldq/par", EV4HWMEM(0x1B,0xF), EV4, ARG_EV4HWMEM },
1072 { "hw_ldq/pav", EV5HWMEM(0x1B,0x36), EV5x, ARG_EV5HWMEM },
1073 { "hw_ldq/pavl", EV5HWMEM(0x1B,0x37), EV5x, ARG_EV5HWMEM },
1074 { "hw_ldq/paw", EV5HWMEM(0x1B,0x3c), EV5x, ARG_EV5HWMEM },
1075 { "hw_ldq/pawl", EV5HWMEM(0x1B,0x3d), EV5x, ARG_EV5HWMEM },
1076 { "hw_ldq/pawv", EV5HWMEM(0x1B,0x3e), EV5x, ARG_EV5HWMEM },
1077 { "hw_ldq/pawvl", EV5HWMEM(0x1B,0x3f), EV5x, ARG_EV5HWMEM },
1078 { "hw_ldq/pl", EV5HWMEM(0x1B,0x25), EV5x, ARG_EV5HWMEM },
1079 { "hw_ldq/pr", EV4HWMEM(0x1B,0xB), EV4, ARG_EV4HWMEM },
1080 { "hw_ldq/pv", EV5HWMEM(0x1B,0x26), EV5x, ARG_EV5HWMEM },
1081 { "hw_ldq/pvl", EV5HWMEM(0x1B,0x27), EV5x, ARG_EV5HWMEM },
1082 { "hw_ldq/pw", EV5HWMEM(0x1B,0x2c), EV5x, ARG_EV5HWMEM },
1083 { "hw_ldq/pwl", EV5HWMEM(0x1B,0x2d), EV5x, ARG_EV5HWMEM },
1084 { "hw_ldq/pwv", EV5HWMEM(0x1B,0x2e), EV5x, ARG_EV5HWMEM },
1085 { "hw_ldq/pwvl", EV5HWMEM(0x1B,0x2f), EV5x, ARG_EV5HWMEM },
1086 { "hw_ldq/r", EV4HWMEM(0x1B,0x3), EV4, ARG_EV4HWMEM },
1087 { "hw_ldq/v", EV5HWMEM(0x1B,0x06), EV5x, ARG_EV5HWMEM },
1088 { "hw_ldq/vl", EV5HWMEM(0x1B,0x07), EV5x, ARG_EV5HWMEM },
1089 { "hw_ldq/w", EV5HWMEM(0x1B,0x0c), EV5x, ARG_EV5HWMEM },
1090 { "hw_ldq/wl", EV5HWMEM(0x1B,0x0d), EV5x, ARG_EV5HWMEM },
1091 { "hw_ldq/wv", EV5HWMEM(0x1B,0x0e), EV5x, ARG_EV5HWMEM },
1092 { "hw_ldq/wvl", EV5HWMEM(0x1B,0x0f), EV5x, ARG_EV5HWMEM },
1093 { "hw_ldq_l", EV5HWMEM(0x1B,0x05), EV5x, ARG_EV5HWMEM },
1094 { "hw_ldq_l/a", EV5HWMEM(0x1B,0x15), EV5x, ARG_EV5HWMEM },
1095 { "hw_ldq_l/av", EV5HWMEM(0x1B,0x17), EV5x, ARG_EV5HWMEM },
1096 { "hw_ldq_l/aw", EV5HWMEM(0x1B,0x1d), EV5x, ARG_EV5HWMEM },
1097 { "hw_ldq_l/awv", EV5HWMEM(0x1B,0x1f), EV5x, ARG_EV5HWMEM },
1098 { "hw_ldq_l/p", EV5HWMEM(0x1B,0x25), EV5x, ARG_EV5HWMEM },
1099 { "hw_ldq_l/pa", EV5HWMEM(0x1B,0x35), EV5x, ARG_EV5HWMEM },
1100 { "hw_ldq_l/pav", EV5HWMEM(0x1B,0x37), EV5x, ARG_EV5HWMEM },
1101 { "hw_ldq_l/paw", EV5HWMEM(0x1B,0x3d), EV5x, ARG_EV5HWMEM },
1102 { "hw_ldq_l/pawv", EV5HWMEM(0x1B,0x3f), EV5x, ARG_EV5HWMEM },
1103 { "hw_ldq_l/pv", EV5HWMEM(0x1B,0x27), EV5x, ARG_EV5HWMEM },
1104 { "hw_ldq_l/pw", EV5HWMEM(0x1B,0x2d), EV5x, ARG_EV5HWMEM },
1105 { "hw_ldq_l/pwv", EV5HWMEM(0x1B,0x2f), EV5x, ARG_EV5HWMEM },
1106 { "hw_ldq_l/v", EV5HWMEM(0x1B,0x07), EV5x, ARG_EV5HWMEM },
1107 { "hw_ldq_l/w", EV5HWMEM(0x1B,0x0d), EV5x, ARG_EV5HWMEM },
1108 { "hw_ldq_l/wv", EV5HWMEM(0x1B,0x0f), EV5x, ARG_EV5HWMEM },
1109 { "hw_ld", EV4HWMEM(0x1B,0x0), EV4, ARG_EV4HWMEM },
1110 { "hw_ld", EV5HWMEM(0x1B,0x00), EV5x, ARG_EV5HWMEM },
1111 { "hw_ld/a", EV4HWMEM(0x1B,0x4), EV4, ARG_EV4HWMEM },
1112 { "hw_ld/a", EV5HWMEM(0x1B,0x10), EV5x, ARG_EV5HWMEM },
1113 { "hw_ld/al", EV5HWMEM(0x1B,0x11), EV5x, ARG_EV5HWMEM },
1114 { "hw_ld/aq", EV4HWMEM(0x1B,0x5), EV4, ARG_EV4HWMEM },
1115 { "hw_ld/aq", EV5HWMEM(0x1B,0x14), EV5x, ARG_EV5HWMEM },
1116 { "hw_ld/aql", EV5HWMEM(0x1B,0x15), EV5x, ARG_EV5HWMEM },
1117 { "hw_ld/aqv", EV5HWMEM(0x1B,0x16), EV5x, ARG_EV5HWMEM },
1118 { "hw_ld/aqvl", EV5HWMEM(0x1B,0x17), EV5x, ARG_EV5HWMEM },
1119 { "hw_ld/ar", EV4HWMEM(0x1B,0x6), EV4, ARG_EV4HWMEM },
1120 { "hw_ld/arq", EV4HWMEM(0x1B,0x7), EV4, ARG_EV4HWMEM },
1121 { "hw_ld/av", EV5HWMEM(0x1B,0x12), EV5x, ARG_EV5HWMEM },
1122 { "hw_ld/avl", EV5HWMEM(0x1B,0x13), EV5x, ARG_EV5HWMEM },
1123 { "hw_ld/aw", EV5HWMEM(0x1B,0x18), EV5x, ARG_EV5HWMEM },
1124 { "hw_ld/awl", EV5HWMEM(0x1B,0x19), EV5x, ARG_EV5HWMEM },
1125 { "hw_ld/awq", EV5HWMEM(0x1B,0x1c), EV5x, ARG_EV5HWMEM },
1126 { "hw_ld/awql", EV5HWMEM(0x1B,0x1d), EV5x, ARG_EV5HWMEM },
1127 { "hw_ld/awqv", EV5HWMEM(0x1B,0x1e), EV5x, ARG_EV5HWMEM },
1128 { "hw_ld/awqvl", EV5HWMEM(0x1B,0x1f), EV5x, ARG_EV5HWMEM },
1129 { "hw_ld/awv", EV5HWMEM(0x1B,0x1a), EV5x, ARG_EV5HWMEM },
1130 { "hw_ld/awvl", EV5HWMEM(0x1B,0x1b), EV5x, ARG_EV5HWMEM },
1131 { "hw_ld/l", EV5HWMEM(0x1B,0x01), EV5x, ARG_EV5HWMEM },
1132 { "hw_ld/p", EV4HWMEM(0x1B,0x8), EV4, ARG_EV4HWMEM },
1133 { "hw_ld/p", EV5HWMEM(0x1B,0x20), EV5x, ARG_EV5HWMEM },
1134 { "hw_ld/pa", EV4HWMEM(0x1B,0xC), EV4, ARG_EV4HWMEM },
1135 { "hw_ld/pa", EV5HWMEM(0x1B,0x30), EV5x, ARG_EV5HWMEM },
1136 { "hw_ld/pal", EV5HWMEM(0x1B,0x31), EV5x, ARG_EV5HWMEM },
1137 { "hw_ld/paq", EV4HWMEM(0x1B,0xD), EV4, ARG_EV4HWMEM },
1138 { "hw_ld/paq", EV5HWMEM(0x1B,0x34), EV5x, ARG_EV5HWMEM },
1139 { "hw_ld/paql", EV5HWMEM(0x1B,0x35), EV5x, ARG_EV5HWMEM },
1140 { "hw_ld/paqv", EV5HWMEM(0x1B,0x36), EV5x, ARG_EV5HWMEM },
1141 { "hw_ld/paqvl", EV5HWMEM(0x1B,0x37), EV5x, ARG_EV5HWMEM },
1142 { "hw_ld/par", EV4HWMEM(0x1B,0xE), EV4, ARG_EV4HWMEM },
1143 { "hw_ld/parq", EV4HWMEM(0x1B,0xF), EV4, ARG_EV4HWMEM },
1144 { "hw_ld/pav", EV5HWMEM(0x1B,0x32), EV5x, ARG_EV5HWMEM },
1145 { "hw_ld/pavl", EV5HWMEM(0x1B,0x33), EV5x, ARG_EV5HWMEM },
1146 { "hw_ld/paw", EV5HWMEM(0x1B,0x38), EV5x, ARG_EV5HWMEM },
1147 { "hw_ld/pawl", EV5HWMEM(0x1B,0x39), EV5x, ARG_EV5HWMEM },
1148 { "hw_ld/pawq", EV5HWMEM(0x1B,0x3c), EV5x, ARG_EV5HWMEM },
1149 { "hw_ld/pawql", EV5HWMEM(0x1B,0x3d), EV5x, ARG_EV5HWMEM },
1150 { "hw_ld/pawqv", EV5HWMEM(0x1B,0x3e), EV5x, ARG_EV5HWMEM },
1151 { "hw_ld/pawqvl", EV5HWMEM(0x1B,0x3f), EV5x, ARG_EV5HWMEM },
1152 { "hw_ld/pawv", EV5HWMEM(0x1B,0x3a), EV5x, ARG_EV5HWMEM },
1153 { "hw_ld/pawvl", EV5HWMEM(0x1B,0x3b), EV5x, ARG_EV5HWMEM },
1154 { "hw_ld/pl", EV5HWMEM(0x1B,0x21), EV5x, ARG_EV5HWMEM },
1155 { "hw_ld/pq", EV4HWMEM(0x1B,0x9), EV4, ARG_EV4HWMEM },
1156 { "hw_ld/pq", EV5HWMEM(0x1B,0x24), EV5x, ARG_EV5HWMEM },
1157 { "hw_ld/pql", EV5HWMEM(0x1B,0x25), EV5x, ARG_EV5HWMEM },
1158 { "hw_ld/pqv", EV5HWMEM(0x1B,0x26), EV5x, ARG_EV5HWMEM },
1159 { "hw_ld/pqvl", EV5HWMEM(0x1B,0x27), EV5x, ARG_EV5HWMEM },
1160 { "hw_ld/pr", EV4HWMEM(0x1B,0xA), EV4, ARG_EV4HWMEM },
1161 { "hw_ld/prq", EV4HWMEM(0x1B,0xB), EV4, ARG_EV4HWMEM },
1162 { "hw_ld/pv", EV5HWMEM(0x1B,0x22), EV5x, ARG_EV5HWMEM },
1163 { "hw_ld/pvl", EV5HWMEM(0x1B,0x23), EV5x, ARG_EV5HWMEM },
1164 { "hw_ld/pw", EV5HWMEM(0x1B,0x28), EV5x, ARG_EV5HWMEM },
1165 { "hw_ld/pwl", EV5HWMEM(0x1B,0x29), EV5x, ARG_EV5HWMEM },
1166 { "hw_ld/pwq", EV5HWMEM(0x1B,0x2c), EV5x, ARG_EV5HWMEM },
1167 { "hw_ld/pwql", EV5HWMEM(0x1B,0x2d), EV5x, ARG_EV5HWMEM },
1168 { "hw_ld/pwqv", EV5HWMEM(0x1B,0x2e), EV5x, ARG_EV5HWMEM },
1169 { "hw_ld/pwqvl", EV5HWMEM(0x1B,0x2f), EV5x, ARG_EV5HWMEM },
1170 { "hw_ld/pwv", EV5HWMEM(0x1B,0x2a), EV5x, ARG_EV5HWMEM },
1171 { "hw_ld/pwvl", EV5HWMEM(0x1B,0x2b), EV5x, ARG_EV5HWMEM },
1172 { "hw_ld/q", EV4HWMEM(0x1B,0x1), EV4, ARG_EV4HWMEM },
1173 { "hw_ld/q", EV5HWMEM(0x1B,0x04), EV5x, ARG_EV5HWMEM },
1174 { "hw_ld/ql", EV5HWMEM(0x1B,0x05), EV5x, ARG_EV5HWMEM },
1175 { "hw_ld/qv", EV5HWMEM(0x1B,0x06), EV5x, ARG_EV5HWMEM },
1176 { "hw_ld/qvl", EV5HWMEM(0x1B,0x07), EV5x, ARG_EV5HWMEM },
1177 { "hw_ld/r", EV4HWMEM(0x1B,0x2), EV4, ARG_EV4HWMEM },
1178 { "hw_ld/rq", EV4HWMEM(0x1B,0x3), EV4, ARG_EV4HWMEM },
1179 { "hw_ld/v", EV5HWMEM(0x1B,0x02), EV5x, ARG_EV5HWMEM },
1180 { "hw_ld/vl", EV5HWMEM(0x1B,0x03), EV5x, ARG_EV5HWMEM },
1181 { "hw_ld/w", EV5HWMEM(0x1B,0x08), EV5x, ARG_EV5HWMEM },
1182 { "hw_ld/wl", EV5HWMEM(0x1B,0x09), EV5x, ARG_EV5HWMEM },
1183 { "hw_ld/wq", EV5HWMEM(0x1B,0x0c), EV5x, ARG_EV5HWMEM },
1184 { "hw_ld/wql", EV5HWMEM(0x1B,0x0d), EV5x, ARG_EV5HWMEM },
1185 { "hw_ld/wqv", EV5HWMEM(0x1B,0x0e), EV5x, ARG_EV5HWMEM },
1186 { "hw_ld/wqvl", EV5HWMEM(0x1B,0x0f), EV5x, ARG_EV5HWMEM },
1187 { "hw_ld/wv", EV5HWMEM(0x1B,0x0a), EV5x, ARG_EV5HWMEM },
1188 { "hw_ld/wvl", EV5HWMEM(0x1B,0x0b), EV5x, ARG_EV5HWMEM },
1189 { "pal1b", PCD(0x1B), ALL, ARG_PCD },
1191 { "hw_mtpr", OPR(0x1D,0x00), EV4, { RA, RBA, EV4EXTHWINDEX } },
1192 { "hw_mtpr", OP(0x1D), OP_MASK, EV5x, { RA, RBA, EV5HWINDEX } },
1193 { "hw_mtpr/i", OPR(0x1D,0x01), EV4, ARG_EV4HWMPR },
1194 { "hw_mtpr/a", OPR(0x1D,0x02), EV4, ARG_EV4HWMPR },
1195 { "hw_mtpr/ai", OPR(0x1D,0x03), EV4, ARG_EV4HWMPR },
1196 { "hw_mtpr/p", OPR(0x1D,0x04), EV4, ARG_EV4HWMPR },
1197 { "hw_mtpr/pi", OPR(0x1D,0x05), EV4, ARG_EV4HWMPR },
1198 { "hw_mtpr/pa", OPR(0x1D,0x06), EV4, ARG_EV4HWMPR },
1199 { "hw_mtpr/pai", OPR(0x1D,0x07), EV4, ARG_EV4HWMPR },
1200 { "pal1d", PCD(0x1D), ALL, ARG_PCD },
1202 { "hw_rei", SPCD(0x1E,0x3FF8000), EV4|EV5x, ARG_NONE },
1203 { "hw_rei_stall", SPCD(0x1E,0x3FFC000), EV5x, ARG_NONE },
1204 { "pal1e", PCD(0x1E), ALL, ARG_PCD },
1206 { "hw_stl", EV4HWMEM(0x1F,0x0), EV4, ARG_EV4HWMEM },
1207 { "hw_stl", EV5HWMEM(0x1F,0x00), EV5x, ARG_EV5HWMEM },
1208 { "hw_stl/a", EV4HWMEM(0x1F,0x4), EV4, ARG_EV4HWMEM },
1209 { "hw_stl/a", EV5HWMEM(0x1F,0x10), EV5x, ARG_EV5HWMEM },
1210 { "hw_stl/ac", EV5HWMEM(0x1F,0x11), EV5x, ARG_EV5HWMEM },
1211 { "hw_stl/ar", EV4HWMEM(0x1F,0x6), EV4, ARG_EV4HWMEM },
1212 { "hw_stl/av", EV5HWMEM(0x1F,0x12), EV5x, ARG_EV5HWMEM },
1213 { "hw_stl/avc", EV5HWMEM(0x1F,0x13), EV5x, ARG_EV5HWMEM },
1214 { "hw_stl/c", EV5HWMEM(0x1F,0x01), EV5x, ARG_EV5HWMEM },
1215 { "hw_stl/p", EV4HWMEM(0x1F,0x8), EV4, ARG_EV4HWMEM },
1216 { "hw_stl/p", EV5HWMEM(0x1F,0x20), EV5x, ARG_EV5HWMEM },
1217 { "hw_stl/pa", EV4HWMEM(0x1F,0xC), EV4, ARG_EV4HWMEM },
1218 { "hw_stl/pa", EV5HWMEM(0x1F,0x30), EV5x, ARG_EV5HWMEM },
1219 { "hw_stl/pac", EV5HWMEM(0x1F,0x31), EV5x, ARG_EV5HWMEM },
1220 { "hw_stl/pav", EV5HWMEM(0x1F,0x32), EV5x, ARG_EV5HWMEM },
1221 { "hw_stl/pavc", EV5HWMEM(0x1F,0x33), EV5x, ARG_EV5HWMEM },
1222 { "hw_stl/pc", EV5HWMEM(0x1F,0x21), EV5x, ARG_EV5HWMEM },
1223 { "hw_stl/pr", EV4HWMEM(0x1F,0xA), EV4, ARG_EV4HWMEM },
1224 { "hw_stl/pv", EV5HWMEM(0x1F,0x22), EV5x, ARG_EV5HWMEM },
1225 { "hw_stl/pvc", EV5HWMEM(0x1F,0x23), EV5x, ARG_EV5HWMEM },
1226 { "hw_stl/r", EV4HWMEM(0x1F,0x2), EV4, ARG_EV4HWMEM },
1227 { "hw_stl/v", EV5HWMEM(0x1F,0x02), EV5x, ARG_EV5HWMEM },
1228 { "hw_stl/vc", EV5HWMEM(0x1F,0x03), EV5x, ARG_EV5HWMEM },
1229 { "hw_stl_c", EV5HWMEM(0x1F,0x01), EV5x, ARG_EV5HWMEM },
1230 { "hw_stl_c/a", EV5HWMEM(0x1F,0x11), EV5x, ARG_EV5HWMEM },
1231 { "hw_stl_c/av", EV5HWMEM(0x1F,0x13), EV5x, ARG_EV5HWMEM },
1232 { "hw_stl_c/p", EV5HWMEM(0x1F,0x21), EV5x, ARG_EV5HWMEM },
1233 { "hw_stl_c/pa", EV5HWMEM(0x1F,0x31), EV5x, ARG_EV5HWMEM },
1234 { "hw_stl_c/pav", EV5HWMEM(0x1F,0x33), EV5x, ARG_EV5HWMEM },
1235 { "hw_stl_c/pv", EV5HWMEM(0x1F,0x23), EV5x, ARG_EV5HWMEM },
1236 { "hw_stl_c/v", EV5HWMEM(0x1F,0x03), EV5x, ARG_EV5HWMEM },
1237 { "hw_stq", EV4HWMEM(0x1F,0x1), EV4, ARG_EV4HWMEM },
1238 { "hw_stq", EV5HWMEM(0x1F,0x04), EV5x, ARG_EV5HWMEM },
1239 { "hw_stq/a", EV4HWMEM(0x1F,0x5), EV4, ARG_EV4HWMEM },
1240 { "hw_stq/a", EV5HWMEM(0x1F,0x14), EV5x, ARG_EV5HWMEM },
1241 { "hw_stq/ac", EV5HWMEM(0x1F,0x15), EV5x, ARG_EV5HWMEM },
1242 { "hw_stq/ar", EV4HWMEM(0x1F,0x7), EV4, ARG_EV4HWMEM },
1243 { "hw_stq/av", EV5HWMEM(0x1F,0x16), EV5x, ARG_EV5HWMEM },
1244 { "hw_stq/avc", EV5HWMEM(0x1F,0x17), EV5x, ARG_EV5HWMEM },
1245 { "hw_stq/c", EV5HWMEM(0x1F,0x05), EV5x, ARG_EV5HWMEM },
1246 { "hw_stq/p", EV4HWMEM(0x1F,0x9), EV4, ARG_EV4HWMEM },
1247 { "hw_stq/p", EV5HWMEM(0x1F,0x24), EV5x, ARG_EV5HWMEM },
1248 { "hw_stq/pa", EV4HWMEM(0x1F,0xD), EV4, ARG_EV4HWMEM },
1249 { "hw_stq/pa", EV5HWMEM(0x1F,0x34), EV5x, ARG_EV5HWMEM },
1250 { "hw_stq/pac", EV5HWMEM(0x1F,0x35), EV5x, ARG_EV5HWMEM },
1251 { "hw_stq/par", EV4HWMEM(0x1F,0xE), EV4, ARG_EV4HWMEM },
1252 { "hw_stq/par", EV4HWMEM(0x1F,0xF), EV4, ARG_EV4HWMEM },
1253 { "hw_stq/pav", EV5HWMEM(0x1F,0x36), EV5x, ARG_EV5HWMEM },
1254 { "hw_stq/pavc", EV5HWMEM(0x1F,0x37), EV5x, ARG_EV5HWMEM },
1255 { "hw_stq/pc", EV5HWMEM(0x1F,0x25), EV5x, ARG_EV5HWMEM },
1256 { "hw_stq/pr", EV4HWMEM(0x1F,0xB), EV4, ARG_EV4HWMEM },
1257 { "hw_stq/pv", EV5HWMEM(0x1F,0x26), EV5x, ARG_EV5HWMEM },
1258 { "hw_stq/pvc", EV5HWMEM(0x1F,0x27), EV5x, ARG_EV5HWMEM },
1259 { "hw_stq/r", EV4HWMEM(0x1F,0x3), EV4, ARG_EV4HWMEM },
1260 { "hw_stq/v", EV5HWMEM(0x1F,0x06), EV5x, ARG_EV5HWMEM },
1261 { "hw_stq/vc", EV5HWMEM(0x1F,0x07), EV5x, ARG_EV5HWMEM },
1262 { "hw_stq_c", EV5HWMEM(0x1F,0x05), EV5x, ARG_EV5HWMEM },
1263 { "hw_stq_c/a", EV5HWMEM(0x1F,0x15), EV5x, ARG_EV5HWMEM },
1264 { "hw_stq_c/av", EV5HWMEM(0x1F,0x17), EV5x, ARG_EV5HWMEM },
1265 { "hw_stq_c/p", EV5HWMEM(0x1F,0x25), EV5x, ARG_EV5HWMEM },
1266 { "hw_stq_c/pa", EV5HWMEM(0x1F,0x35), EV5x, ARG_EV5HWMEM },
1267 { "hw_stq_c/pav", EV5HWMEM(0x1F,0x37), EV5x, ARG_EV5HWMEM },
1268 { "hw_stq_c/pv", EV5HWMEM(0x1F,0x27), EV5x, ARG_EV5HWMEM },
1269 { "hw_stq_c/v", EV5HWMEM(0x1F,0x07), EV5x, ARG_EV5HWMEM },
1270 { "hw_st", EV4HWMEM(0x1F,0x0), EV4, ARG_EV4HWMEM },
1271 { "hw_st", EV5HWMEM(0x1F,0x00), EV5x, ARG_EV5HWMEM },
1272 { "hw_st/a", EV4HWMEM(0x1F,0x4), EV4, ARG_EV4HWMEM },
1273 { "hw_st/a", EV5HWMEM(0x1F,0x10), EV5x, ARG_EV5HWMEM },
1274 { "hw_st/ac", EV5HWMEM(0x1F,0x11), EV5x, ARG_EV5HWMEM },
1275 { "hw_st/aq", EV4HWMEM(0x1F,0x5), EV4, ARG_EV4HWMEM },
1276 { "hw_st/aq", EV5HWMEM(0x1F,0x14), EV5x, ARG_EV5HWMEM },
1277 { "hw_st/aqc", EV5HWMEM(0x1F,0x15), EV5x, ARG_EV5HWMEM },
1278 { "hw_st/aqv", EV5HWMEM(0x1F,0x16), EV5x, ARG_EV5HWMEM },
1279 { "hw_st/aqvc", EV5HWMEM(0x1F,0x17), EV5x, ARG_EV5HWMEM },
1280 { "hw_st/ar", EV4HWMEM(0x1F,0x6), EV4, ARG_EV4HWMEM },
1281 { "hw_st/arq", EV4HWMEM(0x1F,0x7), EV4, ARG_EV4HWMEM },
1282 { "hw_st/av", EV5HWMEM(0x1F,0x12), EV5x, ARG_EV5HWMEM },
1283 { "hw_st/avc", EV5HWMEM(0x1F,0x13), EV5x, ARG_EV5HWMEM },
1284 { "hw_st/c", EV5HWMEM(0x1F,0x01), EV5x, ARG_EV5HWMEM },
1285 { "hw_st/p", EV4HWMEM(0x1F,0x8), EV4, ARG_EV4HWMEM },
1286 { "hw_st/p", EV5HWMEM(0x1F,0x20), EV5x, ARG_EV5HWMEM },
1287 { "hw_st/pa", EV4HWMEM(0x1F,0xC), EV4, ARG_EV4HWMEM },
1288 { "hw_st/pa", EV5HWMEM(0x1F,0x30), EV5x, ARG_EV5HWMEM },
1289 { "hw_st/pac", EV5HWMEM(0x1F,0x31), EV5x, ARG_EV5HWMEM },
1290 { "hw_st/paq", EV4HWMEM(0x1F,0xD), EV4, ARG_EV4HWMEM },
1291 { "hw_st/paq", EV5HWMEM(0x1F,0x34), EV5x, ARG_EV5HWMEM },
1292 { "hw_st/paqc", EV5HWMEM(0x1F,0x35), EV5x, ARG_EV5HWMEM },
1293 { "hw_st/paqv", EV5HWMEM(0x1F,0x36), EV5x, ARG_EV5HWMEM },
1294 { "hw_st/paqvc", EV5HWMEM(0x1F,0x37), EV5x, ARG_EV5HWMEM },
1295 { "hw_st/par", EV4HWMEM(0x1F,0xE), EV4, ARG_EV4HWMEM },
1296 { "hw_st/parq", EV4HWMEM(0x1F,0xF), EV4, ARG_EV4HWMEM },
1297 { "hw_st/pav", EV5HWMEM(0x1F,0x32), EV5x, ARG_EV5HWMEM },
1298 { "hw_st/pavc", EV5HWMEM(0x1F,0x33), EV5x, ARG_EV5HWMEM },
1299 { "hw_st/pc", EV5HWMEM(0x1F,0x21), EV5x, ARG_EV5HWMEM },
1300 { "hw_st/pq", EV4HWMEM(0x1F,0x9), EV4, ARG_EV4HWMEM },
1301 { "hw_st/pq", EV5HWMEM(0x1F,0x24), EV5x, ARG_EV5HWMEM },
1302 { "hw_st/pqc", EV5HWMEM(0x1F,0x25), EV5x, ARG_EV5HWMEM },
1303 { "hw_st/pqv", EV5HWMEM(0x1F,0x26), EV5x, ARG_EV5HWMEM },
1304 { "hw_st/pqvc", EV5HWMEM(0x1F,0x27), EV5x, ARG_EV5HWMEM },
1305 { "hw_st/pr", EV4HWMEM(0x1F,0xA), EV4, ARG_EV4HWMEM },
1306 { "hw_st/prq", EV4HWMEM(0x1F,0xB), EV4, ARG_EV4HWMEM },
1307 { "hw_st/pv", EV5HWMEM(0x1F,0x22), EV5x, ARG_EV5HWMEM },
1308 { "hw_st/pvc", EV5HWMEM(0x1F,0x23), EV5x, ARG_EV5HWMEM },
1309 { "hw_st/q", EV4HWMEM(0x1F,0x1), EV4, ARG_EV4HWMEM },
1310 { "hw_st/q", EV5HWMEM(0x1F,0x04), EV5x, ARG_EV5HWMEM },
1311 { "hw_st/qc", EV5HWMEM(0x1F,0x05), EV5x, ARG_EV5HWMEM },
1312 { "hw_st/qv", EV5HWMEM(0x1F,0x06), EV5x, ARG_EV5HWMEM },
1313 { "hw_st/qvc", EV5HWMEM(0x1F,0x07), EV5x, ARG_EV5HWMEM },
1314 { "hw_st/r", EV4HWMEM(0x1F,0x2), EV4, ARG_EV4HWMEM },
1315 { "hw_st/v", EV5HWMEM(0x1F,0x02), EV5x, ARG_EV5HWMEM },
1316 { "hw_st/vc", EV5HWMEM(0x1F,0x03), EV5x, ARG_EV5HWMEM },
1317 { "pal1f", PCD(0x1F), ALL, ARG_PCD },
1319 { "ldf", MEM(0x20), ALL, ARG_FMEM },
1320 { "ldg", MEM(0x21), ALL, ARG_FMEM },
1321 { "lds", MEM(0x22), ALL, ARG_FMEM },
1322 { "ldt", MEM(0x23), ALL, ARG_FMEM },
1323 { "stf", MEM(0x24), ALL, ARG_FMEM },
1324 { "stg", MEM(0x25), ALL, ARG_FMEM },
1325 { "sts", MEM(0x26), ALL, ARG_FMEM },
1326 { "stt", MEM(0x27), ALL, ARG_FMEM },
1328 { "ldl", MEM(0x28), ALL, ARG_MEM },
1329 { "ldq", MEM(0x29), ALL, ARG_MEM },
1330 { "ldl_l", MEM(0x2A), ALL, ARG_MEM },
1331 { "ldq_l", MEM(0x2B), ALL, ARG_MEM },
1332 { "stl", MEM(0x2C), ALL, ARG_MEM },
1333 { "stq", MEM(0x2D), ALL, ARG_MEM },
1334 { "stl_c", MEM(0x2E), ALL, ARG_MEM },
1335 { "stq_c", MEM(0x2F), ALL, ARG_MEM },
1337 { "br", BRA(0x30), ALL, { ZA, BDISP } }, /* pseudo */
1338 { "br", BRA(0x30), ALL, ARG_BRA },
1339 { "fbeq", BRA(0x31), ALL, ARG_FBRA },
1340 { "fblt", BRA(0x32), ALL, ARG_FBRA },
1341 { "fble", BRA(0x33), ALL, ARG_FBRA },
1342 { "bsr", BRA(0x34), ALL, ARG_BRA },
1343 { "fbne", BRA(0x35), ALL, ARG_FBRA },
1344 { "fbge", BRA(0x36), ALL, ARG_FBRA },
1345 { "fbgt", BRA(0x37), ALL, ARG_FBRA },
1346 { "blbc", BRA(0x38), ALL, ARG_BRA },
1347 { "beq", BRA(0x39), ALL, ARG_BRA },
1348 { "blt", BRA(0x3A), ALL, ARG_BRA },
1349 { "ble", BRA(0x3B), ALL, ARG_BRA },
1350 { "blbs", BRA(0x3C), ALL, ARG_BRA },
1351 { "bne", BRA(0x3D), ALL, ARG_BRA },
1352 { "bge", BRA(0x3E), ALL, ARG_BRA },
1353 { "bgt", BRA(0x3F), ALL, ARG_BRA },
1356 const int alpha_num_opcodes = sizeof(alpha_opcodes)/sizeof(*alpha_opcodes);