Updated ARC assembler from arccores.com
This commit is contained in:
		| @@ -1,3 +1,7 @@ | |||||||
|  | 2001-01-11  Peter Targett  <peter.targett@arccores.com> | ||||||
|  |  | ||||||
|  | 	* dis-asm.h (arc_get_disassembler): Correct declaration. | ||||||
|  |  | ||||||
| 2001-01-09  Philip Blundell  <philb@gnu.org> | 2001-01-09  Philip Blundell  <philb@gnu.org> | ||||||
|  |  | ||||||
| 	* bin-bugs.h (REPORT_BUGS_TO): Set to `bug-binutils@gnu.org'. | 	* bin-bugs.h (REPORT_BUGS_TO): Set to `bug-binutils@gnu.org'. | ||||||
|   | |||||||
| @@ -174,7 +174,7 @@ extern int print_insn_h8300h		PARAMS ((bfd_vma, disassemble_info*)); | |||||||
| extern int print_insn_h8300s		PARAMS ((bfd_vma, disassemble_info*)); | extern int print_insn_h8300s		PARAMS ((bfd_vma, disassemble_info*)); | ||||||
| extern int print_insn_h8500		PARAMS ((bfd_vma, disassemble_info*)); | extern int print_insn_h8500		PARAMS ((bfd_vma, disassemble_info*)); | ||||||
| extern int print_insn_alpha		PARAMS ((bfd_vma, disassemble_info*)); | extern int print_insn_alpha		PARAMS ((bfd_vma, disassemble_info*)); | ||||||
| extern disassembler_ftype arc_get_disassembler PARAMS ((int, int)); | extern disassembler_ftype arc_get_disassembler PARAMS ((void *)); | ||||||
| extern int print_insn_big_arm		PARAMS ((bfd_vma, disassemble_info*)); | extern int print_insn_big_arm		PARAMS ((bfd_vma, disassemble_info*)); | ||||||
| extern int print_insn_little_arm	PARAMS ((bfd_vma, disassemble_info*)); | extern int print_insn_little_arm	PARAMS ((bfd_vma, disassemble_info*)); | ||||||
| extern int print_insn_sparc		PARAMS ((bfd_vma, disassemble_info*)); | extern int print_insn_sparc		PARAMS ((bfd_vma, disassemble_info*)); | ||||||
|   | |||||||
| @@ -1,8 +1,15 @@ | |||||||
|  | 2001-01-11  Peter Targett  <peter.targett@arccores.com> | ||||||
|  |  | ||||||
|  | 	* arc.h (E_ARC_MACH_ARC5, E_ARC_MACH_ARC6, E_ARC_MACH_ARC7, | ||||||
|  | 	E_ARC_MACH_ARC8): New definitions for cpu types. | ||||||
|  |  | ||||||
|  | 	* common.h (EM_ARC): Change comment. | ||||||
|  |  | ||||||
| 2000-12-12  Nick Clifton  <nickc@redhat.com> | 2000-12-12  Nick Clifton  <nickc@redhat.com> | ||||||
|  |  | ||||||
| 	* mips.h: Fix formatting. | 	* mips.h: Fix formatting. | ||||||
|  |  | ||||||
| Mon Dec 11 10:56:58 2000  Jeffrey A Law  (law@cygnus.com) | 2000-12-11  Jeffrey A Law  (law@cygnus.com) | ||||||
|  |  | ||||||
| 	* hppa.h (DT_HP_*): Define relative to OLD_DT_LOOS for hpux | 	* hppa.h (DT_HP_*): Define relative to OLD_DT_LOOS for hpux | ||||||
| 	compatibility. | 	compatibility. | ||||||
|   | |||||||
| @@ -26,6 +26,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */ | |||||||
| #include "elf/reloc-macros.h" | #include "elf/reloc-macros.h" | ||||||
|  |  | ||||||
| /* Relocations.  */ | /* Relocations.  */ | ||||||
|  |  | ||||||
| START_RELOC_NUMBERS (elf_arc_reloc_type) | START_RELOC_NUMBERS (elf_arc_reloc_type) | ||||||
|   RELOC_NUMBER (R_ARC_NONE, 0) |   RELOC_NUMBER (R_ARC_NONE, 0) | ||||||
|   RELOC_NUMBER (R_ARC_32, 1) |   RELOC_NUMBER (R_ARC_32, 1) | ||||||
| @@ -36,18 +37,20 @@ END_RELOC_NUMBERS (R_ARC_max) | |||||||
| /* Processor specific flags for the ELF header e_flags field.  */ | /* Processor specific flags for the ELF header e_flags field.  */ | ||||||
|  |  | ||||||
| /* Four bit ARC machine type field.  */ | /* Four bit ARC machine type field.  */ | ||||||
|  |  | ||||||
| #define EF_ARC_MACH 0x0000000f | #define EF_ARC_MACH 0x0000000f | ||||||
|  |  | ||||||
| /* Various CPU types.  */ | /* Various CPU types.  */ | ||||||
| #define E_ARC_MACH_BASE		0x00000000 |  | ||||||
| #define E_ARC_MACH_UNUSED1	0x00000001 |  | ||||||
| #define E_ARC_MACH_UNUSED2	0x00000002 |  | ||||||
| #define E_ARC_MACH_UNUSED4	0x00000003 |  | ||||||
|  |  | ||||||
| /* Leave bits 0xf0 alone in case we ever have more than 16 cpu types. | #define E_ARC_MACH_ARC5 0 | ||||||
|    Highly unlikely, but what the heck.  */ | #define E_ARC_MACH_ARC6 1	 | ||||||
|  | #define E_ARC_MACH_ARC7 2 | ||||||
|  | #define E_ARC_MACH_ARC8 3 | ||||||
|  |  | ||||||
|  | /* Leave bits 0xf0 alone in case we ever have more than 16 cpu types.  */ | ||||||
|  |  | ||||||
| /* File contains position independent code.  */ | /* File contains position independent code.  */ | ||||||
|  |  | ||||||
| #define EF_ARC_PIC 0x00000100 | #define EF_ARC_PIC 0x00000100 | ||||||
|  |  | ||||||
| #endif /* _ELF_ARC_H */ | #endif /* _ELF_ARC_H */ | ||||||
|   | |||||||
| @@ -125,7 +125,7 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */ | |||||||
| #define EM_SH	       42	/* Hitachi SH */ | #define EM_SH	       42	/* Hitachi SH */ | ||||||
| #define EM_SPARCV9     43	/* SPARC v9 64-bit */ | #define EM_SPARCV9     43	/* SPARC v9 64-bit */ | ||||||
| #define EM_TRICORE     44       /* Siemens Tricore embedded processor */ | #define EM_TRICORE     44       /* Siemens Tricore embedded processor */ | ||||||
| #define EM_ARC         45       /* Argonaut RISC Core, Argonaut Technologies Inc. */ | #define EM_ARC         45       /* ARC Cores */ | ||||||
| #define EM_H8_300      46       /* Hitachi H8/300 */ | #define EM_H8_300      46       /* Hitachi H8/300 */ | ||||||
| #define EM_H8_300H     47       /* Hitachi H8/300H */ | #define EM_H8_300H     47       /* Hitachi H8/300H */ | ||||||
| #define EM_H8S         48       /* Hitachi H8S */ | #define EM_H8S         48       /* Hitachi H8S */ | ||||||
|   | |||||||
| @@ -1,4 +1,12 @@ | |||||||
| Wed Jan 10 15:30:57 MET 2001  Jan Hubicka  <jh@suse.cz> | 2001-01-11  Peter Targett  <peter.targett@arccores.com> | ||||||
|  |  | ||||||
|  | 	* arc.h (ARC_MACH_5, ARC_MACH_6, ARC_MACH_7, ARC_MACH_8): New | ||||||
|  | 	definitions for masking cpu type. | ||||||
|  | 	(arc_ext_operand_value) New structure for storing extended | ||||||
|  | 	operands. | ||||||
|  | 	(ARC_OPERAND_*) Flags for operand values. | ||||||
|  |  | ||||||
|  | 2001-01-10  Jan Hubicka  <jh@suse.cz> | ||||||
|  |  | ||||||
| 	* i386.h (pinsrw): Add. | 	* i386.h (pinsrw): Add. | ||||||
| 	(pshufw): Remove. | 	(pshufw): Remove. | ||||||
| @@ -17,16 +25,16 @@ Wed Jan 10 15:30:57 MET 2001  Jan Hubicka  <jh@suse.cz> | |||||||
| 	(CGEN_SYNTAX): Changed to make array CGEN_SYNTAX_CHAR_TYPE. | 	(CGEN_SYNTAX): Changed to make array CGEN_SYNTAX_CHAR_TYPE. | ||||||
| 	(CGEN_SYNTAX_CHAR): Changed to cast to unsigned char. | 	(CGEN_SYNTAX_CHAR): Changed to cast to unsigned char. | ||||||
|  |  | ||||||
| Fri Jan  5 13:22:23 MET 2001  Jan Hubicka  <jh@suse.cz> | 2001-01-05  Jan Hubicka  <jh@suse.cz> | ||||||
|  |  | ||||||
| 	* i386.h (i386_optab): Make [sml]fence template to use immext field. | 	* i386.h (i386_optab): Make [sml]fence template to use immext field. | ||||||
|  |  | ||||||
| Wed Jan  3 16:27:15 MET 2001  Jan Hubicka  <jh@suse.cz> | 2001-01-03  Jan Hubicka  <jh@suse.cz> | ||||||
|  |  | ||||||
| 	* i386.h (i386_optab): Fix 64bit pushf template; Add instructions | 	* i386.h (i386_optab): Fix 64bit pushf template; Add instructions | ||||||
| 	introduced by Pentium4 | 	introduced by Pentium4 | ||||||
|  |  | ||||||
| Sat Dec 30 19:03:15 MET 2000  Jan Hubicka  <jh@suse.cz> | 2000-12-30  Jan Hubicka  <jh@suse.cz> | ||||||
|  |  | ||||||
| 	* i386.h (i386_optab): Add "rex*" instructions; | 	* i386.h (i386_optab): Add "rex*" instructions; | ||||||
| 	add swapgs; disable jmp/call far direct instructions for | 	add swapgs; disable jmp/call far direct instructions for | ||||||
| @@ -37,7 +45,7 @@ Sat Dec 30 19:03:15 MET 2000  Jan Hubicka  <jh@suse.cz> | |||||||
| 	(*Suf): Add No_qSuf. | 	(*Suf): Add No_qSuf. | ||||||
| 	(q_Suf, wlq_Suf, bwlq_Suf): New. | 	(q_Suf, wlq_Suf, bwlq_Suf): New. | ||||||
|  |  | ||||||
| Wed Dec 20 14:22:03 MET 2000  Jan Hubicka  <jh@suse.cz> | 2000-12-20  Jan Hubicka  <jh@suse.cz> | ||||||
|  |  | ||||||
| 	* i386.h (i386_optab): Replace "Imm" with "EncImm". | 	* i386.h (i386_optab): Replace "Imm" with "EncImm". | ||||||
| 	(i386_regtab): Add flags field. | 	(i386_regtab): Add flags field. | ||||||
|   | |||||||
| @@ -1,77 +1,90 @@ | |||||||
| /* Opcode table for the ARC. | /* Opcode table for the ARC. | ||||||
|    Copyright 1994, 1995, 1997 Free Software Foundation, Inc. |    Copyright 1994, 1995, 1997, 2000 Free Software Foundation, Inc. | ||||||
|    Contributed by Doug Evans (dje@cygnus.com). |    Contributed by Doug Evans (dje@cygnus.com). | ||||||
|  |  | ||||||
| This file is part of GAS, the GNU Assembler, GDB, the GNU debugger, and |    This file is part of GAS, the GNU Assembler, GDB, the GNU debugger, and | ||||||
| the GNU Binutils. |    the GNU Binutils. | ||||||
|  |  | ||||||
| GAS/GDB is free software; you can redistribute it and/or modify |    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 |    it under the terms of the GNU General Public License as published by | ||||||
| the Free Software Foundation; either version 2, or (at your option) |    the Free Software Foundation; either version 2, or (at your option) | ||||||
| any later version. |    any later version. | ||||||
|  |  | ||||||
| GAS/GDB is distributed in the hope that it will be useful, |    GAS/GDB is distributed in the hope that it will be useful, | ||||||
| but WITHOUT ANY WARRANTY; without even the implied warranty of |    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	See the |    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	See the | ||||||
| GNU General Public License for more details. |    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.  */ | ||||||
|  |  | ||||||
| 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. | /* List of the various cpu types. | ||||||
|    The tables currently use bit masks to say whether the instruction or |    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 |    whatever is supported by a particular cpu.  This lets us have one entry | ||||||
|    apply to several cpus. |    apply to several cpus. | ||||||
|  |  | ||||||
|    This duplicates bfd_mach_arc_xxx.  For now I wish to isolate this from bfd |    The `base' cpu must be 0. The cpu type is treated independently of | ||||||
|    and bfd from this.  Also note that these numbers are bit values as we want |    endianness. The complete `mach' number includes endianness. | ||||||
|    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.  */ |    These values are internal to opcodes/bfd/binutils/gas.  */ | ||||||
| #define ARC_MACH_BASE 0 | #define ARC_MACH_5 0 | ||||||
| #define ARC_MACH_UNUSED1 1 | #define ARC_MACH_6 1 | ||||||
| #define ARC_MACH_UNUSED2 2 | #define ARC_MACH_7 2 | ||||||
| #define ARC_MACH_UNUSED4 4 | #define ARC_MACH_8 4 | ||||||
|  |  | ||||||
| /* Additional cpu values can be inserted here and ARC_MACH_BIG moved down.  */ | /* Additional cpu values can be inserted here and ARC_MACH_BIG moved down.  */ | ||||||
| #define ARC_MACH_BIG 8 | #define ARC_MACH_BIG 16 | ||||||
|  |  | ||||||
| /* Mask of number of bits necessary to record cpu type.  */ | /* Mask of number of bits necessary to record cpu type.  */ | ||||||
| #define ARC_MACH_CPU_MASK 7 | #define ARC_MACH_CPU_MASK (ARC_MACH_BIG - 1) | ||||||
|  |  | ||||||
| /* Mask of number of bits necessary to record cpu type + endianness.  */ | /* Mask of number of bits necessary to record cpu type + endianness.  */ | ||||||
| #define ARC_MACH_MASK 15 | #define ARC_MACH_MASK ((ARC_MACH_BIG << 1) - 1) | ||||||
|  |  | ||||||
| /* Type to denote an ARC instruction (at least a 32 bit unsigned int).  */ | /* Type to denote an ARC instruction (at least a 32 bit unsigned int).  */ | ||||||
|  |  | ||||||
| typedef unsigned int arc_insn; | typedef unsigned int arc_insn; | ||||||
|  |  | ||||||
| struct arc_opcode { | struct arc_opcode { | ||||||
|   char *syntax;              /* syntax of insn  */ |   char *syntax;              /* syntax of insn  */ | ||||||
|   unsigned long mask, value;	/* recognize insn if (op&mask)==value */ |   unsigned long mask, value; /* recognize insn if (op&mask) == value  */ | ||||||
|   int flags;                 /* various flag bits  */ |   int flags;                 /* various flag bits  */ | ||||||
|  |  | ||||||
| /* Values for `flags'.  */ | /* Values for `flags'.  */ | ||||||
|  |  | ||||||
| /* Return CPU number, given flag bits.  */ | /* Return CPU number, given flag bits.  */ | ||||||
| #define ARC_OPCODE_CPU(bits) ((bits) & ARC_MACH_CPU_MASK) | #define ARC_OPCODE_CPU(bits) ((bits) & ARC_MACH_CPU_MASK) | ||||||
|  |  | ||||||
| /* Return MACH number, given flag bits.  */ | /* Return MACH number, given flag bits.  */ | ||||||
| #define ARC_OPCODE_MACH(bits) ((bits) & ARC_MACH_MASK) | #define ARC_OPCODE_MACH(bits) ((bits) & ARC_MACH_MASK) | ||||||
|  |  | ||||||
| /* First opcode flag bit available after machine mask.  */ | /* First opcode flag bit available after machine mask.  */ | ||||||
| #define ARC_OPCODE_FLAG_START ((ARC_MACH_MASK + 1) << 0) | #define ARC_OPCODE_FLAG_START (ARC_MACH_MASK + 1) | ||||||
|  |  | ||||||
| /* This insn is a conditional branch.  */ | /* This insn is a conditional branch.  */ | ||||||
| #define ARC_OPCODE_COND_BRANCH (ARC_OPCODE_FLAG_START) | #define ARC_OPCODE_COND_BRANCH (ARC_OPCODE_FLAG_START) | ||||||
|  | #define SYNTAX_3OP             (ARC_OPCODE_COND_BRANCH << 1) | ||||||
|  | #define SYNTAX_LENGTH          (SYNTAX_3OP                 ) | ||||||
|  | #define SYNTAX_2OP             (SYNTAX_3OP             << 1) | ||||||
|  | #define OP1_MUST_BE_IMM        (SYNTAX_2OP             << 1) | ||||||
|  | #define OP1_IMM_IMPLIED        (OP1_MUST_BE_IMM        << 1) | ||||||
|  | #define SYNTAX_VALID           (OP1_IMM_IMPLIED        << 1) | ||||||
|  |  | ||||||
|   /* These values are used to optimize assembly and disassembly.  Each insn is | #define I(x) (((x) & 31) << 27) | ||||||
|      on a list of related insns (same first letter for assembly, same insn code | #define A(x) (((x) & ARC_MASK_REG) << ARC_SHIFT_REGA) | ||||||
|      for disassembly).  */ | #define B(x) (((x) & ARC_MASK_REG) << ARC_SHIFT_REGB) | ||||||
|   struct arc_opcode *next_asm;	/* Next instruction to try during assembly.  */ | #define C(x) (((x) & ARC_MASK_REG) << ARC_SHIFT_REGC) | ||||||
|   struct arc_opcode *next_dis;	/* Next instruction to try during disassembly.  */ | #define R(x,b,m) (((x) & (m)) << (b)) /* value X, mask M, at bit B */ | ||||||
|  |  | ||||||
|   /* Macros to create the hash values for the lists.  */ | /* 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 instr to try during assembly.  */ | ||||||
|  |   struct arc_opcode *next_dis;	/* Next instr to try during disassembly.  */ | ||||||
|  |  | ||||||
|  | /* Macros to create the hash values for the lists.  */ | ||||||
| #define ARC_HASH_OPCODE(string) \ | #define ARC_HASH_OPCODE(string) \ | ||||||
|   ((string)[0] >= 'a' && (string)[0] <= 'z' ? (string)[0] - 'a' : 26) |   ((string)[0] >= 'a' && (string)[0] <= 'z' ? (string)[0] - 'a' : 26) | ||||||
| #define ARC_HASH_ICODE(insn) \ | #define ARC_HASH_ICODE(insn) \ | ||||||
| @@ -83,6 +96,10 @@ struct arc_opcode { | |||||||
| #define ARC_OPCODE_NEXT_DIS(op) ((op)->next_dis) | #define ARC_OPCODE_NEXT_DIS(op) ((op)->next_dis) | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | /* this is an "insert at front" linked list per Metaware spec | ||||||
|  |    that new definitions override older ones.  */ | ||||||
|  | struct arc_opcode *arc_ext_opcodes; | ||||||
|  |  | ||||||
| struct arc_operand_value { | struct arc_operand_value { | ||||||
|   char *name;          /* eg: "eq"  */ |   char *name;          /* eg: "eq"  */ | ||||||
|   short value;         /* eg: 1  */ |   short value;         /* eg: 1  */ | ||||||
| @@ -97,18 +114,23 @@ struct arc_operand_value { | |||||||
| #define ARC_OPVAL_MACH(bits) ((bits) & ARC_MACH_MASK) | #define ARC_OPVAL_MACH(bits) ((bits) & ARC_MACH_MASK) | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | struct arc_ext_operand_value { | ||||||
|  |   struct arc_ext_operand_value *next; | ||||||
|  |   struct arc_operand_value operand; | ||||||
|  | } *arc_ext_operands; | ||||||
|  |  | ||||||
| struct arc_operand { | struct arc_operand { | ||||||
|   /* One of the insn format chars.  */ | /* One of the insn format chars.  */ | ||||||
|   unsigned char fmt; |   unsigned char fmt; | ||||||
|  |  | ||||||
|   /* The number of bits in the operand (may be unused for a modifier).  */ | /* The number of bits in the operand (may be unused for a modifier).  */ | ||||||
|   unsigned char bits; |   unsigned char bits; | ||||||
|  |  | ||||||
|   /* How far the operand is left shifted in the instruction, or | /* How far the operand is left shifted in the instruction, or | ||||||
|    the modifier's flag bit (may be unused for a modifier.  */ |    the modifier's flag bit (may be unused for a modifier.  */ | ||||||
|   unsigned char shift; |   unsigned char shift; | ||||||
|  |  | ||||||
|   /* Various flag bits.  */ | /* Various flag bits.  */ | ||||||
|   int flags; |   int flags; | ||||||
|  |  | ||||||
| /* Values for `flags'.  */ | /* Values for `flags'.  */ | ||||||
| @@ -150,6 +172,19 @@ struct arc_operand { | |||||||
|    in special ways.  */ |    in special ways.  */ | ||||||
| #define ARC_OPERAND_FAKE 0x100 | #define ARC_OPERAND_FAKE 0x100 | ||||||
|  |  | ||||||
|  | /* separate flags operand for j and jl instructions  */ | ||||||
|  | #define ARC_OPERAND_JUMPFLAGS 0x200 | ||||||
|  |  | ||||||
|  | /* allow warnings and errors to be issued after call to insert_xxxxxx  */ | ||||||
|  | #define ARC_OPERAND_WARN  0x400 | ||||||
|  | #define ARC_OPERAND_ERROR 0x800 | ||||||
|  |  | ||||||
|  | /* this is a load operand */ | ||||||
|  | #define ARC_OPERAND_LOAD  0x8000 | ||||||
|  |  | ||||||
|  | /* this is a store operand */ | ||||||
|  | #define ARC_OPERAND_STORE 0x10000 | ||||||
|  |  | ||||||
| /* Modifier values.  */ | /* Modifier values.  */ | ||||||
| /* A dot is required before a suffix.  Eg: .le  */ | /* A dot is required before a suffix.  Eg: .le  */ | ||||||
| #define ARC_MOD_DOT 0x1000 | #define ARC_MOD_DOT 0x1000 | ||||||
| @@ -166,7 +201,12 @@ struct arc_operand { | |||||||
| /* Non-zero if the operand type is really a modifier.  */ | /* Non-zero if the operand type is really a modifier.  */ | ||||||
| #define ARC_MOD_P(X) ((X) & ARC_MOD_BITS) | #define ARC_MOD_P(X) ((X) & ARC_MOD_BITS) | ||||||
|  |  | ||||||
|   /* Insertion function.  This is used by the assembler.  To insert an | /* enforce read/write only register restrictions  */ | ||||||
|  | #define ARC_REGISTER_READONLY    0x01 | ||||||
|  | #define ARC_REGISTER_WRITEONLY   0x02 | ||||||
|  | #define ARC_REGISTER_NOSHORT_CUT 0x04 | ||||||
|  |  | ||||||
|  | /* Insertion function.  This is used by the assembler.  To insert an | ||||||
|    operand value into an instruction, check this field. |    operand value into an instruction, check this field. | ||||||
|  |  | ||||||
|    If it is NULL, execute |    If it is NULL, execute | ||||||
| @@ -189,7 +229,7 @@ struct arc_operand { | |||||||
| 			      const struct arc_operand_value *reg, long value, | 			      const struct arc_operand_value *reg, long value, | ||||||
| 			      const char **errmsg)); | 			      const char **errmsg)); | ||||||
|  |  | ||||||
|   /* Extraction function.  This is used by the disassembler.  To | /* Extraction function.  This is used by the disassembler.  To | ||||||
|    extract this operand type from an instruction, check this field. |    extract this operand type from an instruction, check this field. | ||||||
|     |     | ||||||
|    If it is NULL, compute |    If it is NULL, compute | ||||||
| @@ -219,9 +259,8 @@ struct arc_operand { | |||||||
| 			   int *invalid)); | 			   int *invalid)); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /* Bits that say what version of cpu we have. | /* Bits that say what version of cpu we have. These should be passed to | ||||||
|    These should be passed to arc_init_opcode_tables. |    arc_init_opcode_tables. At present, all there is is the cpu type.  */ | ||||||
|    At present, all there is is the cpu type.  */ |  | ||||||
|  |  | ||||||
| /* CPU number, given value passed to `arc_init_opcode_tables'.  */ | /* CPU number, given value passed to `arc_init_opcode_tables'.  */ | ||||||
| #define ARC_HAVE_CPU(bits) ((bits) & ARC_MACH_CPU_MASK) | #define ARC_HAVE_CPU(bits) ((bits) & ARC_MACH_CPU_MASK) | ||||||
| @@ -252,7 +291,7 @@ struct arc_operand { | |||||||
|  |  | ||||||
| extern const struct arc_operand arc_operands[]; | extern const struct arc_operand arc_operands[]; | ||||||
| extern const int arc_operand_count; | extern const int arc_operand_count; | ||||||
| extern /*const*/ struct arc_opcode arc_opcodes[]; | extern struct arc_opcode arc_opcodes[]; | ||||||
| extern const int arc_opcodes_count; | extern const int arc_opcodes_count; | ||||||
| extern const struct arc_operand_value arc_suffixes[]; | extern const struct arc_operand_value arc_suffixes[]; | ||||||
| extern const int arc_suffixes_count; | extern const int arc_suffixes_count; | ||||||
| @@ -262,6 +301,7 @@ extern unsigned char arc_operand_map[]; | |||||||
|  |  | ||||||
| /* Utility fns in arc-opc.c.  */ | /* Utility fns in arc-opc.c.  */ | ||||||
| int arc_get_opcode_mach PARAMS ((int, int)); | int arc_get_opcode_mach PARAMS ((int, int)); | ||||||
|  |  | ||||||
| /* `arc_opcode_init_tables' must be called before `arc_xxx_supported'.  */ | /* `arc_opcode_init_tables' must be called before `arc_xxx_supported'.  */ | ||||||
| void arc_opcode_init_tables PARAMS ((int)); | void arc_opcode_init_tables PARAMS ((int)); | ||||||
| void arc_opcode_init_insert PARAMS ((void)); | void arc_opcode_init_insert PARAMS ((void)); | ||||||
| @@ -269,6 +309,7 @@ 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_asm PARAMS ((const char *)); | ||||||
| const struct arc_opcode *arc_opcode_lookup_dis PARAMS ((unsigned int)); | const struct arc_opcode *arc_opcode_lookup_dis PARAMS ((unsigned int)); | ||||||
| int arc_opcode_limm_p PARAMS ((long *)); | int arc_opcode_limm_p PARAMS ((long *)); | ||||||
| const struct arc_operand_value *arc_opcode_lookup_suffix PARAMS ((const struct arc_operand *type, int value)); | 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_opcode_supported PARAMS ((const struct arc_opcode *)); | ||||||
| int arc_opval_supported PARAMS ((const struct arc_operand_value *)); | int arc_opval_supported PARAMS ((const struct arc_operand_value *)); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user