Index: ChangeLog
[deliverable/binutils-gdb.git] / opcodes / ia64-opc-m.c
index 13a971e5e0d5296c4eb97727f4cc9130394ed907..8e9454ba3c367dced6bc251b4e9ea1893fc8e989 100644 (file)
@@ -1,5 +1,5 @@
 /* ia64-opc-m.c -- IA-64 `M' opcode table.
-   Copyright (C) 1998, 1999 Free Software Foundation, Inc.
+   Copyright 1998, 1999, 2000, 2002 Free Software Foundation, Inc.
    Contributed by David Mosberger-Tang <davidm@hpl.hp.com>
 
    This file is part of GDB, GAS, and the GNU binutils.
@@ -33,6 +33,8 @@
 #define bX4(x)         (((ia64_insn) ((x) & 0xf)) << 27)
 #define bX6a(x)                (((ia64_insn) ((x) & 0x3f)) << 30)
 #define bX6b(x)                (((ia64_insn) ((x) & 0x3f)) << 27)
+#define bX7(x)         (((ia64_insn) ((x) & 0x1)) << 36)       /* note: alias for bM() */
+#define bY(x)          (((ia64_insn) ((x) & 0x1)) << 26)
 #define bHint(x)       (((ia64_insn) ((x) & 0x3)) << 28)
 
 #define mM     bM (-1)
 #define mX4    bX4 (-1)
 #define mX6a   bX6a (-1)
 #define mX6b   bX6b (-1)
+#define mX7    bX7 (-1)
+#define mY     bY (-1)
 #define mHint  bHint (-1)
 
 #define OpX3(a,b)              (bOp (a) | bX3 (b)), (mOp | mX3)
 #define OpX3X6b(a,b,c)                 (bOp (a) | bX3 (b) | bX6b (c)), \
                                (mOp | mX3 | mX6b)
+#define OpX3X6bX7(a,b,c,d)     (bOp (a) | bX3 (b) | bX6b (c) | bX7 (d)), \
+                               (mOp | mX3 | mX6b | mX7)
 #define OpX3X4(a,b,c)          (bOp (a) | bX3 (b) | bX4 (c)), \
                                (mOp | mX3 | mX4)
 #define OpX3X4X2(a,b,c,d)      (bOp (a) | bX3 (b) | bX4 (c) | bX2 (d)), \
                                (mOp | mX3 | mX4 | mX2)
+#define OpX3X4X2Y(a,b,c,d,e)   (bOp (a) | bX3 (b) | bX4 (c) | bX2 (d) | bY (e)), \
+                               (mOp | mX3 | mX4 | mX2 | mY)
 #define OpX6aHint(a,b,c)       (bOp (a) | bX6a (b) | bHint (c)), \
                                (mOp | mX6a | mHint)
 #define OpXX6aHint(a,b,c,d)    (bOp (a) | bX (b) | bX6a (c) | bHint (d)), \
        (bOp (a) | bM (b) | bX (c) | bX6a (d) | bHint (e)), \
        (mOp | mM | mX | mX6a | mHint)
 
+/* Used to initialise unused fields in ia64_opcode struct,
+   in order to stop gcc from complaining.  */
+#define EMPTY 0,0,NULL
+
 struct ia64_opcode ia64_opcodes_m[] =
   {
-    /* M-type instruction encodings (sorted according to major opcode) */
+    /* M-type instruction encodings (sorted according to major opcode) */
 
-    {"chk.a.nc",       M0, OpX3 (0, 4), {R1, TGT25c}},
-    {"chk.a.clr",      M0, OpX3 (0, 5), {R1, TGT25c}},
-    {"chk.a.nc",       M0, OpX3 (0, 6), {F1, TGT25c}},
-    {"chk.a.clr",      M0, OpX3 (0, 7), {F1, TGT25c}},
+    {"chk.a.nc",       M0, OpX3 (0, 4), {R1, TGT25c}, EMPTY},
+    {"chk.a.clr",      M0, OpX3 (0, 5), {R1, TGT25c}, EMPTY},
+    {"chk.a.nc",       M0, OpX3 (0, 6), {F1, TGT25c}, EMPTY},
+    {"chk.a.clr",      M0, OpX3 (0, 7), {F1, TGT25c}, EMPTY},
 
-    {"invala",         M0, OpX3X4X2 (0, 0, 0, 1)},
-    {"fwb",            M0, OpX3X4X2 (0, 0, 0, 2)},
-    {"mf",             M0, OpX3X4X2 (0, 0, 2, 2)},
-    {"mf.a",           M0, OpX3X4X2 (0, 0, 3, 2)},
-    {"srlz.d",         M0, OpX3X4X2 (0, 0, 0, 3)},
-    {"srlz.i",         M0, OpX3X4X2 (0, 0, 1, 3)},
-    {"sync.i",         M0, OpX3X4X2 (0, 0, 3, 3)},
-    {"flushrs",                M0, OpX3X4X2 (0, 0, 0xc, 0), {0, }, FIRST | NO_PRED},
-    {"loadrs",         M0, OpX3X4X2 (0, 0, 0xa, 0), {0, }, FIRST | NO_PRED},
-    {"invala.e",       M0, OpX3X4X2 (0, 0, 2, 1), {R1}},
-    {"invala.e",       M0, OpX3X4X2 (0, 0, 3, 1), {F1}},
-    {"mov.m",          M, OpX3X4X2 (0, 0, 8, 2), {AR3, IMM8}},
+    {"invala",         M0, OpX3X4X2 (0, 0, 0, 1), {}, EMPTY},
+    {"fwb",            M0, OpX3X4X2 (0, 0, 0, 2), {}, EMPTY},
+    {"mf",             M0, OpX3X4X2 (0, 0, 2, 2), {}, EMPTY},
+    {"mf.a",           M0, OpX3X4X2 (0, 0, 3, 2), {}, EMPTY},
+    {"srlz.d",         M0, OpX3X4X2 (0, 0, 0, 3), {}, EMPTY},
+    {"srlz.i",         M0, OpX3X4X2 (0, 0, 1, 3), {}, EMPTY},
+    {"sync.i",         M0, OpX3X4X2 (0, 0, 3, 3), {}, EMPTY},
+    {"flushrs",                M0, OpX3X4X2 (0, 0, 0xc, 0), {}, FIRST | NO_PRED, 0, NULL},
+    {"loadrs",         M0, OpX3X4X2 (0, 0, 0xa, 0), {}, FIRST | NO_PRED, 0, NULL},
+    {"invala.e",       M0, OpX3X4X2 (0, 0, 2, 1), {R1}, EMPTY},
+    {"invala.e",       M0, OpX3X4X2 (0, 0, 3, 1), {F1}, EMPTY},
+    {"mov.m",          M, OpX3X4X2 (0, 0, 8, 2), {AR3, IMM8}, EMPTY},
 
-    {"break.m",                M0, OpX3X4X2 (0, 0, 0, 0), {IMMU21}},
-    {"nop.m",          M0, OpX3X4X2 (0, 0, 1, 0), {IMMU21}},
+    {"break.m",                M0, OpX3X4X2 (0, 0, 0, 0), {IMMU21}, EMPTY},
+    {"nop.m",          M0, OpX3X4X2Y (0, 0, 1, 0, 0), {IMMU21}, EMPTY},
+    {"hint.m",         M0, OpX3X4X2Y (0, 0, 1, 0, 1), {IMMU21}, EMPTY},
 
-    {"sum",            M0, OpX3X4 (0, 0, 4), {IMMU24}},
-    {"rum",            M0, OpX3X4 (0, 0, 5), {IMMU24}},
-    {"ssm",            M0, OpX3X4 (0, 0, 6), {IMMU24}, PRIV},
-    {"rsm",            M0, OpX3X4 (0, 0, 7), {IMMU24}, PRIV},
+    {"sum",            M0, OpX3X4 (0, 0, 4), {IMMU24}, EMPTY},
+    {"rum",            M0, OpX3X4 (0, 0, 5), {IMMU24}, EMPTY},
+    {"ssm",            M0, OpX3X4 (0, 0, 6), {IMMU24}, PRIV, 0, NULL},
+    {"rsm",            M0, OpX3X4 (0, 0, 7), {IMMU24}, PRIV, 0, NULL},
 
-    {"mov.m",  M, OpX3X6b (1, 0, 0x2a), {AR3, R2}},
-    {"mov.m",  M, OpX3X6b (1, 0, 0x22), {R1, AR3}},
-    {"mov",    M, OpX3X6b (1, 0, 0x2c), {CR3, R2}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x24), {R1, CR3}, PRIV},
+    {"mov.m",  M, OpX3X6b (1, 0, 0x2a), {AR3, R2}, EMPTY},
+    {"mov.m",  M, OpX3X6b (1, 0, 0x22), {R1, AR3}, EMPTY},
+    {"mov",    M, OpX3X6b (1, 0, 0x2c), {CR3, R2}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x24), {R1, CR3}, PRIV, 0, NULL},
 
-    {"alloc",  M, OpX3 (1, 6), {R1, AR_PFS, SOF, SOL, SOR}, FIRST|NO_PRED|MOD_RRBS},
+    {"alloc",  M, OpX3 (1, 6), {R1, AR_PFS, SOF, SOL, SOR}, FIRST|NO_PRED|MOD_RRBS, 0, NULL},
 
-    {"mov",    M, OpX3X6b (1, 0, 0x2d), {PSR_L, R2}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x29), {PSR_UM, R2}},
-    {"mov",    M, OpX3X6b (1, 0, 0x25), {R1, PSR}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x21), {R1, PSR_UM}},
-    {"probe.r",        M, OpX3X6b (1, 0, 0x38), {R1, R3, R2}},
-    {"probe.w",        M, OpX3X6b (1, 0, 0x39), {R1, R3, R2}},
-    {"probe.r", M, OpX3X6b (1, 0, 0x18), {R1, R3, IMMU2}},
-    {"probe.w", M, OpX3X6b (1, 0, 0x19), {R1, R3, IMMU2}},
-    {"probe.rw.fault", M0, OpX3X6b (1, 0, 0x31), {R3, IMMU2}},
-    {"probe.r.fault",  M0, OpX3X6b (1, 0, 0x32), {R3, IMMU2}},
-    {"probe.w.fault",  M0, OpX3X6b (1, 0, 0x33), {R3, IMMU2}},
-    {"itc.d",  M0, OpX3X6b (1, 0, 0x2e), {R2}, LAST | PRIV},
-    {"itc.i",  M0, OpX3X6b (1, 0, 0x2f), {R2}, LAST | PRIV},
+    {"mov",    M, OpX3X6b (1, 0, 0x2d), {PSR_L, R2}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x29), {PSR_UM, R2}, EMPTY},
+    {"mov",    M, OpX3X6b (1, 0, 0x25), {R1, PSR}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x21), {R1, PSR_UM}, EMPTY},
+    {"probe.r",        M, OpX3X6b (1, 0, 0x38), {R1, R3, R2}, EMPTY},
+    {"probe.w",        M, OpX3X6b (1, 0, 0x39), {R1, R3, R2}, EMPTY},
+    {"probe.r", M, OpX3X6b (1, 0, 0x18), {R1, R3, IMMU2}, EMPTY},
+    {"probe.w", M, OpX3X6b (1, 0, 0x19), {R1, R3, IMMU2}, EMPTY},
+    {"probe.rw.fault", M0, OpX3X6b (1, 0, 0x31), {R3, IMMU2}, EMPTY},
+    {"probe.r.fault",  M0, OpX3X6b (1, 0, 0x32), {R3, IMMU2}, EMPTY},
+    {"probe.w.fault",  M0, OpX3X6b (1, 0, 0x33), {R3, IMMU2}, EMPTY},
+    {"itc.d",  M0, OpX3X6b (1, 0, 0x2e), {R2}, LAST | PRIV, 0, NULL},
+    {"itc.i",  M0, OpX3X6b (1, 0, 0x2f), {R2}, LAST | PRIV, 0, NULL},
 
-    {"mov",    M, OpX3X6b (1, 0, 0x00), {RR_R3, R2}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x01), {DBR_R3, R2}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x02), {IBR_R3, R2}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x03), {PKR_R3, R2}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x04), {PMC_R3, R2}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x05), {PMD_R3, R2}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x06), {MSR_R3, R2}, PRIV},
-    {"itr.d",  M, OpX3X6b (1, 0, 0x0e), {DTR_R3, R2}, PRIV},
-    {"itr.i",  M, OpX3X6b (1, 0, 0x0f), {ITR_R3, R2}, PRIV},
+    {"mov",    M, OpX3X6b (1, 0, 0x00), {RR_R3, R2}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x01), {DBR_R3, R2}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x02), {IBR_R3, R2}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x03), {PKR_R3, R2}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x04), {PMC_R3, R2}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x05), {PMD_R3, R2}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x06), {MSR_R3, R2}, PRIV, 0, NULL},
+    {"itr.d",  M, OpX3X6b (1, 0, 0x0e), {DTR_R3, R2}, PRIV, 0, NULL},
+    {"itr.i",  M, OpX3X6b (1, 0, 0x0f), {ITR_R3, R2}, PRIV, 0, NULL},
 
-    {"mov",    M, OpX3X6b (1, 0, 0x10), {R1, RR_R3}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x11), {R1, DBR_R3}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x12), {R1, IBR_R3}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x13), {R1, PKR_R3}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x14), {R1, PMC_R3}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x15), {R1, PMD_R3}},
-    {"mov",    M, OpX3X6b (1, 0, 0x16), {R1, MSR_R3}, PRIV},
-    {"mov",    M, OpX3X6b (1, 0, 0x17), {R1, CPUID_R3}},
+    {"mov",    M, OpX3X6b (1, 0, 0x10), {R1, RR_R3}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x11), {R1, DBR_R3}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x12), {R1, IBR_R3}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x13), {R1, PKR_R3}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x14), {R1, PMC_R3}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x15), {R1, PMD_R3}, EMPTY},
+    {"mov",    M, OpX3X6b (1, 0, 0x16), {R1, MSR_R3}, PRIV, 0, NULL},
+    {"mov",    M, OpX3X6b (1, 0, 0x17), {R1, CPUID_R3}, EMPTY},
 
-    {"ptc.l",  M0, OpX3X6b (1, 0, 0x09), {R3, R2}, PRIV},
-    {"ptc.g",  M0, OpX3X6b (1, 0, 0x0a), {R3, R2}, LAST | PRIV},
-    {"ptc.ga", M0, OpX3X6b (1, 0, 0x0b), {R3, R2}, LAST | PRIV},
-    {"ptr.d",  M0, OpX3X6b (1, 0, 0x0c), {R3, R2}, PRIV},
-    {"ptr.i",  M0, OpX3X6b (1, 0, 0x0d), {R3, R2}, PRIV},
+    {"ptc.l",  M0, OpX3X6b (1, 0, 0x09), {R3, R2}, PRIV, 0, NULL},
+    {"ptc.g",  M0, OpX3X6b (1, 0, 0x0a), {R3, R2}, LAST | PRIV, 0, NULL},
+    {"ptc.ga", M0, OpX3X6b (1, 0, 0x0b), {R3, R2}, LAST | PRIV, 0, NULL},
+    {"ptr.d",  M0, OpX3X6b (1, 0, 0x0c), {R3, R2}, PRIV, 0, NULL},
+    {"ptr.i",  M0, OpX3X6b (1, 0, 0x0d), {R3, R2}, PRIV, 0, NULL},
 
-    {"thash",  M, OpX3X6b (1, 0, 0x1a), {R1, R3}},
-    {"ttag",   M, OpX3X6b (1, 0, 0x1b), {R1, R3}},
-    {"tpa",    M, OpX3X6b (1, 0, 0x1e), {R1, R3}, PRIV},
-    {"tak",    M, OpX3X6b (1, 0, 0x1f), {R1, R3}, PRIV},
+    {"thash",  M, OpX3X6b (1, 0, 0x1a), {R1, R3}, EMPTY},
+    {"ttag",   M, OpX3X6b (1, 0, 0x1b), {R1, R3}, EMPTY},
+    {"tpa",    M, OpX3X6b (1, 0, 0x1e), {R1, R3}, PRIV, 0, NULL},
+    {"tak",    M, OpX3X6b (1, 0, 0x1f), {R1, R3}, PRIV, 0, NULL},
 
-    {"chk.s.m",        M0, OpX3 (1, 1), {R2, TGT25b}},
-    {"chk.s",  M0, OpX3 (1, 3), {F2, TGT25b}},
+    {"chk.s.m",        M0, OpX3 (1, 1), {R2, TGT25b}, EMPTY},
+    {"chk.s",  M0, OpX3 (1, 3), {F2, TGT25b}, EMPTY},
 
-    {"fc",     M0, OpX3X6b (1, 0, 0x30), {R3}},
-    {"ptc.e",  M0, OpX3X6b (1, 0, 0x34), {R3}, PRIV},
+    {"fc",     M0, OpX3X6bX7 (1, 0, 0x30, 0), {R3}, EMPTY},
+    {"fc.i",   M0, OpX3X6bX7 (1, 0, 0x30, 1), {R3}, EMPTY},
+    {"ptc.e",  M0, OpX3X6b (1, 0, 0x34), {R3}, PRIV, 0, NULL},
 
     /* integer load */
