📄 ia64-opc-m.c
字号:
/* ia64-opc-m.c -- IA-64 `M' opcode table. Copyright 1998, 1999, 2000 Free Software Foundation, Inc. Contributed by David Mosberger-Tang <davidm@hpl.hp.com> This file is part of GDB, GAS, and the GNU binutils. GDB, GAS, and the GNU binutils are free software; you can redistribute them and/or modify them under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2, or (at your option) any later version. GDB, GAS, and the GNU binutils are distributed in the hope that they will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this file; see the file COPYING. If not, write to the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */#include "ia64-opc.h"#define M0 IA64_TYPE_M, 0#define M IA64_TYPE_M, 1#define M2 IA64_TYPE_M, 2/* instruction bit fields: */#define bM(x) (((ia64_insn) ((x) & 0x1)) << 36)#define bX(x) (((ia64_insn) ((x) & 0x1)) << 27)#define bX2(x) (((ia64_insn) ((x) & 0x3)) << 31)#define bX3(x) (((ia64_insn) ((x) & 0x7)) << 33)#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 bHint(x) (((ia64_insn) ((x) & 0x3)) << 28)#define mM bM (-1)#define mX bX (-1)#define mX2 bX2 (-1)#define mX3 bX3 (-1)#define mX4 bX4 (-1)#define mX6a bX6a (-1)#define mX6b bX6b (-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 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 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)), \ (mOp | mX | mX6a | mHint)#define OpMXX6a(a,b,c,d) \ (bOp (a) | bM (b) | bX (c) | bX6a (d)), (mOp | mM | mX | mX6a)#define OpMXX6aHint(a,b,c,d,e) \ (bOp (a) | bM (b) | bX (c) | bX6a (d) | bHint (e)), \ (mOp | mM | mX | mX6a | mHint)struct ia64_opcode ia64_opcodes_m[] = { /* 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}}, {"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}}, {"break.m", M0, OpX3X4X2 (0, 0, 0, 0), {IMMU21}}, {"nop.m", M0, OpX3X4X2 (0, 0, 1, 0), {IMMU21}}, {"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}, {"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}, {"alloc", M, OpX3 (1, 6), {R1, AR_PFS, SOF, SOL, SOR}, FIRST|NO_PRED|MOD_RRBS}, {"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, 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, 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}}, {"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}, {"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}, {"chk.s.m", M0, OpX3 (1, 1), {R2, TGT25b}}, {"chk.s", M0, OpX3 (1, 3), {F2, TGT25b}}, {"fc", M0, OpX3X6b (1, 0, 0x30), {R3}}, {"ptc.e", M0, OpX3X6b (1, 0, 0x34), {R3}, PRIV}, /* 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}}, /* integer load w/increment by register */#define LDINCREG(c,h) M, OpMXX6aHint (4, 1, 0, c, h), {R1, MR3, R2}, POSTINC, {"ld1", LDINCREG (0x00, 0)},
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -