summaryrefslogtreecommitdiffstats
path: root/opcodes/ia64-opc-m.c
diff options
context:
space:
mode:
authorJim Wilson <wilson@tuliptree.org>2000-08-16 23:20:15 +0000
committerJim Wilson <wilson@tuliptree.org>2000-08-16 23:20:15 +0000
commit50b81f1903a517fd16ec7a266d6c4668a5e37cce (patch)
treed2e1c065868c30785b3ead12e1620244dfaa3dbc /opcodes/ia64-opc-m.c
parentd670a150a1aa97f5b0a1e8e03184f7390a558310 (diff)
downloadppe42-binutils-50b81f1903a517fd16ec7a266d6c4668a5e37cce.tar.gz
ppe42-binutils-50b81f1903a517fd16ec7a266d6c4668a5e37cce.zip
Fix 3 DV bugs, and a few minor cleanups.
gas/ * config/tc-ia64.c (specify_resource, case IA64_RS_GR): Handle postincrement modified registers. Handle IA64_OPND_R3_2 addl source registers. (note_register_values): Handle IA64_OPND_R3_2 operands. gas/testsuite/ * gas/ia64/dv-raw-err.s: Add new tests for addl and postinc. * gas/ia64/dv-raw-err.l: Likewise. * gas/ia64/dv-waw-err.l: Update sed pattern. * gas/ia64/opc-f.pl: Delete fpsub, and fpadd comment. * gas/ia64/opc-f.s, gas/ia64/opc-f.d: Regenerate. include/opcode/ * ia64.h (IA64_OPCODE_POSTINC): New. opcodes/ * ia64-ic.tbl (pr-readers-nobr-nomovpr): Add addl, adds. Delete break, mov-immediate, nop. * ia64-opc-f.c: Delete fpsub instructions. * ia64-opc-m.c: Add POSTINC to all instructions with postincrement address operand. Rewrite using macros to avoid long lines. * ia64-opc.h (POSTINC): Define. * ia64-asmtab.c: Regenerate.
Diffstat (limited to 'opcodes/ia64-opc-m.c')
-rw-r--r--opcodes/ia64-opc-m.c884
1 files changed, 451 insertions, 433 deletions
diff --git a/opcodes/ia64-opc-m.c b/opcodes/ia64-opc-m.c
index 13a971e5e0..12eb95b706 100644
--- a/opcodes/ia64-opc-m.c
+++ b/opcodes/ia64-opc-m.c
@@ -262,117 +262,119 @@ struct ia64_opcode ia64_opcodes_m[] =
{"ld8.c.clr.acq.nta", M, OpMXX6aHint (4, 0, 0, 0x2b, 3), {R1, MR3}},
/* 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}},
+#define LDINCREG(c,h) M, OpMXX6aHint (4, 1, 0, c, h), {R1, MR3, R2}, POSTINC,
+ {"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}},
@@ -451,137 +453,141 @@ struct ia64_opcode ia64_opcodes_m[] =
{"getf.d", M, OpMXX6a (4, 0, 1, 0x1f), {R1, F2}},
/* 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}},
+#define LDINCIMMED(c,h) M, OpX6aHint (5, c, h), {R1, MR3, IMM9b}, POSTINC
+ {"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}},
+#define STINCIMMED(c,h) M, OpX6aHint (5, c, h), {MR3, R2, IMM9a}, POSTINC
+ {"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}},
@@ -660,81 +666,84 @@ struct ia64_opcode ia64_opcodes_m[] =
{"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}},
- {"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
+ {"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}},
@@ -805,7 +814,7 @@ struct ia64_opcode ia64_opcodes_m[] =
{"ldfp8.c.nc.nta", M2, OpMXX6aHint (6, 0, 1, 0x25, 3), {F1, F2, MR3}},
/* floating-point load pair w/increment by immediate */
-#define LD(a,b,c) M2, OpMXX6aHint (6, 1, 1, a, b), {F1, F2, MR3, c}
+#define LD(a,b,c) M2, OpMXX6aHint (6, 1, 1, a, b), {F1, F2, MR3, c}, POSTINC
{"ldfps", LD (0x02, 0, C8)},
{"ldfps.nt1", LD (0x02, 1, C8)},
{"ldfps.nta", LD (0x02, 3, C8)},
@@ -881,22 +890,24 @@ struct ia64_opcode ia64_opcodes_m[] =
{"lfetch.fault.excl.nta", M0, OpMXX6aHint (6, 0, 0, 0x2f, 3), {MR3}},
/* 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}},
+#define LFETCHINCREG(c,h) M0, OpMXX6aHint (6, 1, 0, c, h), {MR3, R2}, POSTINC
+ {"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}},
@@ -904,111 +915,118 @@ struct ia64_opcode ia64_opcodes_m[] =
{"setf.s", M, OpMXX6a (6, 0, 1, 0x1e), {F1, R2}},
{"setf.d", M, OpMXX6a (6, 0, 1, 0x1f), {F1, R2}},
- {"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
+ {"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}},
+#define FSTINCIMMED(c,h) M, OpX6aHint (7, c, h), {MR3, F2, IMM9a}, POSTINC
+ {"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}},
+#define LFETCHINCIMMED(c,h) M0, OpX6aHint (7, c, h), {MR3, IMM9b}, POSTINC
+ {"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}
};
OpenPOWER on IntegriCloud