-    {"ld1",            M, OpMXX6aHint (4, 0, 0, 0x00, 0), {R1, MR3}},
-    {"ld1.nt1",                M, OpMXX6aHint (4, 0, 0, 0x00, 1), {R1, MR3}},
-    {"ld1.nta",                M, OpMXX6aHint (4, 0, 0, 0x00, 3), {R1, MR3}},
-    {"ld2",            M, OpMXX6aHint (4, 0, 0, 0x01, 0), {R1, MR3}},
-    {"ld2.nt1",                M, OpMXX6aHint (4, 0, 0, 0x01, 1), {R1, MR3}},
-    {"ld2.nta",                M, OpMXX6aHint (4, 0, 0, 0x01, 3), {R1, MR3}},
-    {"ld4",            M, OpMXX6aHint (4, 0, 0, 0x02, 0), {R1, MR3}},
-    {"ld4.nt1",                M, OpMXX6aHint (4, 0, 0, 0x02, 1), {R1, MR3}},
-    {"ld4.nta",                M, OpMXX6aHint (4, 0, 0, 0x02, 3), {R1, MR3}},
-    {"ld8",            M, OpMXX6aHint (4, 0, 0, 0x03, 0), {R1, MR3}},
-    {"ld8.nt1",                M, OpMXX6aHint (4, 0, 0, 0x03, 1), {R1, MR3}},
-    {"ld8.nta",                M, OpMXX6aHint (4, 0, 0, 0x03, 3), {R1, MR3}},
-    {"ld1.s",          M, OpMXX6aHint (4, 0, 0, 0x04, 0), {R1, MR3}},
-    {"ld1.s.nt1",      M, OpMXX6aHint (4, 0, 0, 0x04, 1), {R1, MR3}},
-    {"ld1.s.nta",      M, OpMXX6aHint (4, 0, 0, 0x04, 3), {R1, MR3}},
-    {"ld2.s",          M, OpMXX6aHint (4, 0, 0, 0x05, 0), {R1, MR3}},
-    {"ld2.s.nt1",      M, OpMXX6aHint (4, 0, 0, 0x05, 1), {R1, MR3}},
-    {"ld2.s.nta",      M, OpMXX6aHint (4, 0, 0, 0x05, 3), {R1, MR3}},
-    {"ld4.s",          M, OpMXX6aHint (4, 0, 0, 0x06, 0), {R1, MR3}},
-    {"ld4.s.nt1",      M, OpMXX6aHint (4, 0, 0, 0x06, 1), {R1, MR3}},
-    {"ld4.s.nta",      M, OpMXX6aHint (4, 0, 0, 0x06, 3), {R1, MR3}},
-    {"ld8.s",          M, OpMXX6aHint (4, 0, 0, 0x07, 0), {R1, MR3}},
-    {"ld8.s.nt1",      M, OpMXX6aHint (4, 0, 0, 0x07, 1), {R1, MR3}},
-    {"ld8.s.nta",      M, OpMXX6aHint (4, 0, 0, 0x07, 3), {R1, MR3}},
-    {"ld1.a",          M, OpMXX6aHint (4, 0, 0, 0x08, 0), {R1, MR3}},
-    {"ld1.a.nt1",      M, OpMXX6aHint (4, 0, 0, 0x08, 1), {R1, MR3}},
-    {"ld1.a.nta",      M, OpMXX6aHint (4, 0, 0, 0x08, 3), {R1, MR3}},
-    {"ld2.a",          M, OpMXX6aHint (4, 0, 0, 0x09, 0), {R1, MR3}},
-    {"ld2.a.nt1",      M, OpMXX6aHint (4, 0, 0, 0x09, 1), {R1, MR3}},
-    {"ld2.a.nta",      M, OpMXX6aHint (4, 0, 0, 0x09, 3), {R1, MR3}},
-    {"ld4.a",          M, OpMXX6aHint (4, 0, 0, 0x0a, 0), {R1, MR3}},
-    {"ld4.a.nt1",      M, OpMXX6aHint (4, 0, 0, 0x0a, 1), {R1, MR3}},
-    {"ld4.a.nta",      M, OpMXX6aHint (4, 0, 0, 0x0a, 3), {R1, MR3}},
-    {"ld8.a",          M, OpMXX6aHint (4, 0, 0, 0x0b, 0), {R1, MR3}},
-    {"ld8.a.nt1",      M, OpMXX6aHint (4, 0, 0, 0x0b, 1), {R1, MR3}},
-    {"ld8.a.nta",      M, OpMXX6aHint (4, 0, 0, 0x0b, 3), {R1, MR3}},
-    {"ld1.sa",         M, OpMXX6aHint (4, 0, 0, 0x0c, 0), {R1, MR3}},
-    {"ld1.sa.nt1",     M, OpMXX6aHint (4, 0, 0, 0x0c, 1), {R1, MR3}},
-    {"ld1.sa.nta",     M, OpMXX6aHint (4, 0, 0, 0x0c, 3), {R1, MR3}},
-    {"ld2.sa",         M, OpMXX6aHint (4, 0, 0, 0x0d, 0), {R1, MR3}},
-    {"ld2.sa.nt1",     M, OpMXX6aHint (4, 0, 0, 0x0d, 1), {R1, MR3}},
-    {"ld2.sa.nta",     M, OpMXX6aHint (4, 0, 0, 0x0d, 3), {R1, MR3}},
-    {"ld4.sa",         M, OpMXX6aHint (4, 0, 0, 0x0e, 0), {R1, MR3}},
-    {"ld4.sa.nt1",     M, OpMXX6aHint (4, 0, 0, 0x0e, 1), {R1, MR3}},
-    {"ld4.sa.nta",     M, OpMXX6aHint (4, 0, 0, 0x0e, 3), {R1, MR3}},
-    {"ld8.sa",         M, OpMXX6aHint (4, 0, 0, 0x0f, 0), {R1, MR3}},
-    {"ld8.sa.nt1",     M, OpMXX6aHint (4, 0, 0, 0x0f, 1), {R1, MR3}},
-    {"ld8.sa.nta",     M, OpMXX6aHint (4, 0, 0, 0x0f, 3), {R1, MR3}},
-    {"ld1.bias",       M, OpMXX6aHint (4, 0, 0, 0x10, 0), {R1, MR3}},
-    {"ld1.bias.nt1",   M, OpMXX6aHint (4, 0, 0, 0x10, 1), {R1, MR3}},
-    {"ld1.bias.nta",   M, OpMXX6aHint (4, 0, 0, 0x10, 3), {R1, MR3}},
-    {"ld2.bias",       M, OpMXX6aHint (4, 0, 0, 0x11, 0), {R1, MR3}},
-    {"ld2.bias.nt1",   M, OpMXX6aHint (4, 0, 0, 0x11, 1), {R1, MR3}},
-    {"ld2.bias.nta",   M, OpMXX6aHint (4, 0, 0, 0x11, 3), {R1, MR3}},
-    {"ld4.bias",       M, OpMXX6aHint (4, 0, 0, 0x12, 0), {R1, MR3}},
-    {"ld4.bias.nt1",   M, OpMXX6aHint (4, 0, 0, 0x12, 1), {R1, MR3}},
-    {"ld4.bias.nta",   M, OpMXX6aHint (4, 0, 0, 0x12, 3), {R1, MR3}},
-    {"ld8.bias",       M, OpMXX6aHint (4, 0, 0, 0x13, 0), {R1, MR3}},
-    {"ld8.bias.nt1",   M, OpMXX6aHint (4, 0, 0, 0x13, 1), {R1, MR3}},
-    {"ld8.bias.nta",   M, OpMXX6aHint (4, 0, 0, 0x13, 3), {R1, MR3}},
-    {"ld1.acq",                M, OpMXX6aHint (4, 0, 0, 0x14, 0), {R1, MR3}},
-    {"ld1.acq.nt1",    M, OpMXX6aHint (4, 0, 0, 0x14, 1), {R1, MR3}},
-    {"ld1.acq.nta",    M, OpMXX6aHint (4, 0, 0, 0x14, 3), {R1, MR3}},
-    {"ld2.acq",                M, OpMXX6aHint (4, 0, 0, 0x15, 0), {R1, MR3}},
-    {"ld2.acq.nt1",    M, OpMXX6aHint (4, 0, 0, 0x15, 1), {R1, MR3}},
-    {"ld2.acq.nta",    M, OpMXX6aHint (4, 0, 0, 0x15, 3), {R1, MR3}},
-    {"ld4.acq",                M, OpMXX6aHint (4, 0, 0, 0x16, 0), {R1, MR3}},
-    {"ld4.acq.nt1",    M, OpMXX6aHint (4, 0, 0, 0x16, 1), {R1, MR3}},
-    {"ld4.acq.nta",    M, OpMXX6aHint (4, 0, 0, 0x16, 3), {R1, MR3}},
-    {"ld8.acq",                M, OpMXX6aHint (4, 0, 0, 0x17, 0), {R1, MR3}},
-    {"ld8.acq.nt1",    M, OpMXX6aHint (4, 0, 0, 0x17, 1), {R1, MR3}},
-    {"ld8.acq.nta",    M, OpMXX6aHint (4, 0, 0, 0x17, 3), {R1, MR3}},
-    {"ld8.fill",       M, OpMXX6aHint (4, 0, 0, 0x1b, 0), {R1, MR3}},
-    {"ld8.fill.nt1",   M, OpMXX6aHint (4, 0, 0, 0x1b, 1), {R1, MR3}},
-    {"ld8.fill.nta",   M, OpMXX6aHint (4, 0, 0, 0x1b, 3), {R1, MR3}},
-    {"ld1.c.clr",      M, OpMXX6aHint (4, 0, 0, 0x20, 0), {R1, MR3}},
-    {"ld1.c.clr.nt1",  M, OpMXX6aHint (4, 0, 0, 0x20, 1), {R1, MR3}},
-    {"ld1.c.clr.nta",  M, OpMXX6aHint (4, 0, 0, 0x20, 3), {R1, MR3}},
-    {"ld2.c.clr",      M, OpMXX6aHint (4, 0, 0, 0x21, 0), {R1, MR3}},
-    {"ld2.c.clr.nt1",  M, OpMXX6aHint (4, 0, 0, 0x21, 1), {R1, MR3}},
-    {"ld2.c.clr.nta",  M, OpMXX6aHint (4, 0, 0, 0x21, 3), {R1, MR3}},
-    {"ld4.c.clr",      M, OpMXX6aHint (4, 0, 0, 0x22, 0), {R1, MR3}},
-    {"ld4.c.clr.nt1",  M, OpMXX6aHint (4, 0, 0, 0x22, 1), {R1, MR3}},
-    {"ld4.c.clr.nta",  M, OpMXX6aHint (4, 0, 0, 0x22, 3), {R1, MR3}},
-    {"ld8.c.clr",      M, OpMXX6aHint (4, 0, 0, 0x23, 0), {R1, MR3}},
-    {"ld8.c.clr.nt1",  M, OpMXX6aHint (4, 0, 0, 0x23, 1), {R1, MR3}},
-    {"ld8.c.clr.nta",  M, OpMXX6aHint (4, 0, 0, 0x23, 3), {R1, MR3}},
-    {"ld1.c.nc",       M, OpMXX6aHint (4, 0, 0, 0x24, 0), {R1, MR3}},
-    {"ld1.c.nc.nt1",   M, OpMXX6aHint (4, 0, 0, 0x24, 1), {R1, MR3}},
-    {"ld1.c.nc.nta",   M, OpMXX6aHint (4, 0, 0, 0x24, 3), {R1, MR3}},
-    {"ld2.c.nc",       M, OpMXX6aHint (4, 0, 0, 0x25, 0), {R1, MR3}},
-    {"ld2.c.nc.nt1",   M, OpMXX6aHint (4, 0, 0, 0x25, 1), {R1, MR3}},
-    {"ld2.c.nc.nta",   M, OpMXX6aHint (4, 0, 0, 0x25, 3), {R1, MR3}},
-    {"ld4.c.nc",       M, OpMXX6aHint (4, 0, 0, 0x26, 0), {R1, MR3}},
-    {"ld4.c.nc.nt1",   M, OpMXX6aHint (4, 0, 0, 0x26, 1), {R1, MR3}},
-    {"ld4.c.nc.nta",   M, OpMXX6aHint (4, 0, 0, 0x26, 3), {R1, MR3}},
-    {"ld8.c.nc",       M, OpMXX6aHint (4, 0, 0, 0x27, 0), {R1, MR3}},
-    {"ld8.c.nc.nt1",   M, OpMXX6aHint (4, 0, 0, 0x27, 1), {R1, MR3}},
-    {"ld8.c.nc.nta",   M, OpMXX6aHint (4, 0, 0, 0x27, 3), {R1, MR3}},
-    {"ld1.c.clr.acq",    M, OpMXX6aHint (4, 0, 0, 0x28, 0), {R1, MR3}},
-    {"ld1.c.clr.acq.nt1", M, OpMXX6aHint (4, 0, 0, 0x28, 1), {R1, MR3}},
-    {"ld1.c.clr.acq.nta", M, OpMXX6aHint (4, 0, 0, 0x28, 3), {R1, MR3}},
-    {"ld2.c.clr.acq",    M, OpMXX6aHint (4, 0, 0, 0x29, 0), {R1, MR3}},
-    {"ld2.c.clr.acq.nt1", M, OpMXX6aHint (4, 0, 0, 0x29, 1), {R1, MR3}},
-    {"ld2.c.clr.acq.nta", M, OpMXX6aHint (4, 0, 0, 0x29, 3), {R1, MR3}},
-    {"ld4.c.clr.acq",    M, OpMXX6aHint (4, 0, 0, 0x2a, 0), {R1, MR3}},
-    {"ld4.c.clr.acq.nt1", M, OpMXX6aHint (4, 0, 0, 0x2a, 1), {R1, MR3}},
-    {"ld4.c.clr.acq.nta", M, OpMXX6aHint (4, 0, 0, 0x2a, 3), {R1, MR3}},
-    {"ld8.c.clr.acq",    M, OpMXX6aHint (4, 0, 0, 0x2b, 0), {R1, MR3}},
-    {"ld8.c.clr.acq.nt1", M, OpMXX6aHint (4, 0, 0, 0x2b, 1), {R1, MR3}},
-    {"ld8.c.clr.acq.nta", M, OpMXX6aHint (4, 0, 0, 0x2b, 3), {R1, MR3}},
+    {"ld1",            M, OpMXX6aHint (4, 0, 0, 0x00, 0), {R1, MR3}, EMPTY},
+    {"ld1.nt1",                M, OpMXX6aHint (4, 0, 0, 0x00, 1), {R1, MR3}, EMPTY},
+    {"ld1.nta",                M, OpMXX6aHint (4, 0, 0, 0x00, 3), {R1, MR3}, EMPTY},
+    {"ld2",            M, OpMXX6aHint (4, 0, 0, 0x01, 0), {R1, MR3}, EMPTY},
+    {"ld2.nt1",                M, OpMXX6aHint (4, 0, 0, 0x01, 1), {R1, MR3}, EMPTY},
+    {"ld2.nta",                M, OpMXX6aHint (4, 0, 0, 0x01, 3), {R1, MR3}, EMPTY},
+    {"ld4",            M, OpMXX6aHint (4, 0, 0, 0x02, 0), {R1, MR3}, EMPTY},
+    {"ld4.nt1",                M, OpMXX6aHint (4, 0, 0, 0x02, 1), {R1, MR3}, EMPTY},
+    {"ld4.nta",                M, OpMXX6aHint (4, 0, 0, 0x02, 3), {R1, MR3}, EMPTY},
+    {"ld8",            M, OpMXX6aHint (4, 0, 0, 0x03, 0), {R1, MR3}, EMPTY},
+    {"ld8.nt1",                M, OpMXX6aHint (4, 0, 0, 0x03, 1), {R1, MR3}, EMPTY},
+    {"ld8.nta",                M, OpMXX6aHint (4, 0, 0, 0x03, 3), {R1, MR3}, EMPTY},
+    {"ld16",           M2, OpMXX6aHint (4, 0, 1, 0x28, 0), {R1, AR_CSD, MR3}, EMPTY},
+    {"ld16.nt1",       M2, OpMXX6aHint (4, 0, 1, 0x28, 1), {R1, AR_CSD, MR3}, EMPTY},
+    {"ld16.nta",       M2, OpMXX6aHint (4, 0, 1, 0x28, 3), {R1, AR_CSD, MR3}, EMPTY},
+    {"ld1.s",          M, OpMXX6aHint (4, 0, 0, 0x04, 0), {R1, MR3}, EMPTY},
+    {"ld1.s.nt1",      M, OpMXX6aHint (4, 0, 0, 0x04, 1), {R1, MR3}, EMPTY},
+    {"ld1.s.nta",      M, OpMXX6aHint (4, 0, 0, 0x04, 3), {R1, MR3}, EMPTY},
+    {"ld2.s",          M, OpMXX6aHint (4, 0, 0, 0x05, 0), {R1, MR3}, EMPTY},
+    {"ld2.s.nt1",      M, OpMXX6aHint (4, 0, 0, 0x05, 1), {R1, MR3}, EMPTY},
+    {"ld2.s.nta",      M, OpMXX6aHint (4, 0, 0, 0x05, 3), {R1, MR3}, EMPTY},
+    {"ld4.s",          M, OpMXX6aHint (4, 0, 0, 0x06, 0), {R1, MR3}, EMPTY},
+    {"ld4.s.nt1",      M, OpMXX6aHint (4, 0, 0, 0x06, 1), {R1, MR3}, EMPTY},
+    {"ld4.s.nta",      M, OpMXX6aHint (4, 0, 0, 0x06, 3), {R1, MR3}, EMPTY},
+    {"ld8.s",          M, OpMXX6aHint (4, 0, 0, 0x07, 0), {R1, MR3}, EMPTY},
+    {"ld8.s.nt1",      M, OpMXX6aHint (4, 0, 0, 0x07, 1), {R1, MR3}, EMPTY},
+    {"ld8.s.nta",      M, OpMXX6aHint (4, 0, 0, 0x07, 3), {R1, MR3}, EMPTY},
+    {"ld1.a",          M, OpMXX6aHint (4, 0, 0, 0x08, 0), {R1, MR3}, EMPTY},
+    {"ld1.a.nt1",      M, OpMXX6aHint (4, 0, 0, 0x08, 1), {R1, MR3}, EMPTY},
+    {"ld1.a.nta",      M, OpMXX6aHint (4, 0, 0, 0x08, 3), {R1, MR3}, EMPTY},
+    {"ld2.a",          M, OpMXX6aHint (4, 0, 0, 0x09, 0), {R1, MR3}, EMPTY},
+    {"ld2.a.nt1",      M, OpMXX6aHint (4, 0, 0, 0x09, 1), {R1, MR3}, EMPTY},
+    {"ld2.a.nta",      M, OpMXX6aHint (4, 0, 0, 0x09, 3), {R1, MR3}, EMPTY},
+    {"ld4.a",          M, OpMXX6aHint (4, 0, 0, 0x0a, 0), {R1, MR3}, EMPTY},
+    {"ld4.a.nt1",      M, OpMXX6aHint (4, 0, 0, 0x0a, 1), {R1, MR3}, EMPTY},
+    {"ld4.a.nta",      M, OpMXX6aHint (4, 0, 0, 0x0a, 3), {R1, MR3}, EMPTY},
+    {"ld8.a",          M, OpMXX6aHint (4, 0, 0, 0x0b, 0), {R1, MR3}, EMPTY},
+    {"ld8.a.nt1",      M, OpMXX6aHint (4, 0, 0, 0x0b, 1), {R1, MR3}, EMPTY},
+    {"ld8.a.nta",      M, OpMXX6aHint (4, 0, 0, 0x0b, 3), {R1, MR3}, EMPTY},
+    {"ld1.sa",         M, OpMXX6aHint (4, 0, 0, 0x0c, 0), {R1, MR3}, EMPTY},
+    {"ld1.sa.nt1",     M, OpMXX6aHint (4, 0, 0, 0x0c, 1), {R1, MR3}, EMPTY},
+    {"ld1.sa.nta",     M, OpMXX6aHint (4, 0, 0, 0x0c, 3), {R1, MR3}, EMPTY},
+    {"ld2.sa",         M, OpMXX6aHint (4, 0, 0, 0x0d, 0), {R1, MR3}, EMPTY},
+    {"ld2.sa.nt1",     M, OpMXX6aHint (4, 0, 0, 0x0d, 1), {R1, MR3}, EMPTY},
+    {"ld2.sa.nta",     M, OpMXX6aHint (4, 0, 0, 0x0d, 3), {R1, MR3}, EMPTY},
+    {"ld4.sa",         M, OpMXX6aHint (4, 0, 0, 0x0e, 0), {R1, MR3}, EMPTY},
+    {"ld4.sa.nt1",     M, OpMXX6aHint (4, 0, 0, 0x0e, 1), {R1, MR3}, EMPTY},
+    {"ld4.sa.nta",     M, OpMXX6aHint (4, 0, 0, 0x0e, 3), {R1, MR3}, EMPTY},
+    {"ld8.sa",         M, OpMXX6aHint (4, 0, 0, 0x0f, 0), {R1, MR3}, EMPTY},
+    {"ld8.sa.nt1",     M, OpMXX6aHint (4, 0, 0, 0x0f, 1), {R1, MR3}, EMPTY},
+    {"ld8.sa.nta",     M, OpMXX6aHint (4, 0, 0, 0x0f, 3), {R1, MR3}, EMPTY},
+    {"ld1.bias",       M, OpMXX6aHint (4, 0, 0, 0x10, 0), {R1, MR3}, EMPTY},
+    {"ld1.bias.nt1",   M, OpMXX6aHint (4, 0, 0, 0x10, 1), {R1, MR3}, EMPTY},
+    {"ld1.bias.nta",   M, OpMXX6aHint (4, 0, 0, 0x10, 3), {R1, MR3}, EMPTY},
+    {"ld2.bias",       M, OpMXX6aHint (4, 0, 0, 0x11, 0), {R1, MR3}, EMPTY},
+    {"ld2.bias.nt1",   M, OpMXX6aHint (4, 0, 0, 0x11, 1), {R1, MR3}, EMPTY},
+    {"ld2.bias.nta",   M, OpMXX6aHint (4, 0, 0, 0x11, 3), {R1, MR3}, EMPTY},
+    {"ld4.bias",       M, OpMXX6aHint (4, 0, 0, 0x12, 0), {R1, MR3}, EMPTY},
+    {"ld4.bias.nt1",   M, OpMXX6aHint (4, 0, 0, 0x12, 1), {R1, MR3}, EMPTY},
+    {"ld4.bias.nta",   M, OpMXX6aHint (4, 0, 0, 0x12, 3), {R1, MR3}, EMPTY},
+    {"ld8.bias",       M, OpMXX6aHint (4, 0, 0, 0x13, 0), {R1, MR3}, EMPTY},
+    {"ld8.bias.nt1",   M, OpMXX6aHint (4, 0, 0, 0x13, 1), {R1, MR3}, EMPTY},
+    {"ld8.bias.nta",   M, OpMXX6aHint (4, 0, 0, 0x13, 3), {R1, MR3}, EMPTY},
+    {"ld1.acq",                M, OpMXX6aHint (4, 0, 0, 0x14, 0), {R1, MR3}, EMPTY},
+    {"ld1.acq.nt1",    M, OpMXX6aHint (4, 0, 0, 0x14, 1), {R1, MR3}, EMPTY},
+    {"ld1.acq.nta",    M, OpMXX6aHint (4, 0, 0, 0x14, 3), {R1, MR3}, EMPTY},
+    {"ld2.acq",                M, OpMXX6aHint (4, 0, 0, 0x15, 0), {R1, MR3}, EMPTY},
+    {"ld2.acq.nt1",    M, OpMXX6aHint (4, 0, 0, 0x15, 1), {R1, MR3}, EMPTY},
+    {"ld2.acq.nta",    M, OpMXX6aHint (4, 0, 0, 0x15, 3), {R1, MR3}, EMPTY},
+    {"ld4.acq",                M, OpMXX6aHint (4, 0, 0, 0x16, 0), {R1, MR3}, EMPTY},
+    {"ld4.acq.nt1",    M, OpMXX6aHint (4, 0, 0, 0x16, 1), {R1, MR3}, EMPTY},
+    {"ld4.acq.nta",    M, OpMXX6aHint (4, 0, 0, 0x16, 3), {R1, MR3}, EMPTY},
+    {"ld8.acq",                M, OpMXX6aHint (4, 0, 0, 0x17, 0), {R1, MR3}, EMPTY},
+    {"ld8.acq.nt1",    M, OpMXX6aHint (4, 0, 0, 0x17, 1), {R1, MR3}, EMPTY},
+    {"ld8.acq.nta",    M, OpMXX6aHint (4, 0, 0, 0x17, 3), {R1, MR3}, EMPTY},
+    {"ld16.acq",       M2, OpMXX6aHint (4, 0, 1, 0x2c, 0), {R1, AR_CSD, MR3}, EMPTY},
+    {"ld16.acq.nt1",   M2, OpMXX6aHint (4, 0, 1, 0x2c, 1), {R1, AR_CSD, MR3}, EMPTY},
+    {"ld16.acq.nta",   M2, OpMXX6aHint (4, 0, 1, 0x2c, 3), {R1, AR_CSD, MR3}, EMPTY},
+    {"ld8.fill",       M, OpMXX6aHint (4, 0, 0, 0x1b, 0), {R1, MR3}, EMPTY},
+    {"ld8.fill.nt1",   M, OpMXX6aHint (4, 0, 0, 0x1b, 1), {R1, MR3}, EMPTY},
+    {"ld8.fill.nta",   M, OpMXX6aHint (4, 0, 0, 0x1b, 3), {R1, MR3}, EMPTY},
+    {"ld1.c.clr",      M, OpMXX6aHint (4, 0, 0, 0x20, 0), {R1, MR3}, EMPTY},
+    {"ld1.c.clr.nt1",  M, OpMXX6aHint (4, 0, 0, 0x20, 1), {R1, MR3}, EMPTY},
+    {"ld1.c.clr.nta",  M, OpMXX6aHint (4, 0, 0, 0x20, 3), {R1, MR3}, EMPTY},
+    {"ld2.c.clr",      M, OpMXX6aHint (4, 0, 0, 0x21, 0), {R1, MR3}, EMPTY},
+    {"ld2.c.clr.nt1",  M, OpMXX6aHint (4, 0, 0, 0x21, 1), {R1, MR3}, EMPTY},
+    {"ld2.c.clr.nta",  M, OpMXX6aHint (4, 0, 0, 0x21, 3), {R1, MR3}, EMPTY},
+    {"ld4.c.clr",      M, OpMXX6aHint (4, 0, 0, 0x22, 0), {R1, MR3}, EMPTY},
+    {"ld4.c.clr.nt1",  M, OpMXX6aHint (4, 0, 0, 0x22, 1), {R1, MR3}, EMPTY},
+    {"ld4.c.clr.nta",  M, OpMXX6aHint (4, 0, 0, 0x22, 3), {R1, MR3}, EMPTY},
+    {"ld8.c.clr",      M, OpMXX6aHint (4, 0, 0, 0x23, 0), {R1, MR3}, EMPTY},
+    {"ld8.c.clr.nt1",  M, OpMXX6aHint (4, 0, 0, 0x23, 1), {R1, MR3}, EMPTY},
+    {"ld8.c.clr.nta",  M, OpMXX6aHint (4, 0, 0, 0x23, 3), {R1, MR3}, EMPTY},
+    {"ld1.c.nc",       M, OpMXX6aHint (4, 0, 0, 0x24, 0), {R1, MR3}, EMPTY},
+    {"ld1.c.nc.nt1",   M, OpMXX6aHint (4, 0, 0, 0x24, 1), {R1, MR3}, EMPTY},
+    {"ld1.c.nc.nta",   M, OpMXX6aHint (4, 0, 0, 0x24, 3), {R1, MR3}, EMPTY},
+    {"ld2.c.nc",       M, OpMXX6aHint (4, 0, 0, 0x25, 0), {R1, MR3}, EMPTY},
+    {"ld2.c.nc.nt1",   M, OpMXX6aHint (4, 0, 0, 0x25, 1), {R1, MR3}, EMPTY},
+    {"ld2.c.nc.nta",   M, OpMXX6aHint (4, 0, 0, 0x25, 3), {R1, MR3}, EMPTY},
+    {"ld4.c.nc",       M, OpMXX6aHint (4, 0, 0, 0x26, 0), {R1, MR3}, EMPTY},
+    {"ld4.c.nc.nt1",   M, OpMXX6aHint (4, 0, 0, 0x26, 1), {R1, MR3}, EMPTY},
+    {"ld4.c.nc.nta",   M, OpMXX6aHint (4, 0, 0, 0x26, 3), {R1, MR3}, EMPTY},
+    {"ld8.c.nc",       M, OpMXX6aHint (4, 0, 0, 0x27, 0), {R1, MR3}, EMPTY},
+    {"ld8.c.nc.nt1",   M, OpMXX6aHint (4, 0, 0, 0x27, 1), {R1, MR3}, EMPTY},
+    {"ld8.c.nc.nta",   M, OpMXX6aHint (4, 0, 0, 0x27, 3), {R1, MR3}, EMPTY},
+    {"ld1.c.clr.acq",    M, OpMXX6aHint (4, 0, 0, 0x28, 0), {R1, MR3}, EMPTY},
+    {"ld1.c.clr.acq.nt1", M, OpMXX6aHint (4, 0, 0, 0x28, 1), {R1, MR3}, EMPTY},
+    {"ld1.c.clr.acq.nta", M, OpMXX6aHint (4, 0, 0, 0x28, 3), {R1, MR3}, EMPTY},
+    {"ld2.c.clr.acq",    M, OpMXX6aHint (4, 0, 0, 0x29, 0), {R1, MR3}, EMPTY},
+    {"ld2.c.clr.acq.nt1", M, OpMXX6aHint (4, 0, 0, 0x29, 1), {R1, MR3}, EMPTY},
+    {"ld2.c.clr.acq.nta", M, OpMXX6aHint (4, 0, 0, 0x29, 3), {R1, MR3}, EMPTY},
+    {"ld4.c.clr.acq",    M, OpMXX6aHint (4, 0, 0, 0x2a, 0), {R1, MR3}, EMPTY},
+    {"ld4.c.clr.acq.nt1", M, OpMXX6aHint (4, 0, 0, 0x2a, 1), {R1, MR3}, EMPTY},
+    {"ld4.c.clr.acq.nta", M, OpMXX6aHint (4, 0, 0, 0x2a, 3), {R1, MR3}, EMPTY},
+    {"ld8.c.clr.acq",    M, OpMXX6aHint (4, 0, 0, 0x2b, 0), {R1, MR3}, EMPTY},
+    {"ld8.c.clr.acq.nt1", M, OpMXX6aHint (4, 0, 0, 0x2b, 1), {R1, MR3}, EMPTY},
+    {"ld8.c.clr.acq.nta", M, OpMXX6aHint (4, 0, 0, 0x2b, 3), {R1, MR3}, EMPTY},
+
+    /* Pseudo-op that generates ldxmov relocation.  */
+    {"ld8.mov",                M, OpMXX6aHint (4, 0, 0, 0x03, 0),
+     {R1, MR3, IA64_OPND_LDXMOV}, EMPTY},
 
