mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-12 12:16:04 +08:00
a1c7c0f3ac
including support for Motorola syntax. * config/m68k-parse.h: New file; definitions shared between m68k-parse.y and tc-m68k.c. * config/tc-m68k.c: Include m68k-parse.h. (enum operand_type): Move to m68k-parse.h, where it is named m68k_operand_type. Rename all uses. Rearrange somewhat. Add FPREG. Rename AOFF to DISP. Rename AINDX to BASE. Rename APODX to POST. Rename APRDX to PRE. Remove AMIND. Rename MSCR to CONTROL. Remove DINDR. (struct m68k_exp): Move to m68k-parse.h. Remove e_beg, e_end and e_seg fields. Rename e_exp to exp. Rename e_siz to size, and change type to enum m68k_size. Change all uses. (enum _register): Move to m68k-parse.h, where it is named m68k_register. Rename all uses. Add ZDATA0-7 and ZADDR0-7. (struct m68k_op): Move to m68k-parse.h. Change all fields. (seg): Don't define. (add_exp): Remove. (FAIL, OK): Remove. (m68k_reg_parse): Move to m68k-parse.y, and rewrite. (SKIP_WHITE, SKIP_W): Remove. (try_moto_index, try_index): Remove. (m68k_ip_op): Move to m68k-parse.y, and rewrite to use grammar. (main): Remove obsolete test function. (m68k_ip): Extensive changes to use new grammar. (get_regs): Remove. (crack_operand): m68k_ip_op now returns 0 on success. (init_table): Add ssp, zd0-7 and za0-7. (md_assemble): Make er const. Correct loop over operands when looking for error message. (md_begin): Set alt_notend_table for '(' and '@'. (get_num): Expression is already parsed. Don't set seg. * configure.in: If cpu_type is m68k, put m68k-parse.o in extra-objects. * configure: Rebuild. * Makefile.in (DISTSTUFF): Add m68k-parse.c. (BISON): Use ../bison/bison if it exists. (BISONFLAGS): Define as empty. (TARG_CPU_DEP_m68k): Depend upon $(srcdir)/config/m68k-parse.h. (m68k-parse.c, m68k-parse.o): New targets.
280 lines
5.1 KiB
C
280 lines
5.1 KiB
C
/* m68k-parse.h -- header file for m68k assembler
|
|
Copyright (C) 1987, 91, 92, 93, 94, 1995 Free Software Foundation, Inc.
|
|
|
|
This file is part of GAS, the GNU Assembler.
|
|
|
|
GAS 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 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; see the file COPYING. If not, write to the Free
|
|
Software Foundation, 59 Temple Place - Suite 330, Boston, MA
|
|
02111-1307, USA. */
|
|
|
|
#ifndef M68K_PARSE_H
|
|
#define M68K_PARSE_H
|
|
|
|
/* This header file defines things which are shared between the
|
|
operand parser in m68k.y and the m68k assembler proper in
|
|
tc-m68k.c. */
|
|
|
|
/* The various m68k registers. */
|
|
|
|
/* DATA and ADDR have to be contiguous, so that reg-DATA gives
|
|
0-7==data reg, 8-15==addr reg for operands that take both types.
|
|
|
|
We don't use forms like "ADDR0 = ADDR" here because this file is
|
|
likely to be used on an Apollo, and the broken Apollo compiler
|
|
gives an `undefined variable' error if we do that, according to
|
|
troy@cbme.unsw.edu.au. */
|
|
|
|
#define DATA DATA0
|
|
#define ADDR ADDR0
|
|
#define SP ADDR7
|
|
#define COPNUM COP0
|
|
#define BAD BAD0
|
|
#define BAC BAC0
|
|
|
|
enum m68k_register
|
|
{
|
|
DATA0 = 1, /* 1- 8 == data registers 0-7 */
|
|
DATA1,
|
|
DATA2,
|
|
DATA3,
|
|
DATA4,
|
|
DATA5,
|
|
DATA6,
|
|
DATA7,
|
|
|
|
ADDR0,
|
|
ADDR1,
|
|
ADDR2,
|
|
ADDR3,
|
|
ADDR4,
|
|
ADDR5,
|
|
ADDR6,
|
|
ADDR7,
|
|
|
|
FP0, /* Eight FP registers */
|
|
FP1,
|
|
FP2,
|
|
FP3,
|
|
FP4,
|
|
FP5,
|
|
FP6,
|
|
FP7,
|
|
|
|
/* Note that COP0==processor #1 -- COP0+7==#8, which stores as 000 */
|
|
/* I think. . . */
|
|
|
|
COP0, /* Co-processor #1-#8 */
|
|
COP1,
|
|
COP2,
|
|
COP3,
|
|
COP4,
|
|
COP5,
|
|
COP6,
|
|
COP7,
|
|
|
|
PC, /* Program counter */
|
|
ZPC, /* Hack for Program space, but 0 addressing */
|
|
SR, /* Status Reg */
|
|
CCR, /* Condition code Reg */
|
|
|
|
/* These have to be grouped together for the movec instruction to work. */
|
|
USP, /* User Stack Pointer */
|
|
ISP, /* Interrupt stack pointer */
|
|
SFC,
|
|
DFC,
|
|
CACR,
|
|
VBR,
|
|
CAAR,
|
|
MSP,
|
|
ITT0,
|
|
ITT1,
|
|
DTT0,
|
|
DTT1,
|
|
MMUSR,
|
|
TC,
|
|
SRP,
|
|
URP,
|
|
BUSCR, /* 68060 added these */
|
|
PCR,
|
|
#define last_movec_reg PCR
|
|
/* end of movec ordering constraints */
|
|
|
|
FPI,
|
|
FPS,
|
|
FPC,
|
|
|
|
DRP, /* 68851 or 68030 MMU regs */
|
|
CRP,
|
|
CAL,
|
|
VAL,
|
|
SCC,
|
|
AC,
|
|
BAD0,
|
|
BAD1,
|
|
BAD2,
|
|
BAD3,
|
|
BAD4,
|
|
BAD5,
|
|
BAD6,
|
|
BAD7,
|
|
BAC0,
|
|
BAC1,
|
|
BAC2,
|
|
BAC3,
|
|
BAC4,
|
|
BAC5,
|
|
BAC6,
|
|
BAC7,
|
|
PSR, /* aka MMUSR on 68030 (but not MMUSR on 68040)
|
|
and ACUSR on 68ec030 */
|
|
PCSR,
|
|
|
|
IC, /* instruction cache token */
|
|
DC, /* data cache token */
|
|
NC, /* no cache token */
|
|
BC, /* both caches token */
|
|
|
|
TT0, /* 68030 access control unit regs */
|
|
TT1,
|
|
|
|
ZDATA0, /* suppressed data registers. */
|
|
ZDATA1,
|
|
ZDATA2,
|
|
ZDATA3,
|
|
ZDATA4,
|
|
ZDATA5,
|
|
ZDATA6,
|
|
ZDATA7,
|
|
|
|
ZADDR0, /* suppressed address registers. */
|
|
ZADDR1,
|
|
ZADDR2,
|
|
ZADDR3,
|
|
ZADDR4,
|
|
ZADDR5,
|
|
ZADDR6,
|
|
ZADDR7,
|
|
};
|
|
|
|
/* Size information. */
|
|
|
|
enum m68k_size
|
|
{
|
|
/* Unspecified. */
|
|
SIZE_UNSPEC,
|
|
|
|
/* Byte. */
|
|
SIZE_BYTE,
|
|
|
|
/* Word (2 bytes). */
|
|
SIZE_WORD,
|
|
|
|
/* Longword (4 bytes). */
|
|
SIZE_LONG
|
|
};
|
|
|
|
/* The structure used to hold information about an index register. */
|
|
|
|
struct m68k_indexreg
|
|
{
|
|
/* The index register itself. */
|
|
enum m68k_register reg;
|
|
|
|
/* The size to use. */
|
|
enum m68k_size size;
|
|
|
|
/* The value to scale by. */
|
|
int scale;
|
|
};
|
|
|
|
/* The structure used to hold information about an expression. */
|
|
|
|
struct m68k_exp
|
|
{
|
|
/* The size to use. */
|
|
enum m68k_size size;
|
|
|
|
/* The expression itself. */
|
|
expressionS exp;
|
|
};
|
|
|
|
/* See whether an expression is a signed eight bit value. */
|
|
|
|
#define expr8(ex) \
|
|
((ex)->exp.X_op == O_constant \
|
|
&& (ex)->exp.X_add_number >= -0x80 \
|
|
&& (ex)->exp.X_add_number < 0x80)
|
|
|
|
/* See whether an expression is a signed sixteen bit value. */
|
|
|
|
#define expr16(ex) \
|
|
((ex)->exp.X_op == O_constant \
|
|
&& (ex)->exp.X_add_number >= -0x8000 \
|
|
&& (ex)->exp.X_add_number < 0x8000)
|
|
|
|
/* The operand modes. */
|
|
|
|
enum m68k_operand_type
|
|
{
|
|
IMMED = 1,
|
|
ABSL,
|
|
DREG,
|
|
AREG,
|
|
FPREG,
|
|
CONTROL,
|
|
AINDR,
|
|
AINC,
|
|
ADEC,
|
|
DISP,
|
|
BASE,
|
|
POST,
|
|
PRE,
|
|
REGLST
|
|
};
|
|
|
|
/* The structure used to hold a parsed operand. */
|
|
|
|
struct m68k_op
|
|
{
|
|
/* The type of operand. */
|
|
enum m68k_operand_type mode;
|
|
|
|
/* The main register. */
|
|
enum m68k_register reg;
|
|
|
|
/* The register mask for mode REGLST. */
|
|
unsigned long mask;
|
|
|
|
/* An error message. */
|
|
const char *error;
|
|
|
|
/* The index register. */
|
|
struct m68k_indexreg index;
|
|
|
|
/* The displacement. */
|
|
struct m68k_exp disp;
|
|
|
|
/* The outer displacement. */
|
|
struct m68k_exp odisp;
|
|
};
|
|
|
|
#endif /* ! defined (M68K_PARSE_H) */
|
|
|
|
/* The parsing function. */
|
|
|
|
extern int m68k_ip_op PARAMS ((char *, struct m68k_op *));
|
|
|
|
/* Whether register prefixes are optional. */
|
|
extern int flag_reg_prefix_optional;
|