bfd
* Makefile.am (ALL_MACHINES): Add cpu-rx.lo. (ALL_MACHINES_CFILES): Add cpu-rx.c. (BFD32_BACKENDS): Add elf32-rx.lo. (BFD32_BACKENDS_CFILES): Add elf32-rx.c. * archures.c (bfd_architecture): Add bfd_arch_rx and bfd_mach_rx. Export bfd_rx_arch. (bfd_archures_list): Add bfd_rx_arch. * config.bfd: Add entry for rx-*-elf. * configure.in: Add entries for bfd_elf32_rx_le_vec and bfd_elf32_rx_be_vec. * reloc.c: Add RX relocations. * targets.c: Add RX target vectors. * Makefile.in: Regenerate. * bfd-in2.h: Regenerate. * configure: Regenerate. * libbfd.h: Regenerate. * cpu-rx.c: New file. * elf32-rx.c: New file. binutils * readelf.c: Add support for RX target. * MAINTAINERS: Add DJ and NickC as maintainers for RX. gas * Makefile.am: Add RX target. * configure.in: Likewise. * configure.tgt: Likewise. * read.c (do_repeat_with_expander): New function. * read.h: Provide a prototype for do_repeat_with_expander. * doc/Makefile.am: Add RX target documentation. * doc/all.texi: Likewise. * doc/as.texinfo: Likewise. * Makefile.in: Regenerate. * NEWS: Mention support for RX architecture. * configure: Regenerate. * doc/Makefile.in: Regenerate. * config/rx-defs.h: New file. * config/rx-parse.y: New file. * config/tc-rx.h: New file. * config/tc-rx.c: New file. * doc/c-rx.texi: New file. gas/testsuite * gas/rx: New directory. * gas/rx/*: New set of test cases. * gas/elf/section2.e-rx: New expected output file. * gas/all/gas.exp: Add support for RX target. * gas/elf/elf.exp: Likewise. * gas/lns/lns.exp: Likewise. * gas/macros/macros.exp: Likewise. include * dis-asm.h: Add prototype for print_insn_rx. include/elf * rx.h: New file. include/opcode * rx.h: New file. ld * Makefile.am: Add rules to build RX emulation. * configure.tgt: Likewise. * NEWS: Mention support for RX architecture. * Makefile.in: Regenerate. * emulparams/elf32rx.sh: New file. * emultempl/rxelf.em: New file. opcodes * Makefile.am: Add RX files. * configure.in: Add support for RX target. * disassemble.c: Likewise. * Makefile.in: Regenerate. * configure: Regenerate. * opc2c.c: New file. * rx-decode.c: New file. * rx-decode.opc: New file. * rx-dis.c: New file.
This commit is contained in:
parent
8765b55692
commit
c7927a3c0e
@ -1,3 +1,24 @@
|
||||
2009-09-29 DJ Delorie <dj@redhat.com>
|
||||
|
||||
* Makefile.am (ALL_MACHINES): Add cpu-rx.lo.
|
||||
(ALL_MACHINES_CFILES): Add cpu-rx.c.
|
||||
(BFD32_BACKENDS): Add elf32-rx.lo.
|
||||
(BFD32_BACKENDS_CFILES): Add elf32-rx.c.
|
||||
* archures.c (bfd_architecture): Add bfd_arch_rx and bfd_mach_rx.
|
||||
Export bfd_rx_arch.
|
||||
(bfd_archures_list): Add bfd_rx_arch.
|
||||
* config.bfd: Add entry for rx-*-elf.
|
||||
* configure.in: Add entries for bfd_elf32_rx_le_vec and
|
||||
bfd_elf32_rx_be_vec.
|
||||
* reloc.c: Add RX relocations.
|
||||
* targets.c: Add RX target vectors.
|
||||
* Makefile.in: Regenerate.
|
||||
* bfd-in2.h: Regenerate.
|
||||
* configure: Regenerate.
|
||||
* libbfd.h: Regenerate.
|
||||
* cpu-rx.c: New file.
|
||||
* elf32-rx.c: New file.
|
||||
|
||||
2009-09-29 M R Swami Reddy <MR.Swami.Reddy@nsc.com>
|
||||
|
||||
* elf32-cr16.c (elf32_cr16_relocate_section): Removed
|
||||
|
@ -120,6 +120,7 @@ ALL_MACHINES = \
|
||||
cpu-plugin.lo \
|
||||
cpu-powerpc.lo \
|
||||
cpu-rs6000.lo \
|
||||
cpu-rx.lo \
|
||||
cpu-s390.lo \
|
||||
cpu-score.lo \
|
||||
cpu-sh.lo \
|
||||
@ -191,6 +192,7 @@ ALL_MACHINES_CFILES = \
|
||||
cpu-plugin.c \
|
||||
cpu-powerpc.c \
|
||||
cpu-rs6000.c \
|
||||
cpu-rx.c \
|
||||
cpu-s390.c \
|
||||
cpu-score.c \
|
||||
cpu-sh.c \
|
||||
@ -307,6 +309,7 @@ BFD32_BACKENDS = \
|
||||
elf32-or32.lo \
|
||||
elf32-pj.lo \
|
||||
elf32-ppc.lo \
|
||||
elf32-rx.lo \
|
||||
elf32-s390.lo \
|
||||
elf32-sh-symbian.lo \
|
||||
elf32-sh.lo \
|
||||
@ -490,6 +493,7 @@ BFD32_BACKENDS_CFILES = \
|
||||
elf32-or32.c \
|
||||
elf32-pj.c \
|
||||
elf32-ppc.c \
|
||||
elf32-rx.c \
|
||||
elf32-s390.c \
|
||||
elf32-sh-symbian.c \
|
||||
elf32-sh.c \
|
||||
|
@ -415,6 +415,7 @@ ALL_MACHINES = \
|
||||
cpu-plugin.lo \
|
||||
cpu-powerpc.lo \
|
||||
cpu-rs6000.lo \
|
||||
cpu-rx.lo \
|
||||
cpu-s390.lo \
|
||||
cpu-score.lo \
|
||||
cpu-sh.lo \
|
||||
@ -486,6 +487,7 @@ ALL_MACHINES_CFILES = \
|
||||
cpu-plugin.c \
|
||||
cpu-powerpc.c \
|
||||
cpu-rs6000.c \
|
||||
cpu-rx.c \
|
||||
cpu-s390.c \
|
||||
cpu-score.c \
|
||||
cpu-sh.c \
|
||||
@ -603,6 +605,7 @@ BFD32_BACKENDS = \
|
||||
elf32-or32.lo \
|
||||
elf32-pj.lo \
|
||||
elf32-ppc.lo \
|
||||
elf32-rx.lo \
|
||||
elf32-s390.lo \
|
||||
elf32-sh-symbian.lo \
|
||||
elf32-sh.lo \
|
||||
@ -786,6 +789,7 @@ BFD32_BACKENDS_CFILES = \
|
||||
elf32-or32.c \
|
||||
elf32-pj.c \
|
||||
elf32-ppc.c \
|
||||
elf32-rx.c \
|
||||
elf32-s390.c \
|
||||
elf32-sh-symbian.c \
|
||||
elf32-sh.c \
|
||||
@ -1271,6 +1275,7 @@ distclean-compile:
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-plugin.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-powerpc.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-rs6000.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-rx.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-s390.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-score.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-sh.Plo@am__quote@
|
||||
@ -1345,6 +1350,7 @@ distclean-compile:
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-or32.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-pj.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-ppc.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-rx.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-s390.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-score.Plo@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-score7.Plo@am__quote@
|
||||
|
@ -380,6 +380,8 @@ DESCRIPTION
|
||||
.#define bfd_mach_cris_v0_v10 255
|
||||
.#define bfd_mach_cris_v32 32
|
||||
.#define bfd_mach_cris_v10_v32 1032
|
||||
. bfd_arch_rx, {* Renesas RX. *}
|
||||
.#define bfd_mach_rx 0x75
|
||||
. bfd_arch_s390, {* IBM s390 *}
|
||||
.#define bfd_mach_s390_31 31
|
||||
.#define bfd_mach_s390_64 64
|
||||
@ -513,6 +515,7 @@ extern const bfd_arch_info_type bfd_plugin_arch;
|
||||
extern const bfd_arch_info_type bfd_powerpc_archs[];
|
||||
#define bfd_powerpc_arch bfd_powerpc_archs[0]
|
||||
extern const bfd_arch_info_type bfd_rs6000_arch;
|
||||
extern const bfd_arch_info_type bfd_rx_arch;
|
||||
extern const bfd_arch_info_type bfd_s390_arch;
|
||||
extern const bfd_arch_info_type bfd_score_arch;
|
||||
extern const bfd_arch_info_type bfd_sh_arch;
|
||||
@ -586,6 +589,7 @@ static const bfd_arch_info_type * const bfd_archures_list[] =
|
||||
&bfd_pdp11_arch,
|
||||
&bfd_powerpc_arch,
|
||||
&bfd_rs6000_arch,
|
||||
&bfd_rx_arch,
|
||||
&bfd_s390_arch,
|
||||
&bfd_score_arch,
|
||||
&bfd_sh_arch,
|
||||
|
@ -2047,6 +2047,8 @@ enum bfd_architecture
|
||||
#define bfd_mach_cris_v0_v10 255
|
||||
#define bfd_mach_cris_v32 32
|
||||
#define bfd_mach_cris_v10_v32 1032
|
||||
bfd_arch_rx, /* Renesas RX. */
|
||||
#define bfd_mach_rx 0x75
|
||||
bfd_arch_s390, /* IBM s390 */
|
||||
#define bfd_mach_s390_31 31
|
||||
#define bfd_mach_s390_64 64
|
||||
@ -3844,6 +3846,32 @@ instructions */
|
||||
instructions */
|
||||
BFD_RELOC_AVR_6_ADIW,
|
||||
|
||||
/* Renesas RX Relocations. */
|
||||
BFD_RELOC_RX_NEG8,
|
||||
BFD_RELOC_RX_NEG16,
|
||||
BFD_RELOC_RX_NEG24,
|
||||
BFD_RELOC_RX_NEG32,
|
||||
BFD_RELOC_RX_16_OP,
|
||||
BFD_RELOC_RX_24_OP,
|
||||
BFD_RELOC_RX_32_OP,
|
||||
BFD_RELOC_RX_8U,
|
||||
BFD_RELOC_RX_16U,
|
||||
BFD_RELOC_RX_24U,
|
||||
BFD_RELOC_RX_DIR3U_PCREL,
|
||||
BFD_RELOC_RX_DIFF,
|
||||
BFD_RELOC_RX_GPRELB,
|
||||
BFD_RELOC_RX_GPRELW,
|
||||
BFD_RELOC_RX_GPRELL,
|
||||
BFD_RELOC_RX_SYM,
|
||||
BFD_RELOC_RX_OP_SUBTRACT,
|
||||
BFD_RELOC_RX_ABS8,
|
||||
BFD_RELOC_RX_ABS16,
|
||||
BFD_RELOC_RX_ABS32,
|
||||
BFD_RELOC_RX_ABS16U,
|
||||
BFD_RELOC_RX_ABS16UW,
|
||||
BFD_RELOC_RX_ABS16UL,
|
||||
BFD_RELOC_RX_RELAX,
|
||||
|
||||
/* Direct 12 bit. */
|
||||
BFD_RELOC_390_12,
|
||||
|
||||
|
@ -1191,6 +1191,11 @@ case "${targ}" in
|
||||
targ_selvecs="bfd_powerpcle_pei_vec bfd_powerpc_pei_vec bfd_powerpcle_pe_vec bfd_powerpc_pe_vec"
|
||||
;;
|
||||
|
||||
rx-*-elf)
|
||||
targ_defvec=bfd_elf32_rx_le_vec
|
||||
targ_selvecs="bfd_elf32_rx_be_vec bfd_elf32_rx_le_vec"
|
||||
;;
|
||||
|
||||
s390-*-linux*)
|
||||
targ_defvec=bfd_elf32_s390_vec
|
||||
targ64_selvecs=bfd_elf64_s390_vec
|
||||
|
2
bfd/configure
vendored
2
bfd/configure
vendored
@ -14868,6 +14868,8 @@ do
|
||||
bfd_elf32_powerpc_vec) tb="$tb elf32-ppc.lo elf-vxworks.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_powerpcle_vec) tb="$tb elf32-ppc.lo elf-vxworks.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_powerpc_vxworks_vec) tb="$tb elf32-ppc.lo elf-vxworks.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_rx_le_vec) tb="$tb elf32-rx.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_rx_be_vec) tb="$tb elf32-rx.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_s390_vec) tb="$tb elf32-s390.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_bigscore_vec) tb="$tb elf32-score.lo elf32-score7.lo elf32.lo $elf"; want64=true; target_size=64;;
|
||||
bfd_elf32_littlescore_vec) tb="$tb elf32-score.lo elf32-score7.lo elf32.lo $elf"; want64=true; target_size=64;;
|
||||
|
@ -756,6 +756,8 @@ do
|
||||
bfd_elf32_powerpc_vec) tb="$tb elf32-ppc.lo elf-vxworks.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_powerpcle_vec) tb="$tb elf32-ppc.lo elf-vxworks.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_powerpc_vxworks_vec) tb="$tb elf32-ppc.lo elf-vxworks.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_rx_le_vec) tb="$tb elf32-rx.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_rx_be_vec) tb="$tb elf32-rx.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_s390_vec) tb="$tb elf32-s390.lo elf32.lo $elf" ;;
|
||||
bfd_elf32_bigscore_vec) tb="$tb elf32-score.lo elf32-score7.lo elf32.lo $elf"; want64=true; target_size=64;;
|
||||
bfd_elf32_littlescore_vec) tb="$tb elf32-score.lo elf32-score7.lo elf32.lo $elf"; want64=true; target_size=64;;
|
||||
|
57
bfd/cpu-rx.c
Normal file
57
bfd/cpu-rx.c
Normal file
@ -0,0 +1,57 @@
|
||||
/* BFD support for the RX processor.
|
||||
Copyright (C) 2008, 2009 Free Software Foundation, Inc.
|
||||
|
||||
This file is part of BFD, the Binary File Descriptor library.
|
||||
|
||||
This program 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 3 of the License, or
|
||||
(at your option) any later version.
|
||||
|
||||
This program 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 this program; if not, write to the Free Software
|
||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||
MA 02110-1301, USA. */
|
||||
|
||||
#include "sysdep.h"
|
||||
#include "bfd.h"
|
||||
#include "libbfd.h"
|
||||
|
||||
static const bfd_arch_info_type arch_info_struct[] =
|
||||
{
|
||||
{
|
||||
32, /* Bits per word. */
|
||||
32, /* Bits per address. */
|
||||
8, /* Bits per byte. */
|
||||
bfd_arch_rx, /* Architecture. */
|
||||
bfd_mach_rx, /* Machine. */
|
||||
"rx", /* Architecture name. */
|
||||
"rx", /* Printable name. */
|
||||
3, /* Section align power. */
|
||||
FALSE, /* The default ? */
|
||||
bfd_default_compatible, /* Architecture comparison fn. */
|
||||
bfd_default_scan, /* String to architecture convert fn. */
|
||||
NULL /* Next in list. */
|
||||
},
|
||||
};
|
||||
|
||||
const bfd_arch_info_type bfd_rx_arch =
|
||||
{
|
||||
32, /* Bits per word. */
|
||||
32, /* Bits per address. */
|
||||
8, /* Bits per byte. */
|
||||
bfd_arch_rx, /* Architecture. */
|
||||
bfd_mach_rx, /* Machine. */
|
||||
"rx", /* Architecture name. */
|
||||
"rx", /* Printable name. */
|
||||
4, /* Section align power. */
|
||||
TRUE, /* The default ? */
|
||||
bfd_default_compatible, /* Architecture comparison fn. */
|
||||
bfd_default_scan, /* String to architecture convert fn. */
|
||||
& arch_info_struct[0], /* Next in list. */
|
||||
};
|
3402
bfd/elf32-rx.c
Normal file
3402
bfd/elf32-rx.c
Normal file
File diff suppressed because it is too large
Load Diff
24
bfd/libbfd.h
24
bfd/libbfd.h
@ -1646,6 +1646,30 @@ static const char *const bfd_reloc_code_real_names[] = { "@@uninitialized@@",
|
||||
"BFD_RELOC_AVR_LDI",
|
||||
"BFD_RELOC_AVR_6",
|
||||
"BFD_RELOC_AVR_6_ADIW",
|
||||
"BFD_RELOC_RX_NEG8",
|
||||
"BFD_RELOC_RX_NEG16",
|
||||
"BFD_RELOC_RX_NEG24",
|
||||
"BFD_RELOC_RX_NEG32",
|
||||
"BFD_RELOC_RX_16_OP",
|
||||
"BFD_RELOC_RX_24_OP",
|
||||
"BFD_RELOC_RX_32_OP",
|
||||
"BFD_RELOC_RX_8U",
|
||||
"BFD_RELOC_RX_16U",
|
||||
"BFD_RELOC_RX_24U",
|
||||
"BFD_RELOC_RX_DIR3U_PCREL",
|
||||
"BFD_RELOC_RX_DIFF",
|
||||
"BFD_RELOC_RX_GPRELB",
|
||||
"BFD_RELOC_RX_GPRELW",
|
||||
"BFD_RELOC_RX_GPRELL",
|
||||
"BFD_RELOC_RX_SYM",
|
||||
"BFD_RELOC_RX_OP_SUBTRACT",
|
||||
"BFD_RELOC_RX_ABS8",
|
||||
"BFD_RELOC_RX_ABS16",
|
||||
"BFD_RELOC_RX_ABS32",
|
||||
"BFD_RELOC_RX_ABS16U",
|
||||
"BFD_RELOC_RX_ABS16UW",
|
||||
"BFD_RELOC_RX_ABS16UL",
|
||||
"BFD_RELOC_RX_RELAX",
|
||||
"BFD_RELOC_390_12",
|
||||
"BFD_RELOC_390_GOT12",
|
||||
"BFD_RELOC_390_PLT32",
|
||||
|
51
bfd/reloc.c
51
bfd/reloc.c
@ -4051,6 +4051,57 @@ ENUMDOC
|
||||
This is a 6 bit reloc for the AVR that stores offset for adiw/sbiw
|
||||
instructions
|
||||
|
||||
ENUM
|
||||
BFD_RELOC_RX_NEG8
|
||||
ENUMX
|
||||
BFD_RELOC_RX_NEG16
|
||||
ENUMX
|
||||
BFD_RELOC_RX_NEG24
|
||||
ENUMX
|
||||
BFD_RELOC_RX_NEG32
|
||||
ENUMX
|
||||
BFD_RELOC_RX_16_OP
|
||||
ENUMX
|
||||
BFD_RELOC_RX_24_OP
|
||||
ENUMX
|
||||
BFD_RELOC_RX_32_OP
|
||||
ENUMX
|
||||
BFD_RELOC_RX_8U
|
||||
ENUMX
|
||||
BFD_RELOC_RX_16U
|
||||
ENUMX
|
||||
BFD_RELOC_RX_24U
|
||||
ENUMX
|
||||
BFD_RELOC_RX_DIR3U_PCREL
|
||||
ENUMX
|
||||
BFD_RELOC_RX_DIFF
|
||||
ENUMX
|
||||
BFD_RELOC_RX_GPRELB
|
||||
ENUMX
|
||||
BFD_RELOC_RX_GPRELW
|
||||
ENUMX
|
||||
BFD_RELOC_RX_GPRELL
|
||||
ENUMX
|
||||
BFD_RELOC_RX_SYM
|
||||
ENUMX
|
||||
BFD_RELOC_RX_OP_SUBTRACT
|
||||
ENUMX
|
||||
BFD_RELOC_RX_ABS8
|
||||
ENUMX
|
||||
BFD_RELOC_RX_ABS16
|
||||
ENUMX
|
||||
BFD_RELOC_RX_ABS32
|
||||
ENUMX
|
||||
BFD_RELOC_RX_ABS16U
|
||||
ENUMX
|
||||
BFD_RELOC_RX_ABS16UW
|
||||
ENUMX
|
||||
BFD_RELOC_RX_ABS16UL
|
||||
ENUMX
|
||||
BFD_RELOC_RX_RELAX
|
||||
ENUMDOC
|
||||
Renesas RX Relocations.
|
||||
|
||||
ENUM
|
||||
BFD_RELOC_390_12
|
||||
ENUMDOC
|
||||
|
@ -641,6 +641,8 @@ extern const bfd_target bfd_elf32_pjl_vec;
|
||||
extern const bfd_target bfd_elf32_powerpc_vec;
|
||||
extern const bfd_target bfd_elf32_powerpcle_vec;
|
||||
extern const bfd_target bfd_elf32_powerpc_vxworks_vec;
|
||||
extern const bfd_target bfd_elf32_rx_le_vec;
|
||||
extern const bfd_target bfd_elf32_rx_be_vec;
|
||||
extern const bfd_target bfd_elf32_s390_vec;
|
||||
extern const bfd_target bfd_elf32_bigscore_vec;
|
||||
extern const bfd_target bfd_elf32_littlescore_vec;
|
||||
@ -978,6 +980,8 @@ static const bfd_target * const _bfd_target_vector[] =
|
||||
&bfd_elf32_powerpc_vec,
|
||||
&bfd_elf32_powerpc_vxworks_vec,
|
||||
&bfd_elf32_powerpcle_vec,
|
||||
&bfd_elf32_rx_be_vec,
|
||||
&bfd_elf32_rx_le_vec,
|
||||
&bfd_elf32_s390_vec,
|
||||
#ifdef BFD64
|
||||
&bfd_elf32_bigscore_vec,
|
||||
|
@ -1,3 +1,8 @@
|
||||
2009-09-29 DJ Delorie <dj@redhat.com>
|
||||
|
||||
* readelf.c: Add support for RX target.
|
||||
* MAINTAINERS: Add DJ and NickC as maintainers for RX.
|
||||
|
||||
2009-09-28 Alan Modra <amodra@bigpond.net.au>
|
||||
|
||||
* configure.in: Don't invoke configure.tgt on $enable_targets.
|
||||
|
@ -104,6 +104,8 @@ responsibility among the other maintainers.
|
||||
PPC Geoff Keating <geoffk@geoffk.org>
|
||||
PPC Alan Modra <amodra@bigpond.net.au>
|
||||
PPC vector ext Aldy Hernandez <aldyh@redhat.com>
|
||||
RX DJ Delorie <dj@redhat.com>
|
||||
RX Nick Clifton <nickc@redhat.com>
|
||||
s390, s390x Martin Schwidefsky <schwidefsky@de.ibm.com>
|
||||
SCORE Mei Ligang <ligang@sunnorth.com.cn>
|
||||
SH Alexandre Oliva <aoliva@redhat.com>
|
||||
|
@ -130,6 +130,7 @@
|
||||
#include "elf/pj.h"
|
||||
#include "elf/ppc.h"
|
||||
#include "elf/ppc64.h"
|
||||
#include "elf/rx.h"
|
||||
#include "elf/s390.h"
|
||||
#include "elf/score.h"
|
||||
#include "elf/sh.h"
|
||||
@ -604,6 +605,7 @@ guess_is_rela (unsigned int e_machine)
|
||||
case EM_NIOS32:
|
||||
case EM_PPC64:
|
||||
case EM_PPC:
|
||||
case EM_RX:
|
||||
case EM_S390:
|
||||
case EM_S390_OLD:
|
||||
case EM_SH:
|
||||
@ -1215,6 +1217,10 @@ dump_relocations (FILE * file,
|
||||
case EM_MICROBLAZE_OLD:
|
||||
rtype = elf_microblaze_reloc_type (type);
|
||||
break;
|
||||
|
||||
case EM_RX:
|
||||
rtype = elf_rx_reloc_type (type);
|
||||
break;
|
||||
}
|
||||
|
||||
if (rtype == NULL)
|
||||
@ -1887,6 +1893,7 @@ get_machine_name (unsigned e_machine)
|
||||
case EM_CR16_OLD: return "National Semiconductor's CR16";
|
||||
case EM_MICROBLAZE: return "Xilinx MicroBlaze";
|
||||
case EM_MICROBLAZE_OLD: return "Xilinx MicroBlaze";
|
||||
case EM_RX: return "Renesas RX";
|
||||
default:
|
||||
snprintf (buff, sizeof (buff), _("<unknown>: 0x%x"), e_machine);
|
||||
return buff;
|
||||
@ -2431,6 +2438,12 @@ get_machine_flags (unsigned e_flags, unsigned e_machine)
|
||||
if ((e_flags & EF_VAX_GFLOAT))
|
||||
strcat (buf, ", G-Float");
|
||||
break;
|
||||
|
||||
case EM_RX:
|
||||
if (e_flags & E_FLAG_RX_64BIT_DOUBLES)
|
||||
strcat (buf, ", 64-bit doubles");
|
||||
if (e_flags & E_FLAG_RX_DSP)
|
||||
strcat (buf, ", dsp");
|
||||
}
|
||||
}
|
||||
|
||||
@ -8054,6 +8067,8 @@ is_32bit_abs_reloc (unsigned int reloc_type)
|
||||
return reloc_type == 1; /* R_PPC64_ADDR32. */
|
||||
case EM_PPC:
|
||||
return reloc_type == 1; /* R_PPC_ADDR32. */
|
||||
case EM_RX:
|
||||
return reloc_type == 1; /* R_RX_DIR32. */
|
||||
case EM_S370:
|
||||
return reloc_type == 1; /* R_I370_ADDR31. */
|
||||
case EM_S390_OLD:
|
||||
|
@ -1,3 +1,23 @@
|
||||
2009-09-29 DJ Delorie <dj@redhat.com>
|
||||
|
||||
* Makefile.am: Add RX target.
|
||||
* configure.in: Likewise.
|
||||
* configure.tgt: Likewise.
|
||||
* read.c (do_repeat_with_expander): New function.
|
||||
* read.h: Provide a prototype for do_repeat_with_expander.
|
||||
* doc/Makefile.am: Add RX target documentation.
|
||||
* doc/all.texi: Likewise.
|
||||
* doc/as.texinfo: Likewise.
|
||||
* Makefile.in: Regenerate.
|
||||
* NEWS: Mention support for RX architecture.
|
||||
* configure: Regenerate.
|
||||
* doc/Makefile.in: Regenerate.
|
||||
* config/rx-defs.h: New file.
|
||||
* config/rx-parse.y: New file.
|
||||
* config/tc-rx.h: New file.
|
||||
* config/tc-rx.c: New file.
|
||||
* doc/c-rx.texi: New file.
|
||||
|
||||
2009-09-25 Martin Thuresson <martint@google.com>
|
||||
|
||||
Update soruces to make alpha, arc and arm targets compile cleanly
|
||||
|
@ -81,6 +81,7 @@ CPU_TYPES = \
|
||||
pdp11 \
|
||||
pj \
|
||||
ppc \
|
||||
rx \
|
||||
s390 \
|
||||
score \
|
||||
sh \
|
||||
@ -284,6 +285,7 @@ TARGET_CPU_CFILES = \
|
||||
config/tc-pdp11.c \
|
||||
config/tc-pj.c \
|
||||
config/tc-ppc.c \
|
||||
config/tc-rx.c \
|
||||
config/tc-s390.c \
|
||||
config/tc-score.c \
|
||||
config/tc-sh.c \
|
||||
@ -346,6 +348,7 @@ TARGET_CPU_HFILES = \
|
||||
config/tc-pdp11.h \
|
||||
config/tc-pj.h \
|
||||
config/tc-ppc.h \
|
||||
config/tc-rx.h \
|
||||
config/tc-s390.h \
|
||||
config/tc-score.h \
|
||||
config/tc-sh.h \
|
||||
@ -499,7 +502,8 @@ noinst_SCRIPTS = $(GDBINIT)
|
||||
EXTRA_SCRIPTS = .gdbinit
|
||||
|
||||
EXTRA_DIST = m68k-parse.c itbl-parse.c itbl-parse.h itbl-lex.c \
|
||||
bfin-parse.c bfin-parse.h bfin-lex.c
|
||||
bfin-parse.c bfin-parse.h bfin-lex.c \
|
||||
rx-parse.c rx-parse.h
|
||||
|
||||
diststuff: $(EXTRA_DIST) info
|
||||
|
||||
@ -628,6 +632,15 @@ endif
|
||||
$(COMPILE) -c `test -f bfin-lex.c || echo $(srcdir)/`bfin-lex.c $(NO_WERROR)
|
||||
endif
|
||||
|
||||
rx-parse.c: $(srcdir)/config/rx-parse.y
|
||||
$(SHELL) $(YLWRAP) $(srcdir)/config/rx-parse.y y.tab.c rx-parse.c y.tab.h rx-parse.h -- $(YACCCOMPILE) -d ;
|
||||
rx-parse.h: rx-parse.c
|
||||
rx-parse.o: rx-parse.c rx-parse.h $(srcdir)/config/rx-defs.h \
|
||||
$(INCDIR)/elf/common.h $(INCDIR)/elf/rx.h $(BFDDIR)/libbfd.h
|
||||
|
||||
rx-defs.h: ; @true
|
||||
$(srcdir)/config/rx-defs.h: ; @true
|
||||
|
||||
# The instruction table specification lexical analyzer and parser.
|
||||
|
||||
# Disable -Werror, if it has been enabled, since old versions of bison/
|
||||
|
@ -347,6 +347,7 @@ CPU_TYPES = \
|
||||
pdp11 \
|
||||
pj \
|
||||
ppc \
|
||||
rx \
|
||||
s390 \
|
||||
score \
|
||||
sh \
|
||||
@ -548,6 +549,7 @@ TARGET_CPU_CFILES = \
|
||||
config/tc-pdp11.c \
|
||||
config/tc-pj.c \
|
||||
config/tc-ppc.c \
|
||||
config/tc-rx.c \
|
||||
config/tc-s390.c \
|
||||
config/tc-score.c \
|
||||
config/tc-sh.c \
|
||||
@ -610,6 +612,7 @@ TARGET_CPU_HFILES = \
|
||||
config/tc-pdp11.h \
|
||||
config/tc-pj.h \
|
||||
config/tc-ppc.h \
|
||||
config/tc-rx.h \
|
||||
config/tc-s390.h \
|
||||
config/tc-score.h \
|
||||
config/tc-sh.h \
|
||||
@ -755,7 +758,8 @@ POTFILES = $(MULTI_CFILES) $(CONFIG_ATOF_CFILES) \
|
||||
noinst_SCRIPTS = $(GDBINIT)
|
||||
EXTRA_SCRIPTS = .gdbinit
|
||||
EXTRA_DIST = m68k-parse.c itbl-parse.c itbl-parse.h itbl-lex.c \
|
||||
bfin-parse.c bfin-parse.h bfin-lex.c
|
||||
bfin-parse.c bfin-parse.h bfin-lex.c \
|
||||
rx-parse.c rx-parse.h
|
||||
|
||||
DISTCLEANFILES = targ-cpu.h obj-format.h targ-env.h itbl-cpu.h cgen-desc.h
|
||||
|
||||
@ -989,6 +993,7 @@ distclean-compile:
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-pdp11.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-pj.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-ppc.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-rx.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-s390.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-score.Po@am__quote@
|
||||
@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-sh.Po@am__quote@
|
||||
@ -1646,6 +1651,20 @@ tc-ppc.obj: config/tc-ppc.c
|
||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||
@am__fastdepCC_FALSE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o tc-ppc.obj `if test -f 'config/tc-ppc.c'; then $(CYGPATH_W) 'config/tc-ppc.c'; else $(CYGPATH_W) '$(srcdir)/config/tc-ppc.c'; fi`
|
||||
|
||||
tc-rx.o: config/tc-rx.c
|
||||
@am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT tc-rx.o -MD -MP -MF $(DEPDIR)/tc-rx.Tpo -c -o tc-rx.o `test -f 'config/tc-rx.c' || echo '$(srcdir)/'`config/tc-rx.c
|
||||
@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/tc-rx.Tpo $(DEPDIR)/tc-rx.Po
|
||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='config/tc-rx.c' object='tc-rx.o' libtool=no @AMDEPBACKSLASH@
|
||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||
@am__fastdepCC_FALSE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o tc-rx.o `test -f 'config/tc-rx.c' || echo '$(srcdir)/'`config/tc-rx.c
|
||||
|
||||
tc-rx.obj: config/tc-rx.c
|
||||
@am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT tc-rx.obj -MD -MP -MF $(DEPDIR)/tc-rx.Tpo -c -o tc-rx.obj `if test -f 'config/tc-rx.c'; then $(CYGPATH_W) 'config/tc-rx.c'; else $(CYGPATH_W) '$(srcdir)/config/tc-rx.c'; fi`
|
||||
@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/tc-rx.Tpo $(DEPDIR)/tc-rx.Po
|
||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='config/tc-rx.c' object='tc-rx.obj' libtool=no @AMDEPBACKSLASH@
|
||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||
@am__fastdepCC_FALSE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o tc-rx.obj `if test -f 'config/tc-rx.c'; then $(CYGPATH_W) 'config/tc-rx.c'; else $(CYGPATH_W) '$(srcdir)/config/tc-rx.c'; fi`
|
||||
|
||||
tc-s390.o: config/tc-s390.c
|
||||
@am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT tc-s390.o -MD -MP -MF $(DEPDIR)/tc-s390.Tpo -c -o tc-s390.o `test -f 'config/tc-s390.c' || echo '$(srcdir)/'`config/tc-s390.c
|
||||
@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/tc-s390.Tpo $(DEPDIR)/tc-s390.Po
|
||||
@ -2534,6 +2553,15 @@ bfin-lex.o: bfin-lex.c bfin-parse.h $(srcdir)/config/bfin-defs.h
|
||||
@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
|
||||
@am__fastdepCC_FALSE@ $(COMPILE) -c `test -f bfin-lex.c || echo $(srcdir)/`bfin-lex.c $(NO_WERROR)
|
||||
|
||||
rx-parse.c: $(srcdir)/config/rx-parse.y
|
||||
$(SHELL) $(YLWRAP) $(srcdir)/config/rx-parse.y y.tab.c rx-parse.c y.tab.h rx-parse.h -- $(YACCCOMPILE) -d ;
|
||||
rx-parse.h: rx-parse.c
|
||||
rx-parse.o: rx-parse.c rx-parse.h $(srcdir)/config/rx-defs.h \
|
||||
$(INCDIR)/elf/common.h $(INCDIR)/elf/rx.h $(BFDDIR)/libbfd.h
|
||||
|
||||
rx-defs.h: ; @true
|
||||
$(srcdir)/config/rx-defs.h: ; @true
|
||||
|
||||
# The instruction table specification lexical analyzer and parser.
|
||||
|
||||
# Disable -Werror, if it has been enabled, since old versions of bison/
|
||||
|
2
gas/NEWS
2
gas/NEWS
@ -1,5 +1,7 @@
|
||||
-*- text -*-
|
||||
|
||||
* Add support for the Renesas RX processor.
|
||||
|
||||
Changes in 2.20:
|
||||
|
||||
* GNU/Linux targets now supports "gnu_unique_object" as a value in the .type
|
||||
|
57
gas/config/rx-defs.h
Normal file
57
gas/config/rx-defs.h
Normal file
@ -0,0 +1,57 @@
|
||||
/* rx-defs.h Renesas RX internal definitions
|
||||
Copyright 2008, 2009
|
||||
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 3, 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, 51 Franklin Street - Fifth Floor, Boston, MA
|
||||
02110-1301, USA. */
|
||||
|
||||
#ifndef RX_DEFS_H
|
||||
#define RX_DEFS_H
|
||||
|
||||
/* Third operand to rx_op. */
|
||||
#define RXREL_SIGNED 0
|
||||
#define RXREL_UNSIGNED 1
|
||||
#define RXREL_NEGATIVE 2
|
||||
#define RXREL_PCREL 3
|
||||
#define RXREL_NEGATIVE_BORROW 4
|
||||
|
||||
#define RX_RELAX_NONE 0
|
||||
#define RX_RELAX_BRANCH 1
|
||||
#define RX_RELAX_IMM 2
|
||||
#define RX_RELAX_DISP 3
|
||||
|
||||
extern int rx_error (char *);
|
||||
extern void rx_lex_init (char *, char *);
|
||||
extern void rx_base1 (int);
|
||||
extern void rx_base2 (int, int);
|
||||
extern void rx_base3 (int, int, int);
|
||||
extern void rx_base4 (int, int, int, int);
|
||||
extern void rx_field (int, int, int);
|
||||
extern void rx_op (expressionS, int, int);
|
||||
extern void rx_disp3 (expressionS, int);
|
||||
extern void rx_field5s (expressionS);
|
||||
extern void rx_field5s2 (expressionS);
|
||||
extern void rx_relax (int, int);
|
||||
extern void rx_linkrelax_dsp (int);
|
||||
extern void rx_linkrelax_imm (int);
|
||||
extern void rx_linkrelax_branch (void);
|
||||
extern int rx_parse (void);
|
||||
extern int rx_wrap (void);
|
||||
|
||||
extern char * rx_lex_start;
|
||||
extern char * rx_lex_end;
|
||||
#endif
|
1555
gas/config/rx-parse.y
Normal file
1555
gas/config/rx-parse.y
Normal file
File diff suppressed because it is too large
Load Diff
2394
gas/config/tc-rx.c
Normal file
2394
gas/config/tc-rx.c
Normal file
File diff suppressed because it is too large
Load Diff
93
gas/config/tc-rx.h
Normal file
93
gas/config/tc-rx.h
Normal file
@ -0,0 +1,93 @@
|
||||
/* tc-rx.h - header file for Renesas RX
|
||||
Copyright 2008, 2009
|
||||
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 3, 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, 51 Franklin Street - Fifth Floor, Boston, MA
|
||||
02110-1301, USA. */
|
||||
|
||||
#define TC_RX
|
||||
|
||||
extern int target_big_endian;
|
||||
|
||||
#define LISTING_HEADER (target_big_endian ? "RX GAS BE" : "RX GAS LE")
|
||||
#define LISTING_LHS_WIDTH 8
|
||||
#define LISTING_WORD_SIZE 1
|
||||
|
||||
#define TARGET_ARCH bfd_arch_rx
|
||||
|
||||
/* Instruction bytes are big endian, data bytes can be either. */
|
||||
#define TARGET_BYTES_BIG_ENDIAN 0
|
||||
|
||||
#define TARGET_FORMAT (target_big_endian ? "elf32-rx-be" : "elf32-rx-le")
|
||||
|
||||
/* We don't need to handle .word strangely. */
|
||||
#define WORKING_DOT_WORD
|
||||
|
||||
/* Permit temporary numeric labels. */
|
||||
#define LOCAL_LABELS_FB 1
|
||||
/* But make sure that the binutils treat them as locals. */
|
||||
#define LOCAL_LABEL_PREFIX '.'
|
||||
|
||||
/* Allow classic-style constants. */
|
||||
#define NUMBERS_WITH_SUFFIX 1
|
||||
|
||||
/* .-foo gets turned into PC relative relocs. */
|
||||
#define DIFF_EXPR_OK
|
||||
|
||||
#define md_end rx_md_end
|
||||
extern void rx_md_end (void);
|
||||
|
||||
#define md_relax_frag rx_relax_frag
|
||||
extern int rx_relax_frag (segT, fragS *, long);
|
||||
|
||||
#define TC_FRAG_TYPE struct rx_bytesT *
|
||||
#define TC_FRAG_INIT rx_frag_init
|
||||
extern void rx_frag_init (fragS *);
|
||||
|
||||
/* Call md_pcrel_from_section(), not md_pcrel_from(). */
|
||||
#define MD_PCREL_FROM_SECTION(FIXP, SEC) md_pcrel_from_section (FIXP, SEC)
|
||||
extern long md_pcrel_from_section (struct fix *, segT);
|
||||
|
||||
/* RX doesn't have a 32 bit PCREL relocations. */
|
||||
#define TC_FORCE_RELOCATION_SUB_LOCAL(FIX, SEG) 1
|
||||
|
||||
#define TC_VALIDATE_FIX_SUB(FIX, SEG) \
|
||||
rx_validate_fix_sub (FIX)
|
||||
extern int rx_validate_fix_sub (struct fix *);
|
||||
|
||||
#define TC_CONS_FIX_NEW(FRAG, WHERE, NBYTES, EXP) \
|
||||
rx_cons_fix_new (FRAG, WHERE, NBYTES, EXP)
|
||||
extern void rx_cons_fix_new (fragS *, int, int, expressionS *);
|
||||
|
||||
#define tc_fix_adjustable(x) 0
|
||||
|
||||
#define HANDLE_ALIGN(FRAG) rx_handle_align (FRAG)
|
||||
extern void rx_handle_align (fragS *);
|
||||
|
||||
#define RELOC_EXPANSION_POSSIBLE 1
|
||||
#define MAX_RELOC_EXPANSION 4
|
||||
|
||||
#define elf_tc_final_processing rx_elf_final_processing
|
||||
extern void rx_elf_final_processing (void);
|
||||
|
||||
extern bfd_boolean rx_use_conventional_section_names;
|
||||
#define TEXT_SECTION_NAME (rx_use_conventional_section_names ? ".text" : "P")
|
||||
#define DATA_SECTION_NAME (rx_use_conventional_section_names ? ".data" : "D_1")
|
||||
#define BSS_SECTION_NAME (rx_use_conventional_section_names ? ".bss" : "B_1")
|
||||
|
||||
#define md_start_line_hook rx_start_line
|
||||
extern void rx_start_line (void);
|
7
gas/configure
vendored
7
gas/configure
vendored
@ -12029,6 +12029,13 @@ _ACEOF
|
||||
fi
|
||||
;;
|
||||
|
||||
rx)
|
||||
echo ${extra_objects} | grep -s "rx-parse.o"
|
||||
if test $? -ne 0 ; then
|
||||
extra_objects="$extra_objects rx-parse.o"
|
||||
fi
|
||||
;;
|
||||
|
||||
xstormy16)
|
||||
using_cgen=yes
|
||||
;;
|
||||
|
@ -353,6 +353,13 @@ changequote([,])dnl
|
||||
fi
|
||||
;;
|
||||
|
||||
rx)
|
||||
echo ${extra_objects} | grep -s "rx-parse.o"
|
||||
if test $? -ne 0 ; then
|
||||
extra_objects="$extra_objects rx-parse.o"
|
||||
fi
|
||||
;;
|
||||
|
||||
xstormy16)
|
||||
using_cgen=yes
|
||||
;;
|
||||
|
@ -65,6 +65,7 @@ case ${cpu} in
|
||||
powerpc*le*) cpu_type=ppc endian=little ;;
|
||||
powerpc*) cpu_type=ppc endian=big ;;
|
||||
rs6000*) cpu_type=ppc ;;
|
||||
rx) cpu_type=rx ;;
|
||||
s390x*) cpu_type=s390 arch=s390x ;;
|
||||
s390*) cpu_type=s390 arch=s390 ;;
|
||||
score*l) cpu_type=score endian=little ;;
|
||||
|
@ -58,6 +58,7 @@ CPU_DOCS = \
|
||||
c-pdp11.texi \
|
||||
c-pj.texi \
|
||||
c-ppc.texi \
|
||||
c-rx.texi \
|
||||
c-s390.texi \
|
||||
c-score.texi \
|
||||
c-sh.texi \
|
||||
|
@ -296,6 +296,7 @@ CPU_DOCS = \
|
||||
c-pdp11.texi \
|
||||
c-pj.texi \
|
||||
c-ppc.texi \
|
||||
c-rx.texi \
|
||||
c-s390.texi \
|
||||
c-score.texi \
|
||||
c-sh.texi \
|
||||
|
@ -58,6 +58,7 @@
|
||||
@set PDP11
|
||||
@set PJ
|
||||
@set PPC
|
||||
@set RX
|
||||
@set S390
|
||||
@set SCORE
|
||||
@set SH
|
||||
|
@ -421,6 +421,13 @@ gcc(1), ld(1), and the Info entries for @file{binutils} and @file{ld}.
|
||||
[@b{-mlittle}|@b{-mlittle-endian}|@b{-mbig}|@b{-mbig-endian}]
|
||||
[@b{-msolaris}|@b{-mno-solaris}]
|
||||
@end ifset
|
||||
@ifset RX
|
||||
|
||||
@emph{Target RX options:}
|
||||
[@b{-mlittle-endian}|@b{-mbig-endian}]
|
||||
[@b{-m32bit-ints}|@b{-m16bit-ints}]
|
||||
[@b{-m32bit-doubles}|@b{-m64bit-doubles}]
|
||||
@end ifset
|
||||
@ifset S390
|
||||
|
||||
@emph{Target s390 options:}
|
||||
|
145
gas/doc/c-rx.texi
Normal file
145
gas/doc/c-rx.texi
Normal file
@ -0,0 +1,145 @@
|
||||
@c Copyright 2008, 2009
|
||||
@c Free Software Foundation, Inc.
|
||||
@c This is part of the GAS manual.
|
||||
@c For copying conditions, see the file as.texinfo.
|
||||
@ifset GENERIC
|
||||
@page
|
||||
@node RX-Dependent
|
||||
@chapter RX Dependent Features
|
||||
@end ifset
|
||||
@ifclear GENERIC
|
||||
@node Machine Dependencies
|
||||
@chapter RX Dependent Features
|
||||
@end ifclear
|
||||
|
||||
@cindex RX support
|
||||
@menu
|
||||
* RX-Opts:: RX Assembler Command Line Options
|
||||
* RX-Modifiers:: Symbolic Operand Modifiers
|
||||
* RX-Directives:: Assembler Directives
|
||||
* RX-Float:: Floating Point
|
||||
@end menu
|
||||
|
||||
@node RX-Opts
|
||||
@section RX Options
|
||||
@cindex options, RX
|
||||
@cindex RX options
|
||||
|
||||
The Renesas RX port of @code{@value{AS}} has a few target specfic
|
||||
command line options:
|
||||
|
||||
@table @code
|
||||
|
||||
@cindex @samp{-m32bit-doubles}
|
||||
@item -m32bit-doubles
|
||||
This option controls the ABI and indicates to use a 32-bit float ABI.
|
||||
It has no effect on the assembled instructions, but it does influence
|
||||
the behaviour of the @samp{.double} pseudo-op.
|
||||
This is the default.
|
||||
|
||||
@cindex @samp{-m64bit-doubles}
|
||||
@item -m64bit-doubles
|
||||
This option controls the ABI and indicates to use a 64-bit float ABI.
|
||||
It has no effect on the assembled instructions, but it does influence
|
||||
the behaviour of the @samp{.double} pseudo-op.
|
||||
|
||||
@cindex @samp{-mbig-endian}
|
||||
@item -mbig-endian
|
||||
This option controls the ABI and indicates to use a big-endian data
|
||||
ABI. It has no effect on the assembled instructions, but it does
|
||||
influence the behaviour of the @samp{.short}, @samp{.hword}, @samp{.int},
|
||||
@samp{.word}, @samp{.long}, @samp{.quad} and @samp{.octa} pseudo-ops.
|
||||
|
||||
@cindex @samp{-mlittle-endian}
|
||||
@item -mlittle-endian
|
||||
This option controls the ABI and indicates to use a little-endian data
|
||||
ABI. It has no effect on the assembled instructions, but it does
|
||||
influence the behaviour of the @samp{.short}, @samp{.hword}, @samp{.int},
|
||||
@samp{.word}, @samp{.long}, @samp{.quad} and @samp{.octa} pseudo-ops.
|
||||
This is the default.
|
||||
|
||||
@cindex @samp{-muse-conventional-section-names}
|
||||
@item -muse-conventional-section-names
|
||||
This option controls the default names given to the code (.text),
|
||||
initialised data (.data) and uninitialised data sections (.bss).
|
||||
|
||||
@cindex @samp{-muse-renesas-section-names}
|
||||
@item -muse-renesas-section-names
|
||||
This option controls the default names given to the code (.P),
|
||||
initialised data (.D_1) and uninitialised data sections (.B_1).
|
||||
This is the default.
|
||||
|
||||
@cindex @samp{-msmall-data-limit}
|
||||
@item -msmall-data-limit
|
||||
This option tells the assembler that the small data limit feature of
|
||||
the RX port of GCC is being used. This results in the assembler
|
||||
generating an undefined reference to a symbol called __gp for use by
|
||||
the relocations that are needed to support the small data limit
|
||||
feature. This option is not enabled by default as it would otherwise
|
||||
pollute the symbol table.
|
||||
|
||||
@end table
|
||||
|
||||
@node RX-Modifiers
|
||||
@section Symbolic Operand Modifiers
|
||||
|
||||
@cindex RX modifiers
|
||||
@cindex syntax, RX
|
||||
|
||||
The assembler supports several modifiers when using symbol addresses
|
||||
in RX instruction operands. The general syntax is the following:
|
||||
|
||||
@smallexample
|
||||
%modifier(symbol)
|
||||
@end smallexample
|
||||
|
||||
@table @code
|
||||
@cindex symbol modifiers
|
||||
|
||||
@item %gp
|
||||
@c FIXME: Add documentation here.
|
||||
|
||||
@end table
|
||||
|
||||
@node RX-Directives
|
||||
@section Assembler Directives
|
||||
|
||||
@cindex assembler directives, RX
|
||||
@cindex RX assembler directives
|
||||
|
||||
The RX version of @code{@value{AS}} has the following specific
|
||||
assembler directives:
|
||||
|
||||
@table @code
|
||||
|
||||
@item .3byte
|
||||
@cindex assembler directive .3byte, RX
|
||||
@cindex RX assembler directive .3byte
|
||||
Inserts a 3-byte value into the output file at the current location.
|
||||
|
||||
@end table
|
||||
|
||||
@node RX-Float
|
||||
@section Floating Point
|
||||
|
||||
@cindex floating point, RX
|
||||
@cindex RX floating point
|
||||
|
||||
The floating point formats generated by directives are these.
|
||||
|
||||
@table @code
|
||||
@cindex @code{float} directive, RX
|
||||
|
||||
@item .float
|
||||
@code{Single} precision (32-bit) floating point constants.
|
||||
|
||||
@cindex @code{double} directive, RX
|
||||
@item .double
|
||||
If the @option{-m64bit-doubles} command line option has been specified
|
||||
then then @code{double} directive generates @code{double} precision
|
||||
(64-bit) floating point constants, otherwise it generates
|
||||
@code{single} precision (32-bit) floating point constants. To force
|
||||
the generation of 64-bit floating point constants used the @code{dc.d}
|
||||
directive instead.
|
||||
|
||||
@end table
|
51
gas/read.c
51
gas/read.c
@ -2981,6 +2981,57 @@ do_repeat (int count, const char *start, const char *end)
|
||||
buffer_limit = input_scrub_next_buffer (&input_line_pointer);
|
||||
}
|
||||
|
||||
/* Like do_repeat except that any text matching EXPANDER in the
|
||||
block is replaced by the itteration count. */
|
||||
|
||||
void
|
||||
do_repeat_with_expander (int count,
|
||||
const char * start,
|
||||
const char * end,
|
||||
const char * expander)
|
||||
{
|
||||
sb one;
|
||||
sb many;
|
||||
|
||||
sb_new (&one);
|
||||
if (!buffer_and_nest (start, end, &one, get_non_macro_line_sb))
|
||||
{
|
||||
as_bad (_("%s without %s"), start, end);
|
||||
return;
|
||||
}
|
||||
|
||||
sb_new (&many);
|
||||
|
||||
if (expander != NULL && strstr (one.ptr, expander) != NULL)
|
||||
{
|
||||
while (count -- > 0)
|
||||
{
|
||||
int len;
|
||||
char * sub;
|
||||
sb processed;
|
||||
|
||||
sb_new (& processed);
|
||||
sb_add_sb (& processed, & one);
|
||||
sub = strstr (processed.ptr, expander);
|
||||
len = sprintf (sub, "%d", count);
|
||||
gas_assert (len < 8);
|
||||
strcpy (sub + len, sub + 8);
|
||||
processed.len -= (8 - len);
|
||||
sb_add_sb (& many, & processed);
|
||||
sb_kill (& processed);
|
||||
}
|
||||
}
|
||||
else
|
||||
while (count-- > 0)
|
||||
sb_add_sb (&many, &one);
|
||||
|
||||
sb_kill (&one);
|
||||
|
||||
input_scrub_include_sb (&many, input_line_pointer, 1);
|
||||
sb_kill (&many);
|
||||
buffer_limit = input_scrub_next_buffer (&input_line_pointer);
|
||||
}
|
||||
|
||||
/* Skip to end of current repeat loop; EXTRA indicates how many additional
|
||||
input buffers to skip. Assumes that conditionals preceding the loop end
|
||||
are properly nested.
|
||||
|
@ -127,6 +127,7 @@ extern void stabs_generate_asm_lineno (void);
|
||||
extern void stabs_generate_asm_func (const char *, const char *);
|
||||
extern void stabs_generate_asm_endfunc (const char *, const char *);
|
||||
extern void do_repeat (int,const char *,const char *);
|
||||
extern void do_repeat_with_expander (int, const char *, const char *, const char *);
|
||||
extern void end_repeat (int);
|
||||
extern void do_parse_cons_expression (expressionS *, int);
|
||||
|
||||
|
@ -1,3 +1,13 @@
|
||||
2009-09-29 DJ Delorie <dj@redhat.com>
|
||||
|
||||
* gas/rx: New directory.
|
||||
* gas/rx/*: New set of test cases.
|
||||
* gas/elf/section2.e-rx: New expected output file.
|
||||
* gas/all/gas.exp: Add support for RX target.
|
||||
* gas/elf/elf.exp: Likewise.
|
||||
* gas/lns/lns.exp: Likewise.
|
||||
* gas/macros/macros.exp: Likewise.
|
||||
|
||||
2009-09-29 Peter Bergner <bergner@vnet.ibm.com>
|
||||
|
||||
* gas/ppc/vsx.s ("lxsdux", "lxvd2ux", "lxvw4ux", "stxsdux",
|
||||
|
@ -38,8 +38,11 @@ if { ![istarget cris-*-*] && ![istarget crisv32-*-*]
|
||||
# The MN10300 port supports link time relaxation which in turn allows
|
||||
# for link time resolution of the differneces of two symbols which are
|
||||
# undefined at assembly time. Hence this test will not pass for the
|
||||
# MN10300.
|
||||
if { ![istarget hppa*-*-*] && ![istarget mn10300-*-*] && ![istarget am3*-*-*] } then {
|
||||
# MN10300. The same thing is true for the RX port as well.
|
||||
if { ![istarget hppa*-*-*]
|
||||
&& ![istarget rx-*-*]
|
||||
&& ![istarget mn10300-*-*]
|
||||
&& ![istarget am3*-*-*] } then {
|
||||
gas_test_error "diff1.s" "" "difference of two undefined symbols"
|
||||
}
|
||||
|
||||
@ -109,12 +112,12 @@ case $target_triplet in {
|
||||
# symbol `sym' required but not present
|
||||
setup_xfail "*arm*-*-*aout*" "*arm*-*-*coff" \
|
||||
"*arm*-*-pe" "m68hc*-*-*" "maxq-*-*" \
|
||||
"vax*-*-*" "z8k-*-*"
|
||||
"rx-*-*" "vax*-*-*" "z8k-*-*"
|
||||
run_dump_test redef2
|
||||
setup_xfail "*-*-aix*" "*-*-coff" "*-*-cygwin" "*-*-mingw*" "*-*-pe*" \
|
||||
"bfin-*-*" "hppa*-*-hpux*" \
|
||||
"m68hc*-*-*" "maxq-*-*" "or32-*-*" \
|
||||
"vax*-*-*" "z8k-*-*"
|
||||
"rx-*-*" "vax*-*-*" "z8k-*-*"
|
||||
run_dump_test redef3
|
||||
gas_test_error "redef4.s" "" ".set for symbol already used as label"
|
||||
gas_test_error "redef5.s" "" ".set for symbol already defined through .comm"
|
||||
@ -163,7 +166,7 @@ proc general_info_section {} {
|
||||
gas_start "comment.s" "-agn"
|
||||
while 1 {
|
||||
expect {
|
||||
-re "^ \[^\n\]*\t: \-agn\[^\n\]*\n" { set x1 1 }
|
||||
-re "^ \[^\n\]*\t: .*\-agn\[^\n\]*\n" { set x1 1 }
|
||||
-re "^ \[^\n\]*\t: \[^\n\]*comment\.s\[^\n\]*\n" { set x2 1 }
|
||||
-re "^ \[^\n\]*\t: a\.out\[^\n\]*\n" { set x3 1 }
|
||||
-re "\[^\n\]*\n" { }
|
||||
@ -300,6 +303,7 @@ case $target_triplet in {
|
||||
{ hppa*-*-* } { }
|
||||
{ *c4x*-*-* } { }
|
||||
{ *c54x*-*-* } { }
|
||||
{ rx-*-* } { }
|
||||
default {
|
||||
test_cond
|
||||
remote_download host "$srcdir/$subdir/incbin.dat"
|
||||
|
@ -62,6 +62,9 @@ if { ([istarget "*-*-*elf*"]
|
||||
if {[istarget "xtensa*-*-*"]} then {
|
||||
set target_machine -xtensa
|
||||
}
|
||||
if {[istarget "rx-*-*"]} then {
|
||||
set target_machine -rx
|
||||
}
|
||||
if { ([istarget "*arm*-*-*"]
|
||||
|| [istarget "xscale*-*-*"]) } {
|
||||
|
||||
@ -111,6 +114,7 @@ if { ([istarget "*-*-*elf*"]
|
||||
{ mn10200-*-* } { }
|
||||
{ mn10300-*-* } { }
|
||||
{ *c54x*-*-* } { }
|
||||
{ rx-*-* } { }
|
||||
default {
|
||||
# The next test can fail if the target does not convert fixups
|
||||
# against ordinary symbols into relocations against section symbols.
|
||||
|
9
gas/testsuite/gas/elf/section2.e-rx
Normal file
9
gas/testsuite/gas/elf/section2.e-rx
Normal file
@ -0,0 +1,9 @@
|
||||
|
||||
Symbol table '.symtab' contains . entries:
|
||||
Num: Value[ ]* Size Type Bind Vis Ndx Name
|
||||
0: 0+0 0 NOTYPE LOCAL DEFAULT UND
|
||||
1: 0+0 0 SECTION LOCAL DEFAULT 1
|
||||
2: 0+0 0 SECTION LOCAL DEFAULT 2
|
||||
3: 0+0 0 SECTION LOCAL DEFAULT 3
|
||||
4: 0+0 0 SECTION LOCAL DEFAULT 4
|
||||
#...
|
@ -13,6 +13,7 @@ if {
|
||||
&& ![istarget i960-*-*]
|
||||
&& ![istarget mcore-*-*]
|
||||
&& ![istarget or32-*-*]
|
||||
&& ![istarget rx-*-*]
|
||||
&& ![istarget s390*-*-*]
|
||||
} {
|
||||
# Use alternate file for targets using DW_LNS_fixed_advance_pc opcodes.
|
||||
|
@ -65,6 +65,7 @@ case $target_triplet in {
|
||||
{ m68*-*-* } { }
|
||||
{ m88*-*-* } { }
|
||||
{ mmix-* } { }
|
||||
{ rx-*-* } { }
|
||||
{ z80-* } { }
|
||||
default { run_list_test dot "-alm" }
|
||||
}
|
||||
|
14
gas/testsuite/gas/rx/abs.d
Normal file
14
gas/testsuite/gas/rx/abs.d
Normal file
@ -0,0 +1,14 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 7e 20 abs r0
|
||||
2: 7e 2f abs r15
|
||||
4: fc 0f 00 abs r0, r0
|
||||
7: fc 0f 0f abs r0, r15
|
||||
a: fc 0f f0 abs r15, r0
|
||||
d: fc 0f ff abs r15, r15
|
2
gas/testsuite/gas/rx/abs.sm
Normal file
2
gas/testsuite/gas/rx/abs.sm
Normal file
@ -0,0 +1,2 @@
|
||||
abs {reg}
|
||||
abs {reg},{reg}
|
40
gas/testsuite/gas/rx/adc.d
Normal file
40
gas/testsuite/gas/rx/adc.d
Normal file
@ -0,0 +1,40 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 74 20 80 adc #-128, r0
|
||||
4: fd 74 2f 80 adc #-128, r15
|
||||
8: fd 74 20 7f adc #127, r0
|
||||
c: fd 74 2f 7f adc #127, r15
|
||||
10: fd 78 20 00 80 adc #0xffff8000, r0
|
||||
15: fd 78 2f 00 80 adc #0xffff8000, r15
|
||||
1a: fd 7c 20 00 80 00 adc #0x8000, r0
|
||||
20: fd 7c 2f 00 80 00 adc #0x8000, r15
|
||||
26: fd 7c 20 00 00 80 adc #0xff800000, r0
|
||||
2c: fd 7c 2f 00 00 80 adc #0xff800000, r15
|
||||
32: fd 7c 20 ff ff 7f adc #0x7fffff, r0
|
||||
38: fd 7c 2f ff ff 7f adc #0x7fffff, r15
|
||||
3e: fd 70 20 00 00 00 80 adc #0x80000000, r0
|
||||
45: fd 70 2f 00 00 00 80 adc #0x80000000, r15
|
||||
4c: fd 70 20 ff ff ff 7f adc #0x7fffffff, r0
|
||||
53: fd 70 2f ff ff ff 7f adc #0x7fffffff, r15
|
||||
5a: fc 0b 00 adc r0, r0
|
||||
5d: fc 0b 0f adc r0, r15
|
||||
60: fc 0b f0 adc r15, r0
|
||||
63: fc 0b ff adc r15, r15
|
||||
66: 06 a0 02 00 adc \[r0\]\.l, r0
|
||||
6a: 06 a0 02 0f adc \[r0\]\.l, r15
|
||||
6e: 06 a0 02 f0 adc \[r15\]\.l, r0
|
||||
72: 06 a0 02 ff adc \[r15\]\.l, r15
|
||||
76: 06 a1 02 00 3f adc 252\[r0\]\.l, r0
|
||||
7b: 06 a1 02 0f 3f adc 252\[r0\]\.l, r15
|
||||
80: 06 a1 02 f0 3f adc 252\[r15\]\.l, r0
|
||||
85: 06 a1 02 ff 3f adc 252\[r15\]\.l, r15
|
||||
8a: 06 a2 02 00 ff 3f adc 65532\[r0\]\.l, r0
|
||||
90: 06 a2 02 0f ff 3f adc 65532\[r0\]\.l, r15
|
||||
96: 06 a2 02 f0 ff 3f adc 65532\[r15\]\.l, r0
|
||||
9c: 06 a2 02 ff ff 3f adc 65532\[r15\]\.l, r15
|
4
gas/testsuite/gas/rx/adc.sm
Normal file
4
gas/testsuite/gas/rx/adc.sm
Normal file
@ -0,0 +1,4 @@
|
||||
adc #{imm},{reg}
|
||||
adc {reg},{reg}
|
||||
adc {dsp}[{reg}].L,{reg}
|
||||
|
132
gas/testsuite/gas/rx/add.d
Normal file
132
gas/testsuite/gas/rx/add.d
Normal file
@ -0,0 +1,132 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 62 00 add #0, r0
|
||||
2: 62 0f add #0, r15
|
||||
4: 62 f0 add #15, r0
|
||||
6: 62 ff add #15, r15
|
||||
8: 71 00 80 add #-128, r0, r0
|
||||
b: 71 ff 80 add #-128, r15, r15
|
||||
e: 71 00 7f add #127, r0, r0
|
||||
11: 71 ff 7f add #127, r15, r15
|
||||
14: 72 00 00 80 add #0xffff8000, r0, r0
|
||||
18: 72 ff 00 80 add #0xffff8000, r15, r15
|
||||
1c: 73 00 00 80 00 add #0x8000, r0, r0
|
||||
21: 73 ff 00 80 00 add #0x8000, r15, r15
|
||||
26: 73 00 00 00 80 add #0xff800000, r0, r0
|
||||
2b: 73 ff 00 00 80 add #0xff800000, r15, r15
|
||||
30: 73 00 ff ff 7f add #0x7fffff, r0, r0
|
||||
35: 73 ff ff ff 7f add #0x7fffff, r15, r15
|
||||
3a: 70 00 00 00 00 80 add #0x80000000, r0, r0
|
||||
40: 70 ff 00 00 00 80 add #0x80000000, r15, r15
|
||||
46: 70 00 ff ff ff 7f add #0x7fffffff, r0, r0
|
||||
4c: 70 ff ff ff ff 7f add #0x7fffffff, r15, r15
|
||||
52: 4b 00 add r0, r0
|
||||
54: 4b 0f add r0, r15
|
||||
56: 4b f0 add r15, r0
|
||||
58: 4b ff add r15, r15
|
||||
5a: 48 00 add \[r0\]\.ub, r0
|
||||
5c: 48 0f add \[r0\]\.ub, r15
|
||||
5e: 06 08 00 add \[r0\]\.b, r0
|
||||
61: 06 08 0f add \[r0\]\.b, r15
|
||||
64: 06 c8 00 add \[r0\]\.uw, r0
|
||||
67: 06 c8 0f add \[r0\]\.uw, r15
|
||||
6a: 06 48 00 add \[r0\]\.w, r0
|
||||
6d: 06 48 0f add \[r0\]\.w, r15
|
||||
70: 06 88 00 add \[r0\]\.l, r0
|
||||
73: 06 88 0f add \[r0\]\.l, r15
|
||||
76: 48 f0 add \[r15\]\.ub, r0
|
||||
78: 48 ff add \[r15\]\.ub, r15
|
||||
7a: 06 08 f0 add \[r15\]\.b, r0
|
||||
7d: 06 08 ff add \[r15\]\.b, r15
|
||||
80: 06 c8 f0 add \[r15\]\.uw, r0
|
||||
83: 06 c8 ff add \[r15\]\.uw, r15
|
||||
86: 06 48 f0 add \[r15\]\.w, r0
|
||||
89: 06 48 ff add \[r15\]\.w, r15
|
||||
8c: 06 88 f0 add \[r15\]\.l, r0
|
||||
8f: 06 88 ff add \[r15\]\.l, r15
|
||||
92: 49 00 fc add 252\[r0\]\.ub, r0
|
||||
95: 49 0f fc add 252\[r0\]\.ub, r15
|
||||
98: 06 09 00 fc add 252\[r0\]\.b, r0
|
||||
9c: 06 09 0f fc add 252\[r0\]\.b, r15
|
||||
a0: 06 c9 00 7e add 252\[r0\]\.uw, r0
|
||||
a4: 06 c9 0f 7e add 252\[r0\]\.uw, r15
|
||||
a8: 06 49 00 7e add 252\[r0\]\.w, r0
|
||||
ac: 06 49 0f 7e add 252\[r0\]\.w, r15
|
||||
b0: 06 89 00 3f add 252\[r0\]\.l, r0
|
||||
b4: 06 89 0f 3f add 252\[r0\]\.l, r15
|
||||
b8: 49 f0 fc add 252\[r15\]\.ub, r0
|
||||
bb: 49 ff fc add 252\[r15\]\.ub, r15
|
||||
be: 06 09 f0 fc add 252\[r15\]\.b, r0
|
||||
c2: 06 09 ff fc add 252\[r15\]\.b, r15
|
||||
c6: 06 c9 f0 7e add 252\[r15\]\.uw, r0
|
||||
ca: 06 c9 ff 7e add 252\[r15\]\.uw, r15
|
||||
ce: 06 49 f0 7e add 252\[r15\]\.w, r0
|
||||
d2: 06 49 ff 7e add 252\[r15\]\.w, r15
|
||||
d6: 06 89 f0 3f add 252\[r15\]\.l, r0
|
||||
da: 06 89 ff 3f add 252\[r15\]\.l, r15
|
||||
de: 4a 00 fc ff add 65532\[r0\]\.ub, r0
|
||||
e2: 4a 0f fc ff add 65532\[r0\]\.ub, r15
|
||||
e6: 06 0a 00 fc ff add 65532\[r0\]\.b, r0
|
||||
eb: 06 0a 0f fc ff add 65532\[r0\]\.b, r15
|
||||
f0: 06 ca 00 fe 7f add 65532\[r0\]\.uw, r0
|
||||
f5: 06 ca 0f fe 7f add 65532\[r0\]\.uw, r15
|
||||
fa: 06 4a 00 fe 7f add 65532\[r0\]\.w, r0
|
||||
ff: 06 4a 0f fe 7f add 65532\[r0\]\.w, r15
|
||||
104: 06 8a 00 ff 3f add 65532\[r0\]\.l, r0
|
||||
109: 06 8a 0f ff 3f add 65532\[r0\]\.l, r15
|
||||
10e: 4a f0 fc ff add 65532\[r15\]\.ub, r0
|
||||
112: 4a ff fc ff add 65532\[r15\]\.ub, r15
|
||||
116: 06 0a f0 fc ff add 65532\[r15\]\.b, r0
|
||||
11b: 06 0a ff fc ff add 65532\[r15\]\.b, r15
|
||||
120: 06 ca f0 fe 7f add 65532\[r15\]\.uw, r0
|
||||
125: 06 ca ff fe 7f add 65532\[r15\]\.uw, r15
|
||||
12a: 06 4a f0 fe 7f add 65532\[r15\]\.w, r0
|
||||
12f: 06 4a ff fe 7f add 65532\[r15\]\.w, r15
|
||||
134: 06 8a f0 ff 3f add 65532\[r15\]\.l, r0
|
||||
139: 06 8a ff ff 3f add 65532\[r15\]\.l, r15
|
||||
13e: 71 00 80 add #-128, r0, r0
|
||||
141: 71 0f 80 add #-128, r0, r15
|
||||
144: 71 f0 80 add #-128, r15, r0
|
||||
147: 71 ff 80 add #-128, r15, r15
|
||||
14a: 71 00 7f add #127, r0, r0
|
||||
14d: 71 0f 7f add #127, r0, r15
|
||||
150: 71 f0 7f add #127, r15, r0
|
||||
153: 71 ff 7f add #127, r15, r15
|
||||
156: 72 00 00 80 add #0xffff8000, r0, r0
|
||||
15a: 72 0f 00 80 add #0xffff8000, r0, r15
|
||||
15e: 72 f0 00 80 add #0xffff8000, r15, r0
|
||||
162: 72 ff 00 80 add #0xffff8000, r15, r15
|
||||
166: 73 00 00 80 00 add #0x8000, r0, r0
|
||||
16b: 73 0f 00 80 00 add #0x8000, r0, r15
|
||||
170: 73 f0 00 80 00 add #0x8000, r15, r0
|
||||
175: 73 ff 00 80 00 add #0x8000, r15, r15
|
||||
17a: 73 00 00 00 80 add #0xff800000, r0, r0
|
||||
17f: 73 0f 00 00 80 add #0xff800000, r0, r15
|
||||
184: 73 f0 00 00 80 add #0xff800000, r15, r0
|
||||
189: 73 ff 00 00 80 add #0xff800000, r15, r15
|
||||
18e: 73 00 ff ff 7f add #0x7fffff, r0, r0
|
||||
193: 73 0f ff ff 7f add #0x7fffff, r0, r15
|
||||
198: 73 f0 ff ff 7f add #0x7fffff, r15, r0
|
||||
19d: 73 ff ff ff 7f add #0x7fffff, r15, r15
|
||||
1a2: 70 00 00 00 00 80 add #0x80000000, r0, r0
|
||||
1a8: 70 0f 00 00 00 80 add #0x80000000, r0, r15
|
||||
1ae: 70 f0 00 00 00 80 add #0x80000000, r15, r0
|
||||
1b4: 70 ff 00 00 00 80 add #0x80000000, r15, r15
|
||||
1ba: 70 00 ff ff ff 7f add #0x7fffffff, r0, r0
|
||||
1c0: 70 0f ff ff ff 7f add #0x7fffffff, r0, r15
|
||||
1c6: 70 f0 ff ff ff 7f add #0x7fffffff, r15, r0
|
||||
1cc: 70 ff ff ff ff 7f add #0x7fffffff, r15, r15
|
||||
1d2: ff 20 00 add r0, r0, r0
|
||||
1d5: ff 2f 00 add r0, r0, r15
|
||||
1d8: ff 20 0f add r0, r15, r0
|
||||
1db: ff 2f 0f add r0, r15, r15
|
||||
1de: ff 20 f0 add r15, r0, r0
|
||||
1e1: ff 2f f0 add r15, r0, r15
|
||||
1e4: ff 20 ff add r15, r15, r0
|
||||
1e7: ff 2f ff add r15, r15, r15
|
8
gas/testsuite/gas/rx/add.sm
Normal file
8
gas/testsuite/gas/rx/add.sm
Normal file
@ -0,0 +1,8 @@
|
||||
add #{uimm4},{reg}
|
||||
add #{imm},{reg}
|
||||
|
||||
add {reg},{reg}
|
||||
add {memx},{reg}
|
||||
|
||||
add #{imm},{reg},{reg}
|
||||
add {reg},{reg},{reg}
|
100
gas/testsuite/gas/rx/and.d
Normal file
100
gas/testsuite/gas/rx/and.d
Normal file
@ -0,0 +1,100 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 64 00 and #0, r0
|
||||
2: 64 0f and #0, r15
|
||||
4: 64 f0 and #15, r0
|
||||
6: 64 ff and #15, r15
|
||||
8: 75 20 80 and #-128, r0
|
||||
b: 75 2f 80 and #-128, r15
|
||||
e: 75 20 7f and #127, r0
|
||||
11: 75 2f 7f and #127, r15
|
||||
14: 76 20 00 80 and #0xffff8000, r0
|
||||
18: 76 2f 00 80 and #0xffff8000, r15
|
||||
1c: 77 20 00 80 00 and #0x8000, r0
|
||||
21: 77 2f 00 80 00 and #0x8000, r15
|
||||
26: 77 20 00 00 80 and #0xff800000, r0
|
||||
2b: 77 2f 00 00 80 and #0xff800000, r15
|
||||
30: 77 20 ff ff 7f and #0x7fffff, r0
|
||||
35: 77 2f ff ff 7f and #0x7fffff, r15
|
||||
3a: 74 20 00 00 00 80 and #0x80000000, r0
|
||||
40: 74 2f 00 00 00 80 and #0x80000000, r15
|
||||
46: 74 20 ff ff ff 7f and #0x7fffffff, r0
|
||||
4c: 74 2f ff ff ff 7f and #0x7fffffff, r15
|
||||
52: 53 00 and r0, r0
|
||||
54: 53 0f and r0, r15
|
||||
56: 53 f0 and r15, r0
|
||||
58: 53 ff and r15, r15
|
||||
5a: 50 00 and \[r0\]\.ub, r0
|
||||
5c: 50 0f and \[r0\]\.ub, r15
|
||||
5e: 06 10 00 and \[r0\]\.b, r0
|
||||
61: 06 10 0f and \[r0\]\.b, r15
|
||||
64: 06 d0 00 and \[r0\]\.uw, r0
|
||||
67: 06 d0 0f and \[r0\]\.uw, r15
|
||||
6a: 06 50 00 and \[r0\]\.w, r0
|
||||
6d: 06 50 0f and \[r0\]\.w, r15
|
||||
70: 06 90 00 and \[r0\]\.l, r0
|
||||
73: 06 90 0f and \[r0\]\.l, r15
|
||||
76: 50 f0 and \[r15\]\.ub, r0
|
||||
78: 50 ff and \[r15\]\.ub, r15
|
||||
7a: 06 10 f0 and \[r15\]\.b, r0
|
||||
7d: 06 10 ff and \[r15\]\.b, r15
|
||||
80: 06 d0 f0 and \[r15\]\.uw, r0
|
||||
83: 06 d0 ff and \[r15\]\.uw, r15
|
||||
86: 06 50 f0 and \[r15\]\.w, r0
|
||||
89: 06 50 ff and \[r15\]\.w, r15
|
||||
8c: 06 90 f0 and \[r15\]\.l, r0
|
||||
8f: 06 90 ff and \[r15\]\.l, r15
|
||||
92: 51 00 fc and 252\[r0\]\.ub, r0
|
||||
95: 51 0f fc and 252\[r0\]\.ub, r15
|
||||
98: 06 11 00 fc and 252\[r0\]\.b, r0
|
||||
9c: 06 11 0f fc and 252\[r0\]\.b, r15
|
||||
a0: 06 d1 00 7e and 252\[r0\]\.uw, r0
|
||||
a4: 06 d1 0f 7e and 252\[r0\]\.uw, r15
|
||||
a8: 06 51 00 7e and 252\[r0\]\.w, r0
|
||||
ac: 06 51 0f 7e and 252\[r0\]\.w, r15
|
||||
b0: 06 91 00 3f and 252\[r0\]\.l, r0
|
||||
b4: 06 91 0f 3f and 252\[r0\]\.l, r15
|
||||
b8: 51 f0 fc and 252\[r15\]\.ub, r0
|
||||
bb: 51 ff fc and 252\[r15\]\.ub, r15
|
||||
be: 06 11 f0 fc and 252\[r15\]\.b, r0
|
||||
c2: 06 11 ff fc and 252\[r15\]\.b, r15
|
||||
c6: 06 d1 f0 7e and 252\[r15\]\.uw, r0
|
||||
ca: 06 d1 ff 7e and 252\[r15\]\.uw, r15
|
||||
ce: 06 51 f0 7e and 252\[r15\]\.w, r0
|
||||
d2: 06 51 ff 7e and 252\[r15\]\.w, r15
|
||||
d6: 06 91 f0 3f and 252\[r15\]\.l, r0
|
||||
da: 06 91 ff 3f and 252\[r15\]\.l, r15
|
||||
de: 52 00 fc ff and 65532\[r0\]\.ub, r0
|
||||
e2: 52 0f fc ff and 65532\[r0\]\.ub, r15
|
||||
e6: 06 12 00 fc ff and 65532\[r0\]\.b, r0
|
||||
eb: 06 12 0f fc ff and 65532\[r0\]\.b, r15
|
||||
f0: 06 d2 00 fe 7f and 65532\[r0\]\.uw, r0
|
||||
f5: 06 d2 0f fe 7f and 65532\[r0\]\.uw, r15
|
||||
fa: 06 52 00 fe 7f and 65532\[r0\]\.w, r0
|
||||
ff: 06 52 0f fe 7f and 65532\[r0\]\.w, r15
|
||||
104: 06 92 00 ff 3f and 65532\[r0\]\.l, r0
|
||||
109: 06 92 0f ff 3f and 65532\[r0\]\.l, r15
|
||||
10e: 52 f0 fc ff and 65532\[r15\]\.ub, r0
|
||||
112: 52 ff fc ff and 65532\[r15\]\.ub, r15
|
||||
116: 06 12 f0 fc ff and 65532\[r15\]\.b, r0
|
||||
11b: 06 12 ff fc ff and 65532\[r15\]\.b, r15
|
||||
120: 06 d2 f0 fe 7f and 65532\[r15\]\.uw, r0
|
||||
125: 06 d2 ff fe 7f and 65532\[r15\]\.uw, r15
|
||||
12a: 06 52 f0 fe 7f and 65532\[r15\]\.w, r0
|
||||
12f: 06 52 ff fe 7f and 65532\[r15\]\.w, r15
|
||||
134: 06 92 f0 ff 3f and 65532\[r15\]\.l, r0
|
||||
139: 06 92 ff ff 3f and 65532\[r15\]\.l, r15
|
||||
13e: ff 40 00 and r0, r0, r0
|
||||
141: ff 4f 00 and r0, r0, r15
|
||||
144: ff 40 0f and r0, r15, r0
|
||||
147: ff 4f 0f and r0, r15, r15
|
||||
14a: ff 40 f0 and r15, r0, r0
|
||||
14d: ff 4f f0 and r15, r0, r15
|
||||
150: ff 40 ff and r15, r15, r0
|
||||
153: ff 4f ff and r15, r15, r15
|
7
gas/testsuite/gas/rx/and.sm
Normal file
7
gas/testsuite/gas/rx/and.sm
Normal file
@ -0,0 +1,7 @@
|
||||
and #{uimm4},{reg}
|
||||
and #{imm},{reg}
|
||||
|
||||
and {reg},{reg}
|
||||
and {memx},{reg}
|
||||
|
||||
and {reg},{reg},{reg}
|
40
gas/testsuite/gas/rx/bclr.d
Normal file
40
gas/testsuite/gas/rx/bclr.d
Normal file
@ -0,0 +1,40 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: f0 08 bclr #0, \[r0\]\.b
|
||||
2: f0 f8 bclr #0, \[r15\]\.b
|
||||
4: f1 08 fc bclr #0, 252\[r0\]\.b
|
||||
7: f1 f8 fc bclr #0, 252\[r15\]\.b
|
||||
a: f2 08 fc ff bclr #0, 65532\[r0\]\.b
|
||||
e: f2 f8 fc ff bclr #0, 65532\[r15\]\.b
|
||||
12: f0 0f bclr #7, \[r0\]\.b
|
||||
14: f0 ff bclr #7, \[r15\]\.b
|
||||
16: f1 0f fc bclr #7, 252\[r0\]\.b
|
||||
19: f1 ff fc bclr #7, 252\[r15\]\.b
|
||||
1c: f2 0f fc ff bclr #7, 65532\[r0\]\.b
|
||||
20: f2 ff fc ff bclr #7, 65532\[r15\]\.b
|
||||
24: fc 64 00 bclr r0, \[r0\]\.b
|
||||
27: fc 64 f0 bclr r0, \[r15\]\.b
|
||||
2a: fc 65 00 fc bclr r0, 252\[r0\]\.b
|
||||
2e: fc 65 f0 fc bclr r0, 252\[r15\]\.b
|
||||
32: fc 66 00 fc ff bclr r0, 65532\[r0\]\.b
|
||||
37: fc 66 f0 fc ff bclr r0, 65532\[r15\]\.b
|
||||
3c: fc 64 0f bclr r15, \[r0\]\.b
|
||||
3f: fc 64 ff bclr r15, \[r15\]\.b
|
||||
42: fc 65 0f fc bclr r15, 252\[r0\]\.b
|
||||
46: fc 65 ff fc bclr r15, 252\[r15\]\.b
|
||||
4a: fc 66 0f fc ff bclr r15, 65532\[r0\]\.b
|
||||
4f: fc 66 ff fc ff bclr r15, 65532\[r15\]\.b
|
||||
54: 7a 00 bclr #0, r0
|
||||
56: 7a 0f bclr #0, r15
|
||||
58: 7b f0 bclr #31, r0
|
||||
5a: 7b ff bclr #31, r15
|
||||
5c: fc 67 00 bclr r0, r0
|
||||
5f: fc 67 f0 bclr r0, r15
|
||||
62: fc 67 0f bclr r15, r0
|
||||
65: fc 67 ff bclr r15, r15
|
5
gas/testsuite/gas/rx/bclr.sm
Normal file
5
gas/testsuite/gas/rx/bclr.sm
Normal file
@ -0,0 +1,5 @@
|
||||
bclr #{uimm3}, {dsp}[{reg}].B
|
||||
bclr {reg}, {dsp}[{reg}].B
|
||||
|
||||
bclr #{uimm5}, {reg}
|
||||
bclr {reg}, {reg}
|
104
gas/testsuite/gas/rx/bcnd.d
Normal file
104
gas/testsuite/gas/rx/bcnd.d
Normal file
@ -0,0 +1,104 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 13 beq\.s 0x3
|
||||
1: 12 beq\.s 0xb
|
||||
2: 10 beq\.s 0xa
|
||||
2: R_RX_DIR3U_PCREL foo
|
||||
3: 1b bne\.s 0x6
|
||||
4: 1a bne\.s 0xe
|
||||
5: 18 bne\.s 0xd
|
||||
5: R_RX_DIR3U_PCREL foo
|
||||
6: 22 80 bc\.b 0xffffff86
|
||||
8: 22 7f bc\.b 0x87
|
||||
a: 22 00 bc\.b 0xa
|
||||
b: R_RX_DIR8S_PCREL foo
|
||||
c: 22 80 bc\.b 0xffffff8c
|
||||
e: 22 7f bc\.b 0x8d
|
||||
10: 22 00 bc\.b 0x10
|
||||
11: R_RX_DIR8S_PCREL foo
|
||||
12: 20 80 beq\.b 0xffffff92
|
||||
14: 20 7f beq\.b 0x93
|
||||
16: 20 00 beq\.b 0x16
|
||||
17: R_RX_DIR8S_PCREL foo
|
||||
18: 20 80 beq\.b 0xffffff98
|
||||
1a: 20 7f beq\.b 0x99
|
||||
1c: 20 00 beq\.b 0x1c
|
||||
1d: R_RX_DIR8S_PCREL foo
|
||||
1e: 24 80 bgtu\.b 0xffffff9e
|
||||
20: 24 7f bgtu\.b 0x9f
|
||||
22: 24 00 bgtu\.b 0x22
|
||||
23: R_RX_DIR8S_PCREL foo
|
||||
24: 26 80 bpz\.b 0xffffffa4
|
||||
26: 26 7f bpz\.b 0xa5
|
||||
28: 26 00 bpz\.b 0x28
|
||||
29: R_RX_DIR8S_PCREL foo
|
||||
2a: 28 80 bge\.b 0xffffffaa
|
||||
2c: 28 7f bge\.b 0xab
|
||||
2e: 28 00 bge\.b 0x2e
|
||||
2f: R_RX_DIR8S_PCREL foo
|
||||
30: 2a 80 bgt\.b 0xffffffb0
|
||||
32: 2a 7f bgt\.b 0xb1
|
||||
34: 2a 00 bgt\.b 0x34
|
||||
35: R_RX_DIR8S_PCREL foo
|
||||
36: 2c 80 bo\.b 0xffffffb6
|
||||
38: 2c 7f bo\.b 0xb7
|
||||
3a: 2c 00 bo\.b 0x3a
|
||||
3b: R_RX_DIR8S_PCREL foo
|
||||
3c: 23 80 bnc\.b 0xffffffbc
|
||||
3e: 23 7f bnc\.b 0xbd
|
||||
40: 23 00 bnc\.b 0x40
|
||||
41: R_RX_DIR8S_PCREL foo
|
||||
42: 23 80 bnc\.b 0xffffffc2
|
||||
44: 23 7f bnc\.b 0xc3
|
||||
46: 23 00 bnc\.b 0x46
|
||||
47: R_RX_DIR8S_PCREL foo
|
||||
48: 21 80 bne\.b 0xffffffc8
|
||||
4a: 21 7f bne\.b 0xc9
|
||||
4c: 21 00 bne\.b 0x4c
|
||||
4d: R_RX_DIR8S_PCREL foo
|
||||
4e: 21 80 bne\.b 0xffffffce
|
||||
50: 21 7f bne\.b 0xcf
|
||||
52: 21 00 bne\.b 0x52
|
||||
53: R_RX_DIR8S_PCREL foo
|
||||
54: 25 80 bleu\.b 0xffffffd4
|
||||
56: 25 7f bleu\.b 0xd5
|
||||
58: 25 00 bleu\.b 0x58
|
||||
59: R_RX_DIR8S_PCREL foo
|
||||
5a: 27 80 bn\.b 0xffffffda
|
||||
5c: 27 7f bn\.b 0xdb
|
||||
5e: 27 00 bn\.b 0x5e
|
||||
5f: R_RX_DIR8S_PCREL foo
|
||||
60: 29 80 blt\.b 0xffffffe0
|
||||
62: 29 7f blt\.b 0xe1
|
||||
64: 29 00 blt\.b 0x64
|
||||
65: R_RX_DIR8S_PCREL foo
|
||||
66: 2b 80 ble\.b 0xffffffe6
|
||||
68: 2b 7f ble\.b 0xe7
|
||||
6a: 2b 00 ble\.b 0x6a
|
||||
6b: R_RX_DIR8S_PCREL foo
|
||||
6c: 2d 80 bno\.b 0xffffffec
|
||||
6e: 2d 7f bno\.b 0xed
|
||||
70: 2d 00 bno\.b 0x70
|
||||
71: R_RX_DIR8S_PCREL foo
|
||||
72: 3a 00 80 beq\.w 0xffff8072
|
||||
75: 3a ff 7f beq\.w 0x8074
|
||||
78: 3a 00 00 beq\.w 0x78
|
||||
79: R_RX_DIR16S_PCREL foo
|
||||
7b: 3b 00 80 bne\.w 0xffff807b
|
||||
7e: 3b ff 7f bne\.w 0x807d
|
||||
81: 3b 00 00 bne\.w 0x81
|
||||
82: R_RX_DIR16S_PCREL foo
|
||||
84: 3a 00 80 beq\.w 0xffff8084
|
||||
87: 3a ff 7f beq\.w 0x8086
|
||||
8a: 3a fc 7f beq\.w 0x8086
|
||||
8b: R_RX_DIR16S_PCREL foo
|
||||
8d: 3b 00 80 bne\.w 0xffff808d
|
||||
90: 3b ff 7f bne\.w 0x808f
|
||||
93: 3b fc 7f bne\.w 0x808f
|
||||
94: R_RX_DIR16S_PCREL foo
|
5
gas/testsuite/gas/rx/bcnd.sm
Normal file
5
gas/testsuite/gas/rx/bcnd.sm
Normal file
@ -0,0 +1,5 @@
|
||||
b{eq;ne}.s {lab_s}
|
||||
b{cnd}.b {lab_b}
|
||||
b{eq;ne}.w {lab_w}
|
||||
b{eq;ne} {lab_w}
|
||||
|
296
gas/testsuite/gas/rx/bmcnd.d
Normal file
296
gas/testsuite/gas/rx/bmcnd.d
Normal file
@ -0,0 +1,296 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fc e0 02 bmc #0, \[r0\]\.b
|
||||
3: fc e0 f2 bmc #0, \[r15\]\.b
|
||||
6: fc e1 02 fc bmc #0, 252\[r0\]\.b
|
||||
a: fc e1 f2 fc bmc #0, 252\[r15\]\.b
|
||||
e: fc e2 02 fc ff bmc #0, 65532\[r0\]\.b
|
||||
13: fc e2 f2 fc ff bmc #0, 65532\[r15\]\.b
|
||||
18: fc fc 02 bmc #7, \[r0\]\.b
|
||||
1b: fc fc f2 bmc #7, \[r15\]\.b
|
||||
1e: fc fd 02 fc bmc #7, 252\[r0\]\.b
|
||||
22: fc fd f2 fc bmc #7, 252\[r15\]\.b
|
||||
26: fc fe 02 fc ff bmc #7, 65532\[r0\]\.b
|
||||
2b: fc fe f2 fc ff bmc #7, 65532\[r15\]\.b
|
||||
30: fc e0 02 bmc #0, \[r0\]\.b
|
||||
33: fc e0 f2 bmc #0, \[r15\]\.b
|
||||
36: fc e1 02 fc bmc #0, 252\[r0\]\.b
|
||||
3a: fc e1 f2 fc bmc #0, 252\[r15\]\.b
|
||||
3e: fc e2 02 fc ff bmc #0, 65532\[r0\]\.b
|
||||
43: fc e2 f2 fc ff bmc #0, 65532\[r15\]\.b
|
||||
48: fc fc 02 bmc #7, \[r0\]\.b
|
||||
4b: fc fc f2 bmc #7, \[r15\]\.b
|
||||
4e: fc fd 02 fc bmc #7, 252\[r0\]\.b
|
||||
52: fc fd f2 fc bmc #7, 252\[r15\]\.b
|
||||
56: fc fe 02 fc ff bmc #7, 65532\[r0\]\.b
|
||||
5b: fc fe f2 fc ff bmc #7, 65532\[r15\]\.b
|
||||
60: fc e0 00 bmeq #0, \[r0\]\.b
|
||||
63: fc e0 f0 bmeq #0, \[r15\]\.b
|
||||
66: fc e1 00 fc bmeq #0, 252\[r0\]\.b
|
||||
6a: fc e1 f0 fc bmeq #0, 252\[r15\]\.b
|
||||
6e: fc e2 00 fc ff bmeq #0, 65532\[r0\]\.b
|
||||
73: fc e2 f0 fc ff bmeq #0, 65532\[r15\]\.b
|
||||
78: fc fc 00 bmeq #7, \[r0\]\.b
|
||||
7b: fc fc f0 bmeq #7, \[r15\]\.b
|
||||
7e: fc fd 00 fc bmeq #7, 252\[r0\]\.b
|
||||
82: fc fd f0 fc bmeq #7, 252\[r15\]\.b
|
||||
86: fc fe 00 fc ff bmeq #7, 65532\[r0\]\.b
|
||||
8b: fc fe f0 fc ff bmeq #7, 65532\[r15\]\.b
|
||||
90: fc e0 00 bmeq #0, \[r0\]\.b
|
||||
93: fc e0 f0 bmeq #0, \[r15\]\.b
|
||||
96: fc e1 00 fc bmeq #0, 252\[r0\]\.b
|
||||
9a: fc e1 f0 fc bmeq #0, 252\[r15\]\.b
|
||||
9e: fc e2 00 fc ff bmeq #0, 65532\[r0\]\.b
|
||||
a3: fc e2 f0 fc ff bmeq #0, 65532\[r15\]\.b
|
||||
a8: fc fc 00 bmeq #7, \[r0\]\.b
|
||||
ab: fc fc f0 bmeq #7, \[r15\]\.b
|
||||
ae: fc fd 00 fc bmeq #7, 252\[r0\]\.b
|
||||
b2: fc fd f0 fc bmeq #7, 252\[r15\]\.b
|
||||
b6: fc fe 00 fc ff bmeq #7, 65532\[r0\]\.b
|
||||
bb: fc fe f0 fc ff bmeq #7, 65532\[r15\]\.b
|
||||
c0: fc e0 04 bmgtu #0, \[r0\]\.b
|
||||
c3: fc e0 f4 bmgtu #0, \[r15\]\.b
|
||||
c6: fc e1 04 fc bmgtu #0, 252\[r0\]\.b
|
||||
ca: fc e1 f4 fc bmgtu #0, 252\[r15\]\.b
|
||||
ce: fc e2 04 fc ff bmgtu #0, 65532\[r0\]\.b
|
||||
d3: fc e2 f4 fc ff bmgtu #0, 65532\[r15\]\.b
|
||||
d8: fc fc 04 bmgtu #7, \[r0\]\.b
|
||||
db: fc fc f4 bmgtu #7, \[r15\]\.b
|
||||
de: fc fd 04 fc bmgtu #7, 252\[r0\]\.b
|
||||
e2: fc fd f4 fc bmgtu #7, 252\[r15\]\.b
|
||||
e6: fc fe 04 fc ff bmgtu #7, 65532\[r0\]\.b
|
||||
eb: fc fe f4 fc ff bmgtu #7, 65532\[r15\]\.b
|
||||
f0: fc e0 06 bmpz #0, \[r0\]\.b
|
||||
f3: fc e0 f6 bmpz #0, \[r15\]\.b
|
||||
f6: fc e1 06 fc bmpz #0, 252\[r0\]\.b
|
||||
fa: fc e1 f6 fc bmpz #0, 252\[r15\]\.b
|
||||
fe: fc e2 06 fc ff bmpz #0, 65532\[r0\]\.b
|
||||
103: fc e2 f6 fc ff bmpz #0, 65532\[r15\]\.b
|
||||
108: fc fc 06 bmpz #7, \[r0\]\.b
|
||||
10b: fc fc f6 bmpz #7, \[r15\]\.b
|
||||
10e: fc fd 06 fc bmpz #7, 252\[r0\]\.b
|
||||
112: fc fd f6 fc bmpz #7, 252\[r15\]\.b
|
||||
116: fc fe 06 fc ff bmpz #7, 65532\[r0\]\.b
|
||||
11b: fc fe f6 fc ff bmpz #7, 65532\[r15\]\.b
|
||||
120: fc e0 08 bmge #0, \[r0\]\.b
|
||||
123: fc e0 f8 bmge #0, \[r15\]\.b
|
||||
126: fc e1 08 fc bmge #0, 252\[r0\]\.b
|
||||
12a: fc e1 f8 fc bmge #0, 252\[r15\]\.b
|
||||
12e: fc e2 08 fc ff bmge #0, 65532\[r0\]\.b
|
||||
133: fc e2 f8 fc ff bmge #0, 65532\[r15\]\.b
|
||||
138: fc fc 08 bmge #7, \[r0\]\.b
|
||||
13b: fc fc f8 bmge #7, \[r15\]\.b
|
||||
13e: fc fd 08 fc bmge #7, 252\[r0\]\.b
|
||||
142: fc fd f8 fc bmge #7, 252\[r15\]\.b
|
||||
146: fc fe 08 fc ff bmge #7, 65532\[r0\]\.b
|
||||
14b: fc fe f8 fc ff bmge #7, 65532\[r15\]\.b
|
||||
150: fc e0 0a bmgt #0, \[r0\]\.b
|
||||
153: fc e0 fa bmgt #0, \[r15\]\.b
|
||||
156: fc e1 0a fc bmgt #0, 252\[r0\]\.b
|
||||
15a: fc e1 fa fc bmgt #0, 252\[r15\]\.b
|
||||
15e: fc e2 0a fc ff bmgt #0, 65532\[r0\]\.b
|
||||
163: fc e2 fa fc ff bmgt #0, 65532\[r15\]\.b
|
||||
168: fc fc 0a bmgt #7, \[r0\]\.b
|
||||
16b: fc fc fa bmgt #7, \[r15\]\.b
|
||||
16e: fc fd 0a fc bmgt #7, 252\[r0\]\.b
|
||||
172: fc fd fa fc bmgt #7, 252\[r15\]\.b
|
||||
176: fc fe 0a fc ff bmgt #7, 65532\[r0\]\.b
|
||||
17b: fc fe fa fc ff bmgt #7, 65532\[r15\]\.b
|
||||
180: fc e0 0c bmo #0, \[r0\]\.b
|
||||
183: fc e0 fc bmo #0, \[r15\]\.b
|
||||
186: fc e1 0c fc bmo #0, 252\[r0\]\.b
|
||||
18a: fc e1 fc fc bmo #0, 252\[r15\]\.b
|
||||
18e: fc e2 0c fc ff bmo #0, 65532\[r0\]\.b
|
||||
193: fc e2 fc fc ff bmo #0, 65532\[r15\]\.b
|
||||
198: fc fc 0c bmo #7, \[r0\]\.b
|
||||
19b: fc fc fc bmo #7, \[r15\]\.b
|
||||
19e: fc fd 0c fc bmo #7, 252\[r0\]\.b
|
||||
1a2: fc fd fc fc bmo #7, 252\[r15\]\.b
|
||||
1a6: fc fe 0c fc ff bmo #7, 65532\[r0\]\.b
|
||||
1ab: fc fe fc fc ff bmo #7, 65532\[r15\]\.b
|
||||
1b0: fc e0 03 bmnc #0, \[r0\]\.b
|
||||
1b3: fc e0 f3 bmnc #0, \[r15\]\.b
|
||||
1b6: fc e1 03 fc bmnc #0, 252\[r0\]\.b
|
||||
1ba: fc e1 f3 fc bmnc #0, 252\[r15\]\.b
|
||||
1be: fc e2 03 fc ff bmnc #0, 65532\[r0\]\.b
|
||||
1c3: fc e2 f3 fc ff bmnc #0, 65532\[r15\]\.b
|
||||
1c8: fc fc 03 bmnc #7, \[r0\]\.b
|
||||
1cb: fc fc f3 bmnc #7, \[r15\]\.b
|
||||
1ce: fc fd 03 fc bmnc #7, 252\[r0\]\.b
|
||||
1d2: fc fd f3 fc bmnc #7, 252\[r15\]\.b
|
||||
1d6: fc fe 03 fc ff bmnc #7, 65532\[r0\]\.b
|
||||
1db: fc fe f3 fc ff bmnc #7, 65532\[r15\]\.b
|
||||
1e0: fc e0 03 bmnc #0, \[r0\]\.b
|
||||
1e3: fc e0 f3 bmnc #0, \[r15\]\.b
|
||||
1e6: fc e1 03 fc bmnc #0, 252\[r0\]\.b
|
||||
1ea: fc e1 f3 fc bmnc #0, 252\[r15\]\.b
|
||||
1ee: fc e2 03 fc ff bmnc #0, 65532\[r0\]\.b
|
||||
1f3: fc e2 f3 fc ff bmnc #0, 65532\[r15\]\.b
|
||||
1f8: fc fc 03 bmnc #7, \[r0\]\.b
|
||||
1fb: fc fc f3 bmnc #7, \[r15\]\.b
|
||||
1fe: fc fd 03 fc bmnc #7, 252\[r0\]\.b
|
||||
202: fc fd f3 fc bmnc #7, 252\[r15\]\.b
|
||||
206: fc fe 03 fc ff bmnc #7, 65532\[r0\]\.b
|
||||
20b: fc fe f3 fc ff bmnc #7, 65532\[r15\]\.b
|
||||
210: fc e0 01 bmne #0, \[r0\]\.b
|
||||
213: fc e0 f1 bmne #0, \[r15\]\.b
|
||||
216: fc e1 01 fc bmne #0, 252\[r0\]\.b
|
||||
21a: fc e1 f1 fc bmne #0, 252\[r15\]\.b
|
||||
21e: fc e2 01 fc ff bmne #0, 65532\[r0\]\.b
|
||||
223: fc e2 f1 fc ff bmne #0, 65532\[r15\]\.b
|
||||
228: fc fc 01 bmne #7, \[r0\]\.b
|
||||
22b: fc fc f1 bmne #7, \[r15\]\.b
|
||||
22e: fc fd 01 fc bmne #7, 252\[r0\]\.b
|
||||
232: fc fd f1 fc bmne #7, 252\[r15\]\.b
|
||||
236: fc fe 01 fc ff bmne #7, 65532\[r0\]\.b
|
||||
23b: fc fe f1 fc ff bmne #7, 65532\[r15\]\.b
|
||||
240: fc e0 01 bmne #0, \[r0\]\.b
|
||||
243: fc e0 f1 bmne #0, \[r15\]\.b
|
||||
246: fc e1 01 fc bmne #0, 252\[r0\]\.b
|
||||
24a: fc e1 f1 fc bmne #0, 252\[r15\]\.b
|
||||
24e: fc e2 01 fc ff bmne #0, 65532\[r0\]\.b
|
||||
253: fc e2 f1 fc ff bmne #0, 65532\[r15\]\.b
|
||||
258: fc fc 01 bmne #7, \[r0\]\.b
|
||||
25b: fc fc f1 bmne #7, \[r15\]\.b
|
||||
25e: fc fd 01 fc bmne #7, 252\[r0\]\.b
|
||||
262: fc fd f1 fc bmne #7, 252\[r15\]\.b
|
||||
266: fc fe 01 fc ff bmne #7, 65532\[r0\]\.b
|
||||
26b: fc fe f1 fc ff bmne #7, 65532\[r15\]\.b
|
||||
270: fc e0 05 bmleu #0, \[r0\]\.b
|
||||
273: fc e0 f5 bmleu #0, \[r15\]\.b
|
||||
276: fc e1 05 fc bmleu #0, 252\[r0\]\.b
|
||||
27a: fc e1 f5 fc bmleu #0, 252\[r15\]\.b
|
||||
27e: fc e2 05 fc ff bmleu #0, 65532\[r0\]\.b
|
||||
283: fc e2 f5 fc ff bmleu #0, 65532\[r15\]\.b
|
||||
288: fc fc 05 bmleu #7, \[r0\]\.b
|
||||
28b: fc fc f5 bmleu #7, \[r15\]\.b
|
||||
28e: fc fd 05 fc bmleu #7, 252\[r0\]\.b
|
||||
292: fc fd f5 fc bmleu #7, 252\[r15\]\.b
|
||||
296: fc fe 05 fc ff bmleu #7, 65532\[r0\]\.b
|
||||
29b: fc fe f5 fc ff bmleu #7, 65532\[r15\]\.b
|
||||
2a0: fc e0 07 bmn #0, \[r0\]\.b
|
||||
2a3: fc e0 f7 bmn #0, \[r15\]\.b
|
||||
2a6: fc e1 07 fc bmn #0, 252\[r0\]\.b
|
||||
2aa: fc e1 f7 fc bmn #0, 252\[r15\]\.b
|
||||
2ae: fc e2 07 fc ff bmn #0, 65532\[r0\]\.b
|
||||
2b3: fc e2 f7 fc ff bmn #0, 65532\[r15\]\.b
|
||||
2b8: fc fc 07 bmn #7, \[r0\]\.b
|
||||
2bb: fc fc f7 bmn #7, \[r15\]\.b
|
||||
2be: fc fd 07 fc bmn #7, 252\[r0\]\.b
|
||||
2c2: fc fd f7 fc bmn #7, 252\[r15\]\.b
|
||||
2c6: fc fe 07 fc ff bmn #7, 65532\[r0\]\.b
|
||||
2cb: fc fe f7 fc ff bmn #7, 65532\[r15\]\.b
|
||||
2d0: fc e0 09 bmlt #0, \[r0\]\.b
|
||||
2d3: fc e0 f9 bmlt #0, \[r15\]\.b
|
||||
2d6: fc e1 09 fc bmlt #0, 252\[r0\]\.b
|
||||
2da: fc e1 f9 fc bmlt #0, 252\[r15\]\.b
|
||||
2de: fc e2 09 fc ff bmlt #0, 65532\[r0\]\.b
|
||||
2e3: fc e2 f9 fc ff bmlt #0, 65532\[r15\]\.b
|
||||
2e8: fc fc 09 bmlt #7, \[r0\]\.b
|
||||
2eb: fc fc f9 bmlt #7, \[r15\]\.b
|
||||
2ee: fc fd 09 fc bmlt #7, 252\[r0\]\.b
|
||||
2f2: fc fd f9 fc bmlt #7, 252\[r15\]\.b
|
||||
2f6: fc fe 09 fc ff bmlt #7, 65532\[r0\]\.b
|
||||
2fb: fc fe f9 fc ff bmlt #7, 65532\[r15\]\.b
|
||||
300: fc e0 0b bmle #0, \[r0\]\.b
|
||||
303: fc e0 fb bmle #0, \[r15\]\.b
|
||||
306: fc e1 0b fc bmle #0, 252\[r0\]\.b
|
||||
30a: fc e1 fb fc bmle #0, 252\[r15\]\.b
|
||||
30e: fc e2 0b fc ff bmle #0, 65532\[r0\]\.b
|
||||
313: fc e2 fb fc ff bmle #0, 65532\[r15\]\.b
|
||||
318: fc fc 0b bmle #7, \[r0\]\.b
|
||||
31b: fc fc fb bmle #7, \[r15\]\.b
|
||||
31e: fc fd 0b fc bmle #7, 252\[r0\]\.b
|
||||
322: fc fd fb fc bmle #7, 252\[r15\]\.b
|
||||
326: fc fe 0b fc ff bmle #7, 65532\[r0\]\.b
|
||||
32b: fc fe fb fc ff bmle #7, 65532\[r15\]\.b
|
||||
330: fc e0 0d bmno #0, \[r0\]\.b
|
||||
333: fc e0 fd bmno #0, \[r15\]\.b
|
||||
336: fc e1 0d fc bmno #0, 252\[r0\]\.b
|
||||
33a: fc e1 fd fc bmno #0, 252\[r15\]\.b
|
||||
33e: fc e2 0d fc ff bmno #0, 65532\[r0\]\.b
|
||||
343: fc e2 fd fc ff bmno #0, 65532\[r15\]\.b
|
||||
348: fc fc 0d bmno #7, \[r0\]\.b
|
||||
34b: fc fc fd bmno #7, \[r15\]\.b
|
||||
34e: fc fd 0d fc bmno #7, 252\[r0\]\.b
|
||||
352: fc fd fd fc bmno #7, 252\[r15\]\.b
|
||||
356: fc fe 0d fc ff bmno #7, 65532\[r0\]\.b
|
||||
35b: fc fe fd fc ff bmno #7, 65532\[r15\]\.b
|
||||
360: fd e0 20 bmc #0, r0
|
||||
363: fd e0 2f bmc #0, r15
|
||||
366: fd ff 20 bmc #31, r0
|
||||
369: fd ff 2f bmc #31, r15
|
||||
36c: fd e0 20 bmc #0, r0
|
||||
36f: fd e0 2f bmc #0, r15
|
||||
372: fd ff 20 bmc #31, r0
|
||||
375: fd ff 2f bmc #31, r15
|
||||
378: fd e0 00 bmeq #0, r0
|
||||
37b: fd e0 0f bmeq #0, r15
|
||||
37e: fd ff 00 bmeq #31, r0
|
||||
381: fd ff 0f bmeq #31, r15
|
||||
384: fd e0 00 bmeq #0, r0
|
||||
387: fd e0 0f bmeq #0, r15
|
||||
38a: fd ff 00 bmeq #31, r0
|
||||
38d: fd ff 0f bmeq #31, r15
|
||||
390: fd e0 40 bmgtu #0, r0
|
||||
393: fd e0 4f bmgtu #0, r15
|
||||
396: fd ff 40 bmgtu #31, r0
|
||||
399: fd ff 4f bmgtu #31, r15
|
||||
39c: fd e0 60 bmpz #0, r0
|
||||
39f: fd e0 6f bmpz #0, r15
|
||||
3a2: fd ff 60 bmpz #31, r0
|
||||
3a5: fd ff 6f bmpz #31, r15
|
||||
3a8: fd e0 80 bmge #0, r0
|
||||
3ab: fd e0 8f bmge #0, r15
|
||||
3ae: fd ff 80 bmge #31, r0
|
||||
3b1: fd ff 8f bmge #31, r15
|
||||
3b4: fd e0 a0 bmgt #0, r0
|
||||
3b7: fd e0 af bmgt #0, r15
|
||||
3ba: fd ff a0 bmgt #31, r0
|
||||
3bd: fd ff af bmgt #31, r15
|
||||
3c0: fd e0 c0 bmo #0, r0
|
||||
3c3: fd e0 cf bmo #0, r15
|
||||
3c6: fd ff c0 bmo #31, r0
|
||||
3c9: fd ff cf bmo #31, r15
|
||||
3cc: fd e0 30 bmnc #0, r0
|
||||
3cf: fd e0 3f bmnc #0, r15
|
||||
3d2: fd ff 30 bmnc #31, r0
|
||||
3d5: fd ff 3f bmnc #31, r15
|
||||
3d8: fd e0 30 bmnc #0, r0
|
||||
3db: fd e0 3f bmnc #0, r15
|
||||
3de: fd ff 30 bmnc #31, r0
|
||||
3e1: fd ff 3f bmnc #31, r15
|
||||
3e4: fd e0 10 bmne #0, r0
|
||||
3e7: fd e0 1f bmne #0, r15
|
||||
3ea: fd ff 10 bmne #31, r0
|
||||
3ed: fd ff 1f bmne #31, r15
|
||||
3f0: fd e0 10 bmne #0, r0
|
||||
3f3: fd e0 1f bmne #0, r15
|
||||
3f6: fd ff 10 bmne #31, r0
|
||||
3f9: fd ff 1f bmne #31, r15
|
||||
3fc: fd e0 50 bmleu #0, r0
|
||||
3ff: fd e0 5f bmleu #0, r15
|
||||
402: fd ff 50 bmleu #31, r0
|
||||
405: fd ff 5f bmleu #31, r15
|
||||
408: fd e0 70 bmn #0, r0
|
||||
40b: fd e0 7f bmn #0, r15
|
||||
40e: fd ff 70 bmn #31, r0
|
||||
411: fd ff 7f bmn #31, r15
|
||||
414: fd e0 90 bmlt #0, r0
|
||||
417: fd e0 9f bmlt #0, r15
|
||||
41a: fd ff 90 bmlt #31, r0
|
||||
41d: fd ff 9f bmlt #31, r15
|
||||
420: fd e0 b0 bmle #0, r0
|
||||
423: fd e0 bf bmle #0, r15
|
||||
426: fd ff b0 bmle #31, r0
|
||||
429: fd ff bf bmle #31, r15
|
||||
42c: fd e0 d0 bmno #0, r0
|
||||
42f: fd e0 df bmno #0, r15
|
||||
432: fd ff d0 bmno #31, r0
|
||||
435: fd ff df bmno #31, r15
|
2
gas/testsuite/gas/rx/bmcnd.sm
Normal file
2
gas/testsuite/gas/rx/bmcnd.sm
Normal file
@ -0,0 +1,2 @@
|
||||
bm{cnd} #{uimm3}, {dsp}[{reg}].B
|
||||
bm{cnd} #{uimm5}, {reg}
|
40
gas/testsuite/gas/rx/bnot.d
Normal file
40
gas/testsuite/gas/rx/bnot.d
Normal file
@ -0,0 +1,40 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fc e0 0f bnot #0, \[r0\]\.b
|
||||
3: fc e0 ff bnot #0, \[r15\]\.b
|
||||
6: fc e1 0f fc bnot #0, 252\[r0\]\.b
|
||||
a: fc e1 ff fc bnot #0, 252\[r15\]\.b
|
||||
e: fc e2 0f fc ff bnot #0, 65532\[r0\]\.b
|
||||
13: fc e2 ff fc ff bnot #0, 65532\[r15\]\.b
|
||||
18: fc fc 0f bnot #7, \[r0\]\.b
|
||||
1b: fc fc ff bnot #7, \[r15\]\.b
|
||||
1e: fc fd 0f fc bnot #7, 252\[r0\]\.b
|
||||
22: fc fd ff fc bnot #7, 252\[r15\]\.b
|
||||
26: fc fe 0f fc ff bnot #7, 65532\[r0\]\.b
|
||||
2b: fc fe ff fc ff bnot #7, 65532\[r15\]\.b
|
||||
30: fc 6c 00 bnot r0, \[r0\]\.b
|
||||
33: fc 6c f0 bnot r0, \[r15\]\.b
|
||||
36: fc 6d 00 fc bnot r0, 252\[r0\]\.b
|
||||
3a: fc 6d f0 fc bnot r0, 252\[r15\]\.b
|
||||
3e: fc 6e 00 fc ff bnot r0, 65532\[r0\]\.b
|
||||
43: fc 6e f0 fc ff bnot r0, 65532\[r15\]\.b
|
||||
48: fc 6c 0f bnot r15, \[r0\]\.b
|
||||
4b: fc 6c ff bnot r15, \[r15\]\.b
|
||||
4e: fc 6d 0f fc bnot r15, 252\[r0\]\.b
|
||||
52: fc 6d ff fc bnot r15, 252\[r15\]\.b
|
||||
56: fc 6e 0f fc ff bnot r15, 65532\[r0\]\.b
|
||||
5b: fc 6e ff fc ff bnot r15, 65532\[r15\]\.b
|
||||
60: fd e0 f0 bnot #0, r0
|
||||
63: fd e0 ff bnot #0, r15
|
||||
66: fd ff f0 bnot #31, r0
|
||||
69: fd ff ff bnot #31, r15
|
||||
6c: fc 6f 00 bnot r0, r0
|
||||
6f: fc 6f f0 bnot r0, r15
|
||||
72: fc 6f 0f bnot r15, r0
|
||||
75: fc 6f ff bnot r15, r15
|
5
gas/testsuite/gas/rx/bnot.sm
Normal file
5
gas/testsuite/gas/rx/bnot.sm
Normal file
@ -0,0 +1,5 @@
|
||||
bnot #{uimm3}, {dsp}[{reg}].B
|
||||
bnot {reg}, {dsp}[{reg}].B
|
||||
|
||||
bnot #{uimm5}, {reg}
|
||||
bnot {reg}, {reg}
|
30
gas/testsuite/gas/rx/bra.d
Normal file
30
gas/testsuite/gas/rx/bra.d
Normal file
@ -0,0 +1,30 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 0b bra\.s 0x3
|
||||
1: 0a bra\.s 0xb
|
||||
2: 08 bra\.s 0xa
|
||||
2: R_RX_DIR3U_PCREL foo
|
||||
3: 2e 80 bra\.b 0xffffff83
|
||||
5: 2e 7f bra\.b 0x84
|
||||
7: 2e 00 bra\.b 0x7
|
||||
8: R_RX_DIR8S_PCREL foo
|
||||
9: 38 00 80 bra\.w 0xffff8009
|
||||
c: 38 ff 7f bra\.w 0x800b
|
||||
f: 38 00 00 bra\.w 0xf
|
||||
10: R_RX_DIR16S_PCREL foo
|
||||
12: 04 00 00 80 bra\.a 0xff800012
|
||||
16: 04 ff ff 7f bra\.a 0x800015
|
||||
1a: 04 00 00 00 bra\.a 0x1a
|
||||
1b: R_RX_DIR24S_PCREL foo
|
||||
1e: 04 00 00 80 bra\.a 0xff80001e
|
||||
22: 04 ff ff 7f bra\.a 0x800021
|
||||
26: 04 fb ff 7f bra\.a 0x800021
|
||||
27: R_RX_DIR24S_PCREL foo
|
||||
2a: 7f 40 bra\.l r0
|
||||
2c: 7f 4f bra\.l r15
|
6
gas/testsuite/gas/rx/bra.sm
Normal file
6
gas/testsuite/gas/rx/bra.sm
Normal file
@ -0,0 +1,6 @@
|
||||
bra.s {lab_s}
|
||||
bra.b {lab_b}
|
||||
bra.w {lab_w}
|
||||
bra.a {lab_a}
|
||||
bra {lab_a}
|
||||
bra.l {reg}
|
10
gas/testsuite/gas/rx/brk.d
Normal file
10
gas/testsuite/gas/rx/brk.d
Normal file
@ -0,0 +1,10 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 00 brk
|
||||
1: 03 nop
|
2
gas/testsuite/gas/rx/brk.sm
Normal file
2
gas/testsuite/gas/rx/brk.sm
Normal file
@ -0,0 +1,2 @@
|
||||
brk
|
||||
nop
|
40
gas/testsuite/gas/rx/bset.d
Normal file
40
gas/testsuite/gas/rx/bset.d
Normal file
@ -0,0 +1,40 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: f0 00 bset #0, \[r0\]\.b
|
||||
2: f0 f0 bset #0, \[r15\]\.b
|
||||
4: f1 00 fc bset #0, 252\[r0\]\.b
|
||||
7: f1 f0 fc bset #0, 252\[r15\]\.b
|
||||
a: f2 00 fc ff bset #0, 65532\[r0\]\.b
|
||||
e: f2 f0 fc ff bset #0, 65532\[r15\]\.b
|
||||
12: f0 07 bset #7, \[r0\]\.b
|
||||
14: f0 f7 bset #7, \[r15\]\.b
|
||||
16: f1 07 fc bset #7, 252\[r0\]\.b
|
||||
19: f1 f7 fc bset #7, 252\[r15\]\.b
|
||||
1c: f2 07 fc ff bset #7, 65532\[r0\]\.b
|
||||
20: f2 f7 fc ff bset #7, 65532\[r15\]\.b
|
||||
24: fc 60 00 bset r0, \[r0\]\.b
|
||||
27: fc 60 f0 bset r0, \[r15\]\.b
|
||||
2a: fc 61 00 fc bset r0, 252\[r0\]\.b
|
||||
2e: fc 61 f0 fc bset r0, 252\[r15\]\.b
|
||||
32: fc 62 00 fc ff bset r0, 65532\[r0\]\.b
|
||||
37: fc 62 f0 fc ff bset r0, 65532\[r15\]\.b
|
||||
3c: fc 60 0f bset r15, \[r0\]\.b
|
||||
3f: fc 60 ff bset r15, \[r15\]\.b
|
||||
42: fc 61 0f fc bset r15, 252\[r0\]\.b
|
||||
46: fc 61 ff fc bset r15, 252\[r15\]\.b
|
||||
4a: fc 62 0f fc ff bset r15, 65532\[r0\]\.b
|
||||
4f: fc 62 ff fc ff bset r15, 65532\[r15\]\.b
|
||||
54: 78 00 bset #0, r0
|
||||
56: 78 0f bset #0, r15
|
||||
58: 79 f0 bset #31, r0
|
||||
5a: 79 ff bset #31, r15
|
||||
5c: fc 63 00 bset r0, r0
|
||||
5f: fc 63 f0 bset r0, r15
|
||||
62: fc 63 0f bset r15, r0
|
||||
65: fc 63 ff bset r15, r15
|
5
gas/testsuite/gas/rx/bset.sm
Normal file
5
gas/testsuite/gas/rx/bset.sm
Normal file
@ -0,0 +1,5 @@
|
||||
bset #{uimm3}, {dsp}[{reg}].B
|
||||
bset {reg}, {dsp}[{reg}].B
|
||||
|
||||
bset #{uimm5}, {reg}
|
||||
bset {reg}, {reg}
|
18
gas/testsuite/gas/rx/bsr.d
Normal file
18
gas/testsuite/gas/rx/bsr.d
Normal file
@ -0,0 +1,18 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 39 00 80 bsr\.w 0xffff8000
|
||||
3: 39 ff 7f bsr\.w 0x8002
|
||||
6: 39 00 00 bsr\.w 0x6
|
||||
7: R_RX_DIR16S_PCREL foo
|
||||
9: 05 00 00 80 bsr\.a 0xff800009
|
||||
d: 05 ff ff 7f bsr\.a 0x80000c
|
||||
11: 05 00 00 00 bsr\.a 0x11
|
||||
12: R_RX_DIR24S_PCREL foo
|
||||
15: 7f 50 bsr\.l r0
|
||||
17: 7f 5f bsr\.l r15
|
3
gas/testsuite/gas/rx/bsr.sm
Normal file
3
gas/testsuite/gas/rx/bsr.sm
Normal file
@ -0,0 +1,3 @@
|
||||
bsr.w {lab_w}
|
||||
bsr.a {lab_a}
|
||||
bsr.l {reg}
|
40
gas/testsuite/gas/rx/btst.d
Normal file
40
gas/testsuite/gas/rx/btst.d
Normal file
@ -0,0 +1,40 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: f4 00 btst #0, \[r0\]\.b
|
||||
2: f4 f0 btst #0, \[r15\]\.b
|
||||
4: f5 00 fc btst #0, 252\[r0\]\.b
|
||||
7: f5 f0 fc btst #0, 252\[r15\]\.b
|
||||
a: f6 00 fc ff btst #0, 65532\[r0\]\.b
|
||||
e: f6 f0 fc ff btst #0, 65532\[r15\]\.b
|
||||
12: f4 07 btst #7, \[r0\]\.b
|
||||
14: f4 f7 btst #7, \[r15\]\.b
|
||||
16: f5 07 fc btst #7, 252\[r0\]\.b
|
||||
19: f5 f7 fc btst #7, 252\[r15\]\.b
|
||||
1c: f6 07 fc ff btst #7, 65532\[r0\]\.b
|
||||
20: f6 f7 fc ff btst #7, 65532\[r15\]\.b
|
||||
24: fc 68 00 btst r0, \[r0\]\.b
|
||||
27: fc 68 f0 btst r0, \[r15\]\.b
|
||||
2a: fc 69 00 fc btst r0, 252\[r0\]\.b
|
||||
2e: fc 69 f0 fc btst r0, 252\[r15\]\.b
|
||||
32: fc 6a 00 fc ff btst r0, 65532\[r0\]\.b
|
||||
37: fc 6a f0 fc ff btst r0, 65532\[r15\]\.b
|
||||
3c: fc 68 0f btst r15, \[r0\]\.b
|
||||
3f: fc 68 ff btst r15, \[r15\]\.b
|
||||
42: fc 69 0f fc btst r15, 252\[r0\]\.b
|
||||
46: fc 69 ff fc btst r15, 252\[r15\]\.b
|
||||
4a: fc 6a 0f fc ff btst r15, 65532\[r0\]\.b
|
||||
4f: fc 6a ff fc ff btst r15, 65532\[r15\]\.b
|
||||
54: 7c 00 btst #0, r0
|
||||
56: 7c 0f btst #0, r15
|
||||
58: 7d f0 btst #31, r0
|
||||
5a: 7d ff btst #31, r15
|
||||
5c: fc 6b 00 btst r0, r0
|
||||
5f: fc 6b f0 btst r0, r15
|
||||
62: fc 6b 0f btst r15, r0
|
||||
65: fc 6b ff btst r15, r15
|
5
gas/testsuite/gas/rx/btst.sm
Normal file
5
gas/testsuite/gas/rx/btst.sm
Normal file
@ -0,0 +1,5 @@
|
||||
btst #{uimm3}, {dsp}[{reg}].B
|
||||
btst {reg}, {dsp}[{reg}].B
|
||||
|
||||
btst #{uimm5}, {reg}
|
||||
btst {reg}, {reg}
|
14
gas/testsuite/gas/rx/clrpsw.d
Normal file
14
gas/testsuite/gas/rx/clrpsw.d
Normal file
@ -0,0 +1,14 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 7f b9 clrpsw u
|
||||
2: 7f b8 clrpsw i
|
||||
4: 7f b3 clrpsw o
|
||||
6: 7f b2 clrpsw s
|
||||
8: 7f b1 clrpsw z
|
||||
a: 7f b0 clrpsw c
|
1
gas/testsuite/gas/rx/clrpsw.sm
Normal file
1
gas/testsuite/gas/rx/clrpsw.sm
Normal file
@ -0,0 +1 @@
|
||||
clrpsw {pswf}
|
96
gas/testsuite/gas/rx/cmp.d
Normal file
96
gas/testsuite/gas/rx/cmp.d
Normal file
@ -0,0 +1,96 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 61 00 cmp #0, r0
|
||||
2: 61 0f cmp #0, r15
|
||||
4: 61 f0 cmp #15, r0
|
||||
6: 61 ff cmp #15, r15
|
||||
8: 61 00 cmp #0, r0
|
||||
a: 61 0f cmp #0, r15
|
||||
c: 75 50 ff cmp #255, r0
|
||||
f: 75 5f ff cmp #255, r15
|
||||
12: 75 00 80 cmp #-128, r0
|
||||
15: 75 0f 80 cmp #-128, r15
|
||||
18: 75 50 7f cmp #127, r0
|
||||
1b: 75 5f 7f cmp #127, r15
|
||||
1e: 76 00 00 80 cmp #0xffff8000, r0
|
||||
22: 76 0f 00 80 cmp #0xffff8000, r15
|
||||
26: 77 00 00 80 00 cmp #0x8000, r0
|
||||
2b: 77 0f 00 80 00 cmp #0x8000, r15
|
||||
30: 77 00 00 00 80 cmp #0xff800000, r0
|
||||
35: 77 0f 00 00 80 cmp #0xff800000, r15
|
||||
3a: 77 00 ff ff 7f cmp #0x7fffff, r0
|
||||
3f: 77 0f ff ff 7f cmp #0x7fffff, r15
|
||||
44: 74 00 00 00 00 80 cmp #0x80000000, r0
|
||||
4a: 74 0f 00 00 00 80 cmp #0x80000000, r15
|
||||
50: 74 00 ff ff ff 7f cmp #0x7fffffff, r0
|
||||
56: 74 0f ff ff ff 7f cmp #0x7fffffff, r15
|
||||
5c: 47 00 cmp r0, r0
|
||||
5e: 47 0f cmp r0, r15
|
||||
60: 47 f0 cmp r15, r0
|
||||
62: 47 ff cmp r15, r15
|
||||
64: 44 00 cmp \[r0\]\.ub, r0
|
||||
66: 44 0f cmp \[r0\]\.ub, r15
|
||||
68: 06 04 00 cmp \[r0\]\.b, r0
|
||||
6b: 06 04 0f cmp \[r0\]\.b, r15
|
||||
6e: 06 c4 00 cmp \[r0\]\.uw, r0
|
||||
71: 06 c4 0f cmp \[r0\]\.uw, r15
|
||||
74: 06 44 00 cmp \[r0\]\.w, r0
|
||||
77: 06 44 0f cmp \[r0\]\.w, r15
|
||||
7a: 06 84 00 cmp \[r0\]\.l, r0
|
||||
7d: 06 84 0f cmp \[r0\]\.l, r15
|
||||
80: 44 f0 cmp \[r15\]\.ub, r0
|
||||
82: 44 ff cmp \[r15\]\.ub, r15
|
||||
84: 06 04 f0 cmp \[r15\]\.b, r0
|
||||
87: 06 04 ff cmp \[r15\]\.b, r15
|
||||
8a: 06 c4 f0 cmp \[r15\]\.uw, r0
|
||||
8d: 06 c4 ff cmp \[r15\]\.uw, r15
|
||||
90: 06 44 f0 cmp \[r15\]\.w, r0
|
||||
93: 06 44 ff cmp \[r15\]\.w, r15
|
||||
96: 06 84 f0 cmp \[r15\]\.l, r0
|
||||
99: 06 84 ff cmp \[r15\]\.l, r15
|
||||
9c: 45 00 fc cmp 252\[r0\]\.ub, r0
|
||||
9f: 45 0f fc cmp 252\[r0\]\.ub, r15
|
||||
a2: 06 05 00 fc cmp 252\[r0\]\.b, r0
|
||||
a6: 06 05 0f fc cmp 252\[r0\]\.b, r15
|
||||
aa: 06 c5 00 7e cmp 252\[r0\]\.uw, r0
|
||||
ae: 06 c5 0f 7e cmp 252\[r0\]\.uw, r15
|
||||
b2: 06 45 00 7e cmp 252\[r0\]\.w, r0
|
||||
b6: 06 45 0f 7e cmp 252\[r0\]\.w, r15
|
||||
ba: 06 85 00 3f cmp 252\[r0\]\.l, r0
|
||||
be: 06 85 0f 3f cmp 252\[r0\]\.l, r15
|
||||
c2: 45 f0 fc cmp 252\[r15\]\.ub, r0
|
||||
c5: 45 ff fc cmp 252\[r15\]\.ub, r15
|
||||
c8: 06 05 f0 fc cmp 252\[r15\]\.b, r0
|
||||
cc: 06 05 ff fc cmp 252\[r15\]\.b, r15
|
||||
d0: 06 c5 f0 7e cmp 252\[r15\]\.uw, r0
|
||||
d4: 06 c5 ff 7e cmp 252\[r15\]\.uw, r15
|
||||
d8: 06 45 f0 7e cmp 252\[r15\]\.w, r0
|
||||
dc: 06 45 ff 7e cmp 252\[r15\]\.w, r15
|
||||
e0: 06 85 f0 3f cmp 252\[r15\]\.l, r0
|
||||
e4: 06 85 ff 3f cmp 252\[r15\]\.l, r15
|
||||
e8: 46 00 fc ff cmp 65532\[r0\]\.ub, r0
|
||||
ec: 46 0f fc ff cmp 65532\[r0\]\.ub, r15
|
||||
f0: 06 06 00 fc ff cmp 65532\[r0\]\.b, r0
|
||||
f5: 06 06 0f fc ff cmp 65532\[r0\]\.b, r15
|
||||
fa: 06 c6 00 fe 7f cmp 65532\[r0\]\.uw, r0
|
||||
ff: 06 c6 0f fe 7f cmp 65532\[r0\]\.uw, r15
|
||||
104: 06 46 00 fe 7f cmp 65532\[r0\]\.w, r0
|
||||
109: 06 46 0f fe 7f cmp 65532\[r0\]\.w, r15
|
||||
10e: 06 86 00 ff 3f cmp 65532\[r0\]\.l, r0
|
||||
113: 06 86 0f ff 3f cmp 65532\[r0\]\.l, r15
|
||||
118: 46 f0 fc ff cmp 65532\[r15\]\.ub, r0
|
||||
11c: 46 ff fc ff cmp 65532\[r15\]\.ub, r15
|
||||
120: 06 06 f0 fc ff cmp 65532\[r15\]\.b, r0
|
||||
125: 06 06 ff fc ff cmp 65532\[r15\]\.b, r15
|
||||
12a: 06 c6 f0 fe 7f cmp 65532\[r15\]\.uw, r0
|
||||
12f: 06 c6 ff fe 7f cmp 65532\[r15\]\.uw, r15
|
||||
134: 06 46 f0 fe 7f cmp 65532\[r15\]\.w, r0
|
||||
139: 06 46 ff fe 7f cmp 65532\[r15\]\.w, r15
|
||||
13e: 06 86 f0 ff 3f cmp 65532\[r15\]\.l, r0
|
||||
143: 06 86 ff ff 3f cmp 65532\[r15\]\.l, r15
|
6
gas/testsuite/gas/rx/cmp.sm
Normal file
6
gas/testsuite/gas/rx/cmp.sm
Normal file
@ -0,0 +1,6 @@
|
||||
cmp #{uimm4},{reg}
|
||||
cmp #{uimm8},{reg}
|
||||
cmp #{imm},{reg}
|
||||
cmp {reg},{reg}
|
||||
cmp {memx},{reg}
|
||||
|
9
gas/testsuite/gas/rx/dbt.d
Normal file
9
gas/testsuite/gas/rx/dbt.d
Normal file
@ -0,0 +1,9 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 01 dbt
|
1
gas/testsuite/gas/rx/dbt.sm
Normal file
1
gas/testsuite/gas/rx/dbt.sm
Normal file
@ -0,0 +1 @@
|
||||
dbt
|
88
gas/testsuite/gas/rx/div.d
Normal file
88
gas/testsuite/gas/rx/div.d
Normal file
@ -0,0 +1,88 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 74 80 80 div #-128, r0
|
||||
4: fd 74 8f 80 div #-128, r15
|
||||
8: fd 74 80 7f div #127, r0
|
||||
c: fd 74 8f 7f div #127, r15
|
||||
10: fd 78 80 00 80 div #0xffff8000, r0
|
||||
15: fd 78 8f 00 80 div #0xffff8000, r15
|
||||
1a: fd 7c 80 00 80 00 div #0x8000, r0
|
||||
20: fd 7c 8f 00 80 00 div #0x8000, r15
|
||||
26: fd 7c 80 00 00 80 div #0xff800000, r0
|
||||
2c: fd 7c 8f 00 00 80 div #0xff800000, r15
|
||||
32: fd 7c 80 ff ff 7f div #0x7fffff, r0
|
||||
38: fd 7c 8f ff ff 7f div #0x7fffff, r15
|
||||
3e: fd 70 80 00 00 00 80 div #0x80000000, r0
|
||||
45: fd 70 8f 00 00 00 80 div #0x80000000, r15
|
||||
4c: fd 70 80 ff ff ff 7f div #0x7fffffff, r0
|
||||
53: fd 70 8f ff ff ff 7f div #0x7fffffff, r15
|
||||
5a: fc 23 00 div r0, r0
|
||||
5d: fc 23 0f div r0, r15
|
||||
60: fc 23 f0 div r15, r0
|
||||
63: fc 23 ff div r15, r15
|
||||
66: fc 20 00 div \[r0\]\.ub, r0
|
||||
69: fc 20 0f div \[r0\]\.ub, r15
|
||||
6c: 06 20 08 00 div \[r0\]\.b, r0
|
||||
70: 06 20 08 0f div \[r0\]\.b, r15
|
||||
74: 06 e0 08 00 div \[r0\]\.uw, r0
|
||||
78: 06 e0 08 0f div \[r0\]\.uw, r15
|
||||
7c: 06 60 08 00 div \[r0\]\.w, r0
|
||||
80: 06 60 08 0f div \[r0\]\.w, r15
|
||||
84: 06 a0 08 00 div \[r0\]\.l, r0
|
||||
88: 06 a0 08 0f div \[r0\]\.l, r15
|
||||
8c: fc 20 f0 div \[r15\]\.ub, r0
|
||||
8f: fc 20 ff div \[r15\]\.ub, r15
|
||||
92: 06 20 08 f0 div \[r15\]\.b, r0
|
||||
96: 06 20 08 ff div \[r15\]\.b, r15
|
||||
9a: 06 e0 08 f0 div \[r15\]\.uw, r0
|
||||
9e: 06 e0 08 ff div \[r15\]\.uw, r15
|
||||
a2: 06 60 08 f0 div \[r15\]\.w, r0
|
||||
a6: 06 60 08 ff div \[r15\]\.w, r15
|
||||
aa: 06 a0 08 f0 div \[r15\]\.l, r0
|
||||
ae: 06 a0 08 ff div \[r15\]\.l, r15
|
||||
b2: fc 21 00 fc div 252\[r0\]\.ub, r0
|
||||
b6: fc 21 0f fc div 252\[r0\]\.ub, r15
|
||||
ba: 06 21 08 00 fc div 252\[r0\]\.b, r0
|
||||
bf: 06 21 08 0f fc div 252\[r0\]\.b, r15
|
||||
c4: 06 e1 08 00 7e div 252\[r0\]\.uw, r0
|
||||
c9: 06 e1 08 0f 7e div 252\[r0\]\.uw, r15
|
||||
ce: 06 61 08 00 7e div 252\[r0\]\.w, r0
|
||||
d3: 06 61 08 0f 7e div 252\[r0\]\.w, r15
|
||||
d8: 06 a1 08 00 3f div 252\[r0\]\.l, r0
|
||||
dd: 06 a1 08 0f 3f div 252\[r0\]\.l, r15
|
||||
e2: fc 21 f0 fc div 252\[r15\]\.ub, r0
|
||||
e6: fc 21 ff fc div 252\[r15\]\.ub, r15
|
||||
ea: 06 21 08 f0 fc div 252\[r15\]\.b, r0
|
||||
ef: 06 21 08 ff fc div 252\[r15\]\.b, r15
|
||||
f4: 06 e1 08 f0 7e div 252\[r15\]\.uw, r0
|
||||
f9: 06 e1 08 ff 7e div 252\[r15\]\.uw, r15
|
||||
fe: 06 61 08 f0 7e div 252\[r15\]\.w, r0
|
||||
103: 06 61 08 ff 7e div 252\[r15\]\.w, r15
|
||||
108: 06 a1 08 f0 3f div 252\[r15\]\.l, r0
|
||||
10d: 06 a1 08 ff 3f div 252\[r15\]\.l, r15
|
||||
112: fc 22 00 fc ff div 65532\[r0\]\.ub, r0
|
||||
117: fc 22 0f fc ff div 65532\[r0\]\.ub, r15
|
||||
11c: 06 22 08 00 fc ff div 65532\[r0\]\.b, r0
|
||||
122: 06 22 08 0f fc ff div 65532\[r0\]\.b, r15
|
||||
128: 06 e2 08 00 fe 7f div 65532\[r0\]\.uw, r0
|
||||
12e: 06 e2 08 0f fe 7f div 65532\[r0\]\.uw, r15
|
||||
134: 06 62 08 00 fe 7f div 65532\[r0\]\.w, r0
|
||||
13a: 06 62 08 0f fe 7f div 65532\[r0\]\.w, r15
|
||||
140: 06 a2 08 00 ff 3f div 65532\[r0\]\.l, r0
|
||||
146: 06 a2 08 0f ff 3f div 65532\[r0\]\.l, r15
|
||||
14c: fc 22 f0 fc ff div 65532\[r15\]\.ub, r0
|
||||
151: fc 22 ff fc ff div 65532\[r15\]\.ub, r15
|
||||
156: 06 22 08 f0 fc ff div 65532\[r15\]\.b, r0
|
||||
15c: 06 22 08 ff fc ff div 65532\[r15\]\.b, r15
|
||||
162: 06 e2 08 f0 fe 7f div 65532\[r15\]\.uw, r0
|
||||
168: 06 e2 08 ff fe 7f div 65532\[r15\]\.uw, r15
|
||||
16e: 06 62 08 f0 fe 7f div 65532\[r15\]\.w, r0
|
||||
174: 06 62 08 ff fe 7f div 65532\[r15\]\.w, r15
|
||||
17a: 06 a2 08 f0 ff 3f div 65532\[r15\]\.l, r0
|
||||
180: 06 a2 08 ff ff 3f div 65532\[r15\]\.l, r15
|
4
gas/testsuite/gas/rx/div.sm
Normal file
4
gas/testsuite/gas/rx/div.sm
Normal file
@ -0,0 +1,4 @@
|
||||
div #{imm},{reg}
|
||||
div {reg},{reg}
|
||||
div {memx},{reg}
|
||||
|
88
gas/testsuite/gas/rx/divu.d
Normal file
88
gas/testsuite/gas/rx/divu.d
Normal file
@ -0,0 +1,88 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 74 90 80 divu #-128, r0
|
||||
4: fd 74 9f 80 divu #-128, r15
|
||||
8: fd 74 90 7f divu #127, r0
|
||||
c: fd 74 9f 7f divu #127, r15
|
||||
10: fd 78 90 00 80 divu #0xffff8000, r0
|
||||
15: fd 78 9f 00 80 divu #0xffff8000, r15
|
||||
1a: fd 7c 90 00 80 00 divu #0x8000, r0
|
||||
20: fd 7c 9f 00 80 00 divu #0x8000, r15
|
||||
26: fd 7c 90 00 00 80 divu #0xff800000, r0
|
||||
2c: fd 7c 9f 00 00 80 divu #0xff800000, r15
|
||||
32: fd 7c 90 ff ff 7f divu #0x7fffff, r0
|
||||
38: fd 7c 9f ff ff 7f divu #0x7fffff, r15
|
||||
3e: fd 70 90 00 00 00 80 divu #0x80000000, r0
|
||||
45: fd 70 9f 00 00 00 80 divu #0x80000000, r15
|
||||
4c: fd 70 90 ff ff ff 7f divu #0x7fffffff, r0
|
||||
53: fd 70 9f ff ff ff 7f divu #0x7fffffff, r15
|
||||
5a: fc 27 00 divu r0, r0
|
||||
5d: fc 27 0f divu r0, r15
|
||||
60: fc 27 f0 divu r15, r0
|
||||
63: fc 27 ff divu r15, r15
|
||||
66: fc 24 00 divu \[r0\]\.ub, r0
|
||||
69: fc 24 0f divu \[r0\]\.ub, r15
|
||||
6c: 06 20 09 00 divu \[r0\]\.b, r0
|
||||
70: 06 20 09 0f divu \[r0\]\.b, r15
|
||||
74: 06 e0 09 00 divu \[r0\]\.uw, r0
|
||||
78: 06 e0 09 0f divu \[r0\]\.uw, r15
|
||||
7c: 06 60 09 00 divu \[r0\]\.w, r0
|
||||
80: 06 60 09 0f divu \[r0\]\.w, r15
|
||||
84: 06 a0 09 00 divu \[r0\]\.l, r0
|
||||
88: 06 a0 09 0f divu \[r0\]\.l, r15
|
||||
8c: fc 24 f0 divu \[r15\]\.ub, r0
|
||||
8f: fc 24 ff divu \[r15\]\.ub, r15
|
||||
92: 06 20 09 f0 divu \[r15\]\.b, r0
|
||||
96: 06 20 09 ff divu \[r15\]\.b, r15
|
||||
9a: 06 e0 09 f0 divu \[r15\]\.uw, r0
|
||||
9e: 06 e0 09 ff divu \[r15\]\.uw, r15
|
||||
a2: 06 60 09 f0 divu \[r15\]\.w, r0
|
||||
a6: 06 60 09 ff divu \[r15\]\.w, r15
|
||||
aa: 06 a0 09 f0 divu \[r15\]\.l, r0
|
||||
ae: 06 a0 09 ff divu \[r15\]\.l, r15
|
||||
b2: fc 25 00 fc divu 252\[r0\]\.ub, r0
|
||||
b6: fc 25 0f fc divu 252\[r0\]\.ub, r15
|
||||
ba: 06 21 09 00 fc divu 252\[r0\]\.b, r0
|
||||
bf: 06 21 09 0f fc divu 252\[r0\]\.b, r15
|
||||
c4: 06 e1 09 00 7e divu 252\[r0\]\.uw, r0
|
||||
c9: 06 e1 09 0f 7e divu 252\[r0\]\.uw, r15
|
||||
ce: 06 61 09 00 7e divu 252\[r0\]\.w, r0
|
||||
d3: 06 61 09 0f 7e divu 252\[r0\]\.w, r15
|
||||
d8: 06 a1 09 00 3f divu 252\[r0\]\.l, r0
|
||||
dd: 06 a1 09 0f 3f divu 252\[r0\]\.l, r15
|
||||
e2: fc 25 f0 fc divu 252\[r15\]\.ub, r0
|
||||
e6: fc 25 ff fc divu 252\[r15\]\.ub, r15
|
||||
ea: 06 21 09 f0 fc divu 252\[r15\]\.b, r0
|
||||
ef: 06 21 09 ff fc divu 252\[r15\]\.b, r15
|
||||
f4: 06 e1 09 f0 7e divu 252\[r15\]\.uw, r0
|
||||
f9: 06 e1 09 ff 7e divu 252\[r15\]\.uw, r15
|
||||
fe: 06 61 09 f0 7e divu 252\[r15\]\.w, r0
|
||||
103: 06 61 09 ff 7e divu 252\[r15\]\.w, r15
|
||||
108: 06 a1 09 f0 3f divu 252\[r15\]\.l, r0
|
||||
10d: 06 a1 09 ff 3f divu 252\[r15\]\.l, r15
|
||||
112: fc 26 00 fc ff divu 65532\[r0\]\.ub, r0
|
||||
117: fc 26 0f fc ff divu 65532\[r0\]\.ub, r15
|
||||
11c: 06 22 09 00 fc ff divu 65532\[r0\]\.b, r0
|
||||
122: 06 22 09 0f fc ff divu 65532\[r0\]\.b, r15
|
||||
128: 06 e2 09 00 fe 7f divu 65532\[r0\]\.uw, r0
|
||||
12e: 06 e2 09 0f fe 7f divu 65532\[r0\]\.uw, r15
|
||||
134: 06 62 09 00 fe 7f divu 65532\[r0\]\.w, r0
|
||||
13a: 06 62 09 0f fe 7f divu 65532\[r0\]\.w, r15
|
||||
140: 06 a2 09 00 ff 3f divu 65532\[r0\]\.l, r0
|
||||
146: 06 a2 09 0f ff 3f divu 65532\[r0\]\.l, r15
|
||||
14c: fc 26 f0 fc ff divu 65532\[r15\]\.ub, r0
|
||||
151: fc 26 ff fc ff divu 65532\[r15\]\.ub, r15
|
||||
156: 06 22 09 f0 fc ff divu 65532\[r15\]\.b, r0
|
||||
15c: 06 22 09 ff fc ff divu 65532\[r15\]\.b, r15
|
||||
162: 06 e2 09 f0 fe 7f divu 65532\[r15\]\.uw, r0
|
||||
168: 06 e2 09 ff fe 7f divu 65532\[r15\]\.uw, r15
|
||||
16e: 06 62 09 f0 fe 7f divu 65532\[r15\]\.w, r0
|
||||
174: 06 62 09 ff fe 7f divu 65532\[r15\]\.w, r15
|
||||
17a: 06 a2 09 f0 ff 3f divu 65532\[r15\]\.l, r0
|
||||
180: 06 a2 09 ff ff 3f divu 65532\[r15\]\.l, r15
|
4
gas/testsuite/gas/rx/divu.sm
Normal file
4
gas/testsuite/gas/rx/divu.sm
Normal file
@ -0,0 +1,4 @@
|
||||
divu #{imm},{reg}
|
||||
divu {reg},{reg}
|
||||
divu {memx},{reg}
|
||||
|
88
gas/testsuite/gas/rx/emul.d
Normal file
88
gas/testsuite/gas/rx/emul.d
Normal file
@ -0,0 +1,88 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 74 60 80 emul #-128, r0
|
||||
4: fd 74 6e 80 emul #-128, r14
|
||||
8: fd 74 60 7f emul #127, r0
|
||||
c: fd 74 6e 7f emul #127, r14
|
||||
10: fd 78 60 00 80 emul #0xffff8000, r0
|
||||
15: fd 78 6e 00 80 emul #0xffff8000, r14
|
||||
1a: fd 7c 60 00 80 00 emul #0x8000, r0
|
||||
20: fd 7c 6e 00 80 00 emul #0x8000, r14
|
||||
26: fd 7c 60 00 00 80 emul #0xff800000, r0
|
||||
2c: fd 7c 6e 00 00 80 emul #0xff800000, r14
|
||||
32: fd 7c 60 ff ff 7f emul #0x7fffff, r0
|
||||
38: fd 7c 6e ff ff 7f emul #0x7fffff, r14
|
||||
3e: fd 70 60 00 00 00 80 emul #0x80000000, r0
|
||||
45: fd 70 6e 00 00 00 80 emul #0x80000000, r14
|
||||
4c: fd 70 60 ff ff ff 7f emul #0x7fffffff, r0
|
||||
53: fd 70 6e ff ff ff 7f emul #0x7fffffff, r14
|
||||
5a: fc 1b 00 emul r0, r0
|
||||
5d: fc 1b 0e emul r0, r14
|
||||
60: fc 1b f0 emul r15, r0
|
||||
63: fc 1b fe emul r15, r14
|
||||
66: fc 18 00 emul \[r0\]\.ub, r0
|
||||
69: fc 18 0e emul \[r0\]\.ub, r14
|
||||
6c: 06 20 06 00 emul \[r0\]\.b, r0
|
||||
70: 06 20 06 0e emul \[r0\]\.b, r14
|
||||
74: 06 e0 06 00 emul \[r0\]\.uw, r0
|
||||
78: 06 e0 06 0e emul \[r0\]\.uw, r14
|
||||
7c: 06 60 06 00 emul \[r0\]\.w, r0
|
||||
80: 06 60 06 0e emul \[r0\]\.w, r14
|
||||
84: 06 a0 06 00 emul \[r0\]\.l, r0
|
||||
88: 06 a0 06 0e emul \[r0\]\.l, r14
|
||||
8c: fc 18 f0 emul \[r15\]\.ub, r0
|
||||
8f: fc 18 fe emul \[r15\]\.ub, r14
|
||||
92: 06 20 06 f0 emul \[r15\]\.b, r0
|
||||
96: 06 20 06 fe emul \[r15\]\.b, r14
|
||||
9a: 06 e0 06 f0 emul \[r15\]\.uw, r0
|
||||
9e: 06 e0 06 fe emul \[r15\]\.uw, r14
|
||||
a2: 06 60 06 f0 emul \[r15\]\.w, r0
|
||||
a6: 06 60 06 fe emul \[r15\]\.w, r14
|
||||
aa: 06 a0 06 f0 emul \[r15\]\.l, r0
|
||||
ae: 06 a0 06 fe emul \[r15\]\.l, r14
|
||||
b2: fc 19 00 fc emul 252\[r0\]\.ub, r0
|
||||
b6: fc 19 0e fc emul 252\[r0\]\.ub, r14
|
||||
ba: 06 21 06 00 fc emul 252\[r0\]\.b, r0
|
||||
bf: 06 21 06 0e fc emul 252\[r0\]\.b, r14
|
||||
c4: 06 e1 06 00 7e emul 252\[r0\]\.uw, r0
|
||||
c9: 06 e1 06 0e 7e emul 252\[r0\]\.uw, r14
|
||||
ce: 06 61 06 00 7e emul 252\[r0\]\.w, r0
|
||||
d3: 06 61 06 0e 7e emul 252\[r0\]\.w, r14
|
||||
d8: 06 a1 06 00 3f emul 252\[r0\]\.l, r0
|
||||
dd: 06 a1 06 0e 3f emul 252\[r0\]\.l, r14
|
||||
e2: fc 19 f0 fc emul 252\[r15\]\.ub, r0
|
||||
e6: fc 19 fe fc emul 252\[r15\]\.ub, r14
|
||||
ea: 06 21 06 f0 fc emul 252\[r15\]\.b, r0
|
||||
ef: 06 21 06 fe fc emul 252\[r15\]\.b, r14
|
||||
f4: 06 e1 06 f0 7e emul 252\[r15\]\.uw, r0
|
||||
f9: 06 e1 06 fe 7e emul 252\[r15\]\.uw, r14
|
||||
fe: 06 61 06 f0 7e emul 252\[r15\]\.w, r0
|
||||
103: 06 61 06 fe 7e emul 252\[r15\]\.w, r14
|
||||
108: 06 a1 06 f0 3f emul 252\[r15\]\.l, r0
|
||||
10d: 06 a1 06 fe 3f emul 252\[r15\]\.l, r14
|
||||
112: fc 1a 00 fc ff emul 65532\[r0\]\.ub, r0
|
||||
117: fc 1a 0e fc ff emul 65532\[r0\]\.ub, r14
|
||||
11c: 06 22 06 00 fc ff emul 65532\[r0\]\.b, r0
|
||||
122: 06 22 06 0e fc ff emul 65532\[r0\]\.b, r14
|
||||
128: 06 e2 06 00 fe 7f emul 65532\[r0\]\.uw, r0
|
||||
12e: 06 e2 06 0e fe 7f emul 65532\[r0\]\.uw, r14
|
||||
134: 06 62 06 00 fe 7f emul 65532\[r0\]\.w, r0
|
||||
13a: 06 62 06 0e fe 7f emul 65532\[r0\]\.w, r14
|
||||
140: 06 a2 06 00 ff 3f emul 65532\[r0\]\.l, r0
|
||||
146: 06 a2 06 0e ff 3f emul 65532\[r0\]\.l, r14
|
||||
14c: fc 1a f0 fc ff emul 65532\[r15\]\.ub, r0
|
||||
151: fc 1a fe fc ff emul 65532\[r15\]\.ub, r14
|
||||
156: 06 22 06 f0 fc ff emul 65532\[r15\]\.b, r0
|
||||
15c: 06 22 06 fe fc ff emul 65532\[r15\]\.b, r14
|
||||
162: 06 e2 06 f0 fe 7f emul 65532\[r15\]\.uw, r0
|
||||
168: 06 e2 06 fe fe 7f emul 65532\[r15\]\.uw, r14
|
||||
16e: 06 62 06 f0 fe 7f emul 65532\[r15\]\.w, r0
|
||||
174: 06 62 06 fe fe 7f emul 65532\[r15\]\.w, r14
|
||||
17a: 06 a2 06 f0 ff 3f emul 65532\[r15\]\.l, r0
|
||||
180: 06 a2 06 fe ff 3f emul 65532\[r15\]\.l, r14
|
4
gas/testsuite/gas/rx/emul.sm
Normal file
4
gas/testsuite/gas/rx/emul.sm
Normal file
@ -0,0 +1,4 @@
|
||||
emul #{imm},{reg2}
|
||||
emul {reg},{reg2}
|
||||
emul {memx},{reg2}
|
||||
|
88
gas/testsuite/gas/rx/emulu.d
Normal file
88
gas/testsuite/gas/rx/emulu.d
Normal file
@ -0,0 +1,88 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 74 70 80 emulu #-128, r0
|
||||
4: fd 74 7e 80 emulu #-128, r14
|
||||
8: fd 74 70 7f emulu #127, r0
|
||||
c: fd 74 7e 7f emulu #127, r14
|
||||
10: fd 78 70 00 80 emulu #0xffff8000, r0
|
||||
15: fd 78 7e 00 80 emulu #0xffff8000, r14
|
||||
1a: fd 7c 70 00 80 00 emulu #0x8000, r0
|
||||
20: fd 7c 7e 00 80 00 emulu #0x8000, r14
|
||||
26: fd 7c 70 00 00 80 emulu #0xff800000, r0
|
||||
2c: fd 7c 7e 00 00 80 emulu #0xff800000, r14
|
||||
32: fd 7c 70 ff ff 7f emulu #0x7fffff, r0
|
||||
38: fd 7c 7e ff ff 7f emulu #0x7fffff, r14
|
||||
3e: fd 70 70 00 00 00 80 emulu #0x80000000, r0
|
||||
45: fd 70 7e 00 00 00 80 emulu #0x80000000, r14
|
||||
4c: fd 70 70 ff ff ff 7f emulu #0x7fffffff, r0
|
||||
53: fd 70 7e ff ff ff 7f emulu #0x7fffffff, r14
|
||||
5a: fc 1f 00 emulu r0, r0
|
||||
5d: fc 1f 0e emulu r0, r14
|
||||
60: fc 1f f0 emulu r15, r0
|
||||
63: fc 1f fe emulu r15, r14
|
||||
66: fc 1c 00 emulu \[r0\]\.ub, r0
|
||||
69: fc 1c 0e emulu \[r0\]\.ub, r14
|
||||
6c: 06 20 07 00 emulu \[r0\]\.b, r0
|
||||
70: 06 20 07 0e emulu \[r0\]\.b, r14
|
||||
74: 06 e0 07 00 emulu \[r0\]\.uw, r0
|
||||
78: 06 e0 07 0e emulu \[r0\]\.uw, r14
|
||||
7c: 06 60 07 00 emulu \[r0\]\.w, r0
|
||||
80: 06 60 07 0e emulu \[r0\]\.w, r14
|
||||
84: 06 a0 07 00 emulu \[r0\]\.l, r0
|
||||
88: 06 a0 07 0e emulu \[r0\]\.l, r14
|
||||
8c: fc 1c f0 emulu \[r15\]\.ub, r0
|
||||
8f: fc 1c fe emulu \[r15\]\.ub, r14
|
||||
92: 06 20 07 f0 emulu \[r15\]\.b, r0
|
||||
96: 06 20 07 fe emulu \[r15\]\.b, r14
|
||||
9a: 06 e0 07 f0 emulu \[r15\]\.uw, r0
|
||||
9e: 06 e0 07 fe emulu \[r15\]\.uw, r14
|
||||
a2: 06 60 07 f0 emulu \[r15\]\.w, r0
|
||||
a6: 06 60 07 fe emulu \[r15\]\.w, r14
|
||||
aa: 06 a0 07 f0 emulu \[r15\]\.l, r0
|
||||
ae: 06 a0 07 fe emulu \[r15\]\.l, r14
|
||||
b2: fc 1d 00 fc emulu 252\[r0\]\.ub, r0
|
||||
b6: fc 1d 0e fc emulu 252\[r0\]\.ub, r14
|
||||
ba: 06 21 07 00 fc emulu 252\[r0\]\.b, r0
|
||||
bf: 06 21 07 0e fc emulu 252\[r0\]\.b, r14
|
||||
c4: 06 e1 07 00 7e emulu 252\[r0\]\.uw, r0
|
||||
c9: 06 e1 07 0e 7e emulu 252\[r0\]\.uw, r14
|
||||
ce: 06 61 07 00 7e emulu 252\[r0\]\.w, r0
|
||||
d3: 06 61 07 0e 7e emulu 252\[r0\]\.w, r14
|
||||
d8: 06 a1 07 00 3f emulu 252\[r0\]\.l, r0
|
||||
dd: 06 a1 07 0e 3f emulu 252\[r0\]\.l, r14
|
||||
e2: fc 1d f0 fc emulu 252\[r15\]\.ub, r0
|
||||
e6: fc 1d fe fc emulu 252\[r15\]\.ub, r14
|
||||
ea: 06 21 07 f0 fc emulu 252\[r15\]\.b, r0
|
||||
ef: 06 21 07 fe fc emulu 252\[r15\]\.b, r14
|
||||
f4: 06 e1 07 f0 7e emulu 252\[r15\]\.uw, r0
|
||||
f9: 06 e1 07 fe 7e emulu 252\[r15\]\.uw, r14
|
||||
fe: 06 61 07 f0 7e emulu 252\[r15\]\.w, r0
|
||||
103: 06 61 07 fe 7e emulu 252\[r15\]\.w, r14
|
||||
108: 06 a1 07 f0 3f emulu 252\[r15\]\.l, r0
|
||||
10d: 06 a1 07 fe 3f emulu 252\[r15\]\.l, r14
|
||||
112: fc 1e 00 fc ff emulu 65532\[r0\]\.ub, r0
|
||||
117: fc 1e 0e fc ff emulu 65532\[r0\]\.ub, r14
|
||||
11c: 06 22 07 00 fc ff emulu 65532\[r0\]\.b, r0
|
||||
122: 06 22 07 0e fc ff emulu 65532\[r0\]\.b, r14
|
||||
128: 06 e2 07 00 fe 7f emulu 65532\[r0\]\.uw, r0
|
||||
12e: 06 e2 07 0e fe 7f emulu 65532\[r0\]\.uw, r14
|
||||
134: 06 62 07 00 fe 7f emulu 65532\[r0\]\.w, r0
|
||||
13a: 06 62 07 0e fe 7f emulu 65532\[r0\]\.w, r14
|
||||
140: 06 a2 07 00 ff 3f emulu 65532\[r0\]\.l, r0
|
||||
146: 06 a2 07 0e ff 3f emulu 65532\[r0\]\.l, r14
|
||||
14c: fc 1e f0 fc ff emulu 65532\[r15\]\.ub, r0
|
||||
151: fc 1e fe fc ff emulu 65532\[r15\]\.ub, r14
|
||||
156: 06 22 07 f0 fc ff emulu 65532\[r15\]\.b, r0
|
||||
15c: 06 22 07 fe fc ff emulu 65532\[r15\]\.b, r14
|
||||
162: 06 e2 07 f0 fe 7f emulu 65532\[r15\]\.uw, r0
|
||||
168: 06 e2 07 fe fe 7f emulu 65532\[r15\]\.uw, r14
|
||||
16e: 06 62 07 f0 fe 7f emulu 65532\[r15\]\.w, r0
|
||||
174: 06 62 07 fe fe 7f emulu 65532\[r15\]\.w, r14
|
||||
17a: 06 a2 07 f0 ff 3f emulu 65532\[r15\]\.l, r0
|
||||
180: 06 a2 07 fe ff 3f emulu 65532\[r15\]\.l, r14
|
4
gas/testsuite/gas/rx/emulu.sm
Normal file
4
gas/testsuite/gas/rx/emulu.sm
Normal file
@ -0,0 +1,4 @@
|
||||
emulu #{imm},{reg2}
|
||||
emulu {reg},{reg2}
|
||||
emulu {memx},{reg2}
|
||||
|
199
gas/testsuite/gas/rx/explode
Executable file
199
gas/testsuite/gas/rx/explode
Executable file
@ -0,0 +1,199 @@
|
||||
#!/usr/bin/perl
|
||||
# -*- perl -*-
|
||||
|
||||
# Copyright (C) 2006 Red Hat 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. */
|
||||
|
||||
%myfiles = ();
|
||||
|
||||
$incdir = ".";
|
||||
|
||||
while ($ARGV[0] =~ /^-/) {
|
||||
$opt = shift;
|
||||
if ($opt eq "-I") {
|
||||
$incdir = shift;
|
||||
}
|
||||
}
|
||||
|
||||
$infile = shift;
|
||||
$outfile = shift;
|
||||
|
||||
$inbase = $infile;
|
||||
$inbase =~ s@.*/@@;
|
||||
$inbase =~ s@[^a-zA-Z0-9].*@@;
|
||||
|
||||
$t = 0;
|
||||
$errors = 0;
|
||||
|
||||
if ($outfile) {
|
||||
open(OUT, ">$outfile");
|
||||
} else {
|
||||
open(OUT, ">&STDOUT");
|
||||
}
|
||||
|
||||
open(I, "$incdir/macros.inc") || die("$incdir/macros.inc: $!");
|
||||
&read_file();
|
||||
close I;
|
||||
open(I, $infile) || die("$infile: $!");
|
||||
&read_file();
|
||||
close I;
|
||||
|
||||
sub read_file {
|
||||
while (<I>) {
|
||||
$line ++;
|
||||
next if /^;/;
|
||||
s/[\r\n]+$//;
|
||||
if (/^macro\s+(\S+)\s+(.*)/) {
|
||||
($name, $val) = ($1,$2);
|
||||
print "set macro \"$name\" to \"$val\"\n" if $t;
|
||||
$macro{$name} = $val;
|
||||
} elsif (/\S/) {
|
||||
&explode($_);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
exit ($errors);
|
||||
|
||||
# There's no way to quote braces so you can output them :-P
|
||||
|
||||
sub explode {
|
||||
my ($s) = @_;
|
||||
my ($a, $b, $p, $e, @params);
|
||||
|
||||
print "explode($s)\n" if $t;
|
||||
|
||||
($b, $a, @params) = &split_braces($s);
|
||||
@params = explode_params (@params);
|
||||
if (! $a && ! @params) {
|
||||
if ($t) {
|
||||
print "\033[33m$s\033[0m\n";
|
||||
} else {
|
||||
print OUT "$s\n";
|
||||
}
|
||||
return;
|
||||
}
|
||||
if (@params == 1 && defined $macro{$params[0]}) {
|
||||
$p = $macro{$params[0]};
|
||||
&explode ("$b$p$a");
|
||||
} else {
|
||||
for $p (@params) {
|
||||
&explode ("$b$p$a");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
sub explode_params {
|
||||
my (@p) = @_;
|
||||
my ($p,@r);
|
||||
|
||||
@r = ();
|
||||
while (@p) {
|
||||
$p = shift @p;
|
||||
($b,$a,@e) = split_braces ($p);
|
||||
if (defined $a) {
|
||||
for $e (reverse @e) {
|
||||
unshift (@p, "$b$e$a");
|
||||
}
|
||||
} else {
|
||||
push (@r, $p);
|
||||
}
|
||||
}
|
||||
return @r;
|
||||
}
|
||||
|
||||
sub getmacro {
|
||||
my ($v) = $macro{$_[0]};
|
||||
if (! defined $v) {
|
||||
print STDERR "$line: Error: macro $_[0] not defined\n";
|
||||
$errors ++;
|
||||
}
|
||||
return $v;
|
||||
}
|
||||
|
||||
sub expand_macros {
|
||||
my ($l) = @_;
|
||||
0 while $l =~ s/{([^{};]+)}/&getmacro($1)/ge;
|
||||
return $l;
|
||||
}
|
||||
|
||||
# returns (before, after, list of variances)
|
||||
sub split_braces {
|
||||
my ($l) = @_;
|
||||
my (@l, $i, $a, @parms, $b, $n,$p);
|
||||
|
||||
print "split_braces($l) = (" if $t;
|
||||
|
||||
$l = &expand_macros ($l);
|
||||
|
||||
if ($l !~ /\{.*\}/) {
|
||||
print "nothing)\n" if $t;
|
||||
return ($l);
|
||||
}
|
||||
if ($l =~ /^{([^{};]+)}/) {
|
||||
print "macro:", $macro{$1}, ")\n" if $t;
|
||||
return (&getmacro($1), "");
|
||||
}
|
||||
|
||||
$n = 0;
|
||||
@parms = ('');
|
||||
$p = 0;
|
||||
|
||||
($a, $l) = $l =~ m@^([^\{]*)\{(.*)@;
|
||||
@l = split(//, $l);
|
||||
|
||||
while (defined ($i = shift @l)) {
|
||||
if ($n == 0) {
|
||||
print "\033[32m$i" if $t;
|
||||
if ($i eq '}') {
|
||||
print "\033[0m$a, ", join('', @l), ", (", join("\033[31m;\033[0m", @parms), ")\n" if $t;
|
||||
return ($a, join('',@l), @parms);
|
||||
} elsif ($i eq ';') {
|
||||
$p ++;
|
||||
$parms[$p] = '';
|
||||
} else {
|
||||
$parms[$p] .= $i;
|
||||
$n ++ if $i eq '{';
|
||||
}
|
||||
} else {
|
||||
print "\033[34m$i" if $t;
|
||||
$n ++ if $i eq '{';
|
||||
$n -- if $i eq '}';
|
||||
$parms[$p] .= $i;
|
||||
}
|
||||
}
|
||||
print "$a, <null>, (", join(';', @parms), ")\n" if $t;
|
||||
return ($a, "", @parms);
|
||||
}
|
||||
|
||||
__END__;
|
||||
|
||||
macro rest c,d
|
||||
foo {a;b},{{rest};e;}
|
||||
|
||||
expands to:
|
||||
|
||||
foo a,c
|
||||
foo a,d
|
||||
foo a,e
|
||||
foo a,
|
||||
foo b,c
|
||||
foo b,d
|
||||
foo b,e
|
||||
foo b,
|
28
gas/testsuite/gas/rx/fadd.d
Normal file
28
gas/testsuite/gas/rx/fadd.d
Normal file
@ -0,0 +1,28 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 72 20 00 00 00 80 fadd #0x80000000, r0
|
||||
7: fd 72 2f 00 00 00 80 fadd #0x80000000, r15
|
||||
e: fd 72 20 ff ff ff ff fadd #-1, r0
|
||||
15: fd 72 2f ff ff ff ff fadd #-1, r15
|
||||
1c: fc 8b 00 fadd r0, r0
|
||||
1f: fc 8b 0f fadd r0, r15
|
||||
22: fc 8b f0 fadd r15, r0
|
||||
25: fc 8b ff fadd r15, r15
|
||||
28: fc 88 00 fadd \[r0\]\.l, r0
|
||||
2b: fc 88 0f fadd \[r0\]\.l, r15
|
||||
2e: fc 88 f0 fadd \[r15\]\.l, r0
|
||||
31: fc 88 ff fadd \[r15\]\.l, r15
|
||||
34: fc 89 00 3f fadd 252\[r0\]\.l, r0
|
||||
38: fc 89 0f 3f fadd 252\[r0\]\.l, r15
|
||||
3c: fc 89 f0 3f fadd 252\[r15\]\.l, r0
|
||||
40: fc 89 ff 3f fadd 252\[r15\]\.l, r15
|
||||
44: fc 8a 00 ff 3f fadd 65532\[r0\]\.l, r0
|
||||
49: fc 8a 0f ff 3f fadd 65532\[r0\]\.l, r15
|
||||
4e: fc 8a f0 ff 3f fadd 65532\[r15\]\.l, r0
|
||||
53: fc 8a ff ff 3f fadd 65532\[r15\]\.l, r15
|
3
gas/testsuite/gas/rx/fadd.sm
Normal file
3
gas/testsuite/gas/rx/fadd.sm
Normal file
@ -0,0 +1,3 @@
|
||||
fadd #{imm32},{reg}
|
||||
fadd {reg},{reg}
|
||||
fadd {mem}.L,{reg}
|
28
gas/testsuite/gas/rx/fcmp.d
Normal file
28
gas/testsuite/gas/rx/fcmp.d
Normal file
@ -0,0 +1,28 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 72 10 00 00 00 80 fcmp #0x80000000, r0
|
||||
7: fd 72 1f 00 00 00 80 fcmp #0x80000000, r15
|
||||
e: fd 72 10 ff ff ff ff fcmp #-1, r0
|
||||
15: fd 72 1f ff ff ff ff fcmp #-1, r15
|
||||
1c: fc 87 00 fcmp r0, r0
|
||||
1f: fc 87 0f fcmp r0, r15
|
||||
22: fc 87 f0 fcmp r15, r0
|
||||
25: fc 87 ff fcmp r15, r15
|
||||
28: fc 84 00 fcmp \[r0\]\.l, r0
|
||||
2b: fc 84 0f fcmp \[r0\]\.l, r15
|
||||
2e: fc 84 f0 fcmp \[r15\]\.l, r0
|
||||
31: fc 84 ff fcmp \[r15\]\.l, r15
|
||||
34: fc 85 00 3f fcmp 252\[r0\]\.l, r0
|
||||
38: fc 85 0f 3f fcmp 252\[r0\]\.l, r15
|
||||
3c: fc 85 f0 3f fcmp 252\[r15\]\.l, r0
|
||||
40: fc 85 ff 3f fcmp 252\[r15\]\.l, r15
|
||||
44: fc 86 00 ff 3f fcmp 65532\[r0\]\.l, r0
|
||||
49: fc 86 0f ff 3f fcmp 65532\[r0\]\.l, r15
|
||||
4e: fc 86 f0 ff 3f fcmp 65532\[r15\]\.l, r0
|
||||
53: fc 86 ff ff 3f fcmp 65532\[r15\]\.l, r15
|
3
gas/testsuite/gas/rx/fcmp.sm
Normal file
3
gas/testsuite/gas/rx/fcmp.sm
Normal file
@ -0,0 +1,3 @@
|
||||
fcmp #{imm32},{reg}
|
||||
fcmp {reg},{reg}
|
||||
fcmp {mem}.L,{reg}
|
28
gas/testsuite/gas/rx/fdiv.d
Normal file
28
gas/testsuite/gas/rx/fdiv.d
Normal file
@ -0,0 +1,28 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 72 40 00 00 00 80 fdiv #0x80000000, r0
|
||||
7: fd 72 4f 00 00 00 80 fdiv #0x80000000, r15
|
||||
e: fd 72 40 ff ff ff ff fdiv #-1, r0
|
||||
15: fd 72 4f ff ff ff ff fdiv #-1, r15
|
||||
1c: fc 93 00 fdiv r0, r0
|
||||
1f: fc 93 0f fdiv r0, r15
|
||||
22: fc 93 f0 fdiv r15, r0
|
||||
25: fc 93 ff fdiv r15, r15
|
||||
28: fc 90 00 fdiv \[r0\]\.l, r0
|
||||
2b: fc 90 0f fdiv \[r0\]\.l, r15
|
||||
2e: fc 90 f0 fdiv \[r15\]\.l, r0
|
||||
31: fc 90 ff fdiv \[r15\]\.l, r15
|
||||
34: fc 91 00 3f fdiv 252\[r0\]\.l, r0
|
||||
38: fc 91 0f 3f fdiv 252\[r0\]\.l, r15
|
||||
3c: fc 91 f0 3f fdiv 252\[r15\]\.l, r0
|
||||
40: fc 91 ff 3f fdiv 252\[r15\]\.l, r15
|
||||
44: fc 92 00 ff 3f fdiv 65532\[r0\]\.l, r0
|
||||
49: fc 92 0f ff 3f fdiv 65532\[r0\]\.l, r15
|
||||
4e: fc 92 f0 ff 3f fdiv 65532\[r15\]\.l, r0
|
||||
53: fc 92 ff ff 3f fdiv 65532\[r15\]\.l, r15
|
3
gas/testsuite/gas/rx/fdiv.sm
Normal file
3
gas/testsuite/gas/rx/fdiv.sm
Normal file
@ -0,0 +1,3 @@
|
||||
fdiv #{imm32},{reg}
|
||||
fdiv {reg},{reg}
|
||||
fdiv {mem}.L,{reg}
|
28
gas/testsuite/gas/rx/fmul.d
Normal file
28
gas/testsuite/gas/rx/fmul.d
Normal file
@ -0,0 +1,28 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 72 30 00 00 00 80 fmul #0x80000000, r0
|
||||
7: fd 72 3f 00 00 00 80 fmul #0x80000000, r15
|
||||
e: fd 72 30 ff ff ff ff fmul #-1, r0
|
||||
15: fd 72 3f ff ff ff ff fmul #-1, r15
|
||||
1c: fc 8f 00 fmul r0, r0
|
||||
1f: fc 8f 0f fmul r0, r15
|
||||
22: fc 8f f0 fmul r15, r0
|
||||
25: fc 8f ff fmul r15, r15
|
||||
28: fc 8c 00 fmul \[r0\]\.l, r0
|
||||
2b: fc 8c 0f fmul \[r0\]\.l, r15
|
||||
2e: fc 8c f0 fmul \[r15\]\.l, r0
|
||||
31: fc 8c ff fmul \[r15\]\.l, r15
|
||||
34: fc 8d 00 3f fmul 252\[r0\]\.l, r0
|
||||
38: fc 8d 0f 3f fmul 252\[r0\]\.l, r15
|
||||
3c: fc 8d f0 3f fmul 252\[r15\]\.l, r0
|
||||
40: fc 8d ff 3f fmul 252\[r15\]\.l, r15
|
||||
44: fc 8e 00 ff 3f fmul 65532\[r0\]\.l, r0
|
||||
49: fc 8e 0f ff 3f fmul 65532\[r0\]\.l, r15
|
||||
4e: fc 8e f0 ff 3f fmul 65532\[r15\]\.l, r0
|
||||
53: fc 8e ff ff 3f fmul 65532\[r15\]\.l, r15
|
3
gas/testsuite/gas/rx/fmul.sm
Normal file
3
gas/testsuite/gas/rx/fmul.sm
Normal file
@ -0,0 +1,3 @@
|
||||
fmul #{imm32},{reg}
|
||||
fmul {reg},{reg}
|
||||
fmul {mem}.L,{reg}
|
28
gas/testsuite/gas/rx/fsub.d
Normal file
28
gas/testsuite/gas/rx/fsub.d
Normal file
@ -0,0 +1,28 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fd 72 00 00 00 00 80 fsub #0x80000000, r0
|
||||
7: fd 72 0f 00 00 00 80 fsub #0x80000000, r15
|
||||
e: fd 72 00 ff ff ff ff fsub #-1, r0
|
||||
15: fd 72 0f ff ff ff ff fsub #-1, r15
|
||||
1c: fc 83 00 fsub r0, r0
|
||||
1f: fc 83 0f fsub r0, r15
|
||||
22: fc 83 f0 fsub r15, r0
|
||||
25: fc 83 ff fsub r15, r15
|
||||
28: fc 80 00 fsub \[r0\]\.l, r0
|
||||
2b: fc 80 0f fsub \[r0\]\.l, r15
|
||||
2e: fc 80 f0 fsub \[r15\]\.l, r0
|
||||
31: fc 80 ff fsub \[r15\]\.l, r15
|
||||
34: fc 81 00 3f fsub 252\[r0\]\.l, r0
|
||||
38: fc 81 0f 3f fsub 252\[r0\]\.l, r15
|
||||
3c: fc 81 f0 3f fsub 252\[r15\]\.l, r0
|
||||
40: fc 81 ff 3f fsub 252\[r15\]\.l, r15
|
||||
44: fc 82 00 ff 3f fsub 65532\[r0\]\.l, r0
|
||||
49: fc 82 0f ff 3f fsub 65532\[r0\]\.l, r15
|
||||
4e: fc 82 f0 ff 3f fsub 65532\[r15\]\.l, r0
|
||||
53: fc 82 ff ff 3f fsub 65532\[r15\]\.l, r15
|
3
gas/testsuite/gas/rx/fsub.sm
Normal file
3
gas/testsuite/gas/rx/fsub.sm
Normal file
@ -0,0 +1,3 @@
|
||||
fsub #{imm32},{reg}
|
||||
fsub {reg},{reg}
|
||||
fsub {mem}.L,{reg}
|
24
gas/testsuite/gas/rx/ftoi.d
Normal file
24
gas/testsuite/gas/rx/ftoi.d
Normal file
@ -0,0 +1,24 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fc 97 00 ftoi r0, r0
|
||||
3: fc 97 0f ftoi r0, r15
|
||||
6: fc 97 f0 ftoi r15, r0
|
||||
9: fc 97 ff ftoi r15, r15
|
||||
c: fc 94 00 ftoi \[r0\]\.l, r0
|
||||
f: fc 94 0f ftoi \[r0\]\.l, r15
|
||||
12: fc 94 f0 ftoi \[r15\]\.l, r0
|
||||
15: fc 94 ff ftoi \[r15\]\.l, r15
|
||||
18: fc 95 00 3f ftoi 252\[r0\]\.l, r0
|
||||
1c: fc 95 0f 3f ftoi 252\[r0\]\.l, r15
|
||||
20: fc 95 f0 3f ftoi 252\[r15\]\.l, r0
|
||||
24: fc 95 ff 3f ftoi 252\[r15\]\.l, r15
|
||||
28: fc 96 00 ff 3f ftoi 65532\[r0\]\.l, r0
|
||||
2d: fc 96 0f ff 3f ftoi 65532\[r0\]\.l, r15
|
||||
32: fc 96 f0 ff 3f ftoi 65532\[r15\]\.l, r0
|
||||
37: fc 96 ff ff 3f ftoi 65532\[r15\]\.l, r15
|
2
gas/testsuite/gas/rx/ftoi.sm
Normal file
2
gas/testsuite/gas/rx/ftoi.sm
Normal file
@ -0,0 +1,2 @@
|
||||
ftoi {reg},{reg}
|
||||
ftoi {mem}.L,{reg}
|
53
gas/testsuite/gas/rx/gprel.d
Normal file
53
gas/testsuite/gas/rx/gprel.d
Normal file
@ -0,0 +1,53 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section .text:
|
||||
|
||||
00000000 <_start>:
|
||||
0: ce f1 04 00 mov\.b 4\[r15\], r1
|
||||
2: R_RX_SYM _foo
|
||||
2: R_RX_SYM __gp
|
||||
2: R_RX_OPsub __gp
|
||||
2: R_RX_ABS16U __gp
|
||||
4: ce f1 08 00 mov\.b 8\[r15\], r1
|
||||
6: R_RX_SYM _bar
|
||||
6: R_RX_SYM __gp
|
||||
6: R_RX_OPsub __gp
|
||||
6: R_RX_ABS16U __gp
|
||||
8: ce f1 00 00 mov\.b \[r15\], r1
|
||||
a: R_RX_SYM _grill
|
||||
a: R_RX_SYM __gp
|
||||
a: R_RX_OPsub __gp
|
||||
a: R_RX_ABS16U __gp
|
||||
c: de f1 02 00 mov\.w 4\[r15\], r1
|
||||
e: R_RX_SYM _foo
|
||||
e: R_RX_SYM __gp
|
||||
e: R_RX_OPsub __gp
|
||||
e: R_RX_ABS16UW __gp
|
||||
10: de f1 04 00 mov\.w 8\[r15\], r1
|
||||
12: R_RX_SYM _bar
|
||||
12: R_RX_SYM __gp
|
||||
12: R_RX_OPsub __gp
|
||||
12: R_RX_ABS16UW __gp
|
||||
14: de f1 00 00 mov\.w \[r15\], r1
|
||||
16: R_RX_SYM _grill
|
||||
16: R_RX_SYM __gp
|
||||
16: R_RX_OPsub __gp
|
||||
16: R_RX_ABS16UW __gp
|
||||
18: ee f1 01 00 mov\.l 4\[r15\], r1
|
||||
1a: R_RX_SYM _foo
|
||||
1a: R_RX_SYM __gp
|
||||
1a: R_RX_OPsub __gp
|
||||
1a: R_RX_ABS16UL __gp
|
||||
1c: ee f1 02 00 mov\.l 8\[r15\], r1
|
||||
1e: R_RX_SYM _bar
|
||||
1e: R_RX_SYM __gp
|
||||
1e: R_RX_OPsub __gp
|
||||
1e: R_RX_ABS16UL __gp
|
||||
20: ee f1 00 00 mov\.l \[r15\], r1
|
||||
22: R_RX_SYM _grill
|
||||
22: R_RX_SYM __gp
|
||||
22: R_RX_OPsub __gp
|
||||
22: R_RX_ABS16UL __gp
|
9
gas/testsuite/gas/rx/gprel.sm
Normal file
9
gas/testsuite/gas/rx/gprel.sm
Normal file
@ -0,0 +1,9 @@
|
||||
.text
|
||||
.global _start
|
||||
_start:
|
||||
mov{bwl} %gp({_foo;_bar;_grill})[r15], r1
|
||||
|
||||
.data
|
||||
__gp: .long 0
|
||||
_foo: .long 5
|
||||
_bar: .long 6
|
10
gas/testsuite/gas/rx/int.d
Normal file
10
gas/testsuite/gas/rx/int.d
Normal file
@ -0,0 +1,10 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 75 60 00 int #0
|
||||
3: 75 60 ff int #255
|
1
gas/testsuite/gas/rx/int.sm
Normal file
1
gas/testsuite/gas/rx/int.sm
Normal file
@ -0,0 +1 @@
|
||||
int #{uimm8}
|
72
gas/testsuite/gas/rx/itof.d
Normal file
72
gas/testsuite/gas/rx/itof.d
Normal file
@ -0,0 +1,72 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: fc 47 00 itof r0, r0
|
||||
3: fc 47 0f itof r0, r15
|
||||
6: fc 47 f0 itof r15, r0
|
||||
9: fc 47 ff itof r15, r15
|
||||
c: fc 44 00 itof \[r0\]\.ub, r0
|
||||
f: fc 44 0f itof \[r0\]\.ub, r15
|
||||
12: 06 20 11 00 itof \[r0\]\.b, r0
|
||||
16: 06 20 11 0f itof \[r0\]\.b, r15
|
||||
1a: 06 e0 11 00 itof \[r0\]\.uw, r0
|
||||
1e: 06 e0 11 0f itof \[r0\]\.uw, r15
|
||||
22: 06 60 11 00 itof \[r0\]\.w, r0
|
||||
26: 06 60 11 0f itof \[r0\]\.w, r15
|
||||
2a: 06 a0 11 00 itof \[r0\]\.l, r0
|
||||
2e: 06 a0 11 0f itof \[r0\]\.l, r15
|
||||
32: fc 44 f0 itof \[r15\]\.ub, r0
|
||||
35: fc 44 ff itof \[r15\]\.ub, r15
|
||||
38: 06 20 11 f0 itof \[r15\]\.b, r0
|
||||
3c: 06 20 11 ff itof \[r15\]\.b, r15
|
||||
40: 06 e0 11 f0 itof \[r15\]\.uw, r0
|
||||
44: 06 e0 11 ff itof \[r15\]\.uw, r15
|
||||
48: 06 60 11 f0 itof \[r15\]\.w, r0
|
||||
4c: 06 60 11 ff itof \[r15\]\.w, r15
|
||||
50: 06 a0 11 f0 itof \[r15\]\.l, r0
|
||||
54: 06 a0 11 ff itof \[r15\]\.l, r15
|
||||
58: fc 45 00 fc itof 252\[r0\]\.ub, r0
|
||||
5c: fc 45 0f fc itof 252\[r0\]\.ub, r15
|
||||
60: 06 21 11 00 fc itof 252\[r0\]\.b, r0
|
||||
65: 06 21 11 0f fc itof 252\[r0\]\.b, r15
|
||||
6a: 06 e1 11 00 7e itof 252\[r0\]\.uw, r0
|
||||
6f: 06 e1 11 0f 7e itof 252\[r0\]\.uw, r15
|
||||
74: 06 61 11 00 7e itof 252\[r0\]\.w, r0
|
||||
79: 06 61 11 0f 7e itof 252\[r0\]\.w, r15
|
||||
7e: 06 a1 11 00 3f itof 252\[r0\]\.l, r0
|
||||
83: 06 a1 11 0f 3f itof 252\[r0\]\.l, r15
|
||||
88: fc 45 f0 fc itof 252\[r15\]\.ub, r0
|
||||
8c: fc 45 ff fc itof 252\[r15\]\.ub, r15
|
||||
90: 06 21 11 f0 fc itof 252\[r15\]\.b, r0
|
||||
95: 06 21 11 ff fc itof 252\[r15\]\.b, r15
|
||||
9a: 06 e1 11 f0 7e itof 252\[r15\]\.uw, r0
|
||||
9f: 06 e1 11 ff 7e itof 252\[r15\]\.uw, r15
|
||||
a4: 06 61 11 f0 7e itof 252\[r15\]\.w, r0
|
||||
a9: 06 61 11 ff 7e itof 252\[r15\]\.w, r15
|
||||
ae: 06 a1 11 f0 3f itof 252\[r15\]\.l, r0
|
||||
b3: 06 a1 11 ff 3f itof 252\[r15\]\.l, r15
|
||||
b8: fc 46 00 fc ff itof 65532\[r0\]\.ub, r0
|
||||
bd: fc 46 0f fc ff itof 65532\[r0\]\.ub, r15
|
||||
c2: 06 22 11 00 fc ff itof 65532\[r0\]\.b, r0
|
||||
c8: 06 22 11 0f fc ff itof 65532\[r0\]\.b, r15
|
||||
ce: 06 e2 11 00 fe 7f itof 65532\[r0\]\.uw, r0
|
||||
d4: 06 e2 11 0f fe 7f itof 65532\[r0\]\.uw, r15
|
||||
da: 06 62 11 00 fe 7f itof 65532\[r0\]\.w, r0
|
||||
e0: 06 62 11 0f fe 7f itof 65532\[r0\]\.w, r15
|
||||
e6: 06 a2 11 00 ff 3f itof 65532\[r0\]\.l, r0
|
||||
ec: 06 a2 11 0f ff 3f itof 65532\[r0\]\.l, r15
|
||||
f2: fc 46 f0 fc ff itof 65532\[r15\]\.ub, r0
|
||||
f7: fc 46 ff fc ff itof 65532\[r15\]\.ub, r15
|
||||
fc: 06 22 11 f0 fc ff itof 65532\[r15\]\.b, r0
|
||||
102: 06 22 11 ff fc ff itof 65532\[r15\]\.b, r15
|
||||
108: 06 e2 11 f0 fe 7f itof 65532\[r15\]\.uw, r0
|
||||
10e: 06 e2 11 ff fe 7f itof 65532\[r15\]\.uw, r15
|
||||
114: 06 62 11 f0 fe 7f itof 65532\[r15\]\.w, r0
|
||||
11a: 06 62 11 ff fe 7f itof 65532\[r15\]\.w, r15
|
||||
120: 06 a2 11 f0 ff 3f itof 65532\[r15\]\.l, r0
|
||||
126: 06 a2 11 ff ff 3f itof 65532\[r15\]\.l, r15
|
2
gas/testsuite/gas/rx/itof.sm
Normal file
2
gas/testsuite/gas/rx/itof.sm
Normal file
@ -0,0 +1,2 @@
|
||||
itof {reg},{reg}
|
||||
itof {memx},{reg}
|
10
gas/testsuite/gas/rx/jmp.d
Normal file
10
gas/testsuite/gas/rx/jmp.d
Normal file
@ -0,0 +1,10 @@
|
||||
#objdump: -dr
|
||||
|
||||
dump\.o: file format .*
|
||||
|
||||
|
||||
Disassembly of section \.text:
|
||||
|
||||
00000000 <\.text>:
|
||||
0: 7f 00 jmp r0
|
||||
2: 7f 0f jmp r15
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user