-    /* integer load w/increment by register */
-    {"ld1",            M, OpMXX6aHint (4, 1, 0, 0x00, 0), {R1, MR3, R2}},
-    {"ld1.nt1",                M, OpMXX6aHint (4, 1, 0, 0x00, 1), {R1, MR3, R2}},
-    {"ld1.nta",                M, OpMXX6aHint (4, 1, 0, 0x00, 3), {R1, MR3, R2}},
-    {"ld2",            M, OpMXX6aHint (4, 1, 0, 0x01, 0), {R1, MR3, R2}},
-    {"ld2.nt1",                M, OpMXX6aHint (4, 1, 0, 0x01, 1), {R1, MR3, R2}},
-    {"ld2.nta",                M, OpMXX6aHint (4, 1, 0, 0x01, 3), {R1, MR3, R2}},
-    {"ld4",            M, OpMXX6aHint (4, 1, 0, 0x02, 0), {R1, MR3, R2}},
-    {"ld4.nt1",                M, OpMXX6aHint (4, 1, 0, 0x02, 1), {R1, MR3, R2}},
-    {"ld4.nta",                M, OpMXX6aHint (4, 1, 0, 0x02, 3), {R1, MR3, R2}},
-    {"ld8",            M, OpMXX6aHint (4, 1, 0, 0x03, 0), {R1, MR3, R2}},
-    {"ld8.nt1",                M, OpMXX6aHint (4, 1, 0, 0x03, 1), {R1, MR3, R2}},
-    {"ld8.nta",                M, OpMXX6aHint (4, 1, 0, 0x03, 3), {R1, MR3, R2}},
-    {"ld1.s",          M, OpMXX6aHint (4, 1, 0, 0x04, 0), {R1, MR3, R2}},
-    {"ld1.s.nt1",      M, OpMXX6aHint (4, 1, 0, 0x04, 1), {R1, MR3, R2}},
-    {"ld1.s.nta",      M, OpMXX6aHint (4, 1, 0, 0x04, 3), {R1, MR3, R2}},
-    {"ld2.s",          M, OpMXX6aHint (4, 1, 0, 0x05, 0), {R1, MR3, R2}},
-    {"ld2.s.nt1",      M, OpMXX6aHint (4, 1, 0, 0x05, 1), {R1, MR3, R2}},
-    {"ld2.s.nta",      M, OpMXX6aHint (4, 1, 0, 0x05, 3), {R1, MR3, R2}},
-    {"ld4.s",          M, OpMXX6aHint (4, 1, 0, 0x06, 0), {R1, MR3, R2}},
-    {"ld4.s.nt1",      M, OpMXX6aHint (4, 1, 0, 0x06, 1), {R1, MR3, R2}},
-    {"ld4.s.nta",      M, OpMXX6aHint (4, 1, 0, 0x06, 3), {R1, MR3, R2}},
-    {"ld8.s",          M, OpMXX6aHint (4, 1, 0, 0x07, 0), {R1, MR3, R2}},
-    {"ld8.s.nt1",      M, OpMXX6aHint (4, 1, 0, 0x07, 1), {R1, MR3, R2}},
-    {"ld8.s.nta",      M, OpMXX6aHint (4, 1, 0, 0x07, 3), {R1, MR3, R2}},
-    {"ld1.a",          M, OpMXX6aHint (4, 1, 0, 0x08, 0), {R1, MR3, R2}},
-    {"ld1.a.nt1",      M, OpMXX6aHint (4, 1, 0, 0x08, 1), {R1, MR3, R2}},
-    {"ld1.a.nta",      M, OpMXX6aHint (4, 1, 0, 0x08, 3), {R1, MR3, R2}},
-    {"ld2.a",          M, OpMXX6aHint (4, 1, 0, 0x09, 0), {R1, MR3, R2}},
-    {"ld2.a.nt1",      M, OpMXX6aHint (4, 1, 0, 0x09, 1), {R1, MR3, R2}},
-    {"ld2.a.nta",      M, OpMXX6aHint (4, 1, 0, 0x09, 3), {R1, MR3, R2}},
-    {"ld4.a",          M, OpMXX6aHint (4, 1, 0, 0x0a, 0), {R1, MR3, R2}},
-    {"ld4.a.nt1",      M, OpMXX6aHint (4, 1, 0, 0x0a, 1), {R1, MR3, R2}},
-    {"ld4.a.nta",      M, OpMXX6aHint (4, 1, 0, 0x0a, 3), {R1, MR3, R2}},
-    {"ld8.a",          M, OpMXX6aHint (4, 1, 0, 0x0b, 0), {R1, MR3, R2}},
-    {"ld8.a.nt1",      M, OpMXX6aHint (4, 1, 0, 0x0b, 1), {R1, MR3, R2}},
-    {"ld8.a.nta",      M, OpMXX6aHint (4, 1, 0, 0x0b, 3), {R1, MR3, R2}},
-    {"ld1.sa",         M, OpMXX6aHint (4, 1, 0, 0x0c, 0), {R1, MR3, R2}},
-    {"ld1.sa.nt1",     M, OpMXX6aHint (4, 1, 0, 0x0c, 1), {R1, MR3, R2}},
-    {"ld1.sa.nta",     M, OpMXX6aHint (4, 1, 0, 0x0c, 3), {R1, MR3, R2}},
-    {"ld2.sa",         M, OpMXX6aHint (4, 1, 0, 0x0d, 0), {R1, MR3, R2}},
-    {"ld2.sa.nt1",     M, OpMXX6aHint (4, 1, 0, 0x0d, 1), {R1, MR3, R2}},
-    {"ld2.sa.nta",     M, OpMXX6aHint (4, 1, 0, 0x0d, 3), {R1, MR3, R2}},
-    {"ld4.sa",         M, OpMXX6aHint (4, 1, 0, 0x0e, 0), {R1, MR3, R2}},
-    {"ld4.sa.nt1",     M, OpMXX6aHint (4, 1, 0, 0x0e, 1), {R1, MR3, R2}},
-    {"ld4.sa.nta",     M, OpMXX6aHint (4, 1, 0, 0x0e, 3), {R1, MR3, R2}},
-    {"ld8.sa",         M, OpMXX6aHint (4, 1, 0, 0x0f, 0), {R1, MR3, R2}},
-    {"ld8.sa.nt1",     M, OpMXX6aHint (4, 1, 0, 0x0f, 1), {R1, MR3, R2}},
-    {"ld8.sa.nta",     M, OpMXX6aHint (4, 1, 0, 0x0f, 3), {R1, MR3, R2}},
-    {"ld1.bias",       M, OpMXX6aHint (4, 1, 0, 0x10, 0), {R1, MR3, R2}},
-    {"ld1.bias.nt1",   M, OpMXX6aHint (4, 1, 0, 0x10, 1), {R1, MR3, R2}},
-    {"ld1.bias.nta",   M, OpMXX6aHint (4, 1, 0, 0x10, 3), {R1, MR3, R2}},
-    {"ld2.bias",       M, OpMXX6aHint (4, 1, 0, 0x11, 0), {R1, MR3, R2}},
-    {"ld2.bias.nt1",   M, OpMXX6aHint (4, 1, 0, 0x11, 1), {R1, MR3, R2}},
-    {"ld2.bias.nta",   M, OpMXX6aHint (4, 1, 0, 0x11, 3), {R1, MR3, R2}},
-    {"ld4.bias",       M, OpMXX6aHint (4, 1, 0, 0x12, 0), {R1, MR3, R2}},
-    {"ld4.bias.nt1",   M, OpMXX6aHint (4, 1, 0, 0x12, 1), {R1, MR3, R2}},
-    {"ld4.bias.nta",   M, OpMXX6aHint (4, 1, 0, 0x12, 3), {R1, MR3, R2}},
-    {"ld8.bias",       M, OpMXX6aHint (4, 1, 0, 0x13, 0), {R1, MR3, R2}},
-    {"ld8.bias.nt1",   M, OpMXX6aHint (4, 1, 0, 0x13, 1), {R1, MR3, R2}},
-    {"ld8.bias.nta",   M, OpMXX6aHint (4, 1, 0, 0x13, 3), {R1, MR3, R2}},
-    {"ld1.acq",                M, OpMXX6aHint (4, 1, 0, 0x14, 0), {R1, MR3, R2}},
-    {"ld1.acq.nt1",    M, OpMXX6aHint (4, 1, 0, 0x14, 1), {R1, MR3, R2}},
-    {"ld1.acq.nta",    M, OpMXX6aHint (4, 1, 0, 0x14, 3), {R1, MR3, R2}},
-    {"ld2.acq",                M, OpMXX6aHint (4, 1, 0, 0x15, 0), {R1, MR3, R2}},
-    {"ld2.acq.nt1",    M, OpMXX6aHint (4, 1, 0, 0x15, 1), {R1, MR3, R2}},
-    {"ld2.acq.nta",    M, OpMXX6aHint (4, 1, 0, 0x15, 3), {R1, MR3, R2}},
-    {"ld4.acq",                M, OpMXX6aHint (4, 1, 0, 0x16, 0), {R1, MR3, R2}},
-    {"ld4.acq.nt1",    M, OpMXX6aHint (4, 1, 0, 0x16, 1), {R1, MR3, R2}},
-    {"ld4.acq.nta",    M, OpMXX6aHint (4, 1, 0, 0x16, 3), {R1, MR3, R2}},
-    {"ld8.acq",                M, OpMXX6aHint (4, 1, 0, 0x17, 0), {R1, MR3, R2}},
-    {"ld8.acq.nt1",    M, OpMXX6aHint (4, 1, 0, 0x17, 1), {R1, MR3, R2}},
-    {"ld8.acq.nta",    M, OpMXX6aHint (4, 1, 0, 0x17, 3), {R1, MR3, R2}},
-    {"ld8.fill",       M, OpMXX6aHint (4, 1, 0, 0x1b, 0), {R1, MR3, R2}},
-    {"ld8.fill.nt1",   M, OpMXX6aHint (4, 1, 0, 0x1b, 1), {R1, MR3, R2}},
-    {"ld8.fill.nta",   M, OpMXX6aHint (4, 1, 0, 0x1b, 3), {R1, MR3, R2}},
-    {"ld1.c.clr",      M, OpMXX6aHint (4, 1, 0, 0x20, 0), {R1, MR3, R2}},
-    {"ld1.c.clr.nt1",  M, OpMXX6aHint (4, 1, 0, 0x20, 1), {R1, MR3, R2}},
-    {"ld1.c.clr.nta",  M, OpMXX6aHint (4, 1, 0, 0x20, 3), {R1, MR3, R2}},
-    {"ld2.c.clr",      M, OpMXX6aHint (4, 1, 0, 0x21, 0), {R1, MR3, R2}},
-    {"ld2.c.clr.nt1",  M, OpMXX6aHint (4, 1, 0, 0x21, 1), {R1, MR3, R2}},
-    {"ld2.c.clr.nta",  M, OpMXX6aHint (4, 1, 0, 0x21, 3), {R1, MR3, R2}},
-    {"ld4.c.clr",      M, OpMXX6aHint (4, 1, 0, 0x22, 0), {R1, MR3, R2}},
-    {"ld4.c.clr.nt1",  M, OpMXX6aHint (4, 1, 0, 0x22, 1), {R1, MR3, R2}},
-    {"ld4.c.clr.nta",  M, OpMXX6aHint (4, 1, 0, 0x22, 3), {R1, MR3, R2}},
-    {"ld8.c.clr",      M, OpMXX6aHint (4, 1, 0, 0x23, 0), {R1, MR3, R2}},
-    {"ld8.c.clr.nt1",  M, OpMXX6aHint (4, 1, 0, 0x23, 1), {R1, MR3, R2}},
-    {"ld8.c.clr.nta",  M, OpMXX6aHint (4, 1, 0, 0x23, 3), {R1, MR3, R2}},
-    {"ld1.c.nc",       M, OpMXX6aHint (4, 1, 0, 0x24, 0), {R1, MR3, R2}},
-    {"ld1.c.nc.nt1",   M, OpMXX6aHint (4, 1, 0, 0x24, 1), {R1, MR3, R2}},
-    {"ld1.c.nc.nta",   M, OpMXX6aHint (4, 1, 0, 0x24, 3), {R1, MR3, R2}},
-    {"ld2.c.nc",       M, OpMXX6aHint (4, 1, 0, 0x25, 0), {R1, MR3, R2}},
-    {"ld2.c.nc.nt1",   M, OpMXX6aHint (4, 1, 0, 0x25, 1), {R1, MR3, R2}},
-    {"ld2.c.nc.nta",   M, OpMXX6aHint (4, 1, 0, 0x25, 3), {R1, MR3, R2}},
-    {"ld4.c.nc",       M, OpMXX6aHint (4, 1, 0, 0x26, 0), {R1, MR3, R2}},
-    {"ld4.c.nc.nt1",   M, OpMXX6aHint (4, 1, 0, 0x26, 1), {R1, MR3, R2}},
-    {"ld4.c.nc.nta",   M, OpMXX6aHint (4, 1, 0, 0x26, 3), {R1, MR3, R2}},
-    {"ld8.c.nc",       M, OpMXX6aHint (4, 1, 0, 0x27, 0), {R1, MR3, R2}},
-    {"ld8.c.nc.nt1",   M, OpMXX6aHint (4, 1, 0, 0x27, 1), {R1, MR3, R2}},
-    {"ld8.c.nc.nta",   M, OpMXX6aHint (4, 1, 0, 0x27, 3), {R1, MR3, R2}},
-    {"ld1.c.clr.acq",    M, OpMXX6aHint (4, 1, 0, 0x28, 0), {R1, MR3, R2}},
-    {"ld1.c.clr.acq.nt1", M, OpMXX6aHint (4, 1, 0, 0x28, 1), {R1, MR3, R2}},
-    {"ld1.c.clr.acq.nta", M, OpMXX6aHint (4, 1, 0, 0x28, 3), {R1, MR3, R2}},
-    {"ld2.c.clr.acq",    M, OpMXX6aHint (4, 1, 0, 0x29, 0), {R1, MR3, R2}},
-    {"ld2.c.clr.acq.nt1", M, OpMXX6aHint (4, 1, 0, 0x29, 1), {R1, MR3, R2}},
-    {"ld2.c.clr.acq.nta", M, OpMXX6aHint (4, 1, 0, 0x29, 3), {R1, MR3, R2}},
-    {"ld4.c.clr.acq",    M, OpMXX6aHint (4, 1, 0, 0x2a, 0), {R1, MR3, R2}},
-    {"ld4.c.clr.acq.nt1", M, OpMXX6aHint (4, 1, 0, 0x2a, 1), {R1, MR3, R2}},
-    {"ld4.c.clr.acq.nta", M, OpMXX6aHint (4, 1, 0, 0x2a, 3), {R1, MR3, R2}},
-    {"ld8.c.clr.acq",    M, OpMXX6aHint (4, 1, 0, 0x2b, 0), {R1, MR3, R2}},
-    {"ld8.c.clr.acq.nt1", M, OpMXX6aHint (4, 1, 0, 0x2b, 1), {R1, MR3, R2}},
-    {"ld8.c.clr.acq.nta", M, OpMXX6aHint (4, 1, 0, 0x2b, 3), {R1, MR3, R2}},
+    /* Integer load w/increment by register.  */
+#define LDINCREG(c,h) M, OpMXX6aHint (4, 1, 0, c, h), {R1, MR3, R2}, POSTINC, 0, NULL
+    {"ld1",            LDINCREG (0x00, 0)},
+    {"ld1.nt1",                LDINCREG (0x00, 1)},
+    {"ld1.nta",                LDINCREG (0x00, 3)},
+    {"ld2",            LDINCREG (0x01, 0)},
+    {"ld2.nt1",                LDINCREG (0x01, 1)},
+    {"ld2.nta",                LDINCREG (0x01, 3)},
+    {"ld4",            LDINCREG (0x02, 0)},
+    {"ld4.nt1",                LDINCREG (0x02, 1)},
+    {"ld4.nta",                LDINCREG (0x02, 3)},
+    {"ld8",            LDINCREG (0x03, 0)},
+    {"ld8.nt1",                LDINCREG (0x03, 1)},
+    {"ld8.nta",                LDINCREG (0x03, 3)},
+    {"ld1.s",          LDINCREG (0x04, 0)},
+    {"ld1.s.nt1",      LDINCREG (0x04, 1)},
+    {"ld1.s.nta",      LDINCREG (0x04, 3)},
+    {"ld2.s",          LDINCREG (0x05, 0)},
+    {"ld2.s.nt1",      LDINCREG (0x05, 1)},
+    {"ld2.s.nta",      LDINCREG (0x05, 3)},
+    {"ld4.s",          LDINCREG (0x06, 0)},
+    {"ld4.s.nt1",      LDINCREG (0x06, 1)},
+    {"ld4.s.nta",      LDINCREG (0x06, 3)},
+    {"ld8.s",          LDINCREG (0x07, 0)},
+    {"ld8.s.nt1",      LDINCREG (0x07, 1)},
+    {"ld8.s.nta",      LDINCREG (0x07, 3)},
+    {"ld1.a",          LDINCREG (0x08, 0)},
+    {"ld1.a.nt1",      LDINCREG (0x08, 1)},
+    {"ld1.a.nta",      LDINCREG (0x08, 3)},
+    {"ld2.a",          LDINCREG (0x09, 0)},
+    {"ld2.a.nt1",      LDINCREG (0x09, 1)},
+    {"ld2.a.nta",      LDINCREG (0x09, 3)},
+    {"ld4.a",          LDINCREG (0x0a, 0)},
+    {"ld4.a.nt1",      LDINCREG (0x0a, 1)},
+    {"ld4.a.nta",      LDINCREG (0x0a, 3)},
+    {"ld8.a",          LDINCREG (0x0b, 0)},
+    {"ld8.a.nt1",      LDINCREG (0x0b, 1)},
+    {"ld8.a.nta",      LDINCREG (0x0b, 3)},
+    {"ld1.sa",         LDINCREG (0x0c, 0)},
+    {"ld1.sa.nt1",     LDINCREG (0x0c, 1)},
+    {"ld1.sa.nta",     LDINCREG (0x0c, 3)},
+    {"ld2.sa",         LDINCREG (0x0d, 0)},
+    {"ld2.sa.nt1",     LDINCREG (0x0d, 1)},
+    {"ld2.sa.nta",     LDINCREG (0x0d, 3)},
+    {"ld4.sa",         LDINCREG (0x0e, 0)},
+    {"ld4.sa.nt1",     LDINCREG (0x0e, 1)},
+    {"ld4.sa.nta",     LDINCREG (0x0e, 3)},
+    {"ld8.sa",         LDINCREG (0x0f, 0)},
+    {"ld8.sa.nt1",     LDINCREG (0x0f, 1)},
+    {"ld8.sa.nta",     LDINCREG (0x0f, 3)},
+    {"ld1.bias",       LDINCREG (0x10, 0)},
+    {"ld1.bias.nt1",   LDINCREG (0x10, 1)},
+    {"ld1.bias.nta",   LDINCREG (0x10, 3)},
+    {"ld2.bias",       LDINCREG (0x11, 0)},
+    {"ld2.bias.nt1",   LDINCREG (0x11, 1)},
+    {"ld2.bias.nta",   LDINCREG (0x11, 3)},
+    {"ld4.bias",       LDINCREG (0x12, 0)},
+    {"ld4.bias.nt1",   LDINCREG (0x12, 1)},
+    {"ld4.bias.nta",   LDINCREG (0x12, 3)},
+    {"ld8.bias",       LDINCREG (0x13, 0)},
+    {"ld8.bias.nt1",   LDINCREG (0x13, 1)},
+    {"ld8.bias.nta",   LDINCREG (0x13, 3)},
+    {"ld1.acq",                LDINCREG (0x14, 0)},
+    {"ld1.acq.nt1",    LDINCREG (0x14, 1)},
+    {"ld1.acq.nta",    LDINCREG (0x14, 3)},
+    {"ld2.acq",                LDINCREG (0x15, 0)},
+    {"ld2.acq.nt1",    LDINCREG (0x15, 1)},
+    {"ld2.acq.nta",    LDINCREG (0x15, 3)},
+    {"ld4.acq",                LDINCREG (0x16, 0)},
+    {"ld4.acq.nt1",    LDINCREG (0x16, 1)},
+    {"ld4.acq.nta",    LDINCREG (0x16, 3)},
+    {"ld8.acq",                LDINCREG (0x17, 0)},
+    {"ld8.acq.nt1",    LDINCREG (0x17, 1)},
+    {"ld8.acq.nta",    LDINCREG (0x17, 3)},
+    {"ld8.fill",       LDINCREG (0x1b, 0)},
+    {"ld8.fill.nt1",   LDINCREG (0x1b, 1)},
+    {"ld8.fill.nta",   LDINCREG (0x1b, 3)},
+    {"ld1.c.clr",      LDINCREG (0x20, 0)},
+    {"ld1.c.clr.nt1",  LDINCREG (0x20, 1)},
+    {"ld1.c.clr.nta",  LDINCREG (0x20, 3)},
+    {"ld2.c.clr",      LDINCREG (0x21, 0)},
+    {"ld2.c.clr.nt1",  LDINCREG (0x21, 1)},
+    {"ld2.c.clr.nta",  LDINCREG (0x21, 3)},
+    {"ld4.c.clr",      LDINCREG (0x22, 0)},
+    {"ld4.c.clr.nt1",  LDINCREG (0x22, 1)},
+    {"ld4.c.clr.nta",  LDINCREG (0x22, 3)},
+    {"ld8.c.clr",      LDINCREG (0x23, 0)},
+    {"ld8.c.clr.nt1",  LDINCREG (0x23, 1)},
+    {"ld8.c.clr.nta",  LDINCREG (0x23, 3)},
+    {"ld1.c.nc",       LDINCREG (0x24, 0)},
+    {"ld1.c.nc.nt1",   LDINCREG (0x24, 1)},
+    {"ld1.c.nc.nta",   LDINCREG (0x24, 3)},
+    {"ld2.c.nc",       LDINCREG (0x25, 0)},
+    {"ld2.c.nc.nt1",   LDINCREG (0x25, 1)},
+    {"ld2.c.nc.nta",   LDINCREG (0x25, 3)},
+    {"ld4.c.nc",       LDINCREG (0x26, 0)},
+    {"ld4.c.nc.nt1",   LDINCREG (0x26, 1)},
+    {"ld4.c.nc.nta",   LDINCREG (0x26, 3)},
+    {"ld8.c.nc",       LDINCREG (0x27, 0)},
+    {"ld8.c.nc.nt1",   LDINCREG (0x27, 1)},
+    {"ld8.c.nc.nta",   LDINCREG (0x27, 3)},
+    {"ld1.c.clr.acq",    LDINCREG (0x28, 0)},
+    {"ld1.c.clr.acq.nt1", LDINCREG (0x28, 1)},
+    {"ld1.c.clr.acq.nta", LDINCREG (0x28, 3)},
+    {"ld2.c.clr.acq",    LDINCREG (0x29, 0)},
+    {"ld2.c.clr.acq.nt1", LDINCREG (0x29, 1)},
+    {"ld2.c.clr.acq.nta", LDINCREG (0x29, 3)},
+    {"ld4.c.clr.acq",    LDINCREG (0x2a, 0)},
+    {"ld4.c.clr.acq.nt1", LDINCREG (0x2a, 1)},
+    {"ld4.c.clr.acq.nta", LDINCREG (0x2a, 3)},
+    {"ld8.c.clr.acq",    LDINCREG (0x2b, 0)},
+    {"ld8.c.clr.acq.nt1", LDINCREG (0x2b, 1)},
+    {"ld8.c.clr.acq.nta", LDINCREG (0x2b, 3)},
+#undef LDINCREG
 
