27a53b88d7
(md_pseudo_table): Add fopt and mask2. (m68k_ip): Use m68k_float_copnum, not COPNUM, when setting coprocessor register to use. In case 'I' when checking operands, correct coprocessor register numbers. In case 'I' when setting operands, don't add 1. (s_fopt): New static function. * config/m68k-parse.h (COPNUM): Don't define.
276 lines
5.0 KiB
C
276 lines
5.0 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 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,
|
|
|
|
COP0, /* Co-processor #0-#7 */
|
|
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;
|