Blame mpn/m68k/m68k-defs.m4

Packit 5c3484
divert(-1)
Packit 5c3484
Packit 5c3484
dnl  m4 macros for 68k assembler.
Packit 5c3484
Packit 5c3484
dnl  Copyright 2001-2003 Free Software Foundation, Inc.
Packit 5c3484
Packit 5c3484
dnl  This file is part of the GNU MP Library.
Packit 5c3484
dnl
Packit 5c3484
dnl  The GNU MP Library is free software; you can redistribute it and/or modify
Packit 5c3484
dnl  it under the terms of either:
Packit 5c3484
dnl
Packit 5c3484
dnl    * the GNU Lesser General Public License as published by the Free
Packit 5c3484
dnl      Software Foundation; either version 3 of the License, or (at your
Packit 5c3484
dnl      option) any later version.
Packit 5c3484
dnl
Packit 5c3484
dnl  or
Packit 5c3484
dnl
Packit 5c3484
dnl    * the GNU General Public License as published by the Free Software
Packit 5c3484
dnl      Foundation; either version 2 of the License, or (at your option) any
Packit 5c3484
dnl      later version.
Packit 5c3484
dnl
Packit 5c3484
dnl  or both in parallel, as here.
Packit 5c3484
dnl
Packit 5c3484
dnl  The GNU MP Library is distributed in the hope that it will be useful, but
Packit 5c3484
dnl  WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
Packit 5c3484
dnl  or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
Packit 5c3484
dnl  for more details.
Packit 5c3484
dnl
Packit 5c3484
dnl  You should have received copies of the GNU General Public License and the
Packit 5c3484
dnl  GNU Lesser General Public License along with the GNU MP Library.  If not,
Packit 5c3484
dnl  see https://www.gnu.org/licenses/.
Packit 5c3484
Packit 5c3484
Packit 5c3484
dnl  The default m4 `#' commenting interferes with the assembler syntax for
Packit 5c3484
dnl  immediates.  `|' would be correct, but it interferes with "||" in
Packit 5c3484
dnl  eval().  Would like to disable commenting, but that's not possible (see
Packit 5c3484
dnl  mpn/asm-defs.m4), so use `;' which should be harmless.
Packit 5c3484
Packit 5c3484
changecom(;)
Packit 5c3484
Packit 5c3484
Packit 5c3484
dnl  Called: PROLOGUE_cpu(GSYM_PREFIX`'foo)
Packit 5c3484
dnl
Packit 5c3484
dnl  Same as the standard PROLOGUE, but align to 2 bytes not 4.
Packit 5c3484
Packit 5c3484
define(`PROLOGUE_cpu',
Packit 5c3484
m4_assert_numargs(1)
Packit 5c3484
`	TEXT
Packit 5c3484
	ALIGN(2)
Packit 5c3484
	GLOBL	`$1' GLOBL_ATTR
Packit 5c3484
	TYPE(`$1',`function')