-    {"st1",            M, OpMXX6aHint (4, 0, 0, 0x30, 0), {MR3, R2}},
-    {"st1.nta",                M, OpMXX6aHint (4, 0, 0, 0x30, 3), {MR3, R2}},
-    {"st2",            M, OpMXX6aHint (4, 0, 0, 0x31, 0), {MR3, R2}},
-    {"st2.nta",                M, OpMXX6aHint (4, 0, 0, 0x31, 3), {MR3, R2}},
-    {"st4",            M, OpMXX6aHint (4, 0, 0, 0x32, 0), {MR3, R2}},
-    {"st4.nta",                M, OpMXX6aHint (4, 0, 0, 0x32, 3), {MR3, R2}},
-    {"st8",            M, OpMXX6aHint (4, 0, 0, 0x33, 0), {MR3, R2}},
-    {"st8.nta",                M, OpMXX6aHint (4, 0, 0, 0x33, 3), {MR3, R2}},
-    {"st1.rel",                M, OpMXX6aHint (4, 0, 0, 0x34, 0), {MR3, R2}},
-    {"st1.rel.nta",    M, OpMXX6aHint (4, 0, 0, 0x34, 3), {MR3, R2}},
-    {"st2.rel",                M, OpMXX6aHint (4, 0, 0, 0x35, 0), {MR3, R2}},
-    {"st2.rel.nta",    M, OpMXX6aHint (4, 0, 0, 0x35, 3), {MR3, R2}},
-    {"st4.rel",                M, OpMXX6aHint (4, 0, 0, 0x36, 0), {MR3, R2}},
-    {"st4.rel.nta",    M, OpMXX6aHint (4, 0, 0, 0x36, 3), {MR3, R2}},
-    {"st8.rel",                M, OpMXX6aHint (4, 0, 0, 0x37, 0), {MR3, R2}},
-    {"st8.rel.nta",    M, OpMXX6aHint (4, 0, 0, 0x37, 3), {MR3, R2}},
-    {"st8.spill",      M, OpMXX6aHint (4, 0, 0, 0x3b, 0), {MR3, R2}},
-    {"st8.spill.nta",  M, OpMXX6aHint (4, 0, 0, 0x3b, 3), {MR3, R2}},
+    {"st1",            M, OpMXX6aHint (4, 0, 0, 0x30, 0), {MR3, R2}, EMPTY},
+    {"st1.nta",                M, OpMXX6aHint (4, 0, 0, 0x30, 3), {MR3, R2}, EMPTY},
+    {"st2",            M, OpMXX6aHint (4, 0, 0, 0x31, 0), {MR3, R2}, EMPTY},
+    {"st2.nta",                M, OpMXX6aHint (4, 0, 0, 0x31, 3), {MR3, R2}, EMPTY},
+    {"st4",            M, OpMXX6aHint (4, 0, 0, 0x32, 0), {MR3, R2}, EMPTY},
+    {"st4.nta",                M, OpMXX6aHint (4, 0, 0, 0x32, 3), {MR3, R2}, EMPTY},
+    {"st8",            M, OpMXX6aHint (4, 0, 0, 0x33, 0), {MR3, R2}, EMPTY},
+    {"st8.nta",                M, OpMXX6aHint (4, 0, 0, 0x33, 3), {MR3, R2}, EMPTY},
+    {"st16",           M, OpMXX6aHint (4, 0, 1, 0x30, 0), {MR3, R2, AR_CSD}, EMPTY},
+    {"st16.nta",       M, OpMXX6aHint (4, 0, 1, 0x30, 3), {MR3, R2, AR_CSD}, EMPTY},
+    {"st1.rel",                M, OpMXX6aHint (4, 0, 0, 0x34, 0), {MR3, R2}, EMPTY},
+    {"st1.rel.nta",    M, OpMXX6aHint (4, 0, 0, 0x34, 3), {MR3, R2}, EMPTY},
+    {"st2.rel",                M, OpMXX6aHint (4, 0, 0, 0x35, 0), {MR3, R2}, EMPTY},
+    {"st2.rel.nta",    M, OpMXX6aHint (4, 0, 0, 0x35, 3), {MR3, R2}, EMPTY},
+    {"st4.rel",                M, OpMXX6aHint (4, 0, 0, 0x36, 0), {MR3, R2}, EMPTY},
+    {"st4.rel.nta",    M, OpMXX6aHint (4, 0, 0, 0x36, 3), {MR3, R2}, EMPTY},
+    {"st8.rel",                M, OpMXX6aHint (4, 0, 0, 0x37, 0), {MR3, R2}, EMPTY},
+    {"st8.rel.nta",    M, OpMXX6aHint (4, 0, 0, 0x37, 3), {MR3, R2}, EMPTY},
+    {"st16.rel",       M, OpMXX6aHint (4, 0, 1, 0x34, 0), {MR3, R2, AR_CSD}, EMPTY},
+    {"st16.rel.nta",   M, OpMXX6aHint (4, 0, 1, 0x34, 3), {MR3, R2, AR_CSD}, EMPTY},
+    {"st8.spill",      M, OpMXX6aHint (4, 0, 0, 0x3b, 0), {MR3, R2}, EMPTY},
+    {"st8.spill.nta",  M, OpMXX6aHint (4, 0, 0, 0x3b, 3), {MR3, R2}, EMPTY},
 
-#define CMPXCHG(c,h)   M, OpMXX6aHint (4, 0, 1, c, h), {R1, MR3, R2, AR_CCV}
+#define CMPXCHG(c,h)   M, OpMXX6aHint (4, 0, 1, c, h), {R1, MR3, R2, AR_CCV}, EMPTY
+#define CMPXCHG16(c,h) M, OpMXX6aHint (4, 0, 1, c, h), {R1, MR3, R2, AR_CSD, AR_CCV}, EMPTY
     {"cmpxchg1.acq",           CMPXCHG (0x00, 0)},
     {"cmpxchg1.acq.nt1",       CMPXCHG (0x00, 1)},
     {"cmpxchg1.acq.nta",       CMPXCHG (0x00, 3)},
@@ -406,6 +437,9 @@ struct ia64_opcode ia64_opcodes_m[] =
     {"cmpxchg8.acq",           CMPXCHG (0x03, 0)},
     {"cmpxchg8.acq.nt1",       CMPXCHG (0x03, 1)},
     {"cmpxchg8.acq.nta",       CMPXCHG (0x03, 3)},
+    {"cmp8xchg16.acq",         CMPXCHG16 (0x20, 0)},
+    {"cmp8xchg16.acq.nt1",     CMPXCHG16 (0x20, 1)},
+    {"cmp8xchg16.acq.nta",     CMPXCHG16 (0x20, 3)},
     {"cmpxchg1.rel",           CMPXCHG (0x04, 0)},
     {"cmpxchg1.rel.nt1",       CMPXCHG (0x04, 1)},
     {"cmpxchg1.rel.nta",       CMPXCHG (0x04, 3)},
@@ -418,394 +452,405 @@ struct ia64_opcode ia64_opcodes_m[] =
     {"cmpxchg8.rel",           CMPXCHG (0x07, 0)},
     {"cmpxchg8.rel.nt1",       CMPXCHG (0x07, 1)},
     {"cmpxchg8.rel.nta",       CMPXCHG (0x07, 3)},
+    {"cmp8xchg16.rel",         CMPXCHG16 (0x24, 0)},
+    {"cmp8xchg16.rel.nt1",     CMPXCHG16 (0x24, 1)},
+    {"cmp8xchg16.rel.nta",     CMPXCHG16 (0x24, 3)},
 #undef CMPXCHG
-    {"xchg1",            M, OpMXX6aHint (4, 0, 1, 0x08, 0), {R1, MR3, R2}},
-    {"xchg1.nt1",        M, OpMXX6aHint (4, 0, 1, 0x08, 1), {R1, MR3, R2}},
-    {"xchg1.nta",        M, OpMXX6aHint (4, 0, 1, 0x08, 3), {R1, MR3, R2}},
-    {"xchg2",            M, OpMXX6aHint (4, 0, 1, 0x09, 0), {R1, MR3, R2}},
-    {"xchg2.nt1",        M, OpMXX6aHint (4, 0, 1, 0x09, 1), {R1, MR3, R2}},
-    {"xchg2.nta",        M, OpMXX6aHint (4, 0, 1, 0x09, 3), {R1, MR3, R2}},
-    {"xchg4",            M, OpMXX6aHint (4, 0, 1, 0x0a, 0), {R1, MR3, R2}},
-    {"xchg4.nt1",        M, OpMXX6aHint (4, 0, 1, 0x0a, 1), {R1, MR3, R2}},
-    {"xchg4.nta",        M, OpMXX6aHint (4, 0, 1, 0x0a, 3), {R1, MR3, R2}},
-    {"xchg8",            M, OpMXX6aHint (4, 0, 1, 0x0b, 0), {R1, MR3, R2}},
-    {"xchg8.nt1",        M, OpMXX6aHint (4, 0, 1, 0x0b, 1), {R1, MR3, R2}},
-    {"xchg8.nta",        M, OpMXX6aHint (4, 0, 1, 0x0b, 3), {R1, MR3, R2}},
+#undef CMPXCHG16
+    {"xchg1",            M, OpMXX6aHint (4, 0, 1, 0x08, 0), {R1, MR3, R2}, EMPTY},
+    {"xchg1.nt1",        M, OpMXX6aHint (4, 0, 1, 0x08, 1), {R1, MR3, R2}, EMPTY},
+    {"xchg1.nta",        M, OpMXX6aHint (4, 0, 1, 0x08, 3), {R1, MR3, R2}, EMPTY},
+    {"xchg2",            M, OpMXX6aHint (4, 0, 1, 0x09, 0), {R1, MR3, R2}, EMPTY},
+    {"xchg2.nt1",        M, OpMXX6aHint (4, 0, 1, 0x09, 1), {R1, MR3, R2}, EMPTY},
+    {"xchg2.nta",        M, OpMXX6aHint (4, 0, 1, 0x09, 3), {R1, MR3, R2}, EMPTY},
+    {"xchg4",            M, OpMXX6aHint (4, 0, 1, 0x0a, 0), {R1, MR3, R2}, EMPTY},
+    {"xchg4.nt1",        M, OpMXX6aHint (4, 0, 1, 0x0a, 1), {R1, MR3, R2}, EMPTY},
+    {"xchg4.nta",        M, OpMXX6aHint (4, 0, 1, 0x0a, 3), {R1, MR3, R2}, EMPTY},
+    {"xchg8",            M, OpMXX6aHint (4, 0, 1, 0x0b, 0), {R1, MR3, R2}, EMPTY},
+    {"xchg8.nt1",        M, OpMXX6aHint (4, 0, 1, 0x0b, 1), {R1, MR3, R2}, EMPTY},
+    {"xchg8.nta",        M, OpMXX6aHint (4, 0, 1, 0x0b, 3), {R1, MR3, R2}, EMPTY},
 
-    {"fetchadd4.acq",    M, OpMXX6aHint (4, 0, 1, 0x12, 0), {R1, MR3, INC3}},
-    {"fetchadd4.acq.nt1", M, OpMXX6aHint (4, 0, 1, 0x12, 1), {R1, MR3, INC3}},
-    {"fetchadd4.acq.nta", M, OpMXX6aHint (4, 0, 1, 0x12, 3), {R1, MR3, INC3}},
-    {"fetchadd8.acq",    M, OpMXX6aHint (4, 0, 1, 0x13, 0), {R1, MR3, INC3}},
-    {"fetchadd8.acq.nt1", M, OpMXX6aHint (4, 0, 1, 0x13, 1), {R1, MR3, INC3}},
-    {"fetchadd8.acq.nta", M, OpMXX6aHint (4, 0, 1, 0x13, 3), {R1, MR3, INC3}},
-    {"fetchadd4.rel",    M, OpMXX6aHint (4, 0, 1, 0x16, 0), {R1, MR3, INC3}},
-    {"fetchadd4.rel.nt1", M, OpMXX6aHint (4, 0, 1, 0x16, 1), {R1, MR3, INC3}},
-    {"fetchadd4.rel.nta", M, OpMXX6aHint (4, 0, 1, 0x16, 3), {R1, MR3, INC3}},
-    {"fetchadd8.rel",    M, OpMXX6aHint (4, 0, 1, 0x17, 0), {R1, MR3, INC3}},
-    {"fetchadd8.rel.nt1", M, OpMXX6aHint (4, 0, 1, 0x17, 1), {R1, MR3, INC3}},
-    {"fetchadd8.rel.nta", M, OpMXX6aHint (4, 0, 1, 0x17, 3), {R1, MR3, INC3}},
+    {"fetchadd4.acq",    M, OpMXX6aHint (4, 0, 1, 0x12, 0), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd4.acq.nt1", M, OpMXX6aHint (4, 0, 1, 0x12, 1), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd4.acq.nta", M, OpMXX6aHint (4, 0, 1, 0x12, 3), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd8.acq",    M, OpMXX6aHint (4, 0, 1, 0x13, 0), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd8.acq.nt1", M, OpMXX6aHint (4, 0, 1, 0x13, 1), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd8.acq.nta", M, OpMXX6aHint (4, 0, 1, 0x13, 3), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd4.rel",    M, OpMXX6aHint (4, 0, 1, 0x16, 0), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd4.rel.nt1", M, OpMXX6aHint (4, 0, 1, 0x16, 1), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd4.rel.nta", M, OpMXX6aHint (4, 0, 1, 0x16, 3), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd8.rel",    M, OpMXX6aHint (4, 0, 1, 0x17, 0), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd8.rel.nt1", M, OpMXX6aHint (4, 0, 1, 0x17, 1), {R1, MR3, INC3}, EMPTY},
+    {"fetchadd8.rel.nta", M, OpMXX6aHint (4, 0, 1, 0x17, 3), {R1, MR3, INC3}, EMPTY},
 
-    {"getf.sig",         M, OpMXX6a (4, 0, 1, 0x1c), {R1, F2}},
-    {"getf.exp",         M, OpMXX6a (4, 0, 1, 0x1d), {R1, F2}},
-    {"getf.s",           M, OpMXX6a (4, 0, 1, 0x1e), {R1, F2}},
-    {"getf.d",           M, OpMXX6a (4, 0, 1, 0x1f), {R1, F2}},
+    {"getf.sig",         M, OpMXX6a (4, 0, 1, 0x1c), {R1, F2}, EMPTY},
+    {"getf.exp",         M, OpMXX6a (4, 0, 1, 0x1d), {R1, F2}, EMPTY},
+    {"getf.s",           M, OpMXX6a (4, 0, 1, 0x1e), {R1, F2}, EMPTY},
+    {"getf.d",           M, OpMXX6a (4, 0, 1, 0x1f), {R1, F2}, EMPTY},
 
-    /* integer load w/increment by immediate */
-    {"ld1",            M, OpX6aHint (5, 0x00, 0), {R1, MR3, IMM9b}},
-    {"ld1.nt1",                M, OpX6aHint (5, 0x00, 1), {R1, MR3, IMM9b}},
-    {"ld1.nta",                M, OpX6aHint (5, 0x00, 3), {R1, MR3, IMM9b}},
-    {"ld2",            M, OpX6aHint (5, 0x01, 0), {R1, MR3, IMM9b}},
-    {"ld2.nt1",                M, OpX6aHint (5, 0x01, 1), {R1, MR3, IMM9b}},
-    {"ld2.nta",                M, OpX6aHint (5, 0x01, 3), {R1, MR3, IMM9b}},
-    {"ld4",            M, OpX6aHint (5, 0x02, 0), {R1, MR3, IMM9b}},
-    {"ld4.nt1",                M, OpX6aHint (5, 0x02, 1), {R1, MR3, IMM9b}},
-    {"ld4.nta",                M, OpX6aHint (5, 0x02, 3), {R1, MR3, IMM9b}},
-    {"ld8",            M, OpX6aHint (5, 0x03, 0), {R1, MR3, IMM9b}},
-    {"ld8.nt1",                M, OpX6aHint (5, 0x03, 1), {R1, MR3, IMM9b}},
-    {"ld8.nta",                M, OpX6aHint (5, 0x03, 3), {R1, MR3, IMM9b}},
-    {"ld1.s",          M, OpX6aHint (5, 0x04, 0), {R1, MR3, IMM9b}},
-    {"ld1.s.nt1",      M, OpX6aHint (5, 0x04, 1), {R1, MR3, IMM9b}},
-    {"ld1.s.nta",      M, OpX6aHint (5, 0x04, 3), {R1, MR3, IMM9b}},
-    {"ld2.s",          M, OpX6aHint (5, 0x05, 0), {R1, MR3, IMM9b}},
-    {"ld2.s.nt1",      M, OpX6aHint (5, 0x05, 1), {R1, MR3, IMM9b}},
-    {"ld2.s.nta",      M, OpX6aHint (5, 0x05, 3), {R1, MR3, IMM9b}},
-    {"ld4.s",          M, OpX6aHint (5, 0x06, 0), {R1, MR3, IMM9b}},
-    {"ld4.s.nt1",      M, OpX6aHint (5, 0x06, 1), {R1, MR3, IMM9b}},
-    {"ld4.s.nta",      M, OpX6aHint (5, 0x06, 3), {R1, MR3, IMM9b}},
-    {"ld8.s",          M, OpX6aHint (5, 0x07, 0), {R1, MR3, IMM9b}},
-    {"ld8.s.nt1",      M, OpX6aHint (5, 0x07, 1), {R1, MR3, IMM9b}},
-    {"ld8.s.nta",      M, OpX6aHint (5, 0x07, 3), {R1, MR3, IMM9b}},
-    {"ld1.a",          M, OpX6aHint (5, 0x08, 0), {R1, MR3, IMM9b}},
-    {"ld1.a.nt1",      M, OpX6aHint (5, 0x08, 1), {R1, MR3, IMM9b}},
-    {"ld1.a.nta",      M, OpX6aHint (5, 0x08, 3), {R1, MR3, IMM9b}},
-    {"ld2.a",          M, OpX6aHint (5, 0x09, 0), {R1, MR3, IMM9b}},
-    {"ld2.a.nt1",      M, OpX6aHint (5, 0x09, 1), {R1, MR3, IMM9b}},
-    {"ld2.a.nta",      M, OpX6aHint (5, 0x09, 3), {R1, MR3, IMM9b}},
-    {"ld4.a",          M, OpX6aHint (5, 0x0a, 0), {R1, MR3, IMM9b}},
-    {"ld4.a.nt1",      M, OpX6aHint (5, 0x0a, 1), {R1, MR3, IMM9b}},
-    {"ld4.a.nta",      M, OpX6aHint (5, 0x0a, 3), {R1, MR3, IMM9b}},
-    {"ld8.a",          M, OpX6aHint (5, 0x0b, 0), {R1, MR3, IMM9b}},
-    {"ld8.a.nt1",      M, OpX6aHint (5, 0x0b, 1), {R1, MR3, IMM9b}},
-    {"ld8.a.nta",      M, OpX6aHint (5, 0x0b, 3), {R1, MR3, IMM9b}},
-    {"ld1.sa",         M, OpX6aHint (5, 0x0c, 0), {R1, MR3, IMM9b}},
-    {"ld1.sa.nt1",     M, OpX6aHint (5, 0x0c, 1), {R1, MR3, IMM9b}},
-    {"ld1.sa.nta",     M, OpX6aHint (5, 0x0c, 3), {R1, MR3, IMM9b}},
-    {"ld2.sa",         M, OpX6aHint (5, 0x0d, 0), {R1, MR3, IMM9b}},
-    {"ld2.sa.nt1",     M, OpX6aHint (5, 0x0d, 1), {R1, MR3, IMM9b}},
-    {"ld2.sa.nta",     M, OpX6aHint (5, 0x0d, 3), {R1, MR3, IMM9b}},
-    {"ld4.sa",         M, OpX6aHint (5, 0x0e, 0), {R1, MR3, IMM9b}},
-    {"ld4.sa.nt1",     M, OpX6aHint (5, 0x0e, 1), {R1, MR3, IMM9b}},
-    {"ld4.sa.nta",     M, OpX6aHint (5, 0x0e, 3), {R1, MR3, IMM9b}},
-    {"ld8.sa",         M, OpX6aHint (5, 0x0f, 0), {R1, MR3, IMM9b}},
-    {"ld8.sa.nt1",     M, OpX6aHint (5, 0x0f, 1), {R1, MR3, IMM9b}},
-    {"ld8.sa.nta",     M, OpX6aHint (5, 0x0f, 3), {R1, MR3, IMM9b}},
-    {"ld1.bias",       M, OpX6aHint (5, 0x10, 0), {R1, MR3, IMM9b}},
-    {"ld1.bias.nt1",   M, OpX6aHint (5, 0x10, 1), {R1, MR3, IMM9b}},
-    {"ld1.bias.nta",   M, OpX6aHint (5, 0x10, 3), {R1, MR3, IMM9b}},
-    {"ld2.bias",       M, OpX6aHint (5, 0x11, 0), {R1, MR3, IMM9b}},
-    {"ld2.bias.nt1",   M, OpX6aHint (5, 0x11, 1), {R1, MR3, IMM9b}},
-    {"ld2.bias.nta",   M, OpX6aHint (5, 0x11, 3), {R1, MR3, IMM9b}},
-    {"ld4.bias",       M, OpX6aHint (5, 0x12, 0), {R1, MR3, IMM9b}},
-    {"ld4.bias.nt1",   M, OpX6aHint (5, 0x12, 1), {R1, MR3, IMM9b}},
-    {"ld4.bias.nta",   M, OpX6aHint (5, 0x12, 3), {R1, MR3, IMM9b}},
-    {"ld8.bias",       M, OpX6aHint (5, 0x13, 0), {R1, MR3, IMM9b}},
-    {"ld8.bias.nt1",   M, OpX6aHint (5, 0x13, 1), {R1, MR3, IMM9b}},
-    {"ld8.bias.nta",   M, OpX6aHint (5, 0x13, 3), {R1, MR3, IMM9b}},
-    {"ld1.acq",                M, OpX6aHint (5, 0x14, 0), {R1, MR3, IMM9b}},
-    {"ld1.acq.nt1",    M, OpX6aHint (5, 0x14, 1), {R1, MR3, IMM9b}},
-    {"ld1.acq.nta",    M, OpX6aHint (5, 0x14, 3), {R1, MR3, IMM9b}},
-    {"ld2.acq",                M, OpX6aHint (5, 0x15, 0), {R1, MR3, IMM9b}},
-    {"ld2.acq.nt1",    M, OpX6aHint (5, 0x15, 1), {R1, MR3, IMM9b}},
-    {"ld2.acq.nta",    M, OpX6aHint (5, 0x15, 3), {R1, MR3, IMM9b}},
-    {"ld4.acq",                M, OpX6aHint (5, 0x16, 0), {R1, MR3, IMM9b}},
-    {"ld4.acq.nt1",    M, OpX6aHint (5, 0x16, 1), {R1, MR3, IMM9b}},
-    {"ld4.acq.nta",    M, OpX6aHint (5, 0x16, 3), {R1, MR3, IMM9b}},
-    {"ld8.acq",                M, OpX6aHint (5, 0x17, 0), {R1, MR3, IMM9b}},
-    {"ld8.acq.nt1",    M, OpX6aHint (5, 0x17, 1), {R1, MR3, IMM9b}},
-    {"ld8.acq.nta",    M, OpX6aHint (5, 0x17, 3), {R1, MR3, IMM9b}},
-    {"ld8.fill",       M, OpX6aHint (5, 0x1b, 0), {R1, MR3, IMM9b}},
-    {"ld8.fill.nt1",   M, OpX6aHint (5, 0x1b, 1), {R1, MR3, IMM9b}},
-    {"ld8.fill.nta",   M, OpX6aHint (5, 0x1b, 3), {R1, MR3, IMM9b}},
-    {"ld1.c.clr",      M, OpX6aHint (5, 0x20, 0), {R1, MR3, IMM9b}},
-    {"ld1.c.clr.nt1",  M, OpX6aHint (5, 0x20, 1), {R1, MR3, IMM9b}},
-    {"ld1.c.clr.nta",  M, OpX6aHint (5, 0x20, 3), {R1, MR3, IMM9b}},
-    {"ld2.c.clr",      M, OpX6aHint (5, 0x21, 0), {R1, MR3, IMM9b}},
-    {"ld2.c.clr.nt1",  M, OpX6aHint (5, 0x21, 1), {R1, MR3, IMM9b}},
-    {"ld2.c.clr.nta",  M, OpX6aHint (5, 0x21, 3), {R1, MR3, IMM9b}},
-    {"ld4.c.clr",      M, OpX6aHint (5, 0x22, 0), {R1, MR3, IMM9b}},
-    {"ld4.c.clr.nt1",  M, OpX6aHint (5, 0x22, 1), {R1, MR3, IMM9b}},
-    {"ld4.c.clr.nta",  M, OpX6aHint (5, 0x22, 3), {R1, MR3, IMM9b}},
-    {"ld8.c.clr",      M, OpX6aHint (5, 0x23, 0), {R1, MR3, IMM9b}},
-    {"ld8.c.clr.nt1",  M, OpX6aHint (5, 0x23, 1), {R1, MR3, IMM9b}},
-    {"ld8.c.clr.nta",  M, OpX6aHint (5, 0x23, 3), {R1, MR3, IMM9b}},
-    {"ld1.c.nc",       M, OpX6aHint (5, 0x24, 0), {R1, MR3, IMM9b}},
-    {"ld1.c.nc.nt1",   M, OpX6aHint (5, 0x24, 1), {R1, MR3, IMM9b}},
-    {"ld1.c.nc.nta",   M, OpX6aHint (5, 0x24, 3), {R1, MR3, IMM9b}},
-    {"ld2.c.nc",       M, OpX6aHint (5, 0x25, 0), {R1, MR3, IMM9b}},
-    {"ld2.c.nc.nt1",   M, OpX6aHint (5, 0x25, 1), {R1, MR3, IMM9b}},
-    {"ld2.c.nc.nta",   M, OpX6aHint (5, 0x25, 3), {R1, MR3, IMM9b}},
-    {"ld4.c.nc",       M, OpX6aHint (5, 0x26, 0), {R1, MR3, IMM9b}},
-    {"ld4.c.nc.nt1",   M, OpX6aHint (5, 0x26, 1), {R1, MR3, IMM9b}},
-    {"ld4.c.nc.nta",   M, OpX6aHint (5, 0x26, 3), {R1, MR3, IMM9b}},
-    {"ld8.c.nc",       M, OpX6aHint (5, 0x27, 0), {R1, MR3, IMM9b}},
-    {"ld8.c.nc.nt1",   M, OpX6aHint (5, 0x27, 1), {R1, MR3, IMM9b}},
-    {"ld8.c.nc.nta",   M, OpX6aHint (5, 0x27, 3), {R1, MR3, IMM9b}},
-    {"ld1.c.clr.acq",    M, OpX6aHint (5, 0x28, 0), {R1, MR3, IMM9b}},
-    {"ld1.c.clr.acq.nt1", M, OpX6aHint (5, 0x28, 1), {R1, MR3, IMM9b}},
-    {"ld1.c.clr.acq.nta", M, OpX6aHint (5, 0x28, 3), {R1, MR3, IMM9b}},
-    {"ld2.c.clr.acq",    M, OpX6aHint (5, 0x29, 0), {R1, MR3, IMM9b}},
-    {"ld2.c.clr.acq.nt1", M, OpX6aHint (5, 0x29, 1), {R1, MR3, IMM9b}},
-    {"ld2.c.clr.acq.nta", M, OpX6aHint (5, 0x29, 3), {R1, MR3, IMM9b}},
-    {"ld4.c.clr.acq",    M, OpX6aHint (5, 0x2a, 0), {R1, MR3, IMM9b}},
-    {"ld4.c.clr.acq.nt1", M, OpX6aHint (5, 0x2a, 1), {R1, MR3, IMM9b}},
-    {"ld4.c.clr.acq.nta", M, OpX6aHint (5, 0x2a, 3), {R1, MR3, IMM9b}},
-    {"ld8.c.clr.acq",    M, OpX6aHint (5, 0x2b, 0), {R1, MR3, IMM9b}},
-    {"ld8.c.clr.acq.nt1", M, OpX6aHint (5, 0x2b, 1), {R1, MR3, IMM9b}},
-    {"ld8.c.clr.acq.nta", M, OpX6aHint (5, 0x2b, 3), {R1, MR3, IMM9b}},
+    /* Integer load w/increment by immediate.  */
+#define LDINCIMMED(c,h) M, OpX6aHint (5, c, h), {R1, MR3, IMM9b}, POSTINC, 0, NULL
+    {"ld1",            LDINCIMMED (0x00, 0)},
+    {"ld1.nt1",                LDINCIMMED (0x00, 1)},
+    {"ld1.nta",                LDINCIMMED (0x00, 3)},
+    {"ld2",            LDINCIMMED (0x01, 0)},
+    {"ld2.nt1",                LDINCIMMED (0x01, 1)},
+    {"ld2.nta",                LDINCIMMED (0x01, 3)},
+    {"ld4",            LDINCIMMED (0x02, 0)},
+    {"ld4.nt1",                LDINCIMMED (0x02, 1)},
+    {"ld4.nta",                LDINCIMMED (0x02, 3)},
+    {"ld8",            LDINCIMMED (0x03, 0)},
+    {"ld8.nt1",                LDINCIMMED (0x03, 1)},
+    {"ld8.nta",                LDINCIMMED (0x03, 3)},
+    {"ld1.s",          LDINCIMMED (0x04, 0)},
+    {"ld1.s.nt1",      LDINCIMMED (0x04, 1)},
+    {"ld1.s.nta",      LDINCIMMED (0x04, 3)},
+    {"ld2.s",          LDINCIMMED (0x05, 0)},
+    {"ld2.s.nt1",      LDINCIMMED (0x05, 1)},
+    {"ld2.s.nta",      LDINCIMMED (0x05, 3)},
+    {"ld4.s",          LDINCIMMED (0x06, 0)},
+    {"ld4.s.nt1",      LDINCIMMED (0x06, 1)},
+    {"ld4.s.nta",      LDINCIMMED (0x06, 3)},
+    {"ld8.s",          LDINCIMMED (0x07, 0)},
+    {"ld8.s.nt1",      LDINCIMMED (0x07, 1)},
+    {"ld8.s.nta",      LDINCIMMED (0x07, 3)},
+    {"ld1.a",          LDINCIMMED (0x08, 0)},
+    {"ld1.a.nt1",      LDINCIMMED (0x08, 1)},
+    {"ld1.a.nta",      LDINCIMMED (0x08, 3)},
+    {"ld2.a",          LDINCIMMED (0x09, 0)},
+    {"ld2.a.nt1",      LDINCIMMED (0x09, 1)},
+    {"ld2.a.nta",      LDINCIMMED (0x09, 3)},
+    {"ld4.a",          LDINCIMMED (0x0a, 0)},
+    {"ld4.a.nt1",      LDINCIMMED (0x0a, 1)},
+    {"ld4.a.nta",      LDINCIMMED (0x0a, 3)},
+    {"ld8.a",          LDINCIMMED (0x0b, 0)},
+    {"ld8.a.nt1",      LDINCIMMED (0x0b, 1)},
+    {"ld8.a.nta",      LDINCIMMED (0x0b, 3)},
+    {"ld1.sa",         LDINCIMMED (0x0c, 0)},
+    {"ld1.sa.nt1",     LDINCIMMED (0x0c, 1)},
+    {"ld1.sa.nta",     LDINCIMMED (0x0c, 3)},
+    {"ld2.sa",         LDINCIMMED (0x0d, 0)},
+    {"ld2.sa.nt1",     LDINCIMMED (0x0d, 1)},
+    {"ld2.sa.nta",     LDINCIMMED (0x0d, 3)},
+    {"ld4.sa",         LDINCIMMED (0x0e, 0)},
+    {"ld4.sa.nt1",     LDINCIMMED (0x0e, 1)},
+    {"ld4.sa.nta",     LDINCIMMED (0x0e, 3)},
+    {"ld8.sa",         LDINCIMMED (0x0f, 0)},
+    {"ld8.sa.nt1",     LDINCIMMED (0x0f, 1)},
+    {"ld8.sa.nta",     LDINCIMMED (0x0f, 3)},
+    {"ld1.bias",       LDINCIMMED (0x10, 0)},
+    {"ld1.bias.nt1",   LDINCIMMED (0x10, 1)},
+    {"ld1.bias.nta",   LDINCIMMED (0x10, 3)},
+    {"ld2.bias",       LDINCIMMED (0x11, 0)},
+    {"ld2.bias.nt1",   LDINCIMMED (0x11, 1)},
+    {"ld2.bias.nta",   LDINCIMMED (0x11, 3)},
+    {"ld4.bias",       LDINCIMMED (0x12, 0)},
+    {"ld4.bias.nt1",   LDINCIMMED (0x12, 1)},
+    {"ld4.bias.nta",   LDINCIMMED (0x12, 3)},
+    {"ld8.bias",       LDINCIMMED (0x13, 0)},
+    {"ld8.bias.nt1",   LDINCIMMED (0x13, 1)},
+    {"ld8.bias.nta",   LDINCIMMED (0x13, 3)},
+    {"ld1.acq",                LDINCIMMED (0x14, 0)},
+    {"ld1.acq.nt1",    LDINCIMMED (0x14, 1)},
+    {"ld1.acq.nta",    LDINCIMMED (0x14, 3)},
+    {"ld2.acq",                LDINCIMMED (0x15, 0)},
+    {"ld2.acq.nt1",    LDINCIMMED (0x15, 1)},
+    {"ld2.acq.nta",    LDINCIMMED (0x15, 3)},
+    {"ld4.acq",                LDINCIMMED (0x16, 0)},
+    {"ld4.acq.nt1",    LDINCIMMED (0x16, 1)},
+    {"ld4.acq.nta",    LDINCIMMED (0x16, 3)},
+    {"ld8.acq",                LDINCIMMED (0x17, 0)},
+    {"ld8.acq.nt1",    LDINCIMMED (0x17, 1)},
+    {"ld8.acq.nta",    LDINCIMMED (0x17, 3)},
+    {"ld8.fill",       LDINCIMMED (0x1b, 0)},
+    {"ld8.fill.nt1",   LDINCIMMED (0x1b, 1)},
+    {"ld8.fill.nta",   LDINCIMMED (0x1b, 3)},
+    {"ld1.c.clr",      LDINCIMMED (0x20, 0)},
+    {"ld1.c.clr.nt1",  LDINCIMMED (0x20, 1)},
+    {"ld1.c.clr.nta",  LDINCIMMED (0x20, 3)},
+    {"ld2.c.clr",      LDINCIMMED (0x21, 0)},
+    {"ld2.c.clr.nt1",  LDINCIMMED (0x21, 1)},
+    {"ld2.c.clr.nta",  LDINCIMMED (0x21, 3)},
+    {"ld4.c.clr",      LDINCIMMED (0x22, 0)},
+    {"ld4.c.clr.nt1",  LDINCIMMED (0x22, 1)},
+    {"ld4.c.clr.nta",  LDINCIMMED (0x22, 3)},
+    {"ld8.c.clr",      LDINCIMMED (0x23, 0)},
+    {"ld8.c.clr.nt1",  LDINCIMMED (0x23, 1)},
+    {"ld8.c.clr.nta",  LDINCIMMED (0x23, 3)},
+    {"ld1.c.nc",       LDINCIMMED (0x24, 0)},
+    {"ld1.c.nc.nt1",   LDINCIMMED (0x24, 1)},
+    {"ld1.c.nc.nta",   LDINCIMMED (0x24, 3)},
+    {"ld2.c.nc",       LDINCIMMED (0x25, 0)},
+    {"ld2.c.nc.nt1",   LDINCIMMED (0x25, 1)},
+    {"ld2.c.nc.nta",   LDINCIMMED (0x25, 3)},
+    {"ld4.c.nc",       LDINCIMMED (0x26, 0)},
+    {"ld4.c.nc.nt1",   LDINCIMMED (0x26, 1)},
+    {"ld4.c.nc.nta",   LDINCIMMED (0x26, 3)},
+    {"ld8.c.nc",       LDINCIMMED (0x27, 0)},
+    {"ld8.c.nc.nt1",   LDINCIMMED (0x27, 1)},
+    {"ld8.c.nc.nta",   LDINCIMMED (0x27, 3)},
+    {"ld1.c.clr.acq",    LDINCIMMED (0x28, 0)},
+    {"ld1.c.clr.acq.nt1", LDINCIMMED (0x28, 1)},
+    {"ld1.c.clr.acq.nta", LDINCIMMED (0x28, 3)},
+    {"ld2.c.clr.acq",    LDINCIMMED (0x29, 0)},
+    {"ld2.c.clr.acq.nt1", LDINCIMMED (0x29, 1)},
+    {"ld2.c.clr.acq.nta", LDINCIMMED (0x29, 3)},
+    {"ld4.c.clr.acq",    LDINCIMMED (0x2a, 0)},
+    {"ld4.c.clr.acq.nt1", LDINCIMMED (0x2a, 1)},
+    {"ld4.c.clr.acq.nta", LDINCIMMED (0x2a, 3)},
+    {"ld8.c.clr.acq",    LDINCIMMED (0x2b, 0)},
+    {"ld8.c.clr.acq.nt1", LDINCIMMED (0x2b, 1)},
+    {"ld8.c.clr.acq.nta", LDINCIMMED (0x2b, 3)},
+#undef LDINCIMMED
 
