Blame sysdeps/m68k/asm-syntax.h

Packit 6c4009
/* Definitions for 68k syntax variations.
Packit 6c4009
   Copyright (C) 1992-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.  Its master source is NOT part of
Packit 6c4009
   the C library, however.  The master source lives in the GNU MP Library.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library.  If not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
/* For ELF we need to prefix register names and local labels.  */
Packit 6c4009
#define R_(r) %##r
Packit 6c4009
#define R(r) R_(r)
Packit 6c4009
#define L(label) .##label
Packit 6c4009
Packit 6c4009
#ifdef MIT_SYNTAX
Packit 6c4009
#define MEM(base)R(base)@
Packit 6c4009
#define MEM_DISP(base,displacement)R(base)@(displacement)
Packit 6c4009
#define MEM_INDX(base,idx,size_suffix)R(base)@(R(idx):size_suffix)
Packit 6c4009
#define MEM_INDX1(base,idx,size_suffix,scale)R(base)@(R(idx):size_suffix:scale)
Packit 6c4009
#define MEM_PREDEC(memory_base)R(memory_base)@-
Packit 6c4009
#define MEM_POSTINC(memory_base)R(memory_base)@+
Packit 6c4009
#define TEXT .text
Packit 6c4009
/* Use variable sized opcodes.  */
Packit 6c4009
#define bcc jcc
Packit 6c4009
#define bcs jcs
Packit 6c4009
#define bls jls
Packit 6c4009
#define beq jeq
Packit 6c4009
#define bne jne
Packit 6c4009
#define bra jra
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#ifdef MOTOROLA_SYNTAX
Packit 6c4009
#define MEM(base)(R(base))
Packit 6c4009
#define MEM_DISP(base,displacement)(displacement,R(base))
Packit 6c4009
#define MEM_PREDEC(memory_base)-(R(memory_base))
Packit 6c4009
#define MEM_POSTINC(memory_base)(R(memory_base))+
Packit 6c4009
#define MEM_INDX_(base,idx,size_suffix)(R(base),R(idx##.##size_suffix))
Packit 6c4009
#define MEM_INDX(base,idx,size_suffix)MEM_INDX_(base,idx,size_suffix)
Packit 6c4009
#define MEM_INDX1_(base,idx,size_suffix,scale)(R(base),R(idx##.##size_suffix*scale))
Packit 6c4009
#define MEM_INDX1(base,idx,size_suffix,scale)MEM_INDX1_(base,idx,size_suffix,scale)
Packit 6c4009
#define TEXT .text
Packit 6c4009
#define bcc jbcc
Packit 6c4009
#define bcs jbcs
Packit 6c4009
#define bls jbls
Packit 6c4009
#define beq jbeq
Packit 6c4009
#define bne jbne
Packit 6c4009
#define bra jbra
Packit 6c4009
#define movel move.l
Packit 6c4009
#define moveml movem.l
Packit 6c4009
#define moveql moveq.l
Packit 6c4009
#define cmpl cmp.l
Packit 6c4009
#define orl or.l
Packit 6c4009
#define clrl clr.l
Packit 6c4009
#define andw and.w
Packit 6c4009
#define eorw eor.w
Packit 6c4009
#define andl and.l
Packit 6c4009
#define lsrl lsr.l
Packit 6c4009
#define lsll lsl.l
Packit 6c4009
#define roxrl roxr.l
Packit 6c4009
#define roxll roxl.l
Packit 6c4009
#define addl add.l
Packit 6c4009
#define addxl addx.l
Packit 6c4009
#define addql addq.l
Packit 6c4009
#define subl sub.l
Packit 6c4009
#define subxl subx.l
Packit 6c4009
#define subqw subq.w
Packit 6c4009
#define subql subq.l
Packit 6c4009
#define negl neg.l
Packit 6c4009
#define mulul mulu.l
Packit 6c4009
#define tstw tst.w
Packit 6c4009
#define tstl tst.l
Packit 6c4009
#endif