diff options
| author | cvs2svn <cvs2svn@FreeBSD.org> | 2000-04-18 02:42:13 +0000 | 
|---|---|---|
| committer | cvs2svn <cvs2svn@FreeBSD.org> | 2000-04-18 02:42:13 +0000 | 
| commit | 250e7c04cd108375c2bc4e6657a3d660ecc4f10c (patch) | |
| tree | ffc0692c3d95a48643d48abc64d13f425186d5c0 /contrib/binutils/include/opcode | |
| parent | bf5476a7568284207ef150fa66e60173e5fd7c2b (diff) | |
Notes
Diffstat (limited to 'contrib/binutils/include/opcode')
| -rw-r--r-- | contrib/binutils/include/opcode/ChangeLog | 1364 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/alpha.h | 237 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/arc.h | 274 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/cgen.h | 873 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/convex.h | 1711 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/i386.h | 981 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/mips.h | 715 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/np1.h | 422 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/pn.h | 282 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/sparc.h | 240 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/tic30.h | 691 | ||||
| -rw-r--r-- | contrib/binutils/include/opcode/v850.h | 154 | 
12 files changed, 0 insertions, 7944 deletions
| diff --git a/contrib/binutils/include/opcode/ChangeLog b/contrib/binutils/include/opcode/ChangeLog deleted file mode 100644 index 40ea655e5613..000000000000 --- a/contrib/binutils/include/opcode/ChangeLog +++ /dev/null @@ -1,1364 +0,0 @@ -Mon Mar 30 21:31:56 1998  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h: Revert March 24 patch; no more LinearAddress. - -Mon Mar 30 10:25:54 1998  Alan Modra  <alan@spri.levels.unisa.edu.au> - -	* i386.h (i386_optab): Remove fwait (9b) from all floating point -	instructions, and instead add FWait opcode modifier.  Add short -	form of fldenv and fstenv. -	(FWAIT_OPCODE): Define. - -	* i386.h (i386_optab): Change second operand constraint of `mov -	sreg,reg|mem' instruction from Reg16|Mem to WordReg|WordMem to -	allow legal instructions such as `movl %gs,%esi' - -Fri Mar 27 18:30:52 1998  Ian Lance Taylor  <ian@cygnus.com> - -	* h8300.h: Various changes to fully bracket initializers. - -Tue Mar 24 18:32:47 1998  H.J. Lu  <hjl@gnu.org> - -	* i386.h: Set LinearAddress for lidt and lgdt. - -Mon Mar  2 10:44:07 1998  Doug Evans  <devans@seba.cygnus.com> - -	* cgen.h (CGEN_BOOL_ATTR): New macro. - -Mon Feb 23 10:38:21 1998  Doug Evans  <devans@seba.cygnus.com> - -	* cgen.h (CGEN_CAT3): Delete.  Use CONCAT3 now. -	(cgen_insn): Record syntax and format entries here, rather than -	separately. - -Tue Feb 17 21:42:56 1998  Nick Clifton  <nickc@cygnus.com> - -	* cgen.h (CGEN_SYNTAX_MAKE_FIELD): New macro. - -Tue Feb 17 16:00:56 1998  Doug Evans  <devans@seba.cygnus.com> - -	* cgen.h (cgen_insert_fn): Change type of result to const char *. -	(cgen_parse_{signed,unsigned}_integer): Delete min,max arguments. -	(CGEN_{INSN,KEYWORD,OPERAND}_NBOOL_ATTRS): Renamed from ..._MAX_ATTRS. - -Thu Feb 12 18:30:41 1998  Doug Evans  <devans@canuck.cygnus.com> - -	* cgen.h (lookup_insn): New argument alias_p. - -Thu Feb 12 03:41:00 1998  J"orn Rennecke  <amylaar@cygnus.co.uk> - -Fix rac to accept only a0: -	* d10v.h (OPERAND_ACC): Split into: -	(OPERAND_ACC0, OPERAND_ACC1) . -	(OPERAND_GPR): Define. - -Wed Feb 11 17:31:53 1998  Doug Evans  <devans@seba.cygnus.com> - -	* cgen.h (CGEN_FIELDS): Define here. -	(CGEN_HW_ENTRY): New member `type'. -	(hw_list): Delete decl. -	(enum cgen_mode): Declare. -	(CGEN_OPERAND): New member `hw'. -	(enum cgen_operand_instance_type): Declare. -	(CGEN_OPERAND_INSTANCE): New type. -	(CGEN_INSN): New member `operands'. -	(CGEN_OPCODE_DATA): Make hw_list const. -	(get_insn_operands,lookup_insn): Add prototypes for. - -Tue Feb  3 17:11:23 1998  Doug Evans  <devans@seba.cygnus.com> - -	* cgen.h (CGEN_INSN_MAX_ATTRS): Renamed from CGEN_MAX_INSN_ATTRS. -	(CGEN_HW_ENTRY): Move `next' entry to end of struct. -	(CGEN_KEYWORD_MAX_ATTRS): Renamed from CGEN_MAX_KEYWORD_ATTRS. -	(CGEN_OPERAND_MAX_ATTRS): Renamed from CGEN_MAX_OPERAND_ATTRS. - -Mon Feb  2 19:19:15 1998  Ian Lance Taylor  <ian@cygnus.com> - -	* cgen.h: Correct typo in comment end marker. - -Mon Feb  2 17:10:38 1998  Steve Haworth  <steve@pm.cse.rmit.EDU.AU> - -	* tic30.h: New file. - -Thu Jan 22 17:54:56 1998  Nick Clifton  <nickc@cygnus.com> - -	* cgen.h: Add prototypes for cgen_save_fixups(), -	cgen_restore_fixups(), and cgen_swap_fixups().  Change prototype -	of cgen_asm_finish_insn() to return a char *. - -Wed Jan 14 17:21:43 1998  Nick Clifton  <nickc@cygnus.com> - -	* cgen.h: Formatting changes to improve readability.  - -Mon Jan 12 11:37:36 1998  Doug Evans  <devans@seba.cygnus.com> - -	* cgen.h (*): Clean up pass over `struct foo' usage. -	(CGEN_ATTR): Make unsigned char. -	(CGEN_ATTR_TYPE): Update. -	(CGEN_ATTR_{ENTRY,TABLE}): New types. -	(cgen_base): Move member `attrs' to cgen_insn. -	(CGEN_KEYWORD): New member `null_entry'. -	(CGEN_{SYNTAX,FORMAT}): New types. -	(cgen_insn): Format and syntax separated from each other. - -Mon Dec  1 12:24:44 1997  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> - -	* m68k.h: Fix comment describing operand types. - -Tue Nov 18 18:45:14 1997  J"orn Rennecke  <amylaar@cygnus.co.uk> - -	* d10v.h (OPERAND_FLAG): Split into: -	(OPERAND_FFLAG, OPERAND_CFLAG) . - -Thu Nov 13 11:04:24 1997  Gavin Koch  <gavin@cygnus.com> - -	* mips.h (struct mips_opcode): Changed comments to reflect new -	field usage. - -Fri Oct 24 22:36:20 1997  Ken Raeburn  <raeburn@cygnus.com> - -	* mips.h: Added to comments a quick-ref list of all assigned -	operand type characters. -	(OP_{MASK,SH}_PERFREG): New macros. - -Wed Oct 22 17:28:33 1997  Richard Henderson  <rth@cygnus.com> - -	* sparc.h: Add '_' and '/' for v9a asr's. -	Patch from David Miller <davem@vger.rutgers.edu> - -Tue Oct 14 13:22:29 1997  Jeffrey A Law  (law@cygnus.com) - -	* h8300.h: Bit ops with absolute addresses not in the 8 bit -	area are not available in the base model (H8/300). - -Thu Sep 25 13:03:41 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* m68k.h: Remove documentation of ` operand specifier. - -Wed Sep 24 19:00:34 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* m68k.h: Document q and v operand specifiers. - -Mon Sep 15 18:28:37 1997  Nick Clifton  <nickc@cygnus.com> - -	* v850.h (struct v850_opcode): Add processors field. -	(PROCESSOR_V850, PROCESSOR_ALL): New bit constants. - -Mon Sep  8 14:05:45 1997  Doug Evans  <dje@canuck.cygnus.com> - -	* cgen.h: Move assembler interface section -	up so cgen_parse_operand_result is defined for cgen_parse_address. -	(cgen_parse_address): Update prototype. - -Tue Sep  2 15:32:32 1997  Nick Clifton  <nickc@cygnus.com> - -	* v850.h (V850_OPREAND_ADJUST_SHORT_MEMORY): Removed.  - -Tue Aug 26 12:21:52 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h (two_byte_segment_defaults): Correct base register 5 in -	modes 1 and 2 to be ss rather than ds.  From Gabriel Paubert -	<paubert@iram.es>. - -	* i386.h: Set ud2 to 0x0f0b.  From Gabriel Paubert -	<paubert@iram.es>. - -	* i386.h: Comment fixes for ficom[p]?{s,l} from Gabriel Paubert -	<paubert@iram.es>. - -	* i386.h (JUMP_ON_CX_ZERO): Uncomment (define again). -	(JUMP_ON_ECX_ZERO): Remove commented out macro. - -Fri Aug 22 10:38:29 1997  Nick Clifton  <nickc@cygnus.com> - -	* v850.h (V850_NOT_R0): New flag. - -Mon Aug 18 11:05:58 1997  Nick Clifton  <nickc@cygnus.com> - -	* v850.h (struct v850_opcode): Remove flags field.  - -Wed Aug 13 18:45:48 1997  Nick Clifton  <nickc@cygnus.com> - -	* v850.h (struct v850_opcode): Add flags field. -	(struct v850_operand): Extend meaning of 'bits' and 'shift' -	fields.  - - -Fri Aug  8 16:58:42 1997  Doug Evans  <dje@canuck.cygnus.com> - -	* arc.h: New file. - -Thu Jul 24 21:16:58 1997  Doug Evans  <dje@canuck.cygnus.com> - -	* sparc.h (sparc_opcodes): Declare as const. - -Thu Jul 10 12:53:25 1997  Jeffrey A Law  (law@cygnus.com) - -	* mips.h (FP_S, FP_D): Define.  Bitmasks indicating if an insn -	uses single or double precision floating point resources. -	(INSN_NO_ISA, INSN_ISA1): Define. -	(cpu specific INSN macros): Tweak into bitmasks outside the range -	of INSN_ISA field. - -Mon Jun 16 14:10:00 1997  H.J. Lu  <hjl@gnu.ai.mit.edu> - -	* i386.h: Fix pand opcode. - -Mon Jun  2 11:35:09 1997  Gavin Koch  <gavin@cygnus.com> - -	* mips.h: Widen INSN_ISA and move it to a more convenient -	bit position.  Add INSN_3900. - -Tue May 20 11:25:29 1997  Gavin Koch  <gavin@cygnus.com> - -	* mips.h (struct mips_opcode): added new field membership. - -Mon May 12 16:26:50 1997  H.J. Lu  <hjl@gnu.ai.mit.edu> - -	* i386.h (movd): only Reg32 is allowed. - -	* i386.h: add fcomp and ud2.  From Wayne Scott -	<wscott@ichips.intel.com>. - -Mon May  5 17:16:21 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h: Add MMX instructions. - -Mon May  5 12:45:19 1997  H.J. Lu  <hjl@gnu.ai.mit.edu> - -	* i386.h: Remove W modifier from conditional move instructions. - -Mon Apr 14 14:56:58 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h: Change the opcodes for fsubp, fsubrp, fdivp, and fdivrp -	with no arguments to match that generated by the UnixWare -	assembler. - -Thu Apr 10 14:35:00 1997  Doug Evans  <dje@canuck.cygnus.com> - -	* cgen.h (<cpu>_cgen_assemble_insn): New arg for errmsg. -	(cgen_parse_operand_fn): Declare. -	(cgen_init_parse_operand): Declare. -	(cgen_parse_operand): Renamed from cgen_asm_parse_operand, -	new argument `want'. -	(enum cgen_parse_operand_result): Renamed from cgen_asm_result. -	(enum cgen_parse_operand_type): New enum. - -Sat Apr  5 13:14:05 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h: Revert last patch for the NON_BROKEN_OPCODES cases. - -Fri Apr  4 11:46:11 1997  Doug Evans  <dje@canuck.cygnus.com> - -	* cgen.h: New file. - -Fri Apr  4 14:02:32 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h: Correct opcode values for fsubp, fsubrp, fdivp, and -	fdivrp. - -Tue Mar 25 22:57:26 1997  Stu Grossman  (grossman@critters.cygnus.com) - -	* v850.h (extract):  Make unsigned. - -Mon Mar 24 14:38:15 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h: Add iclr. - -Thu Mar 20 19:49:10 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h: Change DW to W for cmpxchg and xadd, since they don't -	take a direction bit. - -Sat Mar 15 19:03:29 1997  H.J. Lu  <hjl@lucon.org> - -	* sparc.h (sparc_opcode_lookup_arch): Use full prototype. - -Fri Mar 14 15:22:01 1997  Ian Lance Taylor  <ian@cygnus.com> - -	* sparc.h: Include <ansidecl.h>.  Update function declarations to -	use prototypes, and to use const when appropriate. - -Thu Mar  6 14:18:30 1997  Jeffrey A Law  (law@cygnus.com) - -	* mn10300.h (MN10300_OPERAND_RELAX): Define. - -Mon Feb 24 15:15:56 1997  Martin M. Hunt  <hunt@pizza.cygnus.com> - -	* d10v.h: Change pre_defined_registers to  -	d10v_predefined_registers and reg_name_cnt to d10v_reg_name_cnt. - -Sat Feb 22 21:25:00 1997  Dawn Perchik  <dawn@cygnus.com> - -	* mips.h: Add macros for cop0, cop1 cop2 and cop3. -	Change mips_opcodes from const array to a pointer,  -	and change bfd_mips_num_opcodes from const int to int, -	so that we can increase the size of the mips opcodes table  -	dynamically. -	 -Wed Jan 29 09:37:25 1997  Jeffrey A Law  (law@cygnus.com) - -	* mn10200.h (MN10200_OPERAND_RELAX): Define. - -Tue Dec 31 15:05:41 1996  Michael Meissner  <meissner@tiktok.cygnus.com> - -	* v850.h (V850_OPERAND_ADJUST_SHORT_MEMORY): New flag to adjust -	type IV instruction offsets. - -Wed Dec 18 10:06:31 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10200.h (MN10200_OPERAND_NOCHECK): Define. - -Sat Dec 14 10:48:31 1996  Fred Fish  <fnf@ninemoons.com> - -	* mn10200.h: Fix comment, mn10200_operand not powerpc_operand. -	* mn10300.h: Fix comment, mn10300_operand not powerpc_operand. -	* v850.h: Fix comment, v850_operand not powerpc_operand. -	 -Mon Dec  9 16:45:39 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10200.h: Flesh out structures and definitions needed by -	the mn10200 assembler & disassembler. - -Tue Nov 26 10:46:56 1996  Ian Lance Taylor  <ian@cygnus.com> - -	* mips.h: Add mips16 definitions. - -Mon Nov 25 17:56:54 1996  J.T. Conklin  <jtc@cygnus.com> - -	* m68k.h: Document new <, >, m, n, o and p operand specifiers. - -Wed Nov 20 10:59:41 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10300.h (MN10300_OPERAND_PCREL): Define. -	(MN10300_OPERAND_MEMADDR): Define. - -Tue Nov 19 13:30:40 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10300.h (MN10300_OPERAND_REG_LIST): Define. - -Wed Nov  6 13:41:08 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10300.h (MN10300_OPERAND_SPLIT): Define. - -Tue Nov  5 13:26:12 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10300.h (MN10300_OPERAND_EXTENDED): Define. - -Mon Nov  4 12:52:48 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10300.h (MN10300_OPERAND_REPEATED): Define. - -Fri Nov  1 10:31:02 1996  Richard Henderson  <rth@tamu.edu> - -	* alpha.h: Don't include "bfd.h"; private relocation types are now - 	negative to minimize problems with shared libraries.  Organize - 	instruction subsets by AMASK extensions and PALcode - 	implementation. -	(struct alpha_operand): Move flags slot for better packing. - -Tue Oct 29 12:19:10 1996  Jeffrey A Law  (law@cygnus.com) - -	* v850.h (V850_OPERAND_RELAX): New operand flag. - -Thu Oct 10 14:29:11 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10300.h (FMT_*): Move operand format definitions -	here. - -Tue Oct  8 14:48:07 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10300.h (MN10300_OPERAND_PAREN): Define. - -Mon Oct  7 16:52:11 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10300.h (mn10300_opcode): Add "format" field. -	(MN10300_OPERAND_*): Define. - -Thu Oct  3 10:33:46 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10x00.h: Delete. -	* mn10200.h, mn10300.h: New files. - -Wed Oct  2 21:31:26 1996  Jeffrey A Law  (law@cygnus.com) - -	* mn10x00.h: New file. - -Fri Sep 27 18:26:46 1996  Stu Grossman  (grossman@critters.cygnus.com) - -	* v850.h:  Add new flag to indicate this instruction uses a PC -	displacement. - -Fri Sep 13 14:58:13 1996  Jeffrey A Law  (law@cygnus.com) - -	* h8300.h (stmac): Add missing instruction. - -Sat Aug 31 16:02:03 1996  Jeffrey A Law  (law@cygnus.com) - -	* v850.h (v850_opcode): Remove "size" field.  Add "memop" -	field. - -Fri Aug 23 10:39:08 1996  Jeffrey A Law  (law@cygnus.com) - -	* v850.h (V850_OPERAND_EP): Define. - -	* v850.h (v850_opcode): Add size field. - -Thu Aug 22 16:51:25 1996  J.T. Conklin  <jtc@rtl.cygnus.com> - -	* v850.h (v850_operands): Add insert and extract fields, pointers - 	to functions used to handle unusual operand encoding. -	(V850_OPERAND_REG, V850_OPERAND_SRG, V850_OPERAND_CC, - 	V850_OPERAND_SIGNED): Defined. - -Wed Aug 21 17:45:10 1996  J.T. Conklin  <jtc@rtl.cygnus.com> - -	* v850.h (v850_operands): Add flags field. -	(OPERAND_REG, OPERAND_NUM): Defined. - -Tue Aug 20 14:52:02 1996  J.T. Conklin  <jtc@rtl.cygnus.com> - -	* v850.h: New file. - -Fri Aug 16 14:44:15 1996  James G. Smith  <jsmith@cygnus.co.uk> - -	* mips.h (OP_SH_LOCC, OP_SH_HICC, OP_MASK_CC, OP_SH_COP1NORM, - 	OP_MASK_COP1NORM, OP_SH_COP1SPEC, OP_MASK_COP1SPEC, - 	OP_MASK_COP1SCLR, OP_MASK_COP1CMP, OP_SH_COP1CMP, OP_SH_FORMAT, - 	OP_MASK_FORMAT, OP_SH_TRUE, OP_MASK_TRUE, OP_SH_GE, OP_MASK_GE, - 	OP_SH_UNSIGNED, OP_MASK_UNSIGNED, OP_SH_HINT, OP_MASK_HINT): - 	Defined. - -Fri Aug 16 00:15:15 1996  Jeffrey A Law  (law@cygnus.com) - -	* hppa.h (pitlb, pitlbe, iitlba, iitlbp, fic, fice): Accept -	a 3 bit space id instead of a 2 bit space id. - -Thu Aug 15 13:11:46 1996  Martin M. Hunt  <hunt@pizza.cygnus.com> - -	* d10v.h: Add some additional defines to support the - 	assembler in determining which operations can be done in parallel. - -Tue Aug  6 11:13:22 1996  Jeffrey A Law  (law@cygnus.com) - -	* h8300.h (SN): Define. -	(eepmov.b): Renamed from "eepmov" -	(nop, bpt, rte, rts, sleep, clrmac): These have no size associated -	with them. - -Fri Jul 26 11:47:10 1996  Martin M. Hunt  <hunt@pizza.cygnus.com> - -	* d10v.h (OPERAND_SHIFT): New operand flag. - -Thu Jul 25 12:06:22 1996  Martin M. Hunt  <hunt@pizza.cygnus.com> - -	* d10v.h: Changes for divs, parallel-only instructions, and - 	signed numbers. - -Mon Jul 22 11:21:15 1996  Martin M. Hunt  <hunt@pizza.cygnus.com> - -	* d10v.h (pd_reg): Define. Putting the definition here allows -	the assembler and disassembler to share the same struct. - -Mon Jul 22 12:15:25 1996  Ian Lance Taylor  <ian@cygnus.com> - -	* i960.h (i960_opcodes): "halt" takes an argument.  From Stephen -	Williams <steve@icarus.com>. - -Wed Jul 17 14:46:38 1996  Martin M. Hunt  <hunt@pizza.cygnus.com> - -	* d10v.h: New file.  - -Thu Jul 11 12:09:15 1996  Jeffrey A Law  (law@cygnus.com) - -	* h8300.h (band, bclr): Force high bit of immediate nibble to zero. - -Wed Jul  3 14:30:12 1996  J.T. Conklin  <jtc@rtl.cygnus.com> - - 	* m68k.h (mcf5200): New macro. -	Document names of coldfire control registers. - -Tue Jul  2 23:05:45 1996  Jeffrey A Law  (law@cygnus.com) - -	* h8300.h (SRC_IN_DST): Define. - -	* h8300.h (UNOP3): Mark the register operand in this insn -	as a source operand, not a destination operand. -	(SHIFT_2, SHIFT_IMM): Remove.  Eliminate all references. -	(UNOP3): Change SHIFT_IMM to IMM for H8/S bitops.  Mark -	register operand with SRC_IN_DST. - -Fri Jun 21 13:52:17 1996  Richard Henderson  <rth@tamu.edu> - -	* alpha.h: New file. - -Thu Jun 20 15:02:57 1996  Ian Lance Taylor  <ian@cygnus.com> - -	* rs6k.h: Remove obsolete file. - -Wed Jun 19 15:29:38 1996  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h: Correct opcode values for faddp, fsubp, fsubrp, fmulp, -	fdivp, and fdivrp.  Add ffreep. - -Tue Jun 18 16:06:00 1996  Jeffrey A. Law  <law@rtl.cygnus.com> - -	* h8300.h: Reorder various #defines for readability. -	(ABS32SRC, ABS32DST, DSP32LIST, ABS32LIST, A32LIST): Define. -	(BITOP): Accept additional (unused) argument.  All callers changed. -	(EBITOP): Likewise. -	(O_LAST): Bump. -	(ldc, stc, movb, movw, movl): Use 32bit offsets and absolutes. -	 -	* h8300.h (EXR, SHIFT_2, MACREG, SHIFT_IMM, RDINC): Define. -	(O_TAS, O_CLRMAC, O_LDMAC, O_MAC, O_LDM, O_STM): Define. -	(BITOP, EBITOP): Handle new H8/S addressing modes for -	bit insns. -	(UNOP3): Handle new shift/rotate insns on the H8/S. -	(insns using exr): New instructions. -	(tas, mac, ldmac, clrmac, ldm, stm): New instructions. -	 -Thu May 23 16:56:48 1996  Jeffrey A Law  (law@cygnus.com) - -	* h8300.h (add.l): Undo Apr 5th change.  The manual I had -	was incorrect. - -Mon May  6 23:38:22 1996  Jeffrey A Law  (law@cygnus.com) - -	* h8300.h (START): Remove. -	(MEMRELAX): Define.  Mark absolute memory operands in mov.b, mov.w -	and mov.l insns that can be relaxed. - -Tue Apr 30 18:30:58 1996  Ian Lance Taylor  <ian@cygnus.com> - -	* i386.h: Remove Abs32 from lcall. - -Mon Apr 22 17:09:23 1996  Doug Evans  <dje@blues.cygnus.com> - -	* sparc.h (SPARC_OPCODE_ARCH_V9_P): New macro. -	(SLCPOP): New macro. -	Mark X,Y opcode letters as in use. - -Thu Apr 11 17:28:18 1996  Ian Lance Taylor  <ian@cygnus.com> - -	* sparc.h (F_FLOAT, F_FBR): Define. - -Fri Apr  5 16:55:34 1996  Jeffrey A Law  (law@cygnus.com) - -	* h8300.h (ABS8MEM): Renamed from ABSMOV.  Remove ABSMOV -	from all insns. -	(ABS8SRC,ABS8DST): Add ABS8MEM. -	(add.l): Fix reg+reg variant. -	(eepmov.w): Renamed from eepmovw. -	(ldc,stc): Fix many cases. - -Sun Mar 31 13:30:03 1996  Doug Evans  <dje@canuck.cygnus.com> - -	* sparc.h (SPARC_OPCODE_ARCH_MASK): New macro. - -Thu Mar  7 15:08:23 1996  Doug Evans  <dje@charmed.cygnus.com> - -	* sparc.h (O): Mark operand letter as in use. - -Tue Feb 20 20:46:21 1996  Doug Evans  <dje@charmed.cygnus.com> - -	* sparc.h (sparc_{encode,decode}_sparclet_cpreg): Declare. -	Mark operand letters uU as in use. - -Mon Feb 19 01:59:08 1996  Doug Evans  <dje@charmed.cygnus.com> - -	* sparc.h (sparc_opcode_arch_val): Add SPARC_OPCODE_ARCH_SPARCLET. -	(sparc_opcode_arch): Delete member `conflicts'.  Add `supported'. -	(SPARC_OPCODE_SUPPORTED): New macro. -	(SPARC_OPCODE_CONFLICT_P): Rewrite. -	(F_NOTV9): Delete. - -Fri Feb 16 12:23:34 1996  Jeffrey A Law  (law@cygnus.com) - -	* sparc.h (sparc_opcode_lookup_arch) Make return type in -	declaration consistent with return type in definition. - -Wed Feb 14 18:14:11 1996  Alan Modra  <alan@spri.levels.unisa.edu.au> - -	* i386.h (i386_optab): Remove Data32 from pushf and popf. - -Thu Feb  8 14:27:21 1996  James Carlson <carlson@xylogics.com> - -	* i386.h (i386_regtab): Add 80486 test registers. - -Mon Feb  5 18:35:46 1996  Ian Lance Taylor  <ian@cygnus.com> - -	* i960.h (I_HX): Define. -	(i960_opcodes): Add HX instruction. - -Mon Jan 29 12:43:39 1996  Ken Raeburn  <raeburn@cygnus.com> - -	* i386.h: Fix waiting forms of finit, fstenv, fsave, fstsw, fstcw, -	and fclex. - -Wed Jan 24 22:36:59 1996  Doug Evans  <dje@charmed.cygnus.com> - -	* sparc.h (enum sparc_opcode_arch_val): Replaces sparc_architecture. -	(SPARC_OPCODE_CONFLICT_P): Renamed from ARCHITECTURES_CONFLICT_P. -	(bfd_* defines): Delete. -	(sparc_opcode_archs): Replaces architecture_pname. -	(sparc_opcode_lookup_arch): Declare. -	(NUMOPCODES): Delete. - -Mon Jan 22 08:24:32 1996  Doug Evans  <dje@charmed.cygnus.com> - -	* sparc.h (enum sparc_architecture): Add v9a. -	(ARCHITECTURES_CONFLICT_P): Update. - -Thu Dec 28 13:27:53 1995  John Hassey  <hassey@rtp.dg.com> - -	* i386.h: Added Pentium Pro instructions. - -Thu Nov  2 22:59:22 1995  Ian Lance Taylor  <ian@cygnus.com> - -	* m68k.h: Document new 'W' operand place. - -Tue Oct 24 10:49:10 1995  Jeffrey A Law  (law@cygnus.com) - -	* hppa.h: Add lci and syncdma instructions. - -Mon Oct 23 11:09:16 1995  James G. Smith  <jsmith@pasanda.cygnus.co.uk> - -	* mips.h: Added INSN_4100 flag to mark NEC VR4100 specific - 	instructions. - -Mon Oct 16 10:28:15 1995  Michael Meissner  <meissner@tiktok.cygnus.com> - -	* ppc.h (PPC_OPCODE_{COMMON,ANY}): New opcode flags for -	assembler's -mcom and -many switches. - -Wed Oct 11 16:56:33 1995  Ken Raeburn  <raeburn@cygnus.com> - -	* i386.h: Fix cmpxchg8b extension opcode description. - -Thu Oct  5 18:03:36 1995  Ken Raeburn  <raeburn@cygnus.com> - -	* i386.h: Add Pentium instructions wrmsr, rdtsc, rdmsr, cmpxchg8b, -	and register cr4. - -Tue Sep 19 15:26:43 1995  Ian Lance Taylor  <ian@cygnus.com> - -	* m68k.h: Change comment: split type P into types 0, 1 and 2. - -Wed Aug 30 13:50:55 1995  Doug Evans  <dje@canuck.cygnus.com> - -	* sparc.h (sparc_{encode,decode}_prefetch): Declare. - -Tue Aug 29 15:34:58 1995  Doug Evans  <dje@canuck.cygnus.com> - -	* sparc.h (sparc_{encode,decode}_{asi,membar}): Declare. - -Wed Aug  2 18:32:19 1995  Ian Lance Taylor  <ian@cygnus.com> - -	* m68kmri.h: Remove. - -	* m68k.h: Move tables into opcodes/m68k-opc.c, leaving just the -	declarations.  Remove F_ALIAS and flag field of struct -	m68k_opcode.  Change arch field of struct m68k_opcode to unsigned -	int.  Make name and args fields of struct m68k_opcode const. - -Wed Aug  2 08:16:46 1995  Doug Evans  <dje@canuck.cygnus.com> - -	* sparc.h (F_NOTV9): Define. - -Tue Jul 11 14:20:42 1995  Jeff Spiegel  <jeffs@lsil.com> - -	* mips.h (INSN_4010): Define. - -Wed Jun 21 18:49:51 1995  Ken Raeburn  <raeburn@cujo.cygnus.com> - -	* m68k.h (TBL1): Reverse sense of "round" argument in result. - -	Changes from Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>: -	* m68k.h: Fix argument descriptions of coprocessor -	instructions to allow only alterable operands where appropriate. -	[!NO_DEFAULT_SIZES]: An omitted size defaults to `w'. -	(m68k_opcode_aliases): Add more aliases. - -Fri Apr 14 22:15:34 1995  Ken Raeburn  <raeburn@cujo.cygnus.com> - -	* m68k.h: Added explcitly short-sized conditional branches, and a -	bunch of aliases (fmov*, ftest*, tdivul) to support gcc's -	svr4-based configurations. - -Mon Mar 13 21:30:01 1995  Ken Raeburn  <raeburn@cujo.cygnus.com> - -	Mon Feb 27 08:36:39 1995  Bryan Ford  <baford@cs.utah.edu> -	* i386.h: added missing Data16/Data32 flags to a few instructions. - -Wed Mar  8 15:19:53 1995  Ian Lance Taylor  <ian@cygnus.com> - -	* mips.h (OP_MASK_FR, OP_SH_FR): Define. -	(OP_MASK_BCC, OP_SH_BCC): Define. -	(OP_MASK_PREFX, OP_SH_PREFX): Define. -	(OP_MASK_CCC, OP_SH_CCC): Define. -	(INSN_READ_FPR_R): Define. -	(INSN_RFE): Delete. - -Wed Mar  8 03:13:23 1995  Ken Raeburn  <raeburn@cujo.cygnus.com> - -	* m68k.h (enum m68k_architecture): Deleted. -	(struct m68k_opcode_alias): New type. -	(m68k_opcodes): Now const.  Deleted opcode aliases with exactly -	matching constraints, values and flags.  As a side effect of this, -	the MOTOROLA_SYNTAX_ONLY and MIT_SYNTAX_ONLY macros, which so far -	as I know were never used, now may need re-examining. -	(numopcodes): Now const. -	(m68k_opcode_aliases, numaliases): New variables. -	(endop): Deleted. -	[DONT_DEFINE_TABLE]: Declare numopcodes, numaliases, and -	m68k_opcode_aliases; update declaration of m68k_opcodes. - -Mon Mar  6 10:02:00 1995  Jeff Law  (law@snake.cs.utah.edu) - -	* hppa.h (delay_type): Delete unused enumeration. -	(pa_opcode): Replace unused delayed field with an architecture -	field. -	(pa_opcodes): Mark each instruction as either PA1.0 or PA1.1. - -Fri Mar  3 16:10:24 1995  Ian Lance Taylor  <ian@cygnus.com> - -	* mips.h (INSN_ISA4): Define. - -Fri Feb 24 19:13:37 1995  Ian Lance Taylor  <ian@cygnus.com> - -	* mips.h (M_DLA_AB, M_DLI): Define. - -Thu Feb 23 17:33:09 1995  Jeff Law  (law@snake.cs.utah.edu) - -	* hppa.h (fstwx): Fix single-bit error. - -Wed Feb 15 12:19:52 1995  Ian Lance Taylor  <ian@cygnus.com> - -	* mips.h (M_ULD, M_ULD_A, M_USD, M_USD_A): Define. - -Mon Feb  6 10:35:23 1995  J.T. Conklin  <jtc@rtl.cygnus.com> - -	* i386.h: added cpuid instruction , and dr[0-7] aliases for the -	  debug registers.  From Charles Hannum (mycroft@netbsd.org). - -Mon Feb  6 03:31:54 1995  Ken Raeburn  <raeburn@cujo.cygnus.com> - -	Changes from Bryan Ford <baford@schirf.cs.utah.edu> for 16-bit -	i386 support: -	* i386.h (MOV_AX_DISP32): New macro. -	(i386_optab): Added Data16 and Data32 as needed.  Added "w" forms -	of several call/return instructions. -	(ADDR_PREFIX_OPCODE): New macro. - -Mon Jan 23 16:45:43 1995  Ken Raeburn  <raeburn@cujo.cygnus.com> - -	Sat Jan 21 17:50:38 1995  Pat Rankin  (rankin@eql.caltech.edu) - -	* ../include/opcode/vax.h (struct vot_wot, field `args'):  make -	it pointer to const char; -	(struct vot, field `name'):  ditto. - -Thu Jan 19 14:47:53 1995  Ken Raeburn  <raeburn@cujo.cygnus.com> - -	* vax.h: Supply and properly group all values in end sentinel. - -Tue Jan 17 10:55:30 1995  Ian Lance Taylor  <ian@sanguine.cygnus.com> - -	* mips.h (INSN_ISA, INSN_4650): Define. - -Wed Oct 19 13:34:17 1994  Ian Lance Taylor  <ian@sanguine.cygnus.com> - -	* a29k.h: Add operand type 'I' for `inv' and `iretinv'.  On -	systems with a separate instruction and data cache, such as the -	29040, these instructions take an optional argument. - -Wed Sep 14 17:44:20 1994  Ian Lance Taylor  (ian@sanguine.cygnus.com) - -	* mips.h (INSN_STORE_MEMORY): Correct value to not conflict with -	INSN_TRAP. - -Tue Sep  6 11:39:08 1994  Ian Lance Taylor  (ian@sanguine.cygnus.com) - -	* mips.h (INSN_STORE_MEMORY): Define. - -Thu Jul 28 19:28:07 1994  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* sparc.h: Document new operand type 'x'. - -Tue Jul 26 17:48:05 1994  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* i960.h (I_CX2): New instruction category.  It includes -	instructions available on Cx and Jx processors. -	(I_JX): New instruction category, for JX-only instructions. -	(i960_opcodes): Put eshro and sysctl in I_CX2 category.  Added -	Jx-only instructions, in I_JX category. - -Wed Jul 13 18:43:47 1994  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* ns32k.h (endop): Made pointer const too. - -Sun Jul 10 11:01:09 1994  Ian Dall  (dall@hfrd.dsto.gov.au) - -	* ns32k.h: Drop Q operand type as there is no correct use -	for it. Add I and Z operand types which allow better checking. - -Thu Jul  7 12:34:48 1994  Steve Chamberlain  (sac@jonny.cygnus.com) - -	* h8300.h (xor.l) :fix bit pattern.  -	(L_2): New size of operand. -	(trapa): Use it. - -Fri Jun 10 16:38:11 1994  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* m68k.h: Move "trap" before "tpcc" to change disassembly. - -Fri Jun  3 15:57:36 1994  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* sparc.h: Include v9 definitions. - -Thu Jun  2 12:23:17 1994  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* m68k.h (m68060): Defined. -	(m68040up, mfloat, mmmu): Include it. -	(struct m68k_opcode): Widen `arch' field. -	(m68k_opcodes): Updated for M68060.  Removed comments that were -	instructions commented out by "JF" years ago. - -Thu Apr 28 18:31:14 1994  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* m68k.h (struct m68k_opcode): Shorten `arch' field to 8 bits, and -	add a one-bit `flags' field. -	(F_ALIAS): New macro. - -Wed Apr 27 11:29:52 1994  Steve Chamberlain  (sac@cygnus.com) - -	* h8300.h (dec, inc): Get encoding right. - -Mon Apr  4 13:12:43 1994  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* ppc.h (struct powerpc_operand): Removed signedp field; just use -	a flag instead. -	(PPC_OPERAND_SIGNED): Define. -	(PPC_OPERAND_SIGNOPT): Define. - -Thu Mar 31 19:34:08 1994  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* i386.h (IS_JUMP_ON_ECX_ZERO, "jcxz" pattern): Operand size -	prefix is 0x66, not 0x67.  Patch from H.J. Lu (hlu@nynexst.com). - -Thu Mar  3 15:51:05 1994  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* i386.h: Reverse last change.  It'll be handled in gas instead. - -Thu Feb 24 15:29:05 1994  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* i386.h (sar): Disabled the two-operand Imm1 form, since it was -	slower on the 486 and used the implicit shift count despite the -	explicit operand.  The one-operand form is still available to get -	the shorter form with the implicit shift count. - -Thu Feb 17 12:27:52 1994  Torbjorn Granlund  (tege@mexican.cygnus.com) - -	* hppa.h: Fix typo in fstws arg string. - -Wed Feb  9 21:23:52 1994  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* ppc.h (struct powerpc_opcode): Make operands field unsigned. - -Mon Feb  7 19:14:58 1994  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* ppc.h (PPC_OPCODE_601): Define. - -Fri Feb  4 23:43:50 1994  Jeffrey A. Law  (law@snake.cs.utah.edu) - -	* hppa.h (addb): Use '@' for addb and addib pseudo ops. -	(so we can determine valid completers for both addb and addb[tf].) - -	* hppa.h (xmpyu): No floating point format specifier for the -	xmpyu instruction. - -Fri Feb  4 23:36:52 1994  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* ppc.h (PPC_OPERAND_NEXT): Define. -	(PPC_OPERAND_NEGATIVE): Change value to make room for above. -	(struct powerpc_macro): Define. -	(powerpc_macros, powerpc_num_macros): Declare. - -Fri Jan 21 19:13:50 1994  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* ppc.h: New file.  Header file for PowerPC opcode table. - -Mon Jan 17 00:14:23 1994  Jeffrey A. Law  (law@snake.cs.utah.edu) - -	* hppa.h: More minor template fixes for sfu and copr (to allow -	for easier disassembly). - -	* hppa.h: Fix templates for all the sfu and copr instructions. - -Wed Dec 15 15:12:42 1993  Ken Raeburn  (raeburn@cujo.cygnus.com) - -	* i386.h (push): Permit Imm16 operand too. - -Sat Dec 11 16:14:06 1993  Steve Chamberlain  (sac@thepub.cygnus.com) - -	*  h8300.h (andc): Exists in base arch. - -Wed Dec  1 12:15:32 1993  Jeffrey A. Law  (law@snake.cs.utah.edu) - -	* From Hisashi MINAMINO <minamino@sramhc.sra.co.jp>      -	* hppa.h: #undef NONE to avoid conflict with hiux include files. - -Sun Nov 21 22:06:57 1993  Jeffrey A. Law  (law@snake.cs.utah.edu) - -	* hppa.h: Add FP quadword store instructions. - -Wed Nov 17 17:13:16 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* mips.h: (M_J_A): Added. -	(M_LA): Removed. - -Mon Nov  8 12:12:47 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* mips.h (OP_MASK_CACHE, OP_SH_CACHE): Define.  From Ted Lemon -	<mellon@pepper.ncd.com>. - -Sun Nov  7 00:30:11 1993  Jeffrey A. Law  (law@snake.cs.utah.edu) - -	* hppa.h: Immediate field in probei instructions is unsigned, -	not low-sign extended. - -Wed Nov  3 10:30:00 1993  Jim Kingdon  (kingdon@lioth.cygnus.com) - -	* m88k.h (RRI10MASK): Change from 0xfc00ffe0 to 0xfc00fc00. - -Tue Nov  2 12:41:30 1993  Ken Raeburn  (raeburn@rover.cygnus.com) - -	* i386.h: Add "fxch" without operand. - -Mon Nov  1 18:13:03 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* mips.h (M_JAL_1, M_JAL_2, M_JAL_A): Added. - -Sat Oct  2 22:26:11 1993  Jeffrey A Law  (law@snake.cs.utah.edu) - -	* hppa.h: Add gfw and gfr to the opcode table. - -Wed Sep 29 16:23:00 1993  K. Richard Pixley  (rich@sendai.cygnus.com) - -	* m88k.h: extended to handle m88110. - -Tue Sep 28 19:19:08 1993  Jeffrey A Law  (law@snake.cs.utah.edu) - -	* hppa.h (be, ble): Use operand type 'z' to denote absolute branch -	addresses. - -Tue Sep 14 14:04:35 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* i960.h (i960_opcodes): Properly bracket initializers. - -Mon Sep 13 12:50:52 1993  K. Richard Pixley  (rich@sendai.cygnus.com) - -	* m88k.h (BOFLAG): rewrite to avoid nested comment. - -Mon Sep 13 15:46:06 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* m68k.h (two): Protect second argument with parentheses. - -Fri Sep 10 16:29:47 1993  Ken Raeburn  (raeburn@cambridge.cygnus.com) - -	* i386.h (i386_optab): Added new instruction "rsm" (for i386sl). -	Deleted old in/out instructions in "#if 0" section. - -Thu Sep  9 17:42:19 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* i386.h (i386_optab): Properly bracket initializers. - -Wed Aug 25 13:50:56 1993  Ken Raeburn  (raeburn@cambridge.cygnus.com) - -	* hppa.h (pa_opcode): Use '|' for movb and movib insns.  (From -	Jeff Law, law@cs.utah.edu). - -Mon Aug 23 16:55:03 1993  Ken Raeburn  (raeburn@cambridge.cygnus.com) - -	* i386.h (lcall): Accept Imm32 operand also. - -Mon Aug 23 12:43:11 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* mips.h (M_ABSU): Removed (absolute value of unsigned number??). -	(M_DABS): Added. - -Thu Aug 19 15:08:37 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* mips.h (INSN_*): Changed values.  Removed unused definitions. -	Added INSN_COND_BRANCH_LIKELY, INSN_ISA2 and INSN_ISA3.  Split -	INSN_LOAD_DELAY into INSN_LOAD_MEMORY_DELAY and -	INSN_LOAD_COPROC_DELAY.  Split INSN_COPROC_DELAY into -	INSN_COPROC_MOVE_DELAY and INSN_COPROC_MEMORY_DELAY. -	(M_*): Added new values for r6000 and r4000 macros. -	(ANY_DELAY): Removed. - -Wed Aug 18 15:37:48 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* mips.h: Added M_LI_S and M_LI_SS. - -Tue Aug 17 07:08:08 1993  Steve Chamberlain  (sac@phydeaux.cygnus.com) - -	* h8300.h: Get some rare mov.bs correct. - -Thu Aug  5 09:15:17 1993  Jim Kingdon  (kingdon@lioth.cygnus.com) - -	* sparc.h: Don't define const ourself; rely on ansidecl.h having -	been included. - -Fri Jul 30 18:41:11 1993  John Gilmore  (gnu@cygnus.com) - -	* sparc.h (F_JSR, F_UNBR, F_CONDBR):  Add new flags to mark -	jump instructions, for use in disassemblers. - -Thu Jul 22 07:25:27 1993  Ian Lance Taylor  (ian@cygnus.com) - -	* m88k.h: Make bitfields just unsigned, not unsigned long or -	unsigned short. - -Wed Jul 21 11:55:31 1993  Jim Kingdon  (kingdon@deneb.cygnus.com) - -	* hppa.h: New argument type 'y'.  Use in various float instructions. - -Mon Jul 19 17:17:03 1993  Jim Kingdon  (kingdon@deneb.cygnus.com) - -	* hppa.h (break): First immediate field is unsigned. - -	* hppa.h: Add rfir instruction. - -Sun Jul 18 16:28:08 1993  Jim Kingdon  (kingdon@rtl.cygnus.com) - -	* mips.h: Split the actual table out into ../../opcodes/mips-opc.c. - -Fri Jul 16 09:59:29 1993  Ian Lance Taylor  (ian@cygnus.com) - -	* mips.h: Reworked the hazard information somewhat, and fixed some -	bugs in the instruction hazard descriptions. - -Thu Jul 15 12:42:01 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* m88k.h: Corrected a couple of opcodes. - -Tue Jul  6 15:17:35 1993  Ian Lance Taylor  (ian@cygnus.com) - -	* mips.h: Replaced with version from Ralph Campbell and OSF.  The -	new version includes instruction hazard information, but is -	otherwise reasonably similar. - -Thu Jul  1 20:36:17 1993  Doug Evans  (dje@canuck.cygnus.com) - -	* h8300.h: Fix typo in UNOP3 (affected sh[al][lr].l). - -Fri Jun 11 18:38:44 1993  Ken Raeburn  (raeburn@cygnus.com) - -	Patches from Jeff Law, law@cs.utah.edu: -	* hppa.h: Clean up some of the OLD_TABLE, non-OLD_TABLE braindamage. -	Make the tables be the same for the following instructions: -	"bb", "addb[tf]", "addib[tf]", "add", "add[loc]", "addco",  -	"sh[123]add", "sh[123]add[lo]", "sub", "sub[obt]", "sub[bt]o", -	"ds", "comclr", "addi", "addi[ot]", "addito", "subi", "subio",  -	"comiclr", "fadd", "fsub", "fmpy", "fdiv", "fsqrt", "fabs",  -	"frnd", "fcpy", "fcnvff", "fcnvxf", "fcnvfx", "fcnvfxt",  -	"fcmp", and "ftest". - -	* hppa.h: Make new and old tables the same for "break", "mtctl", -	"mfctl", "bb", "ssm", "rsm", "xmpyu", "fmpyadd", "fmpysub". -	Fix typo in last patch.  Collapse several #ifdefs into a -	single #ifdef. - -	* hppa.h: Delete remaining OLD_TABLE code.  Bring some -	of the comments up-to-date. - -	* hppa.h: Update "free list" of letters and update -	comments describing each letter's function. - -Fri Jun  4 15:41:37 1993  Steve Chamberlain  (sac@phydeaux.cygnus.com) - -	* h8300.h: checkpoint, includes H8/300-H opcodes. - -Thu Jun  3 15:42:59 1993  Stu Grossman  (grossman@cygnus.com) - -	* Patches from Jeffrey Law <law@cs.utah.edu>. -	* hppa.h: Rework single precision FP  -	instructions so that they correctly disassemble code -	PA1.1 code. - -Thu May 27 19:21:22 1993  Bruce Bauman  (boot@osf.org) - -	* i386.h (i386_optab, mov pattern): Remove Mem16 restriction from -	mov to allow instructions like mov ss,xyz(ecx) to assemble. - -Tue May 25 00:39:40 1993  Ken Raeburn  (raeburn@cygnus.com) - -	* hppa.h: Use new version from Utah if OLD_TABLE isn't defined; -	gdb will define it for now. - -Mon May 24 15:20:06 1993  Ken Raeburn  (raeburn@cambridge.cygnus.com) - -	* sparc.h: Don't end enumerator list with comma. - -Fri May 14 15:15:50 1993  Ian Lance Taylor  (ian@cygnus.com) - -	* Based on patches from davidj@ICSI.Berkeley.EDU (David Johnson): -	* mips.h (OP_MASK_COPZ, OP_SH_COPZ): Define. -	("bc2t"): Correct typo. -	("[ls]wc[023]"): Use T rather than t. -	("c[0123]"): Define general coprocessor instructions. - -Mon May 10 06:02:25 1993  Ken Raeburn  (raeburn@kr-pc.cygnus.com) - -	* m68k.h: Move split point for gcc compilation more towards -	middle. - -Fri Apr  9 13:26:16 1993  Jim Kingdon  (kingdon@cygnus.com) - -	* rs6k.h: Clean up instructions for primary opcode 19 (many were -	simply wrong, ics, rfi, & rfsvc were missing). -	Add "a" to opr_ext for "bb".  Doc fix. - -Thu Mar 18 13:45:31 1993  Per Bothner  (bothner@rtl.cygnus.com) - -	* i386.h:  486 extensions from John Hassey (hassey@dg-rtp.dg.com). -	* mips.h:  Add casts, to suppress warnings about shifting too much. -	* m68k.h:  Document the placement code '9'. - -Thu Feb 18 02:03:14 1993  John Gilmore  (gnu@cygnus.com) - -	* m68k.h (BREAK_UP_BIG_DECL, AND_OTHER_PART):  Add kludge which -	allows callers to break up the large initialized struct full of -	opcodes into two half-sized ones.  This permits GCC to compile  -	this module, since it takes exponential space for initializers. -	(numopcodes, endop):  Revise to use AND_OTHER_PART in size calcs. - -Thu Feb  4 02:06:56 1993  John Gilmore  (gnu@cygnus.com) - -	* a29k.h:  Remove RCS crud, update GPL to v2, update copyrights. -	* convex.h:  Added, from GDB's convx-opcode.h.  Added CONST to all -	initialized structs in it. - -Thu Jan 28 21:32:22 1993  John Gilmore  (gnu@cygnus.com) - -	Delta 88 changes inspired by Carl Greco, <cgreco@Creighton.Edu>: -	* m88k.h (PMEM):  Avoid previous definition from <sys/param.h>. -	(AND):  Change to AND_ to avoid ansidecl.h `AND' conflict. - -Sat Jan 23 18:10:49 PST 1993  Ralph Campbell  (ralphc@pyramid.com) - -	* mips.h: document "i" and "j" operands correctly. - -Thu Jan  7 15:58:13 1993  Ian Lance Taylor  (ian@tweedledumb.cygnus.com) - -	* mips.h: Removed endianness dependency. - -Sun Jan  3 14:13:35 1993  Steve Chamberlain  (sac@thepub.cygnus.com) - -	* h8300.h: include info on number of cycles per instruction. - -Mon Dec 21 21:29:08 1992  Stu Grossman  (grossman at cygnus.com) - -	* hppa.h:  Move handy aliases to the front.  Fix masks for extract -	and deposit instructions. - -Sat Dec 12 16:09:48 1992  Ian Lance Taylor  (ian@cygnus.com) - -	* i386.h: accept shld and shrd both with and without the shift -	count argument, which is always %cl. - -Fri Nov 27 17:13:18 1992  Ken Raeburn  (raeburn at cygnus.com) - -	* i386.h (i386_optab_end, i386_regtab_end): Now const. -	(one_byte_segment_defaults, two_byte_segment_defaults, -	i386_prefixtab_end): Ditto. - -Mon Nov 23 10:47:25 1992  Ken Raeburn  (raeburn@cygnus.com) - -	* vax.h (bb*): Use "v" (bitfield type), not "a" (address operand) -	for operand 2; from John Carr, jfc@dsg.dec.com. - -Wed Nov  4 07:36:49 1992  Ken Raeburn  (raeburn@cygnus.com) - -	* m68k.h: Define FIXED_SIZE_BRANCH, so bsr and bra instructions -	always use 16-bit offsets.  Makes calculated-size jump tables -	feasible. - -Fri Oct 16 22:52:43 1992  Ken Raeburn  (raeburn@cygnus.com) - -	* i386.h: Fix one-operand forms of in* and out* patterns. - -Tue Sep 22 14:08:14 1992  Ken Raeburn  (raeburn@cambridge.cygnus.com) - -	* m68k.h: Added CPU32 support. - -Tue Sep 22 00:38:41 1992  John Gilmore  (gnu@cygnus.com) - -	* mips.h (break):  Disassemble the argument.  Patch from -	jonathan@cs.stanford.edu (Jonathan Stone). - -Wed Sep  9 11:25:28 1992  Ian Lance Taylor  (ian@cygnus.com) - -	* m68k.h: merged Motorola and MIT syntax. - -Thu Sep  3 09:33:22 1992  Steve Chamberlain  (sac@thepub.cygnus.com) - -	* m68k.h (pmove): make the tests less strict, the 68k book is -	wrong. - -Tue Aug 25 23:25:19 1992  Ken Raeburn  (raeburn@cambridge.cygnus.com) - -	* m68k.h (m68ec030): Defined as alias for 68030. -	(m68k_opcodes): New type characters "3" for 68030 MMU regs and "t" -	for immediate 0-7 added.  Set up some opcodes (ptest, bkpt) to use -	them.  Tightened description of "fmovex" to distinguish it from -	some "pmove" encodings.  Added "pmove" for 68030 MMU regs, cleaned -	up descriptions that claimed versions were available for chips not -	supporting them.  Added "pmovefd". - -Mon Aug 24 12:04:51 1992  Steve Chamberlain  (sac@thepub.cygnus.com) - -	* m68k.h: fix where the . goes in divull - -Wed Aug 19 11:22:24 1992  Ian Lance Taylor  (ian@cygnus.com) - -	* m68k.h: the cas2 instruction is supposed to be written with -	indirection on the last two operands, which can be either data or -	address registers.  Added a new operand type 'r' which accepts -	either register type.  Added new cases for cas2l and cas2w which -	use them.  Corrected masks for cas2 which failed to recognize use -	of address register. - -Fri Aug 14 14:20:38 1992  Per Bothner  (bothner@cygnus.com) - -	* m68k.h:  Merged in patches (mostly m68040-specific) from -	Colin Smith <colin@wrs.com>. - -	* m68k.h:  Merged m68kmri.h and m68k.h (using the former as a -	base).  Also cleaned up duplicates, re-ordered instructions for -	the sake of dis-assembling (so aliases come after standard names). -	* m68kmri.h: Now just defines some macros, and #includes m68k.h. - -Wed Aug 12 16:38:15 1992  Steve Chamberlain  (sac@thepub.cygnus.com) - -	* m68kmri.h: added various opcodes. Moved jbxx to bxxes. Filled in -	all missing .s - -Mon Aug 10 23:22:33 1992  Ken Raeburn  (raeburn@cygnus.com) - -	* sparc.h: Moved tables to BFD library. - -	* i386.h (i386_optab): Add fildq, fistpq aliases used by gcc. - -Sun Jun 28 13:29:03 1992  Fred Fish  (fnf@cygnus.com) - -	* h8300.h:  Finish filling in all the holes in the opcode table, -	so that the Lucid C compiler can digest this as well... - -Fri Jun 26 21:27:17 1992  John Gilmore  (gnu at cygnus.com) - -	* i386.h:  Add setc, setnc, addr16, data16, repz, repnz aliases. -	Fix opcodes on various sizes of fild/fist instructions -	(16bit=no suffix, 32bit="l" suffix, 64bit="ll" suffix). -	Use tabs to indent for comments.  Fixes suggested by Minh Tran-Le. - -Thu Jun 25 16:13:26 1992  Stu Grossman  (grossman at cygnus.com) - -	* h8300.h:  Fill in all the holes in the opcode table so that the -	losing HPUX C compiler can digest this... - -Thu Jun 11 12:15:25 1992  John Gilmore  (gnu at cygnus.com) - -	* mips.h:  Fix decoding of coprocessor instructions, somewhat. -	(Fix by Eric Anderson, 3jean@maas-neotek.arc.nasa.gov.) - -Thu May 28 11:17:44 1992  Jim Wilson  (wilson@sphagnum.cygnus.com) - -	* sparc.h: Add new architecture variant sparclite; add its scan -	and divscc opcodes.  Define ARCHITECTURES_CONFLICT_P macro. - -Tue May  5 14:23:27 1992  Per Bothner  (bothner@rtl.cygnus.com) - -	* mips.h:  Add some more opcode synonyms (from Frank Yellin, -	fy@lucid.com). - -Thu Apr 16 18:25:26 1992  Per Bothner  (bothner@cygnus.com) - -	* rs6k.h:  New version from IBM (Metin). - -Thu Apr  9 00:31:19 1992  Per Bothner  (bothner@rtl.cygnus.com) - -	* rs6k.h: Fix incorrect extended opcode for instructions `fm' -        and `fd'.  (From metin@ibmpa.awdpa.ibm.com (Metin G. Ozisik).) - -Tue Apr  7 13:38:47 1992  Stu Grossman  (grossman at cygnus.com) - -	* rs6k.h:  Move from ../../gdb/rs6k-opcode.h. - -Fri Apr  3 11:30:20 1992  Fred Fish  (fnf@cygnus.com) - -	* m68k.h (one, two):  Cast macro args to unsigned to suppress -	complaints from compiler and lint about integer overflow during -	shift. - -Sun Mar 29 12:22:08 1992  John Gilmore  (gnu at cygnus.com) - -	* sparc.h (OP):  Avoid signed overflow when shifting to high order bit. - -Fri Mar  6 00:22:38 1992  John Gilmore  (gnu at cygnus.com) - -	* mips.h:  Make bitfield layout depend on the HOST compiler, -	not on the TARGET system. - -Fri Feb 21 01:29:51 1992  K. Richard Pixley  (rich@cygnus.com) - -	* i386.h: added inb, inw, outb, outw opcodes, added att syntax for -	  scmp, slod, smov, ssca, ssto.  Curtesy Minh Tran-Le -	  <TRANLE@INTELLICORP.COM>. - -Thu Jan 30 07:31:44 1992  Steve Chamberlain  (sac at rtl.cygnus.com) - -	* h8300.h: turned op_type enum into #define list - -Thu Jan 30 01:07:24 1992  John Gilmore  (gnu at cygnus.com) - -	* sparc.h:  Remove "cypress" architecture.  Remove "fitox" and -	similar instructions -- they've been renamed to "fitoq", etc. -	REALLY fix tsubcctv.  Fix "fcmpeq" and "fcmpq" which had wrong -	number of arguments. -	* h8300.h:  Remove extra ; which produces compiler warning. - -Tue Jan 28 22:59:22 1992  Stu Grossman  (grossman at cygnus.com) - -	* sparc.h:  fix opcode for tsubcctv. - -Tue Jan  7 17:19:39 1992  K. Richard Pixley  (rich at cygnus.com) - -	* sparc.h: fba and cba are now aliases for fb and cb respectively. - -Fri Dec 27 10:55:50 1991  Per Bothner  (bothner at cygnus.com) - -	* sparc.h (nop):  Made the 'lose' field be even tighter, -	so only a standard 'nop' is disassembled as a nop. - -Sun Dec 22 12:18:18 1991  Michael Tiemann  (tiemann at cygnus.com) - -	* sparc.h (nop): Add RD_GO to `lose' so that only %g0 in dest is -	disassembled as a nop. - -Tue Dec 10 00:22:20 1991  K. Richard Pixley  (rich at rtl.cygnus.com) - -	* sparc.h: fix a typo. - -Sat Nov 30 20:40:51 1991  Steve Chamberlain  (sac at rtl.cygnus.com) - -	* a29k.h, arm.h, h8300.h,  i386.h,  i860.h, i960.h , m68k.h,  -	m88k.h, mips.h , np1.h, ns32k.h, pn.h, pyr.h, sparc.h, tahoe.h, -	vax.h, ChangeLog: renamed from ../<foo>-opcode.h - - -Local Variables: -version-control: never -End: diff --git a/contrib/binutils/include/opcode/alpha.h b/contrib/binutils/include/opcode/alpha.h deleted file mode 100644 index c3babc9f3701..000000000000 --- a/contrib/binutils/include/opcode/alpha.h +++ /dev/null @@ -1,237 +0,0 @@ -/* alpha.h -- Header file for Alpha opcode table -   Copyright 1996 Free Software Foundation, Inc. -   Contributed by Richard Henderson <rth@tamu.edu>, -   patterned after the PPC opcode table written by Ian Lance Taylor. - -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 -1, 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.  */ - -#ifndef OPCODE_ALPHA_H -#define OPCODE_ALPHA_H - -/* The opcode table is an array of struct alpha_opcode.  */ - -struct alpha_opcode -{ -  /* The opcode name.  */ -  const char *name; - -  /* The opcode itself.  Those bits which will be filled in with -     operands are zeroes.  */ -  unsigned opcode; - -  /* The opcode mask.  This is used by the disassembler.  This is a -     mask containing ones indicating those bits which must match the -     opcode field, and zeroes indicating those bits which need not -     match (and are presumably filled in by operands).  */ -  unsigned mask; - -  /* One bit flags for the opcode.  These are primarily used to -     indicate specific processors and environments support the -     instructions.  The defined values are listed below. */ -  unsigned flags; - -  /* An array of operand codes.  Each code is an index into the -     operand table.  They appear in the order which the operands must -     appear in assembly code, and are terminated by a zero.  */ -  unsigned char operands[4]; -}; - -/* The table itself is sorted by major opcode number, and is otherwise -   in the order in which the disassembler should consider -   instructions.  */ -extern const struct alpha_opcode alpha_opcodes[]; -extern const int alpha_num_opcodes; - -/* Values defined for the flags field of a struct alpha_opcode.  */ - -/* CPU Availability */ -#define AXP_OPCODE_BASE  0x0001  /* Base architecture -- all cpus.  */ -#define AXP_OPCODE_EV4   0x0002  /* EV4 specific PALcode insns.  */ -#define AXP_OPCODE_EV5   0x0004  /* EV5 specific PALcode insns.  */ -#define AXP_OPCODE_BWX   0x0100  /* Byte/word extension (amask bit 0).  */ -#define AXP_OPCODE_CIX   0x0200  /* "Count" extension (amask bit 1).  */ -#define AXP_OPCODE_MAX   0x0400  /* Multimedia extension (amask bit 8).  */ - -#define AXP_OPCODE_NOPAL (~(AXP_OPCODE_EV4|AXP_OPCODE_EV5)) - -/* A macro to extract the major opcode from an instruction.  */ -#define AXP_OP(i)	(((i) >> 26) & 0x3F) - -/* The total number of major opcodes. */ -#define AXP_NOPS	0x40 - - -/* The operands table is an array of struct alpha_operand.  */ - -struct alpha_operand -{ -  /* The number of bits in the operand.  */ -  int bits; - -  /* How far the operand is left shifted in the instruction.  */ -  int shift; - -  /* The default relocation type for this operand.  */ -  int default_reloc; - -  /* One bit syntax flags.  */ -  unsigned flags; - -  /* Insertion function.  This is used by the assembler.  To insert an -     operand value into an instruction, check this field. - -     If it is NULL, execute -         i |= (op & ((1 << o->bits) - 1)) << o->shift; -     (i is the instruction which we are filling in, o is a pointer to -     this structure, and op is the opcode value; this assumes twos -     complement arithmetic). - -     If this field is not NULL, then simply call it with the -     instruction and the operand value.  It will return the new value -     of the instruction.  If the ERRMSG argument is not NULL, then if -     the operand value is illegal, *ERRMSG will be set to a warning -     string (the operand will be inserted in any case).  If the -     operand value is legal, *ERRMSG will be unchanged (most operands -     can accept any value).  */ -  unsigned (*insert) PARAMS ((unsigned instruction, int op, -			      const char **errmsg)); - -  /* Extraction function.  This is used by the disassembler.  To -     extract this operand type from an instruction, check this field. - -     If it is NULL, compute -         op = ((i) >> o->shift) & ((1 << o->bits) - 1); -	 if ((o->flags & AXP_OPERAND_SIGNED) != 0 -	     && (op & (1 << (o->bits - 1))) != 0) -	   op -= 1 << o->bits; -     (i is the instruction, o is a pointer to this structure, and op -     is the result; this assumes twos complement arithmetic). - -     If this field is not NULL, then simply call it with the -     instruction value.  It will return the value of the operand.  If -     the INVALID argument is not NULL, *INVALID will be set to -     non-zero if this operand type can not actually be extracted from -     this operand (i.e., the instruction does not match).  If the -     operand is valid, *INVALID will not be changed.  */ -  int (*extract) PARAMS ((unsigned instruction, int *invalid)); -}; - -/* Elements in the table are retrieved by indexing with values from -   the operands field of the alpha_opcodes table.  */ - -extern const struct alpha_operand alpha_operands[]; -extern const int alpha_num_operands; - -/* Values defined for the flags field of a struct alpha_operand.  */ - -/* Mask for selecting the type for typecheck purposes */ -#define AXP_OPERAND_TYPECHECK_MASK					\ -  (AXP_OPERAND_PARENS | AXP_OPERAND_COMMA | AXP_OPERAND_IR |		\ -   AXP_OPERAND_FPR | AXP_OPERAND_RELATIVE | AXP_OPERAND_SIGNED | 	\ -   AXP_OPERAND_UNSIGNED) - -/* This operand does not actually exist in the assembler input.  This -   is used to support extended mnemonics, for which two operands fields -   are identical.  The assembler should call the insert function with -   any op value.  The disassembler should call the extract function, -   ignore the return value, and check the value placed in the invalid -   argument.  */ -#define AXP_OPERAND_FAKE	01 - -/* The operand should be wrapped in parentheses rather than separated -   from the previous by a comma.  This is used for the load and store -   instructions which want their operands to look like "Ra,disp(Rb)".  */ -#define AXP_OPERAND_PARENS	02 - -/* Used in combination with PARENS, this supresses the supression of -   the comma.  This is used for "jmp Ra,(Rb),hint".  */ -#define AXP_OPERAND_COMMA	04 - -/* This operand names an integer register.  */ -#define AXP_OPERAND_IR		010 - -/* This operand names a floating point register.  */ -#define AXP_OPERAND_FPR		020 - -/* This operand is a relative branch displacement.  The disassembler -   prints these symbolically if possible.  */ -#define AXP_OPERAND_RELATIVE	040 - -/* This operand takes signed values.  */ -#define AXP_OPERAND_SIGNED	0100 - -/* This operand takes unsigned values.  This exists primarily so that -   a flags value of 0 can be treated as end-of-arguments.  */ -#define AXP_OPERAND_UNSIGNED	0200 - -/* Supress overflow detection on this field.  This is used for hints. */ -#define AXP_OPERAND_NOOVERFLOW	0400 - -/* Mask for optional argument default value.  */ -#define AXP_OPERAND_OPTIONAL_MASK 07000 - -/* This operand defaults to zero.  This is used for jump hints.  */ -#define AXP_OPERAND_DEFAULT_ZERO 01000 - -/* This operand should default to the first (real) operand and is used -   in conjunction with AXP_OPERAND_OPTIONAL.  This allows -   "and $0,3,$0" to be written as "and $0,3", etc.  I don't like -   it, but it's what DEC does.  */ -#define AXP_OPERAND_DEFAULT_FIRST 02000 - -/* Similarly, this operand should default to the second (real) operand. -   This allows "negl $0" instead of "negl $0,$0".  */ -#define AXP_OPERAND_DEFAULT_SECOND 04000 - - -/* Register common names */ - -#define AXP_REG_V0	0 -#define AXP_REG_T0	1 -#define AXP_REG_T1	2 -#define AXP_REG_T2	3 -#define AXP_REG_T3	4 -#define AXP_REG_T4	5 -#define AXP_REG_T5	6 -#define AXP_REG_T6	7 -#define AXP_REG_T7	8 -#define AXP_REG_S0	9 -#define AXP_REG_S1	10 -#define AXP_REG_S2	11 -#define AXP_REG_S3	12 -#define AXP_REG_S4	13 -#define AXP_REG_S5	14 -#define AXP_REG_FP	15 -#define AXP_REG_A0	16 -#define AXP_REG_A1	17 -#define AXP_REG_A2	18 -#define AXP_REG_A3	19 -#define AXP_REG_A4	20 -#define AXP_REG_A5	21 -#define AXP_REG_T8	22 -#define AXP_REG_T9	23 -#define AXP_REG_T10	24 -#define AXP_REG_T11	25 -#define AXP_REG_RA	26 -#define AXP_REG_PV	27 -#define AXP_REG_T12	27 -#define AXP_REG_AT	28 -#define AXP_REG_GP	29 -#define AXP_REG_SP	30 -#define AXP_REG_ZERO	31 - -#endif /* OPCODE_ALPHA_H */ diff --git a/contrib/binutils/include/opcode/arc.h b/contrib/binutils/include/opcode/arc.h deleted file mode 100644 index a1e0ca152632..000000000000 --- a/contrib/binutils/include/opcode/arc.h +++ /dev/null @@ -1,274 +0,0 @@ -/* Opcode table for the ARC. -   Copyright 1994, 1995, 1997 Free Software Foundation, Inc. -   Contributed by Doug Evans (dje@cygnus.com). - -This file is part of GAS, the GNU Assembler, GDB, the GNU debugger, and -the GNU Binutils. - -GAS/GDB is free software; you can redistribute it and/or modify -it 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. - -GAS/GDB is distributed in the hope that it 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 GAS or GDB; see the file COPYING.	If not, write to -the Free Software Foundation, 59 Temple Place - Suite 330, -Boston, MA 02111-1307, USA.  */ - -/* List of the various cpu types. -   The tables currently use bit masks to say whether the instruction or -   whatever is supported by a particular cpu.  This lets us have one entry -   apply to several cpus. - -   This duplicates bfd_mach_arc_xxx.  For now I wish to isolate this from bfd -   and bfd from this.  Also note that these numbers are bit values as we want -   to allow for things available on more than one ARC (but not necessarily all -   ARCs).  */ - -/* The `base' cpu must be 0 (table entries are omitted for the base cpu). -   The cpu type is treated independently of endianness. -   The complete `mach' number includes endianness. -   These values are internal to opcodes/bfd/binutils/gas.  */ -#define ARC_MACH_BASE 0 -#define ARC_MACH_UNUSED1 1 -#define ARC_MACH_UNUSED2 2 -#define ARC_MACH_UNUSED4 4 -/* Additional cpu values can be inserted here and ARC_MACH_BIG moved down.  */ -#define ARC_MACH_BIG 8 - -/* Mask of number of bits necessary to record cpu type.  */ -#define ARC_MACH_CPU_MASK 7 -/* Mask of number of bits necessary to record cpu type + endianness.  */ -#define ARC_MACH_MASK 15 - -/* Type to denote an ARC instruction (at least a 32 bit unsigned int).  */ -typedef unsigned int arc_insn; - -struct arc_opcode { -  char *syntax;			/* syntax of insn */ -  unsigned long mask, value;	/* recognize insn if (op&mask)==value */ -  int flags;			/* various flag bits */ - -/* Values for `flags'.  */ - -/* Return CPU number, given flag bits.  */ -#define ARC_OPCODE_CPU(bits) ((bits) & ARC_MACH_CPU_MASK) -/* Return MACH number, given flag bits.  */ -#define ARC_OPCODE_MACH(bits) ((bits) & ARC_MACH_MASK) -/* First opcode flag bit available after machine mask.  */ -#define ARC_OPCODE_FLAG_START ((ARC_MACH_MASK + 1) << 0) -/* This insn is a conditional branch.  */ -#define ARC_OPCODE_COND_BRANCH (ARC_OPCODE_FLAG_START) - -  /* These values are used to optimize assembly and disassembly.  Each insn is -     on a list of related insns (same first letter for assembly, same insn code -     for disassembly).  */ -  struct arc_opcode *next_asm;	/* Next instruction to try during assembly.  */ -  struct arc_opcode *next_dis;	/* Next instruction to try during disassembly.  */ - -  /* Macros to create the hash values for the lists.  */ -#define ARC_HASH_OPCODE(string) \ -  ((string)[0] >= 'a' && (string)[0] <= 'z' ? (string)[0] - 'a' : 26) -#define ARC_HASH_ICODE(insn) \ -  ((unsigned int) (insn) >> 27) - -  /* Macros to access `next_asm', `next_dis' so users needn't care about the -     underlying mechanism.  */ -#define ARC_OPCODE_NEXT_ASM(op) ((op)->next_asm) -#define ARC_OPCODE_NEXT_DIS(op) ((op)->next_dis) -}; - -struct arc_operand_value { -  char *name;			/* eg: "eq" */ -  short value;			/* eg: 1 */ -  unsigned char type;		/* index into `arc_operands' */ -  unsigned char flags;		/* various flag bits */ - -/* Values for `flags'.  */ - -/* Return CPU number, given flag bits.  */ -#define ARC_OPVAL_CPU(bits) ((bits) & ARC_MACH_CPU_MASK) -/* Return MACH number, given flag bits.  */ -#define ARC_OPVAL_MACH(bits) ((bits) & ARC_MACH_MASK) -}; - -struct arc_operand { -  /* One of the insn format chars.  */ -  unsigned char fmt; - -  /* The number of bits in the operand (may be unused for a modifier).  */ -  unsigned char bits; - -  /* How far the operand is left shifted in the instruction, or -     the modifier's flag bit (may be unused for a modifier.  */ -  unsigned char shift; - -  /* Various flag bits.  */ -  int flags; - -/* Values for `flags'.  */ - -/* This operand is a suffix to the opcode.  */ -#define ARC_OPERAND_SUFFIX 1 - -/* This operand is a relative branch displacement.  The disassembler -   prints these symbolically if possible.  */ -#define ARC_OPERAND_RELATIVE_BRANCH 2 - -/* This operand is an absolute branch address.  The disassembler -   prints these symbolically if possible.  */ -#define ARC_OPERAND_ABSOLUTE_BRANCH 4 - -/* This operand is an address.  The disassembler -   prints these symbolically if possible.  */ -#define ARC_OPERAND_ADDRESS 8 - -/* This operand is a long immediate value.  */ -#define ARC_OPERAND_LIMM 0x10 - -/* This operand takes signed values.  */ -#define ARC_OPERAND_SIGNED 0x20 - -/* This operand takes signed values, but also accepts a full positive -   range of values.  That is, if bits is 16, it takes any value from -   -0x8000 to 0xffff.  */ -#define ARC_OPERAND_SIGNOPT 0x40 - -/* This operand should be regarded as a negative number for the -   purposes of overflow checking (i.e., the normal most negative -   number is disallowed and one more than the normal most positive -   number is allowed).  This flag will only be set for a signed -   operand.  */ -#define ARC_OPERAND_NEGATIVE 0x80 - -/* This operand doesn't really exist.  The program uses these operands -   in special ways.  */ -#define ARC_OPERAND_FAKE 0x100 - -/* Modifier values.  */ -/* A dot is required before a suffix.  Eg: .le  */ -#define ARC_MOD_DOT 0x1000 - -/* A normal register is allowed (not used, but here for completeness).  */ -#define ARC_MOD_REG 0x2000 - -/* An auxiliary register name is expected.  */ -#define ARC_MOD_AUXREG 0x4000 - -/* Sum of all ARC_MOD_XXX bits.  */ -#define ARC_MOD_BITS 0x7000 - -/* Non-zero if the operand type is really a modifier.  */ -#define ARC_MOD_P(X) ((X) & ARC_MOD_BITS) - -  /* Insertion function.  This is used by the assembler.  To insert an -     operand value into an instruction, check this field. - -     If it is NULL, execute -         i |= (p & ((1 << o->bits) - 1)) << o->shift; -     (I is the instruction which we are filling in, O is a pointer to -     this structure, and OP is the opcode value; this assumes twos -     complement arithmetic). - -     If this field is not NULL, then simply call it with the -     instruction and the operand value.  It will return the new value -     of the instruction.  If the ERRMSG argument is not NULL, then if -     the operand value is illegal, *ERRMSG will be set to a warning -     string (the operand will be inserted in any case).  If the -     operand value is legal, *ERRMSG will be unchanged. - -     REG is non-NULL when inserting a register value.  */ - -  arc_insn (*insert) PARAMS ((arc_insn insn, -			      const struct arc_operand *operand, int mods, -			      const struct arc_operand_value *reg, long value, -			      const char **errmsg)); - -  /* Extraction function.  This is used by the disassembler.  To -     extract this operand type from an instruction, check this field. - -     If it is NULL, compute -         op = ((i) >> o->shift) & ((1 << o->bits) - 1); -	 if ((o->flags & ARC_OPERAND_SIGNED) != 0 -	     && (op & (1 << (o->bits - 1))) != 0) -	   op -= 1 << o->bits; -     (I is the instruction, O is a pointer to this structure, and OP -     is the result; this assumes twos complement arithmetic). - -     If this field is not NULL, then simply call it with the -     instruction value.  It will return the value of the operand.  If -     the INVALID argument is not NULL, *INVALID will be set to -     non-zero if this operand type can not actually be extracted from -     this operand (i.e., the instruction does not match).  If the -     operand is valid, *INVALID will not be changed. - -     INSN is a pointer to an array of two `arc_insn's.  The first element is -     the insn, the second is the limm if present. - -     Operands that have a printable form like registers and suffixes have -     their struct arc_operand_value pointer stored in OPVAL.  */ - -  long (*extract) PARAMS ((arc_insn *insn, -			   const struct arc_operand *operand, -			   int mods, const struct arc_operand_value **opval, -			   int *invalid)); -}; - -/* Bits that say what version of cpu we have. -   These should be passed to arc_init_opcode_tables. -   At present, all there is is the cpu type.  */ - -/* CPU number, given value passed to `arc_init_opcode_tables'.  */ -#define ARC_HAVE_CPU(bits) ((bits) & ARC_MACH_CPU_MASK) -/* MACH number, given value passed to `arc_init_opcode_tables'.  */ -#define ARC_HAVE_MACH(bits) ((bits) & ARC_MACH_MASK) - -/* Special register values:  */ -#define ARC_REG_SHIMM_UPDATE 61 -#define ARC_REG_SHIMM 63 -#define ARC_REG_LIMM 62 - -/* Non-zero if REG is a constant marker.  */ -#define ARC_REG_CONSTANT_P(REG) ((REG) >= 61) - -/* Positions and masks of various fields:  */ -#define ARC_SHIFT_REGA 21 -#define ARC_SHIFT_REGB 15 -#define ARC_SHIFT_REGC 9 -#define ARC_MASK_REG 63 - -/* Delay slot types.  */ -#define ARC_DELAY_NONE 0	/* no delay slot */ -#define ARC_DELAY_NORMAL 1	/* delay slot in both cases */ -#define ARC_DELAY_JUMP 2	/* delay slot only if branch taken */ - -/* Non-zero if X will fit in a signed 9 bit field.  */ -#define ARC_SHIMM_CONST_P(x) ((long) (x) >= -256 && (long) (x) <= 255) - -extern const struct arc_operand arc_operands[]; -extern const int arc_operand_count; -extern /*const*/ struct arc_opcode arc_opcodes[]; -extern const int arc_opcodes_count; -extern const struct arc_operand_value arc_suffixes[]; -extern const int arc_suffixes_count; -extern const struct arc_operand_value arc_reg_names[]; -extern const int arc_reg_names_count; -extern unsigned char arc_operand_map[]; - -/* Utility fns in arc-opc.c.  */ -int arc_get_opcode_mach PARAMS ((int, int)); -/* `arc_opcode_init_tables' must be called before `arc_xxx_supported'.  */ -void arc_opcode_init_tables PARAMS ((int)); -void arc_opcode_init_insert PARAMS ((void)); -void arc_opcode_init_extract PARAMS ((void)); -const struct arc_opcode *arc_opcode_lookup_asm PARAMS ((const char *)); -const struct arc_opcode *arc_opcode_lookup_dis PARAMS ((unsigned int)); -int arc_opcode_limm_p PARAMS ((long *)); -const struct arc_operand_value *arc_opcode_lookup_suffix PARAMS ((const struct arc_operand *type, int value)); -int arc_opcode_supported PARAMS ((const struct arc_opcode *)); -int arc_opval_supported PARAMS ((const struct arc_operand_value *)); diff --git a/contrib/binutils/include/opcode/cgen.h b/contrib/binutils/include/opcode/cgen.h deleted file mode 100644 index ab59f24694a1..000000000000 --- a/contrib/binutils/include/opcode/cgen.h +++ /dev/null @@ -1,873 +0,0 @@ -/* Header file for targets using CGEN: Cpu tools GENerator. - -Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc. - -This file is part of GDB, the GNU debugger, and the GNU Binutils. - -This program is free software; you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation; either version 2 of the License, or -(at your option) any later version. - -This program is distributed in the hope that it 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 program; if not, write to the Free Software Foundation, Inc., -59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */ - -#ifndef CGEN_H -#define CGEN_H - -/* Prepend the cpu name, defined in cpu-opc.h, and _cgen_ to symbol S. -   The lack of spaces in the arg list is important for non-stdc systems. -   This file is included by <cpu>-opc.h. -   It can be included independently of cpu-opc.h, in which case the cpu -   dependent portions will be declared as "unknown_cgen_foo".  */ - -#ifndef CGEN_SYM -#define CGEN_SYM(s) CONCAT3 (unknown,_cgen_,s) -#endif - -/* This file contains the static (unchanging) pieces and as much other stuff -   as we can reasonably put here.  It's generally cleaner to put stuff here -   rather than having it machine generated if possible.  */ - -/* The assembler syntax is made up of expressions (duh...). -   At the lowest level the values are mnemonics, register names, numbers, etc. -   Above that are subexpressions, if any (an example might be the -   "effective address" in m68k cpus).  At the second highest level are the -   insns themselves.  Above that are pseudo-insns, synthetic insns, and macros, -   if any. -*/ - -/* Lots of cpu's have a fixed insn size, or one which rarely changes, -   and it's generally easier to handle these by treating the insn as an -   integer type, rather than an array of characters.  So we allow targets -   to control this.  */ - -#ifdef CGEN_INT_INSN -typedef unsigned int cgen_insn_t; -#else -typedef char * cgen_insn_t; -#endif - -#ifdef __GNUC__ -#define CGEN_INLINE inline -#else -#define CGEN_INLINE -#endif - -/* Perhaps we should just use bfd.h, but it's not clear -   one would want to require that yet.  */ -enum cgen_endian -{ -  CGEN_ENDIAN_UNKNOWN, -  CGEN_ENDIAN_LITTLE, -  CGEN_ENDIAN_BIG -}; - -/* Attributes. -   Attributes are used to describe various random things.  */ - -/* Struct to record attribute information.  */ -typedef struct -{ -  unsigned char num_nonbools; -  unsigned int bool; -  unsigned int nonbool[1]; -} CGEN_ATTR; - -/* Define a structure member for attributes with N non-boolean entries. -   The attributes are sorted so that the non-boolean ones come first. -   num_nonbools: count of nonboolean attributes -   bool: values of boolean attributes -   nonbool: values of non-boolean attributes -   There is a maximum of 32 attributes total.  */ -#define CGEN_ATTR_TYPE(n) \ -const struct { unsigned char num_nonbools; \ -	       unsigned int bool; \ -	       unsigned int nonbool[(n) ? (n) : 1]; } - -/* Given an attribute number, return its mask.  */ -#define CGEN_ATTR_MASK(attr) (1 << (attr)) - -/* Return the value of boolean attribute ATTR in ATTRS.  */ -#define CGEN_BOOL_ATTR(attrs, attr) \ -((CGEN_ATTR_MASK (attr) & (attrs)) != 0) - -/* Return value of attribute ATTR in ATTR_TABLE for OBJ. -   OBJ is a pointer to the entity that has the attributes. -   It's not used at present but is reserved for future purposes.  */ -#define CGEN_ATTR_VALUE(obj, attr_table, attr) \ -((unsigned int) (attr) < (attr_table)->num_nonbools \ - ? ((attr_table)->nonbool[attr]) \ - : (((attr_table)->bool & (1 << (attr))) != 0)) - -/* Attribute name/value tables. -   These are used to assist parsing of descriptions at runtime.  */ - -typedef struct -{ -  const char * name; -  int          value; -} CGEN_ATTR_ENTRY; - -/* For each domain (fld,operand,insn), list of attributes.  */ - -typedef struct -{ -  const char *            name; -  /* NULL for boolean attributes.  */ -  const CGEN_ATTR_ENTRY * vals; -} CGEN_ATTR_TABLE; - -/* Parse result (also extraction result). - -   The result of parsing an insn is stored here. -   To generate the actual insn, this is passed to the insert handler. -   When printing an insn, the result of extraction is stored here. -   To print the insn, this is passed to the print handler. - -   It is machine generated so we don't define it here, -   but we do need a forward decl for the handler fns. - -   There is one member for each possible field in the insn. -   The type depends on the field. -   Also recorded here is the computed length of the insn for architectures -   where it varies. -*/ - -typedef struct cgen_fields CGEN_FIELDS; - -/* Total length of the insn, as recorded in the `fields' struct.  */ -/* ??? The field insert handler has lots of opportunities for optimization -   if it ever gets inlined.  On architectures where insns all have the same -   size, may wish to detect that and make this macro a constant - to allow -   further optimizations.  */ -#define CGEN_FIELDS_BITSIZE(fields) ((fields)->length) - -/* Associated with each insn or expression is a set of "handlers" for -   performing operations like parsing, printing, etc.  */ - -/* Forward decl.  */ -typedef struct cgen_insn CGEN_INSN; - -/* Parse handler. -   The first argument is a pointer to a struct describing the insn being -   parsed. -   The second argument is a pointer to a pointer to the text being parsed. -   The third argument is a pointer to a cgen_fields struct -   in which the results are placed. -   If the expression is successfully parsed, the pointer to the text is -   updated.  If not it is left alone. -   The result is NULL if success or an error message.  */ -typedef const char * (cgen_parse_fn) PARAMS ((const struct cgen_insn *, -					      const char **, -					      CGEN_FIELDS *)); - -/* Print handler. -   The first argument is a pointer to the disassembly info. -   Eg: disassemble_info.  It's defined as `PTR' so this file can be included -   without dis-asm.h. -   The second argument is a pointer to a struct describing the insn being -   printed. -   The third argument is a pointer to a cgen_fields struct. -   The fourth argument is the pc value of the insn. -   The fifth argument is the length of the insn, in bytes.  */ -/* Don't require bfd.h unnecessarily.  */ -#ifdef BFD_VERSION -typedef void (cgen_print_fn) PARAMS ((PTR, const struct cgen_insn *, -				      CGEN_FIELDS *, bfd_vma, int)); -#else -typedef void (cgen_print_fn) (); -#endif - -/* Insert handler. -   The first argument is a pointer to a struct describing the insn being -   parsed. -   The second argument is a pointer to a cgen_fields struct -   from which the values are fetched. -   The third argument is a pointer to a buffer in which to place the insn. -   The result is an error message or NULL if success.  */ -typedef const char * (cgen_insert_fn) PARAMS ((const struct cgen_insn *, -					       CGEN_FIELDS *, cgen_insn_t *)); - -/* Extract handler. -   The first argument is a pointer to a struct describing the insn being -   parsed. -   The second argument is a pointer to a struct controlling extraction -   (only used for variable length insns). -   The third argument is the first CGEN_BASE_INSN_SIZE bytes. -   The fourth argument is a pointer to a cgen_fields struct -   in which the results are placed. -   The result is the length of the insn or zero if not recognized.  */ -typedef int (cgen_extract_fn) PARAMS ((const struct cgen_insn *, -				       void *, cgen_insn_t, -				       CGEN_FIELDS *)); - -/* The `parse' and `insert' fields are indices into these tables. -   The elements are pointer to specialized handler functions. -   Element 0 is special, it means use the default handler.  */ -extern cgen_parse_fn * CGEN_SYM (parse_handlers) []; -#define CGEN_PARSE_FN(x) (CGEN_SYM (parse_handlers)[(x)->base.parse]) -extern cgen_insert_fn * CGEN_SYM (insert_handlers) []; -#define CGEN_INSERT_FN(x) (CGEN_SYM (insert_handlers)[(x)->base.insert]) - -/* Likewise for the `extract' and `print' fields.  */ -extern cgen_extract_fn * CGEN_SYM (extract_handlers) []; -#define CGEN_EXTRACT_FN(x) (CGEN_SYM (extract_handlers)[(x)->base.extract]) -extern cgen_print_fn * CGEN_SYM (print_handlers) []; -#define CGEN_PRINT_FN(x) (CGEN_SYM (print_handlers)[(x)->base.print]) - -/* Base class of parser/printer. -   (Don't read too much into the use of the phrase "base class". -   It's a name I'm using to organize my thoughts.) - -   Instructions and expressions all share this data in common. -   It's a collection of the common elements needed to parse, insert, extract, -   and print each of them.  */ - -struct cgen_base -{ -  /* Indices into the handler tables. -     We could use pointers here instead, but in the case of the insn table, -     90% of them would be identical and that's a lot of redundant data. -     0 means use the default (what the default is is up to the code).  */ -  unsigned char parse, insert, extract, print; -}; - -/* Assembler interface. - -   The interface to the assembler is intended to be clean in the sense that -   libopcodes.a is a standalone entity and could be used with any assembler. -   Not that one would necessarily want to do that but rather that it helps -   keep a clean interface.  The interface will obviously be slanted towards -   GAS, but at least it's a start. - -   Parsing is controlled by the assembler which calls -   CGEN_SYM (assemble_insn).  If it can parse and build the entire insn -   it doesn't call back to the assembler.  If it needs/wants to call back -   to the assembler, (*cgen_parse_operand_fn) is called which can either - -   - return a number to be inserted in the insn -   - return a "register" value to be inserted -     (the register might not be a register per pe) -   - queue the argument and return a marker saying the expression has been -     queued (eg: a fix-up) -   - return an error message indicating the expression wasn't recognizable - -   The result is an error message or NULL for success. -   The parsed value is stored in the bfd_vma *.  */ - -/* Values for indicating what the caller wants.  */ -enum cgen_parse_operand_type -{ -  CGEN_PARSE_OPERAND_INIT, -  CGEN_PARSE_OPERAND_INTEGER, -  CGEN_PARSE_OPERAND_ADDRESS -}; - -/* Values for indicating what was parsed. -   ??? Not too useful at present but in time.  */ -enum cgen_parse_operand_result -{ -  CGEN_PARSE_OPERAND_RESULT_NUMBER, -  CGEN_PARSE_OPERAND_RESULT_REGISTER, -  CGEN_PARSE_OPERAND_RESULT_QUEUED, -  CGEN_PARSE_OPERAND_RESULT_ERROR -}; - -/* Don't require bfd.h unnecessarily.  */ -#ifdef BFD_VERSION -extern const char * (*cgen_parse_operand_fn) -     PARAMS ((enum cgen_parse_operand_type, const char **, int, int, -	      enum cgen_parse_operand_result *, bfd_vma *)); -#endif - -/* Called before trying to match a table entry with the insn.  */ -void cgen_init_parse_operand PARAMS ((void)); - -/* Called from <cpu>-asm.c to initialize operand parsing.  */ - -/* These are GAS specific.  They're not here as part of the interface, -   but rather that we need to put them somewhere.  */ - -/* Call this from md_assemble to initialize the assembler callback.  */ -void cgen_asm_init_parse PARAMS ((void)); - -/* Don't require bfd.h unnecessarily.  */ -#ifdef BFD_VERSION -/* The result is an error message or NULL for success. -   The parsed value is stored in the bfd_vma *.  */ -const char * cgen_parse_operand PARAMS ((enum cgen_parse_operand_type, -					 const char **, int, int, -					 enum cgen_parse_operand_result *, -					 bfd_vma *)); -#endif - -void cgen_save_fixups PARAMS ((void)); -void cgen_restore_fixups PARAMS ((void)); -void cgen_swap_fixups PARAMS ((void)); -      -/* Add a register to the assembler's hash table. -   This makes lets GAS parse registers for us. -   ??? This isn't currently used, but it could be in the future.  */ -void cgen_asm_record_register PARAMS ((char *, int)); - -/* After CGEN_SYM (assemble_insn) is done, this is called to -   output the insn and record any fixups.  The address of the -   assembled instruction is returned in case it is needed by -   the caller.  */ -char * cgen_asm_finish_insn PARAMS ((const struct cgen_insn *, cgen_insn_t *, -				   unsigned int)); - -/* Operand values (keywords, integers, symbols, etc.)  */ - -/* Types of assembler elements.  */ - -enum cgen_asm_type -{ -  CGEN_ASM_KEYWORD, CGEN_ASM_MAX -}; - -/* List of hardware elements.  */ - -typedef struct cgen_hw_entry -{ -  /* The type of this entry, one of `enum hw_type'. -     This is an int and not the enum as the latter may not be declared yet.  */ -  int                          type; -  const struct cgen_hw_entry * next; -  char *                       name; -  enum cgen_asm_type           asm_type; -  PTR                          asm_data; -} CGEN_HW_ENTRY; - -const CGEN_HW_ENTRY * cgen_hw_lookup PARAMS ((const char *)); - -/* This struct is used to describe things like register names, etc.  */ - -typedef struct cgen_keyword_entry -{ -  /* Name (as in register name).  */ -  char * name; - -  /* Value (as in register number). -     The value cannot be -1 as that is used to indicate "not found". -     IDEA: Have "FUNCTION" attribute? [function is called to fetch value].  */ -  int value; - -  /* Attributes. -     This should, but technically needn't, appear last.  It is a variable sized -     array in that one architecture may have 1 nonbool attribute and another -     may have more.  Having this last means the non-architecture specific code -     needn't care.  */ -  /* ??? Moving this last should be done by treating keywords like insn lists -     and moving the `next' fields into a CGEN_KEYWORD_LIST struct.  */ -  /* FIXME: Not used yet.  */ -#ifndef CGEN_KEYWORD_NBOOL_ATTRS -#define CGEN_KEYWORD_NBOOL_ATTRS 1 -#endif -  CGEN_ATTR_TYPE (CGEN_KEYWORD_NBOOL_ATTRS) attrs; - -  /* Next name hash table entry.  */ -  struct cgen_keyword_entry *next_name; -  /* Next value hash table entry.  */ -  struct cgen_keyword_entry *next_value; -} CGEN_KEYWORD_ENTRY; - -/* Top level struct for describing a set of related keywords -   (e.g. register names). - -   This struct supports runtime entry of new values, and hashed lookups.  */ - -typedef struct cgen_keyword -{ -  /* Pointer to initial [compiled in] values.  */ -  CGEN_KEYWORD_ENTRY * init_entries; -   -  /* Number of entries in `init_entries'.  */ -  unsigned int num_init_entries; -   -  /* Hash table used for name lookup.  */ -  CGEN_KEYWORD_ENTRY ** name_hash_table; -   -  /* Hash table used for value lookup.  */ -  CGEN_KEYWORD_ENTRY ** value_hash_table; -   -  /* Number of entries in the hash_tables.  */ -  unsigned int hash_table_size; -   -  /* Pointer to null keyword "" entry if present.  */ -  const CGEN_KEYWORD_ENTRY * null_entry; -} CGEN_KEYWORD; - -/* Structure used for searching.  */ - -typedef struct -{ -  /* Table being searched.  */ -  const CGEN_KEYWORD * table; -   -  /* Specification of what is being searched for.  */ -  const char * spec; -   -  /* Current index in hash table.  */ -  unsigned int current_hash; -   -  /* Current element in current hash chain.  */ -  CGEN_KEYWORD_ENTRY * current_entry; -} CGEN_KEYWORD_SEARCH; - -/* Lookup a keyword from its name.  */ -const CGEN_KEYWORD_ENTRY * cgen_keyword_lookup_name -  PARAMS ((CGEN_KEYWORD *, const char *)); -/* Lookup a keyword from its value.  */ -const CGEN_KEYWORD_ENTRY * cgen_keyword_lookup_value -  PARAMS ((CGEN_KEYWORD *, int)); -/* Add a keyword.  */ -void cgen_keyword_add PARAMS ((CGEN_KEYWORD *, CGEN_KEYWORD_ENTRY *)); -/* Keyword searching. -   This can be used to retrieve every keyword, or a subset.  */ -CGEN_KEYWORD_SEARCH cgen_keyword_search_init -  PARAMS ((CGEN_KEYWORD *, const char *)); -const CGEN_KEYWORD_ENTRY *cgen_keyword_search_next -  PARAMS ((CGEN_KEYWORD_SEARCH *)); - -/* Operand value support routines.  */ -/* FIXME: some of the long's here will need to be bfd_vma or some such.  */ - -const char * cgen_parse_keyword PARAMS ((const char **, -					 CGEN_KEYWORD *, -					 long *)); -const char * cgen_parse_signed_integer PARAMS ((const char **, int, long *)); -const char * cgen_parse_unsigned_integer PARAMS ((const char **, int, -						  unsigned long *)); -const char * cgen_parse_address PARAMS ((const char **, int, int, -					 enum cgen_parse_operand_result *, -					 long *)); -const char * cgen_validate_signed_integer PARAMS ((long, long, long)); -const char * cgen_validate_unsigned_integer PARAMS ((unsigned long, -						     unsigned long, -						     unsigned long)); - -/* Operand modes.  */ - -/* ??? This duplicates the values in arch.h.  Revisit. -   These however need the CGEN_ prefix [as does everything in this file].  */ -/* ??? Targets may need to add their own modes so we may wish to move this -   to <arch>-opc.h, or add a hook.  */ - -enum cgen_mode { -  CGEN_MODE_VOID, /* FIXME: rename simulator's VM to VOID */ -  CGEN_MODE_BI, CGEN_MODE_QI, CGEN_MODE_HI, CGEN_MODE_SI, CGEN_MODE_DI, -  CGEN_MODE_UBI, CGEN_MODE_UQI, CGEN_MODE_UHI, CGEN_MODE_USI, CGEN_MODE_UDI, -  CGEN_MODE_SF, CGEN_MODE_DF, CGEN_MODE_XF, CGEN_MODE_TF, -  CGEN_MODE_MAX -}; - -/* FIXME: Until simulator is updated.  */ -#define CGEN_MODE_VM CGEN_MODE_VOID - -/* This struct defines each entry in the operand table.  */ - -typedef struct cgen_operand -{ -  /* Name as it appears in the syntax string.  */ -  char * name; - -  /* The hardware element associated with this operand.  */ -  const CGEN_HW_ENTRY *hw; - -  /* FIXME: We don't yet record ifield definitions, which we should. -     When we do it might make sense to delete start/length (since they will -     be duplicated in the ifield's definition) and replace them with a -     pointer to the ifield entry.  Note that as more complicated situations -     need to be handled, going more and more with an OOP paradigm will help -     keep the complication under control.  Of course, this was the goal from -     the start, but getting there in one step was too much too soon.  */ - -  /* Bit position (msb of first byte = bit 0). -     This is just a hint, and may be unused in more complex operands. -     May be unused for a modifier.  */ -  unsigned char start; - -  /* The number of bits in the operand. -     This is just a hint, and may be unused in more complex operands. -     May be unused for a modifier.  */ -  unsigned char length; - -#if 0 /* ??? Interesting idea but relocs tend to get too complicated, -	 and ABI dependent, for simple table lookups to work.  */ -  /* Ideally this would be the internal (external?) reloc type.  */ -  int reloc_type; -#endif - -  /* Attributes. -     This should, but technically needn't, appear last.  It is a variable sized -     array in that one architecture may have 1 nonbool attribute and another -     may have more.  Having this last means the non-architecture specific code -     needn't care, now or tomorrow.  */ -#ifndef CGEN_OPERAND_NBOOL_ATTRS -#define CGEN_OPERAND_NBOOL_ATTRS 1 -#endif -  CGEN_ATTR_TYPE (CGEN_OPERAND_NBOOL_ATTRS) attrs; -#define CGEN_OPERAND_ATTRS(operand) (&(operand)->attrs) -} CGEN_OPERAND; - -/* Return value of attribute ATTR in OPERAND.  */ -#define CGEN_OPERAND_ATTR(operand, attr) \ -CGEN_ATTR_VALUE (operand, CGEN_OPERAND_ATTRS (operand), attr) - -/* The operand table is currently a very static entity.  */ -extern const CGEN_OPERAND CGEN_SYM (operand_table)[]; - -enum cgen_operand_type; - -#define CGEN_OPERAND_INDEX(operand) ((int) ((operand) - CGEN_SYM (operand_table))) -/* FIXME: Rename, cpu-opc.h defines this as the typedef of the enum.  */ -#define CGEN_OPERAND_TYPE(operand) ((enum cgen_operand_type) CGEN_OPERAND_INDEX (operand)) -#define CGEN_OPERAND_ENTRY(n) (& CGEN_SYM (operand_table) [n]) - -/* Types of parse/insert/extract/print cover-fn handlers.  */ -/* FIXME: move opindex first to match caller.  */ -/* FIXME: also need types of insert/extract/print fns.  */ -/* FIXME: not currently used as type of 3rd arg varies.  */ -typedef const char * (CGEN_PARSE_OPERAND_FN) PARAMS ((const char **, int, -						      long *)); - -/* Instruction operand instances. - -   For each instruction, a list of the hardware elements that are read and -   written are recorded.  */ - -/* The type of the instance.  */ -enum cgen_operand_instance_type { -  /* End of table marker.  */ -  CGEN_OPERAND_INSTANCE_END = 0, -  CGEN_OPERAND_INSTANCE_INPUT, CGEN_OPERAND_INSTANCE_OUTPUT -}; - -typedef struct -{ -  /* The type of this operand.  */ -  enum cgen_operand_instance_type type; -#define CGEN_OPERAND_INSTANCE_TYPE(opinst) ((opinst)->type) - -  /* The hardware element referenced.  */ -  const CGEN_HW_ENTRY *hw; -#define CGEN_OPERAND_INSTANCE_HW(opinst) ((opinst)->hw) - -  /* The mode in which the operand is being used.  */ -  enum cgen_mode mode; -#define CGEN_OPERAND_INSTANCE_MODE(opinst) ((opinst)->mode) - -  /* The operand table entry or NULL if there is none (i.e. an explicit -     hardware reference).  */ -  const CGEN_OPERAND *operand; -#define CGEN_OPERAND_INSTANCE_OPERAND(opinst) ((opinst)->operand) - -  /* If `operand' is NULL, the index (e.g. into array of registers).  */ -  int index; -#define CGEN_OPERAND_INSTANCE_INDEX(opinst) ((opinst)->index) -} CGEN_OPERAND_INSTANCE; - -/* Syntax string. - -   Each insn format and subexpression has one of these. - -   The syntax "string" consists of characters (n > 0 && n < 128), and operand -   values (n >= 128), and is terminated by 0.  Operand values are 128 + index -   into the operand table.  The operand table doesn't exist in C, per se, as -   the data is recorded in the parse/insert/extract/print switch statements. */ - -#ifndef CGEN_MAX_SYNTAX_BYTES -#define CGEN_MAX_SYNTAX_BYTES 16 -#endif - -typedef struct -{ -  unsigned char syntax[CGEN_MAX_SYNTAX_BYTES]; -} CGEN_SYNTAX; - -#define CGEN_SYNTAX_STRING(syn) (syn->syntax) -#define CGEN_SYNTAX_CHAR_P(c) ((c) < 128) -#define CGEN_SYNTAX_CHAR(c) (c) -#define CGEN_SYNTAX_FIELD(c) ((c) - 128) -#define CGEN_SYNTAX_MAKE_FIELD(c) ((c) + 128) - -/* ??? I can't currently think of any case where the mnemonic doesn't come -   first [and if one ever doesn't building the hash tables will be tricky]. -   However, we treat mnemonics as just another operand of the instruction. -   A value of 1 means "this is where the mnemonic appears".  1 isn't -   special other than it's a non-printable ASCII char.  */ -#define CGEN_SYNTAX_MNEMONIC       1 -#define CGEN_SYNTAX_MNEMONIC_P(ch) ((ch) == CGEN_SYNTAX_MNEMONIC) - -/* Instruction formats. - -   Instructions are grouped by format.  Associated with an instruction is its -   format.  Each opcode table entry contains a format table entry. -   ??? There is usually very few formats compared with the number of insns, -   so one can reduce the size of the opcode table by recording the format table -   as a separate entity.  Given that we currently don't, format table entries -   are also distinguished by their operands.  This increases the size of the -   table, but reduces the number of tables.  It's all minutiae anyway so it -   doesn't really matter [at this point in time]. - -   ??? Support for variable length ISA's is wip.  */ - -typedef struct -{ -  /* Length that MASK and VALUE have been calculated to -     [VALUE is recorded elsewhere]. -     Normally it is CGEN_BASE_INSN_BITSIZE.  On [V]LIW architectures where -     the base insn size may be larger than the size of an insn, this field is -     less than CGEN_BASE_INSN_BITSIZE.  */ -  unsigned char mask_length; - -  /* Total length of instruction, in bits.  */ -  unsigned char length; - -  /* Mask to apply to the first MASK_LENGTH bits. -     Each insn's value is stored with the insn. -     The first step in recognizing an insn for disassembly is -     (opcode & mask) == value.  */ -  unsigned int mask; -} CGEN_FORMAT; - -/* This struct defines each entry in the instruction table.  */ - -struct cgen_insn -{ -  /* ??? Further table size reductions can be had by moving this element -     either to the format table or to a separate table of its own.  Not -     sure this is desirable yet.  */ -  struct cgen_base base; -   -/* Given a pointer to a cgen_insn struct, return a pointer to `base'.  */ -#define CGEN_INSN_BASE(insn) (&(insn)->base) - -  /* Name of entry (that distinguishes it from all other entries). -     This is used, for example, in simulator profiling results.  */ -  /* ??? If mnemonics have operands, try to print full mnemonic.  */ -  const char * name; -#define CGEN_INSN_NAME(insn) ((insn)->name) - -  /* Mnemonic.  This is used when parsing and printing the insn. -     In the case of insns that have operands on the mnemonics, this is -     only the constant part.  E.g. for conditional execution of an `add' insn, -     where the full mnemonic is addeq, addne, etc., this is only "add".  */ -  const char * mnemonic; -#define CGEN_INSN_MNEMONIC(insn) ((insn)->mnemonic) - -  /* Syntax string.  */ -  const CGEN_SYNTAX syntax; -#define CGEN_INSN_SYNTAX(insn) (& (insn)->syntax) - -  /* Format entry.  */ -  const CGEN_FORMAT format; -#define CGEN_INSN_MASK_BITSIZE(insn) ((insn)->format.mask_length) -#define CGEN_INSN_BITSIZE(insn) ((insn)->format.length) - -  /* Instruction opcode value.  */ -  unsigned int value; -#define CGEN_INSN_VALUE(insn) ((insn)->value) -#define CGEN_INSN_MASK(insn) ((insn)->format.mask) - -  /* Pointer to NULL entry terminated table of operands used, -     or NULL if none.  */ -  const CGEN_OPERAND_INSTANCE *operands; -#define CGEN_INSN_OPERANDS(insn) ((insn)->operands) - -  /* Attributes. -     This must appear last.  It is a variable sized array in that one -     architecture may have 1 nonbool attribute and another may have more. -     Having this last means the non-architecture specific code needn't -     care.  */ -#ifndef CGEN_INSN_NBOOL_ATTRS -#define CGEN_INSN_NBOOL_ATTRS 1 -#endif -  CGEN_ATTR_TYPE (CGEN_INSN_NBOOL_ATTRS) attrs; -#define CGEN_INSN_ATTRS(insn) (&(insn)->attrs) -/* Return value of attribute ATTR in INSN.  */ -#define CGEN_INSN_ATTR(insn, attr) \ -CGEN_ATTR_VALUE (insn, CGEN_INSN_ATTRS (insn), attr) -}; - -/* Instruction lists. -   This is used for adding new entries and for creating the hash lists.  */ - -typedef struct cgen_insn_list -{ -  struct cgen_insn_list * next; -  const CGEN_INSN * insn; -} CGEN_INSN_LIST; - -/* The table of instructions.  */ - -typedef struct -{ -  /* Pointer to initial [compiled in] entries.  */ -  const CGEN_INSN * init_entries; -   -  /* Size of an entry (since the attribute member is variable sized).  */ -  unsigned int entry_size; -   -  /* Number of entries in `init_entries', including trailing NULL entry.  */ -  unsigned int num_init_entries; -   -  /* Values added at runtime.  */ -  CGEN_INSN_LIST * new_entries; -   -  /* Assembler hash function.  */ -  unsigned int (* asm_hash) PARAMS ((const char *)); -   -  /* Number of entries in assembler hash table.  */ -  unsigned int asm_hash_table_size; -   -  /* Disassembler hash function.  */ -  unsigned int (* dis_hash) PARAMS ((const char *, unsigned long)); -   -  /* Number of entries in disassembler hash table.  */ -  unsigned int dis_hash_table_size; -} CGEN_INSN_TABLE; - -/* ??? This is currently used by the simulator. -   We want this to be fast and the simulator currently doesn't handle -   runtime added instructions so this is ok.  An alternative would be to -   store the index in the table.  */ -extern const CGEN_INSN CGEN_SYM (insn_table_entries)[]; -#define CGEN_INSN_INDEX(insn) ((int) ((insn) - CGEN_SYM (insn_table_entries))) -#define CGEN_INSN_ENTRY(n) (& CGEN_SYM (insn_table_entries) [n]) - -/* Return number of instructions.  This includes any added at runtime.  */ - -int cgen_insn_count PARAMS ((void)); - -/* The assembler insn table is hashed based on some function of the mnemonic -   (the actually hashing done is up to the target, but we provide a few -   examples like the first letter or a function of the entire mnemonic). -   The index of each entry is the index of the corresponding table entry. -   The value of each entry is the index of the next entry, with a 0 -   terminating (thus the first entry is reserved).  */ - -#ifndef CGEN_ASM_HASH -#ifdef CGEN_MNEMONIC_OPERANDS -#define CGEN_ASM_HASH_SIZE 127 -#define CGEN_ASM_HASH(string) (*(unsigned char *) (string) % CGEN_ASM_HASH_SIZE) -#else -#define CGEN_ASM_HASH_SIZE 128 -#define CGEN_ASM_HASH(string) (*(unsigned char *) (string) % CGEN_ASM_HASH_SIZE) /*FIXME*/ -#endif -#endif - -unsigned int CGEN_SYM (asm_hash_insn) PARAMS ((const char *)); -CGEN_INSN_LIST * cgen_asm_lookup_insn PARAMS ((const char *)); -#define CGEN_ASM_LOOKUP_INSN(insn) cgen_asm_lookup_insn (insn) -#define CGEN_ASM_NEXT_INSN(insn) ((insn)->next) - -/* The disassembler insn table is hashed based on some function of machine -   instruction (the actually hashing done is up to the target).  */ - -/* It doesn't make much sense to provide a default here, -   but while this is under development we do. -   BUFFER is a pointer to the bytes of the insn. -   INSN is the first CGEN_BASE_INSN_SIZE bytes as an int in host order.  */ -#ifndef CGEN_DIS_HASH -#define CGEN_DIS_HASH_SIZE 256 -#define CGEN_DIS_HASH(buffer, insn) (*(unsigned char *) (buffer)) -#endif - -unsigned int CGEN_SYM (dis_hash_insn) PARAMS ((const char *, unsigned long)); -CGEN_INSN_LIST * cgen_dis_lookup_insn PARAMS ((const char *, unsigned long)); -#define CGEN_DIS_LOOKUP_INSN(buf, insn) cgen_dis_lookup_insn (buf, insn) -#define CGEN_DIS_NEXT_INSN(insn) ((insn)->next) - -/* Top level structures and functions.  */ - -typedef struct -{ -  const CGEN_HW_ENTRY *  hw_list; -  /*CGEN_OPERAND_TABLE * operand_table; - FIXME:wip */ -  CGEN_INSN_TABLE *      insn_table; -} CGEN_OPCODE_DATA; - -/* Each CPU has one of these.  */ -extern CGEN_OPCODE_DATA CGEN_SYM (opcode_data); - -/* Global state access macros. -   Some of these are tucked away and accessed with cover fns. -   Simpler things like the current machine and endian are not.  */ - -extern int cgen_current_machine; -#define CGEN_CURRENT_MACHINE cgen_current_machine - -extern enum cgen_endian cgen_current_endian; -#define CGEN_CURRENT_ENDIAN cgen_current_endian - -/* Prototypes of major functions.  */ - -/* Set the current cpu (+ mach number, endian, etc.).  */ -void cgen_set_cpu PARAMS ((CGEN_OPCODE_DATA *, int, enum cgen_endian)); - -/* Initialize the assembler, disassembler.  */ -void cgen_asm_init PARAMS ((void)); -void cgen_dis_init PARAMS ((void)); - -/* `init_tables' must be called before `xxx_supported'.  */ -void CGEN_SYM (init_tables) PARAMS ((int)); -void CGEN_SYM (init_asm) PARAMS ((int, enum cgen_endian)); -void CGEN_SYM (init_dis) PARAMS ((int, enum cgen_endian)); -void CGEN_SYM (init_parse) PARAMS ((void)); -void CGEN_SYM (init_print) PARAMS ((void)); -void CGEN_SYM (init_insert) PARAMS ((void)); -void CGEN_SYM (init_extract) PARAMS ((void)); - -/* FIXME: This prototype is wrong ifndef CGEN_INT_INSN. -   Furthermore, ifdef CGEN_INT_INSN, the insn is created in -   target byte order (in which case why use int's at all). -   Perhaps replace cgen_insn_t * with char *?  */ -const struct cgen_insn * -CGEN_SYM (assemble_insn) PARAMS ((const char *, CGEN_FIELDS *, -				  cgen_insn_t *, char **)); -#if 0 /* old */ -int CGEN_SYM (insn_supported) PARAMS ((const struct cgen_insn *)); -int CGEN_SYM (opval_supported) PARAMS ((const struct cgen_opval *)); -#endif - -extern const CGEN_KEYWORD  CGEN_SYM (operand_mach); -int CGEN_SYM (get_mach) PARAMS ((const char *)); - -const CGEN_INSN * -CGEN_SYM (get_insn_operands) PARAMS ((const CGEN_INSN *, cgen_insn_t, -				      int, int *)); -const CGEN_INSN * -CGEN_SYM (lookup_insn) PARAMS ((const CGEN_INSN *, cgen_insn_t, -				int, CGEN_FIELDS *, int)); - -CGEN_INLINE void -CGEN_SYM (put_operand) PARAMS ((int, const long *, -				CGEN_FIELDS *)); -CGEN_INLINE long -CGEN_SYM (get_operand) PARAMS ((int, const CGEN_FIELDS *)); - -const char * -CGEN_SYM (parse_operand) PARAMS ((int, const char **, CGEN_FIELDS *)); - -const char * -CGEN_SYM (insert_operand) PARAMS ((int, CGEN_FIELDS *, char *)); - -/* Default insn parser, printer.  */ -extern cgen_parse_fn CGEN_SYM (parse_insn); -extern cgen_insert_fn CGEN_SYM (insert_insn); -extern cgen_extract_fn CGEN_SYM (extract_insn); -extern cgen_print_fn CGEN_SYM (print_insn); - -/* Read in a cpu description file.  */ -const char * cgen_read_cpu_file PARAMS ((const char *)); - -#endif /* CGEN_H */ diff --git a/contrib/binutils/include/opcode/convex.h b/contrib/binutils/include/opcode/convex.h deleted file mode 100644 index efaeebb65a5f..000000000000 --- a/contrib/binutils/include/opcode/convex.h +++ /dev/null @@ -1,1711 +0,0 @@ -/* Information for instruction disassembly on the Convex. -   Copyright 1989, 1993 Free Software Foundation.   - -This file is part of GDB. - -This program is free software; you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation; either version 2 of the License, or -(at your option) any later version. - -This program is distributed in the hope that it 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 program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */ - -#ifndef	CONST -#define	CONST -#endif	/* CONST */ - -#define xxx 0 -#define rrr 1 -#define rr 2 -#define rxr 3 -#define r 4 -#define nops 5 -#define nr 6 -#define pcrel 7 -#define lr 8 -#define rxl 9 -#define rlr 10 -#define rrl 11 -#define iml 12 -#define imr 13 -#define a1r 14 -#define a1l 15 -#define a2r 16 -#define a2l 17 -#define a3 18 -#define a4 19 -#define a5 20 -#define V 1 -#define S 2 -#define VM 3 -#define A 4 -#define VL 5 -#define VS 6 -#define VLS 7 -#define PSW 8 -/* Prevent an error during "make depend".  */ -#if !defined (PC) -#define PC 9 -#endif -#define ITR 10 -#define VV 11 -#define ITSR 12 -#define TOC 13 -#define CIR 14 -#define TTR 15 -#define VMU 16 -#define VML 17 -#define ICR 18 -#define TCPU 19 -#define CPUID 20 -#define TID 21 - -CONST char *op[] = { -  "", -  "v0\0v1\0v2\0v3\0v4\0v5\0v6\0v7", -  "s0\0s1\0s2\0s3\0s4\0s5\0s6\0s7", -  "vm", -  "sp\0a1\0a2\0a3\0a4\0a5\0ap\0fp", -  "vl", -  "vs", -  "vls", -  "psw", -  "pc", -  "itr", -  "vv", -  "itsr", -  "toc", -  "cir", -  "ttr", -  "vmu", -  "vml", -  "icr", -  "tcpu", -  "cpuid", -  "tid", -}; - -CONST struct formstr format0[] = { -  {0,0,rrr,V,S,S},	/* mov */ -  {0,0,rrr,S,S,V},	/* mov */ -  {1,1,rrr,V,V,V},	/* merg.t */ -  {2,1,rrr,V,V,V},	/* mask.t */ -  {1,2,rrr,V,S,V},	/* merg.f */ -  {2,2,rrr,V,S,V},	/* mask.f */ -  {1,1,rrr,V,S,V},	/* merg.t */ -  {2,1,rrr,V,S,V},	/* mask.t */ -  {3,3,rrr,V,V,V},	/* mul.s */ -  {3,4,rrr,V,V,V},	/* mul.d */ -  {4,3,rrr,V,V,V},	/* div.s */ -  {4,4,rrr,V,V,V},	/* div.d */ -  {3,3,rrr,V,S,V},	/* mul.s */ -  {3,4,rrr,V,S,V},	/* mul.d */ -  {4,3,rrr,V,S,V},	/* div.s */ -  {4,4,rrr,V,S,V},	/* div.d */ -  {5,0,rrr,V,V,V},	/* and */ -  {6,0,rrr,V,V,V},	/* or */ -  {7,0,rrr,V,V,V},	/* xor */ -  {8,0,rrr,V,V,V},	/* shf */ -  {5,0,rrr,V,S,V},	/* and */ -  {6,0,rrr,V,S,V},	/* or */ -  {7,0,rrr,V,S,V},	/* xor */ -  {8,0,rrr,V,S,V},	/* shf */ -  {9,3,rrr,V,V,V},	/* add.s */ -  {9,4,rrr,V,V,V},	/* add.d */ -  {10,3,rrr,V,V,V},	/* sub.s */ -  {10,4,rrr,V,V,V},	/* sub.d */ -  {9,3,rrr,V,S,V},	/* add.s */ -  {9,4,rrr,V,S,V},	/* add.d */ -  {10,3,rrr,V,S,V},	/* sub.s */ -  {10,4,rrr,V,S,V},	/* sub.d */ -  {9,5,rrr,V,V,V},	/* add.b */ -  {9,6,rrr,V,V,V},	/* add.h */ -  {9,7,rrr,V,V,V},	/* add.w */ -  {9,8,rrr,V,V,V},	/* add.l */ -  {9,5,rrr,V,S,V},	/* add.b */ -  {9,6,rrr,V,S,V},	/* add.h */ -  {9,7,rrr,V,S,V},	/* add.w */ -  {9,8,rrr,V,S,V},	/* add.l */ -  {10,5,rrr,V,V,V},	/* sub.b */ -  {10,6,rrr,V,V,V},	/* sub.h */ -  {10,7,rrr,V,V,V},	/* sub.w */ -  {10,8,rrr,V,V,V},	/* sub.l */ -  {10,5,rrr,V,S,V},	/* sub.b */ -  {10,6,rrr,V,S,V},	/* sub.h */ -  {10,7,rrr,V,S,V},	/* sub.w */ -  {10,8,rrr,V,S,V},	/* sub.l */ -  {3,5,rrr,V,V,V},	/* mul.b */ -  {3,6,rrr,V,V,V},	/* mul.h */ -  {3,7,rrr,V,V,V},	/* mul.w */ -  {3,8,rrr,V,V,V},	/* mul.l */ -  {3,5,rrr,V,S,V},	/* mul.b */ -  {3,6,rrr,V,S,V},	/* mul.h */ -  {3,7,rrr,V,S,V},	/* mul.w */ -  {3,8,rrr,V,S,V},	/* mul.l */ -  {4,5,rrr,V,V,V},	/* div.b */ -  {4,6,rrr,V,V,V},	/* div.h */ -  {4,7,rrr,V,V,V},	/* div.w */ -  {4,8,rrr,V,V,V},	/* div.l */ -  {4,5,rrr,V,S,V},	/* div.b */ -  {4,6,rrr,V,S,V},	/* div.h */ -  {4,7,rrr,V,S,V},	/* div.w */ -  {4,8,rrr,V,S,V},	/* div.l */ -}; - -CONST struct formstr format1[] = { -  {11,0,xxx,0,0,0},	/* exit */ -  {12,0,a3,0,0,0},	/* jmp */ -  {13,2,a3,0,0,0},	/* jmpi.f */ -  {13,1,a3,0,0,0},	/* jmpi.t */ -  {14,2,a3,0,0,0},	/* jmpa.f */ -  {14,1,a3,0,0,0},	/* jmpa.t */ -  {15,2,a3,0,0,0},	/* jmps.f */ -  {15,1,a3,0,0,0},	/* jmps.t */ -  {16,0,a3,0,0,0},	/* tac */ -  {17,0,a1r,A,0,0},	/* ldea */ -  {18,8,a1l,VLS,0,0},	/* ld.l */ -  {18,9,a1l,VM,0,0},	/* ld.x */ -  {19,0,a3,0,0,0},	/* tas */ -  {20,0,a3,0,0,0},	/* pshea */ -  {21,8,a2l,VLS,0,0},	/* st.l */ -  {21,9,a2l,VM,0,0},	/* st.x */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {22,0,a3,0,0,0},	/* call */ -  {23,0,a3,0,0,0},	/* calls */ -  {24,0,a3,0,0,0},	/* callq */ -  {25,0,a1r,A,0,0},	/* pfork */ -  {26,5,a2r,S,0,0},	/* ste.b */ -  {26,6,a2r,S,0,0},	/* ste.h */ -  {26,7,a2r,S,0,0},	/* ste.w */ -  {26,8,a2r,S,0,0},	/* ste.l */ -  {18,5,a1r,A,0,0},	/* ld.b */ -  {18,6,a1r,A,0,0},	/* ld.h */ -  {18,7,a1r,A,0,0},	/* ld.w */ -  {27,7,a1r,A,0,0},	/* incr.w */ -  {21,5,a2r,A,0,0},	/* st.b */ -  {21,6,a2r,A,0,0},	/* st.h */ -  {21,7,a2r,A,0,0},	/* st.w */ -  {27,8,a1r,S,0,0},	/* incr.l */ -  {18,5,a1r,S,0,0},	/* ld.b */ -  {18,6,a1r,S,0,0},	/* ld.h */ -  {18,7,a1r,S,0,0},	/* ld.w */ -  {18,8,a1r,S,0,0},	/* ld.l */ -  {21,5,a2r,S,0,0},	/* st.b */ -  {21,6,a2r,S,0,0},	/* st.h */ -  {21,7,a2r,S,0,0},	/* st.w */ -  {21,8,a2r,S,0,0},	/* st.l */ -  {18,5,a1r,V,0,0},	/* ld.b */ -  {18,6,a1r,V,0,0},	/* ld.h */ -  {18,7,a1r,V,0,0},	/* ld.w */ -  {18,8,a1r,V,0,0},	/* ld.l */ -  {21,5,a2r,V,0,0},	/* st.b */ -  {21,6,a2r,V,0,0},	/* st.h */ -  {21,7,a2r,V,0,0},	/* st.w */ -  {21,8,a2r,V,0,0},	/* st.l */ -}; - -CONST struct formstr format2[] = { -  {28,5,rr,A,A,0},	/* cvtw.b */ -  {28,6,rr,A,A,0},	/* cvtw.h */ -  {29,7,rr,A,A,0},	/* cvtb.w */ -  {30,7,rr,A,A,0},	/* cvth.w */ -  {28,5,rr,S,S,0},	/* cvtw.b */ -  {28,6,rr,S,S,0},	/* cvtw.h */ -  {29,7,rr,S,S,0},	/* cvtb.w */ -  {30,7,rr,S,S,0},	/* cvth.w */ -  {28,3,rr,S,S,0},	/* cvtw.s */ -  {31,7,rr,S,S,0},	/* cvts.w */ -  {32,3,rr,S,S,0},	/* cvtd.s */ -  {31,4,rr,S,S,0},	/* cvts.d */ -  {31,8,rr,S,S,0},	/* cvts.l */ -  {32,8,rr,S,S,0},	/* cvtd.l */ -  {33,3,rr,S,S,0},	/* cvtl.s */ -  {33,4,rr,S,S,0},	/* cvtl.d */ -  {34,0,rr,A,A,0},	/* ldpa */ -  {8,0,nr,A,0,0},	/* shf */ -  {18,6,nr,A,0,0},	/* ld.h */ -  {18,7,nr,A,0,0},	/* ld.w */ -  {33,7,rr,S,S,0},	/* cvtl.w */ -  {28,8,rr,S,S,0},	/* cvtw.l */ -  {35,1,rr,S,S,0},	/* plc.t */ -  {36,0,rr,S,S,0},	/* tzc */ -  {37,6,rr,A,A,0},	/* eq.h */ -  {37,7,rr,A,A,0},	/* eq.w */ -  {37,6,nr,A,0,0},	/* eq.h */ -  {37,7,nr,A,0,0},	/* eq.w */ -  {37,5,rr,S,S,0},	/* eq.b */ -  {37,6,rr,S,S,0},	/* eq.h */ -  {37,7,rr,S,S,0},	/* eq.w */ -  {37,8,rr,S,S,0},	/* eq.l */ -  {38,6,rr,A,A,0},	/* leu.h */ -  {38,7,rr,A,A,0},	/* leu.w */ -  {38,6,nr,A,0,0},	/* leu.h */ -  {38,7,nr,A,0,0},	/* leu.w */ -  {38,5,rr,S,S,0},	/* leu.b */ -  {38,6,rr,S,S,0},	/* leu.h */ -  {38,7,rr,S,S,0},	/* leu.w */ -  {38,8,rr,S,S,0},	/* leu.l */ -  {39,6,rr,A,A,0},	/* ltu.h */ -  {39,7,rr,A,A,0},	/* ltu.w */ -  {39,6,nr,A,0,0},	/* ltu.h */ -  {39,7,nr,A,0,0},	/* ltu.w */ -  {39,5,rr,S,S,0},	/* ltu.b */ -  {39,6,rr,S,S,0},	/* ltu.h */ -  {39,7,rr,S,S,0},	/* ltu.w */ -  {39,8,rr,S,S,0},	/* ltu.l */ -  {40,6,rr,A,A,0},	/* le.h */ -  {40,7,rr,A,A,0},	/* le.w */ -  {40,6,nr,A,0,0},	/* le.h */ -  {40,7,nr,A,0,0},	/* le.w */ -  {40,5,rr,S,S,0},	/* le.b */ -  {40,6,rr,S,S,0},	/* le.h */ -  {40,7,rr,S,S,0},	/* le.w */ -  {40,8,rr,S,S,0},	/* le.l */ -  {41,6,rr,A,A,0},	/* lt.h */ -  {41,7,rr,A,A,0},	/* lt.w */ -  {41,6,nr,A,0,0},	/* lt.h */ -  {41,7,nr,A,0,0},	/* lt.w */ -  {41,5,rr,S,S,0},	/* lt.b */ -  {41,6,rr,S,S,0},	/* lt.h */ -  {41,7,rr,S,S,0},	/* lt.w */ -  {41,8,rr,S,S,0},	/* lt.l */ -  {9,7,rr,S,A,0},	/* add.w */ -  {8,0,rr,A,A,0},	/* shf */ -  {0,0,rr,A,A,0},	/* mov */ -  {0,0,rr,S,A,0},	/* mov */ -  {0,7,rr,S,S,0},	/* mov.w */ -  {8,0,rr,S,S,0},	/* shf */ -  {0,0,rr,S,S,0},	/* mov */ -  {0,0,rr,A,S,0},	/* mov */ -  {5,0,rr,A,A,0},	/* and */ -  {6,0,rr,A,A,0},	/* or */ -  {7,0,rr,A,A,0},	/* xor */ -  {42,0,rr,A,A,0},	/* not */ -  {5,0,rr,S,S,0},	/* and */ -  {6,0,rr,S,S,0},	/* or */ -  {7,0,rr,S,S,0},	/* xor */ -  {42,0,rr,S,S,0},	/* not */ -  {40,3,rr,S,S,0},	/* le.s */ -  {40,4,rr,S,S,0},	/* le.d */ -  {41,3,rr,S,S,0},	/* lt.s */ -  {41,4,rr,S,S,0},	/* lt.d */ -  {9,3,rr,S,S,0},	/* add.s */ -  {9,4,rr,S,S,0},	/* add.d */ -  {10,3,rr,S,S,0},	/* sub.s */ -  {10,4,rr,S,S,0},	/* sub.d */ -  {37,3,rr,S,S,0},	/* eq.s */ -  {37,4,rr,S,S,0},	/* eq.d */ -  {43,6,rr,A,A,0},	/* neg.h */ -  {43,7,rr,A,A,0},	/* neg.w */ -  {3,3,rr,S,S,0},	/* mul.s */ -  {3,4,rr,S,S,0},	/* mul.d */ -  {4,3,rr,S,S,0},	/* div.s */ -  {4,4,rr,S,S,0},	/* div.d */ -  {9,6,rr,A,A,0},	/* add.h */ -  {9,7,rr,A,A,0},	/* add.w */ -  {9,6,nr,A,0,0},	/* add.h */ -  {9,7,nr,A,0,0},	/* add.w */ -  {9,5,rr,S,S,0},	/* add.b */ -  {9,6,rr,S,S,0},	/* add.h */ -  {9,7,rr,S,S,0},	/* add.w */ -  {9,8,rr,S,S,0},	/* add.l */ -  {10,6,rr,A,A,0},	/* sub.h */ -  {10,7,rr,A,A,0},	/* sub.w */ -  {10,6,nr,A,0,0},	/* sub.h */ -  {10,7,nr,A,0,0},	/* sub.w */ -  {10,5,rr,S,S,0},	/* sub.b */ -  {10,6,rr,S,S,0},	/* sub.h */ -  {10,7,rr,S,S,0},	/* sub.w */ -  {10,8,rr,S,S,0},	/* sub.l */ -  {3,6,rr,A,A,0},	/* mul.h */ -  {3,7,rr,A,A,0},	/* mul.w */ -  {3,6,nr,A,0,0},	/* mul.h */ -  {3,7,nr,A,0,0},	/* mul.w */ -  {3,5,rr,S,S,0},	/* mul.b */ -  {3,6,rr,S,S,0},	/* mul.h */ -  {3,7,rr,S,S,0},	/* mul.w */ -  {3,8,rr,S,S,0},	/* mul.l */ -  {4,6,rr,A,A,0},	/* div.h */ -  {4,7,rr,A,A,0},	/* div.w */ -  {4,6,nr,A,0,0},	/* div.h */ -  {4,7,nr,A,0,0},	/* div.w */ -  {4,5,rr,S,S,0},	/* div.b */ -  {4,6,rr,S,S,0},	/* div.h */ -  {4,7,rr,S,S,0},	/* div.w */ -  {4,8,rr,S,S,0},	/* div.l */ -}; - -CONST struct formstr format3[] = { -  {32,3,rr,V,V,0},	/* cvtd.s */ -  {31,4,rr,V,V,0},	/* cvts.d */ -  {33,4,rr,V,V,0},	/* cvtl.d */ -  {32,8,rr,V,V,0},	/* cvtd.l */ -  {0,0,rrl,S,S,VM},	/* mov */ -  {0,0,rlr,S,VM,S},	/* mov */ -  {0,0,0,0,0,0}, -  {44,0,rr,S,S,0},	/* lop */ -  {36,0,rr,V,V,0},	/* tzc */ -  {44,0,rr,V,V,0},	/* lop */ -  {0,0,0,0,0,0}, -  {42,0,rr,V,V,0},	/* not */ -  {8,0,rr,S,V,0},	/* shf */ -  {35,1,rr,V,V,0},	/* plc.t */ -  {45,2,rr,V,V,0},	/* cprs.f */ -  {45,1,rr,V,V,0},	/* cprs.t */ -  {37,3,rr,V,V,0},	/* eq.s */ -  {37,4,rr,V,V,0},	/* eq.d */ -  {43,3,rr,V,V,0},	/* neg.s */ -  {43,4,rr,V,V,0},	/* neg.d */ -  {37,3,rr,S,V,0},	/* eq.s */ -  {37,4,rr,S,V,0},	/* eq.d */ -  {43,3,rr,S,S,0},	/* neg.s */ -  {43,4,rr,S,S,0},	/* neg.d */ -  {40,3,rr,V,V,0},	/* le.s */ -  {40,4,rr,V,V,0},	/* le.d */ -  {41,3,rr,V,V,0},	/* lt.s */ -  {41,4,rr,V,V,0},	/* lt.d */ -  {40,3,rr,S,V,0},	/* le.s */ -  {40,4,rr,S,V,0},	/* le.d */ -  {41,3,rr,S,V,0},	/* lt.s */ -  {41,4,rr,S,V,0},	/* lt.d */ -  {37,5,rr,V,V,0},	/* eq.b */ -  {37,6,rr,V,V,0},	/* eq.h */ -  {37,7,rr,V,V,0},	/* eq.w */ -  {37,8,rr,V,V,0},	/* eq.l */ -  {37,5,rr,S,V,0},	/* eq.b */ -  {37,6,rr,S,V,0},	/* eq.h */ -  {37,7,rr,S,V,0},	/* eq.w */ -  {37,8,rr,S,V,0},	/* eq.l */ -  {40,5,rr,V,V,0},	/* le.b */ -  {40,6,rr,V,V,0},	/* le.h */ -  {40,7,rr,V,V,0},	/* le.w */ -  {40,8,rr,V,V,0},	/* le.l */ -  {40,5,rr,S,V,0},	/* le.b */ -  {40,6,rr,S,V,0},	/* le.h */ -  {40,7,rr,S,V,0},	/* le.w */ -  {40,8,rr,S,V,0},	/* le.l */ -  {41,5,rr,V,V,0},	/* lt.b */ -  {41,6,rr,V,V,0},	/* lt.h */ -  {41,7,rr,V,V,0},	/* lt.w */ -  {41,8,rr,V,V,0},	/* lt.l */ -  {41,5,rr,S,V,0},	/* lt.b */ -  {41,6,rr,S,V,0},	/* lt.h */ -  {41,7,rr,S,V,0},	/* lt.w */ -  {41,8,rr,S,V,0},	/* lt.l */ -  {43,5,rr,V,V,0},	/* neg.b */ -  {43,6,rr,V,V,0},	/* neg.h */ -  {43,7,rr,V,V,0},	/* neg.w */ -  {43,8,rr,V,V,0},	/* neg.l */ -  {43,5,rr,S,S,0},	/* neg.b */ -  {43,6,rr,S,S,0},	/* neg.h */ -  {43,7,rr,S,S,0},	/* neg.w */ -  {43,8,rr,S,S,0},	/* neg.l */ -}; - -CONST struct formstr format4[] = { -  {46,0,nops,0,0,0},	/* nop */ -  {47,0,pcrel,0,0,0},	/* br */ -  {48,2,pcrel,0,0,0},	/* bri.f */ -  {48,1,pcrel,0,0,0},	/* bri.t */ -  {49,2,pcrel,0,0,0},	/* bra.f */ -  {49,1,pcrel,0,0,0},	/* bra.t */ -  {50,2,pcrel,0,0,0},	/* brs.f */ -  {50,1,pcrel,0,0,0},	/* brs.t */ -}; - -CONST struct formstr format5[] = { -  {51,5,rr,V,V,0},	/* ldvi.b */ -  {51,6,rr,V,V,0},	/* ldvi.h */ -  {51,7,rr,V,V,0},	/* ldvi.w */ -  {51,8,rr,V,V,0},	/* ldvi.l */ -  {28,3,rr,V,V,0},	/* cvtw.s */ -  {31,7,rr,V,V,0},	/* cvts.w */ -  {28,8,rr,V,V,0},	/* cvtw.l */ -  {33,7,rr,V,V,0},	/* cvtl.w */ -  {52,5,rxr,V,V,0},	/* stvi.b */ -  {52,6,rxr,V,V,0},	/* stvi.h */ -  {52,7,rxr,V,V,0},	/* stvi.w */ -  {52,8,rxr,V,V,0},	/* stvi.l */ -  {52,5,rxr,S,V,0},	/* stvi.b */ -  {52,6,rxr,S,V,0},	/* stvi.h */ -  {52,7,rxr,S,V,0},	/* stvi.w */ -  {52,8,rxr,S,V,0},	/* stvi.l */ -}; - -CONST struct formstr format6[] = { -  {53,0,r,A,0,0},	/* ldsdr */ -  {54,0,r,A,0,0},	/* ldkdr */ -  {55,3,r,S,0,0},	/* ln.s */ -  {55,4,r,S,0,0},	/* ln.d */ -  {56,0,nops,0,0,0},	/* patu */ -  {57,0,r,A,0,0},	/* pate */ -  {58,0,nops,0,0,0},	/* pich */ -  {59,0,nops,0,0,0},	/* plch */ -  {0,0,lr,PSW,A,0},	/* mov */ -  {0,0,rxl,A,PSW,0},	/* mov */ -  {0,0,lr,PC,A,0},	/* mov */ -  {60,0,r,S,0,0},	/* idle */ -  {0,0,lr,ITR,S,0},	/* mov */ -  {0,0,rxl,S,ITR,0},	/* mov */ -  {0,0,0,0,0,0}, -  {0,0,rxl,S,ITSR,0},	/* mov */ -  {61,0,nops,0,0,0},	/* rtnq */ -  {62,0,nops,0,0,0},	/* cfork */ -  {63,0,nops,0,0,0},	/* rtn */ -  {64,0,nops,0,0,0},	/* wfork */ -  {65,0,nops,0,0,0},	/* join */ -  {66,0,nops,0,0,0},	/* rtnc */ -  {67,3,r,S,0,0},	/* exp.s */ -  {67,4,r,S,0,0},	/* exp.d */ -  {68,3,r,S,0,0},	/* sin.s */ -  {68,4,r,S,0,0},	/* sin.d */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {69,3,r,S,0,0},	/* cos.s */ -  {69,4,r,S,0,0},	/* cos.d */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {70,7,r,A,0,0},	/* psh.w */ -  {0,0,0,0,0,0}, -  {71,7,r,A,0,0},	/* pop.w */ -  {0,0,0,0,0,0}, -  {70,7,r,S,0,0},	/* psh.w */ -  {70,8,r,S,0,0},	/* psh.l */ -  {71,7,r,S,0,0},	/* pop.w */ -  {71,8,r,S,0,0},	/* pop.l */ -  {72,0,nops,0,0,0},	/* eni */ -  {73,0,nops,0,0,0},	/* dsi */ -  {74,0,nops,0,0,0},	/* bkpt */ -  {75,0,nops,0,0,0},	/* msync */ -  {76,0,r,S,0,0},	/* mski */ -  {77,0,r,S,0,0},	/* xmti */ -  {0,0,rxl,S,VV,0},	/* mov */ -  {78,0,nops,0,0,0},	/* tstvv */ -  {0,0,lr,VS,A,0},	/* mov */ -  {0,0,rxl,A,VS,0},	/* mov */ -  {0,0,lr,VL,A,0},	/* mov */ -  {0,0,rxl,A,VL,0},	/* mov */ -  {0,7,lr,VS,S,0},	/* mov.w */ -  {0,7,rxl,S,VS,0},	/* mov.w */ -  {0,7,lr,VL,S,0},	/* mov.w */ -  {0,7,rxl,S,VL,0},	/* mov.w */ -  {79,0,r,A,0,0},	/* diag */ -  {80,0,nops,0,0,0},	/* pbkpt */ -  {81,3,r,S,0,0},	/* sqrt.s */ -  {81,4,r,S,0,0},	/* sqrt.d */ -  {82,0,nops,0,0,0},	/* casr */ -  {0,0,0,0,0,0}, -  {83,3,r,S,0,0},	/* atan.s */ -  {83,4,r,S,0,0},	/* atan.d */ -}; - -CONST struct formstr format7[] = { -  {84,5,r,V,0,0},	/* sum.b */ -  {84,6,r,V,0,0},	/* sum.h */ -  {84,7,r,V,0,0},	/* sum.w */ -  {84,8,r,V,0,0},	/* sum.l */ -  {85,0,r,V,0,0},	/* all */ -  {86,0,r,V,0,0},	/* any */ -  {87,0,r,V,0,0},	/* parity */ -  {0,0,0,0,0,0}, -  {88,5,r,V,0,0},	/* max.b */ -  {88,6,r,V,0,0},	/* max.h */ -  {88,7,r,V,0,0},	/* max.w */ -  {88,8,r,V,0,0},	/* max.l */ -  {89,5,r,V,0,0},	/* min.b */ -  {89,6,r,V,0,0},	/* min.h */ -  {89,7,r,V,0,0},	/* min.w */ -  {89,8,r,V,0,0},	/* min.l */ -  {84,3,r,V,0,0},	/* sum.s */ -  {84,4,r,V,0,0},	/* sum.d */ -  {90,3,r,V,0,0},	/* prod.s */ -  {90,4,r,V,0,0},	/* prod.d */ -  {88,3,r,V,0,0},	/* max.s */ -  {88,4,r,V,0,0},	/* max.d */ -  {89,3,r,V,0,0},	/* min.s */ -  {89,4,r,V,0,0},	/* min.d */ -  {90,5,r,V,0,0},	/* prod.b */ -  {90,6,r,V,0,0},	/* prod.h */ -  {90,7,r,V,0,0},	/* prod.w */ -  {90,8,r,V,0,0},	/* prod.l */ -  {35,2,lr,VM,S,0},	/* plc.f */ -  {35,1,lr,VM,S,0},	/* plc.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr formatx[] = { -  {0,0,0,0,0,0}, -}; - -CONST struct formstr format1a[] = { -  {91,0,imr,A,0,0},	/* halt */ -  {92,0,a4,0,0,0},	/* sysc */ -  {18,6,imr,A,0,0},	/* ld.h */ -  {18,7,imr,A,0,0},	/* ld.w */ -  {5,0,imr,A,0,0},	/* and */ -  {6,0,imr,A,0,0},	/* or */ -  {7,0,imr,A,0,0},	/* xor */ -  {8,0,imr,A,0,0},	/* shf */ -  {9,6,imr,A,0,0},	/* add.h */ -  {9,7,imr,A,0,0},	/* add.w */ -  {10,6,imr,A,0,0},	/* sub.h */ -  {10,7,imr,A,0,0},	/* sub.w */ -  {3,6,imr,A,0,0},	/* mul.h */ -  {3,7,imr,A,0,0},	/* mul.w */ -  {4,6,imr,A,0,0},	/* div.h */ -  {4,7,imr,A,0,0},	/* div.w */ -  {18,7,iml,VL,0,0},	/* ld.w */ -  {18,7,iml,VS,0,0},	/* ld.w */ -  {0,0,0,0,0,0}, -  {8,7,imr,S,0,0},	/* shf.w */ -  {93,0,a5,0,0,0},	/* trap */ -  {0,0,0,0,0,0}, -  {37,6,imr,A,0,0},	/* eq.h */ -  {37,7,imr,A,0,0},	/* eq.w */ -  {38,6,imr,A,0,0},	/* leu.h */ -  {38,7,imr,A,0,0},	/* leu.w */ -  {39,6,imr,A,0,0},	/* ltu.h */ -  {39,7,imr,A,0,0},	/* ltu.w */ -  {40,6,imr,A,0,0},	/* le.h */ -  {40,7,imr,A,0,0},	/* le.w */ -  {41,6,imr,A,0,0},	/* lt.h */ -  {41,7,imr,A,0,0},	/* lt.w */ -}; - -CONST struct formstr format1b[] = { -  {18,4,imr,S,0,0},	/* ld.d */ -  {18,10,imr,S,0,0},	/* ld.u */ -  {18,8,imr,S,0,0},	/* ld.l */ -  {18,7,imr,S,0,0},	/* ld.w */ -  {5,0,imr,S,0,0},	/* and */ -  {6,0,imr,S,0,0},	/* or */ -  {7,0,imr,S,0,0},	/* xor */ -  {8,0,imr,S,0,0},	/* shf */ -  {9,6,imr,S,0,0},	/* add.h */ -  {9,7,imr,S,0,0},	/* add.w */ -  {10,6,imr,S,0,0},	/* sub.h */ -  {10,7,imr,S,0,0},	/* sub.w */ -  {3,6,imr,S,0,0},	/* mul.h */ -  {3,7,imr,S,0,0},	/* mul.w */ -  {4,6,imr,S,0,0},	/* div.h */ -  {4,7,imr,S,0,0},	/* div.w */ -  {9,3,imr,S,0,0},	/* add.s */ -  {10,3,imr,S,0,0},	/* sub.s */ -  {3,3,imr,S,0,0},	/* mul.s */ -  {4,3,imr,S,0,0},	/* div.s */ -  {40,3,imr,S,0,0},	/* le.s */ -  {41,3,imr,S,0,0},	/* lt.s */ -  {37,6,imr,S,0,0},	/* eq.h */ -  {37,7,imr,S,0,0},	/* eq.w */ -  {38,6,imr,S,0,0},	/* leu.h */ -  {38,7,imr,S,0,0},	/* leu.w */ -  {39,6,imr,S,0,0},	/* ltu.h */ -  {39,7,imr,S,0,0},	/* ltu.w */ -  {40,6,imr,S,0,0},	/* le.h */ -  {40,7,imr,S,0,0},	/* le.w */ -  {41,6,imr,S,0,0},	/* lt.h */ -  {41,7,imr,S,0,0},	/* lt.w */ -}; - -CONST struct formstr e0_format0[] = { -  {10,3,rrr,S,V,V},	/* sub.s */ -  {10,4,rrr,S,V,V},	/* sub.d */ -  {4,3,rrr,S,V,V},	/* div.s */ -  {4,4,rrr,S,V,V},	/* div.d */ -  {10,11,rrr,S,V,V},	/* sub.s.f */ -  {10,12,rrr,S,V,V},	/* sub.d.f */ -  {4,11,rrr,S,V,V},	/* div.s.f */ -  {4,12,rrr,S,V,V},	/* div.d.f */ -  {3,11,rrr,V,V,V},	/* mul.s.f */ -  {3,12,rrr,V,V,V},	/* mul.d.f */ -  {4,11,rrr,V,V,V},	/* div.s.f */ -  {4,12,rrr,V,V,V},	/* div.d.f */ -  {3,11,rrr,V,S,V},	/* mul.s.f */ -  {3,12,rrr,V,S,V},	/* mul.d.f */ -  {4,11,rrr,V,S,V},	/* div.s.f */ -  {4,12,rrr,V,S,V},	/* div.d.f */ -  {5,2,rrr,V,V,V},	/* and.f */ -  {6,2,rrr,V,V,V},	/* or.f */ -  {7,2,rrr,V,V,V},	/* xor.f */ -  {8,2,rrr,V,V,V},	/* shf.f */ -  {5,2,rrr,V,S,V},	/* and.f */ -  {6,2,rrr,V,S,V},	/* or.f */ -  {7,2,rrr,V,S,V},	/* xor.f */ -  {8,2,rrr,V,S,V},	/* shf.f */ -  {9,11,rrr,V,V,V},	/* add.s.f */ -  {9,12,rrr,V,V,V},	/* add.d.f */ -  {10,11,rrr,V,V,V},	/* sub.s.f */ -  {10,12,rrr,V,V,V},	/* sub.d.f */ -  {9,11,rrr,V,S,V},	/* add.s.f */ -  {9,12,rrr,V,S,V},	/* add.d.f */ -  {10,11,rrr,V,S,V},	/* sub.s.f */ -  {10,12,rrr,V,S,V},	/* sub.d.f */ -  {9,13,rrr,V,V,V},	/* add.b.f */ -  {9,14,rrr,V,V,V},	/* add.h.f */ -  {9,15,rrr,V,V,V},	/* add.w.f */ -  {9,16,rrr,V,V,V},	/* add.l.f */ -  {9,13,rrr,V,S,V},	/* add.b.f */ -  {9,14,rrr,V,S,V},	/* add.h.f */ -  {9,15,rrr,V,S,V},	/* add.w.f */ -  {9,16,rrr,V,S,V},	/* add.l.f */ -  {10,13,rrr,V,V,V},	/* sub.b.f */ -  {10,14,rrr,V,V,V},	/* sub.h.f */ -  {10,15,rrr,V,V,V},	/* sub.w.f */ -  {10,16,rrr,V,V,V},	/* sub.l.f */ -  {10,13,rrr,V,S,V},	/* sub.b.f */ -  {10,14,rrr,V,S,V},	/* sub.h.f */ -  {10,15,rrr,V,S,V},	/* sub.w.f */ -  {10,16,rrr,V,S,V},	/* sub.l.f */ -  {3,13,rrr,V,V,V},	/* mul.b.f */ -  {3,14,rrr,V,V,V},	/* mul.h.f */ -  {3,15,rrr,V,V,V},	/* mul.w.f */ -  {3,16,rrr,V,V,V},	/* mul.l.f */ -  {3,13,rrr,V,S,V},	/* mul.b.f */ -  {3,14,rrr,V,S,V},	/* mul.h.f */ -  {3,15,rrr,V,S,V},	/* mul.w.f */ -  {3,16,rrr,V,S,V},	/* mul.l.f */ -  {4,13,rrr,V,V,V},	/* div.b.f */ -  {4,14,rrr,V,V,V},	/* div.h.f */ -  {4,15,rrr,V,V,V},	/* div.w.f */ -  {4,16,rrr,V,V,V},	/* div.l.f */ -  {4,13,rrr,V,S,V},	/* div.b.f */ -  {4,14,rrr,V,S,V},	/* div.h.f */ -  {4,15,rrr,V,S,V},	/* div.w.f */ -  {4,16,rrr,V,S,V},	/* div.l.f */ -}; - -CONST struct formstr e0_format1[] = { -  {0,0,0,0,0,0}, -  {94,0,a3,0,0,0},	/* tst */ -  {95,0,a3,0,0,0},	/* lck */ -  {96,0,a3,0,0,0},	/* ulk */ -  {17,0,a1r,S,0,0},	/* ldea */ -  {97,0,a1r,A,0,0},	/* spawn */ -  {98,0,a1r,A,0,0},	/* ldcmr */ -  {99,0,a2r,A,0,0},	/* stcmr */ -  {100,0,a1r,A,0,0},	/* popr */ -  {101,0,a2r,A,0,0},	/* pshr */ -  {102,7,a1r,A,0,0},	/* rcvr.w */ -  {103,7,a2r,A,0,0},	/* matm.w */ -  {104,7,a2r,A,0,0},	/* sndr.w */ -  {104,8,a2r,S,0,0},	/* sndr.l */ -  {102,8,a1r,S,0,0},	/* rcvr.l */ -  {103,8,a2r,S,0,0},	/* matm.l */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {105,7,a2r,A,0,0},	/* putr.w */ -  {105,8,a2r,S,0,0},	/* putr.l */ -  {106,7,a1r,A,0,0},	/* getr.w */ -  {106,8,a1r,S,0,0},	/* getr.l */ -  {26,13,a2r,S,0,0},	/* ste.b.f */ -  {26,14,a2r,S,0,0},	/* ste.h.f */ -  {26,15,a2r,S,0,0},	/* ste.w.f */ -  {26,16,a2r,S,0,0},	/* ste.l.f */ -  {107,7,a2r,A,0,0},	/* matr.w */ -  {108,7,a2r,A,0,0},	/* mat.w */ -  {109,7,a1r,A,0,0},	/* get.w */ -  {110,7,a1r,A,0,0},	/* rcv.w */ -  {0,0,0,0,0,0}, -  {111,7,a1r,A,0,0},	/* inc.w */ -  {112,7,a2r,A,0,0},	/* put.w */ -  {113,7,a2r,A,0,0},	/* snd.w */ -  {107,8,a2r,S,0,0},	/* matr.l */ -  {108,8,a2r,S,0,0},	/* mat.l */ -  {109,8,a1r,S,0,0},	/* get.l */ -  {110,8,a1r,S,0,0},	/* rcv.l */ -  {0,0,0,0,0,0}, -  {111,8,a1r,S,0,0},	/* inc.l */ -  {112,8,a2r,S,0,0},	/* put.l */ -  {113,8,a2r,S,0,0},	/* snd.l */ -  {18,13,a1r,V,0,0},	/* ld.b.f */ -  {18,14,a1r,V,0,0},	/* ld.h.f */ -  {18,15,a1r,V,0,0},	/* ld.w.f */ -  {18,16,a1r,V,0,0},	/* ld.l.f */ -  {21,13,a2r,V,0,0},	/* st.b.f */ -  {21,14,a2r,V,0,0},	/* st.h.f */ -  {21,15,a2r,V,0,0},	/* st.w.f */ -  {21,16,a2r,V,0,0},	/* st.l.f */ -}; - -CONST struct formstr e0_format2[] = { -  {28,5,rr,V,V,0},	/* cvtw.b */ -  {28,6,rr,V,V,0},	/* cvtw.h */ -  {29,7,rr,V,V,0},	/* cvtb.w */ -  {30,7,rr,V,V,0},	/* cvth.w */ -  {28,13,rr,V,V,0},	/* cvtw.b.f */ -  {28,14,rr,V,V,0},	/* cvtw.h.f */ -  {29,15,rr,V,V,0},	/* cvtb.w.f */ -  {30,15,rr,V,V,0},	/* cvth.w.f */ -  {31,8,rr,V,V,0},	/* cvts.l */ -  {32,7,rr,V,V,0},	/* cvtd.w */ -  {33,3,rr,V,V,0},	/* cvtl.s */ -  {28,4,rr,V,V,0},	/* cvtw.d */ -  {31,16,rr,V,V,0},	/* cvts.l.f */ -  {32,15,rr,V,V,0},	/* cvtd.w.f */ -  {33,11,rr,V,V,0},	/* cvtl.s.f */ -  {28,12,rr,V,V,0},	/* cvtw.d.f */ -  {114,0,rr,S,S,0},	/* enal */ -  {8,7,rr,S,S,0},	/* shf.w */ -  {115,0,rr,S,S,0},	/* enag */ -  {0,0,0,0,0,0}, -  {28,4,rr,S,S,0},	/* cvtw.d */ -  {32,7,rr,S,S,0},	/* cvtd.w */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {116,3,rr,S,S,0},	/* frint.s */ -  {116,4,rr,S,S,0},	/* frint.d */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {116,3,rr,V,V,0},	/* frint.s */ -  {116,4,rr,V,V,0},	/* frint.d */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {116,11,rr,V,V,0},	/* frint.s.f */ -  {116,12,rr,V,V,0},	/* frint.d.f */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {81,3,rr,V,V,0},	/* sqrt.s */ -  {81,4,rr,V,V,0},	/* sqrt.d */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {81,11,rr,V,V,0},	/* sqrt.s.f */ -  {81,12,rr,V,V,0},	/* sqrt.d.f */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr e0_format3[] = { -  {32,11,rr,V,V,0},	/* cvtd.s.f */ -  {31,12,rr,V,V,0},	/* cvts.d.f */ -  {33,12,rr,V,V,0},	/* cvtl.d.f */ -  {32,16,rr,V,V,0},	/* cvtd.l.f */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {36,2,rr,V,V,0},	/* tzc.f */ -  {44,2,rr,V,V,0},	/* lop.f */ -  {117,2,rr,V,V,0},	/* xpnd.f */ -  {42,2,rr,V,V,0},	/* not.f */ -  {8,2,rr,S,V,0},	/* shf.f */ -  {35,17,rr,V,V,0},	/* plc.t.f */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {37,11,rr,V,V,0},	/* eq.s.f */ -  {37,12,rr,V,V,0},	/* eq.d.f */ -  {43,11,rr,V,V,0},	/* neg.s.f */ -  {43,12,rr,V,V,0},	/* neg.d.f */ -  {37,11,rr,S,V,0},	/* eq.s.f */ -  {37,12,rr,S,V,0},	/* eq.d.f */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {40,11,rr,V,V,0},	/* le.s.f */ -  {40,12,rr,V,V,0},	/* le.d.f */ -  {41,11,rr,V,V,0},	/* lt.s.f */ -  {41,12,rr,V,V,0},	/* lt.d.f */ -  {40,11,rr,S,V,0},	/* le.s.f */ -  {40,12,rr,S,V,0},	/* le.d.f */ -  {41,11,rr,S,V,0},	/* lt.s.f */ -  {41,12,rr,S,V,0},	/* lt.d.f */ -  {37,13,rr,V,V,0},	/* eq.b.f */ -  {37,14,rr,V,V,0},	/* eq.h.f */ -  {37,15,rr,V,V,0},	/* eq.w.f */ -  {37,16,rr,V,V,0},	/* eq.l.f */ -  {37,13,rr,S,V,0},	/* eq.b.f */ -  {37,14,rr,S,V,0},	/* eq.h.f */ -  {37,15,rr,S,V,0},	/* eq.w.f */ -  {37,16,rr,S,V,0},	/* eq.l.f */ -  {40,13,rr,V,V,0},	/* le.b.f */ -  {40,14,rr,V,V,0},	/* le.h.f */ -  {40,15,rr,V,V,0},	/* le.w.f */ -  {40,16,rr,V,V,0},	/* le.l.f */ -  {40,13,rr,S,V,0},	/* le.b.f */ -  {40,14,rr,S,V,0},	/* le.h.f */ -  {40,15,rr,S,V,0},	/* le.w.f */ -  {40,16,rr,S,V,0},	/* le.l.f */ -  {41,13,rr,V,V,0},	/* lt.b.f */ -  {41,14,rr,V,V,0},	/* lt.h.f */ -  {41,15,rr,V,V,0},	/* lt.w.f */ -  {41,16,rr,V,V,0},	/* lt.l.f */ -  {41,13,rr,S,V,0},	/* lt.b.f */ -  {41,14,rr,S,V,0},	/* lt.h.f */ -  {41,15,rr,S,V,0},	/* lt.w.f */ -  {41,16,rr,S,V,0},	/* lt.l.f */ -  {43,13,rr,V,V,0},	/* neg.b.f */ -  {43,14,rr,V,V,0},	/* neg.h.f */ -  {43,15,rr,V,V,0},	/* neg.w.f */ -  {43,16,rr,V,V,0},	/* neg.l.f */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr e0_format4[] = { -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr e0_format5[] = { -  {51,13,rr,V,V,0},	/* ldvi.b.f */ -  {51,14,rr,V,V,0},	/* ldvi.h.f */ -  {51,15,rr,V,V,0},	/* ldvi.w.f */ -  {51,16,rr,V,V,0},	/* ldvi.l.f */ -  {28,11,rr,V,V,0},	/* cvtw.s.f */ -  {31,15,rr,V,V,0},	/* cvts.w.f */ -  {28,16,rr,V,V,0},	/* cvtw.l.f */ -  {33,15,rr,V,V,0},	/* cvtl.w.f */ -  {52,13,rxr,V,V,0},	/* stvi.b.f */ -  {52,14,rxr,V,V,0},	/* stvi.h.f */ -  {52,15,rxr,V,V,0},	/* stvi.w.f */ -  {52,16,rxr,V,V,0},	/* stvi.l.f */ -  {52,13,rxr,S,V,0},	/* stvi.b.f */ -  {52,14,rxr,S,V,0},	/* stvi.h.f */ -  {52,15,rxr,S,V,0},	/* stvi.w.f */ -  {52,16,rxr,S,V,0},	/* stvi.l.f */ -}; - -CONST struct formstr e0_format6[] = { -  {0,0,rxl,S,CIR,0},	/* mov */ -  {0,0,lr,CIR,S,0},	/* mov */ -  {0,0,lr,TOC,S,0},	/* mov */ -  {0,0,lr,CPUID,S,0},	/* mov */ -  {0,0,rxl,S,TTR,0},	/* mov */ -  {0,0,lr,TTR,S,0},	/* mov */ -  {118,0,nops,0,0,0},	/* ctrsl */ -  {119,0,nops,0,0,0},	/* ctrsg */ -  {0,0,rxl,S,VMU,0},	/* mov */ -  {0,0,lr,VMU,S,0},	/* mov */ -  {0,0,rxl,S,VML,0},	/* mov */ -  {0,0,lr,VML,S,0},	/* mov */ -  {0,0,rxl,S,ICR,0},	/* mov */ -  {0,0,lr,ICR,S,0},	/* mov */ -  {0,0,rxl,S,TCPU,0},	/* mov */ -  {0,0,lr,TCPU,S,0},	/* mov */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {120,0,nops,0,0,0},	/* stop */ -  {0,0,0,0,0,0}, -  {0,0,rxl,S,TID,0},	/* mov */ -  {0,0,lr,TID,S,0},	/* mov */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr e0_format7[] = { -  {84,13,r,V,0,0},	/* sum.b.f */ -  {84,14,r,V,0,0},	/* sum.h.f */ -  {84,15,r,V,0,0},	/* sum.w.f */ -  {84,16,r,V,0,0},	/* sum.l.f */ -  {85,2,r,V,0,0},	/* all.f */ -  {86,2,r,V,0,0},	/* any.f */ -  {87,2,r,V,0,0},	/* parity.f */ -  {0,0,0,0,0,0}, -  {88,13,r,V,0,0},	/* max.b.f */ -  {88,14,r,V,0,0},	/* max.h.f */ -  {88,15,r,V,0,0},	/* max.w.f */ -  {88,16,r,V,0,0},	/* max.l.f */ -  {89,13,r,V,0,0},	/* min.b.f */ -  {89,14,r,V,0,0},	/* min.h.f */ -  {89,15,r,V,0,0},	/* min.w.f */ -  {89,16,r,V,0,0},	/* min.l.f */ -  {84,11,r,V,0,0},	/* sum.s.f */ -  {84,12,r,V,0,0},	/* sum.d.f */ -  {90,11,r,V,0,0},	/* prod.s.f */ -  {90,12,r,V,0,0},	/* prod.d.f */ -  {88,11,r,V,0,0},	/* max.s.f */ -  {88,12,r,V,0,0},	/* max.d.f */ -  {89,11,r,V,0,0},	/* min.s.f */ -  {89,12,r,V,0,0},	/* min.d.f */ -  {90,13,r,V,0,0},	/* prod.b.f */ -  {90,14,r,V,0,0},	/* prod.h.f */ -  {90,15,r,V,0,0},	/* prod.w.f */ -  {90,16,r,V,0,0},	/* prod.l.f */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr e1_format0[] = { -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {10,18,rrr,S,V,V},	/* sub.s.t */ -  {10,19,rrr,S,V,V},	/* sub.d.t */ -  {4,18,rrr,S,V,V},	/* div.s.t */ -  {4,19,rrr,S,V,V},	/* div.d.t */ -  {3,18,rrr,V,V,V},	/* mul.s.t */ -  {3,19,rrr,V,V,V},	/* mul.d.t */ -  {4,18,rrr,V,V,V},	/* div.s.t */ -  {4,19,rrr,V,V,V},	/* div.d.t */ -  {3,18,rrr,V,S,V},	/* mul.s.t */ -  {3,19,rrr,V,S,V},	/* mul.d.t */ -  {4,18,rrr,V,S,V},	/* div.s.t */ -  {4,19,rrr,V,S,V},	/* div.d.t */ -  {5,1,rrr,V,V,V},	/* and.t */ -  {6,1,rrr,V,V,V},	/* or.t */ -  {7,1,rrr,V,V,V},	/* xor.t */ -  {8,1,rrr,V,V,V},	/* shf.t */ -  {5,1,rrr,V,S,V},	/* and.t */ -  {6,1,rrr,V,S,V},	/* or.t */ -  {7,1,rrr,V,S,V},	/* xor.t */ -  {8,1,rrr,V,S,V},	/* shf.t */ -  {9,18,rrr,V,V,V},	/* add.s.t */ -  {9,19,rrr,V,V,V},	/* add.d.t */ -  {10,18,rrr,V,V,V},	/* sub.s.t */ -  {10,19,rrr,V,V,V},	/* sub.d.t */ -  {9,18,rrr,V,S,V},	/* add.s.t */ -  {9,19,rrr,V,S,V},	/* add.d.t */ -  {10,18,rrr,V,S,V},	/* sub.s.t */ -  {10,19,rrr,V,S,V},	/* sub.d.t */ -  {9,20,rrr,V,V,V},	/* add.b.t */ -  {9,21,rrr,V,V,V},	/* add.h.t */ -  {9,22,rrr,V,V,V},	/* add.w.t */ -  {9,23,rrr,V,V,V},	/* add.l.t */ -  {9,20,rrr,V,S,V},	/* add.b.t */ -  {9,21,rrr,V,S,V},	/* add.h.t */ -  {9,22,rrr,V,S,V},	/* add.w.t */ -  {9,23,rrr,V,S,V},	/* add.l.t */ -  {10,20,rrr,V,V,V},	/* sub.b.t */ -  {10,21,rrr,V,V,V},	/* sub.h.t */ -  {10,22,rrr,V,V,V},	/* sub.w.t */ -  {10,23,rrr,V,V,V},	/* sub.l.t */ -  {10,20,rrr,V,S,V},	/* sub.b.t */ -  {10,21,rrr,V,S,V},	/* sub.h.t */ -  {10,22,rrr,V,S,V},	/* sub.w.t */ -  {10,23,rrr,V,S,V},	/* sub.l.t */ -  {3,20,rrr,V,V,V},	/* mul.b.t */ -  {3,21,rrr,V,V,V},	/* mul.h.t */ -  {3,22,rrr,V,V,V},	/* mul.w.t */ -  {3,23,rrr,V,V,V},	/* mul.l.t */ -  {3,20,rrr,V,S,V},	/* mul.b.t */ -  {3,21,rrr,V,S,V},	/* mul.h.t */ -  {3,22,rrr,V,S,V},	/* mul.w.t */ -  {3,23,rrr,V,S,V},	/* mul.l.t */ -  {4,20,rrr,V,V,V},	/* div.b.t */ -  {4,21,rrr,V,V,V},	/* div.h.t */ -  {4,22,rrr,V,V,V},	/* div.w.t */ -  {4,23,rrr,V,V,V},	/* div.l.t */ -  {4,20,rrr,V,S,V},	/* div.b.t */ -  {4,21,rrr,V,S,V},	/* div.h.t */ -  {4,22,rrr,V,S,V},	/* div.w.t */ -  {4,23,rrr,V,S,V},	/* div.l.t */ -}; - -CONST struct formstr e1_format1[] = { -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {26,20,a2r,S,0,0},	/* ste.b.t */ -  {26,21,a2r,S,0,0},	/* ste.h.t */ -  {26,22,a2r,S,0,0},	/* ste.w.t */ -  {26,23,a2r,S,0,0},	/* ste.l.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {18,20,a1r,V,0,0},	/* ld.b.t */ -  {18,21,a1r,V,0,0},	/* ld.h.t */ -  {18,22,a1r,V,0,0},	/* ld.w.t */ -  {18,23,a1r,V,0,0},	/* ld.l.t */ -  {21,20,a2r,V,0,0},	/* st.b.t */ -  {21,21,a2r,V,0,0},	/* st.h.t */ -  {21,22,a2r,V,0,0},	/* st.w.t */ -  {21,23,a2r,V,0,0},	/* st.l.t */ -}; - -CONST struct formstr e1_format2[] = { -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {28,20,rr,V,V,0},	/* cvtw.b.t */ -  {28,21,rr,V,V,0},	/* cvtw.h.t */ -  {29,22,rr,V,V,0},	/* cvtb.w.t */ -  {30,22,rr,V,V,0},	/* cvth.w.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {31,23,rr,V,V,0},	/* cvts.l.t */ -  {32,22,rr,V,V,0},	/* cvtd.w.t */ -  {33,18,rr,V,V,0},	/* cvtl.s.t */ -  {28,19,rr,V,V,0},	/* cvtw.d.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {116,18,rr,V,V,0},	/* frint.s.t */ -  {116,19,rr,V,V,0},	/* frint.d.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {81,18,rr,V,V,0},	/* sqrt.s.t */ -  {81,19,rr,V,V,0},	/* sqrt.d.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr e1_format3[] = { -  {32,18,rr,V,V,0},	/* cvtd.s.t */ -  {31,19,rr,V,V,0},	/* cvts.d.t */ -  {33,19,rr,V,V,0},	/* cvtl.d.t */ -  {32,23,rr,V,V,0},	/* cvtd.l.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {36,1,rr,V,V,0},	/* tzc.t */ -  {44,1,rr,V,V,0},	/* lop.t */ -  {117,1,rr,V,V,0},	/* xpnd.t */ -  {42,1,rr,V,V,0},	/* not.t */ -  {8,1,rr,S,V,0},	/* shf.t */ -  {35,24,rr,V,V,0},	/* plc.t.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {37,18,rr,V,V,0},	/* eq.s.t */ -  {37,19,rr,V,V,0},	/* eq.d.t */ -  {43,18,rr,V,V,0},	/* neg.s.t */ -  {43,19,rr,V,V,0},	/* neg.d.t */ -  {37,18,rr,S,V,0},	/* eq.s.t */ -  {37,19,rr,S,V,0},	/* eq.d.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {40,18,rr,V,V,0},	/* le.s.t */ -  {40,19,rr,V,V,0},	/* le.d.t */ -  {41,18,rr,V,V,0},	/* lt.s.t */ -  {41,19,rr,V,V,0},	/* lt.d.t */ -  {40,18,rr,S,V,0},	/* le.s.t */ -  {40,19,rr,S,V,0},	/* le.d.t */ -  {41,18,rr,S,V,0},	/* lt.s.t */ -  {41,19,rr,S,V,0},	/* lt.d.t */ -  {37,20,rr,V,V,0},	/* eq.b.t */ -  {37,21,rr,V,V,0},	/* eq.h.t */ -  {37,22,rr,V,V,0},	/* eq.w.t */ -  {37,23,rr,V,V,0},	/* eq.l.t */ -  {37,20,rr,S,V,0},	/* eq.b.t */ -  {37,21,rr,S,V,0},	/* eq.h.t */ -  {37,22,rr,S,V,0},	/* eq.w.t */ -  {37,23,rr,S,V,0},	/* eq.l.t */ -  {40,20,rr,V,V,0},	/* le.b.t */ -  {40,21,rr,V,V,0},	/* le.h.t */ -  {40,22,rr,V,V,0},	/* le.w.t */ -  {40,23,rr,V,V,0},	/* le.l.t */ -  {40,20,rr,S,V,0},	/* le.b.t */ -  {40,21,rr,S,V,0},	/* le.h.t */ -  {40,22,rr,S,V,0},	/* le.w.t */ -  {40,23,rr,S,V,0},	/* le.l.t */ -  {41,20,rr,V,V,0},	/* lt.b.t */ -  {41,21,rr,V,V,0},	/* lt.h.t */ -  {41,22,rr,V,V,0},	/* lt.w.t */ -  {41,23,rr,V,V,0},	/* lt.l.t */ -  {41,20,rr,S,V,0},	/* lt.b.t */ -  {41,21,rr,S,V,0},	/* lt.h.t */ -  {41,22,rr,S,V,0},	/* lt.w.t */ -  {41,23,rr,S,V,0},	/* lt.l.t */ -  {43,20,rr,V,V,0},	/* neg.b.t */ -  {43,21,rr,V,V,0},	/* neg.h.t */ -  {43,22,rr,V,V,0},	/* neg.w.t */ -  {43,23,rr,V,V,0},	/* neg.l.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr e1_format4[] = { -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr e1_format5[] = { -  {51,20,rr,V,V,0},	/* ldvi.b.t */ -  {51,21,rr,V,V,0},	/* ldvi.h.t */ -  {51,22,rr,V,V,0},	/* ldvi.w.t */ -  {51,23,rr,V,V,0},	/* ldvi.l.t */ -  {28,18,rr,V,V,0},	/* cvtw.s.t */ -  {31,22,rr,V,V,0},	/* cvts.w.t */ -  {28,23,rr,V,V,0},	/* cvtw.l.t */ -  {33,22,rr,V,V,0},	/* cvtl.w.t */ -  {52,20,rxr,V,V,0},	/* stvi.b.t */ -  {52,21,rxr,V,V,0},	/* stvi.h.t */ -  {52,22,rxr,V,V,0},	/* stvi.w.t */ -  {52,23,rxr,V,V,0},	/* stvi.l.t */ -  {52,20,rxr,S,V,0},	/* stvi.b.t */ -  {52,21,rxr,S,V,0},	/* stvi.h.t */ -  {52,22,rxr,S,V,0},	/* stvi.w.t */ -  {52,23,rxr,S,V,0},	/* stvi.l.t */ -}; - -CONST struct formstr e1_format6[] = { -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -CONST struct formstr e1_format7[] = { -  {84,20,r,V,0,0},	/* sum.b.t */ -  {84,21,r,V,0,0},	/* sum.h.t */ -  {84,22,r,V,0,0},	/* sum.w.t */ -  {84,23,r,V,0,0},	/* sum.l.t */ -  {85,1,r,V,0,0},	/* all.t */ -  {86,1,r,V,0,0},	/* any.t */ -  {87,1,r,V,0,0},	/* parity.t */ -  {0,0,0,0,0,0}, -  {88,20,r,V,0,0},	/* max.b.t */ -  {88,21,r,V,0,0},	/* max.h.t */ -  {88,22,r,V,0,0},	/* max.w.t */ -  {88,23,r,V,0,0},	/* max.l.t */ -  {89,20,r,V,0,0},	/* min.b.t */ -  {89,21,r,V,0,0},	/* min.h.t */ -  {89,22,r,V,0,0},	/* min.w.t */ -  {89,23,r,V,0,0},	/* min.l.t */ -  {84,18,r,V,0,0},	/* sum.s.t */ -  {84,19,r,V,0,0},	/* sum.d.t */ -  {90,18,r,V,0,0},	/* prod.s.t */ -  {90,19,r,V,0,0},	/* prod.d.t */ -  {88,18,r,V,0,0},	/* max.s.t */ -  {88,19,r,V,0,0},	/* max.d.t */ -  {89,18,r,V,0,0},	/* min.s.t */ -  {89,19,r,V,0,0},	/* min.d.t */ -  {90,20,r,V,0,0},	/* prod.b.t */ -  {90,21,r,V,0,0},	/* prod.h.t */ -  {90,22,r,V,0,0},	/* prod.w.t */ -  {90,23,r,V,0,0},	/* prod.l.t */ -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -  {0,0,0,0,0,0}, -}; - -char *lop[] = { -  "mov",	/* 0 */ -  "merg",	/* 1 */ -  "mask",	/* 2 */ -  "mul",	/* 3 */ -  "div",	/* 4 */ -  "and",	/* 5 */ -  "or",	/* 6 */ -  "xor",	/* 7 */ -  "shf",	/* 8 */ -  "add",	/* 9 */ -  "sub",	/* 10 */ -  "exit",	/* 11 */ -  "jmp",	/* 12 */ -  "jmpi",	/* 13 */ -  "jmpa",	/* 14 */ -  "jmps",	/* 15 */ -  "tac",	/* 16 */ -  "ldea",	/* 17 */ -  "ld",	/* 18 */ -  "tas",	/* 19 */ -  "pshea",	/* 20 */ -  "st",	/* 21 */ -  "call",	/* 22 */ -  "calls",	/* 23 */ -  "callq",	/* 24 */ -  "pfork",	/* 25 */ -  "ste",	/* 26 */ -  "incr",	/* 27 */ -  "cvtw",	/* 28 */ -  "cvtb",	/* 29 */ -  "cvth",	/* 30 */ -  "cvts",	/* 31 */ -  "cvtd",	/* 32 */ -  "cvtl",	/* 33 */ -  "ldpa",	/* 34 */ -  "plc",	/* 35 */ -  "tzc",	/* 36 */ -  "eq",	/* 37 */ -  "leu",	/* 38 */ -  "ltu",	/* 39 */ -  "le",	/* 40 */ -  "lt",	/* 41 */ -  "not",	/* 42 */ -  "neg",	/* 43 */ -  "lop",	/* 44 */ -  "cprs",	/* 45 */ -  "nop",	/* 46 */ -  "br",	/* 47 */ -  "bri",	/* 48 */ -  "bra",	/* 49 */ -  "brs",	/* 50 */ -  "ldvi",	/* 51 */ -  "stvi",	/* 52 */ -  "ldsdr",	/* 53 */ -  "ldkdr",	/* 54 */ -  "ln",	/* 55 */ -  "patu",	/* 56 */ -  "pate",	/* 57 */ -  "pich",	/* 58 */ -  "plch",	/* 59 */ -  "idle",	/* 60 */ -  "rtnq",	/* 61 */ -  "cfork",	/* 62 */ -  "rtn",	/* 63 */ -  "wfork",	/* 64 */ -  "join",	/* 65 */ -  "rtnc",	/* 66 */ -  "exp",	/* 67 */ -  "sin",	/* 68 */ -  "cos",	/* 69 */ -  "psh",	/* 70 */ -  "pop",	/* 71 */ -  "eni",	/* 72 */ -  "dsi",	/* 73 */ -  "bkpt",	/* 74 */ -  "msync",	/* 75 */ -  "mski",	/* 76 */ -  "xmti",	/* 77 */ -  "tstvv",	/* 78 */ -  "diag",	/* 79 */ -  "pbkpt",	/* 80 */ -  "sqrt",	/* 81 */ -  "casr",	/* 82 */ -  "atan",	/* 83 */ -  "sum",	/* 84 */ -  "all",	/* 85 */ -  "any",	/* 86 */ -  "parity",	/* 87 */ -  "max",	/* 88 */ -  "min",	/* 89 */ -  "prod",	/* 90 */ -  "halt",	/* 91 */ -  "sysc",	/* 92 */ -  "trap",	/* 93 */ -  "tst",	/* 94 */ -  "lck",	/* 95 */ -  "ulk",	/* 96 */ -  "spawn",	/* 97 */ -  "ldcmr",	/* 98 */ -  "stcmr",	/* 99 */ -  "popr",	/* 100 */ -  "pshr",	/* 101 */ -  "rcvr",	/* 102 */ -  "matm",	/* 103 */ -  "sndr",	/* 104 */ -  "putr",	/* 105 */ -  "getr",	/* 106 */ -  "matr",	/* 107 */ -  "mat",	/* 108 */ -  "get",	/* 109 */ -  "rcv",	/* 110 */ -  "inc",	/* 111 */ -  "put",	/* 112 */ -  "snd",	/* 113 */ -  "enal",	/* 114 */ -  "enag",	/* 115 */ -  "frint",	/* 116 */ -  "xpnd",	/* 117 */ -  "ctrsl",	/* 118 */ -  "ctrsg",	/* 119 */ -  "stop",	/* 120 */ -}; - -char *rop[] = { -  "",	/* 0 */ -  ".t",	/* 1 */ -  ".f",	/* 2 */ -  ".s",	/* 3 */ -  ".d",	/* 4 */ -  ".b",	/* 5 */ -  ".h",	/* 6 */ -  ".w",	/* 7 */ -  ".l",	/* 8 */ -  ".x",	/* 9 */ -  ".u",	/* 10 */ -  ".s.f",	/* 11 */ -  ".d.f",	/* 12 */ -  ".b.f",	/* 13 */ -  ".h.f",	/* 14 */ -  ".w.f",	/* 15 */ -  ".l.f",	/* 16 */ -  ".t.f",	/* 17 */ -  ".s.t",	/* 18 */ -  ".d.t",	/* 19 */ -  ".b.t",	/* 20 */ -  ".h.t",	/* 21 */ -  ".w.t",	/* 22 */ -  ".l.t",	/* 23 */ -  ".t.t",	/* 24 */ -}; diff --git a/contrib/binutils/include/opcode/i386.h b/contrib/binutils/include/opcode/i386.h deleted file mode 100644 index da238c9b2eee..000000000000 --- a/contrib/binutils/include/opcode/i386.h +++ /dev/null @@ -1,981 +0,0 @@ -/* i386-opcode.h -- Intel 80386 opcode table -   Copyright 1989, 91, 92, 93, 94, 95, 96, 97, 1998 Free Software Foundation. - -This file is part of GAS, the GNU Assembler, and GDB, the GNU Debugger. - -This program is free software; you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation; either version 2 of the License, or -(at your option) any later version. - -This program is distributed in the hope that it 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 program; if not, write to the Free Software -Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */ - -/* The NON_BROKEN_OPCODES cases use the operands in the reverse order -   from that documented in the Intel manuals.  The opcode values are -   such that they actually generate different instructions.  These -   values must not be changed, as they are the values generated by the -   UnixWare assembler, and possibly other ix86 assemblers.  */ - -static const template i386_optab[] = { - -#define _ None -/* move instructions */ -#define MOV_AX_DISP32 0xa0 -{ "mov", 2, 0xa0, _, DW|NoModrm, { Disp32, Acc, 0 } }, -{ "mov", 2, 0x88, _, DW|Modrm, { Reg, Reg|Mem, 0 } }, -{ "mov", 2, 0xb0, _, ShortFormW, { Imm, Reg, 0 } }, -{ "mov", 2, 0xc6, _,  W|Modrm,  { Imm, Reg|Mem, 0 } }, -/* The next instruction accepts WordReg so that `movl %gs,%esi' can be -   used to move a segment register to a 32 bit register without using -   a size prefix.  This will set the upper 16 bits of the 32 bit -   register to an implementation defined value (on the Pentium Pro, -   the implementation defined value is zero).  */ -{ "mov", 2, 0x8c, _, D|Modrm,  { SReg3|SReg2, WordReg|WordMem, 0 } }, -/* move to/from control debug registers */ -{ "mov", 2, 0x0f20, _, D|Modrm, { Control, Reg32, 0} }, -{ "mov", 2, 0x0f21, _, D|Modrm, { Debug, Reg32, 0} }, -{ "mov", 2, 0x0f24, _, D|Modrm, { Test, Reg32, 0} }, - -/* move with sign extend */ -/* "movsbl" & "movsbw" must not be unified into "movsb" to avoid -   conflict with the "movs" string move instruction.  Thus, -   {"movsb", 2, 0x0fbe, _, ReverseRegRegmem|Modrm, { Reg8|Mem,  Reg16|Reg32, 0} }, -   is not kosher; we must seperate the two instructions. */ -{"movsbl", 2, 0x0fbe, _, ReverseRegRegmem|Modrm|Data32, { Reg8|Mem,  Reg32, 0} }, -{"movsbw", 2, 0x0fbe, _, ReverseRegRegmem|Modrm|Data16, { Reg8|Mem,  Reg16, 0} }, -{"movswl", 2, 0x0fbf, _, ReverseRegRegmem|Modrm, { Reg16|Mem, Reg32, 0} }, - -/* move with zero extend */ -{"movzb", 2, 0x0fb6, _, ReverseRegRegmem|Modrm, { Reg8|Mem, Reg16|Reg32, 0} }, -{"movzwl", 2, 0x0fb7, _, ReverseRegRegmem|Modrm, { Reg16|Mem, Reg32, 0} }, - -/* push instructions */ -{"push", 1, 0x50, _, ShortForm, { WordReg,0,0 } }, -{"push", 1, 0xff, 0x6,  Modrm, { WordReg|WordMem, 0, 0 } }, -{"push", 1, 0x6a, _, NoModrm, { Imm8S, 0, 0} }, -{"push", 1, 0x68, _, NoModrm, { Imm16|Imm32, 0, 0} }, -{"push", 1, 0x06, _,  Seg2ShortForm, { SReg2,0,0 } }, -{"push", 1, 0x0fa0, _, Seg3ShortForm, { SReg3,0,0 } }, -/* push all */ -{"pusha", 0, 0x60, _, NoModrm, { 0, 0, 0 } }, - -/* pop instructions */ -{"pop", 1, 0x58, _, ShortForm, { WordReg,0,0 } }, -{"pop", 1, 0x8f, 0x0,  Modrm, { WordReg|WordMem, 0, 0 } }, -#define POP_SEG_SHORT 0x7 -{"pop", 1, 0x07, _,  Seg2ShortForm, { SReg2,0,0 } }, -{"pop", 1, 0x0fa1, _, Seg3ShortForm, { SReg3,0,0 } }, -/* pop all */ -{"popa", 0, 0x61, _, NoModrm, { 0, 0, 0 } }, - -/* xchg exchange instructions -   xchg commutes:  we allow both operand orders */ -{"xchg", 2, 0x90, _, ShortForm, { WordReg, Acc, 0 } }, -{"xchg", 2, 0x90, _, ShortForm, { Acc, WordReg, 0 } }, -{"xchg", 2, 0x86, _, W|Modrm, { Reg, Reg|Mem, 0 } }, -{"xchg", 2, 0x86, _, W|Modrm, { Reg|Mem, Reg, 0 } }, - -/* in/out from ports */ -{"in", 2, 0xe4, _, W|NoModrm, { Imm8, Acc, 0 } }, -{"in", 2, 0xec, _, W|NoModrm, { InOutPortReg, Acc, 0 } }, -{"in", 1, 0xe4, _, W|NoModrm, { Imm8, 0, 0 } }, -{"in", 1, 0xec, _, W|NoModrm, { InOutPortReg, 0, 0 } }, -{"out", 2, 0xe6, _, W|NoModrm, { Acc, Imm8, 0 } }, -{"out", 2, 0xee, _, W|NoModrm, { Acc, InOutPortReg, 0 } }, -{"out", 1, 0xe6, _, W|NoModrm, { Imm8, 0, 0 } }, -{"out", 1, 0xee, _, W|NoModrm, { InOutPortReg, 0, 0 } }, - -/* load effective address */ -{"lea", 2, 0x8d, _, Modrm, { WordMem, WordReg, 0 } }, - -/* load segment registers from memory */ -{"lds", 2, 0xc5, _, Modrm, { Mem, Reg32, 0} }, -{"les", 2, 0xc4, _, Modrm, { Mem, Reg32, 0} }, -{"lfs", 2, 0x0fb4, _, Modrm, { Mem, Reg32, 0} }, -{"lgs", 2, 0x0fb5, _, Modrm, { Mem, Reg32, 0} }, -{"lss", 2, 0x0fb2, _, Modrm, { Mem, Reg32, 0} }, - -/* flags register instructions */ -{"clc", 0, 0xf8, _, NoModrm, { 0, 0, 0} }, -{"cld", 0, 0xfc, _, NoModrm, { 0, 0, 0} }, -{"cli", 0, 0xfa, _, NoModrm, { 0, 0, 0} }, -{"clts", 0, 0x0f06, _, NoModrm, { 0, 0, 0} }, -{"cmc", 0, 0xf5, _, NoModrm, { 0, 0, 0} }, -{"lahf", 0, 0x9f, _, NoModrm, { 0, 0, 0} }, -{"sahf", 0, 0x9e, _, NoModrm, { 0, 0, 0} }, -{"pushfl", 0, 0x9c, _, NoModrm|Data32, { 0, 0, 0} }, -{"popfl", 0, 0x9d, _, NoModrm|Data32, { 0, 0, 0} }, -{"pushfw", 0, 0x9c, _, NoModrm|Data16, { 0, 0, 0} }, -{"popfw", 0, 0x9d, _, NoModrm|Data16, { 0, 0, 0} }, -{"pushf", 0, 0x9c, _, NoModrm, { 0, 0, 0} }, -{"popf", 0, 0x9d, _, NoModrm, { 0, 0, 0} }, -{"stc", 0, 0xf9, _, NoModrm, { 0, 0, 0} }, -{"std", 0, 0xfd, _, NoModrm, { 0, 0, 0} }, -{"sti", 0, 0xfb, _, NoModrm, { 0, 0, 0} }, - -{"add", 2, 0x0,  _, DW|Modrm, { Reg, Reg|Mem, 0} }, -{"add", 2, 0x83, 0,  Modrm, { Imm8S, WordReg|WordMem, 0} }, -{"add", 2, 0x4,  _,  W|NoModrm, { Imm,  Acc,    0} }, -{"add", 2, 0x80, 0, W|Modrm, { Imm, Reg|Mem, 0} }, - -{"inc", 1, 0x40, _, ShortForm, { WordReg, 0, 0} }, -{"inc", 1, 0xfe, 0, W|Modrm, { Reg|Mem, 0, 0} }, - -{"sub", 2, 0x28,  _, DW|Modrm, { Reg, Reg|Mem, 0} }, -{"sub", 2, 0x83, 5,  Modrm, { Imm8S, WordReg|WordMem, 0} }, -{"sub", 2, 0x2c,  _,  W|NoModrm, { Imm,  Acc,    0} }, -{"sub", 2, 0x80, 5,  W|Modrm, { Imm, Reg|Mem, 0} }, - -{"dec", 1, 0x48, _, ShortForm, { WordReg, 0, 0} }, -{"dec", 1, 0xfe, 1, W|Modrm, { Reg|Mem, 0, 0} }, - -{"sbb", 2, 0x18,  _, DW|Modrm, { Reg, Reg|Mem, 0} }, -{"sbb", 2, 0x83, 3,  Modrm, { Imm8S, WordReg|WordMem, 0} }, -{"sbb", 2, 0x1c,  _,  W|NoModrm, { Imm,  Acc,    0} }, -{"sbb", 2, 0x80, 3,  W|Modrm, { Imm, Reg|Mem, 0} }, - -{"cmp", 2, 0x38,  _, DW|Modrm, { Reg, Reg|Mem, 0} }, -{"cmp", 2, 0x83, 7,  Modrm, { Imm8S, WordReg|WordMem, 0} }, -{"cmp", 2, 0x3c,  _,  W|NoModrm, { Imm,  Acc,    0} }, -{"cmp", 2, 0x80, 7,  W|Modrm, { Imm, Reg|Mem, 0} }, - -{"test", 2, 0x84, _, W|Modrm, { Reg|Mem, Reg, 0} }, -{"test", 2, 0x84, _, W|Modrm, { Reg, Reg|Mem, 0} }, -{"test", 2, 0xa8, _, W|NoModrm, { Imm, Acc, 0} }, -{"test", 2, 0xf6, 0, W|Modrm, { Imm, Reg|Mem, 0} }, - -{"and", 2, 0x20,  _, DW|Modrm, { Reg, Reg|Mem, 0} }, -{"and", 2, 0x83, 4,  Modrm, { Imm8S, WordReg|WordMem, 0} }, -{"and", 2, 0x24,  _,  W|NoModrm, { Imm,  Acc,    0} }, -{"and", 2, 0x80, 4,  W|Modrm, { Imm, Reg|Mem, 0} }, - -{"or", 2, 0x08,  _, DW|Modrm, { Reg, Reg|Mem, 0} }, -{"or", 2, 0x83, 1,  Modrm, { Imm8S, WordReg|WordMem, 0} }, -{"or", 2, 0x0c,  _,  W|NoModrm, { Imm,  Acc,    0} }, -{"or", 2, 0x80, 1,  W|Modrm, { Imm, Reg|Mem, 0} }, - -{"xor", 2, 0x30,  _, DW|Modrm, { Reg, Reg|Mem, 0} }, -{"xor", 2, 0x83, 6,  Modrm, { Imm8S, WordReg|WordMem, 0} }, -{"xor", 2, 0x34,  _,  W|NoModrm, { Imm,  Acc,    0} }, -{"xor", 2, 0x80, 6,  W|Modrm, { Imm, Reg|Mem, 0} }, - -/* iclr with 1 operand is really xor with 2 operands.  */ -{"clr", 1, 0x30, _, W|Modrm|iclrKludge, { Reg } }, - -{"adc", 2, 0x10,  _, DW|Modrm, { Reg, Reg|Mem, 0} }, -{"adc", 2, 0x83, 2,  Modrm, { Imm8S, WordReg|WordMem, 0} }, -{"adc", 2, 0x14,  _,  W|NoModrm, { Imm,  Acc,    0} }, -{"adc", 2, 0x80, 2,  W|Modrm, { Imm, Reg|Mem, 0} }, - -{"neg", 1, 0xf6, 3, W|Modrm, { Reg|Mem, 0, 0} }, -{"not", 1, 0xf6, 2, W|Modrm, { Reg|Mem, 0, 0} }, - -{"aaa", 0, 0x37, _, NoModrm, { 0, 0, 0} }, -{"aas", 0, 0x3f, _, NoModrm, { 0, 0, 0} }, -{"daa", 0, 0x27, _, NoModrm, { 0, 0, 0} }, -{"das", 0, 0x2f, _, NoModrm, { 0, 0, 0} }, -{"aad", 0, 0xd50a, _, NoModrm, { 0, 0, 0} }, -{"aam", 0, 0xd40a, _, NoModrm, { 0, 0, 0} }, - -/* conversion insns */ -/* conversion:  intel naming */ -{"cbw", 0, 0x98, _, NoModrm|Data16, { 0, 0, 0} }, -{"cwd", 0, 0x99, _, NoModrm|Data16, { 0, 0, 0} }, -{"cwde", 0, 0x98, _, NoModrm|Data32, { 0, 0, 0} }, -{"cdq", 0, 0x99, _, NoModrm|Data32, { 0, 0, 0} }, -/*  att naming */ -{"cbtw", 0, 0x98, _, NoModrm|Data16, { 0, 0, 0} }, -{"cwtl", 0, 0x98, _, NoModrm|Data32, { 0, 0, 0} }, -{"cwtd", 0, 0x99, _, NoModrm|Data16, { 0, 0, 0} }, -{"cltd", 0, 0x99, _, NoModrm|Data32, { 0, 0, 0} }, - -/* Warning! the mul/imul (opcode 0xf6) must only have 1 operand!  They are -   expanding 64-bit multiplies, and *cannot* be selected to accomplish -   'imul %ebx, %eax' (opcode 0x0faf must be used in this case) -   These multiplies can only be selected with single operand forms. */ -{"mul",  1, 0xf6, 4, W|Modrm, { Reg|Mem, 0, 0} }, -{"imul", 1, 0xf6, 5, W|Modrm, { Reg|Mem, 0, 0} }, - - - - -/* imulKludge here is needed to reverse the i.rm.reg & i.rm.regmem fields. -   These instructions are exceptions:  'imul $2, %eax, %ecx' would put -   '%eax' in the reg field and '%ecx' in the regmem field if we did not -   switch them. */ -{"imul", 2, 0x0faf, _, Modrm|ReverseRegRegmem, { WordReg|Mem, WordReg, 0} }, -{"imul", 3, 0x6b, _, Modrm|ReverseRegRegmem, { Imm8S, WordReg|Mem, WordReg} }, -{"imul", 3, 0x69, _, Modrm|ReverseRegRegmem, { Imm16|Imm32, WordReg|Mem, WordReg} }, -/* -  imul with 2 operands mimicks imul with 3 by puting register both -  in i.rm.reg & i.rm.regmem fields -*/ -{"imul", 2, 0x6b, _, Modrm|imulKludge, { Imm8S, WordReg, 0} }, -{"imul", 2, 0x69, _, Modrm|imulKludge, { Imm16|Imm32, WordReg, 0} }, -{"div", 1, 0xf6, 6, W|Modrm, { Reg|Mem, 0, 0} }, -{"div", 2, 0xf6, 6, W|Modrm, { Reg|Mem, Acc, 0} }, -{"idiv", 1, 0xf6, 7, W|Modrm, { Reg|Mem, 0, 0} }, -{"idiv", 2, 0xf6, 7, W|Modrm, { Reg|Mem, Acc, 0} }, - -{"rol", 2, 0xd0, 0, W|Modrm, { Imm1, Reg|Mem, 0} }, -{"rol", 2, 0xc0, 0, W|Modrm, { Imm8, Reg|Mem, 0} }, -{"rol", 2, 0xd2, 0, W|Modrm, { ShiftCount, Reg|Mem, 0} }, -{"rol", 1, 0xd0, 0, W|Modrm, { Reg|Mem, 0, 0} }, - -{"ror", 2, 0xd0, 1, W|Modrm, { Imm1, Reg|Mem, 0} }, -{"ror", 2, 0xc0, 1, W|Modrm, { Imm8, Reg|Mem, 0} }, -{"ror", 2, 0xd2, 1, W|Modrm, { ShiftCount, Reg|Mem, 0} }, -{"ror", 1, 0xd0, 1, W|Modrm, { Reg|Mem, 0, 0} }, - -{"rcl", 2, 0xd0, 2, W|Modrm, { Imm1, Reg|Mem, 0} }, -{"rcl", 2, 0xc0, 2, W|Modrm, { Imm8, Reg|Mem, 0} }, -{"rcl", 2, 0xd2, 2, W|Modrm, { ShiftCount, Reg|Mem, 0} }, -{"rcl", 1, 0xd0, 2, W|Modrm, { Reg|Mem, 0, 0} }, - -{"rcr", 2, 0xd0, 3, W|Modrm, { Imm1, Reg|Mem, 0} }, -{"rcr", 2, 0xc0, 3, W|Modrm, { Imm8, Reg|Mem, 0} }, -{"rcr", 2, 0xd2, 3, W|Modrm, { ShiftCount, Reg|Mem, 0} }, -{"rcr", 1, 0xd0, 3, W|Modrm, { Reg|Mem, 0, 0} }, - -{"sal", 2, 0xd0, 4, W|Modrm, { Imm1, Reg|Mem, 0} }, -{"sal", 2, 0xc0, 4, W|Modrm, { Imm8, Reg|Mem, 0} }, -{"sal", 2, 0xd2, 4, W|Modrm, { ShiftCount, Reg|Mem, 0} }, -{"sal", 1, 0xd0, 4, W|Modrm, { Reg|Mem, 0, 0} }, -{"shl", 2, 0xd0, 4, W|Modrm, { Imm1, Reg|Mem, 0} }, -{"shl", 2, 0xc0, 4, W|Modrm, { Imm8, Reg|Mem, 0} }, -{"shl", 2, 0xd2, 4, W|Modrm, { ShiftCount, Reg|Mem, 0} }, -{"shl", 1, 0xd0, 4, W|Modrm, { Reg|Mem, 0, 0} }, - -{"shld", 3, 0x0fa4, _, Modrm, { Imm8, WordReg, WordReg|Mem} }, -{"shld", 3, 0x0fa5, _, Modrm, { ShiftCount, WordReg, WordReg|Mem} }, -{"shld", 2, 0x0fa5, _, Modrm, { WordReg, WordReg|Mem, 0} }, - -{"shr", 2, 0xd0, 5, W|Modrm, { Imm1, Reg|Mem, 0} }, -{"shr", 2, 0xc0, 5, W|Modrm, { Imm8, Reg|Mem, 0} }, -{"shr", 2, 0xd2, 5, W|Modrm, { ShiftCount, Reg|Mem, 0} }, -{"shr", 1, 0xd0, 5, W|Modrm, { Reg|Mem, 0, 0} }, - -{"shrd", 3, 0x0fac, _, Modrm, { Imm8, WordReg, WordReg|Mem} }, -{"shrd", 3, 0x0fad, _, Modrm, { ShiftCount, WordReg, WordReg|Mem} }, -{"shrd", 2, 0x0fad, _, Modrm, { WordReg, WordReg|Mem, 0} }, - -{"sar", 2, 0xd0, 7, W|Modrm, { Imm1, Reg|Mem, 0} }, -{"sar", 2, 0xc0, 7, W|Modrm, { Imm8, Reg|Mem, 0} }, -{"sar", 2, 0xd2, 7, W|Modrm, { ShiftCount, Reg|Mem, 0} }, -{"sar", 1, 0xd0, 7, W|Modrm, { Reg|Mem, 0, 0} }, - -/* control transfer instructions */ -#define CALL_PC_RELATIVE 0xe8 -{"call", 1, 0xe8, _, JumpDword, { Disp32, 0, 0} }, -{"call", 1, 0xff, 2, Modrm|Data32, { Reg|Mem|JumpAbsolute, 0, 0} }, -{"callw", 1, 0xff, 2, Modrm|Data16, { Reg|Mem|JumpAbsolute, 0, 0} }, -#define CALL_FAR_IMMEDIATE 0x9a -{"lcall", 2, 0x9a, _, JumpInterSegment, { Imm16, Imm32, 0} }, -{"lcall", 1, 0xff, 3, Modrm|Data32, { Mem, 0, 0} }, -{"lcallw", 1, 0xff, 3, Modrm|Data16, { Mem, 0, 0} }, - -#define JUMP_PC_RELATIVE 0xeb -{"jmp", 1, 0xeb, _, Jump, { Disp, 0, 0} }, -{"jmp", 1, 0xff, 4, Modrm, { Reg32|Mem|JumpAbsolute, 0, 0} }, -#define JUMP_FAR_IMMEDIATE 0xea -{"ljmp", 2, 0xea, _, JumpInterSegment, { Imm16, Imm32, 0} }, -{"ljmp", 1, 0xff, 5, Modrm|Data32, { Mem, 0, 0} }, - -{"ret", 0, 0xc3, _, NoModrm|Data32, { 0, 0, 0} }, -{"ret", 1, 0xc2, _, NoModrm|Data32, { Imm16, 0, 0} }, -{"retw", 0, 0xc3, _, NoModrm|Data16, { 0, 0, 0} }, -{"retw", 1, 0xc2, _, NoModrm|Data16, { Imm16, 0, 0} }, -{"lret", 0, 0xcb, _, NoModrm|Data32, { 0, 0, 0} }, -{"lret", 1, 0xca, _, NoModrm|Data32, { Imm16, 0, 0} }, -{"lretw", 0, 0xcb, _, NoModrm|Data16, { 0, 0, 0} }, -{"lretw", 1, 0xca, _, NoModrm|Data16, { Imm16, 0, 0} }, -{"enter", 2, 0xc8, _, NoModrm|Data32, { Imm16, Imm8, 0} }, -{"leave", 0, 0xc9, _, NoModrm|Data32, { 0, 0, 0} }, -{"enterw", 2, 0xc8, _, NoModrm|Data16, { Imm16, Imm8, 0} }, -{"leavew", 0, 0xc9, _, NoModrm|Data16, { 0, 0, 0} }, - -/* conditional jumps */ -{"jo", 1, 0x70, _, Jump, { Disp, 0, 0} }, - -{"jno", 1, 0x71, _, Jump, { Disp, 0, 0} }, - -{"jb", 1, 0x72, _, Jump, { Disp, 0, 0} }, -{"jc", 1, 0x72, _, Jump, { Disp, 0, 0} }, -{"jnae", 1, 0x72, _, Jump, { Disp, 0, 0} }, - -{"jnb", 1, 0x73, _, Jump, { Disp, 0, 0} }, -{"jnc", 1, 0x73, _, Jump, { Disp, 0, 0} }, -{"jae", 1, 0x73, _, Jump, { Disp, 0, 0} }, - -{"je", 1, 0x74, _, Jump, { Disp, 0, 0} }, -{"jz", 1, 0x74, _, Jump, { Disp, 0, 0} }, - -{"jne", 1, 0x75, _, Jump, { Disp, 0, 0} }, -{"jnz", 1, 0x75, _, Jump, { Disp, 0, 0} }, - -{"jbe", 1, 0x76, _, Jump, { Disp, 0, 0} }, -{"jna", 1, 0x76, _, Jump, { Disp, 0, 0} }, - -{"jnbe", 1, 0x77, _, Jump, { Disp, 0, 0} }, -{"ja", 1, 0x77, _, Jump, { Disp, 0, 0} }, - -{"js", 1, 0x78, _, Jump, { Disp, 0, 0} }, - -{"jns", 1, 0x79, _, Jump, { Disp, 0, 0} }, - -{"jp", 1, 0x7a, _, Jump, { Disp, 0, 0} }, -{"jpe", 1, 0x7a, _, Jump, { Disp, 0, 0} }, - -{"jnp", 1, 0x7b, _, Jump, { Disp, 0, 0} }, -{"jpo", 1, 0x7b, _, Jump, { Disp, 0, 0} }, - -{"jl", 1, 0x7c, _, Jump, { Disp, 0, 0} }, -{"jnge", 1, 0x7c, _, Jump, { Disp, 0, 0} }, - -{"jnl", 1, 0x7d, _, Jump, { Disp, 0, 0} }, -{"jge", 1, 0x7d, _, Jump, { Disp, 0, 0} }, - -{"jle", 1, 0x7e, _, Jump, { Disp, 0, 0} }, -{"jng", 1, 0x7e, _, Jump, { Disp, 0, 0} }, - -{"jnle", 1, 0x7f, _, Jump, { Disp, 0, 0} }, -{"jg", 1, 0x7f, _, Jump, { Disp, 0, 0} }, - -#define IS_JUMP_ON_CX_ZERO(o) \ -  (o == 0xe3) - -/* jcxz vs. jecxz is chosen on the basis of the address size prefix.  */ -{"jcxz", 1, 0xe3, _, JumpByte|Data16, { Disp, 0, 0} }, -{"jecxz", 1, 0xe3, _, JumpByte|Data32, { Disp, 0, 0} }, - -#define IS_LOOP_ECX_TIMES(o) \ -  (o == 0xe2 || o == 0xe1 || o == 0xe0) - -{"loop", 1, 0xe2, _, JumpByte, { Disp, 0, 0} }, - -{"loopz", 1, 0xe1, _, JumpByte, { Disp, 0, 0} }, -{"loope", 1, 0xe1, _, JumpByte, { Disp, 0, 0} }, - -{"loopnz", 1, 0xe0, _, JumpByte, { Disp, 0, 0} }, -{"loopne", 1, 0xe0, _, JumpByte, { Disp, 0, 0} }, - -/* set byte on flag instructions */ -{"seto", 1, 0x0f90, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setno", 1, 0x0f91, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setb", 1, 0x0f92, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setc", 1, 0x0f92, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setnae", 1, 0x0f92, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setnb", 1, 0x0f93, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setnc", 1, 0x0f93, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setae", 1, 0x0f93, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"sete", 1, 0x0f94, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setz", 1, 0x0f94, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setne", 1, 0x0f95, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setnz", 1, 0x0f95, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setbe", 1, 0x0f96, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setna", 1, 0x0f96, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setnbe", 1, 0x0f97, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"seta", 1, 0x0f97, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"sets", 1, 0x0f98, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setns", 1, 0x0f99, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setp", 1, 0x0f9a, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setpe", 1, 0x0f9a, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setnp", 1, 0x0f9b, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setpo", 1, 0x0f9b, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setl", 1, 0x0f9c, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setnge", 1, 0x0f9c, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setnl", 1, 0x0f9d, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setge", 1, 0x0f9d, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setle", 1, 0x0f9e, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setng", 1, 0x0f9e, 0, Modrm, { Reg8|Mem, 0, 0} }, - -{"setnle", 1, 0x0f9f, 0, Modrm, { Reg8|Mem, 0, 0} }, -{"setg", 1, 0x0f9f, 0, Modrm, { Reg8|Mem, 0, 0} }, - -#define IS_STRING_INSTRUCTION(o) \ -  ((o) == 0xa6 || (o) == 0x6c || (o) == 0x6e || (o) == 0x6e || \ -   (o) == 0xac || (o) == 0xa4 || (o) == 0xae || (o) == 0xaa || \ -   (o) == 0xd7) - -/* string manipulation */ -{"cmps", 0, 0xa6, _, W|NoModrm, { 0, 0, 0} }, -{"scmp", 0, 0xa6, _, W|NoModrm, { 0, 0, 0} }, -{"ins", 0, 0x6c, _, W|NoModrm, { 0, 0, 0} }, -{"outs", 0, 0x6e, _, W|NoModrm, { 0, 0, 0} }, -{"lods", 0, 0xac, _, W|NoModrm, { 0, 0, 0} }, -{"slod", 0, 0xac, _, W|NoModrm, { 0, 0, 0} }, -{"movs", 0, 0xa4, _, W|NoModrm, { 0, 0, 0} }, -{"smov", 0, 0xa4, _, W|NoModrm, { 0, 0, 0} }, -{"scas", 0, 0xae, _, W|NoModrm, { 0, 0, 0} }, -{"ssca", 0, 0xae, _, W|NoModrm, { 0, 0, 0} }, -{"stos", 0, 0xaa, _, W|NoModrm, { 0, 0, 0} }, -{"ssto", 0, 0xaa, _, W|NoModrm, { 0, 0, 0} }, -{"xlat", 0, 0xd7, _, NoModrm, { 0, 0, 0} }, - -/* bit manipulation */ -{"bsf", 2, 0x0fbc, _, Modrm|ReverseRegRegmem, { Reg|Mem, Reg, 0} }, -{"bsr", 2, 0x0fbd, _, Modrm|ReverseRegRegmem, { Reg|Mem, Reg, 0} }, -{"bt", 2, 0x0fa3, _, Modrm, { Reg, Reg|Mem, 0} }, -{"bt", 2, 0x0fba, 4, Modrm, { Imm8, Reg|Mem, 0} }, -{"btc", 2, 0x0fbb, _, Modrm, { Reg, Reg|Mem, 0} }, -{"btc", 2, 0x0fba, 7, Modrm, { Imm8, Reg|Mem, 0} }, -{"btr", 2, 0x0fb3, _, Modrm, { Reg, Reg|Mem, 0} }, -{"btr", 2, 0x0fba, 6, Modrm, { Imm8, Reg|Mem, 0} }, -{"bts", 2, 0x0fab, _, Modrm, { Reg, Reg|Mem, 0} }, -{"bts", 2, 0x0fba, 5, Modrm, { Imm8, Reg|Mem, 0} }, - -/* interrupts & op. sys insns */ -/* See gas/config/tc-i386.c for conversion of 'int $3' into the special -   int 3 insn. */ -#define INT_OPCODE 0xcd -#define INT3_OPCODE 0xcc -{"int", 1, 0xcd, _, NoModrm, { Imm8, 0, 0} }, -{"int3", 0, 0xcc, _, NoModrm, { 0, 0, 0} }, -{"into", 0, 0xce, _, NoModrm, { 0, 0, 0} }, -{"iret", 0, 0xcf, _, NoModrm|Data32, { 0, 0, 0} }, -{"iretw", 0, 0xcf, _, NoModrm|Data16, { 0, 0, 0} }, -/* i386sl, i486sl, later 486, and Pentium */ -{"rsm", 0, 0x0faa, _, NoModrm,{ 0, 0, 0} }, - -{"boundl", 2, 0x62, _, Modrm|Data32, { Reg32, Mem, 0} }, -{"boundw", 2, 0x62, _, Modrm|Data16, { Reg16, Mem, 0} }, - -{"hlt", 0, 0xf4, _, NoModrm, { 0, 0, 0} }, -{"wait", 0, 0x9b, _, NoModrm, { 0, 0, 0} }, -/* nop is actually 'xchgl %eax, %eax' */ -{"nop", 0, 0x90, _, NoModrm, { 0, 0, 0} }, - -/* protection control */ -{"arpl", 2, 0x63, _, Modrm, { Reg16, Reg16|Mem, 0} }, -{"lar", 2, 0x0f02, _, Modrm|ReverseRegRegmem, { WordReg|Mem, WordReg, 0} }, -{"lgdt", 1, 0x0f01, 2, Modrm, { Mem, 0, 0} }, -{"lidt", 1, 0x0f01, 3, Modrm, { Mem, 0, 0} }, -{"lldt", 1, 0x0f00, 2, Modrm, { WordReg|Mem, 0, 0} }, -{"lmsw", 1, 0x0f01, 6, Modrm, { WordReg|Mem, 0, 0} }, -{"lsl", 2, 0x0f03, _, Modrm|ReverseRegRegmem, { WordReg|Mem, WordReg, 0} }, -{"ltr", 1, 0x0f00, 3, Modrm, { WordReg|Mem, 0, 0} }, - -{"sgdt", 1, 0x0f01, 0, Modrm, { Mem, 0, 0} }, -{"sidt", 1, 0x0f01, 1, Modrm, { Mem, 0, 0} }, -{"sldt", 1, 0x0f00, 0, Modrm, { WordReg|Mem, 0, 0} }, -{"smsw", 1, 0x0f01, 4, Modrm, { WordReg|Mem, 0, 0} }, -{"str", 1, 0x0f00, 1, Modrm, { Reg16|Mem, 0, 0} }, - -{"verr", 1, 0x0f00, 4, Modrm, { WordReg|Mem, 0, 0} }, -{"verw", 1, 0x0f00, 5, Modrm, { WordReg|Mem, 0, 0} }, - -/* floating point instructions */ - -/* load */ -{"fld", 1, 0xd9c0, _, ShortForm, { FloatReg, 0, 0} }, /* register */ -{"flds", 1, 0xd9, 0, Modrm, { Mem, 0, 0} },		/* %st0 <-- mem float */ -{"fldl", 1, 0xdd, 0, Modrm, { Mem, 0, 0} },		/* %st0 <-- mem double */ -{"fldl", 1, 0xd9c0, _, ShortForm, { FloatReg, 0, 0} }, /* register */ -{"fild", 1, 0xdf, 0, Modrm, { Mem, 0, 0} },		/* %st0 <-- mem word (16) */ -{"fildl", 1, 0xdb, 0, Modrm, { Mem, 0, 0} },	/* %st0 <-- mem dword (32) */ -{"fildq",1, 0xdf, 5, Modrm, { Mem, 0, 0} },		/* %st0 <-- mem qword (64) */ -{"fildll",1, 0xdf, 5, Modrm, { Mem, 0, 0} },	/* %st0 <-- mem qword (64) */ -{"fldt", 1, 0xdb, 5, Modrm, { Mem, 0, 0} },		/* %st0 <-- mem efloat */ -{"fbld", 1, 0xdf, 4, Modrm, { Mem, 0, 0} },		/* %st0 <-- mem bcd */ - -/* store (no pop) */ -{"fst", 1, 0xddd0, _, ShortForm, { FloatReg, 0, 0} }, /* register */ -{"fsts", 1, 0xd9, 2, Modrm, { Mem, 0, 0} },		/* %st0 --> mem float */ -{"fstl", 1, 0xdd, 2, Modrm, { Mem, 0, 0} },		/* %st0 --> mem double */ -{"fstl", 1, 0xddd0, _, ShortForm, { FloatReg, 0, 0} }, /* register */ -{"fist", 1, 0xdf, 2, Modrm, { Mem, 0, 0} },		/* %st0 --> mem word (16) */ -{"fistl", 1, 0xdb, 2, Modrm, { Mem, 0, 0} },	/* %st0 --> mem dword (32) */ - -/* store (with pop) */ -{"fstp", 1, 0xddd8, _, ShortForm, { FloatReg, 0, 0} }, /* register */ -{"fstps", 1, 0xd9, 3, Modrm, { Mem, 0, 0} },	/* %st0 --> mem float */ -{"fstpl", 1, 0xdd, 3, Modrm, { Mem, 0, 0} },	/* %st0 --> mem double */ -{"fstpl", 1, 0xddd8, _, ShortForm, { FloatReg, 0, 0} }, /* register */ -{"fistp", 1, 0xdf, 3, Modrm, { Mem, 0, 0} },	/* %st0 --> mem word (16) */ -{"fistpl",1, 0xdb, 3, Modrm, { Mem, 0, 0} },	/* %st0 --> mem dword (32) */ -{"fistpq",1, 0xdf, 7, Modrm, { Mem, 0, 0} },	/* %st0 --> mem qword (64) */ -{"fistpll",1,0xdf, 7, Modrm, { Mem, 0, 0} },	/* %st0 --> mem qword (64) */ -{"fstpt", 1, 0xdb, 7, Modrm, { Mem, 0, 0} },	/* %st0 --> mem efloat */ -{"fbstp", 1, 0xdf, 6, Modrm, { Mem, 0, 0} },	/* %st0 --> mem bcd */ - -/* exchange %st<n> with %st0 */ -{"fxch", 1, 0xd9c8, _, ShortForm, { FloatReg, 0, 0} }, -{"fxch", 0, 0xd9c9, _, NoModrm, { 0, 0, 0} }, /* alias for fxch %st, %st(1) */ - -/* comparison (without pop) */ -{"fcom", 1, 0xd8d0, _, ShortForm, { FloatReg, 0, 0} }, -{"fcoms", 1, 0xd8, 2, Modrm, { Mem, 0, 0} },	/* compare %st0, mem float  */ -{"ficoml", 1, 0xda, 2, Modrm, { Mem, 0, 0} },	/* compare %st0, mem dword  */ -{"fcoml", 1, 0xdc, 2, Modrm, { Mem, 0, 0} },	/* compare %st0, mem double  */ -{"fcoml", 1, 0xd8d0, _, ShortForm, { FloatReg, 0, 0} }, -{"ficoms", 1, 0xde, 2, Modrm, { Mem, 0, 0} },	/* compare %st0, mem word */ - -/* comparison (with pop) */ -{"fcomp", 1, 0xd8d8, _, ShortForm, { FloatReg, 0, 0} }, -{"fcomp", 0, 0xd8d9, _, NoModrm, {0, 0, 0} },   /* fcomp %st, %st(1) */ -{"fcomps", 1, 0xd8, 3, Modrm, { Mem, 0, 0} },	/* compare %st0, mem float  */ -{"ficompl", 1, 0xda, 3, Modrm, { Mem, 0, 0} },	/* compare %st0, mem dword  */ -{"fcompl", 1, 0xdc, 3, Modrm, { Mem, 0, 0} },	/* compare %st0, mem double  */ -{"fcompl", 1, 0xd8d8, _, ShortForm, { FloatReg, 0, 0} }, -{"ficomps", 1, 0xde, 3, Modrm, { Mem, 0, 0} },	/* compare %st0, mem word */ -{"fcompp", 0, 0xded9, _, NoModrm, { 0, 0, 0} },	/* compare %st0, %st1 & pop 2 */ - -/* unordered comparison (with pop) */ -{"fucom", 1, 0xdde0, _, ShortForm, { FloatReg, 0, 0} }, -{"fucomp", 1, 0xdde8, _, ShortForm, { FloatReg, 0, 0} }, -{"fucompp", 0, 0xdae9, _, NoModrm, { 0, 0, 0} }, /* ucompare %st0, %st1 & pop twice */ - -{"ftst", 0, 0xd9e4, _, NoModrm, { 0, 0, 0} },	/* test %st0 */ -{"fxam", 0, 0xd9e5, _, NoModrm, { 0, 0, 0} },	/* examine %st0 */ - -/* load constants into %st0 */ -{"fld1", 0, 0xd9e8, _, NoModrm, { 0, 0, 0} },	/* %st0 <-- 1.0 */ -{"fldl2t", 0, 0xd9e9, _, NoModrm, { 0, 0, 0} },	/* %st0 <-- log2(10) */ -{"fldl2e", 0, 0xd9ea, _, NoModrm, { 0, 0, 0} },	/* %st0 <-- log2(e) */ -{"fldpi", 0, 0xd9eb, _, NoModrm, { 0, 0, 0} },	/* %st0 <-- pi */ -{"fldlg2", 0, 0xd9ec, _, NoModrm, { 0, 0, 0} },	/* %st0 <-- log10(2) */ -{"fldln2", 0, 0xd9ed, _, NoModrm, { 0, 0, 0} },	/* %st0 <-- ln(2) */ -{"fldz", 0, 0xd9ee, _, NoModrm, { 0, 0, 0} },	/* %st0 <-- 0.0 */ - -/* arithmetic */ - -/* add */ -{"fadd", 1, 0xd8c0, _, ShortForm, { FloatReg, 0, 0} }, -{"fadd", 2, 0xd8c0, _, ShortForm|FloatD, { FloatReg, FloatAcc, 0} }, -{"fadd", 0, 0xdcc1, _, NoModrm, { 0, 0, 0} }, /* alias for fadd %st, %st(1) */ -{"faddp", 1, 0xdec0, _, ShortForm, { FloatReg, 0, 0} }, -{"faddp", 2, 0xdec0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"faddp", 2, 0xdec0, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"faddp", 0, 0xdec1, _, NoModrm, { 0, 0, 0} }, /* alias for faddp %st, %st(1) */ -{"fadds", 1, 0xd8, 0, Modrm, { Mem, 0, 0} }, -{"fiaddl", 1, 0xda, 0, Modrm, { Mem, 0, 0} }, -{"faddl", 1, 0xdc, 0, Modrm, { Mem, 0, 0} }, -{"fiadds", 1, 0xde, 0, Modrm, { Mem, 0, 0} }, - -/* sub */ -/* Note:  intel has decided that certain of these operations are reversed -   in assembler syntax. */ -{"fsub", 1, 0xd8e0, _, ShortForm, { FloatReg, 0, 0} }, -{"fsub", 2, 0xd8e0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -#ifdef NON_BROKEN_OPCODES -{"fsub", 2, 0xdce8, _, ShortForm, { FloatAcc, FloatReg, 0} }, -#else -{"fsub", 2, 0xdce0, _, ShortForm, { FloatAcc, FloatReg, 0} }, -#endif -{"fsub", 0, 0xdce1, _, NoModrm, { 0, 0, 0} }, -{"fsubp", 1, 0xdee8, _, ShortForm, { FloatReg, 0, 0} }, -{"fsubp", 2, 0xdee8, _, ShortForm, { FloatReg, FloatAcc, 0} }, -#ifdef NON_BROKEN_OPCODES -{"fsubp", 2, 0xdee8, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"fsubp", 0, 0xdee9, _, NoModrm, { 0, 0, 0} }, -#else -{"fsubp", 2, 0xdee0, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"fsubp", 0, 0xdee1, _, NoModrm, { 0, 0, 0} }, -#endif -{"fsubs", 1, 0xd8, 4, Modrm, { Mem, 0, 0} }, -{"fisubl", 1, 0xda, 4, Modrm, { Mem, 0, 0} }, -{"fsubl", 1, 0xdc, 4, Modrm, { Mem, 0, 0} }, -{"fisubs", 1, 0xde, 4, Modrm, { Mem, 0, 0} }, - -/* sub reverse */ -{"fsubr", 1, 0xd8e8, _, ShortForm, { FloatReg, 0, 0} }, -{"fsubr", 2, 0xd8e8, _, ShortForm, { FloatReg, FloatAcc, 0} }, -#ifdef NON_BROKEN_OPCODES -{"fsubr", 2, 0xdce0, _, ShortForm, { FloatAcc, FloatReg, 0} }, -#else -{"fsubr", 2, 0xdce8, _, ShortForm, { FloatAcc, FloatReg, 0} }, -#endif -{"fsubr", 0, 0xdce9, _, NoModrm, { 0, 0, 0} }, -{"fsubrp", 1, 0xdee0, _, ShortForm, { FloatReg, 0, 0} }, -{"fsubrp", 2, 0xdee0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -#ifdef NON_BROKEN_OPCODES -{"fsubrp", 2, 0xdee0, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"fsubrp", 0, 0xdee1, _, NoModrm, { 0, 0, 0} }, -#else -{"fsubrp", 2, 0xdee8, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"fsubrp", 0, 0xdee9, _, NoModrm, { 0, 0, 0} }, -#endif -{"fsubrs", 1, 0xd8, 5, Modrm, { Mem, 0, 0} }, -{"fisubrl", 1, 0xda, 5, Modrm, { Mem, 0, 0} }, -{"fsubrl", 1, 0xdc, 5, Modrm, { Mem, 0, 0} }, -{"fisubrs", 1, 0xde, 5, Modrm, { Mem, 0, 0} }, - -/* mul */ -{"fmul", 1, 0xd8c8, _, ShortForm, { FloatReg, 0, 0} }, -{"fmul", 2, 0xd8c8, _, ShortForm|FloatD, { FloatReg, FloatAcc, 0} }, -{"fmul", 0, 0xdcc9, _, NoModrm, { 0, 0, 0} }, -{"fmulp", 1, 0xdec8, _, ShortForm, { FloatReg, 0, 0} }, -{"fmulp", 2, 0xdec8, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fmulp", 2, 0xdec8, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"fmulp", 0, 0xdec9, _, NoModrm, { 0, 0, 0} }, -{"fmuls", 1, 0xd8, 1, Modrm, { Mem, 0, 0} }, -{"fimull", 1, 0xda, 1, Modrm, { Mem, 0, 0} }, -{"fmull", 1, 0xdc, 1, Modrm, { Mem, 0, 0} }, -{"fimuls", 1, 0xde, 1, Modrm, { Mem, 0, 0} }, - -/* div */ -/* Note:  intel has decided that certain of these operations are reversed -   in assembler syntax. */ -{"fdiv", 1, 0xd8f0, _, ShortForm, { FloatReg, 0, 0} }, -{"fdiv", 2, 0xd8f0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -#ifdef NON_BROKEN_OPCODES -{"fdiv", 2, 0xdcf8, _, ShortForm, { FloatAcc, FloatReg, 0} }, -#else -{"fdiv", 2, 0xdcf0, _, ShortForm, { FloatAcc, FloatReg, 0} }, -#endif -{"fdiv", 0, 0xdcf1, _, NoModrm, { 0, 0, 0} }, -{"fdivp", 1, 0xdef8, _, ShortForm, { FloatReg, 0, 0} }, -{"fdivp", 2, 0xdef8, _, ShortForm, { FloatReg, FloatAcc, 0} }, -#ifdef NON_BROKEN_OPCODES -{"fdivp", 2, 0xdef8, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"fdivp", 0, 0xdef9, _, NoModrm, { 0, 0, 0} }, -#else -{"fdivp", 2, 0xdef0, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"fdivp", 0, 0xdef1, _, NoModrm, { 0, 0, 0} }, -#endif -{"fdivs", 1, 0xd8, 6, Modrm, { Mem, 0, 0} }, -{"fidivl", 1, 0xda, 6, Modrm, { Mem, 0, 0} }, -{"fdivl", 1, 0xdc, 6, Modrm, { Mem, 0, 0} }, -{"fidivs", 1, 0xde, 6, Modrm, { Mem, 0, 0} }, - -/* div reverse */ -{"fdivr", 1, 0xd8f8, _, ShortForm, { FloatReg, 0, 0} }, -{"fdivr", 2, 0xd8f8, _, ShortForm, { FloatReg, FloatAcc, 0} }, -#ifdef NON_BROKEN_OPCODES -{"fdivr", 2, 0xdcf0, _, ShortForm, { FloatAcc, FloatReg, 0} }, -#else -{"fdivr", 2, 0xdcf8, _, ShortForm, { FloatAcc, FloatReg, 0} }, -#endif -{"fdivr", 0, 0xdcf9, _, NoModrm, { 0, 0, 0} }, -{"fdivrp", 1, 0xdef0, _, ShortForm, { FloatReg, 0, 0} }, -{"fdivrp", 2, 0xdef0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -#ifdef NON_BROKEN_OPCODES -{"fdivrp", 2, 0xdef0, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"fdivrp", 0, 0xdef1, _, NoModrm, { 0, 0, 0} }, -#else -{"fdivrp", 2, 0xdef8, _, ShortForm, { FloatAcc, FloatReg, 0} }, -{"fdivrp", 0, 0xdef9, _, NoModrm, { 0, 0, 0} }, -#endif -{"fdivrs", 1, 0xd8, 7, Modrm, { Mem, 0, 0} }, -{"fidivrl", 1, 0xda, 7, Modrm, { Mem, 0, 0} }, -{"fdivrl", 1, 0xdc, 7, Modrm, { Mem, 0, 0} }, -{"fidivrs", 1, 0xde, 7, Modrm, { Mem, 0, 0} }, - -{"f2xm1", 0,   0xd9f0, _, NoModrm, { 0, 0, 0} }, -{"fyl2x", 0,   0xd9f1, _, NoModrm, { 0, 0, 0} }, -{"fptan", 0,   0xd9f2, _, NoModrm, { 0, 0, 0} }, -{"fpatan", 0,  0xd9f3, _, NoModrm, { 0, 0, 0} }, -{"fxtract", 0, 0xd9f4, _, NoModrm, { 0, 0, 0} }, -{"fprem1", 0,  0xd9f5, _, NoModrm, { 0, 0, 0} }, -{"fdecstp", 0,  0xd9f6, _, NoModrm, { 0, 0, 0} }, -{"fincstp", 0,  0xd9f7, _, NoModrm, { 0, 0, 0} }, -{"fprem", 0,   0xd9f8, _, NoModrm, { 0, 0, 0} }, -{"fyl2xp1", 0, 0xd9f9, _, NoModrm, { 0, 0, 0} }, -{"fsqrt", 0,   0xd9fa, _, NoModrm, { 0, 0, 0} }, -{"fsincos", 0, 0xd9fb, _, NoModrm, { 0, 0, 0} }, -{"frndint", 0, 0xd9fc, _, NoModrm, { 0, 0, 0} }, -{"fscale", 0,  0xd9fd, _, NoModrm, { 0, 0, 0} }, -{"fsin", 0,    0xd9fe, _, NoModrm, { 0, 0, 0} }, -{"fcos", 0,    0xd9ff, _, NoModrm, { 0, 0, 0} }, - -{"fchs", 0, 0xd9e0, _, NoModrm, { 0, 0, 0} }, -{"fabs", 0, 0xd9e1, _, NoModrm, { 0, 0, 0} }, - -/* processor control */ -{"fninit", 0, 0xdbe3, _, NoModrm,	{ 0, 0, 0} }, -{"finit",  0, 0xdbe3, _, FWait|NoModrm, { 0, 0, 0} }, -{"fldcw",  1,	0xd9, 5, Modrm,		{ Mem, 0, 0} }, -{"fnstcw", 1,	0xd9, 7, Modrm,		{ Mem, 0, 0} }, -{"fstcw",  1,	0xd9, 7, FWait|Modrm,	{ Mem, 0, 0} }, -{"fnstsw", 1, 0xdfe0, _, NoModrm,	{ Acc, 0, 0} }, -{"fnstsw", 1,	0xdd, 7, Modrm,		{ Mem, 0, 0} }, -{"fnstsw", 0, 0xdfe0, _, NoModrm,	{ 0, 0, 0} }, -{"fstsw",  1, 0xdfe0, _, FWait|NoModrm,	{ Acc, 0, 0} }, -{"fstsw",  1,	0xdd, 7, FWait|Modrm,	{ Mem, 0, 0} }, -{"fstsw",  0, 0xdfe0, _, FWait|NoModrm,	{ 0, 0, 0} }, -{"fnclex", 0, 0xdbe2, _, NoModrm,	{ 0, 0, 0} }, -{"fclex",  0, 0xdbe2, _, FWait|NoModrm,	{ 0, 0, 0} }, -{"fnstenv",1,	0xd9, 6, Modrm,		{ Mem, 0, 0} }, -{"fstenv", 1,	0xd9, 6, FWait|Modrm,	{ Mem, 0, 0} }, -{"fldenv", 1,	0xd9, 4, Modrm,		{ Mem, 0, 0} }, -{"fnsave", 1,	0xdd, 6, Modrm,		{ Mem, 0, 0} }, -{"fsave",  1,	0xdd, 6, FWait|Modrm,	{ Mem, 0, 0} }, -{"frstor", 1,	0xdd, 4, Modrm,		{ Mem, 0, 0} }, -/* Short forms of fldenv, fstenv use data size prefix. (At least I -   think so.  The PentPro prog ref I have says address size in one -   place, operand size elsewhere).  FIXME: Are these the right names?  */ -{"fnstenvs",1,	0xd9, 6, Modrm|Data16,	{ Mem, 0, 0} }, -{"fstenvs", 1,	0xd9, 6, FWait|Modrm|Data16, { Mem, 0, 0} }, -{"fldenvs", 1,	0xd9, 4, Modrm|Data16,	{ Mem, 0, 0} }, - -{"ffree",  1, 0xddc0, _, ShortForm,	{ FloatReg, 0, 0} }, -/* P6:free st(i), pop st */ -{"ffreep", 1, 0xdfc0, _, ShortForm,	{ FloatReg, 0, 0} }, -{"fnop",   0, 0xd9d0, _, NoModrm,	{ 0, 0, 0} }, -#define FWAIT_OPCODE 0x9b -{"fwait",  0,	0x9b, _, NoModrm,	{ 0, 0, 0} }, - -/* -  opcode prefixes; we allow them as seperate insns too -  (see prefix table below) -*/ -{"aword", 0, 0x67, _, NoModrm, { 0, 0, 0} }, -{"addr16", 0, 0x67, _, NoModrm, { 0, 0, 0} }, -{"word", 0, 0x66, _, NoModrm, { 0, 0, 0} }, -{"data16", 0, 0x66, _, NoModrm, { 0, 0, 0} }, -{"lock", 0, 0xf0, _, NoModrm, { 0, 0, 0} }, -{"cs", 0, 0x2e, _, NoModrm, { 0, 0, 0} }, -{"ds", 0, 0x3e, _, NoModrm, { 0, 0, 0} }, -{"es", 0, 0x26, _, NoModrm, { 0, 0, 0} }, -{"fs", 0, 0x64, _, NoModrm, { 0, 0, 0} }, -{"gs", 0, 0x65, _, NoModrm, { 0, 0, 0} }, -{"ss", 0, 0x36, _, NoModrm, { 0, 0, 0} }, -{"rep", 0, 0xf3, _, NoModrm, { 0, 0, 0} }, -{"repe", 0, 0xf3, _, NoModrm, { 0, 0, 0} }, -{"repz", 0, 0xf3, _, NoModrm, { 0, 0, 0} }, -{"repne", 0, 0xf2, _, NoModrm, { 0, 0, 0} }, -{"repnz", 0, 0xf2, _, NoModrm, { 0, 0, 0} }, - -/* 486 extensions */ - -{"bswap", 1, 0x0fc8, _, ShortForm, { Reg32,0,0 } }, -{"xadd", 2, 0x0fc0, _, W|Modrm, { Reg, Reg|Mem, 0 } }, -{"cmpxchg", 2, 0x0fb0, _, W|Modrm, { Reg, Reg|Mem, 0 } }, -{"invd", 0, 0x0f08, _, NoModrm, { 0, 0, 0} }, -{"wbinvd", 0, 0x0f09, _, NoModrm, { 0, 0, 0} }, -{"invlpg", 1, 0x0f01, 7, Modrm, { Mem, 0, 0} }, - -/* 586 and late 486 extensions */ -{"cpuid", 0, 0x0fa2, _, NoModrm, { 0, 0, 0} }, - -/* Pentium extensions */ -{"wrmsr", 0, 0x0f30, _, NoModrm, { 0, 0, 0} }, -{"rdtsc", 0, 0x0f31, _, NoModrm, { 0, 0, 0} }, -{"rdmsr", 0, 0x0f32, _, NoModrm, { 0, 0, 0} }, -{"cmpxchg8b", 1, 0x0fc7, 1, Modrm, { Mem, 0, 0} }, - -/* Pentium Pro extensions */ -{"rdpmc", 0, 0x0f33, _, NoModrm, { 0, 0, 0} }, - -{"ud2", 0, 0x0f0b, _, NoModrm, {0, 0, 0} }, /* official undefined instr. */ - -{"cmovo",  2, 0x0f40, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovno", 2, 0x0f41, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovb",  2, 0x0f42, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovae", 2, 0x0f43, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmove",  2, 0x0f44, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovne", 2, 0x0f45, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovbe", 2, 0x0f46, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmova",  2, 0x0f47, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovs",  2, 0x0f48, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovns", 2, 0x0f49, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovp",  2, 0x0f4a, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovnp", 2, 0x0f4b, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovl",  2, 0x0f4c, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovge", 2, 0x0f4d, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovle", 2, 0x0f4e, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, -{"cmovg",  2, 0x0f4f, _, Modrm|ReverseRegRegmem, { WordReg|WordMem, WordReg, 0} }, - -{"fcmovb", 2, 0xdac0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fcmove", 2, 0xdac8, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fcmovbe",2, 0xdad0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fcmovu", 2, 0xdad8, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fcmovnb", 2, 0xdbc0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fcmovne", 2, 0xdbc8, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fcmovnbe",2, 0xdbd0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fcmovnu", 2, 0xdbd8, _, ShortForm, { FloatReg, FloatAcc, 0} }, - -{"fcomi",  2, 0xdbf0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fucomi", 2, 0xdbe8, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fcomip", 2, 0xdff0, _, ShortForm, { FloatReg, FloatAcc, 0} }, -{"fucomip",2, 0xdfe8, _, ShortForm, { FloatReg, FloatAcc, 0} }, - -/* MMX instructions.  */ - -{"emms",      0, 0x0f77, _, NoModrm, { 0, 0, 0 } }, -{"movd",      2, 0x0f6e, _, Modrm, { Reg32|WordMem, RegMMX, 0 } }, -{"movd",      2, 0x0f7e, _, Modrm, { RegMMX, Reg32|WordMem, 0 } }, -{"movq",      2, 0x0f6f, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"movq",      2, 0x0f7f, _, Modrm, { RegMMX, RegMMX|WordMem, 0 } }, -{"packssdw",  2, 0x0f6b, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"packsswb",  2, 0x0f63, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"packuswb",  2, 0x0f67, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"paddb",     2, 0x0ffc, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"paddw",     2, 0x0ffd, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"paddd",     2, 0x0ffe, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"paddsb",    2, 0x0fec, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"paddsw",    2, 0x0fed, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"paddusb",   2, 0x0fdc, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"paddusw",   2, 0x0fdd, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pand",      2, 0x0fdb, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pandn",     2, 0x0fdf, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pcmpeqb",   2, 0x0f74, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pcmpeqw",   2, 0x0f75, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pcmpeqd",   2, 0x0f76, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pcmpgtb",   2, 0x0f64, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pcmpgtw",   2, 0x0f65, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pcmpgtd",   2, 0x0f66, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pmaddwd",   2, 0x0ff5, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pmulhw",    2, 0x0fe5, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pmullw",    2, 0x0fd5, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"por",       2, 0x0feb, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psllw",     2, 0x0ff1, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psllw",     2, 0x0f71, 6, Modrm, { Imm8, RegMMX, 0 } }, -{"pslld",     2, 0x0ff2, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pslld",     2, 0x0f72, 6, Modrm, { Imm8, RegMMX, 0 } }, -{"psllq",     2, 0x0ff3, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psllq",     2, 0x0f73, 6, Modrm, { Imm8, RegMMX, 0 } }, -{"psraw",     2, 0x0fe1, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psraw",     2, 0x0f71, 4, Modrm, { Imm8, RegMMX, 0 } }, -{"psrad",     2, 0x0fe2, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psrad",     2, 0x0f72, 4, Modrm, { Imm8, RegMMX, 0 } }, -{"psrlw",     2, 0x0fd1, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psrlw",     2, 0x0f71, 2, Modrm, { Imm8, RegMMX, 0 } }, -{"psrld",     2, 0x0fd2, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psrld",     2, 0x0f72, 2, Modrm, { Imm8, RegMMX, 0 } }, -{"psrlq",     2, 0x0fd3, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psrlq",     2, 0x0f73, 2, Modrm, { Imm8, RegMMX, 0 } }, -{"psubb",     2, 0x0ff8, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psubw",     2, 0x0ff9, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psubd",     2, 0x0ffa, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psubsb",    2, 0x0fe8, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psubsw",    2, 0x0fe9, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psubusb",   2, 0x0fd8, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"psubusw",   2, 0x0fd9, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"punpckhbw", 2, 0x0f68, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"punpckhwd", 2, 0x0f69, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"punpckhdq", 2, 0x0f6a, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"punpcklbw", 2, 0x0f60, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"punpcklwd", 2, 0x0f61, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"punpckldq", 2, 0x0f62, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, -{"pxor",      2, 0x0fef, _, Modrm, { RegMMX|WordMem, RegMMX, 0 } }, - -{"", 0, 0, 0, 0, { 0, 0, 0} }	/* sentinel */ -}; -#undef _ - -static const template *const i386_optab_end -  = i386_optab + sizeof (i386_optab)/sizeof(i386_optab[0]); - -/* 386 register table */ - -static const reg_entry i386_regtab[] = { -  /* 8 bit regs */ -  {"al", Reg8|Acc, 0}, {"cl", Reg8|ShiftCount, 1}, {"dl", Reg8, 2}, -  {"bl", Reg8, 3}, -  {"ah", Reg8, 4}, {"ch", Reg8, 5}, {"dh", Reg8, 6}, {"bh", Reg8, 7}, -  /* 16 bit regs */ -  {"ax", Reg16|Acc, 0}, {"cx", Reg16, 1}, {"dx", Reg16|InOutPortReg, 2}, {"bx", Reg16, 3}, -  {"sp", Reg16, 4}, {"bp", Reg16, 5}, {"si", Reg16, 6}, {"di", Reg16, 7}, -  /* 32 bit regs */ -  {"eax", Reg32|Acc, 0}, {"ecx", Reg32, 1}, {"edx", Reg32, 2}, {"ebx", Reg32, 3}, -  {"esp", Reg32, 4}, {"ebp", Reg32, 5}, {"esi", Reg32, 6}, {"edi", Reg32, 7}, -  /* segment registers */ -  {"es", SReg2, 0}, {"cs", SReg2, 1}, {"ss", SReg2, 2}, -  {"ds", SReg2, 3}, {"fs", SReg3, 4}, {"gs", SReg3, 5}, -  /* control registers */ -  {"cr0", Control, 0},   {"cr2", Control, 2},   {"cr3", Control, 3}, -  {"cr4", Control, 4}, -  /* debug registers */ -  {"db0", Debug, 0},   {"db1", Debug, 1},   {"db2", Debug, 2}, -  {"db3", Debug, 3},   {"db6", Debug, 6},   {"db7", Debug, 7}, -  {"dr0", Debug, 0},   {"dr1", Debug, 1},   {"dr2", Debug, 2}, -  {"dr3", Debug, 3},   {"dr6", Debug, 6},   {"dr7", Debug, 7}, -  /* test registers */ -  {"tr3", Test, 3}, {"tr4", Test, 4}, {"tr5", Test, 5}, -  {"tr6", Test, 6}, {"tr7", Test, 7}, -  /* float registers */ -  {"st(0)", FloatReg|FloatAcc, 0}, -  {"st", FloatReg|FloatAcc, 0}, -  {"st(1)", FloatReg, 1}, {"st(2)", FloatReg, 2}, -  {"st(3)", FloatReg, 3}, {"st(4)", FloatReg, 4}, {"st(5)", FloatReg, 5}, -  {"st(6)", FloatReg, 6}, {"st(7)", FloatReg, 7}, -  {"mm0", RegMMX, 0}, {"mm1", RegMMX, 1}, {"mm2", RegMMX, 2}, -  {"mm3", RegMMX, 3}, {"mm4", RegMMX, 4}, {"mm5", RegMMX, 5}, -  {"mm6", RegMMX, 6}, {"mm7", RegMMX, 7} -}; - -#define MAX_REG_NAME_SIZE 8	/* for parsing register names from input */ - -static const reg_entry *const i386_regtab_end -  = i386_regtab + sizeof(i386_regtab)/sizeof(i386_regtab[0]); - -/* segment stuff */ -static const seg_entry cs = { "cs", 0x2e }; -static const seg_entry ds = { "ds", 0x3e }; -static const seg_entry ss = { "ss", 0x36 }; -static const seg_entry es = { "es", 0x26 }; -static const seg_entry fs = { "fs", 0x64 }; -static const seg_entry gs = { "gs", 0x65 }; -static const seg_entry null = { "", 0x0 }; - -/* -  This table is used to store the default segment register implied by all -  possible memory addressing modes. -  It is indexed by the mode & modrm entries of the modrm byte as follows: -      index = (mode<<3) | modrm; -*/ -static const seg_entry *const one_byte_segment_defaults[] = { -  /* mode 0 */ -  &ds, &ds, &ds, &ds, &null, &ds, &ds, &ds, -  /* mode 1 */ -  &ds, &ds, &ds, &ds, &null, &ss, &ds, &ds, -  /* mode 2 */ -  &ds, &ds, &ds, &ds, &null, &ss, &ds, &ds, -  /* mode 3 --- not a memory reference; never referenced */ -}; - -static const seg_entry *const two_byte_segment_defaults[] = { -  /* mode 0 */ -  &ds, &ds, &ds, &ds, &ss, &ds, &ds, &ds, -  /* mode 1 */ -  &ds, &ds, &ds, &ds, &ss, &ss, &ds, &ds, -  /* mode 2 */ -  &ds, &ds, &ds, &ds, &ss, &ss, &ds, &ds, -  /* mode 3 --- not a memory reference; never referenced */ -}; - -static const prefix_entry i386_prefixtab[] = { -#define ADDR_PREFIX_OPCODE 0x67 -  { "addr16", 0x67 },		/* address size prefix ==> 16bit addressing -				 * (How is this useful?) */ -#define WORD_PREFIX_OPCODE 0x66 -  { "data16", 0x66 },		/* operand size prefix */ -  { "lock", 0xf0 },		/* bus lock prefix */ -  { "wait", 0x9b },		/* wait for coprocessor */ -  { "cs", 0x2e }, { "ds", 0x3e }, /* segment overrides ... */ -  { "es", 0x26 }, { "fs", 0x64 }, -  { "gs", 0x65 }, { "ss", 0x36 }, -/* REPE & REPNE used to detect rep/repne with a non-string instruction */ -#define REPNE 0xf2 -#define REPE  0xf3 -  { "rep", 0xf3 }, 		/* repeat string instructions */ -  { "repe", 0xf3 },  { "repz", 0xf3 }, -  { "repne", 0xf2 }, { "repnz", 0xf2 } -}; - -static const prefix_entry *const i386_prefixtab_end -  = i386_prefixtab + sizeof(i386_prefixtab)/sizeof(i386_prefixtab[0]); - -/* end of i386-opcode.h */ diff --git a/contrib/binutils/include/opcode/mips.h b/contrib/binutils/include/opcode/mips.h deleted file mode 100644 index ee5ee82d3cbf..000000000000 --- a/contrib/binutils/include/opcode/mips.h +++ /dev/null @@ -1,715 +0,0 @@ -/* mips.h.  Mips opcode list for GDB, the GNU debugger. -   Copyright 1993, 94, 95, 96, 1997 Free Software Foundation, Inc. -   Contributed by Ralph Campbell and OSF -   Commented and modified by Ian Lance Taylor, Cygnus Support - -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 -1, 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.  */ - -#ifndef _MIPS_H_ -#define _MIPS_H_ - -/* These are bit masks and shift counts to use to access the various -   fields of an instruction.  To retrieve the X field of an -   instruction, use the expression -	(i >> OP_SH_X) & OP_MASK_X -   To set the same field (to j), use -	i = (i &~ (OP_MASK_X << OP_SH_X)) | (j << OP_SH_X) - -   Make sure you use fields that are appropriate for the instruction, -   of course.   - -   The 'i' format uses OP, RS, RT and IMMEDIATE.   - -   The 'j' format uses OP and TARGET. - -   The 'r' format uses OP, RS, RT, RD, SHAMT and FUNCT. - -   The 'b' format uses OP, RS, RT and DELTA. - -   The floating point 'i' format uses OP, RS, RT and IMMEDIATE. - -   The floating point 'r' format uses OP, FMT, FT, FS, FD and FUNCT. - -   A breakpoint instruction uses OP, CODE and SPEC (10 bits of the -   breakpoint instruction are not defined; Kane says the breakpoint -   code field in BREAK is 20 bits; yet MIPS assemblers and debuggers -   only use ten bits). - -   The syscall instruction uses SYSCALL. - -   The general coprocessor instructions use COPZ.  */ - -#define OP_MASK_OP		0x3f -#define OP_SH_OP		26 -#define OP_MASK_RS		0x1f -#define OP_SH_RS		21 -#define OP_MASK_FR		0x1f -#define OP_SH_FR		21 -#define OP_MASK_FMT		0x1f -#define OP_SH_FMT		21 -#define OP_MASK_BCC		0x7 -#define OP_SH_BCC		18 -#define OP_MASK_CODE		0x3ff -#define OP_SH_CODE		16 -#define OP_MASK_RT		0x1f -#define OP_SH_RT		16 -#define OP_MASK_FT		0x1f -#define OP_SH_FT		16 -#define OP_MASK_CACHE		0x1f -#define OP_SH_CACHE		16 -#define OP_MASK_RD		0x1f -#define OP_SH_RD		11 -#define OP_MASK_FS		0x1f -#define OP_SH_FS		11 -#define OP_MASK_PREFX		0x1f -#define OP_SH_PREFX		11 -#define OP_MASK_CCC		0x7 -#define OP_SH_CCC		8 -#define OP_MASK_SYSCALL		0xfffff -#define OP_SH_SYSCALL		6 -#define OP_MASK_SHAMT		0x1f -#define OP_SH_SHAMT		6 -#define OP_MASK_FD		0x1f -#define OP_SH_FD		6 -#define OP_MASK_TARGET		0x3ffffff -#define OP_SH_TARGET		0 -#define OP_MASK_COPZ		0x1ffffff -#define OP_SH_COPZ		0 -#define OP_MASK_IMMEDIATE	0xffff -#define OP_SH_IMMEDIATE		0 -#define OP_MASK_DELTA		0xffff -#define OP_SH_DELTA		0 -#define OP_MASK_FUNCT		0x3f -#define OP_SH_FUNCT		0 -#define OP_MASK_SPEC		0x3f -#define OP_SH_SPEC		0 -#define OP_SH_LOCC              8       /* FP condition code */ -#define OP_SH_HICC              18      /* FP condition code */ -#define OP_MASK_CC              0x7 -#define OP_SH_COP1NORM          25      /* Normal COP1 encoding */ -#define OP_MASK_COP1NORM        0x1     /* a single bit */ -#define OP_SH_COP1SPEC          21      /* COP1 encodings */ -#define OP_MASK_COP1SPEC        0xf -#define OP_MASK_COP1SCLR        0x4 -#define OP_MASK_COP1CMP         0x3 -#define OP_SH_COP1CMP           4 -#define OP_SH_FORMAT            21      /* FP short format field */ -#define OP_MASK_FORMAT          0x7 -#define OP_SH_TRUE              16 -#define OP_MASK_TRUE            0x1 -#define OP_SH_GE                17 -#define OP_MASK_GE              0x01 -#define OP_SH_UNSIGNED          16 -#define OP_MASK_UNSIGNED        0x1 -#define OP_SH_HINT              16 -#define OP_MASK_HINT            0x1f -#define OP_SH_MMI               0       /* Multimedia (parallel) op */ -#define OP_MASK_MMI             0x3f  -#define OP_SH_MMISUB            6 -#define OP_MASK_MMISUB          0x1f -#define OP_MASK_PERFREG		0x1f	/* Performance monitoring */ -#define OP_SH_PERFREG		1 - -/* This structure holds information for a particular instruction.  */ - -struct mips_opcode -{ -  /* The name of the instruction.  */ -  const char *name; -  /* A string describing the arguments for this instruction.  */ -  const char *args; -  /* The basic opcode for the instruction.  When assembling, this -     opcode is modified by the arguments to produce the actual opcode -     that is used.  If pinfo is INSN_MACRO, then this is 0.  */ -  unsigned long match; -  /* If pinfo is not INSN_MACRO, then this is a bit mask for the -     relevant portions of the opcode when disassembling.  If the -     actual opcode anded with the match field equals the opcode field, -     then we have found the correct instruction.  If pinfo is -     INSN_MACRO, then this field is the macro identifier.  */ -  unsigned long mask; -  /* For a macro, this is INSN_MACRO.  Otherwise, it is a collection -     of bits describing the instruction, notably any relevant hazard -     information.  */ -  unsigned long pinfo; -  /* A collection of bits describing the instruction sets of which this -     instruction or macro is a member. */ -  unsigned long membership; -}; - -/* These are the characters which may appears in the args field of an -   instruction.  They appear in the order in which the fields appear -   when the instruction is used.  Commas and parentheses in the args -   string are ignored when assembling, and written into the output -   when disassembling. - -   Each of these characters corresponds to a mask field defined above. - -   "<" 5 bit shift amount (OP_*_SHAMT) -   ">" shift amount between 32 and 63, stored after subtracting 32 (OP_*_SHAMT) -   "a" 26 bit target address (OP_*_TARGET) -   "b" 5 bit base register (OP_*_RS) -   "c" 10 bit breakpoint code (OP_*_CODE) -   "d" 5 bit destination register specifier (OP_*_RD) -   "h" 5 bit prefx hint (OP_*_PREFX) -   "i" 16 bit unsigned immediate (OP_*_IMMEDIATE) -   "j" 16 bit signed immediate (OP_*_DELTA) -   "k" 5 bit cache opcode in target register position (OP_*_CACHE) -   "o" 16 bit signed offset (OP_*_DELTA) -   "p" 16 bit PC relative branch target address (OP_*_DELTA) -   "r" 5 bit same register used as both source and target (OP_*_RS) -   "s" 5 bit source register specifier (OP_*_RS) -   "t" 5 bit target register (OP_*_RT) -   "u" 16 bit upper 16 bits of address (OP_*_IMMEDIATE) -   "v" 5 bit same register used as both source and destination (OP_*_RS) -   "w" 5 bit same register used as both target and destination (OP_*_RT) -   "C" 25 bit coprocessor function code (OP_*_COPZ) -   "B" 20 bit syscall function code (OP_*_SYSCALL) -   "x" accept and ignore register name -   "z" must be zero register - -   Floating point instructions: -   "D" 5 bit destination register (OP_*_FD) -   "M" 3 bit compare condition code (OP_*_CCC) (only used for mips4 and up) -   "N" 3 bit branch condition code (OP_*_BCC) (only used for mips4 and up) -   "S" 5 bit fs source 1 register (OP_*_FS) -   "T" 5 bit ft source 2 register (OP_*_FT) -   "R" 5 bit fr source 3 register (OP_*_FR) -   "V" 5 bit same register used as floating source and destination (OP_*_FS) -   "W" 5 bit same register used as floating target and destination (OP_*_FT) - -   Coprocessor instructions: -   "E" 5 bit target register (OP_*_RT) -   "G" 5 bit destination register (OP_*_RD) -   "P" 5 bit performance-monitor register (OP_*_PERFREG) - -   Macro instructions: -   "A" General 32 bit expression -   "I" 32 bit immediate -   "F" 64 bit floating point constant in .rdata -   "L" 64 bit floating point constant in .lit8 -   "f" 32 bit floating point constant -   "l" 32 bit floating point constant in .lit4 - -   Other: -   "()" parens surrounding optional value -   ","  separates operands - -   Characters used so far, for quick reference when adding more: -   "<>()," -   "ABCDEFGILMNSTRVW" -   "abcdfhijkloprstuvwxz" -*/ - -/* These are the bits which may be set in the pinfo field of an -   instructions, if it is not equal to INSN_MACRO.  */ - -/* Modifies the general purpose register in OP_*_RD.  */ -#define INSN_WRITE_GPR_D            0x00000001 -/* Modifies the general purpose register in OP_*_RT.  */ -#define INSN_WRITE_GPR_T            0x00000002 -/* Modifies general purpose register 31.  */ -#define INSN_WRITE_GPR_31           0x00000004 -/* Modifies the floating point register in OP_*_FD.  */ -#define INSN_WRITE_FPR_D            0x00000008 -/* Modifies the floating point register in OP_*_FS.  */ -#define INSN_WRITE_FPR_S            0x00000010 -/* Modifies the floating point register in OP_*_FT.  */ -#define INSN_WRITE_FPR_T            0x00000020 -/* Reads the general purpose register in OP_*_RS.  */ -#define INSN_READ_GPR_S             0x00000040 -/* Reads the general purpose register in OP_*_RT.  */ -#define INSN_READ_GPR_T             0x00000080 -/* Reads the floating point register in OP_*_FS.  */ -#define INSN_READ_FPR_S             0x00000100 -/* Reads the floating point register in OP_*_FT.  */ -#define INSN_READ_FPR_T             0x00000200 -/* Reads the floating point register in OP_*_FR.  */ -#define INSN_READ_FPR_R		    0x00000400 -/* Modifies coprocessor condition code.  */ -#define INSN_WRITE_COND_CODE        0x00000800 -/* Reads coprocessor condition code.  */ -#define INSN_READ_COND_CODE         0x00001000 -/* TLB operation.  */ -#define INSN_TLB                    0x00002000 -/* Reads coprocessor register other than floating point register.  */ -#define INSN_COP                    0x00004000 -/* Instruction loads value from memory, requiring delay.  */ -#define INSN_LOAD_MEMORY_DELAY      0x00008000 -/* Instruction loads value from coprocessor, requiring delay.  */ -#define INSN_LOAD_COPROC_DELAY	    0x00010000 -/* Instruction has unconditional branch delay slot.  */ -#define INSN_UNCOND_BRANCH_DELAY    0x00020000 -/* Instruction has conditional branch delay slot.  */ -#define INSN_COND_BRANCH_DELAY      0x00040000 -/* Conditional branch likely: if branch not taken, insn nullified.  */ -#define INSN_COND_BRANCH_LIKELY	    0x00080000 -/* Moves to coprocessor register, requiring delay.  */ -#define INSN_COPROC_MOVE_DELAY      0x00100000 -/* Loads coprocessor register from memory, requiring delay.  */ -#define INSN_COPROC_MEMORY_DELAY    0x00200000 -/* Reads the HI register.  */ -#define INSN_READ_HI		    0x00400000 -/* Reads the LO register.  */ -#define INSN_READ_LO		    0x00800000 -/* Modifies the HI register.  */ -#define INSN_WRITE_HI		    0x01000000 -/* Modifies the LO register.  */ -#define INSN_WRITE_LO		    0x02000000 -/* Takes a trap (easier to keep out of delay slot).  */ -#define INSN_TRAP                   0x04000000 -/* Instruction stores value into memory.  */ -#define INSN_STORE_MEMORY	    0x08000000 -/* Instruction uses single precision floating point.  */ -#define FP_S			    0x10000000 -/* Instruction uses double precision floating point.  */ -#define FP_D			    0x20000000 - -/* As yet unused bits:              0x40000000 */ - -/* Instruction is actually a macro.  It should be ignored by the -   disassembler, and requires special treatment by the assembler.  */ -#define INSN_MACRO                  0xffffffff - - - - - -/* MIPS ISA field--CPU level at which insn is supported.  */ -#define INSN_ISA		    0x0000000F -/* An instruction which is not part of any basic MIPS ISA. -   (ie it is a chip specific instruction)  */ -#define INSN_NO_ISA		    0x00000000 -/* MIPS ISA 1 instruction.  */ -#define INSN_ISA1		    0x00000001 -/* MIPS ISA 2 instruction (R6000 or R4000).  */ -#define INSN_ISA2		    0x00000002 -/* MIPS ISA 3 instruction (R4000).  */ -#define INSN_ISA3		    0x00000003 -/* MIPS ISA 4 instruction (R8000).  */ -#define INSN_ISA4		    0x00000004 - -/* Chip specific instructions.  These are bitmasks.  */ -/* MIPS R4650 instruction.  */ -#define INSN_4650		    0x00000010 -/* LSI R4010 instruction.  */ -#define INSN_4010		    0x00000020 -/* NEC VR4100 instruction. */ -#define INSN_4100                   0x00000040 -/* Toshiba R3900 instruction.  */ -#define INSN_3900                   0x00000080 - - -/* This is a list of macro expanded instructions. - * - * _I appended means immediate - * _A appended means address - * _AB appended means address with base register - * _D appended means 64 bit floating point constant - * _S appended means 32 bit floating point constant - */ -enum { -    M_ABS, -    M_ADD_I, -    M_ADDU_I, -    M_AND_I, -    M_BEQ, -    M_BEQ_I, -    M_BEQL_I, -    M_BGE, -    M_BGEL, -    M_BGE_I, -    M_BGEL_I, -    M_BGEU, -    M_BGEUL, -    M_BGEU_I, -    M_BGEUL_I, -    M_BGT, -    M_BGTL, -    M_BGT_I, -    M_BGTL_I, -    M_BGTU, -    M_BGTUL, -    M_BGTU_I, -    M_BGTUL_I, -    M_BLE, -    M_BLEL, -    M_BLE_I, -    M_BLEL_I, -    M_BLEU, -    M_BLEUL, -    M_BLEU_I, -    M_BLEUL_I, -    M_BLT, -    M_BLTL, -    M_BLT_I, -    M_BLTL_I, -    M_BLTU, -    M_BLTUL, -    M_BLTU_I, -    M_BLTUL_I, -    M_BNE, -    M_BNE_I, -    M_BNEL_I, -    M_DABS, -    M_DADD_I, -    M_DADDU_I, -    M_DDIV_3, -    M_DDIV_3I, -    M_DDIVU_3, -    M_DDIVU_3I, -    M_DIV_3, -    M_DIV_3I, -    M_DIVU_3, -    M_DIVU_3I, -    M_DLA_AB, -    M_DLI, -    M_DMUL, -    M_DMUL_I,  -    M_DMULO, -    M_DMULO_I,  -    M_DMULOU, -    M_DMULOU_I,  -    M_DREM_3, -    M_DREM_3I, -    M_DREMU_3, -    M_DREMU_3I, -    M_DSUB_I, -    M_DSUBU_I, -    M_DSUBU_I_2, -    M_J_A, -    M_JAL_1, -    M_JAL_2, -    M_JAL_A, -    M_L_DOB, -    M_L_DAB, -    M_LA_AB, -    M_LB_A, -    M_LB_AB, -    M_LBU_A, -    M_LBU_AB, -    M_LD_A, -    M_LD_OB, -    M_LD_AB, -    M_LDC1_AB, -    M_LDC2_AB, -    M_LDC3_AB, -    M_LDL_AB, -    M_LDR_AB, -    M_LH_A, -    M_LH_AB, -    M_LHU_A, -    M_LHU_AB, -    M_LI, -    M_LI_D, -    M_LI_DD, -    M_LI_S, -    M_LI_SS, -    M_LL_AB, -    M_LLD_AB, -    M_LS_A, -    M_LW_A, -    M_LW_AB, -    M_LWC0_A, -    M_LWC0_AB, -    M_LWC1_A, -    M_LWC1_AB, -    M_LWC2_A, -    M_LWC2_AB, -    M_LWC3_A, -    M_LWC3_AB, -    M_LWL_A, -    M_LWL_AB, -    M_LWR_A, -    M_LWR_AB, -    M_LWU_AB, -    M_MUL, -    M_MUL_I,  -    M_MULO, -    M_MULO_I,  -    M_MULOU, -    M_MULOU_I,  -    M_NOR_I, -    M_OR_I, -    M_REM_3, -    M_REM_3I, -    M_REMU_3, -    M_REMU_3I, -    M_ROL, -    M_ROL_I, -    M_ROR, -    M_ROR_I, -    M_S_DA, -    M_S_DOB, -    M_S_DAB, -    M_S_S, -    M_SC_AB, -    M_SCD_AB, -    M_SD_A, -    M_SD_OB, -    M_SD_AB, -    M_SDC1_AB, -    M_SDC2_AB, -    M_SDC3_AB, -    M_SDL_AB, -    M_SDR_AB, -    M_SEQ, -    M_SEQ_I, -    M_SGE, -    M_SGE_I, -    M_SGEU, -    M_SGEU_I, -    M_SGT, -    M_SGT_I, -    M_SGTU, -    M_SGTU_I, -    M_SLE, -    M_SLE_I, -    M_SLEU, -    M_SLEU_I, -    M_SLT_I, -    M_SLTU_I, -    M_SNE, -    M_SNE_I, -    M_SB_A, -    M_SB_AB, -    M_SH_A, -    M_SH_AB, -    M_SW_A, -    M_SW_AB, -    M_SWC0_A, -    M_SWC0_AB, -    M_SWC1_A, -    M_SWC1_AB, -    M_SWC2_A, -    M_SWC2_AB, -    M_SWC3_A, -    M_SWC3_AB, -    M_SWL_A, -    M_SWL_AB, -    M_SWR_A, -    M_SWR_AB, -    M_SUB_I, -    M_SUBU_I, -    M_SUBU_I_2, -    M_TEQ_I, -    M_TGE_I, -    M_TGEU_I, -    M_TLT_I, -    M_TLTU_I, -    M_TNE_I, -    M_TRUNCWD, -    M_TRUNCWS, -    M_ULD, -    M_ULD_A, -    M_ULH, -    M_ULH_A, -    M_ULHU, -    M_ULHU_A, -    M_ULW, -    M_ULW_A, -    M_USH, -    M_USH_A, -    M_USW, -    M_USW_A, -    M_USD, -    M_USD_A, -    M_XOR_I, -    M_COP0, -    M_COP1, -    M_COP2, -    M_COP3, -    M_NUM_MACROS -}; - - -/* The order of overloaded instructions matters.  Label arguments and -   register arguments look the same. Instructions that can have either -   for arguments must apear in the correct order in this table for the -   assembler to pick the right one. In other words, entries with -   immediate operands must apear after the same instruction with -   registers. - -   Many instructions are short hand for other instructions (i.e., The -   jal <register> instruction is short for jalr <register>).  */ - -extern const struct mips_opcode mips_builtin_opcodes[]; -extern const int bfd_mips_num_builtin_opcodes; -extern struct mips_opcode *mips_opcodes; -extern int bfd_mips_num_opcodes; -#define NUMOPCODES bfd_mips_num_opcodes - - -/* The rest of this file adds definitions for the mips16 TinyRISC -   processor.  */ - -/* These are the bitmasks and shift counts used for the different -   fields in the instruction formats.  Other than OP, no masks are -   provided for the fixed portions of an instruction, since they are -   not needed. - -   The I format uses IMM11. - -   The RI format uses RX and IMM8. - -   The RR format uses RX, and RY. - -   The RRI format uses RX, RY, and IMM5. - -   The RRR format uses RX, RY, and RZ. - -   The RRI_A format uses RX, RY, and IMM4. - -   The SHIFT format uses RX, RY, and SHAMT. - -   The I8 format uses IMM8. - -   The I8_MOVR32 format uses RY and REGR32. - -   The IR_MOV32R format uses REG32R and MOV32Z. - -   The I64 format uses IMM8. - -   The RI64 format uses RY and IMM5. -   */ - -#define MIPS16OP_MASK_OP	0x1f -#define MIPS16OP_SH_OP		11 -#define MIPS16OP_MASK_IMM11	0x7ff -#define MIPS16OP_SH_IMM11	0 -#define MIPS16OP_MASK_RX	0x7 -#define MIPS16OP_SH_RX		8 -#define MIPS16OP_MASK_IMM8	0xff -#define MIPS16OP_SH_IMM8	0 -#define MIPS16OP_MASK_RY	0x7 -#define MIPS16OP_SH_RY		5 -#define MIPS16OP_MASK_IMM5	0x1f -#define MIPS16OP_SH_IMM5	0 -#define MIPS16OP_MASK_RZ	0x7 -#define MIPS16OP_SH_RZ		2 -#define MIPS16OP_MASK_IMM4	0xf -#define MIPS16OP_SH_IMM4	0 -#define MIPS16OP_MASK_REGR32	0x1f -#define MIPS16OP_SH_REGR32	0 -#define MIPS16OP_MASK_REG32R	0x1f -#define MIPS16OP_SH_REG32R	3 -#define MIPS16OP_EXTRACT_REG32R(i) ((((i) >> 5) & 7) | ((i) & 0x18)) -#define MIPS16OP_MASK_MOVE32Z	0x7 -#define MIPS16OP_SH_MOVE32Z	0 -#define MIPS16OP_MASK_IMM6	0x3f -#define MIPS16OP_SH_IMM6	5 - -/* These are the characters which may appears in the args field of an -   instruction.  They appear in the order in which the fields appear -   when the instruction is used.  Commas and parentheses in the args -   string are ignored when assembling, and written into the output -   when disassembling. - -   "y" 3 bit register (MIPS16OP_*_RY) -   "x" 3 bit register (MIPS16OP_*_RX) -   "z" 3 bit register (MIPS16OP_*_RZ) -   "Z" 3 bit register (MIPS16OP_*_MOVE32Z) -   "v" 3 bit same register as source and destination (MIPS16OP_*_RX) -   "w" 3 bit same register as source and destination (MIPS16OP_*_RY) -   "0" zero register ($0) -   "S" stack pointer ($sp or $29) -   "P" program counter -   "R" return address register ($ra or $31) -   "X" 5 bit MIPS register (MIPS16OP_*_REGR32) -   "Y" 5 bit MIPS register (MIPS16OP_*_REG32R) -   "6" 6 bit unsigned break code (MIPS16OP_*_IMM6) -   "a" 26 bit jump address -   "e" 11 bit extension value -   "l" register list for entry instruction -   "L" register list for exit instruction - -   The remaining codes may be extended.  Except as otherwise noted, -   the full extended operand is a 16 bit signed value. -   "<" 3 bit unsigned shift count * 0 (MIPS16OP_*_RZ) (full 5 bit unsigned) -   ">" 3 bit unsigned shift count * 0 (MIPS16OP_*_RX) (full 5 bit unsigned) -   "[" 3 bit unsigned shift count * 0 (MIPS16OP_*_RZ) (full 6 bit unsigned) -   "]" 3 bit unsigned shift count * 0 (MIPS16OP_*_RX) (full 6 bit unsigned) -   "4" 4 bit signed immediate * 0 (MIPS16OP_*_IMM4) (full 15 bit signed) -   "5" 5 bit unsigned immediate * 0 (MIPS16OP_*_IMM5) -   "H" 5 bit unsigned immediate * 2 (MIPS16OP_*_IMM5) -   "W" 5 bit unsigned immediate * 4 (MIPS16OP_*_IMM5) -   "D" 5 bit unsigned immediate * 8 (MIPS16OP_*_IMM5) -   "j" 5 bit signed immediate * 0 (MIPS16OP_*_IMM5) -   "8" 8 bit unsigned immediate * 0 (MIPS16OP_*_IMM8) -   "V" 8 bit unsigned immediate * 4 (MIPS16OP_*_IMM8) -   "C" 8 bit unsigned immediate * 8 (MIPS16OP_*_IMM8) -   "U" 8 bit unsigned immediate * 0 (MIPS16OP_*_IMM8) (full 16 bit unsigned) -   "k" 8 bit signed immediate * 0 (MIPS16OP_*_IMM8) -   "K" 8 bit signed immediate * 8 (MIPS16OP_*_IMM8) -   "p" 8 bit conditional branch address (MIPS16OP_*_IMM8) -   "q" 11 bit branch address (MIPS16OP_*_IMM11) -   "A" 8 bit PC relative address * 4 (MIPS16OP_*_IMM8) -   "B" 5 bit PC relative address * 8 (MIPS16OP_*_IMM5) -   "E" 5 bit PC relative address * 4 (MIPS16OP_*_IMM5) -   */ - -/* For the mips16, we use the same opcode table format and a few of -   the same flags.  However, most of the flags are different.  */ - -/* Modifies the register in MIPS16OP_*_RX.  */ -#define MIPS16_INSN_WRITE_X		    0x00000001 -/* Modifies the register in MIPS16OP_*_RY.  */ -#define MIPS16_INSN_WRITE_Y		    0x00000002 -/* Modifies the register in MIPS16OP_*_RZ.  */ -#define MIPS16_INSN_WRITE_Z		    0x00000004 -/* Modifies the T ($24) register.  */ -#define MIPS16_INSN_WRITE_T		    0x00000008 -/* Modifies the SP ($29) register.  */ -#define MIPS16_INSN_WRITE_SP		    0x00000010 -/* Modifies the RA ($31) register.  */ -#define MIPS16_INSN_WRITE_31		    0x00000020 -/* Modifies the general purpose register in MIPS16OP_*_REG32R.  */ -#define MIPS16_INSN_WRITE_GPR_Y		    0x00000040 -/* Reads the register in MIPS16OP_*_RX.  */ -#define MIPS16_INSN_READ_X		    0x00000080 -/* Reads the register in MIPS16OP_*_RY.  */ -#define MIPS16_INSN_READ_Y		    0x00000100 -/* Reads the register in MIPS16OP_*_MOVE32Z.  */ -#define MIPS16_INSN_READ_Z		    0x00000200 -/* Reads the T ($24) register.  */ -#define MIPS16_INSN_READ_T		    0x00000400 -/* Reads the SP ($29) register.  */ -#define MIPS16_INSN_READ_SP		    0x00000800 -/* Reads the RA ($31) register.  */ -#define MIPS16_INSN_READ_31		    0x00001000 -/* Reads the program counter.  */ -#define MIPS16_INSN_READ_PC		    0x00002000 -/* Reads the general purpose register in MIPS16OP_*_REGR32.  */ -#define MIPS16_INSN_READ_GPR_X		    0x00004000 - -/* The following flags have the same value for the mips16 opcode -   table: -   INSN_UNCOND_BRANCH_DELAY -   INSN_COND_BRANCH_DELAY -   INSN_COND_BRANCH_LIKELY (never used) -   INSN_READ_HI -   INSN_READ_LO -   INSN_WRITE_HI -   INSN_WRITE_LO -   INSN_TRAP -   INSN_ISA3 -   */ - -extern const struct mips_opcode mips16_opcodes[]; -extern const int bfd_mips16_num_opcodes; - -#endif /* _MIPS_H_ */ diff --git a/contrib/binutils/include/opcode/np1.h b/contrib/binutils/include/opcode/np1.h deleted file mode 100644 index d23adc7566cf..000000000000 --- a/contrib/binutils/include/opcode/np1.h +++ /dev/null @@ -1,422 +0,0 @@ -/* Print GOULD NPL instructions for GDB, the GNU debugger. -   Copyright (C) 1986, 1987, 1989 Free Software Foundation, Inc. - -This file is part of GDB. - -GDB is free software; you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation; either version 1, or (at your option) -any later version. - -GDB is distributed in the hope that it 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 GDB; see the file COPYING.  If not, write to -the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */ - -struct gld_opcode -{ -  char *name; -  unsigned long opcode; -  unsigned long mask; -  char *args; -  int length; -}; - -/* We store four bytes of opcode for all opcodes because that -   is the most any of them need.  The actual length of an instruction -   is always at least 2 bytes, and at most four.  The length of the -   instruction is based on the opcode. - -   The mask component is a mask saying which bits must match -   particular opcode in order for an instruction to be an instance -   of that opcode. - -   The args component is a string containing characters -   that are used to format the arguments to the instruction. */ - -/* Kinds of operands: -   r  Register in first field -   R  Register in second field -   b  Base register in first field -   B  Base register in second field -   v  Vector register in first field -   V  Vector register in first field -   A  Optional address register (base register) -   X  Optional index register -   I  Immediate data (16bits signed) -   O  Offset field (16bits signed) -   h  Offset field (15bits signed) -   d  Offset field (14bits signed) -   S  Shift count field - -   any other characters are printed as is... -*/ - -/* The assembler requires that this array be sorted as follows: -   all instances of the same mnemonic must be consecutive. -   All instances of the same mnemonic with the same number of operands -   must be consecutive. - */ -struct gld_opcode gld_opcodes[] = -{ -{ "lb",		0xb4080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lnb",	0xb8080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lbs",	0xec080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lh",		0xb4000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "lnh",	0xb8000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "lw",		0xb4000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lnw",	0xb8000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "ld",		0xb4000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "lnd",	0xb8000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "li",		0xf8000000,	0xfc7f0000,	"r,I",		4 }, -{ "lpa",	0x50080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "la",		0x50000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "labr",	0x58080000,	0xfc080000,	"b,xOA,X",	4 }, -{ "lbp",	0x90080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lhp",	0x90000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "lwp",	0x90000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "ldp",	0x90000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "suabr",	0x58000000,	0xfc080000,	"b,xOA,X",	4 }, -{ "lf",		0xbc000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lfbr",	0xbc080000,	0xfc080000,	"b,xOA,X",	4 }, -{ "lwbr",	0x5c000000,	0xfc080000,	"b,xOA,X",	4 }, -{ "stb",	0xd4080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "sth",	0xd4000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "stw",	0xd4000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "std",	0xd4000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "stf",	0xdc000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "stfbr",	0xdc080000,	0xfc080000,	"b,xOA,X",	4 }, -{ "stwbr",	0x54000000,	0xfc080000,	"b,xOA,X",	4 }, -{ "zmb",	0xd8080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "zmh",	0xd8000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "zmw",	0xd8000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "zmd",	0xd8000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "stbp",	0x94080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "sthp",	0x94000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "stwp",	0x94000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "stdp",	0x94000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "lil",	0xf80b0000,	0xfc7f0000,	"r,D",		4 }, -{ "lwsl1",	0xec000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lwsl2",	0xfc000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lwsl3",	0xfc080000,	0xfc080000,	"r,xOA,X",	4 }, - -{ "lvb",	0xb0080000,	0xfc080000,	"v,xOA,X",	4 }, -{ "lvh",	0xb0000001,	0xfc080001,	"v,xOA,X",	4 }, -{ "lvw",	0xb0000000,	0xfc080000,	"v,xOA,X",	4 }, -{ "lvd",	0xb0000002,	0xfc080002,	"v,xOA,X",	4 }, -{ "liv",	0x3c040000,	0xfc0f0000,	"v,R",		2 }, -{ "livf",	0x3c080000,	0xfc0f0000,	"v,R",		2 }, -{ "stvb",	0xd0080000,	0xfc080000,	"v,xOA,X",	4 }, -{ "stvh",	0xd0000001,	0xfc080001,	"v,xOA,X",	4 }, -{ "stvw",	0xd0000000,	0xfc080000,	"v,xOA,X",	4 }, -{ "stvd",	0xd0000002,	0xfc080002,	"v,xOA,X",	4 }, - -{ "trr",	0x2c000000,	0xfc0f0000,	"r,R",		2 }, -{ "trn",	0x2c040000,	0xfc0f0000,	"r,R",		2 }, -{ "trnd",	0x2c0c0000,	0xfc0f0000,	"r,R",		2 }, -{ "trabs",	0x2c010000,	0xfc0f0000,	"r,R",		2 }, -{ "trabsd",	0x2c090000,	0xfc0f0000,	"r,R",		2 }, -{ "trc",	0x2c030000,	0xfc0f0000,	"r,R",		2 }, -{ "xcr",	0x28040000,	0xfc0f0000,	"r,R",		2 }, -{ "cxcr",	0x2c060000,	0xfc0f0000,	"r,R",		2 }, -{ "cxcrd",	0x2c0e0000,	0xfc0f0000,	"r,R",		2 }, -{ "tbrr",	0x2c020000,	0xfc0f0000,	"r,B",		2 }, -{ "trbr",	0x28030000,	0xfc0f0000,	"b,R",		2 }, -{ "xcbr",	0x28020000,	0xfc0f0000,	"b,B",		2 }, -{ "tbrbr",	0x28010000,	0xfc0f0000,	"b,B",		2 }, - -{ "trvv",	0x28050000,	0xfc0f0000,	"v,V",		2 }, -{ "trvvn",	0x2c050000,	0xfc0f0000,	"v,V",		2 }, -{ "trvvnd",	0x2c0d0000,	0xfc0f0000,	"v,V",		2 }, -{ "trvab",	0x2c070000,	0xfc0f0000,	"v,V",		2 }, -{ "trvabd",	0x2c0f0000,	0xfc0f0000,	"v,V",		2 }, -{ "cmpv",	0x14060000,	0xfc0f0000,	"v,V",		2 }, -{ "expv",	0x14070000,	0xfc0f0000,	"v,V",		2 }, -{ "mrvvlt",	0x10030000,	0xfc0f0000,	"v,V",		2 }, -{ "mrvvle",	0x10040000,	0xfc0f0000,	"v,V",		2 }, -{ "mrvvgt",	0x14030000,	0xfc0f0000,	"v,V",		2 }, -{ "mrvvge",	0x14040000,	0xfc0f0000,	"v,V",		2 }, -{ "mrvveq",	0x10050000,	0xfc0f0000,	"v,V",		2 }, -{ "mrvvne",	0x10050000,	0xfc0f0000,	"v,V",		2 }, -{ "mrvrlt",	0x100d0000,	0xfc0f0000,	"v,R",		2 }, -{ "mrvrle",	0x100e0000,	0xfc0f0000,	"v,R",		2 }, -{ "mrvrgt",	0x140d0000,	0xfc0f0000,	"v,R",		2 }, -{ "mrvrge",	0x140e0000,	0xfc0f0000,	"v,R",		2 }, -{ "mrvreq",	0x100f0000,	0xfc0f0000,	"v,R",		2 }, -{ "mrvrne",	0x140f0000,	0xfc0f0000,	"v,R",		2 }, -{ "trvr",	0x140b0000,	0xfc0f0000,	"r,V",		2 }, -{ "trrv",	0x140c0000,	0xfc0f0000,	"v,R",		2 }, - -{ "bu",		0x40000000,	0xff880000,	"xOA,X",	4 }, -{ "bns",	0x70080000,	0xff880000,	"xOA,X",	4 }, -{ "bnco",	0x70880000,	0xff880000,	"xOA,X",	4 }, -{ "bge",	0x71080000,	0xff880000,	"xOA,X",	4 }, -{ "bne",	0x71880000,	0xff880000,	"xOA,X",	4 }, -{ "bunge",	0x72080000,	0xff880000,	"xOA,X",	4 }, -{ "bunle",	0x72880000,	0xff880000,	"xOA,X",	4 }, -{ "bgt",	0x73080000,	0xff880000,	"xOA,X",	4 }, -{ "bnany",	0x73880000,	0xff880000,	"xOA,X",	4 }, -{ "bs"	,	0x70000000,	0xff880000,	"xOA,X",	4 }, -{ "bco",	0x70800000,	0xff880000,	"xOA,X",	4 }, -{ "blt",	0x71000000,	0xff880000,	"xOA,X",	4 }, -{ "beq",	0x71800000,	0xff880000,	"xOA,X",	4 }, -{ "buge",	0x72000000,	0xff880000,	"xOA,X",	4 }, -{ "bult",	0x72800000,	0xff880000,	"xOA,X",	4 }, -{ "ble",	0x73000000,	0xff880000,	"xOA,X",	4 }, -{ "bany",	0x73800000,	0xff880000,	"xOA,X",	4 }, -{ "brlnk",	0x44000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bib",	0x48000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bih",	0x48080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "biw",	0x4c000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bid",	0x4c080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bivb",	0x60000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bivh",	0x60080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bivw",	0x64000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bivd",	0x64080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bvsb",	0x68000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bvsh",	0x68080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bvsw",	0x6c000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bvsd",	0x6c080000,	0xfc080000,	"r,xOA,X",	4 }, - -{ "camb",	0x80080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "camh",	0x80000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "camw",	0x80000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "camd",	0x80000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "car",	0x10000000,	0xfc0f0000,	"r,R",		2 }, -{ "card",	0x14000000,	0xfc0f0000,	"r,R",		2 }, -{ "ci",		0xf8050000,	0xfc7f0000,	"r,I",		4 }, -{ "chkbnd",	0x5c080000,	0xfc080000,	"r,xOA,X",	4 }, - -{ "cavv",	0x10010000,	0xfc0f0000,	"v,V",		2 }, -{ "cavr",	0x10020000,	0xfc0f0000,	"v,R",		2 }, -{ "cavvd",	0x10090000,	0xfc0f0000,	"v,V",		2 }, -{ "cavrd",	0x100b0000,	0xfc0f0000,	"v,R",		2 }, - -{ "anmb",	0x84080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "anmh",	0x84000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "anmw",	0x84000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "anmd",	0x84000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "anr",	0x04000000,	0xfc0f0000,	"r,R",		2 }, -{ "ani",	0xf8080000,	0xfc7f0000,	"r,I",		4 }, -{ "ormb",	0xb8080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "ormh",	0xb8000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "ormw",	0xb8000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "ormd",	0xb8000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "orr",	0x08000000,	0xfc0f0000,	"r,R",		2 }, -{ "oi",		0xf8090000,	0xfc7f0000,	"r,I",		4 }, -{ "eomb",	0x8c080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "eomh",	0x8c000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "eomw",	0x8c000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "eomd",	0x8c000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "eor",	0x0c000000,	0xfc0f0000,	"r,R",		2 }, -{ "eoi",	0xf80a0000,	0xfc7f0000,	"r,I",		4 }, - -{ "anvv",	0x04010000,	0xfc0f0000,	"v,V",		2 }, -{ "anvr",	0x04020000,	0xfc0f0000,	"v,R",		2 }, -{ "orvv",	0x08010000,	0xfc0f0000,	"v,V",		2 }, -{ "orvr",	0x08020000,	0xfc0f0000,	"v,R",		2 }, -{ "eovv",	0x0c010000,	0xfc0f0000,	"v,V",		2 }, -{ "eovr",	0x0c020000,	0xfc0f0000,	"v,R",		2 }, - -{ "sacz",	0x100c0000,	0xfc0f0000,	"r,R",		2 }, -{ "sla",	0x1c400000,	0xfc600000,	"r,S",		2 }, -{ "sll",	0x1c600000,	0xfc600000,	"r,S",		2 }, -{ "slc",	0x24400000,	0xfc600000,	"r,S",		2 }, -{ "slad",	0x20400000,	0xfc600000,	"r,S",		2 }, -{ "slld",	0x20600000,	0xfc600000,	"r,S",		2 }, -{ "sra",	0x1c000000,	0xfc600000,	"r,S",		2 }, -{ "srl",	0x1c200000,	0xfc600000,	"r,S",		2 }, -{ "src",	0x24000000,	0xfc600000,	"r,S",		2 }, -{ "srad",	0x20000000,	0xfc600000,	"r,S",		2 }, -{ "srld",	0x20200000,	0xfc600000,	"r,S",		2 }, -{ "sda",	0x3c030000,	0xfc0f0000,	"r,R",		2 }, -{ "sdl",	0x3c020000,	0xfc0f0000,	"r,R",		2 }, -{ "sdc",	0x3c010000,	0xfc0f0000,	"r,R",		2 }, -{ "sdad",	0x3c0b0000,	0xfc0f0000,	"r,R",		2 }, -{ "sdld",	0x3c0a0000,	0xfc0f0000,	"r,R",		2 }, - -{ "svda",	0x3c070000,	0xfc0f0000,	"v,R",		2 }, -{ "svdl",	0x3c060000,	0xfc0f0000,	"v,R",		2 }, -{ "svdc",	0x3c050000,	0xfc0f0000,	"v,R",		2 }, -{ "svdad",	0x3c0e0000,	0xfc0f0000,	"v,R",		2 }, -{ "svdld",	0x3c0d0000,	0xfc0f0000,	"v,R",		2 }, - -{ "sbm",	0xac080000,	0xfc080000,	"f,xOA,X",	4 }, -{ "zbm",	0xac000000,	0xfc080000,	"f,xOA,X",	4 }, -{ "tbm",	0xa8080000,	0xfc080000,	"f,xOA,X",	4 }, -{ "incmb",	0xa0000000,	0xfc080000,	"xOA,X",	4 }, -{ "incmh",	0xa0080000,	0xfc080000,	"xOA,X",	4 }, -{ "incmw",	0xa4000000,	0xfc080000,	"xOA,X",	4 }, -{ "incmd",	0xa4080000,	0xfc080000,	"xOA,X",	4 }, -{ "sbmd",	0x7c080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "zbmd",	0x7c000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "tbmd",	0x78080000,	0xfc080000,	"r,xOA,X",	4 }, - -{ "ssm",	0x9c080000,	0xfc080000,	"f,xOA,X",	4 }, -{ "zsm",	0x9c000000,	0xfc080000,	"f,xOA,X",	4 }, -{ "tsm",	0x98080000,	0xfc080000,	"f,xOA,X",	4 }, - -{ "admb",	0xc8080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "admh",	0xc8000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "admw",	0xc8000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "admd",	0xc8000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "adr",	0x38000000,	0xfc0f0000,	"r,R",		2 }, -{ "armb",	0xe8080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "armh",	0xe8000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "armw",	0xe8000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "armd",	0xe8000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "adi",	0xf8010000,	0xfc0f0000,	"r,I",		4 }, -{ "sumb",	0xcc080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "sumh",	0xcc000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "sumw",	0xcc000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "sumd",	0xcc000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "sur",	0x3c000000,	0xfc0f0000,	"r,R",		2 }, -{ "sui",	0xf8020000,	0xfc0f0000,	"r,I",		4 }, -{ "mpmb",	0xc0080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "mpmh",	0xc0000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "mpmw",	0xc0000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "mpr",	0x38020000,	0xfc0f0000,	"r,R",		2 }, -{ "mprd",	0x3c0f0000,	0xfc0f0000,	"r,R",		2 }, -{ "mpi",	0xf8030000,	0xfc0f0000,	"r,I",		4 }, -{ "dvmb",	0xc4080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "dvmh",	0xc4000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "dvmw",	0xc4000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "dvr",	0x380a0000,	0xfc0f0000,	"r,R",		2 }, -{ "dvi",	0xf8040000,	0xfc0f0000,	"r,I",		4 }, -{ "exs",	0x38080000,	0xfc0f0000,	"r,R",		2 }, - -{ "advv",	0x30000000,	0xfc0f0000,	"v,V",		2 }, -{ "advvd",	0x30080000,	0xfc0f0000,	"v,V",		2 }, -{ "adrv",	0x34000000,	0xfc0f0000,	"v,R",		2 }, -{ "adrvd",	0x34080000,	0xfc0f0000,	"v,R",		2 }, -{ "suvv",	0x30010000,	0xfc0f0000,	"v,V",		2 }, -{ "suvvd",	0x30090000,	0xfc0f0000,	"v,V",		2 }, -{ "surv",	0x34010000,	0xfc0f0000,	"v,R",		2 }, -{ "survd",	0x34090000,	0xfc0f0000,	"v,R",		2 }, -{ "mpvv",	0x30020000,	0xfc0f0000,	"v,V",		2 }, -{ "mprv",	0x34020000,	0xfc0f0000,	"v,R",		2 }, - -{ "adfw",	0xe0080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "adfd",	0xe0080002,	0xfc080002,	"r,xOA,X",	4 }, -{ "adrfw",	0x38010000,	0xfc0f0000,	"r,R",		2 }, -{ "adrfd",	0x38090000,	0xfc0f0000,	"r,R",		2 }, -{ "surfw",	0xe0000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "surfd",	0xe0000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "surfw",	0x38030000,	0xfc0f0000,	"r,R",		2 }, -{ "surfd",	0x380b0000,	0xfc0f0000,	"r,R",		2 }, -{ "mpfw",	0xe4080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "mpfd",	0xe4080002,	0xfc080002,	"r,xOA,X",	4 }, -{ "mprfw",	0x38060000,	0xfc0f0000,	"r,R",		2 }, -{ "mprfd",	0x380e0000,	0xfc0f0000,	"r,R",		2 }, -{ "rfw",	0xe4000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "rfd",	0xe4000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "rrfw",	0x0c0e0000,	0xfc0f0000,	"r",		2 }, -{ "rrfd",	0x0c0f0000,	0xfc0f0000,	"r",		2 }, - -{ "advvfw",	0x30040000,	0xfc0f0000,	"v,V",		2 }, -{ "advvfd",	0x300c0000,	0xfc0f0000,	"v,V",		2 }, -{ "adrvfw",	0x34040000,	0xfc0f0000,	"v,R",		2 }, -{ "adrvfd",	0x340c0000,	0xfc0f0000,	"v,R",		2 }, -{ "suvvfw",	0x30050000,	0xfc0f0000,	"v,V",		2 }, -{ "suvvfd",	0x300d0000,	0xfc0f0000,	"v,V",		2 }, -{ "survfw",	0x34050000,	0xfc0f0000,	"v,R",		2 }, -{ "survfd",	0x340d0000,	0xfc0f0000,	"v,R",		2 }, -{ "mpvvfw",	0x30060000,	0xfc0f0000,	"v,V",		2 }, -{ "mpvvfd",	0x300e0000,	0xfc0f0000,	"v,V",		2 }, -{ "mprvfw",	0x34060000,	0xfc0f0000,	"v,R",		2 }, -{ "mprvfd",	0x340e0000,	0xfc0f0000,	"v,R",		2 }, -{ "rvfw",	0x30070000,	0xfc0f0000,	"v",		2 }, -{ "rvfd",	0x300f0000,	0xfc0f0000,	"v",		2 }, - -{ "fltw",	0x38070000,	0xfc0f0000,	"r,R",		2 }, -{ "fltd",	0x380f0000,	0xfc0f0000,	"r,R",		2 }, -{ "fixw",	0x38050000,	0xfc0f0000,	"r,R",		2 }, -{ "fixd",	0x380d0000,	0xfc0f0000,	"r,R",		2 }, -{ "cfpds",	0x3c090000,	0xfc0f0000,	"r,R",		2 }, - -{ "fltvw",	0x080d0000,	0xfc0f0000,	"v,V",		2 }, -{ "fltvd",	0x080f0000,	0xfc0f0000,	"v,V",		2 }, -{ "fixvw",	0x080c0000,	0xfc0f0000,	"v,V",		2 }, -{ "fixvd",	0x080e0000,	0xfc0f0000,	"v,V",		2 }, -{ "cfpvds",	0x0c0d0000,	0xfc0f0000,	"v,V",		2 }, - -{ "orvrn",	0x000a0000,	0xfc0f0000,	"r,V",		2 }, -{ "andvrn",	0x00080000,	0xfc0f0000,	"r,V",		2 }, -{ "frsteq",	0x04090000,	0xfc0f0000,	"r,V",		2 }, -{ "sigma",	0x0c080000,	0xfc0f0000,	"r,V",		2 }, -{ "sigmad",	0x0c0a0000,	0xfc0f0000,	"r,V",		2 }, -{ "sigmf",	0x08080000,	0xfc0f0000,	"r,V",		2 }, -{ "sigmfd",	0x080a0000,	0xfc0f0000,	"r,V",		2 }, -{ "prodf",	0x04080000,	0xfc0f0000,	"r,V",		2 }, -{ "prodfd",	0x040a0000,	0xfc0f0000,	"r,V",		2 }, -{ "maxv",	0x10080000,	0xfc0f0000,	"r,V",		2 }, -{ "maxvd",	0x100a0000,	0xfc0f0000,	"r,V",		2 }, -{ "minv",	0x14080000,	0xfc0f0000,	"r,V",		2 }, -{ "minvd",	0x140a0000,	0xfc0f0000,	"r,V",		2 }, - -{ "lpsd",	0xf0000000,	0xfc080000,	"xOA,X",	4 }, -{ "ldc",	0xf0080000,	0xfc080000,	"xOA,X",	4 }, -{ "spm",	0x040c0000,	0xfc0f0000,	"r",		2 }, -{ "rpm",	0x040d0000,	0xfc0f0000,	"r",		2 }, -{ "tritr",	0x00070000,	0xfc0f0000,	"r",		2 }, -{ "trrit",	0x00060000,	0xfc0f0000,	"r",		2 }, -{ "rpswt",	0x04080000,	0xfc0f0000,	"r",		2 }, -{ "exr",	0xf8070000,	0xfc0f0000,	"",		4 }, -{ "halt",	0x00000000,	0xfc0f0000,	"",		2 }, -{ "wait",	0x00010000,	0xfc0f0000,	"",		2 }, -{ "nop",	0x00020000,	0xfc0f0000,	"",		2 }, -{ "eiae",	0x00030000,	0xfc0f0000,	"",		2 }, -{ "efae",	0x000d0000,	0xfc0f0000,	"",		2 }, -{ "diae",	0x000e0000,	0xfc0f0000,	"",		2 }, -{ "dfae",	0x000f0000,	0xfc0f0000,	"",		2 }, -{ "spvc",	0xf8060000,	0xfc0f0000,	"r,T,N",	4 }, -{ "rdsts",	0x00090000,	0xfc0f0000,	"r",		2 }, -{ "setcpu",	0x000c0000,	0xfc0f0000,	"r",		2 }, -{ "cmc",	0x000b0000,	0xfc0f0000,	"r",		2 }, -{ "trrcu",	0x00040000,	0xfc0f0000,	"r",		2 }, -{ "attnio",	0x00050000,	0xfc0f0000,	"",		2 }, -{ "fudit",	0x28080000,	0xfc0f0000,	"",		2 }, -{ "break",	0x28090000,	0xfc0f0000,	"",		2 }, -{ "frzss",	0x280a0000,	0xfc0f0000,	"",		2 }, -{ "ripi",	0x04040000,	0xfc0f0000,	"r,R",		2 }, -{ "xcp",	0x04050000,	0xfc0f0000,	"r",		2 }, -{ "block",	0x04060000,	0xfc0f0000,	"",		2 }, -{ "unblock",	0x04070000,	0xfc0f0000,	"",		2 }, -{ "trsc",	0x08060000,	0xfc0f0000,	"r,R",		2 }, -{ "tscr",	0x08070000,	0xfc0f0000,	"r,R",		2 }, -{ "fq",		0x04080000,	0xfc0f0000,	"r",		2 }, -{ "flupte",	0x2c080000,	0xfc0f0000,	"r",		2 }, -{ "rviu",	0x040f0000,	0xfc0f0000,	"",		2 }, -{ "ldel",	0x280c0000,	0xfc0f0000,	"r,R",		2 }, -{ "ldu",	0x280d0000,	0xfc0f0000,	"r,R",		2 }, -{ "stdecc",	0x280b0000,	0xfc0f0000,	"r,R",		2 }, -{ "trpc",	0x08040000,	0xfc0f0000,	"r",		2 }, -{ "tpcr",	0x08050000,	0xfc0f0000,	"r",		2 }, -{ "ghalt",	0x0c050000,	0xfc0f0000,	"r",		2 }, -{ "grun",	0x0c040000,	0xfc0f0000,	"",		2 }, -{ "tmpr",	0x2c0a0000,	0xfc0f0000,	"r,R",		2 }, -{ "trmp",	0x2c0b0000,	0xfc0f0000,	"r,R",		2 }, - -{ "trrve",	0x28060000,	0xfc0f0000,	"r",		2 }, -{ "trver",	0x28070000,	0xfc0f0000,	"r",		2 }, -{ "trvlr",	0x280f0000,	0xfc0f0000,	"r",		2 }, - -{ "linkfl",	0x18000000,	0xfc0f0000,	"r,R",		2 }, -{ "linkbl",	0x18020000,	0xfc0f0000,	"r,R",		2 }, -{ "linkfp",	0x18010000,	0xfc0f0000,	"r,R",		2 }, -{ "linkbp",	0x18030000,	0xfc0f0000,	"r,R",		2 }, -{ "linkpl",	0x18040000,	0xfc0f0000,	"r,R",		2 }, -{ "ulinkl",	0x18080000,	0xfc0f0000,	"r,R",		2 }, -{ "ulinkp",	0x18090000,	0xfc0f0000,	"r,R",		2 }, -{ "ulinktl",	0x180a0000,	0xfc0f0000,	"r,R",		2 }, -{ "ulinktp",	0x180b0000,	0xfc0f0000,	"r,R",		2 }, -}; - -int numopcodes = sizeof(gld_opcodes) / sizeof(gld_opcodes[0]); - -struct gld_opcode *endop = gld_opcodes + sizeof(gld_opcodes) / -		 		sizeof(gld_opcodes[0]); diff --git a/contrib/binutils/include/opcode/pn.h b/contrib/binutils/include/opcode/pn.h deleted file mode 100644 index 0f59a2a53ce9..000000000000 --- a/contrib/binutils/include/opcode/pn.h +++ /dev/null @@ -1,282 +0,0 @@ -/* Print GOULD PN (PowerNode) instructions for GDB, the GNU debugger. -   Copyright (C) 1986, 1987, 1989 Free Software Foundation, Inc. - -This file is part of GDB. - -GDB is free software; you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation; either version 1, or (at your option) -any later version. - -GDB is distributed in the hope that it 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 GDB; see the file COPYING.  If not, write to -the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */ - -struct gld_opcode -{ -  char *name; -  unsigned long opcode; -  unsigned long mask; -  char *args; -  int length; -}; - -/* We store four bytes of opcode for all opcodes because that -   is the most any of them need.  The actual length of an instruction -   is always at least 2 bytes, and at most four.  The length of the -   instruction is based on the opcode. - -   The mask component is a mask saying which bits must match -   particular opcode in order for an instruction to be an instance -   of that opcode. - -   The args component is a string containing characters -   that are used to format the arguments to the instruction. */ - -/* Kinds of operands: -   r  Register in first field -   R  Register in second field -   b  Base register in first field -   B  Base register in second field -   v  Vector register in first field -   V  Vector register in first field -   A  Optional address register (base register) -   X  Optional index register -   I  Immediate data (16bits signed) -   O  Offset field (16bits signed) -   h  Offset field (15bits signed) -   d  Offset field (14bits signed) -   S  Shift count field - -   any other characters are printed as is... -*/ - -/* The assembler requires that this array be sorted as follows: -   all instances of the same mnemonic must be consecutive. -   All instances of the same mnemonic with the same number of operands -   must be consecutive. - */ -struct gld_opcode gld_opcodes[] = -{ -{ "abm",	0xa0080000,	0xfc080000,	"f,xOA,X",	4 }, -{ "abr",	0x18080000,	0xfc0c0000,	"r,f",		2 }, -{ "aci",	0xfc770000,	0xfc7f8000,	"r,I",		4 }, -{ "adfd",	0xe0080002,	0xfc080002,	"r,xOA,X",	4 }, -{ "adfw",	0xe0080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "adi",	0xc8010000,	0xfc7f0000,	"r,I",		4 }, -{ "admb",	0xb8080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "admd",	0xb8000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "admh",	0xb8000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "admw",	0xb8000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "adr",	0x38000000,	0xfc0f0000,	"r,R",		2 }, -{ "adrfd",	0x38090000,	0xfc0f0000,	"r,R",		2 }, -{ "adrfw",	0x38010000,	0xfc0f0000,	"r,R",		2 }, -{ "adrm",	0x38080000,	0xfc0f0000,	"r,R",		2 }, -{ "ai", 	0xfc030000,	0xfc07ffff,	"I",		4 }, -{ "anmb",	0x84080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "anmd",	0x84000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "anmh",	0x84000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "anmw",	0x84000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "anr",	0x04000000,	0xfc0f0000,	"r,R",		2 }, -{ "armb",	0xe8080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "armd",	0xe8000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "armh",	0xe8000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "armw",	0xe8000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "bcf",	0xf0000000,	0xfc080000,	"I,xOA,X",	4 }, -{ "bct",	0xec000000,	0xfc080000,	"I,xOA,X",	4 }, -{ "bei",	0x00060000,	0xffff0000,	"",		2 }, -{ "bft",	0xf0000000,	0xff880000,	"xOA,X",	4 }, -{ "bib",	0xf4000000,	0xfc780000,	"r,xOA",	4 }, -{ "bid",	0xf4600000,	0xfc780000,	"r,xOA",	4 }, -{ "bih",	0xf4200000,	0xfc780000,	"r,xOA",	4 }, -{ "biw",	0xf4400000,	0xfc780000,	"r,xOA",	4 }, -{ "bl", 	0xf8800000,	0xff880000,	"xOA,X",	4 }, -{ "bsub",	0x5c080000,	0xff8f0000,	"",		2 }, -{ "bsubm",	0x28080000,	0xfc080000,	"",		4 }, -{ "bu", 	0xec000000,	0xff880000,	"xOA,X",	4 }, -{ "call",	0x28080000,	0xfc0f0000,	"",		2 }, -{ "callm",	0x5c080000,	0xff880000,	"",		4 }, -{ "camb",	0x90080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "camd",	0x90000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "camh",	0x90000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "camw",	0x90000000,	0xfc080000,	"r.xOA,X",	4 }, -{ "car",	0x10000000,	0xfc0f0000,	"r,R",		2 }, -{ "cd", 	0xfc060000,	0xfc070000,	"r,f",		4 }, -{ "cea",	0x000f0000,	0xffff0000,	"",		2 }, -{ "ci", 	0xc8050000,	0xfc7f0000,	"r,I",		4 }, -{ "cmc",	0x040a0000,	0xfc7f0000,	"r",		2 }, -{ "cmmb",	0x94080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "cmmd",	0x94000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "cmmh",	0x94000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "cmmw",	0x94000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "cmr",	0x14000000,	0xfc0f0000,	"r,R",		2 }, -{ "daci",	0xfc7f0000,	0xfc7f8000,	"r,I",		4 }, -{ "dae",	0x000e0000,	0xffff0000,	"",		2 }, -{ "dai",	0xfc040000,	0xfc07ffff,	"I",		4 }, -{ "dci",	0xfc6f0000,	0xfc7f8000,	"r,I",		4 }, -{ "di", 	0xfc010000,	0xfc07ffff,	"I",		4 }, -{ "dvfd",	0xe4000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "dvfw",	0xe4000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "dvi",	0xc8040000,	0xfc7f0000,	"r,I",		4 }, -{ "dvmb",	0xc4080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "dvmh",	0xc4000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "dvmw",	0xc4000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "dvr",	0x380a0000,	0xfc0f0000,	"r,R",		2 }, -{ "dvrfd",	0x380c0000,	0xfc0f0000,	"r,R",		4 }, -{ "dvrfw",	0x38040000,	0xfc0f0000,	"r,xOA,X",	4 }, -{ "eae",	0x00080000,	0xffff0000,	"",		2 }, -{ "eci",	0xfc670000,	0xfc7f8080,	"r,I",		4 }, -{ "ecwcs",	0xfc4f0000,	0xfc7f8000,	"",		4 }, -{ "ei", 	0xfc000000,	0xfc07ffff,	"I",		4 }, -{ "eomb",	0x8c080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "eomd",	0x8c000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "eomh",	0x8c000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "eomw",	0x8c000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "eor",	0x0c000000,	0xfc0f0000,	"r,R",		2 }, -{ "eorm",	0x0c080000,	0xfc0f0000,	"r,R",		2 }, -{ "es", 	0x00040000,	0xfc7f0000,	"r",		2 }, -{ "exm",	0xa8000000,	0xff880000,	"xOA,X",	4 }, -{ "exr",	0xc8070000,	0xfc7f0000,	"r",		2 }, -{ "exrr",	0xc8070002,	0xfc7f0002,	"r",		2 }, -{ "fixd",	0x380d0000,	0xfc0f0000,	"r,R",		2 }, -{ "fixw",	0x38050000,	0xfc0f0000,	"r,R",		2 }, -{ "fltd",	0x380f0000,	0xfc0f0000,	"r,R",		2 }, -{ "fltw",	0x38070000,	0xfc0f0000,	"r,R",		2 }, -{ "grio",	0xfc3f0000,	0xfc7f8000,	"r,I",		4 }, -{ "halt",	0x00000000,	0xffff0000,	"",		2 }, -{ "hio",	0xfc370000,	0xfc7f8000,	"r,I",		4 }, -{ "jwcs",	0xfa080000,	0xff880000,	"xOA,X",	4 }, -{ "la", 	0x50000000,	0xfc000000,	"r,xOA,X",	4 }, -{ "labr",	0x58080000,	0xfc080000,	"b,xOA,X",	4 }, -{ "lb", 	0xac080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lcs", 	0x00030000,	0xfc7f0000,	"r",		2 }, -{ "ld", 	0xac000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "lear", 	0x80000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lf", 	0xcc000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lfbr", 	0xcc080000,	0xfc080000,	"b,xOA,X",	4 }, -{ "lh", 	0xac000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "li", 	0xc8000000,	0xfc7f0000,	"r,I",		4 }, -{ "lmap",	0x2c070000,	0xfc7f0000,	"r",		2 }, -{ "lmb",	0xb0080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lmd",	0xb0000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "lmh",	0xb0000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "lmw",	0xb0000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lnb",	0xb4080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lnd",	0xb4000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "lnh",	0xb4000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "lnw",	0xb4000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lpsd",	0xf9800000,	0xff880000,	"r,xOA,X",	4 }, -{ "lpsdcm",	0xfa800000,	0xff880000,	"r,xOA,X",	4 }, -{ "lw", 	0xac000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "lwbr", 	0x5c000000,	0xfc080000,	"b,xOA,X",	4 }, -{ "mpfd",	0xe4080002,	0xfc080002,	"r,xOA,X",	4 }, -{ "mpfw",	0xe4080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "mpi",	0xc8030000,	0xfc7f0000,	"r,I",		4 }, -{ "mpmb",	0xc0080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "mpmh",	0xc0000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "mpmw",	0xc0000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "mpr",	0x38020000,	0xfc0f0000,	"r,R",		2 }, -{ "mprfd",	0x380e0000,	0xfc0f0000,	"r,R",		2 }, -{ "mprfw",	0x38060000,	0xfc0f0000,	"r,R",		2 }, -{ "nop",	0x00020000,	0xffff0000,	"",		2 }, -{ "ormb",	0x88080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "ormd",	0x88000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "ormh",	0x88000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "ormw",	0x88000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "orr",	0x08000000,	0xfc0f0000,	"r,R",		2 }, -{ "orrm",	0x08080000,	0xfc0f0000,	"r,R",		2 }, -{ "rdsts",	0x00090000,	0xfc7f0000,	"r",		2 }, -{ "return",	0x280e0000,	0xfc7f0000,	"",		2 }, -{ "ri", 	0xfc020000,	0xfc07ffff,	"I",		4 }, -{ "rnd",	0x00050000,	0xfc7f0000,	"r",		2 }, -{ "rpswt",	0x040b0000,	0xfc7f0000,	"r",		2 }, -{ "rschnl",	0xfc2f0000,	0xfc7f8000,	"r,I",		4 }, -{ "rsctl",	0xfc470000,	0xfc7f8000,	"r,I",		4 }, -{ "rwcs",	0x000b0000,	0xfc0f0000,	"r,R",		2 }, -{ "sacz",	0x10080000,	0xfc0f0000,	"r,R",		2 }, -{ "sbm",	0x98080000,	0xfc080000,	"f,xOA,X",	4 }, -{ "sbr",	0x18000000,	0xfc0c0000,	"r,f",		4 }, -{ "sea",	0x000d0000,	0xffff0000,	"",		2 }, -{ "setcpu",	0x2c090000,	0xfc7f0000,	"r",		2 }, -{ "sio",	0xfc170000,	0xfc7f8000,	"r,I",		4 }, -{ "sipu",	0x000a0000,	0xffff0000,	"",		2 }, -{ "sla",	0x1c400000,	0xfc600000,	"r,S",		2 }, -{ "slad",	0x20400000,	0xfc600000,	"r,S",		2 }, -{ "slc",	0x24400000,	0xfc600000,	"r,S",		2 }, -{ "sll",	0x1c600000,	0xfc600000,	"r,S",		2 }, -{ "slld",	0x20600000,	0xfc600000,	"r,S",		2 }, -{ "smc",	0x04070000,	0xfc070000,	"",		2 }, -{ "sra",	0x1c000000,	0xfc600000,	"r,S",		2 }, -{ "srad",	0x20000000,	0xfc600000,	"r,S",		2 }, -{ "src",	0x24000000,	0xfc600000,	"r,S",		2 }, -{ "srl",	0x1c200000,	0xfc600000,	"r,S",		2 }, -{ "srld",	0x20200000,	0xfc600000,	"r,S",		2 }, -{ "stb",	0xd4080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "std",	0xd4000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "stf",	0xdc000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "stfbr",	0x54000000,	0xfc080000,	"b,xOA,X",	4 }, -{ "sth",	0xd4000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "stmb",	0xd8080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "stmd",	0xd8000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "stmh",	0xd8000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "stmw",	0xd8000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "stpio",	0xfc270000,	0xfc7f8000,	"r,I",		4 }, -{ "stw",	0xd4000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "stwbr",	0x54000000,	0xfc080000,	"b,xOA,X",	4 }, -{ "suabr",	0x58000000,	0xfc080000,	"b,xOA,X",	4 }, -{ "sufd",	0xe0000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "sufw",	0xe0000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "sui",	0xc8020000,	0xfc7f0000,	"r,I",		4 }, -{ "sumb",	0xbc080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "sumd",	0xbc000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "sumh",	0xbc000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "sumw",	0xbc000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "sur",	0x3c000000,	0xfc0f0000,	"r,R",		2 }, -{ "surfd",	0x380b0000,	0xfc0f0000,	"r,xOA,X",	4 }, -{ "surfw",	0x38030000,	0xfc0f0000,	"r,R",		2 }, -{ "surm",	0x3c080000,	0xfc0f0000,	"r,R",		2 }, -{ "svc",	0xc8060000,	0xffff0000,	"",		4 }, -{ "tbm",	0xa4080000,	0xfc080000,	"f,xOA,X",	4 }, -{ "tbr",	0x180c0000,	0xfc0c0000,	"r,f",		2 }, -{ "tbrr",	0x2c020000,	0xfc0f0000,	"r,B",		2 }, -{ "tccr",	0x28040000,	0xfc7f0000,	"",		2 }, -{ "td", 	0xfc050000,	0xfc070000,	"r,f",		4 }, -{ "tio",	0xfc1f0000,	0xfc7f8000,	"r,I",		4 }, -{ "tmapr",	0x2c0a0000,	0xfc0f0000,	"r,R",		2 }, -{ "tpcbr",	0x280c0000,	0xfc7f0000,	"r",		2 }, -{ "trbr",	0x2c010000,	0xfc0f0000,	"b,R",		2 }, -{ "trc",	0x2c030000,	0xfc0f0000,	"r,R",		2 }, -{ "trcc",	0x28050000,	0xfc7f0000,	"",		2 }, -{ "trcm",	0x2c0b0000,	0xfc0f0000,	"r,R",		2 }, -{ "trn",	0x2c040000,	0xfc0f0000,	"r,R",		2 }, -{ "trnm",	0x2c0c0000,	0xfc0f0000,	"r,R",		2 }, -{ "trr",	0x2c000000,	0xfc0f0000,	"r,R",		2 }, -{ "trrm",	0x2c080000,	0xfc0f0000,	"r,R",		2 }, -{ "trsc",	0x2c0e0000,	0xfc0f0000,	"r,R",		2 }, -{ "trsw",	0x28000000,	0xfc7f0000,	"r",		2 }, -{ "tscr",	0x2c0f0000,	0xfc0f0000,	"r,R",		2 }, -{ "uei",	0x00070000,	0xffff0000,	"",		2 }, -{ "wait",	0x00010000,	0xffff0000,	"",		2 }, -{ "wcwcs",	0xfc5f0000,	0xfc7f8000,	"",		4 }, -{ "wwcs",	0x000c0000,	0xfc0f0000,	"r,R",		2 }, -{ "xcbr",	0x28020000,	0xfc0f0000,	"b,B",		2 }, -{ "xcr",	0x2c050000,	0xfc0f0000,	"r,R",		2 }, -{ "xcrm",	0x2c0d0000,	0xfc0f0000,	"r,R",		2 }, -{ "zbm",	0x9c080000,	0xfc080000,	"f,xOA,X",	4 }, -{ "zbr",	0x18040000,	0xfc0c0000,	"r,f",		2 }, -{ "zmb",	0xf8080000,	0xfc080000,	"r,xOA,X",	4 }, -{ "zmd",	0xf8000002,	0xfc080002,	"r,xOA,X",	4 }, -{ "zmh",	0xf8000001,	0xfc080001,	"r,xOA,X",	4 }, -{ "zmw",	0xf8000000,	0xfc080000,	"r,xOA,X",	4 }, -{ "zr", 	0x0c000000,	0xfc0f0000,	"r",		2 }, -}; - -int numopcodes = sizeof(gld_opcodes) / sizeof(gld_opcodes[0]); - -struct gld_opcode *endop = gld_opcodes + sizeof(gld_opcodes) / -		sizeof(gld_opcodes[0]); diff --git a/contrib/binutils/include/opcode/sparc.h b/contrib/binutils/include/opcode/sparc.h deleted file mode 100644 index 4f159bd896f6..000000000000 --- a/contrib/binutils/include/opcode/sparc.h +++ /dev/null @@ -1,240 +0,0 @@ -/* Definitions for opcode table for the sparc. -   Copyright (C) 1989, 91, 92, 93, 94, 95, 96, 1997 -   Free Software Foundation, Inc. - -This file is part of GAS, the GNU Assembler, GDB, the GNU debugger, and -the GNU Binutils. - -GAS/GDB is free software; you can redistribute it and/or modify -it 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. - -GAS/GDB is distributed in the hope that it 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 GAS or GDB; see the file COPYING.	If not, write to -the Free Software Foundation, 59 Temple Place - Suite 330, -Boston, MA 02111-1307, USA.  */ - -#include <ansidecl.h> - -/* The SPARC opcode table (and other related data) is defined in -   the opcodes library in sparc-opc.c.  If you change anything here, make -   sure you fix up that file, and vice versa.  */ - - /* FIXME-someday: perhaps the ,a's and such should be embedded in the -    instruction's name rather than the args.  This would make gas faster, pinsn -    slower, but would mess up some macros a bit.  xoxorich. */ - -/* List of instruction sets variations. -   These values are such that each element is either a superset of a -   preceding each one or they conflict in which case SPARC_OPCODE_CONFLICT_P -   returns non-zero. -   The values are indices into `sparc_opcode_archs' defined in sparc-opc.c. -   Don't change this without updating sparc-opc.c.  */ - -enum sparc_opcode_arch_val { -  SPARC_OPCODE_ARCH_V6 = 0, -  SPARC_OPCODE_ARCH_V7, -  SPARC_OPCODE_ARCH_V8, -  SPARC_OPCODE_ARCH_SPARCLET, -  SPARC_OPCODE_ARCH_SPARCLITE, -  /* v9 variants must appear last */ -  SPARC_OPCODE_ARCH_V9, -  SPARC_OPCODE_ARCH_V9A, /* v9 with ultrasparc additions */ -  SPARC_OPCODE_ARCH_BAD /* error return from sparc_opcode_lookup_arch */ -}; - -/* The highest architecture in the table.  */ -#define SPARC_OPCODE_ARCH_MAX (SPARC_OPCODE_ARCH_BAD - 1) - -/* Given an enum sparc_opcode_arch_val, return the bitmask to use in -   insn encoding/decoding.  */ -#define SPARC_OPCODE_ARCH_MASK(arch) (1 << (arch)) - -/* Given a valid sparc_opcode_arch_val, return non-zero if it's v9.  */ -#define SPARC_OPCODE_ARCH_V9_P(arch) ((arch) >= SPARC_OPCODE_ARCH_V9) - -/* Table of cpu variants.  */ - -struct sparc_opcode_arch { -  const char *name; -  /* Mask of sparc_opcode_arch_val's supported. -     EG: For v7 this would be -     (SPARC_OPCODE_ARCH_MASK (..._V6) | SPARC_OPCODE_ARCH_MASK (..._V7)). -     These are short's because sparc_opcode.architecture is.  */ -  short supported; -}; - -extern const struct sparc_opcode_arch sparc_opcode_archs[]; - -/* Given architecture name, look up it's sparc_opcode_arch_val value.  */ -extern enum sparc_opcode_arch_val sparc_opcode_lookup_arch -  PARAMS ((const char *)); - -/* Return the bitmask of supported architectures for ARCH.  */ -#define SPARC_OPCODE_SUPPORTED(ARCH) (sparc_opcode_archs[ARCH].supported) - -/* Non-zero if ARCH1 conflicts with ARCH2. -   IE: ARCH1 as a supported bit set that ARCH2 doesn't, and vice versa.  */ -#define SPARC_OPCODE_CONFLICT_P(ARCH1, ARCH2) \ -(((SPARC_OPCODE_SUPPORTED (ARCH1) & SPARC_OPCODE_SUPPORTED (ARCH2)) \ -  != SPARC_OPCODE_SUPPORTED (ARCH1)) \ - && ((SPARC_OPCODE_SUPPORTED (ARCH1) & SPARC_OPCODE_SUPPORTED (ARCH2)) \ -     != SPARC_OPCODE_SUPPORTED (ARCH2))) - -/* Structure of an opcode table entry.  */ - -struct sparc_opcode { -  const char *name; -  unsigned long match;	/* Bits that must be set. */ -  unsigned long lose;	/* Bits that must not be set. */ -  const char *args; -  /* This was called "delayed" in versions before the flags. */ -  char flags; -  short architecture;	/* Bitmask of sparc_opcode_arch_val's.  */ -}; - -#define	F_DELAYED	1	/* Delayed branch */ -#define	F_ALIAS		2	/* Alias for a "real" instruction */ -#define	F_UNBR		4	/* Unconditional branch */ -#define	F_CONDBR	8	/* Conditional branch */ -#define	F_JSR		16	/* Subroutine call */ -#define F_FLOAT		32	/* Floating point instruction (not a branch) */ -#define F_FBR		64	/* Floating point branch */ -/* FIXME: Add F_ANACHRONISTIC flag for v9.  */ - -/* - -All sparc opcodes are 32 bits, except for the `set' instruction (really a -macro), which is 64 bits. It is handled as a special case. - -The match component is a mask saying which bits must match a particular -opcode in order for an instruction to be an instance of that opcode. - -The args component is a string containing one character for each operand of the -instruction. - -Kinds of operands: -	#	Number used by optimizer.	It is ignored. -	1	rs1 register. -	2	rs2 register. -	d	rd register. -	e	frs1 floating point register. -	v	frs1 floating point register (double/even). -	V	frs1 floating point register (quad/multiple of 4). -	f	frs2 floating point register. -	B	frs2 floating point register (double/even). -	R	frs2 floating point register (quad/multiple of 4). -	g	frsd floating point register. -	H	frsd floating point register (double/even). -	J	frsd floating point register (quad/multiple of 4). -	b	crs1 coprocessor register -	c	crs2 coprocessor register -	D	crsd coprocessor register -	m	alternate space register (asr) in rd -	M	alternate space register (asr) in rs1 -	h	22 high bits. -	X	5 bit unsigned immediate -	Y	6 bit unsigned immediate -	K	MEMBAR mask (7 bits). (v9) -	j	10 bit Immediate. (v9) -	I	11 bit Immediate. (v9) -	i	13 bit Immediate. -	n	22 bit immediate. -	k	2+14 bit PC relative immediate. (v9) -	G	19 bit PC relative immediate. (v9) -	l	22 bit PC relative immediate. -	L	30 bit PC relative immediate. -	a	Annul.	The annul bit is set. -	A	Alternate address space. Stored as 8 bits. -	C	Coprocessor state register. -	F	floating point state register. -	p	Processor state register. -	N	Branch predict clear ",pn" (v9) -	T	Branch predict set ",pt" (v9) -	z	%icc. (v9) -	Z	%xcc. (v9) -	q	Floating point queue. -	r	Single register that is both rs1 and rd. -	O	Single register that is both rs2 and rd. -	Q	Coprocessor queue. -	S	Special case. -	t	Trap base register. -	w	Window invalid mask register. -	y	Y register. -	u	sparclet coprocessor registers in rd position -	U	sparclet coprocessor registers in rs1 position -	E	%ccr. (v9) -	s	%fprs. (v9) -	P	%pc.  (v9) -	W	%tick.	(v9) -	o	%asi. (v9) -	6	%fcc0. (v9) -	7	%fcc1. (v9) -	8	%fcc2. (v9) -	9	%fcc3. (v9) -	!	Privileged Register in rd (v9) -	?	Privileged Register in rs1 (v9) -	*	Prefetch function constant. (v9) -	x	OPF field (v9 impdep). -	0	32/64 bit immediate for set or setx (v9) insns -	_	Ancillary state register in rd (v9a) -	/	Ancillary state register in rs1 (v9a) - -The following chars are unused: (note: ,[] are used as punctuation) -[345] - -*/ - -#define OP2(x)		(((x)&0x7) << 22) /* op2 field of format2 insns */ -#define OP3(x)		(((x)&0x3f) << 19) /* op3 field of format3 insns */ -#define OP(x)		((unsigned)((x)&0x3) << 30) /* op field of all insns */ -#define OPF(x)		(((x)&0x1ff) << 5) /* opf field of float insns */ -#define OPF_LOW5(x)	OPF((x)&0x1f) /* v9 */ -#define F3F(x, y, z)	(OP(x) | OP3(y) | OPF(z)) /* format3 float insns */ -#define F3I(x)		(((x)&0x1) << 13) /* immediate field of format 3 insns */ -#define F2(x, y)	(OP(x) | OP2(y)) /* format 2 insns */ -#define F3(x, y, z)	(OP(x) | OP3(y) | F3I(z)) /* format3 insns */ -#define F1(x)		(OP(x)) -#define DISP30(x)	((x)&0x3fffffff) -#define ASI(x)		(((x)&0xff) << 5) /* asi field of format3 insns */ -#define RS2(x)		((x)&0x1f) /* rs2 field */ -#define SIMM13(x)	((x)&0x1fff) /* simm13 field */ -#define RD(x)		(((x)&0x1f) << 25) /* destination register field */ -#define RS1(x)		(((x)&0x1f) << 14) /* rs1 field */ -#define ASI_RS2(x)	(SIMM13(x)) -#define MEMBAR(x)	((x)&0x7f) -#define SLCPOP(x)	(((x)&0x7f) << 6) /* sparclet cpop */ - -#define ANNUL	(1<<29) -#define BPRED	(1<<19)	/* v9 */ -#define	IMMED	F3I(1) -#define RD_G0	RD(~0) -#define	RS1_G0	RS1(~0) -#define	RS2_G0	RS2(~0) - -extern const struct sparc_opcode sparc_opcodes[]; -extern const int sparc_num_opcodes; - -extern int sparc_encode_asi PARAMS ((const char *)); -extern const char *sparc_decode_asi PARAMS ((int)); -extern int sparc_encode_membar PARAMS ((const char *)); -extern const char *sparc_decode_membar PARAMS ((int)); -extern int sparc_encode_prefetch PARAMS ((const char *)); -extern const char *sparc_decode_prefetch PARAMS ((int)); -extern int sparc_encode_sparclet_cpreg PARAMS ((const char *)); -extern const char *sparc_decode_sparclet_cpreg PARAMS ((int)); - -/* - * Local Variables: - * fill-column: 131 - * comment-column: 0 - * End: - */ - -/* end of sparc.h */ diff --git a/contrib/binutils/include/opcode/tic30.h b/contrib/binutils/include/opcode/tic30.h deleted file mode 100644 index a70027591188..000000000000 --- a/contrib/binutils/include/opcode/tic30.h +++ /dev/null @@ -1,691 +0,0 @@ -/* tic30.h -- Header file for TI TMS320C30 opcode table -   Copyright 1998 Free Software Foundation, Inc. -   Contributed by Steven Haworth (steve@pm.cse.rmit.edu.au) - -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 -1, 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.  */ - -/* FIXME: The opcode table should be in opcodes/tic30-opc.c, not in a -   header file.  */ - -#ifndef _TMS320_H_ -#define _TMS320_H_ - -struct _register -{ -  char *name; -  unsigned char opcode; -  unsigned char regtype; -}; - -typedef struct _register reg; - -#define REG_Rn    0x01 -#define REG_ARn   0x02 -#define REG_DP    0x03 -#define REG_OTHER 0x04 - -static const reg tic30_regtab[] = { -  { "r0", 0x00, REG_Rn }, -  { "r1", 0x01, REG_Rn }, -  { "r2", 0x02, REG_Rn }, -  { "r3", 0x03, REG_Rn }, -  { "r4", 0x04, REG_Rn }, -  { "r5", 0x05, REG_Rn }, -  { "r6", 0x06, REG_Rn }, -  { "r7", 0x07, REG_Rn }, -  { "ar0",0x08, REG_ARn }, -  { "ar1",0x09, REG_ARn }, -  { "ar2",0x0A, REG_ARn }, -  { "ar3",0x0B, REG_ARn }, -  { "ar4",0x0C, REG_ARn }, -  { "ar5",0x0D, REG_ARn }, -  { "ar6",0x0E, REG_ARn }, -  { "ar7",0x0F, REG_ARn }, -  { "dp", 0x10, REG_DP }, -  { "ir0",0x11, REG_OTHER }, -  { "ir1",0x12, REG_OTHER }, -  { "bk", 0x13, REG_OTHER }, -  { "sp", 0x14, REG_OTHER }, -  { "st", 0x15, REG_OTHER }, -  { "ie", 0x16, REG_OTHER }, -  { "if", 0x17, REG_OTHER }, -  { "iof",0x18, REG_OTHER }, -  { "rs", 0x19, REG_OTHER }, -  { "re", 0x1A, REG_OTHER }, -  { "rc", 0x1B, REG_OTHER }, -  { "R0", 0x00, REG_Rn }, -  { "R1", 0x01, REG_Rn }, -  { "R2", 0x02, REG_Rn }, -  { "R3", 0x03, REG_Rn }, -  { "R4", 0x04, REG_Rn }, -  { "R5", 0x05, REG_Rn }, -  { "R6", 0x06, REG_Rn }, -  { "R7", 0x07, REG_Rn }, -  { "AR0",0x08, REG_ARn }, -  { "AR1",0x09, REG_ARn }, -  { "AR2",0x0A, REG_ARn }, -  { "AR3",0x0B, REG_ARn }, -  { "AR4",0x0C, REG_ARn }, -  { "AR5",0x0D, REG_ARn }, -  { "AR6",0x0E, REG_ARn }, -  { "AR7",0x0F, REG_ARn }, -  { "DP", 0x10, REG_DP }, -  { "IR0",0x11, REG_OTHER }, -  { "IR1",0x12, REG_OTHER }, -  { "BK", 0x13, REG_OTHER }, -  { "SP", 0x14, REG_OTHER }, -  { "ST", 0x15, REG_OTHER }, -  { "IE", 0x16, REG_OTHER }, -  { "IF", 0x17, REG_OTHER }, -  { "IOF",0x18, REG_OTHER }, -  { "RS", 0x19, REG_OTHER }, -  { "RE", 0x1A, REG_OTHER }, -  { "RC", 0x1B, REG_OTHER }, -  { "",   0, 0 } -}; - -static const reg *const tic30_regtab_end -  = tic30_regtab + sizeof(tic30_regtab)/sizeof(tic30_regtab[0]); - -/* Indirect Addressing Modes Modification Fields */ -/* Indirect Addressing with Displacement */ -#define PreDisp_Add        0x00 -#define PreDisp_Sub        0x01 -#define PreDisp_Add_Mod    0x02 -#define PreDisp_Sub_Mod    0x03 -#define PostDisp_Add_Mod   0x04 -#define PostDisp_Sub_Mod   0x05 -#define PostDisp_Add_Circ  0x06 -#define PostDisp_Sub_Circ  0x07 -/* Indirect Addressing with Index Register IR0 */ -#define PreIR0_Add         0x08 -#define PreIR0_Sub         0x09 -#define PreIR0_Add_Mod     0x0A -#define PreIR0_Sub_Mod     0x0B -#define PostIR0_Add_Mod    0x0C -#define PostIR0_Sub_Mod    0x0D -#define PostIR0_Add_Circ   0x0E -#define PostIR0_Sub_Circ   0x0F -/* Indirect Addressing with Index Register IR1 */ -#define PreIR1_Add         0x10 -#define PreIR1_Sub         0x11 -#define PreIR1_Add_Mod     0x12 -#define PreIR1_Sub_Mod     0x13 -#define PostIR1_Add_Mod    0x14 -#define PostIR1_Sub_Mod    0x15 -#define PostIR1_Add_Circ   0x16 -#define PostIR1_Sub_Circ   0x17 -/* Indirect Addressing (Special Cases) */ -#define IndirectOnly       0x18 -#define PostIR0_Add_BitRev 0x19 - -typedef struct { -  char *syntax; -  unsigned char modfield; -  unsigned char displacement; -} ind_addr_type; - -#define IMPLIED_DISP  0x01 -#define DISP_REQUIRED 0x02 -#define NO_DISP       0x03 - -static const ind_addr_type tic30_indaddr_tab[] = { -  { "*+ar",       PreDisp_Add,        IMPLIED_DISP }, -  { "*-ar",       PreDisp_Sub,        IMPLIED_DISP }, -  { "*++ar",      PreDisp_Add_Mod,    IMPLIED_DISP }, -  { "*--ar",      PreDisp_Sub_Mod,    IMPLIED_DISP }, -  { "*ar++",      PostDisp_Add_Mod,   IMPLIED_DISP }, -  { "*ar--",      PostDisp_Sub_Mod,   IMPLIED_DISP }, -  { "*ar++%",     PostDisp_Add_Circ,  IMPLIED_DISP }, -  { "*ar--%",     PostDisp_Sub_Circ,  IMPLIED_DISP }, -  { "*+ar()",     PreDisp_Add,        DISP_REQUIRED }, -  { "*-ar()",     PreDisp_Sub,        DISP_REQUIRED }, -  { "*++ar()",    PreDisp_Add_Mod,    DISP_REQUIRED }, -  { "*--ar()",    PreDisp_Sub_Mod,    DISP_REQUIRED }, -  { "*ar++()",    PostDisp_Add_Mod,   DISP_REQUIRED }, -  { "*ar--()",    PostDisp_Sub_Mod,   DISP_REQUIRED }, -  { "*ar++()%",   PostDisp_Add_Circ,  DISP_REQUIRED }, -  { "*ar--()%",   PostDisp_Sub_Circ,  DISP_REQUIRED }, -  { "*+ar(ir0)",  PreIR0_Add,         NO_DISP }, -  { "*-ar(ir0)",  PreIR0_Sub,         NO_DISP }, -  { "*++ar(ir0)", PreIR0_Add_Mod,     NO_DISP }, -  { "*--ar(ir0)", PreIR0_Sub_Mod,     NO_DISP }, -  { "*ar++(ir0)", PostIR0_Add_Mod,    NO_DISP }, -  { "*ar--(ir0)", PostIR0_Sub_Mod,    NO_DISP }, -  { "*ar++(ir0)%",PostIR0_Add_Circ,   NO_DISP }, -  { "*ar--(ir0)%",PostIR0_Sub_Circ,   NO_DISP }, -  { "*+ar(ir1)",  PreIR1_Add,         NO_DISP }, -  { "*-ar(ir1)",  PreIR1_Sub,         NO_DISP }, -  { "*++ar(ir1)", PreIR1_Add_Mod,     NO_DISP }, -  { "*--ar(ir1)", PreIR1_Sub_Mod,     NO_DISP }, -  { "*ar++(ir1)", PostIR1_Add_Mod,    NO_DISP }, -  { "*ar--(ir1)", PostIR1_Sub_Mod,    NO_DISP }, -  { "*ar++(ir1)%",PostIR1_Add_Circ,   NO_DISP }, -  { "*ar--(ir1)%",PostIR1_Sub_Circ,   NO_DISP }, -  { "*ar",        IndirectOnly,       NO_DISP }, -  { "*ar++(ir0)b",PostIR0_Add_BitRev, NO_DISP }, -  { "",           0,0 } -}; - -static const ind_addr_type *const tic30_indaddrtab_end -  = tic30_indaddr_tab + sizeof(tic30_indaddr_tab)/sizeof(tic30_indaddr_tab[0]); - -/* Possible operand types */ -/* Register types */ -#define Rn       0x0001 -#define ARn      0x0002 -#define DPReg    0x0004 -#define OtherReg 0x0008 -/* Addressing mode types */ -#define Direct   0x0010 -#define Indirect 0x0020 -#define Imm16    0x0040 -#define Disp     0x0080 -#define Imm24    0x0100 -#define Abs24    0x0200 -/* 3 operand addressing mode types */ -#define op3T1    0x0400 -#define op3T2    0x0800 -/* Interrupt vector */ -#define IVector  0x1000 -/* Not required */ -#define NotReq   0x2000 - -#define GAddr1   Rn | Direct | Indirect | Imm16 -#define GAddr2   GAddr1 | AllReg -#define TAddr1   op3T1 | Rn | Indirect -#define TAddr2   op3T2 | Rn | Indirect -#define Reg      Rn | ARn -#define AllReg   Reg | DPReg | OtherReg - -typedef struct _template -{ -  char *name; -  unsigned int operands; /* how many operands */ -  unsigned int base_opcode; /* base_opcode is the fundamental opcode byte */ -  /* the bits in opcode_modifier are used to generate the final opcode from -     the base_opcode.  These bits also are used to detect alternate forms of -     the same instruction */ -  unsigned int opcode_modifier; - -  /* opcode_modifier bits: */ -#define AddressMode 0x00600000 -#define PCRel       0x02000000 -#define StackOp     0x001F0000 -#define Rotate      StackOp -   -  /* operand_types[i] describes the type of operand i.  This is made -     by OR'ing together all of the possible type masks.  (e.g. -     'operand_types[i] = Reg|Imm' specifies that operand i can be -     either a register or an immediate operand */ -  unsigned int operand_types[3]; -  /* This defines the number type of an immediate argument to an instruction. */ -  int imm_arg_type; -#define Imm_None  0 -#define Imm_Float 1 -#define Imm_SInt  2 -#define Imm_UInt  3 -} -template; - -static const template tic30_optab[] = { -  { "absf"   ,2,0x00000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "absi"   ,2,0x00800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "addc"   ,2,0x01000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "addc3"  ,3,0x20000000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "addf"   ,2,0x01800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "addf3"  ,3,0x20800000,AddressMode, { TAddr1, TAddr2, Rn }, Imm_None }, -  { "addi"   ,2,0x02000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "addi3"  ,3,0x21000000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "and"    ,2,0x02800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_UInt }, -  { "and3"   ,3,0x21800000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "andn"   ,2,0x03000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_UInt }, -  { "andn3"  ,3,0x22000000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "ash"    ,2,0x03800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ash3"   ,3,0x22800000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "b"      ,1,0x68000000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bu"     ,1,0x68000000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "blo"    ,1,0x68010000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bls"    ,1,0x68020000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bhi"    ,1,0x68030000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bhs"    ,1,0x68040000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "beq"    ,1,0x68050000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bne"    ,1,0x68060000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "blt"    ,1,0x68070000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "ble"    ,1,0x68080000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bgt"    ,1,0x68090000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bge"    ,1,0x680A0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bz"     ,1,0x68050000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnz"    ,1,0x68060000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bp"     ,1,0x68090000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bn"     ,1,0x68070000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnn"    ,1,0x680A0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnv"    ,1,0x680C0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bv"     ,1,0x680D0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnuf"   ,1,0x680E0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "buf"    ,1,0x680F0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnc"    ,1,0x68040000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bc"     ,1,0x68010000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnlv"   ,1,0x68100000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "blv"    ,1,0x68110000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnluf"  ,1,0x68120000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bluf"   ,1,0x68130000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bzuf"   ,1,0x68140000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bd"     ,1,0x68200000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bud"    ,1,0x68200000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "blod"   ,1,0x68210000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "blsd"   ,1,0x68220000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bhid"   ,1,0x68230000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bhsd"   ,1,0x68240000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "beqd"   ,1,0x68250000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bned"   ,1,0x68260000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bltd"   ,1,0x68270000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bled"   ,1,0x68280000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bgtd"   ,1,0x68290000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bged"   ,1,0x682A0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bzd"    ,1,0x68250000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnzd"   ,1,0x68260000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bpd"    ,1,0x68290000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnd"    ,1,0x68270000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnnd"   ,1,0x682A0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnvd"   ,1,0x682C0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bvd"    ,1,0x682D0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnufd"  ,1,0x682E0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bufd"   ,1,0x682F0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bncd"   ,1,0x68240000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bcd"    ,1,0x68210000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnlvd"  ,1,0x68300000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "blvd"   ,1,0x68310000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bnlufd" ,1,0x68320000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "blufd"  ,1,0x68330000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "bzufd"  ,1,0x68340000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_None }, -  { "br"     ,1,0x60000000,0,           { Imm24, 0, 0 }, Imm_UInt }, -  { "brd"    ,1,0x61000000,0,           { Imm24, 0, 0 }, Imm_UInt }, -  { "call"   ,1,0x62000000,0,           { Imm24, 0, 0 }, Imm_UInt }, -  { "callu"  ,1,0x70000000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "calllo" ,1,0x70010000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callls" ,1,0x70020000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callhi" ,1,0x70030000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callhs" ,1,0x70040000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "calleq" ,1,0x70050000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callne" ,1,0x70060000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "calllt" ,1,0x70070000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callle" ,1,0x70080000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callgt" ,1,0x70090000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callge" ,1,0x700A0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callz"  ,1,0x70050000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callnz" ,1,0x70060000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callp"  ,1,0x70090000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "calln"  ,1,0x70070000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callnn" ,1,0x700A0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callnv" ,1,0x700C0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callv"  ,1,0x700D0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callnuf",1,0x700E0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "calluf" ,1,0x700F0000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callnc" ,1,0x70040000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callc"  ,1,0x70010000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callnlv",1,0x70100000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "calllv" ,1,0x70110000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callnluf",1,0x70120000,PCRel,      { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callluf",1,0x70130000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "callzuf",1,0x70140000,PCRel,       { AllReg|Disp, 0, 0 }, Imm_UInt }, -  { "cmpf"   ,2,0x04000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "cmpf3"  ,2,0x23000000,AddressMode, { TAddr1, TAddr2, 0 }, Imm_None }, -  { "cmpi"   ,2,0x04800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "cmpi3"  ,2,0x23800000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, 0 }, Imm_None }, -  { "db"     ,2,0x6C000000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbu"    ,2,0x6C000000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dblo"   ,2,0x6C010000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbls"   ,2,0x6C020000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbhi"   ,2,0x6C030000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbhs"   ,2,0x6C040000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbeq"   ,2,0x6C050000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbne"   ,2,0x6C060000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dblt"   ,2,0x6C070000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dble"   ,2,0x6C080000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbgt"   ,2,0x6C090000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbge"   ,2,0x6C0A0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbz"    ,2,0x6C050000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnz"   ,2,0x6C060000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbp"    ,2,0x6C090000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbn"    ,2,0x6C070000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnn"   ,2,0x6C0A0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnv"   ,2,0x6C0C0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbv"    ,2,0x6C0D0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnuf"  ,2,0x6C0E0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbuf"   ,2,0x6C0F0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnc"   ,2,0x6C040000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbc"    ,2,0x6C010000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnlv"  ,2,0x6C100000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dblv"   ,2,0x6C110000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnluf" ,2,0x6C120000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbluf"  ,2,0x6C130000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbzuf"  ,2,0x6C140000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbd"    ,2,0x6C200000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbud"   ,2,0x6C200000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dblod"  ,2,0x6C210000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dblsd"  ,2,0x6C220000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbhid"  ,2,0x6C230000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbhsd"  ,2,0x6C240000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbeqd"  ,2,0x6C250000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbned"  ,2,0x6C260000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbltd"  ,2,0x6C270000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbled"  ,2,0x6C280000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbgtd"  ,2,0x6C290000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbged"  ,2,0x6C2A0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbzd"   ,2,0x6C250000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnzd"  ,2,0x6C260000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbpd"   ,2,0x6C290000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnd"   ,2,0x6C270000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnnd"  ,2,0x6C2A0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnvd"  ,2,0x6C2C0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbvd"   ,2,0x6C2D0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnufd" ,2,0x6C2E0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbufd"  ,2,0x6C2F0000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbncd"  ,2,0x6C240000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbcd"   ,2,0x6C210000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnlvd" ,2,0x6C300000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dblvd"  ,2,0x6C310000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbnlufd",2,0x6C320000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dblufd" ,2,0x6C330000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "dbzufd" ,2,0x6C340000,PCRel,       { ARn, AllReg|Disp, 0 }, Imm_None }, -  { "fix"    ,2,0x05000000,AddressMode, { GAddr1, AllReg, 0 }, Imm_Float }, -  { "float"  ,2,0x05800000,AddressMode, { GAddr2, Rn, 0 }, Imm_SInt }, -  { "iack"   ,1,0x1B000000,AddressMode, { Direct|Indirect, 0, 0 }, Imm_None }, -  { "idle"   ,0,0x06000000,0,           { 0, 0, 0 }, Imm_None }, -  { "idle2"  ,0,0x06000001,0,           { 0, 0, 0 }, Imm_None }, /* LC31 Only */ -  { "lde"    ,2,0x06800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldf"    ,2,0x07000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfu"   ,2,0x40000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldflo"  ,2,0x40800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfls"  ,2,0x41000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfhi"  ,2,0x41800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfhs"  ,2,0x42000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfeq"  ,2,0x42800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfne"  ,2,0x43000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldflt"  ,2,0x43800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfle"  ,2,0x44000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfgt"  ,2,0x44800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfge"  ,2,0x45000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfz"   ,2,0x42800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfnz"  ,2,0x43000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfp"   ,2,0x44800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfn"   ,2,0x43800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfnn"  ,2,0x45000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfnv"  ,2,0x46000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfv"   ,2,0x46800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfnuf" ,2,0x47000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfuf"  ,2,0x47800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfnc"  ,2,0x42000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfc"   ,2,0x40800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfnlv" ,2,0x48000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldflv"  ,2,0x48800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfnluf",2,0x49000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfluf" ,2,0x49800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfzuf" ,2,0x4A000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldfi"   ,2,0x07800000,AddressMode, { Direct|Indirect, Rn, 0 }, Imm_None }, -  { "ldi"    ,2,0x08000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldiu"   ,2,0x50000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldilo"  ,2,0x50800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldils"  ,2,0x51000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldihi"  ,2,0x51800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldihs"  ,2,0x52000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldieq"  ,2,0x52800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldine"  ,2,0x53000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldilt"  ,2,0x53800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldile"  ,2,0x54000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldigt"  ,2,0x54800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldige"  ,2,0x55000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldiz"   ,2,0x52800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldinz"  ,2,0x53000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldip"   ,2,0x54800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldin"   ,2,0x53800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldinn"  ,2,0x55000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldinv"  ,2,0x56000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldiv"   ,2,0x56800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldinuf" ,2,0x57000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldiuf"  ,2,0x57800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldinc"  ,2,0x52000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldic"   ,2,0x50800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldinlv" ,2,0x58000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldilv"  ,2,0x58800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldinluf",2,0x59000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldiluf" ,2,0x59800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldizuf" ,2,0x5A000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "ldii"   ,2,0x08800000,AddressMode, { Direct|Indirect, AllReg, 0 }, Imm_None }, -  { "ldm"    ,2,0x09000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "ldp"    ,2,0x08700000,0,           { Abs24|Direct, DPReg|NotReq, 0 }, Imm_UInt }, -  { "lopower",0,0x10800001,0,           { 0, 0, 0 }, Imm_None }, /* LC31 Only */ -  { "lsh"    ,2,0x09800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_UInt }, -  { "lsh3"   ,3,0x24000000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "maxspeed",0,0x10800000,0,          { 0, 0, 0 }, Imm_None }, /* LC31 Only */ -  { "mpyf"   ,2,0x0A000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "mpyf3"  ,3,0x24800000,AddressMode, { TAddr1, TAddr2, Rn }, Imm_None }, -  { "mpyi"   ,2,0x0A800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "mpyi3"  ,3,0x25000000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "negb"   ,2,0x0B000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "negf"   ,2,0x0B800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "negi"   ,2,0x0C000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "nop"    ,1,0x0C800000,AddressMode, { AllReg|Indirect|NotReq, 0, 0 }, Imm_None }, -  { "norm"   ,2,0x0D000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, /*Check another source*/ -  { "not"    ,2,0x0D800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_UInt }, -  { "or"     ,2,0x10000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_UInt }, -  { "or3"    ,3,0x25800000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "pop"    ,1,0x0E200000,StackOp,     { AllReg, 0, 0 }, Imm_None }, -  { "popf"   ,1,0x0EA00000,StackOp,     { Rn, 0, 0 }, Imm_None }, -  { "push"   ,1,0x0F200000,StackOp,     { AllReg, 0, 0 }, Imm_None }, -  { "pushf"  ,1,0x0FA00000,StackOp,     { Rn, 0, 0 }, Imm_None }, -  { "reti"   ,0,0x78000000,0,           { 0, 0, 0 }, Imm_None }, -  { "retiu"  ,0,0x78000000,0,           { 0, 0, 0 }, Imm_None }, -  { "retilo" ,0,0x78010000,0,           { 0, 0, 0 }, Imm_None }, -  { "retils" ,0,0x78020000,0,           { 0, 0, 0 }, Imm_None }, -  { "retihi" ,0,0x78030000,0,           { 0, 0, 0 }, Imm_None }, -  { "retihs" ,0,0x78040000,0,           { 0, 0, 0 }, Imm_None }, -  { "retieq" ,0,0x78050000,0,           { 0, 0, 0 }, Imm_None }, -  { "retine" ,0,0x78060000,0,           { 0, 0, 0 }, Imm_None }, -  { "retilt" ,0,0x78070000,0,           { 0, 0, 0 }, Imm_None }, -  { "retile" ,0,0x78080000,0,           { 0, 0, 0 }, Imm_None }, -  { "retigt" ,0,0x78090000,0,           { 0, 0, 0 }, Imm_None }, -  { "retige" ,0,0x780A0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retiz"  ,0,0x78050000,0,           { 0, 0, 0 }, Imm_None }, -  { "retinz" ,0,0x78060000,0,           { 0, 0, 0 }, Imm_None }, -  { "retip"  ,0,0x78090000,0,           { 0, 0, 0 }, Imm_None }, -  { "retin"  ,0,0x78070000,0,           { 0, 0, 0 }, Imm_None }, -  { "retinn" ,0,0x780A0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retinv" ,0,0x780C0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retiv"  ,0,0x780D0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retinuf",0,0x780E0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retiuf" ,0,0x780F0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retinc" ,0,0x78040000,0,           { 0, 0, 0 }, Imm_None }, -  { "retic"  ,0,0x78010000,0,           { 0, 0, 0 }, Imm_None }, -  { "retinlv",0,0x78100000,0,           { 0, 0, 0 }, Imm_None }, -  { "retilv" ,0,0x78110000,0,           { 0, 0, 0 }, Imm_None }, -  { "retinluf",0,0x78120000,0,          { 0, 0, 0 }, Imm_None }, -  { "retiluf",0,0x78130000,0,           { 0, 0, 0 }, Imm_None }, -  { "retizuf",0,0x78140000,0,           { 0, 0, 0 }, Imm_None }, -  { "rets"   ,0,0x78800000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsu"  ,0,0x78800000,0,           { 0, 0, 0 }, Imm_None }, -  { "retslo" ,0,0x78810000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsls" ,0,0x78820000,0,           { 0, 0, 0 }, Imm_None }, -  { "retshi" ,0,0x78830000,0,           { 0, 0, 0 }, Imm_None }, -  { "retshs" ,0,0x78840000,0,           { 0, 0, 0 }, Imm_None }, -  { "retseq" ,0,0x78850000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsne" ,0,0x78860000,0,           { 0, 0, 0 }, Imm_None }, -  { "retslt" ,0,0x78870000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsle" ,0,0x78880000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsgt" ,0,0x78890000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsge" ,0,0x788A0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsz"  ,0,0x78850000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsnz" ,0,0x78860000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsp"  ,0,0x78890000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsn"  ,0,0x78870000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsnn" ,0,0x788A0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsnv" ,0,0x788C0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsv"  ,0,0x788D0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsnuf",0,0x788E0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsuf" ,0,0x788F0000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsnc" ,0,0x78840000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsc"  ,0,0x78810000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsnlv",0,0x78900000,0,           { 0, 0, 0 }, Imm_None }, -  { "retslv" ,0,0x78910000,0,           { 0, 0, 0 }, Imm_None }, -  { "retsnluf",0,0x78920000,0,          { 0, 0, 0 }, Imm_None }, -  { "retsluf",0,0x78930000,0,           { 0, 0, 0 }, Imm_None }, -  { "retszuf",0,0x78940000,0,           { 0, 0, 0 }, Imm_None }, -  { "rnd"    ,2,0x11000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "rol"    ,1,0x11E00001,Rotate,      { AllReg, 0, 0 }, Imm_None }, -  { "rolc"   ,1,0x12600001,Rotate,      { AllReg, 0, 0 }, Imm_None }, -  { "ror"    ,1,0x12E0FFFF,Rotate,      { AllReg, 0, 0 }, Imm_None }, -  { "rorc"   ,1,0x1360FFFF,Rotate,      { AllReg, 0, 0 }, Imm_None }, -  { "rptb"   ,1,0x64000000,0,           { Imm24, 0, 0 }, Imm_UInt }, -  { "rpts"   ,1,0x139B0000,AddressMode, { GAddr2, 0, 0 }, Imm_UInt }, -  { "sigi"   ,0,0x16000000,0,           { 0, 0, 0 }, Imm_None }, -  { "stf"    ,2,0x14000000,AddressMode, { Rn, Direct|Indirect, 0 }, Imm_Float }, -  { "stfi"   ,2,0x14800000,AddressMode, { Rn, Direct|Indirect, 0 }, Imm_Float }, -  { "sti"    ,2,0x15000000,AddressMode, { AllReg, Direct|Indirect, 0 }, Imm_SInt }, -  { "stii"   ,2,0x15800000,AddressMode, { AllReg, Direct|Indirect, 0 }, Imm_SInt }, -  { "subb"   ,2,0x16800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "subb3"  ,3,0x26000000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "subc"   ,2,0x17000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_UInt }, -  { "subf"   ,2,0x17800000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "subf3"  ,3,0x26800000,AddressMode, { TAddr1, TAddr2, Rn }, Imm_None }, -  { "subi"   ,2,0x18000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "subi3"  ,3,0x27000000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { "subrb"  ,2,0x18800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "subrf"  ,2,0x19000000,AddressMode, { GAddr1, Rn, 0 }, Imm_Float }, -  { "subri"  ,2,0x19800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_SInt }, -  { "swi"    ,0,0x66000000,0,           { 0, 0, 0 }, Imm_None }, -  { "trap"   ,1,0x74800020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapu"  ,1,0x74800020,0,           { IVector, 0, 0 }, Imm_None }, -  { "traplo" ,1,0x74810020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapls" ,1,0x74820020,0,           { IVector, 0, 0 }, Imm_None }, -  { "traphi" ,1,0x74830020,0,           { IVector, 0, 0 }, Imm_None }, -  { "traphs" ,1,0x74840020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapeq" ,1,0x74850020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapne" ,1,0x74860020,0,           { IVector, 0, 0 }, Imm_None }, -  { "traplt" ,1,0x74870020,0,           { IVector, 0, 0 }, Imm_None }, -  { "traple" ,1,0x74880020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapgt" ,1,0x74890020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapge" ,1,0x748A0020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapz"  ,1,0x74850020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapnz" ,1,0x74860020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapp"  ,1,0x74890020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapn"  ,1,0x74870020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapnn" ,1,0x748A0020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapnv" ,1,0x748C0020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapv"  ,1,0x748D0020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapnuf",1,0x748E0020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapuf" ,1,0x748F0020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapnc" ,1,0x74840020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapc"  ,1,0x74810020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapnlv",1,0x74900020,0,           { IVector, 0, 0 }, Imm_None }, -  { "traplv" ,1,0x74910020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapnluf",1,0x74920020,0,          { IVector, 0, 0 }, Imm_None }, -  { "trapluf",1,0x74930020,0,           { IVector, 0, 0 }, Imm_None }, -  { "trapzuf",1,0x74940020,0,           { IVector, 0, 0 }, Imm_None }, -  { "tstb"   ,2,0x1A000000,AddressMode, { GAddr2, AllReg, 0 }, Imm_UInt }, -  { "tstb3"  ,2,0x27800000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, 0 }, Imm_None }, -  { "xor"    ,2,0x1A800000,AddressMode, { GAddr2, AllReg, 0 }, Imm_UInt }, -  { "xor3"   ,3,0x28000000,AddressMode, { TAddr1|AllReg, TAddr2|AllReg, AllReg }, Imm_None }, -  { ""       ,0,0x00000000,0,           { 0, 0, 0 }, 0 } -}; - -static const template *const tic30_optab_end = -  tic30_optab + sizeof(tic30_optab)/sizeof(tic30_optab[0]); - -typedef struct { -  char *name; -  unsigned int operands_1; -  unsigned int operands_2; -  unsigned int base_opcode; -  unsigned int operand_types[2][3]; -  /* Which operand fits into which part of the final opcode word. */ -  int oporder; -} partemplate; - -/* oporder defines - not very descriptive. */ -#define OO_4op1   0 -#define OO_4op2   1 -#define OO_4op3   2 -#define OO_5op1   3 -#define OO_5op2   4 -#define OO_PField 5 - -static const partemplate tic30_paroptab[] = { -  { "q_absf_stf",   2,2,0xC8000000, { { Indirect, Rn, 0 }, { Rn, Indirect, 0 } }, -	OO_4op1 }, -  { "q_absi_sti",   2,2,0xCA000000, { { Indirect, Rn, 0 }, { Rn, Indirect, 0 } }, -	OO_4op1 }, -  { "q_addf3_stf",  3,2,0xCC000000, { { Indirect, Rn, Rn }, { Rn, Indirect, 0 } }, -	OO_5op1 }, -  { "q_addi3_sti",  3,2,0xCE000000, { { Indirect, Rn, Rn }, { Rn, Indirect, 0 } }, -	OO_5op1 }, -  { "q_and3_sti",   3,2,0xD0000000, { { Indirect, Rn, Rn }, { Rn, Indirect, 0 } }, -	OO_5op1 }, -  { "q_ash3_sti",   3,2,0xD2000000, { { Rn, Indirect, Rn }, { Rn, Indirect, 0 } }, -	OO_5op2 }, -  { "q_fix_sti",    2,2,0xD4000000, { { Indirect, Rn, 0 }, { Rn, Indirect, 0 } }, -	OO_4op1 }, -  { "q_float_stf",  2,2,0xD6000000, { { Indirect, Rn, 0 }, { Rn, Indirect, 0 } }, -	OO_4op1 }, -  { "q_ldf_ldf",    2,2,0xC4000000, { { Indirect, Rn, 0 }, { Indirect, Rn, 0 } }, -	OO_4op2 }, -  { "q_ldf_stf",    2,2,0xD8000000, { { Indirect, Rn, 0 }, { Rn, Indirect, 0 } }, -	OO_4op1 }, -  { "q_ldi_ldi",    2,2,0xC6000000, { { Indirect, Rn, 0 }, { Indirect, Rn, 0 } }, -	OO_4op2 }, -  { "q_ldi_sti",    2,2,0xDA000000, { { Indirect, Rn, 0 }, { Rn, Indirect, 0 } }, -	OO_4op1 }, -  { "q_lsh3_sti",   3,2,0xDC000000, { { Rn, Indirect, Rn }, { Rn, Indirect, 0 } }, -	OO_5op2 }, -  { "q_mpyf3_addf3",3,3,0x80000000, { { Rn | Indirect, Rn | Indirect, Rn }, - 	                              { Rn | Indirect, Rn | Indirect, Rn } }, OO_PField }, -  { "q_mpyf3_stf",  3,2,0xDE000000, { { Indirect, Rn, Rn }, { Rn, Indirect, 0 } }, -	OO_5op1 }, -  { "q_mpyf3_subf3",3,3,0x84000000, { { Rn | Indirect, Rn | Indirect, Rn }, -	                              { Rn | Indirect, Rn | Indirect, Rn } }, OO_PField }, -  { "q_mpyi3_addi3",3,3,0x88000000, { { Rn | Indirect, Rn | Indirect, Rn }, -	                              { Rn | Indirect, Rn | Indirect, Rn } }, OO_PField }, -  { "q_mpyi3_sti",  3,2,0xE0000000, { { Indirect, Rn, Rn }, { Rn, Indirect, 0 } }, -	OO_5op1 }, -  { "q_mpyi3_subi3",3,3,0x8C000000, { { Rn | Indirect, Rn | Indirect, Rn }, -	                              { Rn | Indirect, Rn | Indirect, Rn } }, OO_PField }, -  { "q_negf_stf",   2,2,0xE2000000, { { Indirect, Rn, 0 }, { Rn, Indirect, 0 } }, -	OO_4op1 }, -  { "q_negi_sti",   2,2,0xE4000000, { { Indirect, Rn, 0 }, { Rn, Indirect, 0 } }, -	OO_4op1 }, -  { "q_not_sti",    2,2,0xE6000000, { { Indirect, Rn, 0 }, { Rn, Indirect, 0 } }, -	OO_4op1 }, -  { "q_or3_sti",    3,2,0xE8000000, { { Indirect, Rn, Rn }, { Rn, Indirect, 0 } }, -	OO_5op1 }, -  { "q_stf_stf",    2,2,0xC0000000, { { Rn, Indirect, 0 }, { Rn, Indirect, 0 } }, -	OO_4op3 }, -  { "q_sti_sti",    2,2,0xC2000000, { { Rn, Indirect, 0 }, { Rn, Indirect, 0 } }, -	OO_4op3 }, -  { "q_subf3_stf",  3,2,0xEA000000, { { Rn, Indirect, Rn }, { Rn, Indirect, 0 } }, -	OO_5op2 }, -  { "q_subi3_sti",  3,2,0xEC000000, { { Rn, Indirect, Rn }, { Rn, Indirect, 0 } }, -	OO_5op2 }, -  { "q_xor3_sti",   3,2,0xEE000000, { { Indirect, Rn, Rn }, { Rn, Indirect, 0 } }, -	OO_5op1 }, -  { "",             0,0,0x00000000, { { 0, 0, 0 }, { 0, 0, 0 } }, 0 } -}; - -static const partemplate *const tic30_paroptab_end = -  tic30_paroptab + sizeof(tic30_paroptab)/sizeof(tic30_paroptab[0]); - -#endif diff --git a/contrib/binutils/include/opcode/v850.h b/contrib/binutils/include/opcode/v850.h deleted file mode 100644 index 0c10adeb84b9..000000000000 --- a/contrib/binutils/include/opcode/v850.h +++ /dev/null @@ -1,154 +0,0 @@ -/* v850.h -- Header file for NEC V850 opcode table -   Copyright 1996 Free Software Foundation, Inc. -   Written by J.T. Conklin, Cygnus Support - -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 -1, 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.  */ - -#ifndef V850_H -#define V850_H - -/* The opcode table is an array of struct v850_opcode.  */ - -struct v850_opcode -{ -  /* The opcode name.  */ -  const char *name; - -  /* The opcode itself.  Those bits which will be filled in with -     operands are zeroes.  */ -  unsigned long opcode; - -  /* The opcode mask.  This is used by the disassembler.  This is a -     mask containing ones indicating those bits which must match the -     opcode field, and zeroes indicating those bits which need not -     match (and are presumably filled in by operands).  */ -  unsigned long mask; - -  /* An array of operand codes.  Each code is an index into the -     operand table.  They appear in the order which the operands must -     appear in assembly code, and are terminated by a zero.  */ -  unsigned char operands[8]; - -  /* Which (if any) operand is a memory operand.  */ -  unsigned int memop; - -  /* Target processor(s).  A bit field of processors which support -     this instruction.  Note a bit field is used as some instructions -     are available on multiple, different processor types, whereas -     other instructions are only available on one specific type.  */ -  unsigned int processors; -}; - -/* Values for the processors field in the v850_opcode structure.  */ -#define PROCESSOR_V850		(1 << 0)		/* Just the V850.  */ -#define PROCESSOR_ALL		-1			/* Any processor.  */ - -/* The table itself is sorted by major opcode number, and is otherwise -   in the order in which the disassembler should consider -   instructions.  */ -extern const struct v850_opcode v850_opcodes[]; -extern const int v850_num_opcodes; - - -/* The operands table is an array of struct v850_operand.  */ - -struct v850_operand -{ -  /* The number of bits in the operand.  */ -  /* If this value is -1 then the operand's bits are in a discontinous distribution in the instruction. */ -  int bits; - -  /* (bits >= 0):  How far the operand is left shifted in the instruction.  */ -  /* (bits == -1): Bit mask of the bits in the operand.  */ -  int shift; - -  /* Insertion function.  This is used by the assembler.  To insert an -     operand value into an instruction, check this field. - -     If it is NULL, execute -         i |= (op & ((1 << o->bits) - 1)) << o->shift; -     (i is the instruction which we are filling in, o is a pointer to -     this structure, and op is the opcode value; this assumes twos -     complement arithmetic). - -     If this field is not NULL, then simply call it with the -     instruction and the operand value.  It will return the new value -     of the instruction.  If the ERRMSG argument is not NULL, then if -     the operand value is illegal, *ERRMSG will be set to a warning -     string (the operand will be inserted in any case).  If the -     operand value is legal, *ERRMSG will be unchanged (most operands -     can accept any value).  */ -  unsigned long (* insert) PARAMS ((unsigned long instruction, long op, -				   const char ** errmsg)); - -  /* Extraction function.  This is used by the disassembler.  To -     extract this operand type from an instruction, check this field. - -     If it is NULL, compute -         op = o->bits == -1 ? ((i) & o->shift) : ((i) >> o->shift) & ((1 << o->bits) - 1); -	 if (o->flags & V850_OPERAND_SIGNED) -	     op = (op << (32 - o->bits)) >> (32 - o->bits); -     (i is the instruction, o is a pointer to this structure, and op -     is the result; this assumes twos complement arithmetic). - -     If this field is not NULL, then simply call it with the -     instruction value.  It will return the value of the operand.  If -     the INVALID argument is not NULL, *INVALID will be set to -     non-zero if this operand type can not actually be extracted from -     this operand (i.e., the instruction does not match).  If the -     operand is valid, *INVALID will not be changed.  */ -  unsigned long (* extract) PARAMS ((unsigned long instruction, int * invalid)); - -  /* One bit syntax flags.  */ -  int flags; -}; - -/* Elements in the table are retrieved by indexing with values from -   the operands field of the v850_opcodes table.  */ - -extern const struct v850_operand v850_operands[]; - -/* Values defined for the flags field of a struct v850_operand.  */ - -/* This operand names a general purpose register */ -#define V850_OPERAND_REG	0x01 - -/* This operand names a system register */ -#define V850_OPERAND_SRG	0x02 - -/* This operand names a condition code used in the setf instruction */ -#define V850_OPERAND_CC		0x04 - -/* This operand takes signed values */ -#define V850_OPERAND_SIGNED	0x08 - -/* This operand is the ep register.  */ -#define V850_OPERAND_EP		0x10 - -/* This operand is a PC displacement */ -#define V850_OPERAND_DISP	0x20 - -/* This is a relaxable operand.   Only used for D9->D22 branch relaxing -   right now.  We may need others in the future (or maybe handle them like -   promoted operands on the mn10300?)  */ -#define V850_OPERAND_RELAX	0x40 - -/* The register specified must not be r0 */ -#define V850_NOT_R0	        0x80 - - -#endif /* V850_H */ | 