-    /* store w/increment by immediate */
-    {"st1",            M, OpX6aHint (5, 0x30, 0), {MR3, R2, IMM9a}},
-    {"st1.nta",                M, OpX6aHint (5, 0x30, 3), {MR3, R2, IMM9a}},
-    {"st2",            M, OpX6aHint (5, 0x31, 0), {MR3, R2, IMM9a}},
-    {"st2.nta",                M, OpX6aHint (5, 0x31, 3), {MR3, R2, IMM9a}},
-    {"st4",            M, OpX6aHint (5, 0x32, 0), {MR3, R2, IMM9a}},
-    {"st4.nta",                M, OpX6aHint (5, 0x32, 3), {MR3, R2, IMM9a}},
-    {"st8",            M, OpX6aHint (5, 0x33, 0), {MR3, R2, IMM9a}},
-    {"st8.nta",                M, OpX6aHint (5, 0x33, 3), {MR3, R2, IMM9a}},
-    {"st1.rel",                M, OpX6aHint (5, 0x34, 0), {MR3, R2, IMM9a}},
-    {"st1.rel.nta",    M, OpX6aHint (5, 0x34, 3), {MR3, R2, IMM9a}},
-    {"st2.rel",                M, OpX6aHint (5, 0x35, 0), {MR3, R2, IMM9a}},
-    {"st2.rel.nta",    M, OpX6aHint (5, 0x35, 3), {MR3, R2, IMM9a}},
-    {"st4.rel",                M, OpX6aHint (5, 0x36, 0), {MR3, R2, IMM9a}},
-    {"st4.rel.nta",    M, OpX6aHint (5, 0x36, 3), {MR3, R2, IMM9a}},
-    {"st8.rel",                M, OpX6aHint (5, 0x37, 0), {MR3, R2, IMM9a}},
-    {"st8.rel.nta",    M, OpX6aHint (5, 0x37, 3), {MR3, R2, IMM9a}},
-    {"st8.spill",      M, OpX6aHint (5, 0x3b, 0), {MR3, R2, IMM9a}},
-    {"st8.spill.nta",  M, OpX6aHint (5, 0x3b, 3), {MR3, R2, IMM9a}},
+    /* Store w/increment by immediate.  */
+#define STINCIMMED(c,h) M, OpX6aHint (5, c, h), {MR3, R2, IMM9a}, POSTINC, 0, NULL
+    {"st1",            STINCIMMED (0x30, 0)},
+    {"st1.nta",                STINCIMMED (0x30, 3)},
+    {"st2",            STINCIMMED (0x31, 0)},
+    {"st2.nta",                STINCIMMED (0x31, 3)},
+    {"st4",            STINCIMMED (0x32, 0)},
+    {"st4.nta",                STINCIMMED (0x32, 3)},
+    {"st8",            STINCIMMED (0x33, 0)},
+    {"st8.nta",                STINCIMMED (0x33, 3)},
+    {"st1.rel",                STINCIMMED (0x34, 0)},
+    {"st1.rel.nta",    STINCIMMED (0x34, 3)},
+    {"st2.rel",                STINCIMMED (0x35, 0)},
+    {"st2.rel.nta",    STINCIMMED (0x35, 3)},
+    {"st4.rel",                STINCIMMED (0x36, 0)},
+    {"st4.rel.nta",    STINCIMMED (0x36, 3)},
+    {"st8.rel",                STINCIMMED (0x37, 0)},
+    {"st8.rel.nta",    STINCIMMED (0x37, 3)},
+    {"st8.spill",      STINCIMMED (0x3b, 0)},
+    {"st8.spill.nta",  STINCIMMED (0x3b, 3)},
+#undef STINCIMMED
 