Packit 5c3484
`$1'LABEL_SUFFIX')
Packit 5c3484
Packit 5c3484
Packit 5c3484
dnl  Usage: d0, etc
Packit 5c3484
dnl
Packit 5c3484
dnl  Expand to d0 or %d0 according to the assembler's requirements.
Packit 5c3484
dnl
Packit 5c3484
dnl  Actually d0 expands to `d0' or %`d0', the quotes protecting against
Packit 5c3484
dnl  further expansion.  Definitions are made even if d0 is to be just `d0',
Packit 5c3484
dnl  so that any m4 quoting problems will show up everywhere, not just on a
Packit 5c3484
dnl  %d0 system.
Packit 5c3484
dnl
Packit 5c3484
dnl  Care must be taken with quoting when using these in a definition.  For
Packit 5c3484
dnl  instance the quotes in the following are essential or two %'s will be
Packit 5c3484
dnl  produced when `counter' is used.
Packit 5c3484
dnl
Packit 5c3484
dnl         define(counter, `d7')
Packit 5c3484
dnl
Packit 5c3484
Packit 5c3484
dnl  Called: m68k_reg(r)
Packit 5c3484
define(m68k_reg,
Packit 5c3484
m4_assert_numargs(1)
Packit 5c3484
m4_assert_defined(`WANT_REGISTER_PERCENT')
Packit 5c3484
`ifelse(WANT_REGISTER_PERCENT,yes,%)`$1'')
Packit 5c3484
Packit 5c3484
dnl  Usage: m68k_defreg(r)
Packit 5c3484
define(m68k_defreg,
Packit 5c3484
m4_assert_numargs(1)
Packit 5c3484
`deflit($1,`m68k_reg(`$1')')')
Packit 5c3484
Packit 5c3484
m68k_defreg(d0)
Packit 5c3484
m68k_defreg(d1)
Packit 5c3484
m68k_defreg(d2)
Packit 5c3484
m68k_defreg(d3)
Packit 5c3484
m68k_defreg(d4)
Packit 5c3484
m68k_defreg(d5)
Packit 5c3484
m68k_defreg(d6)
Packit 5c3484
m68k_defreg(d7)
Packit 5c3484
Packit 5c3484
m68k_defreg(a0)
Packit 5c3484
m68k_defreg(a1)
Packit 5c3484
m68k_defreg(a2)
Packit 5c3484
m68k_defreg(a3)
Packit 5c3484
m68k_defreg(a4)
Packit 5c3484
m68k_defreg(a5)
Packit 5c3484
m68k_defreg(a6)
Packit 5c3484
m68k_defreg(a7)
Packit 5c3484
Packit 5c3484
m68k_defreg(sp)
Packit 5c3484
m68k_defreg(pc)
Packit 5c3484
Packit 5c3484
Packit 5c3484
dnl  Usage: M(base)
Packit 5c3484
dnl         M(base,displacement)
Packit 5c3484
dnl         M(base,index,size)
Packit 5c3484
dnl         M(base,index,size,scale)
Packit 5c3484
dnl         M(base,+)
Packit 5c3484
dnl         M(-,base)
Packit 5c3484
dnl
Packit 5c3484
dnl  `base' is an address register, `index' is a data register, `size' is w
Packit 5c3484
dnl  or l, and scale is 1, 2, 4 or 8.
Packit 5c3484
dnl
Packit 5c3484
dnl  M(-,base) has it's arguments that way around to emphasise it's a
Packit 5c3484
dnl  pre-decrement, as opposed to M(base,+) a post-increment.
Packit 5c3484
dnl
Packit 5c3484
dnl  Enhancement: Add the memory indirect modes, if/when they're needed.
Packit 5c3484
Packit 5c3484
define(M,
Packit 5c3484
m4_assert_numargs_range(1,4)
Packit 5c3484
m4_assert_defined(`WANT_ADDRESSING')
Packit 5c3484
`ifelse(WANT_ADDRESSING,mit,
Packit 5c3484
`ifelse($#,1, ``$1'@')dnl
Packit 5c3484
ifelse($#,2,
Packit 5c3484
`ifelse($2,+, ``$1'@+',
Packit 5c3484
`ifelse($1,-, ``$2'@-',
Packit 5c3484
              ``$1'@($2)')')')dnl
Packit 5c3484
ifelse($#,3,  ``$1'@(`$2':`$3')')dnl
Packit 5c3484
ifelse($#,4,  ``$1'@(`$2':`$3':$4)')',
Packit 5c3484
Packit 5c3484
dnl  WANT_ADDRESSING `motorola'
Packit 5c3484
`ifelse($#,1, `(`$1')')dnl
Packit 5c3484
ifelse($#,2,
Packit 5c3484
`ifelse($2,+, `(`$1')+',
Packit 5c3484
`ifelse($1,-, `-(`$2')',
Packit 5c3484
              `$2(`$1')')')')dnl
Packit 5c3484
ifelse($#,3,  `(`$1',`$2'.$3)')dnl
Packit 5c3484
ifelse($#,4,  `(`$1',`$2'.$3*$4)')')')
Packit 5c3484
Packit 5c3484
Packit 5c3484
dnl  Usage: addl etc
Packit 5c3484
dnl
Packit 5c3484
dnl  m68k instructions with special handling for the suffix, with for
Packit 5c3484
dnl  instance addl expanding to addl or add.l as necessary.
Packit 5c3484
dnl
Packit 5c3484
dnl  See also t-m68k-defs.pl which verifies all mnemonics used in the asm
Packit 5c3484
dnl  files have entries here.
Packit 5c3484
Packit 5c3484
dnl  Called: m68k_insn(mnemonic,suffix)
Packit 5c3484
define(m68k_insn,
Packit 5c3484
m4_assert_numargs(2)
Packit 5c3484
m4_assert_defined(`WANT_DOT_SIZE')
Packit 5c3484
`ifelse(WANT_DOT_SIZE,yes, ``$1'.``$2''',
Packit 5c3484
                           ``$1$2'')')
Packit 5c3484
Packit 5c3484
dnl  Usage: m68k_definsn(mnemonic,suffix)
Packit 5c3484
define(m68k_definsn,
Packit 5c3484
m4_assert_numargs(2)
Packit 5c3484
`deflit($1`'$2,`m68k_insn(`$1',`$2')')')
Packit 5c3484
Packit 5c3484
m68k_definsn(add,  l)
Packit 5c3484
m68k_definsn(addx, l)
Packit 5c3484
m68k_definsn(addq, l)
Packit 5c3484
m68k_definsn(asl,  l)
Packit 5c3484
m68k_definsn(cmp,  l)
Packit 5c3484
m68k_definsn(cmp,  w)
Packit 5c3484
m68k_definsn(clr,  l)
Packit 5c3484
m68k_definsn(divu, l)
Packit 5c3484
m68k_definsn(eor,  w)
Packit 5c3484
m68k_definsn(lsl,  l)
Packit 5c3484
m68k_definsn(lsr,  l)
Packit 5c3484
m68k_definsn(move, l)
Packit 5c3484
m68k_definsn(move, w)
Packit 5c3484
m68k_definsn(movem,l)
Packit 5c3484
m68k_definsn(moveq,l)
Packit 5c3484
m68k_definsn(mulu, l)
Packit 5c3484
m68k_definsn(neg,  l)
Packit 5c3484
m68k_definsn(or,   l)
Packit 5c3484
m68k_definsn(roxl, l)
Packit 5c3484
m68k_definsn(roxr, l)
Packit 5c3484
m68k_definsn(sub,  l)
Packit 5c3484
m68k_definsn(subx, l)
Packit 5c3484
m68k_definsn(subq, l)
Packit 5c3484
Packit 5c3484
Packit 5c3484
dnl  Usage: bra etc
Packit 5c3484
dnl
Packit 5c3484
dnl  Expand to `bra', `jra' or `jbra' according to what the assembler will
Packit 5c3484
dnl  accept.  The latter two give variable-sized branches in gas.
Packit 5c3484
dnl
Packit 5c3484
dnl  See also t-m68k-defs.pl which verifies all the bXX branches used in the
Packit 5c3484
dnl  asm files have entries here.
Packit 5c3484
Packit 5c3484
dnl  Called: m68k_branch(cond)
Packit 5c3484
define(m68k_branch,
Packit 5c3484
m4_assert_numargs(1)
Packit 5c3484
m4_assert_defined(`WANT_BRANCHES')
Packit 5c3484
`ifelse(WANT_BRANCHES,jra, `j$1',
Packit 5c3484
`ifelse(WANT_BRANCHES,jbra,`jb$1',
Packit 5c3484
                           ``b$1'')')')
Packit 5c3484
Packit 5c3484
dnl  Called: m68k_defbranch(cond)
Packit 5c3484
define(m68k_defbranch,
Packit 5c3484
m4_assert_numargs(1)
Packit 5c3484
`deflit(b$1,`m68k_branch(`$1')')')
Packit 5c3484
Packit 5c3484
m68k_defbranch(ra)
Packit 5c3484
m68k_defbranch(cc)
Packit 5c3484
m68k_defbranch(cs)
Packit 5c3484
m68k_defbranch(ls)
Packit 5c3484
m68k_defbranch(eq)
Packit 5c3484
m68k_defbranch(ne)
Packit 5c3484
Packit 5c3484
Packit 5c3484
dnl  Usage: scale_available_p
Packit 5c3484
dnl
Packit 5c3484
dnl  Expand to 1 if a scale factor can be used in addressing modes, or 0 if
Packit 5c3484
dnl  not.  M(a0,d0,l,4), meaning a0+d0*4, is not available in 68000 or
Packit 5c3484
dnl  68010, but is in CPU32 and in 68020 and up.
Packit 5c3484
Packit 5c3484
define(scale_available_p,
Packit 5c3484
`m4_ifdef_anyof_p(
Packit 5c3484
`HAVE_HOST_CPU_m68360'
Packit 5c3484
`HAVE_HOST_CPU_m68020'
Packit 5c3484
`HAVE_HOST_CPU_m68030'
Packit 5c3484
`HAVE_HOST_CPU_m68040'
Packit 5c3484
`HAVE_HOST_CPU_m68060')')
Packit 5c3484
Packit 5c3484
Packit 5c3484
divert