-    /* floating-point load */
-    {"ldfs",           M, OpMXX6aHint (6, 0, 0, 0x02, 0), {F1, MR3}},
-    {"ldfs.nt1",       M, OpMXX6aHint (6, 0, 0, 0x02, 1), {F1, MR3}},
-    {"ldfs.nta",       M, OpMXX6aHint (6, 0, 0, 0x02, 3), {F1, MR3}},
-    {"ldfd",           M, OpMXX6aHint (6, 0, 0, 0x03, 0), {F1, MR3}},
-    {"ldfd.nt1",       M, OpMXX6aHint (6, 0, 0, 0x03, 1), {F1, MR3}},
-    {"ldfd.nta",       M, OpMXX6aHint (6, 0, 0, 0x03, 3), {F1, MR3}},
-    {"ldf8",           M, OpMXX6aHint (6, 0, 0, 0x01, 0), {F1, MR3}},
-    {"ldf8.nt1",       M, OpMXX6aHint (6, 0, 0, 0x01, 1), {F1, MR3}},
-    {"ldf8.nta",       M, OpMXX6aHint (6, 0, 0, 0x01, 3), {F1, MR3}},
-    {"ldfe",           M, OpMXX6aHint (6, 0, 0, 0x00, 0), {F1, MR3}},
-    {"ldfe.nt1",       M, OpMXX6aHint (6, 0, 0, 0x00, 1), {F1, MR3}},
-    {"ldfe.nta",       M, OpMXX6aHint (6, 0, 0, 0x00, 3), {F1, MR3}},
-    {"ldfs.s",         M, OpMXX6aHint (6, 0, 0, 0x06, 0), {F1, MR3}},
-    {"ldfs.s.nt1",     M, OpMXX6aHint (6, 0, 0, 0x06, 1), {F1, MR3}},
-    {"ldfs.s.nta",     M, OpMXX6aHint (6, 0, 0, 0x06, 3), {F1, MR3}},
-    {"ldfd.s",         M, OpMXX6aHint (6, 0, 0, 0x07, 0), {F1, MR3}},
-    {"ldfd.s.nt1",     M, OpMXX6aHint (6, 0, 0, 0x07, 1), {F1, MR3}},
-    {"ldfd.s.nta",     M, OpMXX6aHint (6, 0, 0, 0x07, 3), {F1, MR3}},
-    {"ldf8.s",         M, OpMXX6aHint (6, 0, 0, 0x05, 0), {F1, MR3}},
-    {"ldf8.s.nt1",     M, OpMXX6aHint (6, 0, 0, 0x05, 1), {F1, MR3}},
-    {"ldf8.s.nta",     M, OpMXX6aHint (6, 0, 0, 0x05, 3), {F1, MR3}},
-    {"ldfe.s",         M, OpMXX6aHint (6, 0, 0, 0x04, 0), {F1, MR3}},
-    {"ldfe.s.nt1",     M, OpMXX6aHint (6, 0, 0, 0x04, 1), {F1, MR3}},
-    {"ldfe.s.nta",     M, OpMXX6aHint (6, 0, 0, 0x04, 3), {F1, MR3}},
-    {"ldfs.a",         M, OpMXX6aHint (6, 0, 0, 0x0a, 0), {F1, MR3}},
-    {"ldfs.a.nt1",     M, OpMXX6aHint (6, 0, 0, 0x0a, 1), {F1, MR3}},
-    {"ldfs.a.nta",     M, OpMXX6aHint (6, 0, 0, 0x0a, 3), {F1, MR3}},
-    {"ldfd.a",         M, OpMXX6aHint (6, 0, 0, 0x0b, 0), {F1, MR3}},
-    {"ldfd.a.nt1",     M, OpMXX6aHint (6, 0, 0, 0x0b, 1), {F1, MR3}},
-    {"ldfd.a.nta",     M, OpMXX6aHint (6, 0, 0, 0x0b, 3), {F1, MR3}},
-    {"ldf8.a",         M, OpMXX6aHint (6, 0, 0, 0x09, 0), {F1, MR3}},
-    {"ldf8.a.nt1",     M, OpMXX6aHint (6, 0, 0, 0x09, 1), {F1, MR3}},
-    {"ldf8.a.nta",     M, OpMXX6aHint (6, 0, 0, 0x09, 3), {F1, MR3}},
-    {"ldfe.a",         M, OpMXX6aHint (6, 0, 0, 0x08, 0), {F1, MR3}},
-    {"ldfe.a.nt1",     M, OpMXX6aHint (6, 0, 0, 0x08, 1), {F1, MR3}},
-    {"ldfe.a.nta",     M, OpMXX6aHint (6, 0, 0, 0x08, 3), {F1, MR3}},
-    {"ldfs.sa",                M, OpMXX6aHint (6, 0, 0, 0x0e, 0), {F1, MR3}},
-    {"ldfs.sa.nt1",    M, OpMXX6aHint (6, 0, 0, 0x0e, 1), {F1, MR3}},
-    {"ldfs.sa.nta",    M, OpMXX6aHint (6, 0, 0, 0x0e, 3), {F1, MR3}},
-    {"ldfd.sa",                M, OpMXX6aHint (6, 0, 0, 0x0f, 0), {F1, MR3}},
-    {"ldfd.sa.nt1",    M, OpMXX6aHint (6, 0, 0, 0x0f, 1), {F1, MR3}},
-    {"ldfd.sa.nta",    M, OpMXX6aHint (6, 0, 0, 0x0f, 3), {F1, MR3}},
-    {"ldf8.sa",                M, OpMXX6aHint (6, 0, 0, 0x0d, 0), {F1, MR3}},
-    {"ldf8.sa.nt1",    M, OpMXX6aHint (6, 0, 0, 0x0d, 1), {F1, MR3}},
-    {"ldf8.sa.nta",    M, OpMXX6aHint (6, 0, 0, 0x0d, 3), {F1, MR3}},
-    {"ldfe.sa",                M, OpMXX6aHint (6, 0, 0, 0x0c, 0), {F1, MR3}},
-    {"ldfe.sa.nt1",    M, OpMXX6aHint (6, 0, 0, 0x0c, 1), {F1, MR3}},
-    {"ldfe.sa.nta",    M, OpMXX6aHint (6, 0, 0, 0x0c, 3), {F1, MR3}},
-    {"ldf.fill",       M, OpMXX6aHint (6, 0, 0, 0x1b, 0), {F1, MR3}},
-    {"ldf.fill.nt1",   M, OpMXX6aHint (6, 0, 0, 0x1b, 1), {F1, MR3}},
-    {"ldf.fill.nta",   M, OpMXX6aHint (6, 0, 0, 0x1b, 3), {F1, MR3}},
-    {"ldfs.c.clr",     M, OpMXX6aHint (6, 0, 0, 0x22, 0), {F1, MR3}},
-    {"ldfs.c.clr.nt1", M, OpMXX6aHint (6, 0, 0, 0x22, 1), {F1, MR3}},
-    {"ldfs.c.clr.nta", M, OpMXX6aHint (6, 0, 0, 0x22, 3), {F1, MR3}},
-    {"ldfd.c.clr",     M, OpMXX6aHint (6, 0, 0, 0x23, 0), {F1, MR3}},
-    {"ldfd.c.clr.nt1", M, OpMXX6aHint (6, 0, 0, 0x23, 1), {F1, MR3}},
-    {"ldfd.c.clr.nta", M, OpMXX6aHint (6, 0, 0, 0x23, 3), {F1, MR3}},
-    {"ldf8.c.clr",     M, OpMXX6aHint (6, 0, 0, 0x21, 0), {F1, MR3}},
-    {"ldf8.c.clr.nt1", M, OpMXX6aHint (6, 0, 0, 0x21, 1), {F1, MR3}},
-    {"ldf8.c.clr.nta", M, OpMXX6aHint (6, 0, 0, 0x21, 3), {F1, MR3}},
-    {"ldfe.c.clr",     M, OpMXX6aHint (6, 0, 0, 0x20, 0), {F1, MR3}},
-    {"ldfe.c.clr.nt1", M, OpMXX6aHint (6, 0, 0, 0x20, 1), {F1, MR3}},
-    {"ldfe.c.clr.nta", M, OpMXX6aHint (6, 0, 0, 0x20, 3), {F1, MR3}},
-    {"ldfs.c.nc",      M, OpMXX6aHint (6, 0, 0, 0x26, 0), {F1, MR3}},
-    {"ldfs.c.nc.nt1",  M, OpMXX6aHint (6, 0, 0, 0x26, 1), {F1, MR3}},
-    {"ldfs.c.nc.nta",  M, OpMXX6aHint (6, 0, 0, 0x26, 3), {F1, MR3}},
-    {"ldfd.c.nc",      M, OpMXX6aHint (6, 0, 0, 0x27, 0), {F1, MR3}},
-    {"ldfd.c.nc.nt1",  M, OpMXX6aHint (6, 0, 0, 0x27, 1), {F1, MR3}},
-    {"ldfd.c.nc.nta",  M, OpMXX6aHint (6, 0, 0, 0x27, 3), {F1, MR3}},
-    {"ldf8.c.nc",      M, OpMXX6aHint (6, 0, 0, 0x25, 0), {F1, MR3}},
-    {"ldf8.c.nc.nt1",  M, OpMXX6aHint (6, 0, 0, 0x25, 1), {F1, MR3}},
-    {"ldf8.c.nc.nta",  M, OpMXX6aHint (6, 0, 0, 0x25, 3), {F1, MR3}},
-    {"ldfe.c.nc",      M, OpMXX6aHint (6, 0, 0, 0x24, 0), {F1, MR3}},
-    {"ldfe.c.nc.nt1",  M, OpMXX6aHint (6, 0, 0, 0x24, 1), {F1, MR3}},
-    {"ldfe.c.nc.nta",  M, OpMXX6aHint (6, 0, 0, 0x24, 3), {F1, MR3}},
+    /* Floating-point load.  */
+    {"ldfs",           M, OpMXX6aHint (6, 0, 0, 0x02, 0), {F1, MR3}, EMPTY},
+    {"ldfs.nt1",       M, OpMXX6aHint (6, 0, 0, 0x02, 1), {F1, MR3}, EMPTY},
+    {"ldfs.nta",       M, OpMXX6aHint (6, 0, 0, 0x02, 3), {F1, MR3}, EMPTY},
+    {"ldfd",           M, OpMXX6aHint (6, 0, 0, 0x03, 0), {F1, MR3}, EMPTY},
+    {"ldfd.nt1",       M, OpMXX6aHint (6, 0, 0, 0x03, 1), {F1, MR3}, EMPTY},
+    {"ldfd.nta",       M, OpMXX6aHint (6, 0, 0, 0x03, 3), {F1, MR3}, EMPTY},
+    {"ldf8",           M, OpMXX6aHint (6, 0, 0, 0x01, 0), {F1, MR3}, EMPTY},
+    {"ldf8.nt1",       M, OpMXX6aHint (6, 0, 0, 0x01, 1), {F1, MR3}, EMPTY},
+    {"ldf8.nta",       M, OpMXX6aHint (6, 0, 0, 0x01, 3), {F1, MR3}, EMPTY},
+    {"ldfe",           M, OpMXX6aHint (6, 0, 0, 0x00, 0), {F1, MR3}, EMPTY},
+    {"ldfe.nt1",       M, OpMXX6aHint (6, 0, 0, 0x00, 1), {F1, MR3}, EMPTY},
+    {"ldfe.nta",       M, OpMXX6aHint (6, 0, 0, 0x00, 3), {F1, MR3}, EMPTY},
+    {"ldfs.s",         M, OpMXX6aHint (6, 0, 0, 0x06, 0), {F1, MR3}, EMPTY},
+    {"ldfs.s.nt1",     M, OpMXX6aHint (6, 0, 0, 0x06, 1), {F1, MR3}, EMPTY},
+    {"ldfs.s.nta",     M, OpMXX6aHint (6, 0, 0, 0x06, 3), {F1, MR3}, EMPTY},
+    {"ldfd.s",         M, OpMXX6aHint (6, 0, 0, 0x07, 0), {F1, MR3}, EMPTY},
+    {"ldfd.s.nt1",     M, OpMXX6aHint (6, 0, 0, 0x07, 1), {F1, MR3}, EMPTY},
+    {"ldfd.s.nta",     M, OpMXX6aHint (6, 0, 0, 0x07, 3), {F1, MR3}, EMPTY},
+    {"ldf8.s",         M, OpMXX6aHint (6, 0, 0, 0x05, 0), {F1, MR3}, EMPTY},
+    {"ldf8.s.nt1",     M, OpMXX6aHint (6, 0, 0, 0x05, 1), {F1, MR3}, EMPTY},
+    {"ldf8.s.nta",     M, OpMXX6aHint (6, 0, 0, 0x05, 3), {F1, MR3}, EMPTY},
+    {"ldfe.s",         M, OpMXX6aHint (6, 0, 0, 0x04, 0), {F1, MR3}, EMPTY},
+    {"ldfe.s.nt1",     M, OpMXX6aHint (6, 0, 0, 0x04, 1), {F1, MR3}, EMPTY},
+    {"ldfe.s.nta",     M, OpMXX6aHint (6, 0, 0, 0x04, 3), {F1, MR3}, EMPTY},
+    {"ldfs.a",         M, OpMXX6aHint (6, 0, 0, 0x0a, 0), {F1, MR3}, EMPTY},
+    {"ldfs.a.nt1",     M, OpMXX6aHint (6, 0, 0, 0x0a, 1), {F1, MR3}, EMPTY},
+    {"ldfs.a.nta",     M, OpMXX6aHint (6, 0, 0, 0x0a, 3), {F1, MR3}, EMPTY},
+    {"ldfd.a",         M, OpMXX6aHint (6, 0, 0, 0x0b, 0), {F1, MR3}, EMPTY},
+    {"ldfd.a.nt1",     M, OpMXX6aHint (6, 0, 0, 0x0b, 1), {F1, MR3}, EMPTY},
+    {"ldfd.a.nta",     M, OpMXX6aHint (6, 0, 0, 0x0b, 3), {F1, MR3}, EMPTY},
+    {"ldf8.a",         M, OpMXX6aHint (6, 0, 0, 0x09, 0), {F1, MR3}, EMPTY},
+    {"ldf8.a.nt1",     M, OpMXX6aHint (6, 0, 0, 0x09, 1), {F1, MR3}, EMPTY},
+    {"ldf8.a.nta",     M, OpMXX6aHint (6, 0, 0, 0x09, 3), {F1, MR3}, EMPTY},
+    {"ldfe.a",         M, OpMXX6aHint (6, 0, 0, 0x08, 0), {F1, MR3}, EMPTY},
+    {"ldfe.a.nt1",     M, OpMXX6aHint (6, 0, 0, 0x08, 1), {F1, MR3}, EMPTY},
+    {"ldfe.a.nta",     M, OpMXX6aHint (6, 0, 0, 0x08, 3), {F1, MR3}, EMPTY},
+    {"ldfs.sa",                M, OpMXX6aHint (6, 0, 0, 0x0e, 0), {F1, MR3}, EMPTY},
+    {"ldfs.sa.nt1",    M, OpMXX6aHint (6, 0, 0, 0x0e, 1), {F1, MR3}, EMPTY},
+    {"ldfs.sa.nta",    M, OpMXX6aHint (6, 0, 0, 0x0e, 3), {F1, MR3}, EMPTY},
+    {"ldfd.sa",                M, OpMXX6aHint (6, 0, 0, 0x0f, 0), {F1, MR3}, EMPTY},
+    {"ldfd.sa.nt1",    M, OpMXX6aHint (6, 0, 0, 0x0f, 1), {F1, MR3}, EMPTY},
+    {"ldfd.sa.nta",    M, OpMXX6aHint (6, 0, 0, 0x0f, 3), {F1, MR3}, EMPTY},
+    {"ldf8.sa",                M, OpMXX6aHint (6, 0, 0, 0x0d, 0), {F1, MR3}, EMPTY},
+    {"ldf8.sa.nt1",    M, OpMXX6aHint (6, 0, 0, 0x0d, 1), {F1, MR3}, EMPTY},
+    {"ldf8.sa.nta",    M, OpMXX6aHint (6, 0, 0, 0x0d, 3), {F1, MR3}, EMPTY},
+    {"ldfe.sa",                M, OpMXX6aHint (6, 0, 0, 0x0c, 0), {F1, MR3}, EMPTY},
+    {"ldfe.sa.nt1",    M, OpMXX6aHint (6, 0, 0, 0x0c, 1), {F1, MR3}, EMPTY},
+    {"ldfe.sa.nta",    M, OpMXX6aHint (6, 0, 0, 0x0c, 3), {F1, MR3}, EMPTY},
+    {"ldf.fill",       M, OpMXX6aHint (6, 0, 0, 0x1b, 0), {F1, MR3}, EMPTY},
+    {"ldf.fill.nt1",   M, OpMXX6aHint (6, 0, 0, 0x1b, 1), {F1, MR3}, EMPTY},
+    {"ldf.fill.nta",   M, OpMXX6aHint (6, 0, 0, 0x1b, 3), {F1, MR3}, EMPTY},
+    {"ldfs.c.clr",     M, OpMXX6aHint (6, 0, 0, 0x22, 0), {F1, MR3}, EMPTY},
+    {"ldfs.c.clr.nt1", M, OpMXX6aHint (6, 0, 0, 0x22, 1), {F1, MR3}, EMPTY},
+    {"ldfs.c.clr.nta", M, OpMXX6aHint (6, 0, 0, 0x22, 3), {F1, MR3}, EMPTY},
+    {"ldfd.c.clr",     M, OpMXX6aHint (6, 0, 0, 0x23, 0), {F1, MR3}, EMPTY},
+    {"ldfd.c.clr.nt1", M, OpMXX6aHint (6, 0, 0, 0x23, 1), {F1, MR3}, EMPTY},
+    {"ldfd.c.clr.nta", M, OpMXX6aHint (6, 0, 0, 0x23, 3), {F1, MR3}, EMPTY},
+    {"ldf8.c.clr",     M, OpMXX6aHint (6, 0, 0, 0x21, 0), {F1, MR3}, EMPTY},
+    {"ldf8.c.clr.nt1", M, OpMXX6aHint (6, 0, 0, 0x21, 1), {F1, MR3}, EMPTY},
+    {"ldf8.c.clr.nta", M, OpMXX6aHint (6, 0, 0, 0x21, 3), {F1, MR3}, EMPTY},
+    {"ldfe.c.clr",     M, OpMXX6aHint (6, 0, 0, 0x20, 0), {F1, MR3}, EMPTY},
+    {"ldfe.c.clr.nt1", M, OpMXX6aHint (6, 0, 0, 0x20, 1), {F1, MR3}, EMPTY},
+    {"ldfe.c.clr.nta", M, OpMXX6aHint (6, 0, 0, 0x20, 3), {F1, MR3}, EMPTY},
+    {"ldfs.c.nc",      M, OpMXX6aHint (6, 0, 0, 0x26, 0), {F1, MR3}, EMPTY},
+    {"ldfs.c.nc.nt1",  M, OpMXX6aHint (6, 0, 0, 0x26, 1), {F1, MR3}, EMPTY},
+    {"ldfs.c.nc.nta",  M, OpMXX6aHint (6, 0, 0, 0x26, 3), {F1, MR3}, EMPTY},
+    {"ldfd.c.nc",      M, OpMXX6aHint (6, 0, 0, 0x27, 0), {F1, MR3}, EMPTY},
+    {"ldfd.c.nc.nt1",  M, OpMXX6aHint (6, 0, 0, 0x27, 1), {F1, MR3}, EMPTY},
+    {"ldfd.c.nc.nta",  M, OpMXX6aHint (6, 0, 0, 0x27, 3), {F1, MR3}, EMPTY},
+    {"ldf8.c.nc",      M, OpMXX6aHint (6, 0, 0, 0x25, 0), {F1, MR3}, EMPTY},
+    {"ldf8.c.nc.nt1",  M, OpMXX6aHint (6, 0, 0, 0x25, 1), {F1, MR3}, EMPTY},
+    {"ldf8.c.nc.nta",  M, OpMXX6aHint (6, 0, 0, 0x25, 3), {F1, MR3}, EMPTY},
+    {"ldfe.c.nc",      M, OpMXX6aHint (6, 0, 0, 0x24, 0), {F1, MR3}, EMPTY},
+    {"ldfe.c.nc.nt1",  M, OpMXX6aHint (6, 0, 0, 0x24, 1), {F1, MR3}, EMPTY},
+    {"ldfe.c.nc.nta",  M, OpMXX6aHint (6, 0, 0, 0x24, 3), {F1, MR3}, EMPTY},
 
-    {"ldfs",           M, OpMXX6aHint (6, 1, 0, 0x02, 0), {F1, MR3, R2}},
-    {"ldfs.nt1",       M, OpMXX6aHint (6, 1, 0, 0x02, 1), {F1, MR3, R2}},
-    {"ldfs.nta",       M, OpMXX6aHint (6, 1, 0, 0x02, 3), {F1, MR3, R2}},
-    {"ldfd",           M, OpMXX6aHint (6, 1, 0, 0x03, 0), {F1, MR3, R2}},
-    {"ldfd.nt1",       M, OpMXX6aHint (6, 1, 0, 0x03, 1), {F1, MR3, R2}},
-    {"ldfd.nta",       M, OpMXX6aHint (6, 1, 0, 0x03, 3), {F1, MR3, R2}},
-    {"ldf8",           M, OpMXX6aHint (6, 1, 0, 0x01, 0), {F1, MR3, R2}},
-    {"ldf8.nt1",       M, OpMXX6aHint (6, 1, 0, 0x01, 1), {F1, MR3, R2}},
-    {"ldf8.nta",       M, OpMXX6aHint (6, 1, 0, 0x01, 3), {F1, MR3, R2}},
-    {"ldfe",           M, OpMXX6aHint (6, 1, 0, 0x00, 0), {F1, MR3, R2}},
-    {"ldfe.nt1",       M, OpMXX6aHint (6, 1, 0, 0x00, 1), {F1, MR3, R2}},
-    {"ldfe.nta",       M, OpMXX6aHint (6, 1, 0, 0x00, 3), {F1, MR3, R2}},
-    {"ldfs.s",         M, OpMXX6aHint (6, 1, 0, 0x06, 0), {F1, MR3, R2}},
-    {"ldfs.s.nt1",     M, OpMXX6aHint (6, 1, 0, 0x06, 1), {F1, MR3, R2}},
-    {"ldfs.s.nta",     M, OpMXX6aHint (6, 1, 0, 0x06, 3), {F1, MR3, R2}},
-    {"ldfd.s",         M, OpMXX6aHint (6, 1, 0, 0x07, 0), {F1, MR3, R2}},
-    {"ldfd.s.nt1",     M, OpMXX6aHint (6, 1, 0, 0x07, 1), {F1, MR3, R2}},
-    {"ldfd.s.nta",     M, OpMXX6aHint (6, 1, 0, 0x07, 3), {F1, MR3, R2}},
-    {"ldf8.s",         M, OpMXX6aHint (6, 1, 0, 0x05, 0), {F1, MR3, R2}},
-    {"ldf8.s.nt1",     M, OpMXX6aHint (6, 1, 0, 0x05, 1), {F1, MR3, R2}},
-    {"ldf8.s.nta",     M, OpMXX6aHint (6, 1, 0, 0x05, 3), {F1, MR3, R2}},
-    {"ldfe.s",         M, OpMXX6aHint (6, 1, 0, 0x04, 0), {F1, MR3, R2}},
-    {"ldfe.s.nt1",     M, OpMXX6aHint (6, 1, 0, 0x04, 1), {F1, MR3, R2}},
-    {"ldfe.s.nta",     M, OpMXX6aHint (6, 1, 0, 0x04, 3), {F1, MR3, R2}},
-    {"ldfs.a",         M, OpMXX6aHint (6, 1, 0, 0x0a, 0), {F1, MR3, R2}},
-    {"ldfs.a.nt1",     M, OpMXX6aHint (6, 1, 0, 0x0a, 1), {F1, MR3, R2}},
-    {"ldfs.a.nta",     M, OpMXX6aHint (6, 1, 0, 0x0a, 3), {F1, MR3, R2}},
-    {"ldfd.a",         M, OpMXX6aHint (6, 1, 0, 0x0b, 0), {F1, MR3, R2}},
-    {"ldfd.a.nt1",     M, OpMXX6aHint (6, 1, 0, 0x0b, 1), {F1, MR3, R2}},
-    {"ldfd.a.nta",     M, OpMXX6aHint (6, 1, 0, 0x0b, 3), {F1, MR3, R2}},
-    {"ldf8.a",         M, OpMXX6aHint (6, 1, 0, 0x09, 0), {F1, MR3, R2}},
-    {"ldf8.a.nt1",     M, OpMXX6aHint (6, 1, 0, 0x09, 1), {F1, MR3, R2}},
-    {"ldf8.a.nta",     M, OpMXX6aHint (6, 1, 0, 0x09, 3), {F1, MR3, R2}},
-    {"ldfe.a",         M, OpMXX6aHint (6, 1, 0, 0x08, 0), {F1, MR3, R2}},
-    {"ldfe.a.nt1",     M, OpMXX6aHint (6, 1, 0, 0x08, 1), {F1, MR3, R2}},
-    {"ldfe.a.nta",     M, OpMXX6aHint (6, 1, 0, 0x08, 3), {F1, MR3, R2}},
-    {"ldfs.sa",                M, OpMXX6aHint (6, 1, 0, 0x0e, 0), {F1, MR3, R2}},
-    {"ldfs.sa.nt1",    M, OpMXX6aHint (6, 1, 0, 0x0e, 1), {F1, MR3, R2}},
-    {"ldfs.sa.nta",    M, OpMXX6aHint (6, 1, 0, 0x0e, 3), {F1, MR3, R2}},
-    {"ldfd.sa",                M, OpMXX6aHint (6, 1, 0, 0x0f, 0), {F1, MR3, R2}},
-    {"ldfd.sa.nt1",    M, OpMXX6aHint (6, 1, 0, 0x0f, 1), {F1, MR3, R2}},
-    {"ldfd.sa.nta",    M, OpMXX6aHint (6, 1, 0, 0x0f, 3), {F1, MR3, R2}},
-    {"ldf8.sa",                M, OpMXX6aHint (6, 1, 0, 0x0d, 0), {F1, MR3, R2}},
-    {"ldf8.sa.nt1",    M, OpMXX6aHint (6, 1, 0, 0x0d, 1), {F1, MR3, R2}},
-    {"ldf8.sa.nta",    M, OpMXX6aHint (6, 1, 0, 0x0d, 3), {F1, MR3, R2}},
-    {"ldfe.sa",                M, OpMXX6aHint (6, 1, 0, 0x0c, 0), {F1, MR3, R2}},
-    {"ldfe.sa.nt1",    M, OpMXX6aHint (6, 1, 0, 0x0c, 1), {F1, MR3, R2}},
-    {"ldfe.sa.nta",    M, OpMXX6aHint (6, 1, 0, 0x0c, 3), {F1, MR3, R2}},
-    {"ldf.fill",       M, OpMXX6aHint (6, 1, 0, 0x1b, 0), {F1, MR3, R2}},
-    {"ldf.fill.nt1",   M, OpMXX6aHint (6, 1, 0, 0x1b, 1), {F1, MR3, R2}},
-    {"ldf.fill.nta",   M, OpMXX6aHint (6, 1, 0, 0x1b, 3), {F1, MR3, R2}},
-    {"ldfs.c.clr",     M, OpMXX6aHint (6, 1, 0, 0x22, 0), {F1, MR3, R2}},
-    {"ldfs.c.clr.nt1", M, OpMXX6aHint (6, 1, 0, 0x22, 1), {F1, MR3, R2}},
-    {"ldfs.c.clr.nta", M, OpMXX6aHint (6, 1, 0, 0x22, 3), {F1, MR3, R2}},
-    {"ldfd.c.clr",     M, OpMXX6aHint (6, 1, 0, 0x23, 0), {F1, MR3, R2}},
-    {"ldfd.c.clr.nt1", M, OpMXX6aHint (6, 1, 0, 0x23, 1), {F1, MR3, R2}},
-    {"ldfd.c.clr.nta", M, OpMXX6aHint (6, 1, 0, 0x23, 3), {F1, MR3, R2}},
-    {"ldf8.c.clr",     M, OpMXX6aHint (6, 1, 0, 0x21, 0), {F1, MR3, R2}},
-    {"ldf8.c.clr.nt1", M, OpMXX6aHint (6, 1, 0, 0x21, 1), {F1, MR3, R2}},
-    {"ldf8.c.clr.nta", M, OpMXX6aHint (6, 1, 0, 0x21, 3), {F1, MR3, R2}},
-    {"ldfe.c.clr",     M, OpMXX6aHint (6, 1, 0, 0x20, 0), {F1, MR3, R2}},
-    {"ldfe.c.clr.nt1", M, OpMXX6aHint (6, 1, 0, 0x20, 1), {F1, MR3, R2}},
-    {"ldfe.c.clr.nta", M, OpMXX6aHint (6, 1, 0, 0x20, 3), {F1, MR3, R2}},
-    {"ldfs.c.nc",      M, OpMXX6aHint (6, 1, 0, 0x26, 0), {F1, MR3, R2}},
-    {"ldfs.c.nc.nt1",  M, OpMXX6aHint (6, 1, 0, 0x26, 1), {F1, MR3, R2}},
-    {"ldfs.c.nc.nta",  M, OpMXX6aHint (6, 1, 0, 0x26, 3), {F1, MR3, R2}},
-    {"ldfd.c.nc",      M, OpMXX6aHint (6, 1, 0, 0x27, 0), {F1, MR3, R2}},
-    {"ldfd.c.nc.nt1",  M, OpMXX6aHint (6, 1, 0, 0x27, 1), {F1, MR3, R2}},
-    {"ldfd.c.nc.nta",  M, OpMXX6aHint (6, 1, 0, 0x27, 3), {F1, MR3, R2}},
-    {"ldf8.c.nc",      M, OpMXX6aHint (6, 1, 0, 0x25, 0), {F1, MR3, R2}},
-    {"ldf8.c.nc.nt1",  M, OpMXX6aHint (6, 1, 0, 0x25, 1), {F1, MR3, R2}},
-    {"ldf8.c.nc.nta",  M, OpMXX6aHint (6, 1, 0, 0x25, 3), {F1, MR3, R2}},
-    {"ldfe.c.nc",      M, OpMXX6aHint (6, 1, 0, 0x24, 0), {F1, MR3, R2}},
-    {"ldfe.c.nc.nt1",  M, OpMXX6aHint (6, 1, 0, 0x24, 1), {F1, MR3, R2}},
-    {"ldfe.c.nc.nta",  M, OpMXX6aHint (6, 1, 0, 0x24, 3), {F1, MR3, R2}},
+    /* Floating-point load w/increment by register.  */
+#define FLDINCREG(c,h) M, OpMXX6aHint (6, 1, 0, c, h), {F1, MR3, R2}, POSTINC, 0, NULL
+    {"ldfs",           FLDINCREG (0x02, 0)},
+    {"ldfs.nt1",       FLDINCREG (0x02, 1)},
+    {"ldfs.nta",       FLDINCREG (0x02, 3)},
+    {"ldfd",           FLDINCREG (0x03, 0)},
+    {"ldfd.nt1",       FLDINCREG (0x03, 1)},
+    {"ldfd.nta",       FLDINCREG (0x03, 3)},
+    {"ldf8",           FLDINCREG (0x01, 0)},
+    {"ldf8.nt1",       FLDINCREG (0x01, 1)},
+    {"ldf8.nta",       FLDINCREG (0x01, 3)},
+    {"ldfe",           FLDINCREG (0x00, 0)},
+    {"ldfe.nt1",       FLDINCREG (0x00, 1)},
+    {"ldfe.nta",       FLDINCREG (0x00, 3)},
+    {"ldfs.s",         FLDINCREG (0x06, 0)},
+    {"ldfs.s.nt1",     FLDINCREG (0x06, 1)},
+    {"ldfs.s.nta",     FLDINCREG (0x06, 3)},
+    {"ldfd.s",         FLDINCREG (0x07, 0)},
+    {"ldfd.s.nt1",     FLDINCREG (0x07, 1)},
+    {"ldfd.s.nta",     FLDINCREG (0x07, 3)},
+    {"ldf8.s",         FLDINCREG (0x05, 0)},
+    {"ldf8.s.nt1",     FLDINCREG (0x05, 1)},
+    {"ldf8.s.nta",     FLDINCREG (0x05, 3)},
+    {"ldfe.s",         FLDINCREG (0x04, 0)},
+    {"ldfe.s.nt1",     FLDINCREG (0x04, 1)},
+    {"ldfe.s.nta",     FLDINCREG (0x04, 3)},
+    {"ldfs.a",         FLDINCREG (0x0a, 0)},
+    {"ldfs.a.nt1",     FLDINCREG (0x0a, 1)},
+    {"ldfs.a.nta",     FLDINCREG (0x0a, 3)},
+    {"ldfd.a",         FLDINCREG (0x0b, 0)},
+    {"ldfd.a.nt1",     FLDINCREG (0x0b, 1)},
+    {"ldfd.a.nta",     FLDINCREG (0x0b, 3)},
+    {"ldf8.a",         FLDINCREG (0x09, 0)},
+    {"ldf8.a.nt1",     FLDINCREG (0x09, 1)},
+    {"ldf8.a.nta",     FLDINCREG (0x09, 3)},
+    {"ldfe.a",         FLDINCREG (0x08, 0)},
+    {"ldfe.a.nt1",     FLDINCREG (0x08, 1)},
+    {"ldfe.a.nta",     FLDINCREG (0x08, 3)},
+    {"ldfs.sa",                FLDINCREG (0x0e, 0)},
+    {"ldfs.sa.nt1",    FLDINCREG (0x0e, 1)},
+    {"ldfs.sa.nta",    FLDINCREG (0x0e, 3)},
+    {"ldfd.sa",                FLDINCREG (0x0f, 0)},
+    {"ldfd.sa.nt1",    FLDINCREG (0x0f, 1)},
+    {"ldfd.sa.nta",    FLDINCREG (0x0f, 3)},
+    {"ldf8.sa",                FLDINCREG (0x0d, 0)},
+    {"ldf8.sa.nt1",    FLDINCREG (0x0d, 1)},
+    {"ldf8.sa.nta",    FLDINCREG (0x0d, 3)},
+    {"ldfe.sa",                FLDINCREG (0x0c, 0)},
+    {"ldfe.sa.nt1",    FLDINCREG (0x0c, 1)},
+    {"ldfe.sa.nta",    FLDINCREG (0x0c, 3)},
+    {"ldf.fill",       FLDINCREG (0x1b, 0)},
+    {"ldf.fill.nt1",   FLDINCREG (0x1b, 1)},
+    {"ldf.fill.nta",   FLDINCREG (0x1b, 3)},
+    {"ldfs.c.clr",     FLDINCREG (0x22, 0)},
+    {"ldfs.c.clr.nt1", FLDINCREG (0x22, 1)},
+    {"ldfs.c.clr.nta", FLDINCREG (0x22, 3)},
+    {"ldfd.c.clr",     FLDINCREG (0x23, 0)},
+    {"ldfd.c.clr.nt1", FLDINCREG (0x23, 1)},
+    {"ldfd.c.clr.nta", FLDINCREG (0x23, 3)},
+    {"ldf8.c.clr",     FLDINCREG (0x21, 0)},
+    {"ldf8.c.clr.nt1", FLDINCREG (0x21, 1)},
+    {"ldf8.c.clr.nta", FLDINCREG (0x21, 3)},
+    {"ldfe.c.clr",     FLDINCREG (0x20, 0)},
+    {"ldfe.c.clr.nt1", FLDINCREG (0x20, 1)},
+    {"ldfe.c.clr.nta", FLDINCREG (0x20, 3)},
+    {"ldfs.c.nc",      FLDINCREG (0x26, 0)},
+    {"ldfs.c.nc.nt1",  FLDINCREG (0x26, 1)},
+    {"ldfs.c.nc.nta",  FLDINCREG (0x26, 3)},
+    {"ldfd.c.nc",      FLDINCREG (0x27, 0)},
+    {"ldfd.c.nc.nt1",  FLDINCREG (0x27, 1)},
+    {"ldfd.c.nc.nta",  FLDINCREG (0x27, 3)},
+    {"ldf8.c.nc",      FLDINCREG (0x25, 0)},
+    {"ldf8.c.nc.nt1",  FLDINCREG (0x25, 1)},
+    {"ldf8.c.nc.nta",  FLDINCREG (0x25, 3)},
+    {"ldfe.c.nc",      FLDINCREG (0x24, 0)},
+    {"ldfe.c.nc.nt1",  FLDINCREG (0x24, 1)},
+    {"ldfe.c.nc.nta",  FLDINCREG (0x24, 3)},
+#undef FLDINCREG
 
-    /* floating-point store */
-    {"stfs",           M, OpMXX6aHint (6, 0, 0, 0x32, 0), {MR3, F2}},
-    {"stfs.nta",       M, OpMXX6aHint (6, 0, 0, 0x32, 3), {MR3, F2}},
-    {"stfd",           M, OpMXX6aHint (6, 0, 0, 0x33, 0), {MR3, F2}},
-    {"stfd.nta",       M, OpMXX6aHint (6, 0, 0, 0x33, 3), {MR3, F2}},
-    {"stf8",           M, OpMXX6aHint (6, 0, 0, 0x31, 0), {MR3, F2}},
-    {"stf8.nta",       M, OpMXX6aHint (6, 0, 0, 0x31, 3), {MR3, F2}},
-    {"stfe",           M, OpMXX6aHint (6, 0, 0, 0x30, 0), {MR3, F2}},
-    {"stfe.nta",       M, OpMXX6aHint (6, 0, 0, 0x30, 3), {MR3, F2}},
-    {"stf.spill",      M, OpMXX6aHint (6, 0, 0, 0x3b, 0), {MR3, F2}},
-    {"stf.spill.nta",  M, OpMXX6aHint (6, 0, 0, 0x3b, 3), {MR3, F2}},
+    /* Floating-point store.  */
+    {"stfs",           M, OpMXX6aHint (6, 0, 0, 0x32, 0), {MR3, F2}, EMPTY},
+    {"stfs.nta",       M, OpMXX6aHint (6, 0, 0, 0x32, 3), {MR3, F2}, EMPTY},
+    {"stfd",           M, OpMXX6aHint (6, 0, 0, 0x33, 0), {MR3, F2}, EMPTY},
+    {"stfd.nta",       M, OpMXX6aHint (6, 0, 0, 0x33, 3), {MR3, F2}, EMPTY},
+    {"stf8",           M, OpMXX6aHint (6, 0, 0, 0x31, 0), {MR3, F2}, EMPTY},
+    {"stf8.nta",       M, OpMXX6aHint (6, 0, 0, 0x31, 3), {MR3, F2}, EMPTY},
+    {"stfe",           M, OpMXX6aHint (6, 0, 0, 0x30, 0), {MR3, F2}, EMPTY},
+    {"stfe.nta",       M, OpMXX6aHint (6, 0, 0, 0x30, 3), {MR3, F2}, EMPTY},
+    {"stf.spill",      M, OpMXX6aHint (6, 0, 0, 0x3b, 0), {MR3, F2}, EMPTY},
+    {"stf.spill.nta",  M, OpMXX6aHint (6, 0, 0, 0x3b, 3), {MR3, F2}, EMPTY},
 
-    /* floating-point load pair */
-    {"ldfps",          M2, OpMXX6aHint (6, 0, 1, 0x02, 0), {F1, F2, MR3}},
-    {"ldfps.nt1",      M2, OpMXX6aHint (6, 0, 1, 0x02, 1), {F1, F2, MR3}},
-    {"ldfps.nta",      M2, OpMXX6aHint (6, 0, 1, 0x02, 3), {F1, F2, MR3}},
-    {"ldfpd",          M2, OpMXX6aHint (6, 0, 1, 0x03, 0), {F1, F2, MR3}},
-    {"ldfpd.nt1",      M2, OpMXX6aHint (6, 0, 1, 0x03, 1), {F1, F2, MR3}},
-    {"ldfpd.nta",      M2, OpMXX6aHint (6, 0, 1, 0x03, 3), {F1, F2, MR3}},
-    {"ldfp8",          M2, OpMXX6aHint (6, 0, 1, 0x01, 0), {F1, F2, MR3}},
-    {"ldfp8.nt1",      M2, OpMXX6aHint (6, 0, 1, 0x01, 1), {F1, F2, MR3}},
-    {"ldfp8.nta",      M2, OpMXX6aHint (6, 0, 1, 0x01, 3), {F1, F2, MR3}},
-    {"ldfps.s",                M2, OpMXX6aHint (6, 0, 1, 0x06, 0), {F1, F2, MR3}},
-    {"ldfps.s.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x06, 1), {F1, F2, MR3}},
-    {"ldfps.s.nta",    M2, OpMXX6aHint (6, 0, 1, 0x06, 3), {F1, F2, MR3}},
-    {"ldfpd.s",                M2, OpMXX6aHint (6, 0, 1, 0x07, 0), {F1, F2, MR3}},
-    {"ldfpd.s.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x07, 1), {F1, F2, MR3}},
-    {"ldfpd.s.nta",    M2, OpMXX6aHint (6, 0, 1, 0x07, 3), {F1, F2, MR3}},
-    {"ldfp8.s",                M2, OpMXX6aHint (6, 0, 1, 0x05, 0), {F1, F2, MR3}},
-    {"ldfp8.s.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x05, 1), {F1, F2, MR3}},
-    {"ldfp8.s.nta",    M2, OpMXX6aHint (6, 0, 1, 0x05, 3), {F1, F2, MR3}},
-    {"ldfps.a",                M2, OpMXX6aHint (6, 0, 1, 0x0a, 0), {F1, F2, MR3}},
-    {"ldfps.a.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x0a, 1), {F1, F2, MR3}},
-    {"ldfps.a.nta",    M2, OpMXX6aHint (6, 0, 1, 0x0a, 3), {F1, F2, MR3}},
-    {"ldfpd.a",                M2, OpMXX6aHint (6, 0, 1, 0x0b, 0), {F1, F2, MR3}},
-    {"ldfpd.a.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x0b, 1), {F1, F2, MR3}},
-    {"ldfpd.a.nta",    M2, OpMXX6aHint (6, 0, 1, 0x0b, 3), {F1, F2, MR3}},
-    {"ldfp8.a",                M2, OpMXX6aHint (6, 0, 1, 0x09, 0), {F1, F2, MR3}},
-    {"ldfp8.a.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x09, 1), {F1, F2, MR3}},
-    {"ldfp8.a.nta",    M2, OpMXX6aHint (6, 0, 1, 0x09, 3), {F1, F2, MR3}},
-    {"ldfps.sa",       M2, OpMXX6aHint (6, 0, 1, 0x0e, 0), {F1, F2, MR3}},
-    {"ldfps.sa.nt1",   M2, OpMXX6aHint (6, 0, 1, 0x0e, 1), {F1, F2, MR3}},
-    {"ldfps.sa.nta",   M2, OpMXX6aHint (6, 0, 1, 0x0e, 3), {F1, F2, MR3}},
-    {"ldfpd.sa",       M2, OpMXX6aHint (6, 0, 1, 0x0f, 0), {F1, F2, MR3}},
-    {"ldfpd.sa.nt1",   M2, OpMXX6aHint (6, 0, 1, 0x0f, 1), {F1, F2, MR3}},
-    {"ldfpd.sa.nta",   M2, OpMXX6aHint (6, 0, 1, 0x0f, 3), {F1, F2, MR3}},
-    {"ldfp8.sa",       M2, OpMXX6aHint (6, 0, 1, 0x0d, 0), {F1, F2, MR3}},
-    {"ldfp8.sa.nt1",   M2, OpMXX6aHint (6, 0, 1, 0x0d, 1), {F1, F2, MR3}},
-    {"ldfp8.sa.nta",   M2, OpMXX6aHint (6, 0, 1, 0x0d, 3), {F1, F2, MR3}},
-    {"ldfps.c.clr",    M2, OpMXX6aHint (6, 0, 1, 0x22, 0), {F1, F2, MR3}},
-    {"ldfps.c.clr.nt1",        M2, OpMXX6aHint (6, 0, 1, 0x22, 1), {F1, F2, MR3}},
-    {"ldfps.c.clr.nta",        M2, OpMXX6aHint (6, 0, 1, 0x22, 3), {F1, F2, MR3}},
-    {"ldfpd.c.clr",    M2, OpMXX6aHint (6, 0, 1, 0x23, 0), {F1, F2, MR3}},
-    {"ldfpd.c.clr.nt1",        M2, OpMXX6aHint (6, 0, 1, 0x23, 1), {F1, F2, MR3}},
-    {"ldfpd.c.clr.nta",        M2, OpMXX6aHint (6, 0, 1, 0x23, 3), {F1, F2, MR3}},
-    {"ldfp8.c.clr",    M2, OpMXX6aHint (6, 0, 1, 0x21, 0), {F1, F2, MR3}},
-    {"ldfp8.c.clr.nt1",        M2, OpMXX6aHint (6, 0, 1, 0x21, 1), {F1, F2, MR3}},
-    {"ldfp8.c.clr.nta",        M2, OpMXX6aHint (6, 0, 1, 0x21, 3), {F1, F2, MR3}},
-    {"ldfps.c.nc",     M2, OpMXX6aHint (6, 0, 1, 0x26, 0), {F1, F2, MR3}},
-    {"ldfps.c.nc.nt1", M2, OpMXX6aHint (6, 0, 1, 0x26, 1), {F1, F2, MR3}},
-    {"ldfps.c.nc.nta", M2, OpMXX6aHint (6, 0, 1, 0x26, 3), {F1, F2, MR3}},
-    {"ldfpd.c.nc",     M2, OpMXX6aHint (6, 0, 1, 0x27, 0), {F1, F2, MR3}},
-    {"ldfpd.c.nc.nt1", M2, OpMXX6aHint (6, 0, 1, 0x27, 1), {F1, F2, MR3}},
-    {"ldfpd.c.nc.nta", M2, OpMXX6aHint (6, 0, 1, 0x27, 3), {F1, F2, MR3}},
-    {"ldfp8.c.nc",     M2, OpMXX6aHint (6, 0, 1, 0x25, 0), {F1, F2, MR3}},
-    {"ldfp8.c.nc.nt1", M2, OpMXX6aHint (6, 0, 1, 0x25, 1), {F1, F2, MR3}},
-    {"ldfp8.c.nc.nta", M2, OpMXX6aHint (6, 0, 1, 0x25, 3), {F1, F2, MR3}},
+    /* Floating-point load pair.  */
+    {"ldfps",          M2, OpMXX6aHint (6, 0, 1, 0x02, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfps.nt1",      M2, OpMXX6aHint (6, 0, 1, 0x02, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfps.nta",      M2, OpMXX6aHint (6, 0, 1, 0x02, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfpd",          M2, OpMXX6aHint (6, 0, 1, 0x03, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.nt1",      M2, OpMXX6aHint (6, 0, 1, 0x03, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.nta",      M2, OpMXX6aHint (6, 0, 1, 0x03, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfp8",          M2, OpMXX6aHint (6, 0, 1, 0x01, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.nt1",      M2, OpMXX6aHint (6, 0, 1, 0x01, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.nta",      M2, OpMXX6aHint (6, 0, 1, 0x01, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfps.s",                M2, OpMXX6aHint (6, 0, 1, 0x06, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfps.s.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x06, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfps.s.nta",    M2, OpMXX6aHint (6, 0, 1, 0x06, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.s",                M2, OpMXX6aHint (6, 0, 1, 0x07, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.s.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x07, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.s.nta",    M2, OpMXX6aHint (6, 0, 1, 0x07, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.s",                M2, OpMXX6aHint (6, 0, 1, 0x05, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.s.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x05, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.s.nta",    M2, OpMXX6aHint (6, 0, 1, 0x05, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfps.a",                M2, OpMXX6aHint (6, 0, 1, 0x0a, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfps.a.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x0a, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfps.a.nta",    M2, OpMXX6aHint (6, 0, 1, 0x0a, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.a",                M2, OpMXX6aHint (6, 0, 1, 0x0b, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.a.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x0b, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.a.nta",    M2, OpMXX6aHint (6, 0, 1, 0x0b, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.a",                M2, OpMXX6aHint (6, 0, 1, 0x09, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.a.nt1",    M2, OpMXX6aHint (6, 0, 1, 0x09, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.a.nta",    M2, OpMXX6aHint (6, 0, 1, 0x09, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfps.sa",       M2, OpMXX6aHint (6, 0, 1, 0x0e, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfps.sa.nt1",   M2, OpMXX6aHint (6, 0, 1, 0x0e, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfps.sa.nta",   M2, OpMXX6aHint (6, 0, 1, 0x0e, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.sa",       M2, OpMXX6aHint (6, 0, 1, 0x0f, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.sa.nt1",   M2, OpMXX6aHint (6, 0, 1, 0x0f, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.sa.nta",   M2, OpMXX6aHint (6, 0, 1, 0x0f, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.sa",       M2, OpMXX6aHint (6, 0, 1, 0x0d, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.sa.nt1",   M2, OpMXX6aHint (6, 0, 1, 0x0d, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.sa.nta",   M2, OpMXX6aHint (6, 0, 1, 0x0d, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfps.c.clr",    M2, OpMXX6aHint (6, 0, 1, 0x22, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfps.c.clr.nt1",        M2, OpMXX6aHint (6, 0, 1, 0x22, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfps.c.clr.nta",        M2, OpMXX6aHint (6, 0, 1, 0x22, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.c.clr",    M2, OpMXX6aHint (6, 0, 1, 0x23, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.c.clr.nt1",        M2, OpMXX6aHint (6, 0, 1, 0x23, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.c.clr.nta",        M2, OpMXX6aHint (6, 0, 1, 0x23, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.c.clr",    M2, OpMXX6aHint (6, 0, 1, 0x21, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.c.clr.nt1",        M2, OpMXX6aHint (6, 0, 1, 0x21, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.c.clr.nta",        M2, OpMXX6aHint (6, 0, 1, 0x21, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfps.c.nc",     M2, OpMXX6aHint (6, 0, 1, 0x26, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfps.c.nc.nt1", M2, OpMXX6aHint (6, 0, 1, 0x26, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfps.c.nc.nta", M2, OpMXX6aHint (6, 0, 1, 0x26, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.c.nc",     M2, OpMXX6aHint (6, 0, 1, 0x27, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.c.nc.nt1", M2, OpMXX6aHint (6, 0, 1, 0x27, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfpd.c.nc.nta", M2, OpMXX6aHint (6, 0, 1, 0x27, 3), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.c.nc",     M2, OpMXX6aHint (6, 0, 1, 0x25, 0), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.c.nc.nt1", M2, OpMXX6aHint (6, 0, 1, 0x25, 1), {F1, F2, MR3}, EMPTY},
+    {"ldfp8.c.nc.nta", M2, OpMXX6aHint (6, 0, 1, 0x25, 3), {F1, F2, MR3}, EMPTY},
 
-    /* floating-point load pair w/increment by immediate */
-#define LD(a,b,c)      M2, OpMXX6aHint (6, 1, 1, a, b), {F1, F2, MR3, c}
+    /* Floating-point load pair w/increment by immediate.  */
+#define LD(a,b,c) M2, OpMXX6aHint (6, 1, 1, a, b), {F1, F2, MR3, c}, POSTINC, 0, NULL
     {"ldfps",          LD (0x02, 0, C8)},
     {"ldfps.nt1",      LD (0x02, 1, C8)},
     {"ldfps.nta",      LD (0x02, 3, C8)},
@@ -862,155 +907,164 @@ struct ia64_opcode ia64_opcodes_m[] =
     {"ldfp8.c.nc.nta", LD (0x25, 3, C16)},
 #undef LD
 
-    /* line prefetch */
-    {"lfetch",                 M0, OpMXX6aHint (6, 0, 0, 0x2c, 0), {MR3}},
-    {"lfetch.nt1",             M0, OpMXX6aHint (6, 0, 0, 0x2c, 1), {MR3}},
-    {"lfetch.nt2",             M0, OpMXX6aHint (6, 0, 0, 0x2c, 2), {MR3}},
-    {"lfetch.nta",             M0, OpMXX6aHint (6, 0, 0, 0x2c, 3), {MR3}},
-    {"lfetch.excl",            M0, OpMXX6aHint (6, 0, 0, 0x2d, 0), {MR3}},
-    {"lfetch.excl.nt1",                M0, OpMXX6aHint (6, 0, 0, 0x2d, 1), {MR3}},
-    {"lfetch.excl.nt2",                M0, OpMXX6aHint (6, 0, 0, 0x2d, 2), {MR3}},
-    {"lfetch.excl.nta",                M0, OpMXX6aHint (6, 0, 0, 0x2d, 3), {MR3}},
-    {"lfetch.fault",           M0, OpMXX6aHint (6, 0, 0, 0x2e, 0), {MR3}},
-    {"lfetch.fault.nt1",       M0, OpMXX6aHint (6, 0, 0, 0x2e, 1), {MR3}},
-    {"lfetch.fault.nt2",       M0, OpMXX6aHint (6, 0, 0, 0x2e, 2), {MR3}},
-    {"lfetch.fault.nta",       M0, OpMXX6aHint (6, 0, 0, 0x2e, 3), {MR3}},
-    {"lfetch.fault.excl",      M0, OpMXX6aHint (6, 0, 0, 0x2f, 0), {MR3}},
-    {"lfetch.fault.excl.nt1",  M0, OpMXX6aHint (6, 0, 0, 0x2f, 1), {MR3}},
-    {"lfetch.fault.excl.nt2",  M0, OpMXX6aHint (6, 0, 0, 0x2f, 2), {MR3}},
-    {"lfetch.fault.excl.nta",  M0, OpMXX6aHint (6, 0, 0, 0x2f, 3), {MR3}},
+    /* Line prefetch.  */
+    {"lfetch",                 M0, OpMXX6aHint (6, 0, 0, 0x2c, 0), {MR3}, EMPTY},
+    {"lfetch.nt1",             M0, OpMXX6aHint (6, 0, 0, 0x2c, 1), {MR3}, EMPTY},
+    {"lfetch.nt2",             M0, OpMXX6aHint (6, 0, 0, 0x2c, 2), {MR3}, EMPTY},
+    {"lfetch.nta",             M0, OpMXX6aHint (6, 0, 0, 0x2c, 3), {MR3}, EMPTY},
+    {"lfetch.excl",            M0, OpMXX6aHint (6, 0, 0, 0x2d, 0), {MR3}, EMPTY},
+    {"lfetch.excl.nt1",                M0, OpMXX6aHint (6, 0, 0, 0x2d, 1), {MR3}, EMPTY},
+    {"lfetch.excl.nt2",                M0, OpMXX6aHint (6, 0, 0, 0x2d, 2), {MR3}, EMPTY},
+    {"lfetch.excl.nta",                M0, OpMXX6aHint (6, 0, 0, 0x2d, 3), {MR3}, EMPTY},
+    {"lfetch.fault",           M0, OpMXX6aHint (6, 0, 0, 0x2e, 0), {MR3}, EMPTY},
+    {"lfetch.fault.nt1",       M0, OpMXX6aHint (6, 0, 0, 0x2e, 1), {MR3}, EMPTY},
+    {"lfetch.fault.nt2",       M0, OpMXX6aHint (6, 0, 0, 0x2e, 2), {MR3}, EMPTY},
+    {"lfetch.fault.nta",       M0, OpMXX6aHint (6, 0, 0, 0x2e, 3), {MR3}, EMPTY},
+    {"lfetch.fault.excl",      M0, OpMXX6aHint (6, 0, 0, 0x2f, 0), {MR3}, EMPTY},
+    {"lfetch.fault.excl.nt1",  M0, OpMXX6aHint (6, 0, 0, 0x2f, 1), {MR3}, EMPTY},
+    {"lfetch.fault.excl.nt2",  M0, OpMXX6aHint (6, 0, 0, 0x2f, 2), {MR3}, EMPTY},
+    {"lfetch.fault.excl.nta",  M0, OpMXX6aHint (6, 0, 0, 0x2f, 3), {MR3}, EMPTY},
 
-    /* line prefetch w/increment by register */
-    {"lfetch",                 M0, OpMXX6aHint (6, 1, 0, 0x2c, 0), {MR3, R2}},
-    {"lfetch.nt1",             M0, OpMXX6aHint (6, 1, 0, 0x2c, 1), {MR3, R2}},
-    {"lfetch.nt2",             M0, OpMXX6aHint (6, 1, 0, 0x2c, 2), {MR3, R2}},
-    {"lfetch.nta",             M0, OpMXX6aHint (6, 1, 0, 0x2c, 3), {MR3, R2}},
-    {"lfetch.excl",            M0, OpMXX6aHint (6, 1, 0, 0x2d, 0), {MR3, R2}},
-    {"lfetch.excl.nt1",                M0, OpMXX6aHint (6, 1, 0, 0x2d, 1), {MR3, R2}},
-    {"lfetch.excl.nt2",                M0, OpMXX6aHint (6, 1, 0, 0x2d, 2), {MR3, R2}},
-    {"lfetch.excl.nta",                M0, OpMXX6aHint (6, 1, 0, 0x2d, 3), {MR3, R2}},
-    {"lfetch.fault",           M0, OpMXX6aHint (6, 1, 0, 0x2e, 0), {MR3, R2}},
-    {"lfetch.fault.nt1",       M0, OpMXX6aHint (6, 1, 0, 0x2e, 1), {MR3, R2}},
-    {"lfetch.fault.nt2",       M0, OpMXX6aHint (6, 1, 0, 0x2e, 2), {MR3, R2}},
-    {"lfetch.fault.nta",       M0, OpMXX6aHint (6, 1, 0, 0x2e, 3), {MR3, R2}},
-    {"lfetch.fault.excl",      M0, OpMXX6aHint (6, 1, 0, 0x2f, 0), {MR3, R2}},
-    {"lfetch.fault.excl.nt1",  M0, OpMXX6aHint (6, 1, 0, 0x2f, 1), {MR3, R2}},
-    {"lfetch.fault.excl.nt2",  M0, OpMXX6aHint (6, 1, 0, 0x2f, 2), {MR3, R2}},
-    {"lfetch.fault.excl.nta",  M0, OpMXX6aHint (6, 1, 0, 0x2f, 3), {MR3, R2}},
+    /* Line prefetch w/increment by register.  */
+#define LFETCHINCREG(c,h) M0, OpMXX6aHint (6, 1, 0, c, h), {MR3, R2}, POSTINC, 0, NULL
+    {"lfetch",                 LFETCHINCREG (0x2c, 0)},
+    {"lfetch.nt1",             LFETCHINCREG (0x2c, 1)},
+    {"lfetch.nt2",             LFETCHINCREG (0x2c, 2)},
+    {"lfetch.nta",             LFETCHINCREG (0x2c, 3)},
+    {"lfetch.excl",            LFETCHINCREG (0x2d, 0)},
+    {"lfetch.excl.nt1",                LFETCHINCREG (0x2d, 1)},
+    {"lfetch.excl.nt2",                LFETCHINCREG (0x2d, 2)},
+    {"lfetch.excl.nta",                LFETCHINCREG (0x2d, 3)},
+    {"lfetch.fault",           LFETCHINCREG (0x2e, 0)},
+    {"lfetch.fault.nt1",       LFETCHINCREG (0x2e, 1)},
+    {"lfetch.fault.nt2",       LFETCHINCREG (0x2e, 2)},
+    {"lfetch.fault.nta",       LFETCHINCREG (0x2e, 3)},
+    {"lfetch.fault.excl",      LFETCHINCREG (0x2f, 0)},
+    {"lfetch.fault.excl.nt1",  LFETCHINCREG (0x2f, 1)},
+    {"lfetch.fault.excl.nt2",  LFETCHINCREG (0x2f, 2)},
+    {"lfetch.fault.excl.nta",  LFETCHINCREG (0x2f, 3)},
+#undef LFETCHINCREG
 
-    /* semaphore operations */
-    {"setf.sig",       M, OpMXX6a (6, 0, 1, 0x1c), {F1, R2}},
-    {"setf.exp",       M, OpMXX6a (6, 0, 1, 0x1d), {F1, R2}},
-    {"setf.s",         M, OpMXX6a (6, 0, 1, 0x1e), {F1, R2}},
-    {"setf.d",         M, OpMXX6a (6, 0, 1, 0x1f), {F1, R2}},
+    /* Semaphore operations.  */
+    {"setf.sig",       M, OpMXX6a (6, 0, 1, 0x1c), {F1, R2}, EMPTY},
+    {"setf.exp",       M, OpMXX6a (6, 0, 1, 0x1d), {F1, R2}, EMPTY},
+    {"setf.s",         M, OpMXX6a (6, 0, 1, 0x1e), {F1, R2}, EMPTY},
+    {"setf.d",         M, OpMXX6a (6, 0, 1, 0x1f), {F1, R2}, EMPTY},
 
-    {"ldfs",           M, OpX6aHint (7, 0x02, 0), {F1, MR3, IMM9b}},
-    {"ldfs.nt1",       M, OpX6aHint (7, 0x02, 1), {F1, MR3, IMM9b}},
-    {"ldfs.nta",       M, OpX6aHint (7, 0x02, 3), {F1, MR3, IMM9b}},
-    {"ldfd",           M, OpX6aHint (7, 0x03, 0), {F1, MR3, IMM9b}},
-    {"ldfd.nt1",       M, OpX6aHint (7, 0x03, 1), {F1, MR3, IMM9b}},
-    {"ldfd.nta",       M, OpX6aHint (7, 0x03, 3), {F1, MR3, IMM9b}},
-    {"ldf8",           M, OpX6aHint (7, 0x01, 0), {F1, MR3, IMM9b}},
-    {"ldf8.nt1",       M, OpX6aHint (7, 0x01, 1), {F1, MR3, IMM9b}},
-    {"ldf8.nta",       M, OpX6aHint (7, 0x01, 3), {F1, MR3, IMM9b}},
-    {"ldfe",           M, OpX6aHint (7, 0x00, 0), {F1, MR3, IMM9b}},
-    {"ldfe.nt1",       M, OpX6aHint (7, 0x00, 1), {F1, MR3, IMM9b}},
-    {"ldfe.nta",       M, OpX6aHint (7, 0x00, 3), {F1, MR3, IMM9b}},
-    {"ldfs.s",         M, OpX6aHint (7, 0x06, 0), {F1, MR3, IMM9b}},
-    {"ldfs.s.nt1",     M, OpX6aHint (7, 0x06, 1), {F1, MR3, IMM9b}},
-    {"ldfs.s.nta",     M, OpX6aHint (7, 0x06, 3), {F1, MR3, IMM9b}},
-    {"ldfd.s",         M, OpX6aHint (7, 0x07, 0), {F1, MR3, IMM9b}},
-    {"ldfd.s.nt1",     M, OpX6aHint (7, 0x07, 1), {F1, MR3, IMM9b}},
-    {"ldfd.s.nta",     M, OpX6aHint (7, 0x07, 3), {F1, MR3, IMM9b}},
-    {"ldf8.s",         M, OpX6aHint (7, 0x05, 0), {F1, MR3, IMM9b}},
-    {"ldf8.s.nt1",     M, OpX6aHint (7, 0x05, 1), {F1, MR3, IMM9b}},
-    {"ldf8.s.nta",     M, OpX6aHint (7, 0x05, 3), {F1, MR3, IMM9b}},
-    {"ldfe.s",         M, OpX6aHint (7, 0x04, 0), {F1, MR3, IMM9b}},
-    {"ldfe.s.nt1",     M, OpX6aHint (7, 0x04, 1), {F1, MR3, IMM9b}},
-    {"ldfe.s.nta",     M, OpX6aHint (7, 0x04, 3), {F1, MR3, IMM9b}},
-    {"ldfs.a",         M, OpX6aHint (7, 0x0a, 0), {F1, MR3, IMM9b}},
-    {"ldfs.a.nt1",     M, OpX6aHint (7, 0x0a, 1), {F1, MR3, IMM9b}},
-    {"ldfs.a.nta",     M, OpX6aHint (7, 0x0a, 3), {F1, MR3, IMM9b}},
-    {"ldfd.a",         M, OpX6aHint (7, 0x0b, 0), {F1, MR3, IMM9b}},
-    {"ldfd.a.nt1",     M, OpX6aHint (7, 0x0b, 1), {F1, MR3, IMM9b}},
-    {"ldfd.a.nta",     M, OpX6aHint (7, 0x0b, 3), {F1, MR3, IMM9b}},
-    {"ldf8.a",         M, OpX6aHint (7, 0x09, 0), {F1, MR3, IMM9b}},
-    {"ldf8.a.nt1",     M, OpX6aHint (7, 0x09, 1), {F1, MR3, IMM9b}},
-    {"ldf8.a.nta",     M, OpX6aHint (7, 0x09, 3), {F1, MR3, IMM9b}},
-    {"ldfe.a",         M, OpX6aHint (7, 0x08, 0), {F1, MR3, IMM9b}},
-    {"ldfe.a.nt1",     M, OpX6aHint (7, 0x08, 1), {F1, MR3, IMM9b}},
-    {"ldfe.a.nta",     M, OpX6aHint (7, 0x08, 3), {F1, MR3, IMM9b}},
-    {"ldfs.sa",                M, OpX6aHint (7, 0x0e, 0), {F1, MR3, IMM9b}},
-    {"ldfs.sa.nt1",    M, OpX6aHint (7, 0x0e, 1), {F1, MR3, IMM9b}},
-    {"ldfs.sa.nta",    M, OpX6aHint (7, 0x0e, 3), {F1, MR3, IMM9b}},
-    {"ldfd.sa",                M, OpX6aHint (7, 0x0f, 0), {F1, MR3, IMM9b}},
-    {"ldfd.sa.nt1",    M, OpX6aHint (7, 0x0f, 1), {F1, MR3, IMM9b}},
-    {"ldfd.sa.nta",    M, OpX6aHint (7, 0x0f, 3), {F1, MR3, IMM9b}},
-    {"ldf8.sa",                M, OpX6aHint (7, 0x0d, 0), {F1, MR3, IMM9b}},
-    {"ldf8.sa.nt1",    M, OpX6aHint (7, 0x0d, 1), {F1, MR3, IMM9b}},
-    {"ldf8.sa.nta",    M, OpX6aHint (7, 0x0d, 3), {F1, MR3, IMM9b}},
-    {"ldfe.sa",                M, OpX6aHint (7, 0x0c, 0), {F1, MR3, IMM9b}},
-    {"ldfe.sa.nt1",    M, OpX6aHint (7, 0x0c, 1), {F1, MR3, IMM9b}},
-    {"ldfe.sa.nta",    M, OpX6aHint (7, 0x0c, 3), {F1, MR3, IMM9b}},
-    {"ldf.fill",       M, OpX6aHint (7, 0x1b, 0), {F1, MR3, IMM9b}},
-    {"ldf.fill.nt1",   M, OpX6aHint (7, 0x1b, 1), {F1, MR3, IMM9b}},
-    {"ldf.fill.nta",   M, OpX6aHint (7, 0x1b, 3), {F1, MR3, IMM9b}},
-    {"ldfs.c.clr",     M, OpX6aHint (7, 0x22, 0), {F1, MR3, IMM9b}},
-    {"ldfs.c.clr.nt1", M, OpX6aHint (7, 0x22, 1), {F1, MR3, IMM9b}},
-    {"ldfs.c.clr.nta", M, OpX6aHint (7, 0x22, 3), {F1, MR3, IMM9b}},
-    {"ldfd.c.clr",     M, OpX6aHint (7, 0x23, 0), {F1, MR3, IMM9b}},
-    {"ldfd.c.clr.nt1", M, OpX6aHint (7, 0x23, 1), {F1, MR3, IMM9b}},
-    {"ldfd.c.clr.nta", M, OpX6aHint (7, 0x23, 3), {F1, MR3, IMM9b}},
-    {"ldf8.c.clr",     M, OpX6aHint (7, 0x21, 0), {F1, MR3, IMM9b}},
-    {"ldf8.c.clr.nt1", M, OpX6aHint (7, 0x21, 1), {F1, MR3, IMM9b}},
-    {"ldf8.c.clr.nta", M, OpX6aHint (7, 0x21, 3), {F1, MR3, IMM9b}},
-    {"ldfe.c.clr",     M, OpX6aHint (7, 0x20, 0), {F1, MR3, IMM9b}},
-    {"ldfe.c.clr.nt1", M, OpX6aHint (7, 0x20, 1), {F1, MR3, IMM9b}},
-    {"ldfe.c.clr.nta", M, OpX6aHint (7, 0x20, 3), {F1, MR3, IMM9b}},
-    {"ldfs.c.nc",      M, OpX6aHint (7, 0x26, 0), {F1, MR3, IMM9b}},
-    {"ldfs.c.nc.nt1",  M, OpX6aHint (7, 0x26, 1), {F1, MR3, IMM9b}},
-    {"ldfs.c.nc.nta",  M, OpX6aHint (7, 0x26, 3), {F1, MR3, IMM9b}},
-    {"ldfd.c.nc",      M, OpX6aHint (7, 0x27, 0), {F1, MR3, IMM9b}},
-    {"ldfd.c.nc.nt1",  M, OpX6aHint (7, 0x27, 1), {F1, MR3, IMM9b}},
-    {"ldfd.c.nc.nta",  M, OpX6aHint (7, 0x27, 3), {F1, MR3, IMM9b}},
-    {"ldf8.c.nc",      M, OpX6aHint (7, 0x25, 0), {F1, MR3, IMM9b}},
-    {"ldf8.c.nc.nt1",  M, OpX6aHint (7, 0x25, 1), {F1, MR3, IMM9b}},
-    {"ldf8.c.nc.nta",  M, OpX6aHint (7, 0x25, 3), {F1, MR3, IMM9b}},
-    {"ldfe.c.nc",      M, OpX6aHint (7, 0x24, 0), {F1, MR3, IMM9b}},
-    {"ldfe.c.nc.nt1",  M, OpX6aHint (7, 0x24, 1), {F1, MR3, IMM9b}},
-    {"ldfe.c.nc.nta",  M, OpX6aHint (7, 0x24, 3), {F1, MR3, IMM9b}},
+    /* Floating-point load w/increment by immediate.  */
+#define FLDINCIMMED(c,h) M, OpX6aHint (7, c, h), {F1, MR3, IMM9b}, POSTINC, 0, NULL
+    {"ldfs",           FLDINCIMMED (0x02, 0)},
+    {"ldfs.nt1",       FLDINCIMMED (0x02, 1)},
+    {"ldfs.nta",       FLDINCIMMED (0x02, 3)},
+    {"ldfd",           FLDINCIMMED (0x03, 0)},
+    {"ldfd.nt1",       FLDINCIMMED (0x03, 1)},
+    {"ldfd.nta",       FLDINCIMMED (0x03, 3)},
+    {"ldf8",           FLDINCIMMED (0x01, 0)},
+    {"ldf8.nt1",       FLDINCIMMED (0x01, 1)},
+    {"ldf8.nta",       FLDINCIMMED (0x01, 3)},
+    {"ldfe",           FLDINCIMMED (0x00, 0)},
+    {"ldfe.nt1",       FLDINCIMMED (0x00, 1)},
+    {"ldfe.nta",       FLDINCIMMED (0x00, 3)},
+    {"ldfs.s",         FLDINCIMMED (0x06, 0)},
+    {"ldfs.s.nt1",     FLDINCIMMED (0x06, 1)},
+    {"ldfs.s.nta",     FLDINCIMMED (0x06, 3)},
+    {"ldfd.s",         FLDINCIMMED (0x07, 0)},
+    {"ldfd.s.nt1",     FLDINCIMMED (0x07, 1)},
+    {"ldfd.s.nta",     FLDINCIMMED (0x07, 3)},
+    {"ldf8.s",         FLDINCIMMED (0x05, 0)},
+    {"ldf8.s.nt1",     FLDINCIMMED (0x05, 1)},
+    {"ldf8.s.nta",     FLDINCIMMED (0x05, 3)},
+    {"ldfe.s",         FLDINCIMMED (0x04, 0)},
+    {"ldfe.s.nt1",     FLDINCIMMED (0x04, 1)},
+    {"ldfe.s.nta",     FLDINCIMMED (0x04, 3)},
+    {"ldfs.a",         FLDINCIMMED (0x0a, 0)},
+    {"ldfs.a.nt1",     FLDINCIMMED (0x0a, 1)},
+    {"ldfs.a.nta",     FLDINCIMMED (0x0a, 3)},
+    {"ldfd.a",         FLDINCIMMED (0x0b, 0)},
+    {"ldfd.a.nt1",     FLDINCIMMED (0x0b, 1)},
+    {"ldfd.a.nta",     FLDINCIMMED (0x0b, 3)},
+    {"ldf8.a",         FLDINCIMMED (0x09, 0)},
+    {"ldf8.a.nt1",     FLDINCIMMED (0x09, 1)},
+    {"ldf8.a.nta",     FLDINCIMMED (0x09, 3)},
+    {"ldfe.a",         FLDINCIMMED (0x08, 0)},
+    {"ldfe.a.nt1",     FLDINCIMMED (0x08, 1)},
+    {"ldfe.a.nta",     FLDINCIMMED (0x08, 3)},
+    {"ldfs.sa",                FLDINCIMMED (0x0e, 0)},
+    {"ldfs.sa.nt1",    FLDINCIMMED (0x0e, 1)},
+    {"ldfs.sa.nta",    FLDINCIMMED (0x0e, 3)},
+    {"ldfd.sa",                FLDINCIMMED (0x0f, 0)},
+    {"ldfd.sa.nt1",    FLDINCIMMED (0x0f, 1)},
+    {"ldfd.sa.nta",    FLDINCIMMED (0x0f, 3)},
+    {"ldf8.sa",                FLDINCIMMED (0x0d, 0)},
+    {"ldf8.sa.nt1",    FLDINCIMMED (0x0d, 1)},
+    {"ldf8.sa.nta",    FLDINCIMMED (0x0d, 3)},
+    {"ldfe.sa",                FLDINCIMMED (0x0c, 0)},
+    {"ldfe.sa.nt1",    FLDINCIMMED (0x0c, 1)},
+    {"ldfe.sa.nta",    FLDINCIMMED (0x0c, 3)},
+    {"ldf.fill",       FLDINCIMMED (0x1b, 0)},
+    {"ldf.fill.nt1",   FLDINCIMMED (0x1b, 1)},
+    {"ldf.fill.nta",   FLDINCIMMED (0x1b, 3)},
+    {"ldfs.c.clr",     FLDINCIMMED (0x22, 0)},
+    {"ldfs.c.clr.nt1", FLDINCIMMED (0x22, 1)},
+    {"ldfs.c.clr.nta", FLDINCIMMED (0x22, 3)},
+    {"ldfd.c.clr",     FLDINCIMMED (0x23, 0)},
+    {"ldfd.c.clr.nt1", FLDINCIMMED (0x23, 1)},
+    {"ldfd.c.clr.nta", FLDINCIMMED (0x23, 3)},
+    {"ldf8.c.clr",     FLDINCIMMED (0x21, 0)},
+    {"ldf8.c.clr.nt1", FLDINCIMMED (0x21, 1)},
+    {"ldf8.c.clr.nta", FLDINCIMMED (0x21, 3)},
+    {"ldfe.c.clr",     FLDINCIMMED (0x20, 0)},
+    {"ldfe.c.clr.nt1", FLDINCIMMED (0x20, 1)},
+    {"ldfe.c.clr.nta", FLDINCIMMED (0x20, 3)},
+    {"ldfs.c.nc",      FLDINCIMMED (0x26, 0)},
+    {"ldfs.c.nc.nt1",  FLDINCIMMED (0x26, 1)},
+    {"ldfs.c.nc.nta",  FLDINCIMMED (0x26, 3)},
+    {"ldfd.c.nc",      FLDINCIMMED (0x27, 0)},
+    {"ldfd.c.nc.nt1",  FLDINCIMMED (0x27, 1)},
+    {"ldfd.c.nc.nta",  FLDINCIMMED (0x27, 3)},
+    {"ldf8.c.nc",      FLDINCIMMED (0x25, 0)},
+    {"ldf8.c.nc.nt1",  FLDINCIMMED (0x25, 1)},
+    {"ldf8.c.nc.nta",  FLDINCIMMED (0x25, 3)},
+    {"ldfe.c.nc",      FLDINCIMMED (0x24, 0)},
+    {"ldfe.c.nc.nt1",  FLDINCIMMED (0x24, 1)},
+    {"ldfe.c.nc.nta",  FLDINCIMMED (0x24, 3)},
+#undef FLDINCIMMED
 
-    /* floating-point store w/increment by immediate */
-    {"stfs",           M, OpX6aHint (7, 0x32, 0), {MR3, F2, IMM9a}},
-    {"stfs.nta",       M, OpX6aHint (7, 0x32, 3), {MR3, F2, IMM9a}},
-    {"stfd",           M, OpX6aHint (7, 0x33, 0), {MR3, F2, IMM9a}},
-    {"stfd.nta",       M, OpX6aHint (7, 0x33, 3), {MR3, F2, IMM9a}},
-    {"stf8",           M, OpX6aHint (7, 0x31, 0), {MR3, F2, IMM9a}},
-    {"stf8.nta",       M, OpX6aHint (7, 0x31, 3), {MR3, F2, IMM9a}},
-    {"stfe",           M, OpX6aHint (7, 0x30, 0), {MR3, F2, IMM9a}},
-    {"stfe.nta",       M, OpX6aHint (7, 0x30, 3), {MR3, F2, IMM9a}},
-    {"stf.spill",      M, OpX6aHint (7, 0x3b, 0), {MR3, F2, IMM9a}},
-    {"stf.spill.nta",  M, OpX6aHint (7, 0x3b, 3), {MR3, F2, IMM9a}},
+    /* Floating-point store w/increment by immediate.  */
+#define FSTINCIMMED(c,h) M, OpX6aHint (7, c, h), {MR3, F2, IMM9a}, POSTINC, 0, NULL
+    {"stfs",           FSTINCIMMED (0x32, 0)},
+    {"stfs.nta",       FSTINCIMMED (0x32, 3)},
+    {"stfd",           FSTINCIMMED (0x33, 0)},
+    {"stfd.nta",       FSTINCIMMED (0x33, 3)},
+    {"stf8",           FSTINCIMMED (0x31, 0)},
+    {"stf8.nta",       FSTINCIMMED (0x31, 3)},
+    {"stfe",           FSTINCIMMED (0x30, 0)},
+    {"stfe.nta",       FSTINCIMMED (0x30, 3)},
+    {"stf.spill",      FSTINCIMMED (0x3b, 0)},
+    {"stf.spill.nta",  FSTINCIMMED (0x3b, 3)},
+#undef FSTINCIMMED
 
-    /* line prefetch w/increment by immediate */
-    {"lfetch",                 M0, OpX6aHint (7, 0x2c, 0), {MR3, IMM9b}},
-    {"lfetch.nt1",             M0, OpX6aHint (7, 0x2c, 1), {MR3, IMM9b}},
-    {"lfetch.nt2",             M0, OpX6aHint (7, 0x2c, 2), {MR3, IMM9b}},
-    {"lfetch.nta",             M0, OpX6aHint (7, 0x2c, 3), {MR3, IMM9b}},
-    {"lfetch.excl",            M0, OpX6aHint (7, 0x2d, 0), {MR3, IMM9b}},
-    {"lfetch.excl.nt1",                M0, OpX6aHint (7, 0x2d, 1), {MR3, IMM9b}},
-    {"lfetch.excl.nt2",                M0, OpX6aHint (7, 0x2d, 2), {MR3, IMM9b}},
-    {"lfetch.excl.nta",                M0, OpX6aHint (7, 0x2d, 3), {MR3, IMM9b}},
-    {"lfetch.fault",           M0, OpX6aHint (7, 0x2e, 0), {MR3, IMM9b}},
-    {"lfetch.fault.nt1",       M0, OpX6aHint (7, 0x2e, 1), {MR3, IMM9b}},
-    {"lfetch.fault.nt2",       M0, OpX6aHint (7, 0x2e, 2), {MR3, IMM9b}},
-    {"lfetch.fault.nta",       M0, OpX6aHint (7, 0x2e, 3), {MR3, IMM9b}},
-    {"lfetch.fault.excl",      M0, OpX6aHint (7, 0x2f, 0), {MR3, IMM9b}},
-    {"lfetch.fault.excl.nt1",  M0, OpX6aHint (7, 0x2f, 1), {MR3, IMM9b}},
-    {"lfetch.fault.excl.nt2",  M0, OpX6aHint (7, 0x2f, 2), {MR3, IMM9b}},
-    {"lfetch.fault.excl.nta",  M0, OpX6aHint (7, 0x2f, 3), {MR3, IMM9b}},
+    /* Line prefetch w/increment by immediate.  */
+#define LFETCHINCIMMED(c,h) M0, OpX6aHint (7, c, h), {MR3, IMM9b}, POSTINC, 0, NULL
+    {"lfetch",                 LFETCHINCIMMED (0x2c, 0)},
+    {"lfetch.nt1",             LFETCHINCIMMED (0x2c, 1)},
+    {"lfetch.nt2",             LFETCHINCIMMED (0x2c, 2)},
+    {"lfetch.nta",             LFETCHINCIMMED (0x2c, 3)},
+    {"lfetch.excl",            LFETCHINCIMMED (0x2d, 0)},
+    {"lfetch.excl.nt1",                LFETCHINCIMMED (0x2d, 1)},
+    {"lfetch.excl.nt2",                LFETCHINCIMMED (0x2d, 2)},
+    {"lfetch.excl.nta",                LFETCHINCIMMED (0x2d, 3)},
+    {"lfetch.fault",           LFETCHINCIMMED (0x2e, 0)},
+    {"lfetch.fault.nt1",       LFETCHINCIMMED (0x2e, 1)},
+    {"lfetch.fault.nt2",       LFETCHINCIMMED (0x2e, 2)},
+    {"lfetch.fault.nta",       LFETCHINCIMMED (0x2e, 3)},
+    {"lfetch.fault.excl",      LFETCHINCIMMED (0x2f, 0)},
+    {"lfetch.fault.excl.nt1",  LFETCHINCIMMED (0x2f, 1)},
+    {"lfetch.fault.excl.nt2",  LFETCHINCIMMED (0x2f, 2)},
+    {"lfetch.fault.excl.nta",  LFETCHINCIMMED (0x2f, 3)},
+#undef LFETCHINCIMMED
 
-    {0}
+    {NULL, 0, 0, 0, 0, {0}, 0, 0, NULL}
   };
 
 #undef M0
@@ -1040,3 +1094,4 @@ struct ia64_opcode ia64_opcodes_m[] =
 #undef OpXX6aHint
 #undef OpMXX6a
 #undef OpMXX6aHint
+#undef EMPTY
This page took 0.050142 seconds and 4 git commands to generate.