diff options
author | Alan Modra <amodra@gmail.com> | 2018-04-11 18:46:05 +0930 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2018-04-11 21:49:30 +0930 |
commit | a8eb42a8b7d48ff6bd12ac83b0e31967b4f5abf1 (patch) | |
tree | 60b19da93f47532605aea14cc4cec88b442c43f6 | |
parent | c43b2c546be1fead208b816b59c8bdcdf9562571 (diff) | |
download | gdb-a8eb42a8b7d48ff6bd12ac83b0e31967b4f5abf1.zip gdb-a8eb42a8b7d48ff6bd12ac83b0e31967b4f5abf1.tar.gz gdb-a8eb42a8b7d48ff6bd12ac83b0e31967b4f5abf1.tar.bz2 |
Remove i860, i960, bout and aout-adobe targets
Plus remove a few leftovers from the 29k support.
include/
* aout/adobe.h: Delete.
* aout/reloc.h: Delete.
* coff/i860.h: Delete.
* coff/i960.h: Delete.
* elf/i860.h: Delete.
* elf/i960.h: Delete.
* opcode/i860.h: Delete.
* opcode/i960.h: Delete.
* aout/aout64.h (enum reloc_type): Trim off 29k and other unused values.
* aout/ar.h (ARMAGB): Remove.
* coff/internal.h (struct internal_aouthdr, struct internal_scnhdr,
union internal_auxent): Remove i960 support.
bfd/
* aout-adobe.c: Delete.
* bout.c: Delete.
* coff-i860.c: Delete.
* coff-i960.c: Delete.
* cpu-i860.c: Delete.
* cpu-i960.c: Delete.
* elf32-i860.c: Delete.
* elf32-i960.c: Delete.
* hosts/i860mach3.h: Delete.
* Makefile.am: Remove i860, i960, bout, and adobe support.
* archures.c: Remove i860 and i960 support.
* coffcode.h: Likewise.
* reloc.c: Likewise.
* aoutx.h: Comment updates.
* archive.c: Remove BOUT and i960 support.
* bfd.c: Remove BOUT support.
* coffswap.h: Remove i960 support.
* config.bfd: Remove i860, i960 and adobe targets.
* configure.ac: Remove adode, bout, i860, i960, icoff targets.
* targets.c: Likewise.
* ieee.c: Remove i960 support.
* mach-o.c: Remove i860 support.
* Makefile.in: Regenerate.
* bfd-in2.h: Regenerate.
* configure: Regenerate.
* libbfd.h: Regenerate.
* po/SRC-POTFILES.in: Regenerate.
opcodes/
* opcodes/i860-dis.c: Delete.
* opcodes/i960-dis.c: Delete.
* Makefile.am: Remove i860 and i960 support.
* configure.ac: Likewise.
* disassemble.c: Likewise.
* disassemble.h: Likewise.
* Makefile.in: Regenerate.
* configure: Regenerate.
* po/POTFILES.in: Regenerate.
binutils/
* ieee.c: Remove i960 support.
* od-macho.c: Remove i860 support.
* readelf.c: Remove i860 and i960 support.
* testsuite/binutils-all/objcopy.exp: Likewise.
* testsuite/binutils-all/objdump.exp: Likewise.
* testsuite/lib/binutils-common.exp: Likewise.
gas/
* config/aout_gnu.h: Delete.
* config/tc-i860.c: Delete.
* config/tc-i860.h: Delete.
* config/tc-i960.c: Delete.
* config/tc-i960.h: Delete.
* doc/c-i860.texi: Delete.
* doc/c-i960.texi: Delete.
* testsuite/gas/i860/README.i860: Delete.
* testsuite/gas/i860/bitwise.d: Delete.
* testsuite/gas/i860/bitwise.s: Delete.
* testsuite/gas/i860/branch.d: Delete.
* testsuite/gas/i860/branch.s: Delete.
* testsuite/gas/i860/bte.d: Delete.
* testsuite/gas/i860/bte.s: Delete.
* testsuite/gas/i860/dir-align01.d: Delete.
* testsuite/gas/i860/dir-align01.s: Delete.
* testsuite/gas/i860/dir-intel01.d: Delete.
* testsuite/gas/i860/dir-intel01.s: Delete.
* testsuite/gas/i860/dir-intel02.d: Delete.
* testsuite/gas/i860/dir-intel02.s: Delete.
* testsuite/gas/i860/dir-intel03-err.l: Delete.
* testsuite/gas/i860/dir-intel03-err.s: Delete.
* testsuite/gas/i860/dual01.d: Delete.
* testsuite/gas/i860/dual01.s: Delete.
* testsuite/gas/i860/dual02-err.l: Delete.
* testsuite/gas/i860/dual02-err.s: Delete.
* testsuite/gas/i860/dual03.d: Delete.
* testsuite/gas/i860/dual03.s: Delete.
* testsuite/gas/i860/fldst01.d: Delete.
* testsuite/gas/i860/fldst01.s: Delete.
* testsuite/gas/i860/fldst02.d: Delete.
* testsuite/gas/i860/fldst02.s: Delete.
* testsuite/gas/i860/fldst03.d: Delete.
* testsuite/gas/i860/fldst03.s: Delete.
* testsuite/gas/i860/fldst04.d: Delete.
* testsuite/gas/i860/fldst04.s: Delete.
* testsuite/gas/i860/fldst05.d: Delete.
* testsuite/gas/i860/fldst05.s: Delete.
* testsuite/gas/i860/fldst06.d: Delete.
* testsuite/gas/i860/fldst06.s: Delete.
* testsuite/gas/i860/fldst07.d: Delete.
* testsuite/gas/i860/fldst07.s: Delete.
* testsuite/gas/i860/fldst08.d: Delete.
* testsuite/gas/i860/fldst08.s: Delete.
* testsuite/gas/i860/float01.d: Delete.
* testsuite/gas/i860/float01.s: Delete.
* testsuite/gas/i860/float02.d: Delete.
* testsuite/gas/i860/float02.s: Delete.
* testsuite/gas/i860/float03.d: Delete.
* testsuite/gas/i860/float03.s: Delete.
* testsuite/gas/i860/float04.d: Delete.
* testsuite/gas/i860/float04.s: Delete.
* testsuite/gas/i860/form.d: Delete.
* testsuite/gas/i860/form.s: Delete.
* testsuite/gas/i860/i860.exp: Delete.
* testsuite/gas/i860/iarith.d: Delete.
* testsuite/gas/i860/iarith.s: Delete.
* testsuite/gas/i860/ldst01.d: Delete.
* testsuite/gas/i860/ldst01.s: Delete.
* testsuite/gas/i860/ldst02.d: Delete.
* testsuite/gas/i860/ldst02.s: Delete.
* testsuite/gas/i860/ldst03.d: Delete.
* testsuite/gas/i860/ldst03.s: Delete.
* testsuite/gas/i860/ldst04.d: Delete.
* testsuite/gas/i860/ldst04.s: Delete.
* testsuite/gas/i860/ldst05.d: Delete.
* testsuite/gas/i860/ldst05.s: Delete.
* testsuite/gas/i860/ldst06.d: Delete.
* testsuite/gas/i860/ldst06.s: Delete.
* testsuite/gas/i860/pfam.d: Delete.
* testsuite/gas/i860/pfam.s: Delete.
* testsuite/gas/i860/pfmam.d: Delete.
* testsuite/gas/i860/pfmam.s: Delete.
* testsuite/gas/i860/pfmsm.d: Delete.
* testsuite/gas/i860/pfmsm.s: Delete.
* testsuite/gas/i860/pfsm.d: Delete.
* testsuite/gas/i860/pfsm.s: Delete.
* testsuite/gas/i860/pseudo-ops01.d: Delete.
* testsuite/gas/i860/pseudo-ops01.s: Delete.
* testsuite/gas/i860/regress01.d: Delete.
* testsuite/gas/i860/regress01.s: Delete.
* testsuite/gas/i860/shift.d: Delete.
* testsuite/gas/i860/shift.s: Delete.
* testsuite/gas/i860/simd.d: Delete.
* testsuite/gas/i860/simd.s: Delete.
* testsuite/gas/i860/system.d: Delete.
* testsuite/gas/i860/system.s: Delete.
* testsuite/gas/i860/xp.d: Delete.
* testsuite/gas/i860/xp.s: Delete.
* Makefile.am: Remove i860 and i960 support.
* configure.tgt: Likewise.
* doc/Makefile.am: Likewise.
* doc/all.texi: Likewise.
* testsuite/gas/all/gas.exp
* config/obj-coff.h: Remove i960 support.
* doc/internals.texi: Likewise.
* expr.c: Likewise.
* read.c: Likewise.
* write.c: Likewise.
* write.h: Likewise.
* testsuite/gas/lns/lns.exp: Likewise.
* testsuite/gas/symver/symver.exp: Likewise.
* config/tc-m68k.c: Remove BOUT support.
* config/tc-score.c: Likewise.
* config/tc-score7.c: Likewise.
* config/tc-sparc.c: Likewise.
* symbols.c: Likewise.
* doc/h8.texi: Likewise.
* configure.ac: Remove BOUT and i860 support.
* doc/as.texinfo: Remove BOUT, i860 and i960 support
* Makefile.in: Regenerate.
* config.in: Regenerate.
* configure: Regenerate.
* doc/Makefile.in: Regenerate.
* po/POTFILES.in: Regenerate.
ld/
* emulparams/coff_i860.sh: Delete.
* emulparams/elf32_i860.sh: Delete.
* emulparams/elf32_i960.sh: Delete.
* emulparams/gld960.sh: Delete.
* emulparams/gld960coff.sh: Delete.
* emulparams/lnk960.sh: Delete.
* emultempl/gld960.em: Delete.
* emultempl/gld960c.em: Delete.
* emultempl/lnk960.em: Delete.
* scripttempl/i860coff.sc: Delete.
* scripttempl/i960.sc: Delete.
* ld.texinfo: Remove i960 support.
* Makefile.am: Remove i860 and i960 support.
* configure.tgt: Likewise.
* testsuite/ld-discard/extern.d: Likewise.
* testsuite/ld-discard/start.d: Likewise.
* testsuite/ld-discard/static.d: Likewise.
* testsuite/ld-elf/compressed1d.d: Likewise.
* testsuite/ld-elf/group1.d: Likewise.
* testsuite/ld-elf/group3b.d: Likewise.
* testsuite/ld-elf/group8a.d: Likewise.
* testsuite/ld-elf/group8b.d: Likewise.
* testsuite/ld-elf/group9a.d: Likewise.
* testsuite/ld-elf/group9b.d: Likewise.
* testsuite/ld-elf/linkonce2.d: Likewise.
* testsuite/ld-elf/merge.d: Likewise.
* testsuite/ld-elf/merge2.d: Likewise.
* testsuite/ld-elf/merge3.d: Likewise.
* testsuite/ld-elf/orphan-10.d: Likewise.
* testsuite/ld-elf/orphan-11.d: Likewise.
* testsuite/ld-elf/orphan-12.d: Likewise.
* testsuite/ld-elf/orphan-9.d: Likewise.
* testsuite/ld-elf/orphan-region.d: Likewise.
* testsuite/ld-elf/orphan.d: Likewise.
* testsuite/ld-elf/orphan3.d: Likewise.
* testsuite/ld-elf/pr12851.d: Likewise.
* testsuite/ld-elf/pr12975.d: Likewise.
* testsuite/ld-elf/pr13177.d: Likewise.
* testsuite/ld-elf/pr13195.d: Likewise.
* testsuite/ld-elf/pr17550a.d: Likewise.
* testsuite/ld-elf/pr17550b.d: Likewise.
* testsuite/ld-elf/pr17550c.d: Likewise.
* testsuite/ld-elf/pr17550d.d: Likewise.
* testsuite/ld-elf/pr17615.d: Likewise.
* testsuite/ld-elf/pr20528a.d: Likewise.
* testsuite/ld-elf/pr20528b.d: Likewise.
* testsuite/ld-elf/pr21562a.d: Likewise.
* testsuite/ld-elf/pr21562b.d: Likewise.
* testsuite/ld-elf/pr21562c.d: Likewise.
* testsuite/ld-elf/pr21562d.d: Likewise.
* testsuite/ld-elf/pr21562i.d: Likewise.
* testsuite/ld-elf/pr21562j.d: Likewise.
* testsuite/ld-elf/pr21562k.d: Likewise.
* testsuite/ld-elf/pr21562l.d: Likewise.
* testsuite/ld-elf/pr21562m.d: Likewise.
* testsuite/ld-elf/pr21562n.d: Likewise.
* testsuite/ld-elf/pr22677.d: Likewise.
* testsuite/ld-elf/pr22836-1a.d: Likewise.
* testsuite/ld-elf/pr22836-1b.d: Likewise.
* testsuite/ld-elf/pr349.d: Likewise.
* testsuite/ld-elf/sec-to-seg.exp: Likewise.
* testsuite/ld-elf/sec64k.exp: Likewise.
* testsuite/ld-elf/warn1.d: Likewise.
* testsuite/ld-elf/warn2.d: Likewise.
* testsuite/ld-elf/warn3.d: Likewise.
* testsuite/lib/ld-lib.exp: Likewise.
* Makefile.in: Regenerate.
* po/BLD-POTFILES.in: Regenerate.
242 files changed, 380 insertions, 21807 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 33127be..d396af1 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,33 @@ +2018-04-11 Alan Modra <amodra@gmail.com> + + * aout-adobe.c: Delete. + * bout.c: Delete. + * coff-i860.c: Delete. + * coff-i960.c: Delete. + * cpu-i860.c: Delete. + * cpu-i960.c: Delete. + * elf32-i860.c: Delete. + * elf32-i960.c: Delete. + * hosts/i860mach3.h: Delete. + * Makefile.am: Remove i860, i960, bout, and adobe support. + * archures.c: Remove i860 and i960 support. + * coffcode.h: Likewise. + * reloc.c: Likewise. + * aoutx.h: Comment updates. + * archive.c: Remove BOUT and i960 support. + * bfd.c: Remove BOUT support. + * coffswap.h: Remove i960 support. + * config.bfd: Remove i860, i960 and adobe targets. + * configure.ac: Remove adode, bout, i860, i960, icoff targets. + * targets.c: Likewise. + * ieee.c: Remove i960 support. + * mach-o.c: Remove i860 support. + * Makefile.in: Regenerate. + * bfd-in2.h: Regenerate. + * configure: Regenerate. + * libbfd.h: Regenerate. + * po/SRC-POTFILES.in: Regenerate. + 2018-04-09 Maciej W. Rozycki <macro@mips.com> * elf64-mips.c (mips_elf64_write_rel): Handle a NULL BFD pointer diff --git a/bfd/Makefile.am b/bfd/Makefile.am index f727ebe..a03e2b2 100644 --- a/bfd/Makefile.am +++ b/bfd/Makefile.am @@ -114,8 +114,6 @@ ALL_MACHINES = \ cpu-iamcu.lo \ cpu-l1om.lo \ cpu-k1om.lo \ - cpu-i860.lo \ - cpu-i960.lo \ cpu-ia64.lo \ cpu-ip2k.lo \ cpu-iq2000.lo \ @@ -204,8 +202,6 @@ ALL_MACHINES_CFILES = \ cpu-iamcu.c \ cpu-l1om.c \ cpu-k1om.c \ - cpu-i860.c \ - cpu-i960.c \ cpu-ia64.c \ cpu-ip2k.c \ cpu-iq2000.c \ @@ -271,7 +267,6 @@ ALL_MACHINES_CFILES = \ # The .o files needed by all of the 32 bit vectors that are configured into # target_vector in targets.c if configured with --enable-targets=all. BFD32_BACKENDS = \ - aout-adobe.lo \ aout-arm.lo \ aout-cris.lo \ aout-ns32k.lo \ @@ -280,7 +275,6 @@ BFD32_BACKENDS = \ aout0.lo \ aout32.lo \ armnetbsd.lo \ - bout.lo \ cf-i386lynx.lo \ cf-sparclynx.lo \ coff-apollo.lo \ @@ -290,8 +284,6 @@ BFD32_BACKENDS = \ coff-h8300.lo \ coff-h8500.lo \ coff-i386.lo \ - coff-i860.lo \ - coff-i960.lo \ coff-m68k.lo \ coff-m88k.lo \ coff-mips.lo \ @@ -347,8 +339,6 @@ BFD32_BACKENDS = \ elf32-i370.lo \ elf32-i386.lo \ elfxx-x86.lo \ - elf32-i860.lo \ - elf32-i960.lo \ elf32-ip2k.lo \ elf32-iq2000.lo \ elf32-lm32.lo \ @@ -468,7 +458,6 @@ BFD32_BACKENDS = \ xtensa-modules.lo BFD32_BACKENDS_CFILES = \ - aout-adobe.c \ aout-arm.c \ aout-cris.c \ aout-ns32k.c \ @@ -477,7 +466,6 @@ BFD32_BACKENDS_CFILES = \ aout0.c \ aout32.c \ armnetbsd.c \ - bout.c \ cf-i386lynx.c \ cf-sparclynx.c \ coff-apollo.c \ @@ -487,8 +475,6 @@ BFD32_BACKENDS_CFILES = \ coff-h8300.c \ coff-h8500.c \ coff-i386.c \ - coff-i860.c \ - coff-i960.c \ coff-m68k.c \ coff-m88k.c \ coff-mips.c \ @@ -544,8 +530,6 @@ BFD32_BACKENDS_CFILES = \ elf32-i370.c \ elf32-i386.c \ elfxx-x86.c \ - elf32-i860.c \ - elf32-i960.c \ elf32-ip2k.c \ elf32-iq2000.c \ elf32-lm32.c \ diff --git a/bfd/Makefile.in b/bfd/Makefile.in index 4060823..d63aef9 100644 --- a/bfd/Makefile.in +++ b/bfd/Makefile.in @@ -447,8 +447,6 @@ ALL_MACHINES = \ cpu-iamcu.lo \ cpu-l1om.lo \ cpu-k1om.lo \ - cpu-i860.lo \ - cpu-i960.lo \ cpu-ia64.lo \ cpu-ip2k.lo \ cpu-iq2000.lo \ @@ -537,8 +535,6 @@ ALL_MACHINES_CFILES = \ cpu-iamcu.c \ cpu-l1om.c \ cpu-k1om.c \ - cpu-i860.c \ - cpu-i960.c \ cpu-ia64.c \ cpu-ip2k.c \ cpu-iq2000.c \ @@ -605,7 +601,6 @@ ALL_MACHINES_CFILES = \ # The .o files needed by all of the 32 bit vectors that are configured into # target_vector in targets.c if configured with --enable-targets=all. BFD32_BACKENDS = \ - aout-adobe.lo \ aout-arm.lo \ aout-cris.lo \ aout-ns32k.lo \ @@ -614,7 +609,6 @@ BFD32_BACKENDS = \ aout0.lo \ aout32.lo \ armnetbsd.lo \ - bout.lo \ cf-i386lynx.lo \ cf-sparclynx.lo \ coff-apollo.lo \ @@ -624,8 +618,6 @@ BFD32_BACKENDS = \ coff-h8300.lo \ coff-h8500.lo \ coff-i386.lo \ - coff-i860.lo \ - coff-i960.lo \ coff-m68k.lo \ coff-m88k.lo \ coff-mips.lo \ @@ -681,8 +673,6 @@ BFD32_BACKENDS = \ elf32-i370.lo \ elf32-i386.lo \ elfxx-x86.lo \ - elf32-i860.lo \ - elf32-i960.lo \ elf32-ip2k.lo \ elf32-iq2000.lo \ elf32-lm32.lo \ @@ -802,7 +792,6 @@ BFD32_BACKENDS = \ xtensa-modules.lo BFD32_BACKENDS_CFILES = \ - aout-adobe.c \ aout-arm.c \ aout-cris.c \ aout-ns32k.c \ @@ -811,7 +800,6 @@ BFD32_BACKENDS_CFILES = \ aout0.c \ aout32.c \ armnetbsd.c \ - bout.c \ cf-i386lynx.c \ cf-sparclynx.c \ coff-apollo.c \ @@ -821,8 +809,6 @@ BFD32_BACKENDS_CFILES = \ coff-h8300.c \ coff-h8500.c \ coff-i386.c \ - coff-i860.c \ - coff-i960.c \ coff-m68k.c \ coff-m88k.c \ coff-mips.c \ @@ -878,8 +864,6 @@ BFD32_BACKENDS_CFILES = \ elf32-i370.c \ elf32-i386.c \ elfxx-x86.c \ - elf32-i860.c \ - elf32-i960.c \ elf32-ip2k.c \ elf32-iq2000.c \ elf32-lm32.c \ @@ -1322,7 +1306,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/aix386-core.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/aix5ppc-core.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/aout-adobe.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/aout-arm.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/aout-cris.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/aout-ns32k.Plo@am__quote@ @@ -1339,7 +1322,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/bfdio.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/bfdwin.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/binary.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/bout.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cache.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cf-i386lynx.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cf-sparclynx.Plo@am__quote@ @@ -1353,8 +1335,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-h8300.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-h8500.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-i386.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-i860.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-i960.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-m68k.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-m88k.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/coff-mips.Plo@am__quote@ @@ -1400,8 +1380,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-hppa.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-i370.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-i386.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-i860.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-i960.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-ia64.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-iamcu.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cpu-ip2k.Plo@am__quote@ @@ -1503,8 +1481,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-hppa.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-i370.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-i386.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-i860.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-i960.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-ia64.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-ip2k.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elf32-iq2000.Plo@am__quote@ diff --git a/bfd/aout-adobe.c b/bfd/aout-adobe.c deleted file mode 100644 index 48189d8..0000000 --- a/bfd/aout-adobe.c +++ /dev/null @@ -1,535 +0,0 @@ -/* BFD back-end for a.out.adobe binaries. - Copyright (C) 1990-2018 Free Software Foundation, Inc. - Written by Cygnus Support. Based on bout.c. - - 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" -#include "aout/adobe.h" -#include "aout/stab_gnu.h" -#include "libaout.h" /* BFD a.out internal data structures. */ - -/* Forward decl. */ -extern const bfd_target aout_adobe_vec; - -/* Swaps the information in an executable header taken from a raw byte - stream memory image, into the internal exec_header structure. */ - -static void -aout_adobe_swap_exec_header_in (bfd *abfd, - struct external_exec *bytes, - struct internal_exec *execp) -{ - /* Now fill in fields in the execp, from the bytes in the raw data. */ - execp->a_info = H_GET_32 (abfd, bytes->e_info); - execp->a_text = GET_WORD (abfd, bytes->e_text); - execp->a_data = GET_WORD (abfd, bytes->e_data); - execp->a_bss = GET_WORD (abfd, bytes->e_bss); - execp->a_syms = GET_WORD (abfd, bytes->e_syms); - execp->a_entry = GET_WORD (abfd, bytes->e_entry); - execp->a_trsize = GET_WORD (abfd, bytes->e_trsize); - execp->a_drsize = GET_WORD (abfd, bytes->e_drsize); -} - -/* Swaps the information in an internal exec header structure into the - supplied buffer ready for writing to disk. */ - -static void -aout_adobe_swap_exec_header_out (bfd *abfd, - struct internal_exec *execp, - struct external_exec *bytes) -{ - /* Now fill in fields in the raw data, from the fields in the exec - struct. */ - H_PUT_32 (abfd, execp->a_info , bytes->e_info); - PUT_WORD (abfd, execp->a_text , bytes->e_text); - PUT_WORD (abfd, execp->a_data , bytes->e_data); - PUT_WORD (abfd, execp->a_bss , bytes->e_bss); - PUT_WORD (abfd, execp->a_syms , bytes->e_syms); - PUT_WORD (abfd, execp->a_entry , bytes->e_entry); - PUT_WORD (abfd, execp->a_trsize, bytes->e_trsize); - PUT_WORD (abfd, execp->a_drsize, bytes->e_drsize); -} - -/* Finish up the opening of a b.out file for reading. Fill in all the - fields that are not handled by common code. */ - -static const bfd_target * -aout_adobe_callback (bfd *abfd) -{ - struct internal_exec *execp = exec_hdr (abfd); - asection *sect; - struct external_segdesc ext[1]; - char *section_name; - char try_again[30]; /* Name and number. */ - char *newname; - int trynum; - flagword flags; - - /* Architecture and machine type -- unknown in this format. */ - bfd_set_arch_mach (abfd, bfd_arch_unknown, 0L); - - /* The positions of the string table and symbol table. */ - obj_str_filepos (abfd) = N_STROFF (execp); - obj_sym_filepos (abfd) = N_SYMOFF (execp); - - /* Suck up the section information from the file, one section at a time. */ - for (;;) - { - bfd_size_type amt = sizeof (*ext); - if (bfd_bread ( ext, amt, abfd) != amt) - { - if (bfd_get_error () != bfd_error_system_call) - bfd_set_error (bfd_error_wrong_format); - - return NULL; - } - switch (ext->e_type[0]) - { - case N_TEXT: - section_name = ".text"; - flags = SEC_CODE | SEC_LOAD | SEC_ALLOC | SEC_HAS_CONTENTS; - break; - - case N_DATA: - section_name = ".data"; - flags = SEC_DATA | SEC_LOAD | SEC_ALLOC | SEC_HAS_CONTENTS; - break; - - case N_BSS: - section_name = ".bss"; - flags = SEC_DATA | SEC_HAS_CONTENTS; - break; - - case 0: - goto no_more_sections; - - default: - _bfd_error_handler - /* xgettext:c-format */ - (_("%pB: unknown section type in a.out.adobe file: %x"), - abfd, ext->e_type[0]); - goto no_more_sections; - } - - /* First one is called ".text" or whatever; subsequent ones are - ".text1", ".text2", ... */ - bfd_set_error (bfd_error_no_error); - sect = bfd_make_section_with_flags (abfd, section_name, flags); - trynum = 0; - - while (!sect) - { - if (bfd_get_error () != bfd_error_no_error) - /* Some other error -- slide into the sunset. */ - return NULL; - sprintf (try_again, "%s%d", section_name, ++trynum); - sect = bfd_make_section_with_flags (abfd, try_again, flags); - } - - /* Fix the name, if it is a sprintf'd name. */ - if (sect->name == try_again) - { - amt = strlen (sect->name); - newname = bfd_zalloc (abfd, amt); - if (newname == NULL) - return NULL; - strcpy (newname, sect->name); - sect->name = newname; - } - - /* Assumed big-endian. */ - sect->size = ((ext->e_size[0] << 8) - | ext->e_size[1] << 8 - | ext->e_size[2]); - sect->vma = H_GET_32 (abfd, ext->e_virtbase); - sect->filepos = H_GET_32 (abfd, ext->e_filebase); - /* FIXME XXX alignment? */ - - /* Set relocation information for first section of each type. */ - if (trynum == 0) - switch (ext->e_type[0]) - { - case N_TEXT: - sect->rel_filepos = N_TRELOFF (execp); - sect->reloc_count = execp->a_trsize; - break; - - case N_DATA: - sect->rel_filepos = N_DRELOFF (execp); - sect->reloc_count = execp->a_drsize; - break; - - default: - break; - } - } - no_more_sections: - - adata (abfd).reloc_entry_size = sizeof (struct reloc_std_external); - adata (abfd).symbol_entry_size = sizeof (struct external_nlist); - adata (abfd).page_size = 1; /* Not applicable. */ - adata (abfd).segment_size = 1; /* Not applicable. */ - adata (abfd).exec_bytes_size = EXEC_BYTES_SIZE; - - return abfd->xvec; -} - -static const bfd_target * -aout_adobe_object_p (bfd *abfd) -{ - struct internal_exec anexec; - struct external_exec exec_bytes; - char *targ; - bfd_size_type amt = EXEC_BYTES_SIZE; - - if (bfd_bread (& exec_bytes, amt, abfd) != amt) - { - if (bfd_get_error () != bfd_error_system_call) - bfd_set_error (bfd_error_wrong_format); - return NULL; - } - - anexec.a_info = H_GET_32 (abfd, exec_bytes.e_info); - - /* Normally we just compare for the magic number. - However, a bunch of Adobe tools aren't fixed up yet; they generate - files using ZMAGIC(!). - If the environment variable GNUTARGET is set to "a.out.adobe", we will - take just about any a.out file as an Adobe a.out file. FIXME! */ - - if (N_BADMAG (&anexec)) - { - targ = getenv ("GNUTARGET"); - if (targ && !strcmp (targ, aout_adobe_vec.name)) - /* Just continue anyway, if specifically set to this format. */ - ; - else - { - bfd_set_error (bfd_error_wrong_format); - return NULL; - } - } - - aout_adobe_swap_exec_header_in (abfd, &exec_bytes, &anexec); - return aout_32_some_aout_object_p (abfd, &anexec, aout_adobe_callback); -} - -struct bout_data_struct -{ - struct aoutdata a; - struct internal_exec e; -}; - -static bfd_boolean -aout_adobe_mkobject (bfd *abfd) -{ - struct bout_data_struct *rawptr; - bfd_size_type amt = sizeof (struct bout_data_struct); - - rawptr = bfd_zalloc (abfd, amt); - if (rawptr == NULL) - return FALSE; - - abfd->tdata.bout_data = rawptr; - exec_hdr (abfd) = &rawptr->e; - - adata (abfd).reloc_entry_size = sizeof (struct reloc_std_external); - adata (abfd).symbol_entry_size = sizeof (struct external_nlist); - adata (abfd).page_size = 1; /* Not applicable. */ - adata (abfd).segment_size = 1; /* Not applicable. */ - adata (abfd).exec_bytes_size = EXEC_BYTES_SIZE; - - return TRUE; -} - -static void -aout_adobe_write_section (bfd *abfd ATTRIBUTE_UNUSED, - sec_ptr sect ATTRIBUTE_UNUSED) -{ - /* FIXME XXX. */ -} - -static bfd_boolean -aout_adobe_write_object_contents (bfd *abfd) -{ - struct external_exec swapped_hdr; - static struct external_segdesc sentinel[1]; /* Initialized to zero. */ - asection *sect; - bfd_size_type amt; - - exec_hdr (abfd)->a_info = ZMAGIC; - - /* Calculate text size as total of text sections, etc. */ - exec_hdr (abfd)->a_text = 0; - exec_hdr (abfd)->a_data = 0; - exec_hdr (abfd)->a_bss = 0; - exec_hdr (abfd)->a_trsize = 0; - exec_hdr (abfd)->a_drsize = 0; - - for (sect = abfd->sections; sect; sect = sect->next) - { - if (sect->flags & SEC_CODE) - { - exec_hdr (abfd)->a_text += sect->size; - exec_hdr (abfd)->a_trsize += sect->reloc_count * - sizeof (struct reloc_std_external); - } - else if (sect->flags & SEC_DATA) - { - exec_hdr (abfd)->a_data += sect->size; - exec_hdr (abfd)->a_drsize += sect->reloc_count * - sizeof (struct reloc_std_external); - } - else if (sect->flags & SEC_ALLOC && !(sect->flags & SEC_LOAD)) - exec_hdr (abfd)->a_bss += sect->size; - } - - exec_hdr (abfd)->a_syms = bfd_get_symcount (abfd) - * sizeof (struct external_nlist); - exec_hdr (abfd)->a_entry = bfd_get_start_address (abfd); - - aout_adobe_swap_exec_header_out (abfd, exec_hdr (abfd), &swapped_hdr); - - amt = EXEC_BYTES_SIZE; - if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0 - || bfd_bwrite (& swapped_hdr, amt, abfd) != amt) - return FALSE; - - /* Now write out the section information. Text first, data next, rest - afterward. */ - for (sect = abfd->sections; sect; sect = sect->next) - if (sect->flags & SEC_CODE) - aout_adobe_write_section (abfd, sect); - - for (sect = abfd->sections; sect; sect = sect->next) - if (sect->flags & SEC_DATA) - aout_adobe_write_section (abfd, sect); - - for (sect = abfd->sections; sect; sect = sect->next) - if (!(sect->flags & (SEC_CODE | SEC_DATA))) - aout_adobe_write_section (abfd, sect); - - /* Write final `sentinel` section header (with type of 0). */ - amt = sizeof (*sentinel); - if (bfd_bwrite (sentinel, amt, abfd) != amt) - return FALSE; - - /* Now write out reloc info, followed by syms and strings. */ - if (bfd_get_symcount (abfd) != 0) - { - if (bfd_seek (abfd, (file_ptr) (N_SYMOFF (exec_hdr (abfd))), SEEK_SET) - != 0) - return FALSE; - - if (! aout_32_write_syms (abfd)) - return FALSE; - - if (bfd_seek (abfd, (file_ptr) (N_TRELOFF (exec_hdr (abfd))), SEEK_SET) - != 0) - return FALSE; - - for (sect = abfd->sections; sect; sect = sect->next) - if (sect->flags & SEC_CODE) - if (!aout_32_squirt_out_relocs (abfd, sect)) - return FALSE; - - if (bfd_seek (abfd, (file_ptr) (N_DRELOFF (exec_hdr (abfd))), SEEK_SET) - != 0) - return FALSE; - - for (sect = abfd->sections; sect; sect = sect->next) - if (sect->flags & SEC_DATA) - if (!aout_32_squirt_out_relocs (abfd, sect)) - return FALSE; - } - - return TRUE; -} - -static bfd_boolean -aout_adobe_set_section_contents (bfd *abfd, - asection *section, - const void * location, - file_ptr offset, - bfd_size_type count) -{ - file_ptr section_start; - sec_ptr sect; - - /* Set by bfd.c handler. */ - if (! abfd->output_has_begun) - { - /* Assign file offsets to sections. Text sections are first, and - are contiguous. Then data sections. Everything else at the end. */ - section_start = N_TXTOFF (0); - - for (sect = abfd->sections; sect; sect = sect->next) - { - if (sect->flags & SEC_CODE) - { - sect->filepos = section_start; - /* FIXME: Round to alignment. */ - section_start += sect->size; - } - } - - for (sect = abfd->sections; sect; sect = sect->next) - { - if (sect->flags & SEC_DATA) - { - sect->filepos = section_start; - /* FIXME: Round to alignment. */ - section_start += sect->size; - } - } - - for (sect = abfd->sections; sect; sect = sect->next) - { - if (sect->flags & SEC_HAS_CONTENTS && - !(sect->flags & (SEC_CODE | SEC_DATA))) - { - sect->filepos = section_start; - /* FIXME: Round to alignment. */ - section_start += sect->size; - } - } - } - - /* Regardless, once we know what we're doing, we might as well get - going. */ - if (bfd_seek (abfd, section->filepos + offset, SEEK_SET) != 0) - return FALSE; - - if (count == 0) - return TRUE; - - return bfd_bwrite (location, count, abfd) == count; -} - -static bfd_boolean -aout_adobe_set_arch_mach (bfd *abfd, - enum bfd_architecture arch, - unsigned long machine) -{ - if (! bfd_default_set_arch_mach (abfd, arch, machine)) - return FALSE; - - if (arch == bfd_arch_unknown - || arch == bfd_arch_m68k) - return TRUE; - - return FALSE; -} - -static int -aout_adobe_sizeof_headers (bfd *ignore_abfd ATTRIBUTE_UNUSED, - struct bfd_link_info *info ATTRIBUTE_UNUSED) -{ - return sizeof (struct internal_exec); -} - -/* Build the transfer vector for Adobe A.Out files. */ - -#define aout_32_find_line _bfd_nosymbols_find_line -#define aout_32_get_symbol_version_string _bfd_nosymbols_get_symbol_version_string -#define aout_32_bfd_make_debug_symbol _bfd_nosymbols_bfd_make_debug_symbol -#define aout_32_bfd_reloc_type_lookup _bfd_norelocs_bfd_reloc_type_lookup -#define aout_32_bfd_reloc_name_lookup _bfd_norelocs_bfd_reloc_name_lookup -#define aout_32_close_and_cleanup aout_32_bfd_free_cached_info -#define aout_32_set_arch_mach aout_adobe_set_arch_mach -#define aout_32_set_section_contents aout_adobe_set_section_contents -#define aout_32_sizeof_headers aout_adobe_sizeof_headers -#define aout_32_bfd_get_relocated_section_contents bfd_generic_get_relocated_section_contents -#define aout_32_get_section_contents_in_window _bfd_generic_get_section_contents_in_window -#define aout_32_bfd_relax_section bfd_generic_relax_section -#define aout_32_bfd_gc_sections bfd_generic_gc_sections -#define aout_32_bfd_lookup_section_flags bfd_generic_lookup_section_flags -#define aout_32_bfd_merge_sections bfd_generic_merge_sections -#define aout_32_bfd_is_group_section bfd_generic_is_group_section -#define aout_32_bfd_discard_group bfd_generic_discard_group -#define aout_32_section_already_linked _bfd_generic_section_already_linked -#define aout_32_bfd_define_common_symbol bfd_generic_define_common_symbol -#define aout_32_bfd_define_start_stop bfd_generic_define_start_stop -#define aout_32_bfd_link_hash_table_create _bfd_generic_link_hash_table_create -#define aout_32_bfd_link_add_symbols _bfd_generic_link_add_symbols -#define aout_32_bfd_link_just_syms _bfd_generic_link_just_syms -#define aout_32_bfd_copy_link_hash_symbol_type \ - _bfd_generic_copy_link_hash_symbol_type -#define aout_32_bfd_final_link _bfd_generic_final_link -#define aout_32_bfd_link_split_section _bfd_generic_link_split_section -#define aout_32_bfd_link_check_relocs _bfd_generic_link_check_relocs -#define aout_32_set_reloc _bfd_generic_set_reloc - -const bfd_target aout_adobe_vec = -{ - "a.out.adobe", /* Name. */ - bfd_target_aout_flavour, - BFD_ENDIAN_BIG, /* Data byte order is unknown (big assumed). */ - BFD_ENDIAN_BIG, /* Header byte order is big. */ - (HAS_RELOC | EXEC_P | /* Object flags. */ - HAS_LINENO | HAS_DEBUG | - HAS_SYMS | HAS_LOCALS | WP_TEXT ), - /* section flags */ - (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_CODE | SEC_DATA | SEC_RELOC), - '_', /* Symbol leading char. */ - ' ', /* AR_pad_char. */ - 16, /* AR_max_namelen. */ - 0, /* match priority. */ - - bfd_getb64, bfd_getb_signed_64, bfd_putb64, - bfd_getb32, bfd_getb_signed_32, bfd_putb32, - bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* Data. */ - bfd_getb64, bfd_getb_signed_64, bfd_putb64, - bfd_getb32, bfd_getb_signed_32, bfd_putb32, - bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* Headers. */ - - { /* bfd_check_format. */ - _bfd_dummy_target, - aout_adobe_object_p, - bfd_generic_archive_p, - _bfd_dummy_target - }, - { /* bfd_set_format. */ - _bfd_bool_bfd_false_error, - aout_adobe_mkobject, - _bfd_generic_mkarchive, - _bfd_bool_bfd_false_error - }, - { /* bfd_write_contents. */ - _bfd_bool_bfd_false_error, - aout_adobe_write_object_contents, - _bfd_write_archive_contents, - _bfd_bool_bfd_false_error - }, - - BFD_JUMP_TABLE_GENERIC (aout_32), - BFD_JUMP_TABLE_COPY (_bfd_generic), - BFD_JUMP_TABLE_CORE (_bfd_nocore), - BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_bsd), - BFD_JUMP_TABLE_SYMBOLS (aout_32), - BFD_JUMP_TABLE_RELOCS (aout_32), - BFD_JUMP_TABLE_WRITE (aout_32), - BFD_JUMP_TABLE_LINK (aout_32), - BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), - - NULL, - - NULL -}; diff --git a/bfd/aoutx.h b/bfd/aoutx.h index 525e560..7809fac 100644 --- a/bfd/aoutx.h +++ b/bfd/aoutx.h @@ -33,9 +33,9 @@ DESCRIPTION The support is split into a basic support file @file{aoutx.h} and other files which derive functions from the base. One derivation file is @file{aoutf1.h} (for a.out flavour 1), and - adds to the basic a.out functions support for sun3, sun4, 386 - and 29k a.out files, to create a target jump vector for a - specific target. + adds to the basic a.out functions support for sun3, sun4, and + 386 a.out files, to create a target jump vector for a specific + target. This information is further split out into more specific files for each machine, including @file{sunos.c} for sun3 and sun4, @@ -136,10 +136,9 @@ DESCRIPTION The file @file{aoutx.h} provides for both the @emph{standard} and @emph{extended} forms of a.out relocation records. - The standard records contain only an - address, a symbol index, and a type field. The extended records - (used on 29ks and sparcs) also have a full integer for an - addend. */ + The standard records contain only an address, a symbol index, + and a type field. The extended records also have a full + integer for an addend. */ #ifndef CTOR_TABLE_RELOC_HOWTO #define CTOR_TABLE_RELOC_IDX 2 diff --git a/bfd/archive.c b/bfd/archive.c index d58f172..b949310 100644 --- a/bfd/archive.c +++ b/bfd/archive.c @@ -847,7 +847,6 @@ bfd_generic_archive_p (bfd *abfd) bfd_is_thin_archive (abfd) = (strncmp (armag, ARMAGT, SARMAG) == 0); if (strncmp (armag, ARMAG, SARMAG) != 0 - && strncmp (armag, ARMAGB, SARMAG) != 0 && ! bfd_is_thin_archive (abfd)) { bfd_set_error (bfd_error_wrong_format); @@ -1042,21 +1041,6 @@ do_slurp_coff_armap (bfd *abfd) nsymz = bfd_getb32 (int_buf); stringsize = parsed_size - (4 * nsymz) - 4; - /* ... except that some archive formats are broken, and it may be our - fault - the i960 little endian coff sometimes has big and sometimes - little, because our tools changed. Here's a horrible hack to clean - up the crap. */ - - if (stringsize > 0xfffff - && bfd_get_arch (abfd) == bfd_arch_i960 - && bfd_get_flavour (abfd) == bfd_target_coff_flavour) - { - /* This looks dangerous, let's do it the other way around. */ - nsymz = bfd_getl32 (int_buf); - stringsize = parsed_size - (4 * nsymz) - 4; - swap = bfd_getl32; - } - /* The coff armap must be read sequentially. So we construct a bsd-style one in core all at once, for simplicity. */ diff --git a/bfd/archures.c b/bfd/archures.c index 7327f5f..20868ecd 100644 --- a/bfd/archures.c +++ b/bfd/archures.c @@ -63,8 +63,7 @@ DESCRIPTION Another field indicates which processor within the family is in use. The machine gives a number which distinguishes different versions of the architecture, - containing, for example, 2 and 3 for Intel i960 KA and i960 KB, - and 68020 and 68030 for Motorola 68020 and 68030. + containing, for example, 68020 for Motorola 68020. .enum bfd_architecture .{ @@ -103,23 +102,6 @@ DESCRIPTION .#define bfd_mach_mcf_isa_c_nodiv_mac 30 .#define bfd_mach_mcf_isa_c_nodiv_emac 31 . bfd_arch_vax, {* DEC Vax. *} -. bfd_arch_i960, {* Intel 960. *} -. {* The order of the following is important. -. lower number indicates a machine type that -. only accepts a subset of the instructions -. available to machines with higher numbers. -. The exception is the "ca", which is -. incompatible with all other machines except -. "core". *} -. -.#define bfd_mach_i960_core 1 -.#define bfd_mach_i960_ka_sa 2 -.#define bfd_mach_i960_kb_sb 3 -.#define bfd_mach_i960_mc 4 -.#define bfd_mach_i960_xa 5 -.#define bfd_mach_i960_ca 6 -.#define bfd_mach_i960_jx 7 -.#define bfd_mach_i960_hx 8 . . bfd_arch_or1k, {* OpenRISC 1000. *} .#define bfd_mach_or1k 1 @@ -237,7 +219,6 @@ DESCRIPTION .#define bfd_mach_i386_iamcu_intel_syntax (bfd_mach_i386_iamcu | bfd_mach_i386_intel_syntax) . bfd_arch_we32k, {* AT&T WE32xxx. *} . bfd_arch_tahoe, {* CCI/Harris Tahoe. *} -. bfd_arch_i860, {* Intel 860. *} . bfd_arch_i370, {* IBM 360/370 Mainframes. *} . bfd_arch_romp, {* IBM ROMP PC/RT. *} . bfd_arch_convex, {* Convex. *} @@ -603,8 +584,6 @@ extern const bfd_arch_info_type bfd_hppa_arch; extern const bfd_arch_info_type bfd_i370_arch; extern const bfd_arch_info_type bfd_i386_arch; extern const bfd_arch_info_type bfd_iamcu_arch; -extern const bfd_arch_info_type bfd_i860_arch; -extern const bfd_arch_info_type bfd_i960_arch; extern const bfd_arch_info_type bfd_ia64_arch; extern const bfd_arch_info_type bfd_ip2k_arch; extern const bfd_arch_info_type bfd_iq2000_arch; @@ -698,8 +677,6 @@ static const bfd_arch_info_type * const bfd_archures_list[] = &bfd_i370_arch, &bfd_i386_arch, &bfd_iamcu_arch, - &bfd_i860_arch, - &bfd_i960_arch, &bfd_ia64_arch, &bfd_ip2k_arch, &bfd_iq2000_arch, diff --git a/bfd/bfd-in2.h b/bfd/bfd-in2.h index de5f68d..3f5d38b 100644 --- a/bfd/bfd-in2.h +++ b/bfd/bfd-in2.h @@ -1979,23 +1979,6 @@ enum bfd_architecture #define bfd_mach_mcf_isa_c_nodiv_mac 30 #define bfd_mach_mcf_isa_c_nodiv_emac 31 bfd_arch_vax, /* DEC Vax. */ - bfd_arch_i960, /* Intel 960. */ - /* The order of the following is important. - lower number indicates a machine type that - only accepts a subset of the instructions - available to machines with higher numbers. - The exception is the "ca", which is - incompatible with all other machines except - "core". */ - -#define bfd_mach_i960_core 1 -#define bfd_mach_i960_ka_sa 2 -#define bfd_mach_i960_kb_sb 3 -#define bfd_mach_i960_mc 4 -#define bfd_mach_i960_xa 5 -#define bfd_mach_i960_ca 6 -#define bfd_mach_i960_jx 7 -#define bfd_mach_i960_hx 8 bfd_arch_or1k, /* OpenRISC 1000. */ #define bfd_mach_or1k 1 @@ -2113,7 +2096,6 @@ enum bfd_architecture #define bfd_mach_i386_iamcu_intel_syntax (bfd_mach_i386_iamcu | bfd_mach_i386_intel_syntax) bfd_arch_we32k, /* AT&T WE32xxx. */ bfd_arch_tahoe, /* CCI/Harris Tahoe. */ - bfd_arch_i860, /* Intel 860. */ bfd_arch_i370, /* IBM 360/370 Mainframes. */ bfd_arch_romp, /* IBM ROMP PC/RT. */ bfd_arch_convex, /* Convex. */ @@ -2506,10 +2488,9 @@ typedef enum bfd_reloc_status /* The symbol to relocate against was undefined. */ bfd_reloc_undefined, - /* The relocation was performed, but may not be ok - presently - generated only when linking i960 coff files with i960 b.out - symbols. If this type is returned, the error_message argument - to bfd_perform_relocation will be set. */ + /* The relocation was performed, but may not be ok. If this type is + returned, the error_message argument to bfd_perform_relocation + will be set. */ bfd_reloc_dangerous } bfd_reloc_status_type; @@ -2589,8 +2570,7 @@ struct reloc_howto_struct /* If this field is non null, then the supplied function is called rather than the normal function. This allows really - strange relocation methods to be accommodated (e.g., i960 callj - instructions). */ + strange relocation methods to be accommodated. */ bfd_reloc_status_type (*special_function) (bfd *, arelent *, struct bfd_symbol *, void *, asection *, bfd *, char **); @@ -2715,9 +2695,7 @@ enum bfd_reloc_code_real { /* PC-relative relocations. Sometimes these are relative to the address of the relocation itself; sometimes they are relative to the start of -the section containing the relocation. It depends on the specific target. - -The 24-bit relocation is used in some Intel 960 configurations. */ +the section containing the relocation. It depends on the specific target. */ BFD_RELOC_64_PCREL, BFD_RELOC_32_PCREL, BFD_RELOC_24_PCREL, @@ -2809,9 +2787,6 @@ decided relatively late. */ BFD_RELOC_GPREL16, BFD_RELOC_GPREL32, -/* Reloc types used for i960/b.out. */ - BFD_RELOC_I960_CALLJ, - /* SPARC ELF relocations. There is probably some overlap with other relocation types already defined. */ BFD_RELOC_NONE, @@ -5435,40 +5410,6 @@ a matching LO8XG part. */ BFD_RELOC_CRIS_DTPMOD, BFD_RELOC_CRIS_32_IE, -/* Intel i860 Relocations. */ - BFD_RELOC_860_COPY, - BFD_RELOC_860_GLOB_DAT, - BFD_RELOC_860_JUMP_SLOT, - BFD_RELOC_860_RELATIVE, - BFD_RELOC_860_PC26, - BFD_RELOC_860_PLT26, - BFD_RELOC_860_PC16, - BFD_RELOC_860_LOW0, - BFD_RELOC_860_SPLIT0, - BFD_RELOC_860_LOW1, - BFD_RELOC_860_SPLIT1, - BFD_RELOC_860_LOW2, - BFD_RELOC_860_SPLIT2, - BFD_RELOC_860_LOW3, - BFD_RELOC_860_LOGOT0, - BFD_RELOC_860_SPGOT0, - BFD_RELOC_860_LOGOT1, - BFD_RELOC_860_SPGOT1, - BFD_RELOC_860_LOGOTOFF0, - BFD_RELOC_860_SPGOTOFF0, - BFD_RELOC_860_LOGOTOFF1, - BFD_RELOC_860_SPGOTOFF1, - BFD_RELOC_860_LOGOTOFF2, - BFD_RELOC_860_LOGOTOFF3, - BFD_RELOC_860_LOPC, - BFD_RELOC_860_HIGHADJ, - BFD_RELOC_860_HAGOT, - BFD_RELOC_860_HAGOTOFF, - BFD_RELOC_860_HAPC, - BFD_RELOC_860_HIGH, - BFD_RELOC_860_HIGOT, - BFD_RELOC_860_HIGOTOFF, - /* OpenRISC 1000 Relocations. */ BFD_RELOC_OR1K_REL_26, BFD_RELOC_OR1K_GOTPC_HI16, @@ -7076,7 +7017,6 @@ struct bfd struct tekhex_data_struct *tekhex_data; struct elf_obj_tdata *elf_obj_data; struct nlm_obj_tdata *nlm_obj_data; - struct bout_data_struct *bout_data; struct mmo_data_struct *mmo_data; struct sun_core_struct *sun_core_data; struct sco5_core_struct *sco5_core_data; @@ -318,7 +318,6 @@ CODE_FRAGMENT . struct tekhex_data_struct *tekhex_data; . struct elf_obj_tdata *elf_obj_data; . struct nlm_obj_tdata *nlm_obj_data; -. struct bout_data_struct *bout_data; . struct mmo_data_struct *mmo_data; . struct sun_core_struct *sun_core_data; . struct sco5_core_struct *sco5_core_data; diff --git a/bfd/bout.c b/bfd/bout.c deleted file mode 100644 index c766633..0000000 --- a/bfd/bout.c +++ /dev/null @@ -1,1508 +0,0 @@ -/* BFD back-end for Intel 960 b.out binaries. - Copyright (C) 1990-2018 Free Software Foundation, Inc. - Written by Cygnus Support. - - 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" -#include "bfdlink.h" -#include "genlink.h" -#include "bout.h" -#include "libiberty.h" - -#include "aout/stab_gnu.h" -#include "libaout.h" /* BFD a.out internal data structures. */ - -#define ABS32CODE 0 -#define ABS32CODE_SHRUNK 1 -#define PCREL24 2 -#define CALLJ 3 -#define ABS32 4 -#define PCREL13 5 -#define ABS32_MAYBE_RELAXABLE 1 -#define ABS32_WAS_RELAXABLE 2 - -#define ALIGNER 10 -#define ALIGNDONE 11 - -static reloc_howto_type howto_reloc_callj = - HOWTO (CALLJ, 0, 2, 24, TRUE, 0, complain_overflow_signed, 0,"callj", TRUE, 0x00ffffff, 0x00ffffff,FALSE); -static reloc_howto_type howto_reloc_abs32 = - HOWTO (ABS32, 0, 2, 32, FALSE, 0, complain_overflow_bitfield,0,"abs32", TRUE, 0xffffffff,0xffffffff,FALSE); -static reloc_howto_type howto_reloc_pcrel24 = - HOWTO (PCREL24, 0, 2, 24, TRUE, 0, complain_overflow_signed,0,"pcrel24", TRUE, 0x00ffffff,0x00ffffff,FALSE); -static reloc_howto_type howto_reloc_pcrel13 = - HOWTO (PCREL13, 0, 2, 13, TRUE, 0, complain_overflow_signed,0,"pcrel13", TRUE, 0x00001fff,0x00001fff,FALSE); -static reloc_howto_type howto_reloc_abs32codeshrunk = - HOWTO (ABS32CODE_SHRUNK, 0, 2, 24, TRUE, 0, complain_overflow_signed, 0,"callx->callj", TRUE, 0x00ffffff, 0x00ffffff,FALSE); -static reloc_howto_type howto_reloc_abs32code = - HOWTO (ABS32CODE, 0, 2, 32, FALSE, 0, complain_overflow_bitfield,0,"callx", TRUE, 0xffffffff,0xffffffff,FALSE); - -static reloc_howto_type howto_align_table[] = -{ - HOWTO (ALIGNER, 0, 0x1, 0, FALSE, 0, complain_overflow_dont, 0, "align16", FALSE, 0, 0, FALSE), - HOWTO (ALIGNER, 0, 0x3, 0, FALSE, 0, complain_overflow_dont, 0, "align32", FALSE, 0, 0, FALSE), - HOWTO (ALIGNER, 0, 0x7, 0, FALSE, 0, complain_overflow_dont, 0, "align64", FALSE, 0, 0, FALSE), - HOWTO (ALIGNER, 0, 0xf, 0, FALSE, 0, complain_overflow_dont, 0, "align128", FALSE, 0, 0, FALSE), -}; - -static reloc_howto_type howto_done_align_table[] = -{ - HOWTO (ALIGNDONE, 0x1, 0x1, 0, FALSE, 0, complain_overflow_dont, 0, "donealign16", FALSE, 0, 0, FALSE), - HOWTO (ALIGNDONE, 0x3, 0x3, 0, FALSE, 0, complain_overflow_dont, 0, "donealign32", FALSE, 0, 0, FALSE), - HOWTO (ALIGNDONE, 0x7, 0x7, 0, FALSE, 0, complain_overflow_dont, 0, "donealign64", FALSE, 0, 0, FALSE), - HOWTO (ALIGNDONE, 0xf, 0xf, 0, FALSE, 0, complain_overflow_dont, 0, "donealign128", FALSE, 0, 0, FALSE), -}; - -/* Swaps the information in an executable header taken from a raw byte - stream memory image, into the internal exec_header structure. */ - -static void -bout_swap_exec_header_in (bfd *abfd, - struct external_exec *bytes, - struct internal_exec *execp) -{ - /* Now fill in fields in the execp, from the bytes in the raw data. */ - execp->a_info = H_GET_32 (abfd, bytes->e_info); - execp->a_text = GET_WORD (abfd, bytes->e_text); - execp->a_data = GET_WORD (abfd, bytes->e_data); - execp->a_bss = GET_WORD (abfd, bytes->e_bss); - execp->a_syms = GET_WORD (abfd, bytes->e_syms); - execp->a_entry = GET_WORD (abfd, bytes->e_entry); - execp->a_trsize = GET_WORD (abfd, bytes->e_trsize); - execp->a_drsize = GET_WORD (abfd, bytes->e_drsize); - execp->a_tload = GET_WORD (abfd, bytes->e_tload); - execp->a_dload = GET_WORD (abfd, bytes->e_dload); - execp->a_talign = bytes->e_talign[0]; - execp->a_dalign = bytes->e_dalign[0]; - execp->a_balign = bytes->e_balign[0]; - execp->a_relaxable = bytes->e_relaxable[0]; -} - -/* Swaps the information in an internal exec header structure into the - supplied buffer ready for writing to disk. */ - -static void -bout_swap_exec_header_out (bfd *abfd, - struct internal_exec *execp, - struct external_exec *bytes) -{ - /* Now fill in fields in the raw data, from the fields in the exec struct. */ - H_PUT_32 (abfd, execp->a_info , bytes->e_info); - PUT_WORD (abfd, execp->a_text , bytes->e_text); - PUT_WORD (abfd, execp->a_data , bytes->e_data); - PUT_WORD (abfd, execp->a_bss , bytes->e_bss); - PUT_WORD (abfd, execp->a_syms , bytes->e_syms); - PUT_WORD (abfd, execp->a_entry , bytes->e_entry); - PUT_WORD (abfd, execp->a_trsize, bytes->e_trsize); - PUT_WORD (abfd, execp->a_drsize, bytes->e_drsize); - PUT_WORD (abfd, execp->a_tload , bytes->e_tload); - PUT_WORD (abfd, execp->a_dload , bytes->e_dload); - bytes->e_talign[0] = execp->a_talign; - bytes->e_dalign[0] = execp->a_dalign; - bytes->e_balign[0] = execp->a_balign; - bytes->e_relaxable[0] = execp->a_relaxable; -} - -/* Finish up the opening of a b.out file for reading. Fill in all the - fields that are not handled by common code. */ - -static const bfd_target * -b_out_callback (bfd *abfd) -{ - struct internal_exec *execp = exec_hdr (abfd); - unsigned long bss_start; - - /* Architecture and machine type. */ - bfd_set_arch_mach (abfd, - bfd_arch_i960, /* B.out only used on i960. */ - bfd_mach_i960_core /* Default. */ - ); - - /* The positions of the string table and symbol table. */ - obj_str_filepos (abfd) = N_STROFF (execp); - obj_sym_filepos (abfd) = N_SYMOFF (execp); - - /* The alignments of the sections. */ - obj_textsec (abfd)->alignment_power = execp->a_talign; - obj_datasec (abfd)->alignment_power = execp->a_dalign; - obj_bsssec (abfd)->alignment_power = execp->a_balign; - - /* The starting addresses of the sections. */ - obj_textsec (abfd)->vma = execp->a_tload; - obj_datasec (abfd)->vma = execp->a_dload; - - obj_textsec (abfd)->lma = obj_textsec (abfd)->vma; - obj_datasec (abfd)->lma = obj_datasec (abfd)->vma; - - /* And reload the sizes, since the aout module zaps them. */ - obj_textsec (abfd)->size = execp->a_text; - - bss_start = execp->a_dload + execp->a_data; /* BSS = end of data section. */ - obj_bsssec (abfd)->vma = align_power (bss_start, execp->a_balign); - - obj_bsssec (abfd)->lma = obj_bsssec (abfd)->vma; - - /* The file positions of the sections. */ - obj_textsec (abfd)->filepos = N_TXTOFF (execp); - obj_datasec (abfd)->filepos = N_DATOFF (execp); - - /* The file positions of the relocation info. */ - obj_textsec (abfd)->rel_filepos = N_TROFF (execp); - obj_datasec (abfd)->rel_filepos = N_DROFF (execp); - - adata (abfd).page_size = 1; /* Not applicable. */ - adata (abfd).segment_size = 1; /* Not applicable. */ - adata (abfd).exec_bytes_size = EXEC_BYTES_SIZE; - - if (execp->a_relaxable) - abfd->flags |= BFD_IS_RELAXABLE; - return abfd->xvec; -} - -static const bfd_target * -b_out_object_p (bfd *abfd) -{ - struct internal_exec anexec; - struct external_exec exec_bytes; - bfd_size_type amt = EXEC_BYTES_SIZE; - - if (bfd_bread ((void *) &exec_bytes, amt, abfd) != amt) - { - if (bfd_get_error () != bfd_error_system_call) - bfd_set_error (bfd_error_wrong_format); - return 0; - } - - anexec.a_info = H_GET_32 (abfd, exec_bytes.e_info); - - if (N_BADMAG (&anexec)) - { - bfd_set_error (bfd_error_wrong_format); - return 0; - } - - bout_swap_exec_header_in (abfd, &exec_bytes, &anexec); - return aout_32_some_aout_object_p (abfd, &anexec, b_out_callback); -} - -struct bout_data_struct - { - struct aoutdata a; - struct internal_exec e; - }; - -static bfd_boolean -b_out_mkobject (bfd *abfd) -{ - struct bout_data_struct *rawptr; - bfd_size_type amt = sizeof (struct bout_data_struct); - - rawptr = bfd_zalloc (abfd, amt); - if (rawptr == NULL) - return FALSE; - - abfd->tdata.bout_data = rawptr; - exec_hdr (abfd) = &rawptr->e; - - obj_textsec (abfd) = NULL; - obj_datasec (abfd) = NULL; - obj_bsssec (abfd) = NULL; - - return TRUE; -} - -static int -b_out_symbol_cmp (const void * a_ptr, const void * b_ptr) -{ - struct aout_symbol ** a = (struct aout_symbol **) a_ptr; - struct aout_symbol ** b = (struct aout_symbol **) b_ptr; - asection *sec; - bfd_vma av, bv; - - /* Primary key is address. */ - sec = bfd_get_section (&(*a)->symbol); - av = sec->output_section->vma + sec->output_offset + (*a)->symbol.value; - sec = bfd_get_section (&(*b)->symbol); - bv = sec->output_section->vma + sec->output_offset + (*b)->symbol.value; - - if (av < bv) - return -1; - if (av > bv) - return 1; - - /* Secondary key puts CALLNAME syms last and BALNAME syms first, - so that they have the best chance of being contiguous. */ - if (IS_BALNAME ((*a)->other) || IS_CALLNAME ((*b)->other)) - return -1; - if (IS_CALLNAME ((*a)->other) || IS_BALNAME ((*b)->other)) - return 1; - - return 0; -} - -static bfd_boolean -b_out_squirt_out_relocs (bfd *abfd, asection *section) -{ - arelent **generic; - int r_extern = 0; - int r_idx; - int incode_mask; - int len_1; - unsigned int count = section->reloc_count; - struct relocation_info *native, *natptr; - bfd_size_type natsize; - int extern_mask, pcrel_mask, len_2, callj_mask; - - if (count == 0) - return TRUE; - - generic = section->orelocation; - natsize = (bfd_size_type) count * sizeof (struct relocation_info); - native = bfd_malloc (natsize); - if (!native && natsize != 0) - return FALSE; - - if (bfd_header_big_endian (abfd)) - { - /* Big-endian bit field allocation order. */ - pcrel_mask = 0x80; - extern_mask = 0x10; - len_2 = 0x40; - len_1 = 0x20; - callj_mask = 0x02; - incode_mask = 0x08; - } - else - { - /* Little-endian bit field allocation order. */ - pcrel_mask = 0x01; - extern_mask = 0x08; - len_2 = 0x04; - len_1 = 0x02; - callj_mask = 0x40; - incode_mask = 0x10; - } - - for (natptr = native; count > 0; --count, ++natptr, ++generic) - { - arelent *g = *generic; - unsigned char *raw = (unsigned char *) natptr; - asymbol *sym = *(g->sym_ptr_ptr); - asection *output_section = sym->section->output_section; - - H_PUT_32 (abfd, g->address, raw); - /* Find a type in the output format which matches the input howto - - at the moment we assume input format == output format FIXME!! */ - r_idx = 0; - /* FIXME: Need callj stuff here, and to check the howto entries to - be sure they are real for this architecture. */ - if (g->howto== &howto_reloc_callj) - raw[7] = callj_mask + pcrel_mask + len_2; - else if (g->howto == &howto_reloc_pcrel24) - raw[7] = pcrel_mask + len_2; - else if (g->howto == &howto_reloc_pcrel13) - raw[7] = pcrel_mask + len_1; - else if (g->howto == &howto_reloc_abs32code) - raw[7] = len_2 + incode_mask; - else if (g->howto >= howto_align_table - && g->howto <= (howto_align_table + ARRAY_SIZE (howto_align_table) - 1)) - { - /* symnum == -2; extern_mask not set, pcrel_mask set. */ - r_idx = -2; - r_extern = 0; - raw[7] = (pcrel_mask - | ((g->howto - howto_align_table) << 1)); - } - else - raw[7] = len_2; - - if (r_idx != 0) - /* Already mucked with r_extern, r_idx. */; - else if (bfd_is_com_section (output_section) - || bfd_is_abs_section (output_section) - || bfd_is_und_section (output_section)) - { - if (bfd_abs_section_ptr->symbol == sym) - { - /* Whoops, looked like an abs symbol, but is really an offset - from the abs section. */ - r_idx = 0; - r_extern = 0; - } - else - { - /* Fill in symbol. */ - r_extern = 1; - r_idx = (*g->sym_ptr_ptr)->udata.i; - } - } - else - { - /* Just an ordinary section. */ - r_extern = 0; - r_idx = output_section->target_index; - } - - if (bfd_header_big_endian (abfd)) - { - raw[4] = (unsigned char) (r_idx >> 16); - raw[5] = (unsigned char) (r_idx >> 8); - raw[6] = (unsigned char) (r_idx ); - } - else - { - raw[6] = (unsigned char) (r_idx >> 16); - raw[5] = (unsigned char) (r_idx>> 8); - raw[4] = (unsigned char) (r_idx ); - } - - if (r_extern) - raw[7] |= extern_mask; - } - - if (bfd_bwrite ((void *) native, natsize, abfd) != natsize) - { - free (native); - return FALSE; - } - - free (native); - - return TRUE; -} - -static bfd_boolean -b_out_write_object_contents (bfd *abfd) -{ - struct external_exec swapped_hdr; - bfd_size_type amt; - - if (! aout_32_make_sections (abfd)) - return FALSE; - - exec_hdr (abfd)->a_info = BMAGIC; - - exec_hdr (abfd)->a_text = obj_textsec (abfd)->size; - exec_hdr (abfd)->a_data = obj_datasec (abfd)->size; - exec_hdr (abfd)->a_bss = obj_bsssec (abfd)->size; - exec_hdr (abfd)->a_syms = bfd_get_symcount (abfd) * 12; - exec_hdr (abfd)->a_entry = bfd_get_start_address (abfd); - exec_hdr (abfd)->a_trsize = (obj_textsec (abfd)->reloc_count) * 8; - exec_hdr (abfd)->a_drsize = (obj_datasec (abfd)->reloc_count) * 8; - - exec_hdr (abfd)->a_talign = obj_textsec (abfd)->alignment_power; - exec_hdr (abfd)->a_dalign = obj_datasec (abfd)->alignment_power; - exec_hdr (abfd)->a_balign = obj_bsssec (abfd)->alignment_power; - - exec_hdr (abfd)->a_tload = obj_textsec (abfd)->vma; - exec_hdr (abfd)->a_dload = obj_datasec (abfd)->vma; - - bout_swap_exec_header_out (abfd, exec_hdr (abfd), &swapped_hdr); - - amt = EXEC_BYTES_SIZE; - if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0 - || bfd_bwrite ((void *) &swapped_hdr, amt, abfd) != amt) - return FALSE; - - /* Now write out reloc info, followed by syms and strings */ - if (bfd_get_symcount (abfd) != 0) - { - /* Make sure {CALL,BAL}NAME symbols remain adjacent on output - by sorting. This is complicated by the fact that stabs are - also ordered. Solve this by shifting all stabs to the end - in order, then sorting the rest. */ - - asymbol **outsyms, **p, **q; - - outsyms = bfd_get_outsymbols (abfd); - p = outsyms + bfd_get_symcount (abfd); - - for (q = p--; p >= outsyms; p--) - { - if ((*p)->flags & BSF_DEBUGGING) - { - asymbol *t = *--q; - *q = *p; - *p = t; - } - } - - if (q > outsyms) - qsort (outsyms, (size_t) (q - outsyms), sizeof (asymbol*), - b_out_symbol_cmp); - - /* Back to your regularly scheduled program. */ - if (bfd_seek (abfd, (file_ptr) (N_SYMOFF (exec_hdr (abfd))), SEEK_SET) - != 0) - return FALSE; - - if (! aout_32_write_syms (abfd)) - return FALSE; - - if (bfd_seek (abfd, (file_ptr) (N_TROFF (exec_hdr (abfd))), SEEK_SET) - != 0) - return FALSE; - - if (!b_out_squirt_out_relocs (abfd, obj_textsec (abfd))) - return FALSE; - if (bfd_seek (abfd, (file_ptr) (N_DROFF (exec_hdr (abfd))), SEEK_SET) - != 0) - return FALSE; - - if (!b_out_squirt_out_relocs (abfd, obj_datasec (abfd))) - return FALSE; - } - return TRUE; -} - -/* Some reloc hackery. */ - -#define CALLS 0x66003800 /* Template for 'calls' instruction */ -#define BAL 0x0b000000 /* Template for 'bal' instruction */ -#define BAL_MASK 0x00ffffff -#define BALX 0x85f00000 /* Template for 'balx' instruction */ -#define BALX_MASK 0x0007ffff -#define CALL 0x09000000 -#define PCREL13_MASK 0x1fff - -#define output_addr(sec) ((sec)->output_offset+(sec)->output_section->vma) - -static bfd_vma -get_value (arelent *reloc, - struct bfd_link_info *link_info, - asection *input_section) -{ - bfd_vma value; - asymbol *symbol = *(reloc->sym_ptr_ptr); - - /* A symbol holds a pointer to a section, and an offset from the - base of the section. To relocate, we find where the section will - live in the output and add that in. */ - if (bfd_is_und_section (symbol->section)) - { - struct bfd_link_hash_entry *h; - - /* The symbol is undefined in this BFD. Look it up in the - global linker hash table. FIXME: This should be changed when - we convert b.out to use a specific final_link function and - change the interface to bfd_relax_section to not require the - generic symbols. */ - h = bfd_wrapped_link_hash_lookup (input_section->owner, link_info, - bfd_asymbol_name (symbol), - FALSE, FALSE, TRUE); - if (h != (struct bfd_link_hash_entry *) NULL - && (h->type == bfd_link_hash_defined - || h->type == bfd_link_hash_defweak)) - value = h->u.def.value + output_addr (h->u.def.section); - else if (h != (struct bfd_link_hash_entry *) NULL - && h->type == bfd_link_hash_common) - value = h->u.c.size; - else - { - (*link_info->callbacks->undefined_symbol) - (link_info, bfd_asymbol_name (symbol), - input_section->owner, input_section, reloc->address, TRUE); - value = 0; - } - } - else - value = symbol->value + output_addr (symbol->section); - - /* Add the value contained in the relocation. */ - value += reloc->addend; - - return value; -} - -/* Magic to turn callx into calljx. */ - -static bfd_reloc_status_type -calljx_callback (bfd *abfd, - struct bfd_link_info *link_info, - arelent *reloc_entry, - void * src, - void * dst, - asection *input_section) -{ - int word = bfd_get_32 (abfd, src); - asymbol *symbol_in = *(reloc_entry->sym_ptr_ptr); - aout_symbol_type *symbol = aout_symbol (symbol_in); - bfd_vma value; - - value = get_value (reloc_entry, link_info, input_section); - - if (IS_CALLNAME (symbol->other)) - { - aout_symbol_type *balsym = symbol+1; - int inst = bfd_get_32 (abfd, (bfd_byte *) src-4); - - /* The next symbol should be an N_BALNAME. */ - BFD_ASSERT (IS_BALNAME (balsym->other)); - inst &= BALX_MASK; - inst |= BALX; - bfd_put_32 (abfd, (bfd_vma) inst, (bfd_byte *) dst-4); - symbol = balsym; - value = (symbol->symbol.value - + output_addr (symbol->symbol.section)); - } - - word += value + reloc_entry->addend; - - bfd_put_32 (abfd, (bfd_vma) word, dst); - return bfd_reloc_ok; -} - -/* Magic to turn call into callj. */ - -static bfd_reloc_status_type -callj_callback (bfd *abfd, - struct bfd_link_info *link_info, - arelent *reloc_entry, - void * data, - unsigned int srcidx, - unsigned int dstidx, - asection *input_section, - bfd_boolean shrinking) -{ - int word = bfd_get_32 (abfd, (bfd_byte *) data + srcidx); - asymbol *symbol_in = *(reloc_entry->sym_ptr_ptr); - aout_symbol_type *symbol = aout_symbol (symbol_in); - bfd_vma value; - - value = get_value (reloc_entry, link_info, input_section); - - if (IS_OTHER (symbol->other)) - /* Call to a system procedure - replace code with system - procedure number. */ - word = CALLS | (symbol->other - 1); - - else if (IS_CALLNAME (symbol->other)) - { - aout_symbol_type *balsym = symbol+1; - - /* The next symbol should be an N_BALNAME. */ - BFD_ASSERT (IS_BALNAME (balsym->other)); - - /* We are calling a leaf, so replace the call instruction with a - bal. */ - word = BAL | ((word - + output_addr (balsym->symbol.section) - + balsym->symbol.value + reloc_entry->addend - - dstidx - - output_addr (input_section)) - & BAL_MASK); - } - else if ((symbol->symbol.flags & BSF_SECTION_SYM) != 0) - { - /* A callj against a symbol in the same section is a fully - resolved relative call. We don't need to do anything here. - If the symbol is not in the same section, I'm not sure what - to do; fortunately, this case will probably never arise. */ - BFD_ASSERT (! shrinking); - BFD_ASSERT (symbol->symbol.section == input_section); - } - else - word = CALL | (((word & BAL_MASK) - + value - + reloc_entry->addend - - (shrinking ? dstidx : 0) - - output_addr (input_section)) - & BAL_MASK); - - bfd_put_32 (abfd, (bfd_vma) word, (bfd_byte *) data + dstidx); - return bfd_reloc_ok; -} - -static reloc_howto_type * -b_out_bfd_reloc_type_lookup (bfd *abfd ATTRIBUTE_UNUSED, - bfd_reloc_code_real_type code) -{ - switch (code) - { - default: - return 0; - case BFD_RELOC_I960_CALLJ: - return &howto_reloc_callj; - case BFD_RELOC_32: - case BFD_RELOC_CTOR: - return &howto_reloc_abs32; - case BFD_RELOC_24_PCREL: - return &howto_reloc_pcrel24; - } -} - -static reloc_howto_type * -b_out_bfd_reloc_name_lookup (bfd *abfd ATTRIBUTE_UNUSED, - const char *r_name) -{ - if (strcasecmp (howto_reloc_callj.name, r_name) == 0) - return &howto_reloc_callj; - if (strcasecmp (howto_reloc_abs32.name, r_name) == 0) - return &howto_reloc_abs32; - if (strcasecmp (howto_reloc_pcrel24.name, r_name) == 0) - return &howto_reloc_pcrel24; - - return NULL; -} - -/* Allocate enough room for all the reloc entries, plus pointers to them all. */ - -static bfd_boolean -b_out_slurp_reloc_table (bfd *abfd, sec_ptr asect, asymbol **symbols) -{ - struct relocation_info *rptr; - unsigned int counter; - arelent *cache_ptr; - int extern_mask, pcrel_mask, callj_mask, length_shift; - int incode_mask; - int size_mask; - bfd_vma prev_addr = 0; - unsigned int count; - bfd_size_type reloc_size, amt; - struct relocation_info *relocs; - arelent *reloc_cache; - - if (asect->relocation) - return TRUE; - - if (!aout_32_slurp_symbol_table (abfd)) - return FALSE; - - if (asect == obj_datasec (abfd)) - reloc_size = exec_hdr (abfd)->a_drsize; - else if (asect == obj_textsec (abfd)) - reloc_size = exec_hdr (abfd)->a_trsize; - else if (asect == obj_bsssec (abfd)) - reloc_size = 0; - else - { - bfd_set_error (bfd_error_invalid_operation); - return FALSE; - } - - if (bfd_seek (abfd, asect->rel_filepos, SEEK_SET) != 0) - return FALSE; - count = reloc_size / sizeof (struct relocation_info); - - relocs = bfd_malloc (reloc_size); - if (!relocs && reloc_size != 0) - return FALSE; - - amt = ((bfd_size_type) count + 1) * sizeof (arelent); - reloc_cache = bfd_malloc (amt); - if (!reloc_cache) - { - if (relocs != NULL) - free (relocs); - return FALSE; - } - - if (bfd_bread ((void *) relocs, reloc_size, abfd) != reloc_size) - { - free (reloc_cache); - if (relocs != NULL) - free (relocs); - return FALSE; - } - - if (bfd_header_big_endian (abfd)) - { - /* Big-endian bit field allocation order. */ - pcrel_mask = 0x80; - extern_mask = 0x10; - incode_mask = 0x08; - callj_mask = 0x02; - size_mask = 0x20; - length_shift = 5; - } - else - { - /* Little-endian bit field allocation order. */ - pcrel_mask = 0x01; - extern_mask = 0x08; - incode_mask = 0x10; - callj_mask = 0x40; - size_mask = 0x02; - length_shift = 1; - } - - for (rptr = relocs, cache_ptr = reloc_cache, counter = 0; - counter < count; - counter++, rptr++, cache_ptr++) - { - unsigned char *raw = (unsigned char *)rptr; - unsigned int symnum; - - cache_ptr->address = H_GET_32 (abfd, raw + 0); - cache_ptr->howto = 0; - - if (bfd_header_big_endian (abfd)) - symnum = (raw[4] << 16) | (raw[5] << 8) | raw[6]; - else - symnum = (raw[6] << 16) | (raw[5] << 8) | raw[4]; - - if (raw[7] & extern_mask) - { - /* If this is set then the r_index is an index into the symbol table; - if the bit is not set then r_index contains a section map. - We either fill in the sym entry with a pointer to the symbol, - or point to the correct section. */ - cache_ptr->sym_ptr_ptr = symbols + symnum; - cache_ptr->addend = 0; - } - else - { - /* In a.out symbols are relative to the beginning of the - file rather than sections ? - (look in translate_from_native_sym_flags) - The reloc entry addend has added to it the offset into the - file of the data, so subtract the base to make the reloc - section relative. */ - int s; - - /* Sign-extend symnum from 24 bits to whatever host uses. */ - s = symnum; - if (s & (1 << 23)) - s |= (~0U) << 24; - - cache_ptr->sym_ptr_ptr = (asymbol **)NULL; - switch (s) - { - case N_TEXT: - case N_TEXT | N_EXT: - cache_ptr->sym_ptr_ptr = obj_textsec (abfd)->symbol_ptr_ptr; - cache_ptr->addend = - obj_textsec (abfd)->vma; - break; - case N_DATA: - case N_DATA | N_EXT: - cache_ptr->sym_ptr_ptr = obj_datasec (abfd)->symbol_ptr_ptr; - cache_ptr->addend = - obj_datasec (abfd)->vma; - break; - case N_BSS: - case N_BSS | N_EXT: - cache_ptr->sym_ptr_ptr = obj_bsssec (abfd)->symbol_ptr_ptr; - cache_ptr->addend = - obj_bsssec (abfd)->vma; - break; - case N_ABS: - case N_ABS | N_EXT: - cache_ptr->sym_ptr_ptr = obj_bsssec (abfd)->symbol_ptr_ptr; - cache_ptr->addend = 0; - break; - case -2: /* .align */ - if (raw[7] & pcrel_mask) - { - cache_ptr->howto = &howto_align_table[(raw[7] >> length_shift) & 3]; - cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr; - } - else - { - /* .org? */ - abort (); - } - cache_ptr->addend = 0; - break; - default: - BFD_ASSERT (FALSE); - break; - } - } - - /* The i960 only has a few relocation types: - abs 32-bit and pcrel 24bit. except for callj's! */ - if (cache_ptr->howto != 0) - ; - else if (raw[7] & callj_mask) - { - cache_ptr->howto = &howto_reloc_callj; - } - else if ( raw[7] & pcrel_mask) - { - if (raw[7] & size_mask) - cache_ptr->howto = &howto_reloc_pcrel13; - else - cache_ptr->howto = &howto_reloc_pcrel24; - } - else - { - if (raw[7] & incode_mask) - cache_ptr->howto = &howto_reloc_abs32code; - else - cache_ptr->howto = &howto_reloc_abs32; - } - - if (cache_ptr->address < prev_addr) - { - /* Ouch! this reloc is out of order, insert into the right place. */ - arelent tmp; - arelent *cursor = cache_ptr-1; - bfd_vma stop = cache_ptr->address; - - tmp = *cache_ptr; - while (cursor->address > stop && cursor >= reloc_cache) - { - cursor[1] = cursor[0]; - cursor--; - } - - cursor[1] = tmp; - } - else - prev_addr = cache_ptr->address; - } - - if (relocs != NULL) - free (relocs); - asect->relocation = reloc_cache; - asect->reloc_count = count; - - return TRUE; -} - -/* This is stupid. This function should be a boolean predicate. */ - -static long -b_out_canonicalize_reloc (bfd *abfd, - sec_ptr section, - arelent **relptr, - asymbol **symbols) -{ - arelent *tblptr; - unsigned int count; - - if ((section->flags & SEC_CONSTRUCTOR) != 0) - { - arelent_chain *chain = section->constructor_chain; - - for (count = 0; count < section->reloc_count; count++) - { - *relptr++ = &chain->relent; - chain = chain->next; - } - } - else - { - if (section->relocation == NULL - && ! b_out_slurp_reloc_table (abfd, section, symbols)) - return -1; - - tblptr = section->relocation; - for (count = 0; count++ < section->reloc_count;) - *relptr++ = tblptr++; - } - - *relptr = NULL; - - return section->reloc_count; -} - -static long -b_out_get_reloc_upper_bound (bfd *abfd, sec_ptr asect) -{ - if (bfd_get_format (abfd) != bfd_object) - { - bfd_set_error (bfd_error_invalid_operation); - return -1; - } - - if (asect->flags & SEC_CONSTRUCTOR) - return sizeof (arelent *) * (asect->reloc_count + 1); - - if (asect == obj_datasec (abfd)) - return (sizeof (arelent *) * - ((exec_hdr (abfd)->a_drsize / sizeof (struct relocation_info)) - + 1)); - - if (asect == obj_textsec (abfd)) - return (sizeof (arelent *) * - ((exec_hdr (abfd)->a_trsize / sizeof (struct relocation_info)) - + 1)); - - if (asect == obj_bsssec (abfd)) - return 0; - - bfd_set_error (bfd_error_invalid_operation); - return -1; -} - - -static bfd_boolean -b_out_set_section_contents (bfd *abfd, - asection *section, - const void * location, - file_ptr offset, - bfd_size_type count) -{ - if (! abfd->output_has_begun) - { - /* Set by bfd.c handler. */ - if (! aout_32_make_sections (abfd)) - return FALSE; - - obj_textsec (abfd)->filepos = sizeof (struct external_exec); - obj_datasec (abfd)->filepos = obj_textsec (abfd)->filepos - + obj_textsec (abfd)->size; - } - - /* Regardless, once we know what we're doing, we might as well get going. */ - if (bfd_seek (abfd, section->filepos + offset, SEEK_SET) != 0) - return FALSE; - - if (count == 0) - return TRUE; - - return bfd_bwrite ((void *) location, count, abfd) == count; -} - -static bfd_boolean -b_out_set_arch_mach (bfd *abfd, - enum bfd_architecture arch, - unsigned long machine) -{ - bfd_default_set_arch_mach (abfd, arch, machine); - - if (arch == bfd_arch_unknown) /* Unknown machine arch is OK. */ - return TRUE; - - if (arch == bfd_arch_i960) /* i960 default is OK. */ - switch (machine) - { - case bfd_mach_i960_core: - case bfd_mach_i960_kb_sb: - case bfd_mach_i960_mc: - case bfd_mach_i960_xa: - case bfd_mach_i960_ca: - case bfd_mach_i960_ka_sa: - case bfd_mach_i960_jx: - case bfd_mach_i960_hx: - case 0: - return TRUE; - default: - return FALSE; - } - - return FALSE; -} - -static int -b_out_sizeof_headers (bfd *ignore_abfd ATTRIBUTE_UNUSED, - struct bfd_link_info *info ATTRIBUTE_UNUSED) -{ - return sizeof (struct external_exec); -} - -static void -perform_slip (bfd *abfd, - unsigned int slip, - asection *input_section, - bfd_vma value) -{ - asymbol **s; - - s = _bfd_generic_link_get_symbols (abfd); - BFD_ASSERT (s != (asymbol **) NULL); - - /* Find all symbols past this point, and make them know - what's happened. */ - while (*s) - { - asymbol *p = *s; - - if (p->section == input_section) - { - /* This was pointing into this section, so mangle it. */ - if (p->value > value) - { - p->value -=slip; - - if (p->udata.p != NULL) - { - struct generic_link_hash_entry *h; - - h = (struct generic_link_hash_entry *) p->udata.p; - BFD_ASSERT (h->root.type == bfd_link_hash_defined); - h->root.u.def.value -= slip; - BFD_ASSERT (h->root.u.def.value == p->value); - } - } - } - s++; - } -} - -/* This routine works out if the thing we want to get to can be - reached with a 24bit offset instead of a 32 bit one. - If it can, then it changes the amode. */ - -static int -abs32code (bfd *abfd, - asection *input_section, - arelent *r, - unsigned int shrink, - struct bfd_link_info *link_info) -{ - bfd_vma value = get_value (r, link_info, input_section); - bfd_vma dot = output_addr (input_section) + r->address; - bfd_vma gap; - - /* See if the address we're looking at within 2^23 bytes of where - we are, if so then we can use a small branch rather than the - jump we were going to. */ - gap = value - (dot - shrink); - - if ((long)(-1UL << 23) < (long)gap && (long)gap < 1L << 23) - { - /* Change the reloc type from 32bitcode possible 24, to 24bit - possible 32. */ - r->howto = &howto_reloc_abs32codeshrunk; - /* The place to relc moves back by four bytes. */ - r->address -=4; - - /* This will be four bytes smaller in the long run. */ - shrink += 4 ; - perform_slip (abfd, 4, input_section, r->address-shrink + 4); - } - - return shrink; -} - -static int -aligncode (bfd *abfd, - asection *input_section, - arelent *r, - unsigned int shrink) -{ - bfd_vma dot = output_addr (input_section) + r->address; - bfd_vma old_end; - bfd_vma new_end; - unsigned int shrink_delta; - int size = r->howto->size; - - /* Reduce the size of the alignment so that it's still aligned but - smaller - the current size is already the same size as or bigger - than the alignment required. */ - - /* Calculate the first byte following the padding before we optimize. */ - old_end = ((dot + size ) & ~size) + size+1; - /* Work out where the new end will be - remember that we're smaller - than we used to be. */ - new_end = ((dot - shrink + size) & ~size); - - shrink_delta = (old_end - new_end) - shrink; - - if (shrink_delta) - { - /* Change the reloc so that it knows how far to align to. */ - r->howto = howto_done_align_table + (r->howto - howto_align_table); - - /* Encode the stuff into the addend - for future use we need to - know how big the reloc used to be. */ - r->addend = old_end - dot + r->address; - - /* This will be N bytes smaller in the long run, adjust all the symbols. */ - perform_slip (abfd, shrink_delta, input_section, r->address - shrink); - shrink += shrink_delta; - } - - return shrink; -} - -static bfd_boolean -b_out_bfd_relax_section (bfd *abfd, - asection *i, - struct bfd_link_info *link_info, - bfd_boolean *again) -{ - /* Get enough memory to hold the stuff. */ - bfd *input_bfd = i->owner; - asection *input_section = i; - unsigned int shrink = 0 ; - arelent **reloc_vector = NULL; - long reloc_size = bfd_get_reloc_upper_bound (input_bfd, input_section); - - if (bfd_link_relocatable (link_info)) - (*link_info->callbacks->einfo) - (_("%P%F: --relax and -r may not be used together\n")); - - if (reloc_size < 0) - return FALSE; - - /* We only run this relaxation once. It might work to run it - multiple times, but it hasn't been tested. */ - *again = FALSE; - - if (reloc_size) - { - long reloc_count; - - reloc_vector = bfd_malloc ((bfd_size_type) reloc_size); - if (reloc_vector == NULL && reloc_size != 0) - goto error_return; - - /* Get the relocs and think about them. */ - reloc_count = - bfd_canonicalize_reloc (input_bfd, input_section, reloc_vector, - _bfd_generic_link_get_symbols (input_bfd)); - if (reloc_count < 0) - goto error_return; - if (reloc_count > 0) - { - arelent **parent; - - for (parent = reloc_vector; *parent; parent++) - { - arelent *r = *parent; - - switch (r->howto->type) - { - case ALIGNER: - /* An alignment reloc. */ - shrink = aligncode (abfd, input_section, r, shrink); - break; - case ABS32CODE: - /* A 32bit reloc in an addressing mode. */ - shrink = abs32code (input_bfd, input_section, r, shrink, - link_info); - break; - case ABS32CODE_SHRUNK: - shrink += 4; - break; - } - } - } - } - input_section->size -= shrink; - - if (reloc_vector != NULL) - free (reloc_vector); - return TRUE; - error_return: - if (reloc_vector != NULL) - free (reloc_vector); - return FALSE; -} - -static bfd_byte * -b_out_bfd_get_relocated_section_contents (bfd *output_bfd, - struct bfd_link_info *link_info, - struct bfd_link_order *link_order, - bfd_byte *data, - bfd_boolean relocatable, - asymbol **symbols) -{ - /* Get enough memory to hold the stuff. */ - bfd *input_bfd = link_order->u.indirect.section->owner; - asection *input_section = link_order->u.indirect.section; - long reloc_size = bfd_get_reloc_upper_bound (input_bfd, input_section); - arelent **reloc_vector = NULL; - long reloc_count; - - if (reloc_size < 0) - goto error_return; - - /* If producing relocatable output, don't bother to relax. */ - if (relocatable) - return bfd_generic_get_relocated_section_contents (output_bfd, link_info, - link_order, - data, relocatable, - symbols); - - reloc_vector = bfd_malloc ((bfd_size_type) reloc_size); - if (reloc_vector == NULL && reloc_size != 0) - goto error_return; - - /* Read in the section. */ - BFD_ASSERT (bfd_get_section_contents (input_bfd, - input_section, - data, - (bfd_vma) 0, - input_section->size)); - - reloc_count = bfd_canonicalize_reloc (input_bfd, - input_section, - reloc_vector, - symbols); - if (reloc_count < 0) - goto error_return; - if (reloc_count > 0) - { - arelent **parent = reloc_vector; - arelent *reloc ; - unsigned int dst_address = 0; - unsigned int src_address = 0; - unsigned int run; - unsigned int idx; - - /* Find how long a run we can do. */ - while (dst_address < link_order->size) - { - reloc = *parent; - if (reloc) - { - /* Note that the relaxing didn't tie up the addresses in the - relocation, so we use the original address to work out the - run of non-relocated data. */ - BFD_ASSERT (reloc->address >= src_address); - run = reloc->address - src_address; - parent++; - } - else - run = link_order->size - dst_address; - - /* Copy the bytes. */ - for (idx = 0; idx < run; idx++) - data[dst_address++] = data[src_address++]; - - /* Now do the relocation. */ - if (reloc) - { - switch (reloc->howto->type) - { - case ABS32CODE: - calljx_callback (input_bfd, link_info, reloc, - src_address + data, dst_address + data, - input_section); - src_address += 4; - dst_address += 4; - break; - case ABS32: - bfd_put_32 (input_bfd, - (bfd_get_32 (input_bfd, data + src_address) - + get_value (reloc, link_info, input_section)), - data + dst_address); - src_address += 4; - dst_address += 4; - break; - case CALLJ: - callj_callback (input_bfd, link_info, reloc, data, - src_address, dst_address, input_section, - FALSE); - src_address += 4; - dst_address += 4; - break; - case ALIGNDONE: - BFD_ASSERT (reloc->addend >= src_address); - BFD_ASSERT ((bfd_vma) reloc->addend - <= input_section->size); - src_address = reloc->addend; - dst_address = ((dst_address + reloc->howto->size) - & ~reloc->howto->size); - break; - case ABS32CODE_SHRUNK: - /* This used to be a callx, but we've found out that a - callj will reach, so do the right thing. */ - callj_callback (input_bfd, link_info, reloc, data, - src_address + 4, dst_address, input_section, - TRUE); - dst_address += 4; - src_address += 8; - break; - case PCREL24: - { - long int word = bfd_get_32 (input_bfd, - data + src_address); - bfd_vma value; - - value = get_value (reloc, link_info, input_section); - word = ((word & ~BAL_MASK) - | (((word & BAL_MASK) - + value - - output_addr (input_section) - + reloc->addend) - & BAL_MASK)); - - bfd_put_32 (input_bfd, (bfd_vma) word, data + dst_address); - dst_address += 4; - src_address += 4; - - } - break; - case PCREL13: - { - long int word = bfd_get_32 (input_bfd, - data + src_address); - bfd_vma value; - - value = get_value (reloc, link_info, input_section); - word = ((word & ~PCREL13_MASK) - | (((word & PCREL13_MASK) - + value - + reloc->addend - - output_addr (input_section)) - & PCREL13_MASK)); - - bfd_put_32 (input_bfd, (bfd_vma) word, data + dst_address); - dst_address += 4; - src_address += 4; - } - break; - - default: - abort (); - } - } - } - } - if (reloc_vector != NULL) - free (reloc_vector); - return data; - error_return: - if (reloc_vector != NULL) - free (reloc_vector); - return NULL; -} - - -/* Build the transfer vectors for Big and Little-Endian B.OUT files. */ - -#define aout_32_find_line _bfd_nosymbols_find_line -#define aout_32_get_symbol_version_string _bfd_nosymbols_get_symbol_version_string -#define aout_32_bfd_make_debug_symbol _bfd_nosymbols_bfd_make_debug_symbol -#define aout_32_close_and_cleanup aout_32_bfd_free_cached_info -#define b_out_bfd_link_hash_table_create _bfd_generic_link_hash_table_create -#define b_out_bfd_link_add_symbols _bfd_generic_link_add_symbols -#define b_out_bfd_link_just_syms _bfd_generic_link_just_syms -#define b_out_bfd_copy_link_hash_symbol_type \ - _bfd_generic_copy_link_hash_symbol_type -#define b_out_bfd_final_link _bfd_generic_final_link -#define b_out_bfd_link_split_section _bfd_generic_link_split_section -#define b_out_bfd_gc_sections bfd_generic_gc_sections -#define b_out_bfd_lookup_section_flags bfd_generic_lookup_section_flags -#define b_out_bfd_merge_sections bfd_generic_merge_sections -#define b_out_bfd_is_group_section bfd_generic_is_group_section -#define b_out_bfd_discard_group bfd_generic_discard_group -#define b_out_section_already_linked _bfd_generic_section_already_linked -#define b_out_bfd_define_common_symbol bfd_generic_define_common_symbol -#define b_out_bfd_define_start_stop bfd_generic_define_start_stop -#define aout_32_get_section_contents_in_window _bfd_generic_get_section_contents_in_window -#define b_out_bfd_link_check_relocs _bfd_generic_link_check_relocs -#define b_out_set_reloc _bfd_generic_set_reloc - -extern const bfd_target bout_le_vec; - -const bfd_target bout_be_vec = -{ - "b.out.big", /* Name. */ - bfd_target_aout_flavour, - BFD_ENDIAN_LITTLE, /* Data byte order. */ - BFD_ENDIAN_BIG, /* Header byte order. */ - (HAS_RELOC | EXEC_P | /* Object flags. */ - HAS_LINENO | HAS_DEBUG | - HAS_SYMS | HAS_LOCALS | WP_TEXT | BFD_IS_RELAXABLE ), - (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | SEC_CODE | SEC_DATA), - '_', /* Symbol leading char. */ - ' ', /* AR_pad_char. */ - 16, /* AR_max_namelen. */ - 0, /* match priority. */ - bfd_getl64, bfd_getl_signed_64, bfd_putl64, - bfd_getl32, bfd_getl_signed_32, bfd_putl32, - bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* Data. */ - bfd_getb64, bfd_getb_signed_64, bfd_putb64, - bfd_getb32, bfd_getb_signed_32, bfd_putb32, - bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* Headers. */ - - { /* bfd_check_format. */ - _bfd_dummy_target, - b_out_object_p, - bfd_generic_archive_p, - _bfd_dummy_target - }, - { /* bfd_set_format. */ - _bfd_bool_bfd_false_error, - b_out_mkobject, - _bfd_generic_mkarchive, - _bfd_bool_bfd_false_error - }, - { /* bfd_write_contents. */ - _bfd_bool_bfd_false_error, - b_out_write_object_contents, - _bfd_write_archive_contents, - _bfd_bool_bfd_false_error - }, - - BFD_JUMP_TABLE_GENERIC (aout_32), - BFD_JUMP_TABLE_COPY (_bfd_generic), - BFD_JUMP_TABLE_CORE (_bfd_nocore), - BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_bsd), - BFD_JUMP_TABLE_SYMBOLS (aout_32), - BFD_JUMP_TABLE_RELOCS (b_out), - BFD_JUMP_TABLE_WRITE (b_out), - BFD_JUMP_TABLE_LINK (b_out), - BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), - - &bout_le_vec, - - NULL -}; - -const bfd_target bout_le_vec = -{ - "b.out.little", /* Name. */ - bfd_target_aout_flavour, - BFD_ENDIAN_LITTLE, /* Data byte order. */ - BFD_ENDIAN_LITTLE, /* Header byte order. */ - (HAS_RELOC | EXEC_P | /* Object flags. */ - HAS_LINENO | HAS_DEBUG | - HAS_SYMS | HAS_LOCALS | WP_TEXT | BFD_IS_RELAXABLE ), - (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC | SEC_CODE | SEC_DATA), - '_', /* Symbol leading char. */ - ' ', /* AR_pad_char. */ - 16, /* AR_max_namelen. */ - 0, /* match priority. */ - bfd_getl64, bfd_getl_signed_64, bfd_putl64, - bfd_getl32, bfd_getl_signed_32, bfd_putl32, - bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* Data. */ - bfd_getl64, bfd_getl_signed_64, bfd_putl64, - bfd_getl32, bfd_getl_signed_32, bfd_putl32, - bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* Headers. */ - - { /* bfd_check_format. */ - _bfd_dummy_target, - b_out_object_p, - bfd_generic_archive_p, - _bfd_dummy_target - }, - { /* bfd_set_format. */ - _bfd_bool_bfd_false_error, - b_out_mkobject, - _bfd_generic_mkarchive, - _bfd_bool_bfd_false_error - }, - { /* bfd_write_contents. */ - _bfd_bool_bfd_false_error, - b_out_write_object_contents, - _bfd_write_archive_contents, - _bfd_bool_bfd_false_error - }, - - BFD_JUMP_TABLE_GENERIC (aout_32), - BFD_JUMP_TABLE_COPY (_bfd_generic), - BFD_JUMP_TABLE_CORE (_bfd_nocore), - BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_bsd), - BFD_JUMP_TABLE_SYMBOLS (aout_32), - BFD_JUMP_TABLE_RELOCS (b_out), - BFD_JUMP_TABLE_WRITE (b_out), - BFD_JUMP_TABLE_LINK (b_out), - BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), - - &bout_be_vec, - - NULL -}; diff --git a/bfd/coff-i860.c b/bfd/coff-i860.c deleted file mode 100644 index 9ff96ea..0000000 --- a/bfd/coff-i860.c +++ /dev/null @@ -1,730 +0,0 @@ -/* BFD back-end for Intel i860 COFF files. - Copyright (C) 1990-2018 Free Software Foundation, Inc. - Created mostly by substituting "860" for "386" in coff-i386.c - Harry Dolan <dolan@ssd.intel.com>, October 1995 - - 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" - -#include "coff/i860.h" - -#include "coff/internal.h" - -#ifndef bfd_pe_print_pdata -#define bfd_pe_print_pdata NULL -#endif - -#include "libcoff.h" - - -#define COFF_DEFAULT_SECTION_ALIGNMENT_POWER (2) -/* The page size is a guess based on ELF. */ - -#define COFF_PAGE_SIZE 0x1000 - -/* For some reason when using i860 COFF the value stored in the .text - section for a reference to a common symbol is the value itself plus - any desired offset. Ian Taylor, Cygnus Support. */ - -/* If we are producing relocatable output, we need to do some - adjustments to the object file that are not done by the - bfd_perform_relocation function. This function is called by every - reloc type to make any required adjustments. */ - -static bfd_reloc_status_type -coff_i860_reloc (bfd *abfd, - arelent *reloc_entry, - asymbol *symbol, - void *data, - asection *input_section ATTRIBUTE_UNUSED, - bfd *output_bfd, - char **error_message ATTRIBUTE_UNUSED) -{ - symvalue diff; - - if (output_bfd == (bfd *) NULL) - return bfd_reloc_continue; - - if (bfd_is_com_section (symbol->section)) - { - /* We are relocating a common symbol. The current value in the - object file is ORIG + OFFSET, where ORIG is the value of the - common symbol as seen by the object file when it was compiled - (this may be zero if the symbol was undefined) and OFFSET is - the offset into the common symbol (normally zero, but may be - non-zero when referring to a field in a common structure). - ORIG is the negative of reloc_entry->addend, which is set by - the CALC_ADDEND macro below. We want to replace the value in - the object file with NEW + OFFSET, where NEW is the value of - the common symbol which we are going to put in the final - object file. NEW is symbol->value. */ - diff = symbol->value + reloc_entry->addend; - } - else - { - /* For some reason bfd_perform_relocation always effectively - ignores the addend for a COFF target when producing - relocatable output. This seems to be always wrong for 860 - COFF, so we handle the addend here instead. */ - diff = reloc_entry->addend; - } - -#define DOIT(x) \ - x = ((x & ~howto->dst_mask) | (((x & howto->src_mask) + diff) & howto->dst_mask)) - - if (diff != 0) - { - reloc_howto_type *howto = reloc_entry->howto; - unsigned char *addr = (unsigned char *) data + reloc_entry->address; - - if (! bfd_reloc_offset_in_range (howto, abfd, input_section, - reloc_entry->address - * bfd_octets_per_byte (abfd))) - return bfd_reloc_outofrange; - - switch (howto->size) - { - case 0: - { - char x = bfd_get_8 (abfd, addr); - DOIT (x); - bfd_put_8 (abfd, x, addr); - } - break; - - case 1: - { - short x = bfd_get_16 (abfd, addr); - DOIT (x); - bfd_put_16 (abfd, (bfd_vma) x, addr); - } - break; - - case 2: - { - long x = bfd_get_32 (abfd, addr); - DOIT (x); - bfd_put_32 (abfd, (bfd_vma) x, addr); - } - break; - - default: - abort (); - } - } - - /* Now let bfd_perform_relocation finish everything up. */ - return bfd_reloc_continue; -} - -/* This is just a temporary measure until we teach bfd to generate - these relocations. */ - -static bfd_reloc_status_type -coff_i860_reloc_nyi (bfd *abfd, - arelent *reloc_entry, - asymbol *symbol ATTRIBUTE_UNUSED, - void *data ATTRIBUTE_UNUSED, - asection *input_section ATTRIBUTE_UNUSED, - bfd *output_bfd ATTRIBUTE_UNUSED, - char **error_message ATTRIBUTE_UNUSED) -{ - reloc_howto_type *howto = reloc_entry->howto; - _bfd_error_handler (_("%pB: %s unsupported"), abfd, howto->name); - return bfd_reloc_notsupported; -} - -#ifndef PCRELOFFSET -#define PCRELOFFSET FALSE -#endif - -static reloc_howto_type howto_table[] = -{ - EMPTY_HOWTO (0), - EMPTY_HOWTO (1), - EMPTY_HOWTO (2), - EMPTY_HOWTO (3), - EMPTY_HOWTO (4), - EMPTY_HOWTO (5), - HOWTO (R_DIR32, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "dir32", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - /* {7}, */ - HOWTO (R_IMAGEBASE, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "rva32", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - EMPTY_HOWTO (010), - EMPTY_HOWTO (011), - EMPTY_HOWTO (012), - EMPTY_HOWTO (013), - EMPTY_HOWTO (014), - EMPTY_HOWTO (015), - EMPTY_HOWTO (016), - HOWTO (R_RELBYTE, /* type */ - 0, /* rightshift */ - 0, /* size (0 = byte, 1 = short, 2 = long) */ - 8, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "8", /* name */ - TRUE, /* partial_inplace */ - 0x000000ff, /* src_mask */ - 0x000000ff, /* dst_mask */ - PCRELOFFSET), /* pcrel_offset */ - HOWTO (R_RELWORD, /* type */ - 0, /* rightshift */ - 1, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "16", /* name */ - TRUE, /* partial_inplace */ - 0x0000ffff, /* src_mask */ - 0x0000ffff, /* dst_mask */ - PCRELOFFSET), /* pcrel_offset */ - HOWTO (R_RELLONG, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "32", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - PCRELOFFSET), /* pcrel_offset */ - HOWTO (R_PCRBYTE, /* type */ - 0, /* rightshift */ - 0, /* size (0 = byte, 1 = short, 2 = long) */ - 8, /* bitsize */ - TRUE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_signed, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "DISP8", /* name */ - TRUE, /* partial_inplace */ - 0x000000ff, /* src_mask */ - 0x000000ff, /* dst_mask */ - PCRELOFFSET), /* pcrel_offset */ - HOWTO (R_PCRWORD, /* type */ - 0, /* rightshift */ - 1, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - TRUE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_signed, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "DISP16", /* name */ - TRUE, /* partial_inplace */ - 0x0000ffff, /* src_mask */ - 0x0000ffff, /* dst_mask */ - PCRELOFFSET), /* pcrel_offset */ - HOWTO (R_PCRLONG, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - TRUE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_signed, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "DISP32", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - PCRELOFFSET), /* pcrel_offset */ - EMPTY_HOWTO (0x15), - EMPTY_HOWTO (0x16), - EMPTY_HOWTO (0x17), - EMPTY_HOWTO (0x18), - EMPTY_HOWTO (0x19), - EMPTY_HOWTO (0x1a), - EMPTY_HOWTO (0x1b), - HOWTO (COFF860_R_PAIR, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc_nyi, /* special_function */ - "PAIR", /* name */ - FALSE, /* partial_inplace */ - 0xffff, /* src_mask */ - 0xffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - EMPTY_HOWTO (0x1d), - HOWTO (COFF860_R_HIGH, /* type */ - 16, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "HIGH", /* name */ - FALSE, /* partial_inplace */ - 0xffff, /* src_mask */ - 0xffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_LOW0, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "LOW0", /* name */ - FALSE, /* partial_inplace */ - 0xffff, /* src_mask */ - 0xffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_LOW1, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "LOW1", /* name */ - FALSE, /* partial_inplace */ - 0xfffe, /* src_mask */ - 0xfffe, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_LOW2, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "LOW2", /* name */ - FALSE, /* partial_inplace */ - 0xfffc, /* src_mask */ - 0xfffc, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_LOW3, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "LOW3", /* name */ - FALSE, /* partial_inplace */ - 0xfff8, /* src_mask */ - 0xfff8, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_LOW4, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc, /* special_function */ - "LOW4", /* name */ - FALSE, /* partial_inplace */ - 0xfff0, /* src_mask */ - 0xfff0, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_SPLIT0, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc_nyi, /* special_function */ - "SPLIT0", /* name */ - FALSE, /* partial_inplace */ - 0x1f07ff, /* src_mask */ - 0x1f07ff, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_SPLIT1, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc_nyi, /* special_function */ - "SPLIT1", /* name */ - FALSE, /* partial_inplace */ - 0x1f07fe, /* src_mask */ - 0x1f07fe, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_SPLIT2, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc_nyi, /* special_function */ - "SPLIT2", /* name */ - FALSE, /* partial_inplace */ - 0x1f07fc, /* src_mask */ - 0x1f07fc, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_HIGHADJ, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - coff_i860_reloc_nyi, /* special_function */ - "HIGHADJ", /* name */ - FALSE, /* partial_inplace */ - 0xffff, /* src_mask */ - 0xffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - HOWTO (COFF860_R_BRADDR, /* type */ - 2, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 26, /* bitsize */ - TRUE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - coff_i860_reloc_nyi, /* special_function */ - "BRADDR", /* name */ - FALSE, /* partial_inplace */ - 0x3ffffff, /* src_mask */ - 0x3ffffff, /* dst_mask */ - TRUE) /* pcrel_offset */ -}; - -/* Turn a howto into a reloc number. */ - -#define SELECT_RELOC(x,howto) { x.r_type = howto->type; } -#define BADMAG(x) I860BADMAG(x) -#define I860 1 /* Customize coffcode.h */ - -#define RTYPE2HOWTO(cache_ptr, dst) \ - ((cache_ptr)->howto = \ - ((dst)->r_type < sizeof (howto_table) / sizeof (howto_table[0]) \ - ? howto_table + (dst)->r_type \ - : NULL)) - -/* For 860 COFF a STYP_NOLOAD | STYP_BSS section is part of a shared - library. On some other COFF targets STYP_BSS is normally - STYP_NOLOAD. */ -#define BSS_NOLOAD_IS_SHARED_LIBRARY - -/* Compute the addend of a reloc. If the reloc is to a common symbol, - the object file contains the value of the common symbol. By the - time this is called, the linker may be using a different symbol - from a different object file with a different value. Therefore, we - hack wildly to locate the original symbol from this file so that we - can make the correct adjustment. This macro sets coffsym to the - symbol from the original file, and uses it to set the addend value - correctly. If this is not a common symbol, the usual addend - calculation is done, except that an additional tweak is needed for - PC relative relocs. - FIXME: This macro refers to symbols and asect; these are from the - calling function, not the macro arguments. */ - -/* PR 17512: file: 0a38fb7c - Set an addend value, even if it is not going to be used. A tool - like coffdump might be used to print out the contents of the reloc. */ -#define CALC_ADDEND(abfd, ptr, reloc, cache_ptr) (cache_ptr)->addend = 0 - -/* We use the special COFF backend linker. */ -#define coff_relocate_section _bfd_coff_generic_relocate_section - -static reloc_howto_type * -coff_i860_rtype_to_howto (bfd *abfd ATTRIBUTE_UNUSED, - asection *sec, - struct internal_reloc *rel, - struct coff_link_hash_entry *h, - struct internal_syment *sym, - bfd_vma *addendp) -{ - - reloc_howto_type *howto; - - if (rel->r_type > sizeof (howto_table) / sizeof (howto_table[0])) - { - bfd_set_error (bfd_error_bad_value); - return NULL; - } - - howto = howto_table + rel->r_type; - - if (howto->pc_relative) - *addendp += sec->vma; - - if (sym != NULL && sym->n_scnum == 0 && sym->n_value != 0) - { - /* This is a common symbol. The section contents include the - size (sym->n_value) as an addend. The relocate_section - function will be adding in the final value of the symbol. We - need to subtract out the current size in order to get the - correct result. */ - - BFD_ASSERT (h != NULL); - - /* I think we *do* want to bypass this. If we don't, I have seen some data - parameters get the wrong relocation address. If I link two versions - with and without this section bypassed and then do a binary comparison, - the addresses which are different can be looked up in the map. The - case in which this section has been bypassed has addresses which correspond - to values I can find in the map. */ - *addendp -= sym->n_value; - } - - /* If the output symbol is common (in which case this must be a - relocatable link), we need to add in the final size of the - common symbol. */ - if (h != NULL && h->root.type == bfd_link_hash_common) - *addendp += h->root.u.c.size; - - return howto; -} - -static reloc_howto_type * -coff_i860_reloc_type_lookup (bfd *abfd ATTRIBUTE_UNUSED, - bfd_reloc_code_real_type code) -{ - switch (code) - { - case BFD_RELOC_32: - return howto_table + R_DIR32; - case BFD_RELOC_860_PC26: - return howto_table + COFF860_R_BRADDR; - case BFD_RELOC_860_PC16: - /* ??? How to handle PC16 for COFF? SPLIT0 is close for now. */ - return howto_table + COFF860_R_SPLIT0; - case BFD_RELOC_860_LOW0: - return howto_table + COFF860_R_LOW0; - case BFD_RELOC_860_SPLIT0: - return howto_table + COFF860_R_SPLIT0; - case BFD_RELOC_860_LOW1: - return howto_table + COFF860_R_LOW1; - case BFD_RELOC_860_SPLIT1: - return howto_table + COFF860_R_SPLIT1; - case BFD_RELOC_860_LOW2: - return howto_table + COFF860_R_LOW2; - case BFD_RELOC_860_SPLIT2: - return howto_table + COFF860_R_SPLIT2; - case BFD_RELOC_860_LOW3: - return howto_table + COFF860_R_LOW3; - case BFD_RELOC_860_HIGHADJ: - return howto_table + COFF860_R_HIGHADJ; - case BFD_RELOC_860_HIGH: - return howto_table + COFF860_R_HIGH; - default: - BFD_FAIL (); - return 0; - } -} - -static reloc_howto_type * -coff_i860_reloc_name_lookup (bfd *abfd ATTRIBUTE_UNUSED, - const char *r_name) -{ - unsigned int i; - - for (i = 0; i < sizeof (howto_table) / sizeof (howto_table[0]); i++) - if (howto_table[i].name != NULL - && strcasecmp (howto_table[i].name, r_name) == 0) - return &howto_table[i]; - - return NULL; -} - -/* This is called from coff_slurp_reloc_table for each relocation - entry. This special handling is due to the `PAIR' relocation - which has a different meaning for the `r_symndx' field. */ - -static void -i860_reloc_processing (arelent *cache_ptr, struct internal_reloc *dst, - asymbol **symbols, bfd *abfd, asection *asect) -{ - if (dst->r_type == COFF860_R_PAIR) - { - /* Handle the PAIR relocation specially. */ - cache_ptr->howto = howto_table + dst->r_type; - cache_ptr->address = dst->r_vaddr; - cache_ptr->addend = dst->r_symndx; - cache_ptr->sym_ptr_ptr= bfd_abs_section_ptr->symbol_ptr_ptr; - } - else - { - /* For every other relocation, do exactly what coff_slurp_reloc_table - would do (which this code is taken directly from). */ - asymbol *ptr = NULL; - cache_ptr->address = dst->r_vaddr; - - if (dst->r_symndx != -1) - { - if (dst->r_symndx < 0 || dst->r_symndx >= obj_conv_table_size (abfd)) - { - _bfd_error_handler - /* xgettext: c-format */ - (_("%pB: warning: illegal symbol index %ld in relocs"), - abfd, dst->r_symndx); - cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr; - ptr = NULL; - } - else - { - cache_ptr->sym_ptr_ptr = (symbols - + obj_convert (abfd)[dst->r_symndx]); - ptr = *(cache_ptr->sym_ptr_ptr); - } - } - else - { - cache_ptr->sym_ptr_ptr = bfd_abs_section_ptr->symbol_ptr_ptr; - ptr = NULL; - } - - /* The symbols definitions that we have read in have been - relocated as if their sections started at 0. But the offsets - refering to the symbols in the raw data have not been - modified, so we have to have a negative addend to compensate. - - Note that symbols which used to be common must be left alone. */ - - /* Calculate any reloc addend by looking at the symbol. */ - CALC_ADDEND (abfd, ptr, (*dst), cache_ptr); - (void) ptr; - - cache_ptr->address -= asect->vma; - - /* Fill in the cache_ptr->howto field from dst->r_type. */ - RTYPE2HOWTO (cache_ptr, dst); - } -} - -#define coff_rtype_to_howto coff_i860_rtype_to_howto -#define coff_bfd_reloc_type_lookup coff_i860_reloc_type_lookup -#define coff_bfd_reloc_name_lookup coff_i860_reloc_name_lookup - -#define RELOC_PROCESSING(relent, reloc, symbols, abfd, section) \ - i860_reloc_processing (relent, reloc, symbols, abfd, section) - -#include "coffcode.h" - -static const bfd_target * -i3coff_object_p(bfd *a) -{ - return coff_object_p (a); -} - -const bfd_target -#ifdef TARGET_SYM - TARGET_SYM = -#else - i860_coff_vec = -#endif -{ -#ifdef TARGET_NAME - TARGET_NAME, -#else - "coff-i860", /* name */ -#endif - bfd_target_coff_flavour, - BFD_ENDIAN_LITTLE, /* data byte order is little */ - BFD_ENDIAN_LITTLE, /* header byte order is little */ - - (HAS_RELOC | EXEC_P /* object flags */ - | HAS_LINENO | HAS_DEBUG - | HAS_SYMS | HAS_LOCALS | WP_TEXT | D_PAGED), - - (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC), /* section flags */ - '_', /* leading underscore */ - '/', /* ar_pad_char */ - 15, /* ar_max_namelen */ - 0, /* match priority. */ - - bfd_getl64, bfd_getl_signed_64, bfd_putl64, - bfd_getl32, bfd_getl_signed_32, bfd_putl32, - bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* data */ - bfd_getl64, bfd_getl_signed_64, bfd_putl64, - bfd_getl32, bfd_getl_signed_32, bfd_putl32, - bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* hdrs */ - -/* Note that we allow an object file to be treated as a core file as well. */ - { /* bfd_check_format */ - _bfd_dummy_target, - i3coff_object_p, - bfd_generic_archive_p, - i3coff_object_p - }, - { /* bfd_set_format */ - _bfd_bool_bfd_false_error, - coff_mkobject, - _bfd_generic_mkarchive, - _bfd_bool_bfd_false_error - }, - { /* bfd_write_contents */ - _bfd_bool_bfd_false_error, - coff_write_object_contents, - _bfd_write_archive_contents, - _bfd_bool_bfd_false_error - }, - - BFD_JUMP_TABLE_GENERIC (coff), - BFD_JUMP_TABLE_COPY (coff), - BFD_JUMP_TABLE_CORE (_bfd_nocore), - BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), - BFD_JUMP_TABLE_SYMBOLS (coff), - BFD_JUMP_TABLE_RELOCS (coff), - BFD_JUMP_TABLE_WRITE (coff), - BFD_JUMP_TABLE_LINK (coff), - BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), - - NULL, - - COFF_SWAP_TABLE -}; diff --git a/bfd/coff-i960.c b/bfd/coff-i960.c deleted file mode 100644 index 4e68d44..0000000 --- a/bfd/coff-i960.c +++ /dev/null @@ -1,666 +0,0 @@ -/* BFD back-end for Intel 960 COFF files. - Copyright (C) 1990-2018 Free Software Foundation, Inc. - Written by Cygnus Support. - - 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. */ - -#define I960 1 -#define BADMAG(x) I960BADMAG(x) - -#include "sysdep.h" -#include "bfd.h" -#include "libbfd.h" -#include "coff/i960.h" -#include "coff/internal.h" - -#ifndef bfd_pe_print_pdata -#define bfd_pe_print_pdata NULL -#endif - -#include "libcoff.h" /* To allow easier abstraction-breaking. */ - - -#define COFF_DEFAULT_SECTION_ALIGNMENT_POWER (3) -#define COFF_ALIGN_IN_SECTION_HEADER 1 - -#define GET_SCNHDR_ALIGN H_GET_32 -#define PUT_SCNHDR_ALIGN H_PUT_32 - -/* The i960 does not support an MMU, so COFF_PAGE_SIZE can be - arbitrarily small. */ -#define COFF_PAGE_SIZE 1 - -#define COFF_LONG_FILENAMES - -/* This set of local label names is taken from gas. */ - -static bfd_boolean -coff_i960_is_local_label_name (bfd *abfd ATTRIBUTE_UNUSED, const char *name) -{ - return (name[0] == 'L' - || (name[0] == '.' - && (name[1] == 'C' - || name[1] == 'I' - || name[1] == '.'))); -} - -/* This is just like the usual CALC_ADDEND, but it includes the - section VMA for PC relative relocs. */ -#ifndef CALC_ADDEND -#define CALC_ADDEND(abfd, ptr, reloc, cache_ptr) \ - { \ - coff_symbol_type *coffsym = (coff_symbol_type *) NULL; \ - if (ptr && bfd_asymbol_bfd (ptr) != abfd) \ - coffsym = (obj_symbols (abfd) \ - + (cache_ptr->sym_ptr_ptr - symbols)); \ - else if (ptr) \ - coffsym = coff_symbol_from (ptr); \ - if (coffsym != (coff_symbol_type *) NULL \ - && coffsym->native->u.syment.n_scnum == 0) \ - cache_ptr->addend = 0; \ - else if (ptr && bfd_asymbol_bfd (ptr) == abfd \ - && ptr->section != (asection *) NULL) \ - cache_ptr->addend = - (ptr->section->vma + ptr->value); \ - else \ - cache_ptr->addend = 0; \ - if (ptr && (reloc.r_type == 25 || reloc.r_type == 27)) \ - cache_ptr->addend += asect->vma; \ - } -#endif - -#define CALLS 0x66003800 /* Template for 'calls' instruction */ -#define BAL 0x0b000000 /* Template for 'bal' instruction */ -#define BAL_MASK 0x00ffffff - -static bfd_reloc_status_type -optcall_callback (bfd *abfd, - arelent *reloc_entry, - asymbol *symbol_in, - void * data, - asection *input_section, - bfd *ignore_bfd ATTRIBUTE_UNUSED, - char **error_message) -{ - /* This item has already been relocated correctly, but we may be - * able to patch in yet better code - done by digging out the - * correct info on this symbol */ - bfd_reloc_status_type result; - coff_symbol_type *cs = coffsymbol(symbol_in); - - /* Don't do anything with symbols which aren't tied up yet, - except move the reloc. */ - if (bfd_is_und_section (cs->symbol.section)) { - reloc_entry->address += input_section->output_offset; - return bfd_reloc_ok; - } - - /* So the target symbol has to be of coff type, and the symbol - has to have the correct native information within it */ - if ((bfd_asymbol_flavour(&cs->symbol) != bfd_target_coff_flavour) - || (cs->native == (combined_entry_type *)NULL)) - { - /* This is interesting, consider the case where we're outputting coff - from a mix n match input, linking from coff to a symbol defined in a - bout file will cause this match to be true. Should I complain? This - will only work if the bout symbol is non leaf. */ - *error_message = - (char *) _("uncertain calling convention for non-COFF symbol"); - result = bfd_reloc_dangerous; - } - else - { - switch (cs->native->u.syment.n_sclass) - { - case C_LEAFSTAT: - case C_LEAFEXT: - /* This is a call to a leaf procedure, replace instruction with a bal - to the correct location. */ - { - union internal_auxent *aux = &((cs->native+2)->u.auxent); - int word = bfd_get_32 (abfd, (bfd_byte *)data + reloc_entry->address); - int olf = (aux->x_bal.x_balntry - cs->native->u.syment.n_value); - BFD_ASSERT(cs->native->u.syment.n_numaux==2); - - /* We replace the original call instruction with a bal to - the bal entry point - the offset of which is described in - the 2nd auxent of the original symbol. We keep the native - sym and auxents untouched, so the delta between the two - is the offset of the bal entry point. */ - word = ((word + olf) & BAL_MASK) | BAL; - bfd_put_32 (abfd, (bfd_vma) word, - (bfd_byte *) data + reloc_entry->address); - } - result = bfd_reloc_ok; - break; - case C_SCALL: - /* This is a call to a system call, replace with a calls to # */ - BFD_ASSERT(0); - result = bfd_reloc_ok; - break; - default: - result = bfd_reloc_ok; - break; - } - } - return result; -} - -/* i960 COFF is used by VxWorks 5.1. However, VxWorks 5.1 does not - appear to correctly handle a reloc against a symbol defined in the - same object file. It appears to simply discard such relocs, rather - than adding their values into the object file. We handle this here - by converting all relocs against defined symbols into relocs - against the section symbol, when generating a relocatable output - file. - - Note that this function is only called if we are not using the COFF - specific backend linker. It only does something when doing a - relocatable link, which will almost certainly fail when not - generating COFF i960 output, so this function is actually no longer - useful. It was used before this target was converted to use the - COFF specific backend linker. */ - -static bfd_reloc_status_type -coff_i960_relocate (bfd *abfd, - arelent *reloc_entry, - asymbol *symbol, - void * data ATTRIBUTE_UNUSED, - asection *input_section ATTRIBUTE_UNUSED, - bfd *output_bfd, - char **error_message ATTRIBUTE_UNUSED) -{ - asection *osec; - - if (output_bfd == NULL) - { - /* Not generating relocatable output file. */ - return bfd_reloc_continue; - } - - if (bfd_is_und_section (bfd_get_section (symbol))) - { - /* Symbol is not defined, so no need to worry about it. */ - return bfd_reloc_continue; - } - - if (bfd_is_com_section (bfd_get_section (symbol))) - { - /* I don't really know what the right action is for a common - symbol. */ - return bfd_reloc_continue; - } - - /* Convert the reloc to use the section symbol. FIXME: This method - is ridiculous. */ - osec = bfd_get_section (symbol)->output_section; - if (coff_section_data (output_bfd, osec) != NULL - && coff_section_data (output_bfd, osec)->tdata != NULL) - reloc_entry->sym_ptr_ptr = - (asymbol **) coff_section_data (output_bfd, osec)->tdata; - else - { - const char *sec_name; - asymbol **syms, **sym_end; - - sec_name = bfd_get_section_name (output_bfd, osec); - syms = bfd_get_outsymbols (output_bfd); - sym_end = syms + bfd_get_symcount (output_bfd); - for (; syms < sym_end; syms++) - { - if (bfd_asymbol_name (*syms) != NULL - && (*syms)->value == 0 - && strcmp ((*syms)->section->output_section->name, - sec_name) == 0) - break; - } - - if (syms >= sym_end) - abort (); - - reloc_entry->sym_ptr_ptr = syms; - - if (coff_section_data (output_bfd, osec) == NULL) - { - bfd_size_type amt = sizeof (struct coff_section_tdata); - osec->used_by_bfd = bfd_zalloc (abfd, amt); - if (osec->used_by_bfd == NULL) - return bfd_reloc_overflow; - } - coff_section_data (output_bfd, osec)->tdata = syms; - } - - /* Let bfd_perform_relocation do its thing, which will include - stuffing the symbol addend into the object file. */ - return bfd_reloc_continue; -} - -static reloc_howto_type howto_rellong = - HOWTO ((unsigned int) R_RELLONG, 0, 2, 32,FALSE, 0, - complain_overflow_bitfield, coff_i960_relocate,"rellong", TRUE, - 0xffffffff, 0xffffffff, 0); -static reloc_howto_type howto_iprmed = - HOWTO (R_IPRMED, 0, 2, 24,TRUE,0, complain_overflow_signed, - coff_i960_relocate, "iprmed ", TRUE, 0x00ffffff, 0x00ffffff, 0); -static reloc_howto_type howto_optcall = - HOWTO (R_OPTCALL, 0,2,24,TRUE,0, complain_overflow_signed, - optcall_callback, "optcall", TRUE, 0x00ffffff, 0x00ffffff, 0); - -static reloc_howto_type * -coff_i960_reloc_type_lookup (bfd *abfd ATTRIBUTE_UNUSED, - bfd_reloc_code_real_type code) -{ - switch (code) - { - default: - return 0; - case BFD_RELOC_I960_CALLJ: - return &howto_optcall; - case BFD_RELOC_32: - case BFD_RELOC_CTOR: - return &howto_rellong; - case BFD_RELOC_24_PCREL: - return &howto_iprmed; - } -} - -static reloc_howto_type * -coff_i960_reloc_name_lookup (bfd *abfd ATTRIBUTE_UNUSED, - const char *r_name) -{ - if (strcasecmp (howto_optcall.name, r_name) == 0) - return &howto_optcall; - if (strcasecmp (howto_rellong.name, r_name) == 0) - return &howto_rellong; - if (strcasecmp (howto_iprmed.name, r_name) == 0) - return &howto_iprmed; - - return NULL; -} - -/* The real code is in coffcode.h */ - -#define RTYPE2HOWTO(cache_ptr, dst) \ -{ \ - reloc_howto_type *howto_ptr; \ - switch ((dst)->r_type) { \ - case 17: howto_ptr = &howto_rellong; break; \ - case 25: howto_ptr = &howto_iprmed; break; \ - case 27: howto_ptr = &howto_optcall; break; \ - default: howto_ptr = 0; break; \ - } \ - (cache_ptr)->howto = howto_ptr; \ - } - -/* i960 COFF is used by VxWorks 5.1. However, VxWorks 5.1 does not - appear to correctly handle a reloc against a symbol defined in the - same object file. It appears to simply discard such relocs, rather - than adding their values into the object file. We handle this by - converting all relocs against global symbols into relocs against - internal symbols at the start of the section. This routine is - called at the start of the linking process, and it creates the - necessary symbols. */ - -static bfd_boolean -coff_i960_start_final_link (bfd *abfd, struct bfd_link_info *info) -{ - bfd_size_type symesz = bfd_coff_symesz (abfd); - asection *o; - bfd_byte *esym; - - if (! bfd_link_relocatable (info)) - return TRUE; - - esym = (bfd_byte *) bfd_malloc (symesz); - if (esym == NULL) - return FALSE; - - if (bfd_seek (abfd, obj_sym_filepos (abfd), SEEK_SET) != 0) - return FALSE; - - for (o = abfd->sections; o != NULL; o = o->next) - { - struct internal_syment isym; - - strncpy (isym._n._n_name, o->name, SYMNMLEN); - isym.n_value = 0; - isym.n_scnum = o->target_index; - isym.n_type = T_NULL; - isym.n_sclass = C_STAT; - isym.n_numaux = 0; - - bfd_coff_swap_sym_out (abfd, &isym, esym); - - if (bfd_bwrite (esym, symesz, abfd) != symesz) - { - free (esym); - return FALSE; - } - - obj_raw_syment_count (abfd) += 1; - } - - free (esym); - - return TRUE; -} - -/* The reloc processing routine for the optimized COFF linker. */ - -static bfd_boolean -coff_i960_relocate_section (bfd *output_bfd ATTRIBUTE_UNUSED, - struct bfd_link_info *info, - bfd *input_bfd, - asection *input_section, - bfd_byte *contents, - struct internal_reloc *relocs, - struct internal_syment *syms, - asection **sections) -{ - struct internal_reloc *rel; - struct internal_reloc *relend; - - rel = relocs; - relend = rel + input_section->reloc_count; - for (; rel < relend; rel++) - { - long symndx; - struct coff_link_hash_entry *h; - struct internal_syment *sym; - bfd_vma addend; - bfd_vma val; - reloc_howto_type *howto; - bfd_reloc_status_type rstat = bfd_reloc_ok; - bfd_boolean done; - - symndx = rel->r_symndx; - - if (symndx == -1) - { - h = NULL; - sym = NULL; - } - else - { - h = obj_coff_sym_hashes (input_bfd)[symndx]; - sym = syms + symndx; - } - - if (sym != NULL && sym->n_scnum != 0) - addend = - sym->n_value; - else - addend = 0; - - switch (rel->r_type) - { - case 17: howto = &howto_rellong; break; - case 25: howto = &howto_iprmed; break; - case 27: howto = &howto_optcall; break; - default: - bfd_set_error (bfd_error_bad_value); - return FALSE; - } - - val = 0; - - if (h == NULL) - { - asection *sec; - - if (symndx == -1) - { - sec = bfd_abs_section_ptr; - val = 0; - } - else - { - sec = sections[symndx]; - val = (sec->output_section->vma - + sec->output_offset - + sym->n_value - - sec->vma); - } - } - else - { - if (h->root.type == bfd_link_hash_defined - || h->root.type == bfd_link_hash_defweak) - { - asection *sec; - - sec = h->root.u.def.section; - val = (h->root.u.def.value - + sec->output_section->vma - + sec->output_offset); - } - else if (! bfd_link_relocatable (info)) - (*info->callbacks->undefined_symbol) - (info, h->root.root.string, input_bfd, input_section, - rel->r_vaddr - input_section->vma, TRUE); - } - - done = FALSE; - - if (howto->type == R_OPTCALL && ! bfd_link_relocatable (info) && symndx != -1) - { - int class_val; - - if (h != NULL) - class_val = h->symbol_class; - else - class_val = sym->n_sclass; - - switch (class_val) - { - case C_NULL: - /* This symbol is apparently not from a COFF input file. - We warn, and then assume that it is not a leaf - function. */ - (*info->callbacks->reloc_dangerous) - (info, - _("uncertain calling convention for non-COFF symbol"), - input_bfd, input_section, - rel->r_vaddr - input_section->vma); - break; - case C_LEAFSTAT: - case C_LEAFEXT: - /* This is a call to a leaf procedure; use the bal - instruction. */ - { - long olf; - unsigned long word; - - if (h != NULL) - { - BFD_ASSERT (h->numaux == 2); - olf = h->aux[1].x_bal.x_balntry; - } - else - { - bfd_byte *esyms; - union internal_auxent aux; - - BFD_ASSERT (sym->n_numaux == 2); - esyms = (bfd_byte *) obj_coff_external_syms (input_bfd); - esyms += (symndx + 2) * bfd_coff_symesz (input_bfd); - bfd_coff_swap_aux_in (input_bfd, esyms, sym->n_type, - sym->n_sclass, 1, sym->n_numaux, - &aux); - olf = aux.x_bal.x_balntry; - } - - word = bfd_get_32 (input_bfd, - (contents - + (rel->r_vaddr - input_section->vma))); - word = ((word + olf - val) & BAL_MASK) | BAL; - bfd_put_32 (input_bfd, - (bfd_vma) word, - contents + (rel->r_vaddr - input_section->vma)); - done = TRUE; - } - break; - case C_SCALL: - BFD_ASSERT (0); - break; - } - } - - if (! done) - { - if (howto->pc_relative) - addend += input_section->vma; - rstat = _bfd_final_link_relocate (howto, input_bfd, input_section, - contents, - rel->r_vaddr - input_section->vma, - val, addend); - } - - switch (rstat) - { - default: - abort (); - case bfd_reloc_ok: - break; - case bfd_reloc_overflow: - { - const char *name; - char buf[SYMNMLEN + 1]; - - if (symndx == -1) - name = "*ABS*"; - else if (h != NULL) - name = NULL; - else - { - name = _bfd_coff_internal_syment_name (input_bfd, sym, buf); - if (name == NULL) - return FALSE; - } - - (*info->callbacks->reloc_overflow) - (info, (h ? &h->root : NULL), name, howto->name, - (bfd_vma) 0, input_bfd, input_section, - rel->r_vaddr - input_section->vma); - } - } - } - - return TRUE; -} - -/* Adjust the symbol index of any reloc against a global symbol to - instead be a reloc against the internal symbol we created specially - for the section. */ - -static bfd_boolean -coff_i960_adjust_symndx (bfd *obfd ATTRIBUTE_UNUSED, - struct bfd_link_info *info ATTRIBUTE_UNUSED, - bfd *ibfd, - asection *sec ATTRIBUTE_UNUSED, - struct internal_reloc *irel, - bfd_boolean *adjustedp) -{ - struct coff_link_hash_entry *h; - - *adjustedp = FALSE; - - h = obj_coff_sym_hashes (ibfd)[irel->r_symndx]; - if (h == NULL - || (h->root.type != bfd_link_hash_defined - && h->root.type != bfd_link_hash_defweak)) - return TRUE; - - irel->r_symndx = h->root.u.def.section->output_section->target_index - 1; - *adjustedp = TRUE; - - return TRUE; -} - -#define coff_bfd_is_local_label_name coff_i960_is_local_label_name - -#define coff_start_final_link coff_i960_start_final_link - -#define coff_relocate_section coff_i960_relocate_section - -#define coff_adjust_symndx coff_i960_adjust_symndx - -#define coff_bfd_reloc_type_lookup coff_i960_reloc_type_lookup -#define coff_bfd_reloc_name_lookup coff_i960_reloc_name_lookup - -#include "coffcode.h" - -extern const bfd_target icoff_be_vec; - -CREATE_LITTLE_COFF_TARGET_VEC (icoff_le_vec, "coff-Intel-little", 0, 0, '_', & icoff_be_vec, COFF_SWAP_TABLE) - -const bfd_target icoff_be_vec = -{ - "coff-Intel-big", /* name */ - bfd_target_coff_flavour, - BFD_ENDIAN_LITTLE, /* data byte order is little */ - BFD_ENDIAN_BIG, /* header byte order is big */ - - (HAS_RELOC | EXEC_P /* object flags */ - | HAS_LINENO | HAS_DEBUG - | HAS_SYMS | HAS_LOCALS | WP_TEXT), - - (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC), /* section flags */ - '_', /* leading underscore */ - '/', /* ar_pad_char */ - 15, /* ar_max_namelen */ - 0, /* match priority. */ - - bfd_getl64, bfd_getl_signed_64, bfd_putl64, - bfd_getl32, bfd_getl_signed_32, bfd_putl32, - bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* data */ - bfd_getb64, bfd_getb_signed_64, bfd_putb64, - bfd_getb32, bfd_getb_signed_32, bfd_putb32, - bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* hdrs */ - - { /* bfd_check_format */ - _bfd_dummy_target, - coff_object_p, - bfd_generic_archive_p, - _bfd_dummy_target - }, - { /* bfd_set_format */ - _bfd_bool_bfd_false_error, - coff_mkobject, - _bfd_generic_mkarchive, - _bfd_bool_bfd_false_error - }, - { /* bfd_write_contents */ - _bfd_bool_bfd_false_error, - coff_write_object_contents, - _bfd_write_archive_contents, - _bfd_bool_bfd_false_error - }, - - BFD_JUMP_TABLE_GENERIC (coff), - BFD_JUMP_TABLE_COPY (coff), - BFD_JUMP_TABLE_CORE (_bfd_nocore), - BFD_JUMP_TABLE_ARCHIVE (_bfd_archive_coff), - BFD_JUMP_TABLE_SYMBOLS (coff), - BFD_JUMP_TABLE_RELOCS (coff), - BFD_JUMP_TABLE_WRITE (coff), - BFD_JUMP_TABLE_LINK (coff), - BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic), - - &icoff_le_vec, - - COFF_SWAP_TABLE -}; diff --git a/bfd/coffcode.h b/bfd/coffcode.h index caa8bcb..4a0741a1 100644 --- a/bfd/coffcode.h +++ b/bfd/coffcode.h @@ -40,11 +40,6 @@ SECTION defines the relocations used by the 88k format @xref{Relocations}. - The Intel i960 processor version of coff is implemented in - @file{coff-i960.c}. This file has the same structure as - @file{coff-m88k.c}, except that it includes @file{coff/i960.h} - rather than @file{coff-m88k.h}. - SUBSECTION Porting to a new version of coff @@ -97,15 +92,6 @@ SUBSUBSECTION Some of the Coff targets then also have additional routines in the target source file itself. - For example, @file{coff-i960.c} includes - @file{coff/internal.h} and @file{coff/i960.h}. It then - defines a few constants, such as @code{I960}, and includes - @file{coffcode.h}. Since the i960 has complex relocation - types, @file{coff-i960.c} also includes some code to - manipulate the i960 relocs. This code is not in - @file{coffcode.h} because it would not be used by any other - target. - SUBSUBSECTION Coff long section names @@ -1664,19 +1650,6 @@ coff_bad_format_hook (bfd * abfd ATTRIBUTE_UNUSED, void * filehdr) if (BADMAG (*internal_f)) return FALSE; - /* If the optional header is NULL or not the correct size then - quit; the only difference I can see between m88k dgux headers (MC88DMAGIC) - and Intel 960 readwrite headers (I960WRMAGIC) is that the - optional header is of a different size. - - But the mips keeps extra stuff in it's opthdr, so dont check - when doing that. */ - -#if defined(M88) || defined(I960) - if (internal_f->f_opthdr != 0 && bfd_coff_aoutsz (abfd) != internal_f->f_opthdr) - return FALSE; -#endif - return TRUE; } @@ -1848,12 +1821,6 @@ coff_set_alignment_hook (bfd * abfd ATTRIBUTE_UNUSED, struct internal_scnhdr *hdr = (struct internal_scnhdr *) scnhdr; unsigned int i; -#ifdef I960 - /* Extract ALIGN from 2**ALIGN stored in section header. */ - for (i = 0; i < 32; i++) - if ((1 << i) >= hdr->s_align) - break; -#endif #ifdef COFF_DECODE_ALIGNMENT i = COFF_DECODE_ALIGNMENT(hdr->s_flags); #endif @@ -2235,47 +2202,6 @@ coff_set_arch_mach_hook (bfd *abfd, void * filehdr) } break; #endif -#ifdef I860 - case I860MAGIC: - arch = bfd_arch_i860; - break; -#endif -#ifdef I960 -#ifdef I960ROMAGIC - case I960ROMAGIC: - case I960RWMAGIC: - arch = bfd_arch_i960; - switch (F_I960TYPE & internal_f->f_flags) - { - default: - case F_I960CORE: - machine = bfd_mach_i960_core; - break; - case F_I960KB: - machine = bfd_mach_i960_kb_sb; - break; - case F_I960MC: - machine = bfd_mach_i960_mc; - break; - case F_I960XA: - machine = bfd_mach_i960_xa; - break; - case F_I960CA: - machine = bfd_mach_i960_ca; - break; - case F_I960KA: - machine = bfd_mach_i960_ka_sa; - break; - case F_I960JX: - machine = bfd_mach_i960_jx; - break; - case F_I960HX: - machine = bfd_mach_i960_hx; - break; - } - break; -#endif -#endif #ifdef RS6000COFF_C #ifdef XCOFF64 @@ -2552,31 +2478,7 @@ coff_pointerize_aux_hook (bfd *abfd ATTRIBUTE_UNUSED, } #else -#ifdef I960 - -/* We don't want to pointerize bal entries. */ - -static bfd_boolean -coff_pointerize_aux_hook (bfd *abfd ATTRIBUTE_UNUSED, - combined_entry_type *table_base ATTRIBUTE_UNUSED, - combined_entry_type *symbol, - unsigned int indaux, - combined_entry_type *aux ATTRIBUTE_UNUSED) -{ - /* Return TRUE if we don't want to pointerize this aux entry, which - is the case for the lastfirst aux entry for a C_LEAFPROC symbol. */ - return (indaux == 1 - && symbol->is_sym - && (symbol->u.syment.n_sclass == C_LEAFPROC - || symbol->u.syment.n_sclass == C_LEAFSTAT - || symbol->u.syment.n_sclass == C_LEAFEXT)); -} - -#else /* ! I960 */ - #define coff_pointerize_aux_hook 0 - -#endif /* ! I960 */ #endif /* ! RS6000COFF_C */ /* Print an aux entry. This returns TRUE if it has printed it. */ @@ -2856,32 +2758,6 @@ coff_set_flags (bfd * abfd, return TRUE; #endif -#ifdef I960ROMAGIC - case bfd_arch_i960: - - { - unsigned flags; - - *magicp = I960ROMAGIC; - - switch (bfd_get_mach (abfd)) - { - case bfd_mach_i960_core: flags = F_I960CORE; break; - case bfd_mach_i960_kb_sb: flags = F_I960KB; break; - case bfd_mach_i960_mc: flags = F_I960MC; break; - case bfd_mach_i960_xa: flags = F_I960XA; break; - case bfd_mach_i960_ca: flags = F_I960CA; break; - case bfd_mach_i960_ka_sa: flags = F_I960KA; break; - case bfd_mach_i960_jx: flags = F_I960JX; break; - case bfd_mach_i960_hx: flags = F_I960HX; break; - default: return FALSE; - } - *flagsp = flags; - return TRUE; - } - break; -#endif - #ifdef TIC30MAGIC case bfd_arch_tic30: *magicp = TIC30MAGIC; @@ -2981,12 +2857,6 @@ coff_set_flags (bfd * abfd, return TRUE; #endif -#ifdef I860MAGIC - case bfd_arch_i860: - *magicp = I860MAGIC; - return TRUE; -#endif - #ifdef IA64MAGIC case bfd_arch_ia64: *magicp = IA64MAGIC; @@ -3146,9 +3016,7 @@ sort_by_secaddr (const void * arg1, const void * arg2) /* Calculate the file position for each section. */ -#ifndef I960 #define ALIGN_SECTIONS_IN_FILE -#endif #if defined(TIC80COFF) || defined(TICOFF) #undef ALIGN_SECTIONS_IN_FILE #endif @@ -3389,9 +3257,7 @@ coff_compute_section_file_positions (bfd * abfd) #endif /* Align the sections in the file to the same boundary on - which they are aligned in virtual memory. I960 doesn't - do this (FIXME) so we can stay in sync with Intel. 960 - doesn't yet page from files... */ + which they are aligned in virtual memory. */ #ifdef ALIGN_SECTIONS_IN_FILE if ((abfd->flags & EXEC_P) != 0) { @@ -3855,11 +3721,6 @@ coff_write_object_contents (bfd * abfd) else if (!strcmp (current->name, _BSS)) bss_sec = current; -#ifdef I960 - section.s_align = (current->alignment_power - ? 1 << current->alignment_power - : 0); -#endif #ifdef COFF_ENCODE_ALIGNMENT COFF_ENCODE_ALIGNMENT(section, current->alignment_power); if ((unsigned int)COFF_DECODE_ALIGNMENT(section.s_flags) @@ -4118,15 +3979,6 @@ coff_write_object_contents (bfd * abfd) internal_a.magic = TIC80_ARCH_MAGIC; #define __A_MAGIC_SET__ #endif /* TIC80 */ -#ifdef I860 - /* FIXME: What are the a.out magic numbers for the i860? */ - internal_a.magic = 0; -#define __A_MAGIC_SET__ -#endif /* I860 */ -#ifdef I960 - internal_a.magic = (magic == I960ROMAGIC ? NMAGIC : OMAGIC); -#define __A_MAGIC_SET__ -#endif /* I960 */ #if M88 #define __A_MAGIC_SET__ internal_a.magic = PAGEMAGICBCS; @@ -4820,11 +4672,6 @@ coff_slurp_symbol_table (bfd * abfd) switch (src->u.syment.n_sclass) { -#ifdef I960 - case C_LEAFEXT: - /* Fall through to next case. */ -#endif - case C_EXT: case C_WEAKEXT: #if defined ARM @@ -4918,9 +4765,6 @@ coff_slurp_symbol_table (bfd * abfd) break; case C_STAT: /* Static. */ -#ifdef I960 - case C_LEAFSTAT: /* Static leaf procedure. */ -#endif #if defined ARM case C_THUMBSTAT: /* Thumb static. */ case C_THUMBLABEL: /* Thumb label. */ @@ -4958,11 +4802,6 @@ coff_slurp_symbol_table (bfd * abfd) case C_REGPARM: /* Register parameter. */ case C_REG: /* register variable. */ /* C_AUTOARG conflicts with TI COFF C_UEXT. */ -#if !defined (TIC80COFF) && !defined (TICOFF) -#ifdef C_AUTOARG - case C_AUTOARG: /* 960-specific storage class. */ -#endif -#endif case C_TPDEF: /* Type definition. */ case C_ARG: case C_AUTO: /* Automatic variable. */ @@ -5158,9 +4997,6 @@ coff_classify_symbol (bfd *abfd, { case C_EXT: case C_WEAKEXT: -#ifdef I960 - case C_LEAFEXT: -#endif #ifdef ARM case C_THUMBEXT: case C_THUMBEXTFUNC: @@ -5262,7 +5098,7 @@ SUBSUBSECTION o The reloc index is turned into a pointer to a howto structure, in a back end specific way. For instance, the 386 - and 960 use the @code{r_type} to directly produce an index + uses the @code{r_type} to directly produce an index into a howto table vector; the 88k subtracts a number from the @code{r_type} field and creates an addend field. */ diff --git a/bfd/coffswap.h b/bfd/coffswap.h index 7b000e0..5fec8bf 100644 --- a/bfd/coffswap.h +++ b/bfd/coffswap.h @@ -618,10 +618,6 @@ coff_swap_aouthdr_in (bfd * abfd, void * aouthdr_ext1, void * aouthdr_int1) aouthdr_int->data_start = GET_AOUTHDR_DATA_START (abfd, aouthdr_ext->data_start); -#ifdef I960 - aouthdr_int->tagentries = H_GET_32 (abfd, aouthdr_ext->tagentries); -#endif - #ifdef APOLLO_M68 H_PUT_32 (abfd, aouthdr_int->o_inlib, aouthdr_ext->o_inlib); H_PUT_32 (abfd, aouthdr_int->o_sri, aouthdr_ext->o_sri); @@ -689,10 +685,6 @@ coff_swap_aouthdr_out (bfd * abfd, void * in, void * out) PUT_AOUTHDR_DATA_START (abfd, aouthdr_in->data_start, aouthdr_out->data_start); -#ifdef I960 - H_PUT_32 (abfd, aouthdr_in->tagentries, aouthdr_out->tagentries); -#endif - #ifdef RS6000COFF_C #ifdef XCOFF64 H_PUT_64 (abfd, aouthdr_in->o_toc, aouthdr_out->o_toc); @@ -767,9 +759,6 @@ coff_swap_scnhdr_in (bfd * abfd, void * ext, void * in) scnhdr_int->s_flags = GET_SCNHDR_FLAGS (abfd, scnhdr_ext->s_flags); scnhdr_int->s_nreloc = GET_SCNHDR_NRELOC (abfd, scnhdr_ext->s_nreloc); scnhdr_int->s_nlnno = GET_SCNHDR_NLNNO (abfd, scnhdr_ext->s_nlnno); -#ifdef I960 - scnhdr_int->s_align = GET_SCNHDR_ALIGN (abfd, scnhdr_ext->s_align); -#endif #ifdef COFF_ADJUST_SCNHDR_IN_POST COFF_ADJUST_SCNHDR_IN_POST (abfd, ext, in); #endif @@ -830,9 +819,6 @@ coff_swap_scnhdr_out (bfd * abfd, void * in, void * out) } #endif -#ifdef I960 - PUT_SCNHDR_ALIGN (abfd, scnhdr_int->s_align, scnhdr_ext->s_align); -#endif #ifdef COFF_ADJUST_SCNHDR_OUT_POST COFF_ADJUST_SCNHDR_OUT_POST (abfd, in, out); #endif diff --git a/bfd/config.bfd b/bfd/config.bfd index f04a993..881c48c 100644 --- a/bfd/config.bfd +++ b/bfd/config.bfd @@ -81,8 +81,6 @@ case $targ in i[3-7]86-*-os9k | \ i[3-7]86-none-* | \ i[3-7]86-*-aout* | i[3-7]86*-*-vsta* | \ - i860-*-* | \ - i960-*-* | \ m68*-motorola-sysv* | m68*-hp-bsd* | m68*-*-aout* | \ m68*-*-coff* | m68*-*-sysv* | \ m68*-*-hpux* | \ @@ -115,7 +113,6 @@ case $targ in we32k-*-* | \ w65-*-* | \ *-*-ieee* | \ - *-adobe-* | \ *-sony-* | \ *-tandem-* | \ i370-* | \ @@ -131,13 +128,15 @@ case $targ in esac case $targ in + *-adobe-* | \ *-go32-rtems* | \ *-*-rtemsaout* | \ *-*-rtemscoff* | \ a29k-* | \ arm-*-oabi | \ hppa*-*-rtems* | \ - i960-*-rtems* | \ + i860-*-* | \ + i960-*-* | \ m68*-*-lynxos* | \ m68*-apollo-* | \ m68*-apple-aux* | \ @@ -882,37 +881,6 @@ case "${targ}" in targ_selfvecs="iamcu_elf32_vec i386chaos_vec" ;; - i860-*-mach3* | i860-*-osf1* | i860-*-coff*) - targ_defvec=i860_coff_vec - ;; - i860-stardent-sysv4* | i860-stardent-elf*) - targ_defvec=i860_elf32_le_vec - targ_selvecs="i860_elf32_vec i860_elf32_le_vec" - ;; - i860-*-sysv4* | i860-*-elf*) - targ_defvec=i860_elf32_vec - ;; - - i960-*-vxworks4* | i960-*-vxworks5.0) - targ_defvec=bout_le_vec - targ_selvecs="bout_be_vec icoff_le_vec icoff_be_vec ieee_vec" - targ_underscore=yes - ;; - i960-*-vxworks5.* | i960-*-coff* | i960-*-sysv*) - targ_defvec=icoff_le_vec - targ_selvecs="icoff_be_vec bout_le_vec bout_be_vec ieee_vec" - targ_underscore=yes - ;; - i960-*-vxworks* | i960-*-aout* | i960-*-bout* | i960-*-nindy*) - targ_defvec=bout_le_vec - targ_selvecs="bout_be_vec icoff_le_vec icoff_be_vec ieee_vec" - targ_underscore=yes - ;; - i960-*-elf*) - targ_defvec=i960_elf32_vec - targ_selvecs="icoff_le_vec icoff_be_vec" - ;; - ia16-*-elf) targ_defvec=i386_elf32_vec targ_selvecs="i386_msdos_vec i386_aout_vec" @@ -1854,11 +1822,6 @@ case "${targ}" in targ_defvec=ieee_vec ;; - *-adobe-*) - targ_defvec=aout_adobe_vec - targ_underscore=yes - ;; - *-sony-*) targ_defvec=m68k_aout_newsos3_vec targ_underscore=yes diff --git a/bfd/configure b/bfd/configure index 667f001..f14c96c 100755 --- a/bfd/configure +++ b/bfd/configure @@ -14344,7 +14344,6 @@ do aout0_be_vec) tb="$tb aout0.lo aout32.lo" ;; aout64_vec) tb="$tb demo64.lo aout64.lo"; target_size=64 ;; aout_vec) tb="$tb host-aout.lo aout32.lo" ;; - aout_adobe_vec) tb="$tb aout-adobe.lo aout32.lo" ;; arc_elf32_be_vec) tb="$tb elf32-arc.lo elf32.lo $elf" ;; arc_elf32_le_vec) tb="$tb elf32-arc.lo elf32.lo $elf" ;; arm_aout_be_vec) tb="$tb aout-arm.lo aout32.lo" ;; @@ -14377,8 +14376,6 @@ do avr_elf32_vec) tb="$tb elf32-avr.lo elf32.lo $elf" ;; bfin_elf32_vec) tb="$tb elf32-bfin.lo elf32.lo $elf" ;; bfin_elf32_fdpic_vec) tb="$tb elf32-bfin.lo elf32.lo $elf" ;; - bout_be_vec) tb="$tb bout.lo aout32.lo" ;; - bout_le_vec) tb="$tb bout.lo aout32.lo" ;; cr16_elf32_vec) tb="$tb elf32-cr16.lo elf32.lo $elf" ;; cr16c_elf32_vec) tb="$tb elf32-cr16c.lo elf32.lo $elf" ;; cris_aout_vec) tb="$tb aout-cris.lo" ;; @@ -14431,10 +14428,6 @@ do i386_pe_vec) tb="$tb pe-i386.lo peigen.lo $coff" ;; i386_pei_vec) tb="$tb pei-i386.lo peigen.lo $coff" ;; iamcu_elf32_vec) tb="$tb elf32-i386.lo elfxx-x86.lo elf-ifunc.lo elf-nacl.lo elf-vxworks.lo elf32.lo $elf" ;; - i860_coff_vec) tb="$tb coff-i860.lo $coff" ;; - i860_elf32_vec) tb="$tb elf32-i860.lo elf32.lo $elf" ;; - i860_elf32_le_vec) tb="$tb elf32-i860.lo elf32.lo $elf" ;; - i960_elf32_vec) tb="$tb elf32-i960.lo elf32.lo $elf" ;; ia64_elf32_be_vec) tb="$tb elf32-ia64.lo elfxx-ia64.lo elf32.lo $elf" ;; ia64_elf32_hpux_be_vec) tb="$tb elf32-ia64.lo elfxx-ia64.lo elf32.lo $elf" ;; ia64_elf64_be_vec) tb="$tb elf64-ia64.lo elfxx-ia64.lo elf64.lo $elf"; target_size=64 ;; @@ -14442,8 +14435,6 @@ do ia64_elf64_hpux_be_vec) tb="$tb elf64-ia64.lo elfxx-ia64.lo elf64.lo $elf"; target_size=64 ;; ia64_elf64_vms_vec) tb="$tb elf64-ia64-vms.lo elf64-ia64.lo elfxx-ia64.lo elf64.lo vms-lib.lo vms-misc.lo $elf"; target_size=64 ;; ia64_pei_vec) tb="$tb pei-ia64.lo pepigen.lo $coff"; target_size=64 ;; - icoff_be_vec) tb="$tb coff-i960.lo $coff" ;; - icoff_le_vec) tb="$tb coff-i960.lo $coff" ;; ieee_vec) tb="$tb ieee.lo" ;; ip2k_elf32_vec) tb="$tb elf32-ip2k.lo elf32.lo $elf" ;; iq2000_elf32_vec) tb="$tb elf32-iq2000.lo elf32.lo $elf" ;; @@ -14890,10 +14881,6 @@ if test "${target}" = "${host}"; then ;; i[3-7]86-*-isc*) COREFILE=trad-core.lo ;; i[3-7]86-*-aix*) COREFILE=aix386-core.lo ;; - i860-*-mach3* | i860-*-osf1*) - COREFILE=trad-core.lo - TRAD_HEADER='"hosts/i860mach3.h"' - ;; mips-*-netbsd* | mips*-*-openbsd*) COREFILE=netbsd-core.lo ;; diff --git a/bfd/configure.ac b/bfd/configure.ac index 20e2c02..8eeb5ff 100644 --- a/bfd/configure.ac +++ b/bfd/configure.ac @@ -421,7 +421,6 @@ do aout0_be_vec) tb="$tb aout0.lo aout32.lo" ;; aout64_vec) tb="$tb demo64.lo aout64.lo"; target_size=64 ;; aout_vec) tb="$tb host-aout.lo aout32.lo" ;; - aout_adobe_vec) tb="$tb aout-adobe.lo aout32.lo" ;; arc_elf32_be_vec) tb="$tb elf32-arc.lo elf32.lo $elf" ;; arc_elf32_le_vec) tb="$tb elf32-arc.lo elf32.lo $elf" ;; arm_aout_be_vec) tb="$tb aout-arm.lo aout32.lo" ;; @@ -454,8 +453,6 @@ do avr_elf32_vec) tb="$tb elf32-avr.lo elf32.lo $elf" ;; bfin_elf32_vec) tb="$tb elf32-bfin.lo elf32.lo $elf" ;; bfin_elf32_fdpic_vec) tb="$tb elf32-bfin.lo elf32.lo $elf" ;; - bout_be_vec) tb="$tb bout.lo aout32.lo" ;; - bout_le_vec) tb="$tb bout.lo aout32.lo" ;; cr16_elf32_vec) tb="$tb elf32-cr16.lo elf32.lo $elf" ;; cr16c_elf32_vec) tb="$tb elf32-cr16c.lo elf32.lo $elf" ;; cris_aout_vec) tb="$tb aout-cris.lo" ;; @@ -508,10 +505,6 @@ do i386_pe_vec) tb="$tb pe-i386.lo peigen.lo $coff" ;; i386_pei_vec) tb="$tb pei-i386.lo peigen.lo $coff" ;; iamcu_elf32_vec) tb="$tb elf32-i386.lo elfxx-x86.lo elf-ifunc.lo elf-nacl.lo elf-vxworks.lo elf32.lo $elf" ;; - i860_coff_vec) tb="$tb coff-i860.lo $coff" ;; - i860_elf32_vec) tb="$tb elf32-i860.lo elf32.lo $elf" ;; - i860_elf32_le_vec) tb="$tb elf32-i860.lo elf32.lo $elf" ;; - i960_elf32_vec) tb="$tb elf32-i960.lo elf32.lo $elf" ;; ia64_elf32_be_vec) tb="$tb elf32-ia64.lo elfxx-ia64.lo elf32.lo $elf" ;; ia64_elf32_hpux_be_vec) tb="$tb elf32-ia64.lo elfxx-ia64.lo elf32.lo $elf" ;; ia64_elf64_be_vec) tb="$tb elf64-ia64.lo elfxx-ia64.lo elf64.lo $elf"; target_size=64 ;; @@ -519,8 +512,6 @@ do ia64_elf64_hpux_be_vec) tb="$tb elf64-ia64.lo elfxx-ia64.lo elf64.lo $elf"; target_size=64 ;; ia64_elf64_vms_vec) tb="$tb elf64-ia64-vms.lo elf64-ia64.lo elfxx-ia64.lo elf64.lo vms-lib.lo vms-misc.lo $elf"; target_size=64 ;; ia64_pei_vec) tb="$tb pei-ia64.lo pepigen.lo $coff"; target_size=64 ;; - icoff_be_vec) tb="$tb coff-i960.lo $coff" ;; - icoff_le_vec) tb="$tb coff-i960.lo $coff" ;; ieee_vec) tb="$tb ieee.lo" ;; ip2k_elf32_vec) tb="$tb elf32-ip2k.lo elf32.lo $elf" ;; iq2000_elf32_vec) tb="$tb elf32-iq2000.lo elf32.lo $elf" ;; @@ -976,10 +967,6 @@ changequote(,)dnl i[3-7]86-*-isc*) COREFILE=trad-core.lo ;; i[3-7]86-*-aix*) COREFILE=aix386-core.lo ;; changequote([,])dnl - i860-*-mach3* | i860-*-osf1*) - COREFILE=trad-core.lo - TRAD_HEADER='"hosts/i860mach3.h"' - ;; mips-*-netbsd* | mips*-*-openbsd*) COREFILE=netbsd-core.lo ;; diff --git a/bfd/cpu-i860.c b/bfd/cpu-i860.c deleted file mode 100644 index 7f6eb4b..0000000 --- a/bfd/cpu-i860.c +++ /dev/null @@ -1,42 +0,0 @@ -/* BFD support for the Intel 860 architecture. - Copyright (C) 1992-2018 Free Software Foundation, Inc. - Created mostly by substituting "860" for "386" in cpu-i386.c - Harry Dolan <dolan@ssd.intel.com>, October 1995 - - 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" - -const bfd_arch_info_type bfd_i860_arch = - { - 32, /* 32 bits in a word */ - 32, /* 32 bits in an address */ - 8, /* 8 bits in a byte */ - bfd_arch_i860, /* Architecture */ - 0, /* Only one machine */ - "i860", /* Architecture name */ - "i860", /* Printable name */ - 3, /* Section alignment exponent */ - TRUE, /* Is this the default architecture? */ - bfd_default_compatible, - bfd_default_scan, - bfd_arch_default_fill, - 0, /* Next in list */ - }; diff --git a/bfd/cpu-i960.c b/bfd/cpu-i960.c deleted file mode 100644 index f1333db..0000000 --- a/bfd/cpu-i960.c +++ /dev/null @@ -1,172 +0,0 @@ -/* BFD library support routines for the i960 architecture. - Copyright (C) 1990-2018 Free Software Foundation, Inc. - Hacked by Steve Chamberlain of Cygnus Support. - - 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" - -/* This routine is provided a string, and tries to work out if it - could possibly refer to the i960 machine pointed at in the - info_struct pointer */ - -static bfd_boolean -scan_960_mach (const bfd_arch_info_type *ap, - const char *string) -{ - unsigned long machine; - int fail_because_not_80960 = FALSE; - - /* Look for the string i960 at the front of the string. */ - if (strncasecmp ("i960", string, 4) == 0) - { - string += 4; - - /* i960 on it's own means core to us. */ - if (* string == 0) - return ap->mach == bfd_mach_i960_core; - - /* "i960:*" is valid, anything else is not. */ - if (* string != ':') - return FALSE; - - string ++; - } - /* In some bfds the cpu-id is written as "80960KA", "80960KB", - "80960CA" or "80960MC". */ - else if (CONST_STRNEQ (string, "80960")) - { - string += 5; - - /* Set this to TRUE here. If a correct matching postfix - is detected below it will be reset to FALSE. */ - fail_because_not_80960 = TRUE; - } - /* No match, can't be us. */ - else - return FALSE; - - if (* string == '\0') - return FALSE; - - if (string[0] == 'c' && string[1] == 'o' && string[2] == 'r' && - string[3] == 'e' && string[4] == '\0') - machine = bfd_mach_i960_core; - else if (strcasecmp (string, "ka_sa") == 0) - machine = bfd_mach_i960_ka_sa; - else if (strcasecmp (string, "kb_sb") == 0) - machine = bfd_mach_i960_kb_sb; - else if (string[1] == '\0' || string[2] != '\0') /* rest are 2-char. */ - return FALSE; - else if (string[0] == 'k' && string[1] == 'b') - { machine = bfd_mach_i960_kb_sb; fail_because_not_80960 = FALSE; } - else if (string[0] == 's' && string[1] == 'b') - machine = bfd_mach_i960_kb_sb; - else if (string[0] == 'm' && string[1] == 'c') - { machine = bfd_mach_i960_mc; fail_because_not_80960 = FALSE; } - else if (string[0] == 'x' && string[1] == 'a') - machine = bfd_mach_i960_xa; - else if (string[0] == 'c' && string[1] == 'a') - { machine = bfd_mach_i960_ca; fail_because_not_80960 = FALSE; } - else if (string[0] == 'k' && string[1] == 'a') - { machine = bfd_mach_i960_ka_sa; fail_because_not_80960 = FALSE; } - else if (string[0] == 's' && string[1] == 'a') - machine = bfd_mach_i960_ka_sa; - else if (string[0] == 'j' && string[1] == 'x') - machine = bfd_mach_i960_jx; - else if (string[0] == 'h' && string[1] == 'x') - machine = bfd_mach_i960_hx; - else - return FALSE; - - if (fail_because_not_80960) - return FALSE; - - if (machine == ap->mach) - return TRUE; - - return FALSE; -} - -/* This routine is provided two arch_infos and works out the i960 - machine which would be compatible with both and returns a pointer - to its info structure */ - -static const bfd_arch_info_type * -compatible (const bfd_arch_info_type *a, - const bfd_arch_info_type *b) -{ - - /* The i960 has distinct subspecies which may not interbreed: - CORE CA - CORE KA KB MC XA - CORE HX JX - Any architecture on the same line is compatible, the one on - the right is the least restrictive. - - We represent this information in an array, each machine to a side */ - -#define ERROR 0 -#define CORE bfd_mach_i960_core /*1*/ -#define KA bfd_mach_i960_ka_sa /*2*/ -#define KB bfd_mach_i960_kb_sb /*3*/ -#define MC bfd_mach_i960_mc /*4*/ -#define XA bfd_mach_i960_xa /*5*/ -#define CA bfd_mach_i960_ca /*6*/ -#define JX bfd_mach_i960_jx /*7*/ -#define HX bfd_mach_i960_hx /*8*/ -#define MAX_ARCH ((int)HX) - - static const unsigned long matrix[MAX_ARCH+1][MAX_ARCH+1] = - { - { ERROR, CORE, KA, KB, MC, XA, CA, JX, HX }, - { CORE, CORE, KA, KB, MC, XA, CA, JX, HX }, - { KA, KA, KA, KB, MC, XA, ERROR, ERROR, ERROR}, - { KB, KB, KB, KB, MC, XA, ERROR, ERROR, ERROR}, - { MC, MC, MC, MC, MC, XA, ERROR, ERROR, ERROR}, - { XA, XA, XA, XA, XA, XA, ERROR, ERROR, ERROR}, - { CA, CA, ERROR, ERROR, ERROR, ERROR, CA, ERROR, ERROR}, - { JX, JX, ERROR, ERROR, ERROR, ERROR, ERROR, JX, HX }, - { HX, HX, ERROR, ERROR, ERROR, ERROR, ERROR, HX, HX }, - }; - - if (a->arch != b->arch || matrix[a->mach][b->mach] == ERROR) - return NULL; - - return (a->mach == matrix[a->mach][b->mach]) ? a : b; -} - -#define N(a,b,d,n) \ -{ 32, 32, 8,bfd_arch_i960,a,"i960",b,3,d,compatible,scan_960_mach, \ - bfd_arch_default_fill, n,} - -static const bfd_arch_info_type arch_info_struct[] = -{ - N(bfd_mach_i960_ka_sa,"i960:ka_sa",FALSE, &arch_info_struct[1]), - N(bfd_mach_i960_kb_sb,"i960:kb_sb",FALSE, &arch_info_struct[2]), - N(bfd_mach_i960_mc, "i960:mc", FALSE, &arch_info_struct[3]), - N(bfd_mach_i960_xa, "i960:xa", FALSE, &arch_info_struct[4]), - N(bfd_mach_i960_ca, "i960:ca", FALSE, &arch_info_struct[5]), - N(bfd_mach_i960_jx, "i960:jx", FALSE, &arch_info_struct[6]), - N(bfd_mach_i960_hx, "i960:hx", FALSE, 0), -}; - -const bfd_arch_info_type bfd_i960_arch = - N(bfd_mach_i960_core, "i960:core", TRUE, &arch_info_struct[0]); diff --git a/bfd/elf32-i860.c b/bfd/elf32-i860.c deleted file mode 100644 index d588dc5..0000000 --- a/bfd/elf32-i860.c +++ /dev/null @@ -1,1274 +0,0 @@ -/* Intel i860 specific support for 32-bit ELF. - Copyright (C) 1993-2018 Free Software Foundation, Inc. - - Full i860 support contributed by Jason Eckhardt <jle@cygnus.com>. - - 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" -#include "elf-bfd.h" -#include "elf/i860.h" - -/* special_function for R_860_PC26 relocation. */ -static bfd_reloc_status_type -i860_howto_pc26_reloc (bfd *abfd ATTRIBUTE_UNUSED, - arelent *reloc_entry, - asymbol *symbol, - void *data ATTRIBUTE_UNUSED, - asection *input_section, - bfd *output_bfd, - char **error_message ATTRIBUTE_UNUSED) -{ - bfd_vma insn; - bfd_vma relocation; - bfd_byte *addr; - - if (output_bfd != NULL - && (symbol->flags & BSF_SECTION_SYM) == 0 - && (! reloc_entry->howto->partial_inplace - || reloc_entry->addend == 0)) - { - reloc_entry->address += input_section->output_offset; - return bfd_reloc_ok; - } - - /* Used elf32-mips.c as an example. */ - if (bfd_is_und_section (symbol->section) - && output_bfd == (bfd *) NULL) - return bfd_reloc_undefined; - - if (bfd_is_com_section (symbol->section)) - relocation = 0; - else - relocation = symbol->value; - - relocation += symbol->section->output_section->vma; - relocation += symbol->section->output_offset; - relocation += reloc_entry->addend; - - if (reloc_entry->address > bfd_get_section_limit (abfd, input_section)) - return bfd_reloc_outofrange; - - /* Adjust for PC-relative relocation. */ - relocation -= (input_section->output_section->vma - + input_section->output_offset - + reloc_entry->address - + 4); - - /* Check for target out of range. */ - if ((bfd_signed_vma)relocation > (0x3ffffff << 2) - || (bfd_signed_vma)relocation < (-0x4000000 * 4)) - return bfd_reloc_outofrange; - - addr = (bfd_byte *) data + reloc_entry->address; - insn = bfd_get_32 (abfd, addr); - - relocation >>= reloc_entry->howto->rightshift; - insn = (insn & ~reloc_entry->howto->dst_mask) - | (relocation & reloc_entry->howto->dst_mask); - - bfd_put_32 (abfd, (bfd_vma) insn, addr); - - return bfd_reloc_ok; -} - -/* special_function for R_860_PC16 relocation. */ -static bfd_reloc_status_type -i860_howto_pc16_reloc (bfd *abfd, - arelent *reloc_entry, - asymbol *symbol, - void *data, - asection *input_section, - bfd *output_bfd, - char **error_message ATTRIBUTE_UNUSED) -{ - bfd_vma insn; - bfd_vma relocation; - bfd_byte *addr; - - if (output_bfd != NULL - && (symbol->flags & BSF_SECTION_SYM) == 0 - && (! reloc_entry->howto->partial_inplace - || reloc_entry->addend == 0)) - { - reloc_entry->address += input_section->output_offset; - return bfd_reloc_ok; - } - - /* Used elf32-mips.c as an example. */ - if (bfd_is_und_section (symbol->section) - && output_bfd == (bfd *) NULL) - return bfd_reloc_undefined; - - if (bfd_is_com_section (symbol->section)) - relocation = 0; - else - relocation = symbol->value; - - relocation += symbol->section->output_section->vma; - relocation += symbol->section->output_offset; - relocation += reloc_entry->addend; - - if (reloc_entry->address > bfd_get_section_limit (abfd, input_section)) - return bfd_reloc_outofrange; - - /* Adjust for PC-relative relocation. */ - relocation -= (input_section->output_section->vma - + input_section->output_offset - + reloc_entry->address - + 4); - - /* Check for target out of range. */ - if ((bfd_signed_vma)relocation > (0x7fff << 2) - || (bfd_signed_vma)relocation < (-0x8000 * 4)) - return bfd_reloc_outofrange; - - addr = (bfd_byte *) data + reloc_entry->address; - insn = bfd_get_32 (abfd, addr); - - relocation >>= reloc_entry->howto->rightshift; - relocation = (((relocation & 0xf800) << 5) | (relocation & 0x7ff)) - & reloc_entry->howto->dst_mask; - insn = (insn & ~reloc_entry->howto->dst_mask) | relocation; - - bfd_put_32 (abfd, (bfd_vma) insn, addr); - - return bfd_reloc_ok; -} - -/* special_function for R_860_HIGHADJ relocation. */ -static bfd_reloc_status_type -i860_howto_highadj_reloc (bfd *abfd, - arelent *reloc_entry, - asymbol *symbol, - void *data, - asection *input_section, - bfd *output_bfd, - char **error_message ATTRIBUTE_UNUSED) -{ - bfd_vma insn; - bfd_vma relocation; - bfd_byte *addr; - - if (output_bfd != NULL - && (symbol->flags & BSF_SECTION_SYM) == 0 - && (! reloc_entry->howto->partial_inplace - || reloc_entry->addend == 0)) - { - reloc_entry->address += input_section->output_offset; - return bfd_reloc_ok; - } - - /* Used elf32-mips.c as an example. */ - if (bfd_is_und_section (symbol->section) - && output_bfd == (bfd *) NULL) - return bfd_reloc_undefined; - - if (bfd_is_com_section (symbol->section)) - relocation = 0; - else - relocation = symbol->value; - - relocation += symbol->section->output_section->vma; - relocation += symbol->section->output_offset; - relocation += reloc_entry->addend; - relocation += 0x8000; - - if (reloc_entry->address > bfd_get_section_limit (abfd, input_section)) - return bfd_reloc_outofrange; - - addr = (bfd_byte *) data + reloc_entry->address; - insn = bfd_get_32 (abfd, addr); - - relocation = ((relocation >> 16) & 0xffff); - - insn = (insn & 0xffff0000) | relocation; - - bfd_put_32 (abfd, (bfd_vma) insn, addr); - - return bfd_reloc_ok; -} - -/* special_function for R_860_SPLITn relocations. */ -static bfd_reloc_status_type -i860_howto_splitn_reloc (bfd *abfd, - arelent *reloc_entry, - asymbol *symbol, - void *data, - asection *input_section, - bfd *output_bfd, - char **error_message ATTRIBUTE_UNUSED) -{ - bfd_vma insn; - bfd_vma relocation; - bfd_byte *addr; - - if (output_bfd != NULL - && (symbol->flags & BSF_SECTION_SYM) == 0 - && (! reloc_entry->howto->partial_inplace - || reloc_entry->addend == 0)) - { - reloc_entry->address += input_section->output_offset; - return bfd_reloc_ok; - } - - /* Used elf32-mips.c as an example. */ - if (bfd_is_und_section (symbol->section) - && output_bfd == (bfd *) NULL) - return bfd_reloc_undefined; - - if (bfd_is_com_section (symbol->section)) - relocation = 0; - else - relocation = symbol->value; - - relocation += symbol->section->output_section->vma; - relocation += symbol->section->output_offset; - relocation += reloc_entry->addend; - - if (reloc_entry->address > bfd_get_section_limit (abfd, input_section)) - return bfd_reloc_outofrange; - - addr = (bfd_byte *) data + reloc_entry->address; - insn = bfd_get_32 (abfd, addr); - - relocation = (((relocation & 0xf800) << 5) | (relocation & 0x7ff)) - & reloc_entry->howto->dst_mask; - insn = (insn & ~reloc_entry->howto->dst_mask) | relocation; - - bfd_put_32 (abfd, (bfd_vma) insn, addr); - - return bfd_reloc_ok; -} - -/* This howto table is preliminary. */ -static reloc_howto_type elf32_i860_howto_table [] = -{ - /* This relocation does nothing. */ - HOWTO (R_860_NONE, /* type */ - 0, /* rightshift */ - 3, /* size (0 = byte, 1 = short, 2 = long) */ - 0, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_NONE", /* name */ - FALSE, /* partial_inplace */ - 0, /* src_mask */ - 0, /* dst_mask */ - FALSE), /* pcrel_offset */ - - /* A 32-bit absolute relocation. */ - HOWTO (R_860_32, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_32", /* name */ - FALSE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_COPY, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_COPY", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_GLOB_DAT, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_GLOB_DAT", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_JUMP_SLOT, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_JUMP_SLOT", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_RELATIVE, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_RELATIVE", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - /* A 26-bit PC-relative relocation. */ - HOWTO (R_860_PC26, /* type */ - 2, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 26, /* bitsize */ - TRUE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - i860_howto_pc26_reloc, /* special_function */ - "R_860_PC26", /* name */ - FALSE, /* partial_inplace */ - 0x3ffffff, /* src_mask */ - 0x3ffffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_PLT26, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 26, /* bitsize */ - TRUE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_PLT26", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - /* A 16-bit PC-relative relocation. */ - HOWTO (R_860_PC16, /* type */ - 2, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - TRUE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - i860_howto_pc16_reloc, /* special_function */ - "R_860_PC16", /* name */ - FALSE, /* partial_inplace */ - 0x1f07ff, /* src_mask */ - 0x1f07ff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_LOW0, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOW0", /* name */ - FALSE, /* partial_inplace */ - 0xffff, /* src_mask */ - 0xffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_SPLIT0, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - i860_howto_splitn_reloc, /* special_function */ - "R_860_SPLIT0", /* name */ - FALSE, /* partial_inplace */ - 0x1f07ff, /* src_mask */ - 0x1f07ff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_LOW1, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOW1", /* name */ - FALSE, /* partial_inplace */ - 0xfffe, /* src_mask */ - 0xfffe, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_SPLIT1, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - i860_howto_splitn_reloc, /* special_function */ - "R_860_SPLIT1", /* name */ - FALSE, /* partial_inplace */ - 0x1f07fe, /* src_mask */ - 0x1f07fe, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_LOW2, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOW2", /* name */ - FALSE, /* partial_inplace */ - 0xfffc, /* src_mask */ - 0xfffc, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_SPLIT2, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - i860_howto_splitn_reloc, /* special_function */ - "R_860_SPLIT2", /* name */ - FALSE, /* partial_inplace */ - 0x1f07fc, /* src_mask */ - 0x1f07fc, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_LOW3, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOW3", /* name */ - FALSE, /* partial_inplace */ - 0xfff8, /* src_mask */ - 0xfff8, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_LOGOT0, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOGOT0", /* name */ - FALSE, /* partial_inplace */ - 0, /* src_mask */ - 0xffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_SPGOT0, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_SPGOT0", /* name */ - FALSE, /* partial_inplace */ - 0, /* src_mask */ - 0xffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_LOGOT1, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOGOT1", /* name */ - FALSE, /* partial_inplace */ - 0, /* src_mask */ - 0xffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_SPGOT1, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_SPGOT1", /* name */ - FALSE, /* partial_inplace */ - 0, /* src_mask */ - 0xffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_LOGOTOFF0, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOGOTOFF0", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_SPGOTOFF0, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_SPGOTOFF0", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_LOGOTOFF1, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOGOTOFF1", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_SPGOTOFF1, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_SPGOTOFF1", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_LOGOTOFF2, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOGOTOFF2", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_LOGOTOFF3, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOGOTOFF3", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_LOPC, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - TRUE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_LOPC", /* name */ - FALSE, /* partial_inplace */ - 0xffff, /* src_mask */ - 0xffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_HIGHADJ, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - i860_howto_highadj_reloc, /* special_function */ - "R_860_HIGHADJ", /* name */ - FALSE, /* partial_inplace */ - 0xffff, /* src_mask */ - 0xffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_HAGOT, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_HAGOT", /* name */ - FALSE, /* partial_inplace */ - 0, /* src_mask */ - 0xffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_HAGOTOFF, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_HAGOTOFF", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_HAPC, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - TRUE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_bitfield, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_HAPC", /* name */ - FALSE, /* partial_inplace */ - 0xffff, /* src_mask */ - 0xffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_HIGH, /* type */ - 16, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_HIGH", /* name */ - FALSE, /* partial_inplace */ - 0xffff, /* src_mask */ - 0xffff, /* dst_mask */ - FALSE), /* pcrel_offset */ - - HOWTO (R_860_HIGOT, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 16, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_HIGOT", /* name */ - FALSE, /* partial_inplace */ - 0, /* src_mask */ - 0xffff, /* dst_mask */ - TRUE), /* pcrel_offset */ - - HOWTO (R_860_HIGOTOFF, /* type */ - 0, /* rightshift */ - 2, /* size (0 = byte, 1 = short, 2 = long) */ - 32, /* bitsize */ - FALSE, /* pc_relative */ - 0, /* bitpos */ - complain_overflow_dont, /* complain_on_overflow */ - bfd_elf_generic_reloc, /* special_function */ - "R_860_HIGOTOFF", /* name */ - TRUE, /* partial_inplace */ - 0xffffffff, /* src_mask */ - 0xffffffff, /* dst_mask */ - FALSE), /* pcrel_offset */ -}; - -static unsigned char elf_code_to_howto_index[R_860_max + 1]; - -static reloc_howto_type * -lookup_howto (bfd *abfd, unsigned int rtype) -{ - static int initialized = 0; - int i; - int howto_tbl_size = (int) (sizeof (elf32_i860_howto_table) - / sizeof (elf32_i860_howto_table[0])); - reloc_howto_type *howto = NULL; - - if (! initialized) - { - initialized = 1; - memset (elf_code_to_howto_index, 0xff, - sizeof (elf_code_to_howto_index)); - for (i = 0; i < howto_tbl_size; i++) - elf_code_to_howto_index[elf32_i860_howto_table[i].type] = i; - } - - if (rtype < R_860_max) - { - i = elf_code_to_howto_index[rtype]; - if (i < howto_tbl_size) - howto = elf32_i860_howto_table + i; - } - if (howto == NULL) - { - _bfd_error_handler (_("%pB: unsupported relocation type %#x"), - abfd, rtype); - bfd_set_error (bfd_error_bad_value); - } - return howto; -} - -/* Given a BFD reloc, return the matching HOWTO structure. */ -static reloc_howto_type * -elf32_i860_reloc_type_lookup (bfd *abfd, bfd_reloc_code_real_type code) -{ - unsigned int rtype; - - switch (code) - { - case BFD_RELOC_NONE: - rtype = R_860_NONE; - break; - case BFD_RELOC_32: - rtype = R_860_32; - break; - case BFD_RELOC_860_COPY: - rtype = R_860_COPY; - break; - case BFD_RELOC_860_GLOB_DAT: - rtype = R_860_GLOB_DAT; - break; - case BFD_RELOC_860_JUMP_SLOT: - rtype = R_860_JUMP_SLOT; - break; - case BFD_RELOC_860_RELATIVE: - rtype = R_860_RELATIVE; - break; - case BFD_RELOC_860_PC26: - rtype = R_860_PC26; - break; - case BFD_RELOC_860_PLT26: - rtype = R_860_PLT26; - break; - case BFD_RELOC_860_PC16: - rtype = R_860_PC16; - break; - case BFD_RELOC_860_LOW0: - rtype = R_860_LOW0; - break; - case BFD_RELOC_860_SPLIT0: - rtype = R_860_SPLIT0; - break; - case BFD_RELOC_860_LOW1: - rtype = R_860_LOW1; - break; - case BFD_RELOC_860_SPLIT1: - rtype = R_860_SPLIT1; - break; - case BFD_RELOC_860_LOW2: - rtype = R_860_LOW2; - break; - case BFD_RELOC_860_SPLIT2: - rtype = R_860_SPLIT2; - break; - case BFD_RELOC_860_LOW3: - rtype = R_860_LOW3; - break; - case BFD_RELOC_860_LOGOT0: - rtype = R_860_LOGOT0; - break; - case BFD_RELOC_860_SPGOT0: - rtype = R_860_SPGOT0; - break; - case BFD_RELOC_860_LOGOT1: - rtype = R_860_LOGOT1; - break; - case BFD_RELOC_860_SPGOT1: - rtype = R_860_SPGOT1; - break; - case BFD_RELOC_860_LOGOTOFF0: - rtype = R_860_LOGOTOFF0; - break; - case BFD_RELOC_860_SPGOTOFF0: - rtype = R_860_SPGOTOFF0; - break; - case BFD_RELOC_860_LOGOTOFF1: - rtype = R_860_LOGOTOFF1; - break; - case BFD_RELOC_860_SPGOTOFF1: - rtype = R_860_SPGOTOFF1; - break; - case BFD_RELOC_860_LOGOTOFF2: - rtype = R_860_LOGOTOFF2; - break; - case BFD_RELOC_860_LOGOTOFF3: - rtype = R_860_LOGOTOFF3; - break; - case BFD_RELOC_860_LOPC: - rtype = R_860_LOPC; - break; - case BFD_RELOC_860_HIGHADJ: - rtype = R_860_HIGHADJ; - break; - case BFD_RELOC_860_HAGOT: - rtype = R_860_HAGOT; - break; - case BFD_RELOC_860_HAGOTOFF: - rtype = R_860_HAGOTOFF; - break; - case BFD_RELOC_860_HAPC: - rtype = R_860_HAPC; - break; - case BFD_RELOC_860_HIGH: - rtype = R_860_HIGH; - break; - case BFD_RELOC_860_HIGOT: - rtype = R_860_HIGOT; - break; - case BFD_RELOC_860_HIGOTOFF: - rtype = R_860_HIGOTOFF; - break; - default: - return NULL; - } - return lookup_howto (abfd, rtype); -} - -static reloc_howto_type * -elf32_i860_reloc_name_lookup (bfd *abfd ATTRIBUTE_UNUSED, - const char *r_name) -{ - unsigned int i; - - for (i = 0; - i < (sizeof (elf32_i860_howto_table) - / sizeof (elf32_i860_howto_table[0])); - i++) - if (elf32_i860_howto_table[i].name != NULL - && strcasecmp (elf32_i860_howto_table[i].name, r_name) == 0) - return &elf32_i860_howto_table[i]; - - return NULL; -} - -/* Given a ELF reloc, return the matching HOWTO structure. */ - -static bfd_boolean -elf32_i860_info_to_howto_rela (bfd *abfd, - arelent *bfd_reloc, - Elf_Internal_Rela *elf_reloc) -{ - bfd_reloc->howto - = lookup_howto (abfd, (unsigned) ELF32_R_TYPE (elf_reloc->r_info)); - return bfd_reloc->howto != NULL; -} - -/* Specialized relocation handler for R_860_SPLITn. These relocations - involves a 16-bit field that is split into two contiguous parts. */ -static bfd_reloc_status_type -elf32_i860_relocate_splitn (bfd *input_bfd, - Elf_Internal_Rela *rello, - bfd_byte *contents, - bfd_vma value) -{ - bfd_vma insn; - reloc_howto_type *howto; - howto = lookup_howto (input_bfd, (unsigned) ELF32_R_TYPE (rello->r_info)); - insn = bfd_get_32 (input_bfd, contents + rello->r_offset); - - /* Relocate. */ - value += rello->r_addend; - - /* Separate the fields and insert. */ - value = (((value & 0xf800) << 5) | (value & 0x7ff)) & howto->dst_mask; - insn = (insn & ~howto->dst_mask) | value; - - bfd_put_32 (input_bfd, insn, contents + rello->r_offset); - return bfd_reloc_ok; -} - -/* Specialized relocation handler for R_860_PC16. This relocation - involves a 16-bit, PC-relative field that is split into two contiguous - parts. */ -static bfd_reloc_status_type -elf32_i860_relocate_pc16 (bfd *input_bfd, - asection *input_section, - Elf_Internal_Rela *rello, - bfd_byte *contents, - bfd_vma value) -{ - bfd_vma insn; - reloc_howto_type *howto; - howto = lookup_howto (input_bfd, (unsigned) ELF32_R_TYPE (rello->r_info)); - insn = bfd_get_32 (input_bfd, contents + rello->r_offset); - - /* Adjust for PC-relative relocation. */ - value -= (input_section->output_section->vma - + input_section->output_offset); - value -= rello->r_offset; - - /* Relocate. */ - value += rello->r_addend; - - /* Adjust the value by 4, then separate the fields and insert. */ - value = (value - 4) >> howto->rightshift; - value = (((value & 0xf800) << 5) | (value & 0x7ff)) & howto->dst_mask; - insn = (insn & ~howto->dst_mask) | value; - - bfd_put_32 (input_bfd, insn, contents + rello->r_offset); - return bfd_reloc_ok; - -} - -/* Specialized relocation handler for R_860_PC26. This relocation - involves a 26-bit, PC-relative field which must be adjusted by 4. */ -static bfd_reloc_status_type -elf32_i860_relocate_pc26 (bfd *input_bfd, - asection *input_section, - Elf_Internal_Rela *rello, - bfd_byte *contents, - bfd_vma value) -{ - bfd_vma insn; - reloc_howto_type *howto; - howto = lookup_howto (input_bfd, (unsigned) ELF32_R_TYPE (rello->r_info)); - insn = bfd_get_32 (input_bfd, contents + rello->r_offset); - - /* Adjust for PC-relative relocation. */ - value -= (input_section->output_section->vma - + input_section->output_offset); - value -= rello->r_offset; - - /* Relocate. */ - value += rello->r_addend; - - /* Adjust value by 4 and insert the field. */ - value = ((value - 4) >> howto->rightshift) & howto->dst_mask; - insn = (insn & ~howto->dst_mask) | value; - - bfd_put_32 (input_bfd, insn, contents + rello->r_offset); - return bfd_reloc_ok; - -} - -/* Specialized relocation handler for R_860_HIGHADJ. */ -static bfd_reloc_status_type -elf32_i860_relocate_highadj (bfd *input_bfd, - Elf_Internal_Rela *rel, - bfd_byte *contents, - bfd_vma value) -{ - bfd_vma insn; - - insn = bfd_get_32 (input_bfd, contents + rel->r_offset); - - value += rel->r_addend; - value += 0x8000; - value = ((value >> 16) & 0xffff); - - insn = (insn & 0xffff0000) | value; - - bfd_put_32 (input_bfd, insn, contents + rel->r_offset); - return bfd_reloc_ok; -} - -/* Perform a single relocation. By default we use the standard BFD - routines. However, we handle some specially. */ -static bfd_reloc_status_type -i860_final_link_relocate (reloc_howto_type *howto, - bfd *input_bfd, - asection *input_section, - bfd_byte *contents, - Elf_Internal_Rela *rel, - bfd_vma relocation) -{ - return _bfd_final_link_relocate (howto, input_bfd, input_section, - contents, rel->r_offset, relocation, - rel->r_addend); -} - -/* Relocate an i860 ELF section. - - This is boiler-plate code copied from fr30. - - The RELOCATE_SECTION function is called by the new ELF backend linker - to handle the relocations for a section. - - The relocs are always passed as Rela structures; if the section - actually uses Rel structures, the r_addend field will always be - zero. - - This function is responsible for adjusting the section contents as - necessary, and (if using Rela relocs and generating a relocatable - output file) adjusting the reloc addend as necessary. - - This function does not have to worry about setting the reloc - address or the reloc symbol index. - - LOCAL_SYMS is a pointer to the swapped in local symbols. - - LOCAL_SECTIONS is an array giving the section in the input file - corresponding to the st_shndx field of each local symbol. - - The global hash table entry for the global symbols can be found - via elf_sym_hashes (input_bfd). - - When generating relocatable output, this function must handle - STB_LOCAL/STT_SECTION symbols specially. The output symbol is - going to be the section symbol corresponding to the output - section, which means that the addend must be adjusted - accordingly. */ -static bfd_boolean -elf32_i860_relocate_section (bfd *output_bfd ATTRIBUTE_UNUSED, - struct bfd_link_info *info, - bfd *input_bfd, - asection *input_section, - bfd_byte *contents, - Elf_Internal_Rela *relocs, - Elf_Internal_Sym *local_syms, - asection **local_sections) -{ - Elf_Internal_Shdr *symtab_hdr; - struct elf_link_hash_entry **sym_hashes; - Elf_Internal_Rela *rel; - Elf_Internal_Rela *relend; - - symtab_hdr = & elf_tdata (input_bfd)->symtab_hdr; - sym_hashes = elf_sym_hashes (input_bfd); - relend = relocs + input_section->reloc_count; - - for (rel = relocs; rel < relend; rel ++) - { - reloc_howto_type * howto; - unsigned long r_symndx; - Elf_Internal_Sym * sym; - asection * sec; - struct elf_link_hash_entry * h; - bfd_vma relocation; - bfd_reloc_status_type r; - const char * name = NULL; - int r_type; - - r_type = ELF32_R_TYPE (rel->r_info); - r_symndx = ELF32_R_SYM (rel->r_info); - - howto = lookup_howto (input_bfd, (unsigned) ELF32_R_TYPE (rel->r_info)); - h = NULL; - sym = NULL; - sec = NULL; - - if (r_symndx < symtab_hdr->sh_info) - { - sym = local_syms + r_symndx; - sec = local_sections [r_symndx]; - relocation = _bfd_elf_rela_local_sym (output_bfd, sym, &sec, rel); - - name = bfd_elf_string_from_elf_section - (input_bfd, symtab_hdr->sh_link, sym->st_name); - name = (name == NULL) ? bfd_section_name (input_bfd, sec) : name; - } - else - { - bfd_boolean unresolved_reloc, warned, ignored; - - RELOC_FOR_GLOBAL_SYMBOL (info, input_bfd, input_section, rel, - r_symndx, symtab_hdr, sym_hashes, - h, sec, relocation, - unresolved_reloc, warned, ignored); - } - - if (sec != NULL && discarded_section (sec)) - RELOC_AGAINST_DISCARDED_SECTION (info, input_bfd, input_section, - rel, 1, relend, howto, 0, contents); - - if (bfd_link_relocatable (info)) - continue; - - switch (r_type) - { - default: - r = i860_final_link_relocate (howto, input_bfd, input_section, - contents, rel, relocation); - break; - - case R_860_HIGHADJ: - r = elf32_i860_relocate_highadj (input_bfd, rel, contents, - relocation); - break; - - case R_860_PC16: - r = elf32_i860_relocate_pc16 (input_bfd, input_section, rel, - contents, relocation); - break; - - case R_860_PC26: - r = elf32_i860_relocate_pc26 (input_bfd, input_section, rel, - contents, relocation); - break; - - case R_860_SPLIT0: - case R_860_SPLIT1: - case R_860_SPLIT2: - r = elf32_i860_relocate_splitn (input_bfd, rel, contents, - relocation); - break; - - /* We do not yet handle GOT/PLT/Dynamic relocations. */ - case R_860_COPY: - case R_860_GLOB_DAT: - case R_860_JUMP_SLOT: - case R_860_RELATIVE: - case R_860_PLT26: - case R_860_LOGOT0: - case R_860_SPGOT0: - case R_860_LOGOT1: - case R_860_SPGOT1: - case R_860_LOGOTOFF0: - case R_860_SPGOTOFF0: - case R_860_LOGOTOFF1: - case R_860_SPGOTOFF1: - case R_860_LOGOTOFF2: - case R_860_LOGOTOFF3: - case R_860_LOPC: - case R_860_HAGOT: - case R_860_HAGOTOFF: - case R_860_HAPC: - case R_860_HIGOT: - case R_860_HIGOTOFF: - r = bfd_reloc_notsupported; - break; - } - - if (r != bfd_reloc_ok) - { - const char * msg = (const char *) NULL; - - switch (r) - { - case bfd_reloc_overflow: - (*info->callbacks->reloc_overflow) - (info, (h ? &h->root : NULL), name, howto->name, - (bfd_vma) 0, input_bfd, input_section, rel->r_offset); - break; - - case bfd_reloc_undefined: - (*info->callbacks->undefined_symbol) - (info, name, input_bfd, input_section, rel->r_offset, TRUE); - break; - - case bfd_reloc_outofrange: - msg = _("internal error: out of range error"); - break; - - case bfd_reloc_notsupported: - msg = _("internal error: unsupported relocation error"); - break; - - case bfd_reloc_dangerous: - msg = _("internal error: dangerous relocation"); - break; - - default: - msg = _("internal error: unknown error"); - break; - } - - if (msg) - (*info->callbacks->warning) (info, msg, name, input_bfd, - input_section, rel->r_offset); - } - } - - return TRUE; -} - -/* Return whether a symbol name implies a local label. SVR4/860 compilers - generate labels of the form ".ep.function_name" to denote the end of a - function prolog. These should be local. - ??? Do any other SVR4 compilers have this convention? If so, this should - be added to the generic routine. */ -static bfd_boolean -elf32_i860_is_local_label_name (bfd *abfd, const char *name) -{ - if (name[0] == '.' && name[1] == 'e' && name[2] == 'p' && name[3] == '.') - return TRUE; - - return _bfd_elf_is_local_label_name (abfd, name); -} - -#define TARGET_BIG_SYM i860_elf32_vec -#define TARGET_BIG_NAME "elf32-i860" -#define TARGET_LITTLE_SYM i860_elf32_le_vec -#define TARGET_LITTLE_NAME "elf32-i860-little" -#define ELF_ARCH bfd_arch_i860 -#define ELF_MACHINE_CODE EM_860 -#define ELF_MAXPAGESIZE 4096 - -#define elf_backend_rela_normal 1 -#define elf_info_to_howto_rel NULL -#define elf_info_to_howto elf32_i860_info_to_howto_rela -#define elf_backend_relocate_section elf32_i860_relocate_section -#define bfd_elf32_bfd_reloc_type_lookup elf32_i860_reloc_type_lookup -#define bfd_elf32_bfd_reloc_name_lookup elf32_i860_reloc_name_lookup -#define bfd_elf32_bfd_is_local_label_name elf32_i860_is_local_label_name - -#include "elf32-target.h" diff --git a/bfd/elf32-i960.c b/bfd/elf32-i960.c deleted file mode 100644 index 244e4ea..0000000 --- a/bfd/elf32-i960.c +++ /dev/null @@ -1,169 +0,0 @@ -/* Intel 960 specific support for 32-bit ELF - Copyright (C) 1999-2018 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" -#include "elf-bfd.h" -#include "elf/i960.h" - -#define USE_REL 1 - -#define bfd_elf32_bfd_reloc_type_lookup elf32_i960_reloc_type_lookup -#define bfd_elf32_bfd_reloc_name_lookup \ - elf32_i960_reloc_name_lookup -#define elf_info_to_howto NULL -#define elf_info_to_howto_rel elf32_i960_info_to_howto_rel - -/* ELF relocs are against symbols. If we are producing relocatable - output, and the reloc is against an external symbol, and nothing - has given us any additional addend, the resulting reloc will also - be against the same symbol. In such a case, we don't want to - change anything about the way the reloc is handled, since it will - all be done at final link time. Rather than put special case code - into bfd_perform_relocation, all the reloc types use this howto - function. It just short circuits the reloc if producing - relocatable output against an external symbol. */ - -static bfd_reloc_status_type -elf32_i960_relocate (bfd *abfd ATTRIBUTE_UNUSED, - arelent *reloc_entry, - asymbol *symbol, - void * data ATTRIBUTE_UNUSED, - asection *input_section, - bfd *output_bfd, - char **error_message ATTRIBUTE_UNUSED) -{ - /* HACK: I think this first condition is necessary when producing - relocatable output. After the end of HACK, the code is identical - to bfd_elf_generic_reloc(). I would _guess_ the first change - belongs there rather than here. martindo 1998-10-23. */ - if (output_bfd != (bfd *) NULL - && reloc_entry->howto->pc_relative - && !reloc_entry->howto->pcrel_offset) - reloc_entry->addend -= symbol->value; - - /* This is more dubious. */ - else if (output_bfd != (bfd *) NULL - && (symbol->flags & BSF_SECTION_SYM) != 0) - reloc_entry->addend -= symbol->section->output_section->vma; - - else - { - /* ...end of HACK. */ - if (output_bfd != (bfd *) NULL - && (symbol->flags & BSF_SECTION_SYM) == 0 - && (! reloc_entry->howto->partial_inplace - || reloc_entry->addend == 0)) - { - reloc_entry->address += input_section->output_offset; - return bfd_reloc_ok; - } - } - - return bfd_reloc_continue; -} - -static reloc_howto_type elf_howto_table[]= -{ - HOWTO (R_960_NONE, 0, 3, 0, FALSE, 0, complain_overflow_dont, - elf32_i960_relocate, "R_960_NONE", TRUE, - 0x00000000, 0x00000000, FALSE), - EMPTY_HOWTO (1), - HOWTO (R_960_32, 0, 2, 32, FALSE, 0, complain_overflow_bitfield, - elf32_i960_relocate, "R_960_32", TRUE, - 0xffffffff, 0xffffffff, FALSE), - HOWTO (R_960_IP24, 0, 2, 24, TRUE, 0, complain_overflow_signed, - elf32_i960_relocate, "R_960_IP24 ", TRUE, - 0x00ffffff, 0x00ffffff, FALSE), - EMPTY_HOWTO (4), - EMPTY_HOWTO (5), - EMPTY_HOWTO (6), - EMPTY_HOWTO (7) -}; - -static enum elf_i960_reloc_type -elf32_i960_bfd_to_reloc_type (bfd_reloc_code_real_type code) -{ - switch (code) - { - default: - return R_960_NONE; - case BFD_RELOC_I960_CALLJ: - return R_960_OPTCALL; - case BFD_RELOC_32: - case BFD_RELOC_CTOR: - return R_960_32; - case BFD_RELOC_24_PCREL: - return R_960_IP24; - } -} - -static bfd_boolean -elf32_i960_info_to_howto_rel (bfd *abfd ATTRIBUTE_UNUSED, - arelent *cache_ptr, - Elf_Internal_Rela *dst) -{ - enum elf_i960_reloc_type type; - - type = (enum elf_i960_reloc_type) ELF32_R_TYPE (dst->r_info); - - /* PR 17521: file: 9609b8d6. */ - if (type >= R_960_max) - { - /* xgettext:c-format */ - _bfd_error_handler (_("%pB: unsupported relocation type %#x"), - abfd, type); - bfd_set_error (bfd_error_bad_value); - return FALSE; - } - - cache_ptr->howto = &elf_howto_table[(int) type]; - return TRUE; -} - -static reloc_howto_type * -elf32_i960_reloc_type_lookup (bfd *abfd ATTRIBUTE_UNUSED, - bfd_reloc_code_real_type code) -{ - return elf_howto_table + elf32_i960_bfd_to_reloc_type (code); -} - -static reloc_howto_type * -elf32_i960_reloc_name_lookup (bfd *abfd ATTRIBUTE_UNUSED, - const char *r_name) -{ - unsigned int i; - - for (i = 0; i < sizeof (elf_howto_table) / sizeof (elf_howto_table[0]); i++) - if (elf_howto_table[i].name != NULL - && strcasecmp (elf_howto_table[i].name, r_name) == 0) - return &elf_howto_table[i]; - - return NULL; -} - -#define TARGET_LITTLE_SYM i960_elf32_vec -#define TARGET_LITTLE_NAME "elf32-i960" -#define ELF_ARCH bfd_arch_i960 -#define ELF_MACHINE_CODE EM_960 -#define ELF_MAXPAGESIZE 1 /* FIXME: This number is wrong, It should be the page size in bytes. */ - -#include "elf32-target.h" diff --git a/bfd/hosts/i860mach3.h b/bfd/hosts/i860mach3.h deleted file mode 100644 index f18ff37..0000000 --- a/bfd/hosts/i860mach3.h +++ /dev/null @@ -1,46 +0,0 @@ -/* Copyright (C) 2007-2018 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. */ - -/* This file was hacked from i386mach3.h [dolan@ssd.intel.com] */ - -#include <machine/vmparam.h> -#include <sys/param.h> - -/* This is an ugly way to hack around the incorrect - * definition of UPAGES in i386/machparam.h. - * - * The definition should specify the size reserved - * for "struct user" in core files in PAGES, - * but instead it gives it in 512-byte core-clicks - * for i386 and i860. UPAGES is used only in trad-core.c. - */ -#if UPAGES == 16 -#undef UPAGES -#define UPAGES 2 -#endif - -#if UPAGES != 2 -FIXME!! UPAGES is neither 2 nor 16 -#endif - -#define HOST_PAGE_SIZE 1 -#define HOST_SEGMENT_SIZE NBPG -#define HOST_MACHINE_ARCH bfd_arch_i860 -#define HOST_TEXT_START_ADDR USRTEXT -#define HOST_STACK_END_ADDR USRSTACK @@ -3567,34 +3567,6 @@ ieee_write_processor (bfd *abfd) return FALSE; break; - case bfd_arch_i960: - switch (arch->mach) - { - default: - case bfd_mach_i960_core: - case bfd_mach_i960_ka_sa: - if (! ieee_write_id (abfd, "80960KA")) - return FALSE; - break; - - case bfd_mach_i960_kb_sb: - if (! ieee_write_id (abfd, "80960KB")) - return FALSE; - break; - - case bfd_mach_i960_ca: - if (! ieee_write_id (abfd, "80960CA")) - return FALSE; - break; - - case bfd_mach_i960_mc: - case bfd_mach_i960_xa: - if (! ieee_write_id (abfd, "80960MC")) - return FALSE; - break; - } - break; - case bfd_arch_m68k: { const char *id; diff --git a/bfd/libbfd.h b/bfd/libbfd.h index 4af1019..5a087a7 100644 --- a/bfd/libbfd.h +++ b/bfd/libbfd.h @@ -981,7 +981,6 @@ static const char *const bfd_reloc_code_real_names[] = { "@@uninitialized@@", "BFD_RELOC_LO10", "BFD_RELOC_GPREL16", "BFD_RELOC_GPREL32", - "BFD_RELOC_I960_CALLJ", "BFD_RELOC_NONE", "BFD_RELOC_SPARC_WDISP22", "BFD_RELOC_SPARC22", @@ -2588,38 +2587,6 @@ static const char *const bfd_reloc_code_real_names[] = { "@@uninitialized@@", "BFD_RELOC_CRIS_16_TPREL", "BFD_RELOC_CRIS_DTPMOD", "BFD_RELOC_CRIS_32_IE", - "BFD_RELOC_860_COPY", - "BFD_RELOC_860_GLOB_DAT", - "BFD_RELOC_860_JUMP_SLOT", - "BFD_RELOC_860_RELATIVE", - "BFD_RELOC_860_PC26", - "BFD_RELOC_860_PLT26", - "BFD_RELOC_860_PC16", - "BFD_RELOC_860_LOW0", - "BFD_RELOC_860_SPLIT0", - "BFD_RELOC_860_LOW1", - "BFD_RELOC_860_SPLIT1", - "BFD_RELOC_860_LOW2", - "BFD_RELOC_860_SPLIT2", - "BFD_RELOC_860_LOW3", - "BFD_RELOC_860_LOGOT0", - "BFD_RELOC_860_SPGOT0", - "BFD_RELOC_860_LOGOT1", - "BFD_RELOC_860_SPGOT1", - "BFD_RELOC_860_LOGOTOFF0", - "BFD_RELOC_860_SPGOTOFF0", - "BFD_RELOC_860_LOGOTOFF1", - "BFD_RELOC_860_SPGOTOFF1", - "BFD_RELOC_860_LOGOTOFF2", - "BFD_RELOC_860_LOGOTOFF3", - "BFD_RELOC_860_LOPC", - "BFD_RELOC_860_HIGHADJ", - "BFD_RELOC_860_HAGOT", - "BFD_RELOC_860_HAGOTOFF", - "BFD_RELOC_860_HAPC", - "BFD_RELOC_860_HIGH", - "BFD_RELOC_860_HIGOT", - "BFD_RELOC_860_HIGOTOFF", "BFD_RELOC_OR1K_REL_26", "BFD_RELOC_OR1K_GOTPC_HI16", "BFD_RELOC_OR1K_GOTPC_LO16", diff --git a/bfd/mach-o.c b/bfd/mach-o.c index f26be0c..ded60cf 100644 --- a/bfd/mach-o.c +++ b/bfd/mach-o.c @@ -1047,9 +1047,6 @@ bfd_mach_o_convert_architecture (bfd_mach_o_cpu_type mtype, *type = bfd_arch_sparc; *subtype = bfd_mach_sparc; break; - case BFD_MACH_O_CPU_TYPE_I860: - *type = bfd_arch_i860; - break; case BFD_MACH_O_CPU_TYPE_ALPHA: *type = bfd_arch_alpha; break; @@ -5446,8 +5443,6 @@ bfd_mach_o_stack_addr (enum bfd_mach_o_cpu_type type) return 0xc0000000; case BFD_MACH_O_CPU_TYPE_SPARC: return 0xf0000000; - case BFD_MACH_O_CPU_TYPE_I860: - return 0; case BFD_MACH_O_CPU_TYPE_HPPA: return 0xc0000000 - 0x04000000; default: diff --git a/bfd/po/SRC-POTFILES.in b/bfd/po/SRC-POTFILES.in index 7ea56ca..afa459e 100644 --- a/bfd/po/SRC-POTFILES.in +++ b/bfd/po/SRC-POTFILES.in @@ -1,6 +1,5 @@ aix386-core.c aix5ppc-core.c -aout-adobe.c aout-arm.c aout-cris.c aout-ns32k.c @@ -20,7 +19,6 @@ bfd.c bfdio.c bfdwin.c binary.c -bout.c cache.c cf-i386lynx.c cf-sparclynx.c @@ -34,8 +32,6 @@ coff-go32.c coff-h8300.c coff-h8500.c coff-i386.c -coff-i860.c -coff-i960.c coff-m68k.c coff-m88k.c coff-mips.c @@ -83,8 +79,6 @@ cpu-h8500.c cpu-hppa.c cpu-i370.c cpu-i386.c -cpu-i860.c -cpu-i960.c cpu-ia64.c cpu-iamcu.c cpu-ip2k.c @@ -190,8 +184,6 @@ elf32-hppa.c elf32-hppa.h elf32-i370.c elf32-i386.c -elf32-i860.c -elf32-i960.c elf32-ip2k.c elf32-iq2000.c elf32-lm32.c diff --git a/bfd/reloc.c b/bfd/reloc.c index ca1d81c..9da9128 100644 --- a/bfd/reloc.c +++ b/bfd/reloc.c @@ -87,10 +87,9 @@ CODE_FRAGMENT . {* The symbol to relocate against was undefined. *} . bfd_reloc_undefined, . -. {* The relocation was performed, but may not be ok - presently -. generated only when linking i960 coff files with i960 b.out -. symbols. If this type is returned, the error_message argument -. to bfd_perform_relocation will be set. *} +. {* The relocation was performed, but may not be ok. If this type is +. returned, the error_message argument to bfd_perform_relocation +. will be set. *} . bfd_reloc_dangerous . } . bfd_reloc_status_type; @@ -318,8 +317,7 @@ CODE_FRAGMENT . . {* If this field is non null, then the supplied function is . called rather than the normal function. This allows really -. strange relocation methods to be accommodated (e.g., i960 callj -. instructions). *} +. strange relocation methods to be accommodated. *} . bfd_reloc_status_type (*special_function) . (bfd *, arelent *, struct bfd_symbol *, void *, asection *, . bfd *, char **); @@ -1739,8 +1737,6 @@ ENUMDOC of the relocation itself; sometimes they are relative to the start of the section containing the relocation. It depends on the specific target. -The 24-bit relocation is used in some Intel 960 configurations. - ENUM BFD_RELOC_32_SECREL ENUMDOC @@ -1892,11 +1888,6 @@ handled specially, because the value the register will have is decided relatively late. ENUM - BFD_RELOC_I960_CALLJ -ENUMDOC - Reloc types used for i960/b.out. - -ENUM BFD_RELOC_NONE ENUMX BFD_RELOC_SPARC_WDISP22 @@ -6225,73 +6216,6 @@ ENUMDOC Relocs used in TLS code for CRIS. ENUM - BFD_RELOC_860_COPY -ENUMX - BFD_RELOC_860_GLOB_DAT -ENUMX - BFD_RELOC_860_JUMP_SLOT -ENUMX - BFD_RELOC_860_RELATIVE -ENUMX - BFD_RELOC_860_PC26 -ENUMX - BFD_RELOC_860_PLT26 -ENUMX - BFD_RELOC_860_PC16 -ENUMX - BFD_RELOC_860_LOW0 -ENUMX - BFD_RELOC_860_SPLIT0 -ENUMX - BFD_RELOC_860_LOW1 -ENUMX - BFD_RELOC_860_SPLIT1 -ENUMX - BFD_RELOC_860_LOW2 -ENUMX - BFD_RELOC_860_SPLIT2 -ENUMX - BFD_RELOC_860_LOW3 -ENUMX - BFD_RELOC_860_LOGOT0 -ENUMX - BFD_RELOC_860_SPGOT0 -ENUMX - BFD_RELOC_860_LOGOT1 -ENUMX - BFD_RELOC_860_SPGOT1 -ENUMX - BFD_RELOC_860_LOGOTOFF0 -ENUMX - BFD_RELOC_860_SPGOTOFF0 -ENUMX - BFD_RELOC_860_LOGOTOFF1 -ENUMX - BFD_RELOC_860_SPGOTOFF1 -ENUMX - BFD_RELOC_860_LOGOTOFF2 -ENUMX - BFD_RELOC_860_LOGOTOFF3 -ENUMX - BFD_RELOC_860_LOPC -ENUMX - BFD_RELOC_860_HIGHADJ -ENUMX - BFD_RELOC_860_HAGOT -ENUMX - BFD_RELOC_860_HAGOTOFF -ENUMX - BFD_RELOC_860_HAPC -ENUMX - BFD_RELOC_860_HIGH -ENUMX - BFD_RELOC_860_HIGOT -ENUMX - BFD_RELOC_860_HIGOTOFF -ENUMDOC - Intel i860 Relocations. - -ENUM BFD_RELOC_OR1K_REL_26 ENUMX BFD_RELOC_OR1K_GOTPC_HI16 diff --git a/bfd/targets.c b/bfd/targets.c index 43102d4..34169c5 100644 --- a/bfd/targets.c +++ b/bfd/targets.c @@ -601,7 +601,6 @@ extern const bfd_target am33_elf32_linux_vec; extern const bfd_target aout0_be_vec; extern const bfd_target aout64_vec; extern const bfd_target aout_vec; -extern const bfd_target aout_adobe_vec; extern const bfd_target arc_elf32_be_vec; extern const bfd_target arc_elf32_le_vec; extern const bfd_target arm_aout_be_vec; @@ -634,8 +633,6 @@ extern const bfd_target arm_pei_wince_le_vec; extern const bfd_target avr_elf32_vec; extern const bfd_target bfin_elf32_vec; extern const bfd_target bfin_elf32_fdpic_vec; -extern const bfd_target bout_be_vec; -extern const bfd_target bout_le_vec; extern const bfd_target cr16_elf32_vec; extern const bfd_target cr16c_elf32_vec; extern const bfd_target cris_aout_vec; @@ -688,10 +685,6 @@ extern const bfd_target i386_nlm32_vec; extern const bfd_target i386_pe_vec; extern const bfd_target i386_pei_vec; extern const bfd_target iamcu_elf32_vec; -extern const bfd_target i860_coff_vec; -extern const bfd_target i860_elf32_vec; -extern const bfd_target i860_elf32_le_vec; -extern const bfd_target i960_elf32_vec; extern const bfd_target ia64_elf32_be_vec; extern const bfd_target ia64_elf32_hpux_be_vec; extern const bfd_target ia64_elf64_be_vec; @@ -699,8 +692,6 @@ extern const bfd_target ia64_elf64_le_vec; extern const bfd_target ia64_elf64_hpux_be_vec; extern const bfd_target ia64_elf64_vms_vec; extern const bfd_target ia64_pei_vec; -extern const bfd_target icoff_be_vec; -extern const bfd_target icoff_le_vec; extern const bfd_target ieee_vec; extern const bfd_target ip2k_elf32_vec; extern const bfd_target iq2000_elf32_vec; @@ -1002,7 +993,6 @@ static const bfd_target * const _bfd_target_vector[] = which kind of a.out file it is. */ &aout_vec, #endif - &aout_adobe_vec, &arc_elf32_be_vec, &arc_elf32_le_vec, @@ -1044,9 +1034,6 @@ static const bfd_target * const _bfd_target_vector[] = &bfin_elf32_vec, &bfin_elf32_fdpic_vec, - &bout_be_vec, - &bout_le_vec, - &cr16_elf32_vec, &cr16c_elf32_vec, @@ -1130,12 +1117,6 @@ static const bfd_target * const _bfd_target_vector[] = &iamcu_elf32_vec, - &i860_coff_vec, - &i860_elf32_vec, - &i860_elf32_le_vec, - - &i960_elf32_vec, - #ifdef BFD64 #if 0 &ia64_elf32_be_vec, @@ -1148,9 +1129,6 @@ static const bfd_target * const _bfd_target_vector[] = &ia64_pei_vec, #endif - &icoff_be_vec, - &icoff_le_vec, - &ieee_vec, &ip2k_elf32_vec, diff --git a/binutils/ChangeLog b/binutils/ChangeLog index 1028851..e95fa85 100644 --- a/binutils/ChangeLog +++ b/binutils/ChangeLog @@ -1,3 +1,12 @@ +2018-04-11 Alan Modra <amodra@gmail.com> + + * ieee.c: Remove i960 support. + * od-macho.c: Remove i860 support. + * readelf.c: Remove i860 and i960 support. + * testsuite/binutils-all/objcopy.exp: Likewise. + * testsuite/binutils-all/objdump.exp: Likewise. + * testsuite/lib/binutils-common.exp: Likewise. + 2018-04-11 Maciej W. Rozycki <macro@mips.com> * testsuite/lib/binutils-common.exp (is_elf_format): Also return diff --git a/binutils/ieee.c b/binutils/ieee.c index eab3e4d..902b882 100644 --- a/binutils/ieee.c +++ b/binutils/ieee.c @@ -3561,12 +3561,6 @@ ieee_regno_to_genreg (bfd *abfd, int r) r += 2; break; - case bfd_arch_i960: - /* Stabs uses 0 to 15 for r0 to r15, 16 to 31 for g0 to g15, and - 32 to 35 for fp0 to fp3. */ - --r; - break; - default: break; } @@ -3588,12 +3582,6 @@ ieee_genreg_to_regno (bfd *abfd, int r) r -= 2; break; - case bfd_arch_i960: - /* Stabs uses 0 to 15 for r0 to r15, 16 to 31 for g0 to g15, and - 32 to 35 for fp0 to fp3. */ - ++r; - break; - default: break; } diff --git a/binutils/od-macho.c b/binutils/od-macho.c index 09cc218..fb2ed70 100644 --- a/binutils/od-macho.c +++ b/binutils/od-macho.c @@ -106,7 +106,6 @@ static const bfd_mach_o_xlat_name bfd_mach_o_cpu_name[] = { "arm", BFD_MACH_O_CPU_TYPE_ARM }, { "mc88000", BFD_MACH_O_CPU_TYPE_MC88000 }, { "sparc", BFD_MACH_O_CPU_TYPE_SPARC }, - { "i860", BFD_MACH_O_CPU_TYPE_I860 }, { "alpha", BFD_MACH_O_CPU_TYPE_ALPHA }, { "powerpc", BFD_MACH_O_CPU_TYPE_POWERPC }, { "powerpc_64", BFD_MACH_O_CPU_TYPE_POWERPC_64 }, diff --git a/binutils/readelf.c b/binutils/readelf.c index 80075c2..166dd23 100644 --- a/binutils/readelf.c +++ b/binutils/readelf.c @@ -109,8 +109,6 @@ #include "elf/hppa.h" #include "elf/i386.h" #include "elf/i370.h" -#include "elf/i860.h" -#include "elf/i960.h" #include "elf/ia64.h" #include "elf/ip2k.h" #include "elf/lm32.h" @@ -765,7 +763,6 @@ guess_is_rela (unsigned int e_machine) /* Targets that use REL relocations. */ case EM_386: case EM_IAMCU: - case EM_960: case EM_ARM: case EM_D10V: case EM_CYGNUS_D10V: @@ -779,7 +776,6 @@ guess_is_rela (unsigned int e_machine) /* Targets that use RELA relocations. */ case EM_68K: - case EM_860: case EM_AARCH64: case EM_ADAPTEVA_EPIPHANY: case EM_ALPHA: @@ -1275,10 +1271,6 @@ dump_relocations (Filedata * filedata, rtype = elf_m68k_reloc_type (type); break; - case EM_960: - rtype = elf_i960_reloc_type (type); - break; - case EM_AVR: case EM_AVR_OLD: rtype = elf_avr_reloc_type (type); @@ -1428,10 +1420,6 @@ dump_relocations (Filedata * filedata, rtype = elf_cris_reloc_type (type); break; - case EM_860: - rtype = elf_i860_reloc_type (type); - break; - case EM_X86_64: case EM_L1OM: case EM_K1OM: @@ -2264,7 +2252,6 @@ get_machine_name (unsigned e_machine) case EM_68K: return "MC68000"; case EM_88K: return "MC88000"; case EM_IAMCU: return "Intel MCU"; - case EM_860: return "Intel 80860"; case EM_MIPS: return "MIPS R3000"; case EM_S370: return "IBM System/370"; /* 10 */ @@ -2273,7 +2260,6 @@ get_machine_name (unsigned e_machine) case EM_PARISC: return "HPPA"; case EM_VPP550: return "Fujitsu VPP500"; case EM_SPARC32PLUS: return "Sparc v8+" ; - case EM_960: return "Intel 90860"; case EM_PPC: return "PowerPC"; /* 20 */ case EM_PPC64: return "PowerPC64"; @@ -12195,10 +12181,6 @@ is_32bit_abs_reloc (Filedata * filedata, unsigned int reloc_type) return reloc_type == 1; /* R_386_32. */ case EM_68K: return reloc_type == 1; /* R_68K_32. */ - case EM_860: - return reloc_type == 1; /* R_860_32. */ - case EM_960: - return reloc_type == 2; /* R_960_32. */ case EM_AARCH64: return (reloc_type == 258 || reloc_type == 1); /* R_AARCH64_ABS32 || R_AARCH64_P32_ABS32 */ diff --git a/binutils/testsuite/binutils-all/objcopy.exp b/binutils/testsuite/binutils-all/objcopy.exp index b308fd7..68fccbe 100644 --- a/binutils/testsuite/binutils-all/objcopy.exp +++ b/binutils/testsuite/binutils-all/objcopy.exp @@ -80,7 +80,6 @@ proc objcopy_test {testname srcfile} { setup_xfail "h8300-*-coff" setup_xfail "h8500-*-rtems*" "h8500-*-coff" setup_xfail "hppa*-*-*" - setup_xfail "i960-*" setup_xfail "m68*-*-*coff" "m68*-*-hpux*" "m68*-*-lynxos*" setup_xfail "m68*-*-sysv*" "m68*-apple-aux*" setup_xfail "m8*-*" @@ -1091,7 +1090,6 @@ if [is_elf_format] { || [istarget "d10v-*"] \ || [istarget "dlx-*"] \ || [istarget "i*86-*"] \ - || [istarget "i960-*"] \ || [istarget "m681*-*"] \ || [istarget "m68hc1*-*"] \ || ([istarget "mips*-*"] \ diff --git a/binutils/testsuite/binutils-all/objdump.exp b/binutils/testsuite/binutils-all/objdump.exp index f006d64..5a31834 100644 --- a/binutils/testsuite/binutils-all/objdump.exp +++ b/binutils/testsuite/binutils-all/objdump.exp @@ -35,7 +35,7 @@ set got [binutils_run $OBJDUMP "$OBJDUMPFLAGS -i"] set cpus_expected [list] lappend cpus_expected aarch64 alpha am33-2 arc ARC700 ARCv2 arm cris -lappend cpus_expected d10v d30v fr30 fr500 fr550 h8 hppa i386 i860 i960 iamcu ip2022 +lappend cpus_expected d10v d30v fr30 fr500 fr550 h8 hppa i386 iamcu ip2022 lappend cpus_expected m16c m32c m32r m68hc11 m68hc12 m68k m88k MCore mep c5 h1 MicroBlaze lappend cpus_expected mips mn10200 mn10300 ms1 msp MSP430 nds32 n1h_v3 ns32k lappend cpus_expected or1k or1knd pj powerpc pyramid riscv romp rs6000 s390 sh sparc @@ -279,7 +279,6 @@ if { ![is_elf_format] } then { if { ![is_elf_format] || [istarget "hppa64*-*-hpux*"] || [istarget "i370-*-*"] - || [istarget "i960-*-*"] || [istarget "ia64*-*-*"] || [istarget "mcore-*-*"] || [istarget "moxie-*-*"] diff --git a/binutils/testsuite/lib/binutils-common.exp b/binutils/testsuite/lib/binutils-common.exp index 325a07c..13f09b1 100644 --- a/binutils/testsuite/lib/binutils-common.exp +++ b/binutils/testsuite/lib/binutils-common.exp @@ -59,8 +59,7 @@ proc is_elf_format {} { || [istarget *-*-linux*oldld*] || [istarget *-*-rtemscoff*] || [istarget h8500-*-rtems*] - || [istarget i?86-*-freebsd\[12\].*] - || [istarget i960-*-rtems*] } { + || [istarget i?86-*-freebsd\[12\].*] } { return 0 } @@ -173,7 +172,7 @@ proc is_elf64 { binary_file } { # and Visium targets set OSABI to ELFOSABI_STANDALONE and cannot # support STB_GNU_UNIQUE. Likewise non-EABI ARM targets set OSABI to # ELFOSABI_ARM, and TI C6X targets to ELFOSABI_C6000_*. Finally -# rather than `bfd_elf_final_link' AM33/2.0, D30V, DLX, i960, and +# rather than `bfd_elf_final_link' AM33/2.0, D30V, DLX, and # picoJava targets use `_bfd_generic_final_link', which does not # support STB_GNU_UNIQUE symbol binding causing assertion failures. # @@ -201,7 +200,6 @@ proc supports_gnu_unique {} { if { [istarget "am33_2.0-*-*"] || [istarget "d30v-*-*"] || [istarget "dlx-*-*"] - || [istarget "i960-*-*"] || [istarget "pj*-*-*"] } { return 0 } diff --git a/gas/ChangeLog b/gas/ChangeLog index f7dc5e5..894ad7d 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,121 @@ +2018-04-11 Alan Modra <amodra@gmail.com> + + * config/aout_gnu.h: Delete. + * config/tc-i860.c: Delete. + * config/tc-i860.h: Delete. + * config/tc-i960.c: Delete. + * config/tc-i960.h: Delete. + * doc/c-i860.texi: Delete. + * doc/c-i960.texi: Delete. + * testsuite/gas/i860/README.i860: Delete. + * testsuite/gas/i860/bitwise.d: Delete. + * testsuite/gas/i860/bitwise.s: Delete. + * testsuite/gas/i860/branch.d: Delete. + * testsuite/gas/i860/branch.s: Delete. + * testsuite/gas/i860/bte.d: Delete. + * testsuite/gas/i860/bte.s: Delete. + * testsuite/gas/i860/dir-align01.d: Delete. + * testsuite/gas/i860/dir-align01.s: Delete. + * testsuite/gas/i860/dir-intel01.d: Delete. + * testsuite/gas/i860/dir-intel01.s: Delete. + * testsuite/gas/i860/dir-intel02.d: Delete. + * testsuite/gas/i860/dir-intel02.s: Delete. + * testsuite/gas/i860/dir-intel03-err.l: Delete. + * testsuite/gas/i860/dir-intel03-err.s: Delete. + * testsuite/gas/i860/dual01.d: Delete. + * testsuite/gas/i860/dual01.s: Delete. + * testsuite/gas/i860/dual02-err.l: Delete. + * testsuite/gas/i860/dual02-err.s: Delete. + * testsuite/gas/i860/dual03.d: Delete. + * testsuite/gas/i860/dual03.s: Delete. + * testsuite/gas/i860/fldst01.d: Delete. + * testsuite/gas/i860/fldst01.s: Delete. + * testsuite/gas/i860/fldst02.d: Delete. + * testsuite/gas/i860/fldst02.s: Delete. + * testsuite/gas/i860/fldst03.d: Delete. + * testsuite/gas/i860/fldst03.s: Delete. + * testsuite/gas/i860/fldst04.d: Delete. + * testsuite/gas/i860/fldst04.s: Delete. + * testsuite/gas/i860/fldst05.d: Delete. + * testsuite/gas/i860/fldst05.s: Delete. + * testsuite/gas/i860/fldst06.d: Delete. + * testsuite/gas/i860/fldst06.s: Delete. + * testsuite/gas/i860/fldst07.d: Delete. + * testsuite/gas/i860/fldst07.s: Delete. + * testsuite/gas/i860/fldst08.d: Delete. + * testsuite/gas/i860/fldst08.s: Delete. + * testsuite/gas/i860/float01.d: Delete. + * testsuite/gas/i860/float01.s: Delete. + * testsuite/gas/i860/float02.d: Delete. + * testsuite/gas/i860/float02.s: Delete. + * testsuite/gas/i860/float03.d: Delete. + * testsuite/gas/i860/float03.s: Delete. + * testsuite/gas/i860/float04.d: Delete. + * testsuite/gas/i860/float04.s: Delete. + * testsuite/gas/i860/form.d: Delete. + * testsuite/gas/i860/form.s: Delete. + * testsuite/gas/i860/i860.exp: Delete. + * testsuite/gas/i860/iarith.d: Delete. + * testsuite/gas/i860/iarith.s: Delete. + * testsuite/gas/i860/ldst01.d: Delete. + * testsuite/gas/i860/ldst01.s: Delete. + * testsuite/gas/i860/ldst02.d: Delete. + * testsuite/gas/i860/ldst02.s: Delete. + * testsuite/gas/i860/ldst03.d: Delete. + * testsuite/gas/i860/ldst03.s: Delete. + * testsuite/gas/i860/ldst04.d: Delete. + * testsuite/gas/i860/ldst04.s: Delete. + * testsuite/gas/i860/ldst05.d: Delete. + * testsuite/gas/i860/ldst05.s: Delete. + * testsuite/gas/i860/ldst06.d: Delete. + * testsuite/gas/i860/ldst06.s: Delete. + * testsuite/gas/i860/pfam.d: Delete. + * testsuite/gas/i860/pfam.s: Delete. + * testsuite/gas/i860/pfmam.d: Delete. + * testsuite/gas/i860/pfmam.s: Delete. + * testsuite/gas/i860/pfmsm.d: Delete. + * testsuite/gas/i860/pfmsm.s: Delete. + * testsuite/gas/i860/pfsm.d: Delete. + * testsuite/gas/i860/pfsm.s: Delete. + * testsuite/gas/i860/pseudo-ops01.d: Delete. + * testsuite/gas/i860/pseudo-ops01.s: Delete. + * testsuite/gas/i860/regress01.d: Delete. + * testsuite/gas/i860/regress01.s: Delete. + * testsuite/gas/i860/shift.d: Delete. + * testsuite/gas/i860/shift.s: Delete. + * testsuite/gas/i860/simd.d: Delete. + * testsuite/gas/i860/simd.s: Delete. + * testsuite/gas/i860/system.d: Delete. + * testsuite/gas/i860/system.s: Delete. + * testsuite/gas/i860/xp.d: Delete. + * testsuite/gas/i860/xp.s: Delete. + * Makefile.am: Remove i860 and i960 support. + * configure.tgt: Likewise. + * doc/Makefile.am: Likewise. + * doc/all.texi: Likewise. + * testsuite/gas/all/gas.exp + * config/obj-coff.h: Remove i960 support. + * doc/internals.texi: Likewise. + * expr.c: Likewise. + * read.c: Likewise. + * write.c: Likewise. + * write.h: Likewise. + * testsuite/gas/lns/lns.exp: Likewise. + * testsuite/gas/symver/symver.exp: Likewise. + * config/tc-m68k.c: Remove BOUT support. + * config/tc-score.c: Likewise. + * config/tc-score7.c: Likewise. + * config/tc-sparc.c: Likewise. + * symbols.c: Likewise. + * doc/h8.texi: Likewise. + * configure.ac: Remove BOUT and i860 support. + * doc/as.texinfo: Remove BOUT, i860 and i960 support + * Makefile.in: Regenerate. + * config.in: Regenerate. + * configure: Regenerate. + * doc/Makefile.in: Regenerate. + * po/POTFILES.in: Regenerate. + 2018-04-05 H.J. Lu <hongjiu.lu@intel.com> PR gas/22318 diff --git a/gas/Makefile.am b/gas/Makefile.am index 5aa68f3..3b0dd03 100644 --- a/gas/Makefile.am +++ b/gas/Makefile.am @@ -150,8 +150,6 @@ TARGET_CPU_CFILES = \ config/tc-ia64.c \ config/tc-i370.c \ config/tc-i386.c \ - config/tc-i860.c \ - config/tc-i960.c \ config/tc-ip2k.c \ config/tc-iq2000.c \ config/tc-lm32.c \ @@ -227,8 +225,6 @@ TARGET_CPU_HFILES = \ config/tc-ia64.h \ config/tc-i370.h \ config/tc-i386.h \ - config/tc-i860.h \ - config/tc-i960.h \ config/tc-ip2k.h \ config/tc-iq2000.h \ config/tc-lm32.h \ diff --git a/gas/Makefile.in b/gas/Makefile.in index 51e96e5..8968b1e 100644 --- a/gas/Makefile.in +++ b/gas/Makefile.in @@ -446,8 +446,6 @@ TARGET_CPU_CFILES = \ config/tc-ia64.c \ config/tc-i370.c \ config/tc-i386.c \ - config/tc-i860.c \ - config/tc-i960.c \ config/tc-ip2k.c \ config/tc-iq2000.c \ config/tc-lm32.c \ @@ -523,8 +521,6 @@ TARGET_CPU_HFILES = \ config/tc-ia64.h \ config/tc-i370.h \ config/tc-i386.h \ - config/tc-i860.h \ - config/tc-i960.h \ config/tc-ip2k.h \ config/tc-iq2000.h \ config/tc-lm32.h \ @@ -882,8 +878,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-hppa.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-i370.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-i386.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-i860.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-i960.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-ia64.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-ip2k.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/tc-iq2000.Po@am__quote@ @@ -1255,34 +1249,6 @@ tc-i386.obj: config/tc-i386.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-i386.obj `if test -f 'config/tc-i386.c'; then $(CYGPATH_W) 'config/tc-i386.c'; else $(CYGPATH_W) '$(srcdir)/config/tc-i386.c'; fi` -tc-i860.o: config/tc-i860.c -@am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT tc-i860.o -MD -MP -MF $(DEPDIR)/tc-i860.Tpo -c -o tc-i860.o `test -f 'config/tc-i860.c' || echo '$(srcdir)/'`config/tc-i860.c -@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/tc-i860.Tpo $(DEPDIR)/tc-i860.Po -@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='config/tc-i860.c' object='tc-i860.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-i860.o `test -f 'config/tc-i860.c' || echo '$(srcdir)/'`config/tc-i860.c - -tc-i860.obj: config/tc-i860.c -@am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT tc-i860.obj -MD -MP -MF $(DEPDIR)/tc-i860.Tpo -c -o tc-i860.obj `if test -f 'config/tc-i860.c'; then $(CYGPATH_W) 'config/tc-i860.c'; else $(CYGPATH_W) '$(srcdir)/config/tc-i860.c'; fi` -@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/tc-i860.Tpo $(DEPDIR)/tc-i860.Po -@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='config/tc-i860.c' object='tc-i860.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-i860.obj `if test -f 'config/tc-i860.c'; then $(CYGPATH_W) 'config/tc-i860.c'; else $(CYGPATH_W) '$(srcdir)/config/tc-i860.c'; fi` - -tc-i960.o: config/tc-i960.c -@am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT tc-i960.o -MD -MP -MF $(DEPDIR)/tc-i960.Tpo -c -o tc-i960.o `test -f 'config/tc-i960.c' || echo '$(srcdir)/'`config/tc-i960.c -@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/tc-i960.Tpo $(DEPDIR)/tc-i960.Po -@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='config/tc-i960.c' object='tc-i960.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-i960.o `test -f 'config/tc-i960.c' || echo '$(srcdir)/'`config/tc-i960.c - -tc-i960.obj: config/tc-i960.c -@am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT tc-i960.obj -MD -MP -MF $(DEPDIR)/tc-i960.Tpo -c -o tc-i960.obj `if test -f 'config/tc-i960.c'; then $(CYGPATH_W) 'config/tc-i960.c'; else $(CYGPATH_W) '$(srcdir)/config/tc-i960.c'; fi` -@am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/tc-i960.Tpo $(DEPDIR)/tc-i960.Po -@AMDEP_TRUE@@am__fastdepCC_FALSE@ source='config/tc-i960.c' object='tc-i960.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-i960.obj `if test -f 'config/tc-i960.c'; then $(CYGPATH_W) 'config/tc-i960.c'; else $(CYGPATH_W) '$(srcdir)/config/tc-i960.c'; fi` - tc-ip2k.o: config/tc-ip2k.c @am__fastdepCC_TRUE@ $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT tc-ip2k.o -MD -MP -MF $(DEPDIR)/tc-ip2k.Tpo -c -o tc-ip2k.o `test -f 'config/tc-ip2k.c' || echo '$(srcdir)/'`config/tc-ip2k.c @am__fastdepCC_TRUE@ $(am__mv) $(DEPDIR)/tc-ip2k.Tpo $(DEPDIR)/tc-ip2k.Po diff --git a/gas/config.in b/gas/config.in index 0855179..76c7c17 100644 --- a/gas/config.in +++ b/gas/config.in @@ -238,9 +238,6 @@ /* a.out support? */ #undef OBJ_MAYBE_AOUT -/* b.out support? */ -#undef OBJ_MAYBE_BOUT - /* COFF support? */ #undef OBJ_MAYBE_COFF diff --git a/gas/config/aout_gnu.h b/gas/config/aout_gnu.h deleted file mode 100644 index f404d1e..0000000 --- a/gas/config/aout_gnu.h +++ /dev/null @@ -1,451 +0,0 @@ -/* This file is aout_gnu.h - - Copyright (C) 1987-2018 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 __A_OUT_GNU_H__ -#define __A_OUT_GNU_H__ - -/* There are two main flavours of a.out, one which uses the standard - relocations, and one which uses extended relocations. - - Today, the extended reloc uses are - TC_SPARC - - each must define the enum reloc_type - -*/ - -#if defined(TC_SPARC) -enum reloc_type - { - RELOC_8, RELOC_16, RELOC_32,/* simple relocations */ - RELOC_DISP8, RELOC_DISP16, RELOC_DISP32, /* pc-rel displacement */ - RELOC_WDISP30, RELOC_WDISP22, - RELOC_HI22, RELOC_22, - RELOC_13, RELOC_LO10, - RELOC_SFA_BASE, RELOC_SFA_OFF13, - RELOC_BASE10, RELOC_BASE13, RELOC_BASE22, /* P.I.C. (base-relative) */ - RELOC_PC10, RELOC_PC22, /* for some sort of pc-rel P.I.C. (?) */ - RELOC_JMP_TBL, /* P.I.C. jump table */ - RELOC_SEGOFF16, /* reputedly for shared libraries somehow */ - RELOC_GLOB_DAT, RELOC_JMP_SLOT, RELOC_RELATIVE, - RELOC_10, RELOC_11, - RELOC_WDISP2_14, - RELOC_WDISP19, - RELOC_HHI22, - RELOC_HLO10, - - /* 29K relocation types */ - RELOC_JUMPTARG, RELOC_CONST, RELOC_CONSTH, - - RELOC_WDISP14, RELOC_WDISP21, - - NO_RELOC - }; - -#define USE_EXTENDED_RELOC 1 -#else -#define USE_EXTENDED_RELOC 0 -#endif /* TC_SPARC */ - -#define __GNU_EXEC_MACROS__ - -#ifndef __STRUCT_EXEC_OVERRIDE__ - -/* This is the layout on disk of a Unix V7, Berkeley, SunOS, Vax Ultrix - "struct exec". Don't assume that on this machine, the "struct exec" - will lay out the same sizes or alignments. */ - -struct exec_bytes - { - unsigned char a_info[4]; - unsigned char a_text[4]; - unsigned char a_data[4]; - unsigned char a_bss[4]; - unsigned char a_syms[4]; - unsigned char a_entry[4]; - unsigned char a_trsize[4]; - unsigned char a_drsize[4]; - }; - -/* How big the "struct exec" is on disk */ -#define EXEC_BYTES_SIZE (8 * 4) - -/* This is the layout in memory of a "struct exec" while we process it. */ - -struct exec -{ - unsigned long a_info; /* Use macros N_MAGIC, etc for access */ - unsigned a_text; /* length of text, in bytes */ - unsigned a_data; /* length of data, in bytes */ - unsigned a_bss; /* length of uninitialized data area for file, in bytes */ - unsigned a_syms; /* length of symbol table data in file, in bytes */ - unsigned a_entry; /* start address */ - unsigned a_trsize; /* length of relocation info for text, in bytes */ - unsigned a_drsize; /* length of relocation info for data, in bytes */ -}; - -#endif /* __STRUCT_EXEC_OVERRIDE__ */ - -/* these go in the N_MACHTYPE field */ -/* These symbols could be defined by code from Suns...punt 'em */ -#undef M_UNKNOWN -#undef M_68010 -#undef M_68020 -#undef M_SPARC -enum machine_type - { - M_UNKNOWN = 0, - M_68010 = 1, - M_68020 = 2, - M_SPARC = 3, - /* skip a bunch so we don't run into any of sun's numbers */ - M_386 = 100, - M_29K = 101, - M_RS6000 = 102, /* IBM RS/6000 */ - M_VAX4K_NETBSD = 150, - /* HP/BSD formats */ - M_HP200 = 200, /* hp200 (68010) BSD binary */ - M_HP300 = 300, /* hp300 (68020+68881) BSD binary */ - M_HPUX23 = 0x020C /* hp200/300 HPUX binary */ - }; - -#define N_MAGIC(execp) ((execp)->a_info & 0xffff) -#define N_MACHTYPE(execp) ((enum machine_type)(((execp)->a_info >> 16) & 0xff)) -#define N_FLAGS(execp) (((execp)->a_info >> 24) & 0xff) -#define N_SET_INFO(execp, magic, type, flags) \ - ((execp)->a_info = ((magic) & 0xffff) \ - | (((int)(type) & 0xff) << 16) \ - | (((flags) & 0xff) << 24)) -#define N_SET_MAGIC(execp, magic) \ - ((execp)->a_info = (((execp)->a_info & 0xffff0000) | ((magic) & 0xffff))) - -#define N_SET_MACHTYPE(execp, machtype) \ - ((execp)->a_info = \ - ((execp)->a_info & 0xff00ffff) | ((((int) (machtype)) & 0xff) << 16)) - -#define N_SET_FLAGS(execp, flags) \ - ((execp)->a_info = \ - ((execp)->a_info & 0x00ffffff) | (((flags) & 0xff) << 24)) - -/* Code indicating object file or impure executable. */ -#ifndef OMAGIC -#define OMAGIC 0407 -#endif -/* Code indicating pure executable. */ -#define NMAGIC 0410 -/* Code indicating demand-paged executable. */ -#define ZMAGIC 0413 - -/* Virtual Address of text segment from the a.out file. For OMAGIC, - (almost always "unlinked .o's" these days), should be zero. - For linked files, should reflect reality if we know it. */ - -#ifndef N_TXTADDR -#define N_TXTADDR(x) (N_MAGIC(x)==OMAGIC? 0 : TEXT_START_ADDR) -#endif - -#ifndef N_BADMAG -#define N_BADMAG(x) (N_MAGIC(x) != OMAGIC \ - && N_MAGIC(x) != NMAGIC \ - && N_MAGIC(x) != ZMAGIC) -#endif - -/* By default, segment size is constant. But on some machines, it can - be a function of the a.out header (e.g. machine type). */ -#ifndef N_SEGSIZE -#define N_SEGSIZE(x) SEGMENT_SIZE -#endif - -/* This complexity is for encapsulated COFF support */ -#ifndef _N_HDROFF -#define _N_HDROFF(x) (N_SEGSIZE(x) - sizeof (struct exec)) -#endif - -#ifndef N_TXTOFF -#define N_TXTOFF(x) (N_MAGIC(x) == ZMAGIC ? \ - _N_HDROFF((x)) + sizeof (struct exec) : \ - sizeof (struct exec)) -#endif - -#ifndef N_DATOFF -#define N_DATOFF(x) ( N_TXTOFF(x) + (x)->a_text ) -#endif - -#ifndef N_TRELOFF -#define N_TRELOFF(x) ( N_DATOFF(x) + (x)->a_data ) -#endif - -#ifndef N_DRELOFF -#define N_DRELOFF(x) ( N_TRELOFF(x) + (x)->a_trsize ) -#endif - -#ifndef N_SYMOFF -#define N_SYMOFF(x) ( N_DRELOFF(x) + (x)->a_drsize ) -#endif - -#ifndef N_STROFF -#define N_STROFF(x) ( N_SYMOFF(x) + (x)->a_syms ) -#endif - -/* Address of text segment in memory after it is loaded. */ -#ifndef N_TXTADDR -#define N_TXTADDR(x) 0 -#endif - -#ifndef N_DATADDR -#define N_DATADDR(x) \ - (N_MAGIC(x)==OMAGIC? (N_TXTADDR(x)+(x)->a_text) \ - : (N_SEGSIZE(x) + ((N_TXTADDR(x)+(x)->a_text-1) & ~(N_SEGSIZE(x)-1)))) -#endif - -/* Address of bss segment in memory after it is loaded. */ -#define N_BSSADDR(x) (N_DATADDR(x) + (x)->a_data) - -struct nlist - { - union - { - char *n_name; - struct nlist *n_next; - long n_strx; - } - n_un; - unsigned char n_type; - char n_other; - short n_desc; - unsigned long n_value; - }; - -#define N_UNDF 0 -#define N_ABS 2 -#define N_TEXT 4 -#define N_DATA 6 -#define N_BSS 8 -#define N_COMM 0x12 /* common (visible in shared lib commons) */ -#define N_FN 0x1F /* File name of a .o file */ - -/* Note: N_EXT can only usefully be OR-ed with N_UNDF, N_ABS, N_TEXT, - N_DATA, or N_BSS. When the low-order bit of other types is set, - (e.g. N_WARNING versus N_FN), they are two different types. */ -#define N_EXT 1 -#define N_TYPE 036 -#define N_STAB 0340 - -/* The following type indicates the definition of a symbol as being - an indirect reference to another symbol. The other symbol - appears as an undefined reference, immediately following this symbol. - - Indirection is asymmetrical. The other symbol's value will be used - to satisfy requests for the indirect symbol, but not vice versa. - If the other symbol does not have a definition, libraries will - be searched to find a definition. */ - -#define N_INDR 0xa - -/* The following symbols refer to set elements. - All the N_SET[ATDB] symbols with the same name form one set. - Space is allocated for the set in the text section, and each set - element's value is stored into one word of the space. - The first word of the space is the length of the set (number of elements). - - The address of the set is made into an N_SETV symbol - whose name is the same as the name of the set. - This symbol acts like a N_DATA global symbol - in that it can satisfy undefined external references. */ - -/* These appear as input to LD, in a .o file. */ -#define N_SETA 0x14 /* Absolute set element symbol */ -#define N_SETT 0x16 /* Text set element symbol */ -#define N_SETD 0x18 /* Data set element symbol */ -#define N_SETB 0x1A /* Bss set element symbol */ - -/* This is output from LD. */ -#define N_SETV 0x1C /* Pointer to set vector in data area. */ - -/* Warning symbol. The text gives a warning message, the next symbol - in the table will be undefined. When the symbol is referenced, the - message is printed. */ - -#define N_WARNING 0x1e - -/* Weak symbols. These are a GNU extension to the a.out format. The - semantics are those of ELF weak symbols. Weak symbols are always - externally visible. The N_WEAK? values are squeezed into the - available slots. The value of a N_WEAKU symbol is 0. The values - of the other types are the definitions. */ -#define N_WEAKU 0x0d /* Weak undefined symbol. */ -#define N_WEAKA 0x0e /* Weak absolute symbol. */ -#define N_WEAKT 0x0f /* Weak text symbol. */ -#define N_WEAKD 0x10 /* Weak data symbol. */ -#define N_WEAKB 0x11 /* Weak bss symbol. */ - -/* This structure describes a single relocation to be performed. - The text-relocation section of the file is a vector of these structures, - all of which apply to the text section. - Likewise, the data-relocation section applies to the data section. */ - -/* The following enum and struct were borrowed from SunOS's - /usr/include/sun4/a.out.h and extended to handle - other machines. It is currently used on SPARC. - - reloc_ext_bytes is how it looks on disk. reloc_info_extended is - how we might process it on a native host. */ -#if USE_EXTENDED_RELOC - -struct reloc_ext_bytes - { - unsigned char r_address[4]; - unsigned char r_index[3]; - unsigned char r_bits[1]; - unsigned char r_addend[4]; - }; - -#define RELOC_EXT_BITS_EXTERN_BIG 0x80 -#define RELOC_EXT_BITS_EXTERN_LITTLE 0x01 - -#define RELOC_EXT_BITS_TYPE_BIG 0x1F -#define RELOC_EXT_BITS_TYPE_SH_BIG 0 -#define RELOC_EXT_BITS_TYPE_LITTLE 0xF8 -#define RELOC_EXT_BITS_TYPE_SH_LITTLE 3 - -#define RELOC_EXT_SIZE 12 /* Bytes per relocation entry */ - -struct reloc_info_extended -{ - unsigned long r_address; - unsigned int r_index:24; -# define r_symbolnum r_index - unsigned r_extern:1; - unsigned:2; - /* RS/6000 compiler does not support enum bitfield - enum reloc_type r_type:5; */ - enum reloc_type r_type; - long int r_addend; -}; - -#else - -/* The standard, old-fashioned, Berkeley compatible relocation struct */ - -#ifdef TC_I860 -/* NOTE: three bits max, see struct reloc_info_i860.r_type */ -enum i860_reloc_type - { - NO_RELOC = 0, BRADDR, LOW0, LOW1, LOW2, LOW3, LOW4, SPLIT0, SPLIT1, SPLIT2, RELOC_32, - }; - -typedef enum i860_reloc_type reloc_type; - -/* NOTE: two bits max, see reloc_info_i860.r_type */ -enum highlow_type - { - NO_SPEC = 0, PAIR, HIGH, HIGHADJ, - }; - -struct reloc_info_i860 -{ - unsigned long r_address; - /* - * Using bit fields here is a bad idea because the order is not portable. :-( - */ - unsigned int r_symbolnum:24; - unsigned int r_pcrel:1; - unsigned int r_extern:1; - /* combining the two field simplifies the argument passing in "new_fix()" */ - /* and is compatible with the existing Sparc #ifdef's */ - /* r_type: highlow_type - bits 5,4; reloc_type - bits 3-0 */ - unsigned int r_type:6; - long r_addend; -}; - -#endif /* TC_I860 */ - -struct reloc_std_bytes - { - unsigned char r_address[4]; - unsigned char r_index[3]; - unsigned char r_bits[1]; - }; - -#define RELOC_STD_BITS_PCREL_BIG 0x80 -#define RELOC_STD_BITS_PCREL_LITTLE 0x01 - -#define RELOC_STD_BITS_LENGTH_BIG 0x60 -#define RELOC_STD_BITS_LENGTH_SH_BIG 5 /* To shift to units place */ -#define RELOC_STD_BITS_LENGTH_LITTLE 0x06 -#define RELOC_STD_BITS_LENGTH_SH_LITTLE 1 - -#define RELOC_STD_BITS_EXTERN_BIG 0x10 -#define RELOC_STD_BITS_EXTERN_LITTLE 0x08 - -#define RELOC_STD_BITS_BASEREL_BIG 0x08 -#define RELOC_STD_BITS_BASEREL_LITTLE 0x08 - -#define RELOC_STD_BITS_JMPTABLE_BIG 0x04 -#define RELOC_STD_BITS_JMPTABLE_LITTLE 0x04 - -#define RELOC_STD_BITS_RELATIVE_BIG 0x02 -#define RELOC_STD_BITS_RELATIVE_LITTLE 0x02 - -#define RELOC_STD_SIZE 8 /* Bytes per relocation entry */ - -#endif /* USE_EXTENDED_RELOC */ - -#ifndef CUSTOM_RELOC_FORMAT -struct relocation_info -{ - /* Address (within segment) to be relocated. */ - int r_address; - /* The meaning of r_symbolnum depends on r_extern. */ - unsigned int r_symbolnum:24; - /* Nonzero means value is a pc-relative offset - and it should be relocated for changes in its own address - as well as for changes in the symbol or section specified. */ - unsigned int r_pcrel:1; - /* Length (as exponent of 2) of the field to be relocated. - Thus, a value of 2 indicates 1<<2 bytes. */ - unsigned int r_length:2; - /* 1 => relocate with value of symbol. - r_symbolnum is the index of the symbol - in file's the symbol table. - 0 => relocate with the address of a segment. - r_symbolnum is N_TEXT, N_DATA, N_BSS or N_ABS - (the N_EXT bit may be set also, but signifies nothing). */ - unsigned int r_extern:1; - /* The next three bits are for SunOS shared libraries, and seem to - be undocumented. */ -#ifdef TC_NS32K - unsigned int r_bsr:1; - unsigned int r_disp:2; -#else - unsigned int r_baserel:1; /* Linkage table relative */ - unsigned int r_jmptable:1; /* pc-relative to jump table */ - unsigned int r_relative:1; /* "relative relocation" */ -#endif /* TC_NS32K */ - /* unused */ - unsigned int r_pad:1; /* Padding -- set to zero */ -}; - -#endif /* CUSTOM_RELOC_FORMAT */ - -#endif /* __A_OUT_GNU_H__ */ - -/* end of aout_gnu.h */ diff --git a/gas/config/obj-coff.h b/gas/config/obj-coff.h index 7c4fff5..ee28ab4 100644 --- a/gas/config/obj-coff.h +++ b/gas/config/obj-coff.h @@ -75,11 +75,6 @@ #endif #endif -#ifdef TC_I960 -#include "coff/i960.h" -#define TARGET_FORMAT "coff-Intel-little" -#endif - #ifdef TC_Z80 #include "coff/z80.h" #define TARGET_FORMAT "coff-z80" @@ -168,11 +163,6 @@ /* Alter the field names, for now, until we've fixed up the other references to use the new name. */ -#ifdef TC_I960 -#define TC_SYMFIELD_TYPE symbolS * -#define sy_tc bal -#endif - #define OBJ_SYMFIELD_TYPE unsigned long #define sy_obj sy_obj_flags @@ -224,17 +214,7 @@ /* Internal use only definitions. SF_ stands for symbol flags. - These values can be assigned to sy_symbol.ost_flags field of a symbolS. - - You'll break i960 if you shift the SYSPROC bits anywhere else. for - more on the balname/callname hack, see tc-i960.h. b.out is done - differently. */ - -#define SF_I960_MASK 0x000001ff /* Bits 0-8 are used by the i960 port. */ -#define SF_SYSPROC 0x0000003f /* bits 0-5 are used to store the sysproc number. */ -#define SF_IS_SYSPROC 0x00000040 /* bit 6 marks symbols that are sysprocs. */ -#define SF_BALNAME 0x00000080 /* bit 7 marks BALNAME symbols. */ -#define SF_CALLNAME 0x00000100 /* bit 8 marks CALLNAME symbols. */ + These values can be assigned to sy_symbol.ost_flags field of a symbolS. */ #define SF_NORMAL_MASK 0x0000ffff /* bits 12-15 are general purpose. */ @@ -269,11 +249,6 @@ #define SF_GET_TAGGED(s) (SF_GET (s) & SF_TAGGED) #define SF_GET_TAG(s) (SF_GET (s) & SF_TAG) #define SF_GET_GET_SEGMENT(s) (SF_GET (s) & SF_GET_SEGMENT) -#define SF_GET_I960(s) (SF_GET (s) & SF_I960_MASK) /* Used by i960. */ -#define SF_GET_BALNAME(s) (SF_GET (s) & SF_BALNAME) /* Used by i960. */ -#define SF_GET_CALLNAME(s) (SF_GET (s) & SF_CALLNAME) /* Used by i960. */ -#define SF_GET_IS_SYSPROC(s) (SF_GET (s) & SF_IS_SYSPROC) /* Used by i960. */ -#define SF_GET_SYSPROC(s) (SF_GET (s) & SF_SYSPROC) /* Used by i960. */ /* Modifiers. */ #define SF_SET(s,v) (SF_GET (s) = (v)) @@ -290,11 +265,6 @@ #define SF_SET_TAGGED(s) (SF_GET (s) |= SF_TAGGED) #define SF_SET_TAG(s) (SF_GET (s) |= SF_TAG) #define SF_SET_GET_SEGMENT(s) (SF_GET (s) |= SF_GET_SEGMENT) -#define SF_SET_I960(s,v) (SF_GET (s) |= ((v) & SF_I960_MASK)) /* Used by i960. */ -#define SF_SET_BALNAME(s) (SF_GET (s) |= SF_BALNAME) /* Used by i960. */ -#define SF_SET_CALLNAME(s) (SF_GET (s) |= SF_CALLNAME) /* Used by i960. */ -#define SF_SET_IS_SYSPROC(s) (SF_GET (s) |= SF_IS_SYSPROC) /* Used by i960. */ -#define SF_SET_SYSPROC(s,v) (SF_GET (s) |= ((v) & SF_SYSPROC)) /* Used by i960. */ /* Line number handling. */ @@ -330,12 +300,6 @@ extern symbolS *coff_last_function; /* Sanity check. */ -#ifdef TC_I960 -#ifndef C_LEAFSTAT -hey ! Where is the C_LEAFSTAT definition ? i960 - coff support is depending on it. -#endif /* no C_LEAFSTAT */ -#endif /* TC_I960 */ - extern const pseudo_typeS coff_pseudo_table[]; #ifndef obj_pop_insert diff --git a/gas/config/tc-i860.c b/gas/config/tc-i860.c deleted file mode 100644 index 5872678..0000000 --- a/gas/config/tc-i860.c +++ /dev/null @@ -1,1491 +0,0 @@ -/* tc-i860.c -- Assembler for the Intel i860 architecture. - Copyright (C) 1989-2018 Free Software Foundation, Inc. - - Brought back from the dead and completely reworked - by Jason Eckhardt <jle@cygnus.com>. - - 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. */ - -#include "as.h" -#include "safe-ctype.h" -#include "subsegs.h" -#include "opcode/i860.h" -#include "elf/i860.h" - - -/* The opcode hash table. */ -static struct hash_control *op_hash = NULL; - -/* These characters always start a comment. */ -const char comment_chars[] = "#!/"; - -/* These characters start a comment at the beginning of a line. */ -const char line_comment_chars[] = "#/"; - -const char line_separator_chars[] = ";"; - -/* Characters that can be used to separate the mantissa from the exponent - in floating point numbers. */ -const char EXP_CHARS[] = "eE"; - -/* Characters that indicate this number is a floating point constant. - As in 0f12.456 or 0d1.2345e12. */ -const char FLT_CHARS[] = "rRsSfFdDxXpP"; - -/* Register prefix (depends on syntax). */ -static char reg_prefix; - -#define MAX_FIXUPS 2 - -struct i860_it -{ - const char *error; - unsigned long opcode; - enum expand_type expand; - struct i860_fi - { - expressionS exp; - bfd_reloc_code_real_type reloc; - int pcrel; - valueT fup; - } fi[MAX_FIXUPS]; -} the_insn; - -/* The current fixup count. */ -static int fc; - -static char *expr_end; - -/* Indicates error if a pseudo operation was expanded after a branch. */ -static char last_expand; - -/* If true, then warn if any pseudo operations were expanded. */ -static int target_warn_expand = 0; - -/* If true, then XP support is enabled. */ -static int target_xp = 0; - -/* If true, then Intel syntax is enabled (default to AT&T/SVR4 syntax). */ -static int target_intel_syntax = 0; - - -/* Prototypes. */ -static void i860_process_insn (char *); -static void s_dual (int); -static void s_enddual (int); -static void s_atmp (int); -static void s_align_wrapper (int); -static int i860_get_expression (char *); -static bfd_reloc_code_real_type obtain_reloc_for_imm16 (fixS *, long *); -#ifdef DEBUG_I860 -static void print_insn (struct i860_it *); -#endif - -const pseudo_typeS md_pseudo_table[] = -{ - {"align", s_align_wrapper, 0}, - {"dual", s_dual, 0}, - {"enddual", s_enddual, 0}, - {"atmp", s_atmp, 0}, - {NULL, 0, 0}, -}; - -/* Dual-instruction mode handling. */ -enum dual -{ - DUAL_OFF = 0, DUAL_ON, DUAL_DDOT, DUAL_ONDDOT, -}; -static enum dual dual_mode = DUAL_OFF; - -/* Handle ".dual" directive. */ -static void -s_dual (int ignore ATTRIBUTE_UNUSED) -{ - if (target_intel_syntax) - dual_mode = DUAL_ON; - else - as_bad (_("Directive .dual available only with -mintel-syntax option")); -} - -/* Handle ".enddual" directive. */ -static void -s_enddual (int ignore ATTRIBUTE_UNUSED) -{ - if (target_intel_syntax) - dual_mode = DUAL_OFF; - else - as_bad (_("Directive .enddual available only with -mintel-syntax option")); -} - -/* Temporary register used when expanding assembler pseudo operations. */ -static int atmp = 31; - -static void -s_atmp (int ignore ATTRIBUTE_UNUSED) -{ - int temp; - - if (! target_intel_syntax) - { - as_bad (_("Directive .atmp available only with -mintel-syntax option")); - demand_empty_rest_of_line (); - return; - } - - if (strncmp (input_line_pointer, "sp", 2) == 0) - { - input_line_pointer += 2; - atmp = 2; - } - else if (strncmp (input_line_pointer, "fp", 2) == 0) - { - input_line_pointer += 2; - atmp = 3; - } - else if (strncmp (input_line_pointer, "r", 1) == 0) - { - input_line_pointer += 1; - temp = get_absolute_expression (); - if (temp >= 0 && temp <= 31) - atmp = temp; - else - as_bad (_("Unknown temporary pseudo register")); - } - else - { - as_bad (_("Unknown temporary pseudo register")); - } - demand_empty_rest_of_line (); -} - -/* Handle ".align" directive depending on syntax mode. - AT&T/SVR4 syntax uses the standard align directive. However, - the Intel syntax additionally allows keywords for the alignment - parameter: ".align type", where type is one of {.short, .long, - .quad, .single, .double} representing alignments of 2, 4, - 16, 4, and 8, respectively. */ -static void -s_align_wrapper (int arg) -{ - char *parm = input_line_pointer; - - if (target_intel_syntax) - { - /* Replace a keyword with the equivalent integer so the - standard align routine can parse the directive. */ - if (strncmp (parm, ".short", 6) == 0) - strncpy (parm, " 2", 6); - else if (strncmp (parm, ".long", 5) == 0) - strncpy (parm, " 4", 5); - else if (strncmp (parm, ".quad", 5) == 0) - strncpy (parm, " 16", 5); - else if (strncmp (parm, ".single", 7) == 0) - strncpy (parm, " 4", 7); - else if (strncmp (parm, ".double", 7) == 0) - strncpy (parm, " 8", 7); - - while (*input_line_pointer == ' ') - ++input_line_pointer; - } - - s_align_bytes (arg); -} - -/* This function is called once, at assembler startup time. It should - set up all the tables and data structures that the MD part of the - assembler will need. */ -void -md_begin (void) -{ - const char *retval = NULL; - int lose = 0; - unsigned int i = 0; - - op_hash = hash_new (); - - while (i860_opcodes[i].name != NULL) - { - const char *name = i860_opcodes[i].name; - retval = hash_insert (op_hash, name, (void *) &i860_opcodes[i]); - if (retval != NULL) - { - fprintf (stderr, _("internal error: can't hash `%s': %s\n"), - i860_opcodes[i].name, retval); - lose = 1; - } - do - { - if (i860_opcodes[i].match & i860_opcodes[i].lose) - { - fprintf (stderr, - _("internal error: losing opcode: `%s' \"%s\"\n"), - i860_opcodes[i].name, i860_opcodes[i].args); - lose = 1; - } - ++i; - } - while (i860_opcodes[i].name != NULL - && strcmp (i860_opcodes[i].name, name) == 0); - } - - if (lose) - as_fatal (_("Defective assembler. No assembly attempted.")); - - /* Set the register prefix for either Intel or AT&T/SVR4 syntax. */ - reg_prefix = target_intel_syntax ? 0 : '%'; -} - -/* This is the core of the machine-dependent assembler. STR points to a - machine dependent instruction. This function emits the frags/bytes - it assembles to. */ -void -md_assemble (char *str) -{ - char *destp; - int num_opcodes = 1; - int i; - struct i860_it pseudo[3]; - - gas_assert (str); - fc = 0; - - /* Assemble the instruction. */ - i860_process_insn (str); - - /* Check for expandable flag to produce pseudo-instructions. This - is an undesirable feature that should be avoided. */ - if (the_insn.expand != 0 && the_insn.expand != XP_ONLY - && ! (the_insn.fi[0].fup & (OP_SEL_HA | OP_SEL_H | OP_SEL_L | OP_SEL_GOT - | OP_SEL_GOTOFF | OP_SEL_PLT))) - { - for (i = 0; i < 3; i++) - pseudo[i] = the_insn; - - fc = 1; - switch (the_insn.expand) - { - - case E_DELAY: - num_opcodes = 1; - break; - - case E_MOV: - if (the_insn.fi[0].exp.X_add_symbol == NULL - && the_insn.fi[0].exp.X_op_symbol == NULL - && (the_insn.fi[0].exp.X_add_number < (1 << 15) - && the_insn.fi[0].exp.X_add_number >= -(1 << 15))) - break; - - /* Emit "or l%const,r0,ireg_dest". */ - pseudo[0].opcode = (the_insn.opcode & 0x001f0000) | 0xe4000000; - pseudo[0].fi[0].fup = (OP_IMM_S16 | OP_SEL_L); - - /* Emit "orh h%const,ireg_dest,ireg_dest". */ - pseudo[1].opcode = (the_insn.opcode & 0x03ffffff) | 0xec000000 - | ((the_insn.opcode & 0x001f0000) << 5); - pseudo[1].fi[0].fup = (OP_IMM_S16 | OP_SEL_H); - - num_opcodes = 2; - break; - - case E_ADDR: - if (the_insn.fi[0].exp.X_add_symbol == NULL - && the_insn.fi[0].exp.X_op_symbol == NULL - && (the_insn.fi[0].exp.X_add_number < (1 << 15) - && the_insn.fi[0].exp.X_add_number >= -(1 << 15))) - break; - - /* Emit "orh ha%addr_expr,ireg_src2,r31". */ - pseudo[0].opcode = 0xec000000 | (the_insn.opcode & 0x03e00000) - | (atmp << 16); - pseudo[0].fi[0].fup = (OP_IMM_S16 | OP_SEL_HA); - - /* Emit "l%addr_expr(r31),ireg_dest". We pick up the fixup - information from the original instruction. */ - pseudo[1].opcode = (the_insn.opcode & ~0x03e00000) | (atmp << 21); - pseudo[1].fi[0].fup = the_insn.fi[0].fup | OP_SEL_L; - - num_opcodes = 2; - break; - - case E_U32: - if (the_insn.fi[0].exp.X_add_symbol == NULL - && the_insn.fi[0].exp.X_op_symbol == NULL - && (the_insn.fi[0].exp.X_add_number < (1 << 16) - && the_insn.fi[0].exp.X_add_number >= 0)) - break; - - /* Emit "$(opcode)h h%const,ireg_src2,r31". */ - pseudo[0].opcode = (the_insn.opcode & 0xf3e0ffff) | 0x0c000000 - | (atmp << 16); - pseudo[0].fi[0].fup = (OP_IMM_S16 | OP_SEL_H); - - /* Emit "$(opcode) l%const,r31,ireg_dest". */ - pseudo[1].opcode = (the_insn.opcode & 0xf01f0000) | 0x04000000 - | (atmp << 21); - pseudo[1].fi[0].fup = (OP_IMM_S16 | OP_SEL_L); - - num_opcodes = 2; - break; - - case E_AND: - if (the_insn.fi[0].exp.X_add_symbol == NULL - && the_insn.fi[0].exp.X_op_symbol == NULL - && (the_insn.fi[0].exp.X_add_number < (1 << 16) - && the_insn.fi[0].exp.X_add_number >= 0)) - break; - - /* Emit "andnot h%const,ireg_src2,r31". */ - pseudo[0].opcode = (the_insn.opcode & 0x03e0ffff) | 0xd4000000 - | (atmp << 16); - pseudo[0].fi[0].fup = (OP_IMM_S16 | OP_SEL_H); - pseudo[0].fi[0].exp.X_add_number = - -1 - the_insn.fi[0].exp.X_add_number; - - /* Emit "andnot l%const,r31,ireg_dest". */ - pseudo[1].opcode = (the_insn.opcode & 0x001f0000) | 0xd4000000 - | (atmp << 21); - pseudo[1].fi[0].fup = (OP_IMM_S16 | OP_SEL_L); - pseudo[1].fi[0].exp.X_add_number = - -1 - the_insn.fi[0].exp.X_add_number; - - num_opcodes = 2; - break; - - case E_S32: - if (the_insn.fi[0].exp.X_add_symbol == NULL - && the_insn.fi[0].exp.X_op_symbol == NULL - && (the_insn.fi[0].exp.X_add_number < (1 << 15) - && the_insn.fi[0].exp.X_add_number >= -(1 << 15))) - break; - - /* Emit "orh h%const,r0,r31". */ - pseudo[0].opcode = 0xec000000 | (atmp << 16); - pseudo[0].fi[0].fup = (OP_IMM_S16 | OP_SEL_H); - - /* Emit "or l%const,r31,r31". */ - pseudo[1].opcode = 0xe4000000 | (atmp << 21) | (atmp << 16); - pseudo[1].fi[0].fup = (OP_IMM_S16 | OP_SEL_L); - - /* Emit "r31,ireg_src2,ireg_dest". */ - pseudo[2].opcode = (the_insn.opcode & ~0x0400ffff) | (atmp << 11); - pseudo[2].fi[0].fup = OP_IMM_S16; - - num_opcodes = 3; - break; - - default: - as_fatal (_("failed sanity check.")); - } - - the_insn = pseudo[0]; - - /* Warn if an opcode is expanded after a delayed branch. */ - if (num_opcodes > 1 && last_expand == 1) - as_warn (_("Expanded opcode after delayed branch: `%s'"), str); - - /* Warn if an opcode is expanded in dual mode. */ - if (num_opcodes > 1 && dual_mode != DUAL_OFF) - as_warn (_("Expanded opcode in dual mode: `%s'"), str); - - /* Notify if any expansions happen. */ - if (target_warn_expand && num_opcodes > 1) - as_warn (_("An instruction was expanded (%s)"), str); - } - - dwarf2_emit_insn (0); - i = 0; - do - { - int tmp; - - /* Output the opcode. Note that the i860 always reads instructions - as little-endian data. */ - destp = frag_more (4); - number_to_chars_littleendian (destp, the_insn.opcode, 4); - - /* Check for expanded opcode after branch or in dual mode. */ - last_expand = the_insn.fi[0].pcrel; - - /* Output the symbol-dependent stuff. Only btne and bte will ever - loop more than once here, since only they (possibly) have more - than one fixup. */ - for (tmp = 0; tmp < fc; tmp++) - { - if (the_insn.fi[tmp].fup != OP_NONE) - { - fixS *fix; - fix = fix_new_exp (frag_now, - destp - frag_now->fr_literal, - 4, - &the_insn.fi[tmp].exp, - the_insn.fi[tmp].pcrel, - the_insn.fi[tmp].reloc); - - /* Despite the odd name, this is a scratch field. We use - it to encode operand type information. */ - fix->fx_addnumber = the_insn.fi[tmp].fup; - } - } - the_insn = pseudo[++i]; - } - while (--num_opcodes > 0); - -} - -/* Assemble the instruction pointed to by STR. */ -static void -i860_process_insn (char *str) -{ - char *s; - const char *args; - char c; - struct i860_opcode *insn; - char *args_start; - unsigned long opcode; - unsigned int mask; - int match = 0; - int comma = 0; - -#if 1 /* For compiler warnings. */ - args = 0; - insn = 0; - args_start = 0; - opcode = 0; -#endif - - for (s = str; ISLOWER (*s) || *s == '.' || *s == '3' - || *s == '2' || *s == '1'; ++s) - ; - - switch (*s) - { - case '\0': - break; - - case ',': - comma = 1; - - /*FALLTHROUGH*/ - - case ' ': - *s++ = '\0'; - break; - - default: - as_fatal (_("Unknown opcode: `%s'"), str); - } - - /* Check for dual mode ("d.") opcode prefix. */ - if (strncmp (str, "d.", 2) == 0) - { - if (dual_mode == DUAL_ON) - dual_mode = DUAL_ONDDOT; - else - dual_mode = DUAL_DDOT; - str += 2; - } - - if ((insn = (struct i860_opcode *) hash_find (op_hash, str)) == NULL) - { - if (dual_mode == DUAL_DDOT || dual_mode == DUAL_ONDDOT) - str -= 2; - as_bad (_("Unknown opcode: `%s'"), str); - return; - } - - if (comma) - *--s = ','; - - args_start = s; - for (;;) - { - int t; - opcode = insn->match; - memset (&the_insn, '\0', sizeof (the_insn)); - fc = 0; - for (t = 0; t < MAX_FIXUPS; t++) - { - the_insn.fi[t].reloc = BFD_RELOC_NONE; - the_insn.fi[t].pcrel = 0; - the_insn.fi[t].fup = OP_NONE; - } - - /* Build the opcode, checking as we go that the operands match. */ - for (args = insn->args; ; ++args) - { - if (fc > MAX_FIXUPS) - abort (); - - switch (*args) - { - - /* End of args. */ - case '\0': - if (*s == '\0') - match = 1; - break; - - /* These must match exactly. */ - case '+': - case '(': - case ')': - case ',': - case ' ': - if (*s++ == *args) - continue; - break; - - /* Must be at least one digit. */ - case '#': - if (ISDIGIT (*s++)) - { - while (ISDIGIT (*s)) - ++s; - continue; - } - break; - - /* Next operand must be a register. */ - case '1': - case '2': - case 'd': - /* Check for register prefix if necessary. */ - if (reg_prefix && *s != reg_prefix) - goto error; - else if (reg_prefix) - s++; - - switch (*s) - { - /* Frame pointer. */ - case 'f': - s++; - if (*s++ == 'p') - { - mask = 0x3; - break; - } - goto error; - - /* Stack pointer. */ - case 's': - s++; - if (*s++ == 'p') - { - mask = 0x2; - break; - } - goto error; - - /* Any register r0..r31. */ - case 'r': - s++; - if (!ISDIGIT (c = *s++)) - { - goto error; - } - if (ISDIGIT (*s)) - { - if ((c = 10 * (c - '0') + (*s++ - '0')) >= 32) - goto error; - } - else - c -= '0'; - mask = c; - break; - - /* Not this opcode. */ - default: - goto error; - } - - /* Obtained the register, now place it in the opcode. */ - switch (*args) - { - case '1': - opcode |= mask << 11; - continue; - - case '2': - opcode |= mask << 21; - continue; - - case 'd': - opcode |= mask << 16; - continue; - - } - break; - - /* Next operand is a floating point register. */ - case 'e': - case 'f': - case 'g': - /* Check for register prefix if necessary. */ - if (reg_prefix && *s != reg_prefix) - goto error; - else if (reg_prefix) - s++; - - if (*s++ == 'f' && ISDIGIT (*s)) - { - mask = *s++; - if (ISDIGIT (*s)) - { - mask = 10 * (mask - '0') + (*s++ - '0'); - if (mask >= 32) - { - break; - } - } - else - mask -= '0'; - - switch (*args) - { - - case 'e': - opcode |= mask << 11; - continue; - - case 'f': - opcode |= mask << 21; - continue; - - case 'g': - opcode |= mask << 16; - if ((opcode & (1 << 10)) && mask != 0 - && (mask == ((opcode >> 11) & 0x1f))) - as_warn (_("Pipelined instruction: fsrc1 = fdest")); - continue; - } - } - break; - - /* Next operand must be a control register. */ - case 'c': - /* Check for register prefix if necessary. */ - if (reg_prefix && *s != reg_prefix) - goto error; - else if (reg_prefix) - s++; - - if (strncmp (s, "fir", 3) == 0) - { - opcode |= 0x0 << 21; - s += 3; - continue; - } - if (strncmp (s, "psr", 3) == 0) - { - opcode |= 0x1 << 21; - s += 3; - continue; - } - if (strncmp (s, "dirbase", 7) == 0) - { - opcode |= 0x2 << 21; - s += 7; - continue; - } - if (strncmp (s, "db", 2) == 0) - { - opcode |= 0x3 << 21; - s += 2; - continue; - } - if (strncmp (s, "fsr", 3) == 0) - { - opcode |= 0x4 << 21; - s += 3; - continue; - } - if (strncmp (s, "epsr", 4) == 0) - { - opcode |= 0x5 << 21; - s += 4; - continue; - } - /* The remaining control registers are XP only. */ - if (target_xp && strncmp (s, "bear", 4) == 0) - { - opcode |= 0x6 << 21; - s += 4; - continue; - } - if (target_xp && strncmp (s, "ccr", 3) == 0) - { - opcode |= 0x7 << 21; - s += 3; - continue; - } - if (target_xp && strncmp (s, "p0", 2) == 0) - { - opcode |= 0x8 << 21; - s += 2; - continue; - } - if (target_xp && strncmp (s, "p1", 2) == 0) - { - opcode |= 0x9 << 21; - s += 2; - continue; - } - if (target_xp && strncmp (s, "p2", 2) == 0) - { - opcode |= 0xa << 21; - s += 2; - continue; - } - if (target_xp && strncmp (s, "p3", 2) == 0) - { - opcode |= 0xb << 21; - s += 2; - continue; - } - break; - - /* 5-bit immediate in src1. */ - case '5': - if (! i860_get_expression (s)) - { - s = expr_end; - the_insn.fi[fc].fup |= OP_IMM_U5; - fc++; - continue; - } - break; - - /* 26-bit immediate, relative branch (lbroff). */ - case 'l': - the_insn.fi[fc].pcrel = 1; - the_insn.fi[fc].fup |= OP_IMM_BR26; - goto immediate; - - /* 16-bit split immediate, relative branch (sbroff). */ - case 'r': - the_insn.fi[fc].pcrel = 1; - the_insn.fi[fc].fup |= OP_IMM_BR16; - goto immediate; - - /* 16-bit split immediate. */ - case 's': - the_insn.fi[fc].fup |= OP_IMM_SPLIT16; - goto immediate; - - /* 16-bit split immediate, byte aligned (st.b). */ - case 'S': - the_insn.fi[fc].fup |= OP_IMM_SPLIT16; - goto immediate; - - /* 16-bit split immediate, half-word aligned (st.s). */ - case 'T': - the_insn.fi[fc].fup |= (OP_IMM_SPLIT16 | OP_ENCODE1 | OP_ALIGN2); - goto immediate; - - /* 16-bit split immediate, word aligned (st.l). */ - case 'U': - the_insn.fi[fc].fup |= (OP_IMM_SPLIT16 | OP_ENCODE1 | OP_ALIGN4); - goto immediate; - - /* 16-bit immediate. */ - case 'i': - the_insn.fi[fc].fup |= OP_IMM_S16; - goto immediate; - - /* 16-bit immediate, byte aligned (ld.b). */ - case 'I': - the_insn.fi[fc].fup |= OP_IMM_S16; - goto immediate; - - /* 16-bit immediate, half-word aligned (ld.s). */ - case 'J': - the_insn.fi[fc].fup |= (OP_IMM_S16 | OP_ENCODE1 | OP_ALIGN2); - goto immediate; - - /* 16-bit immediate, word aligned (ld.l, {p}fld.l, fst.l). */ - case 'K': - if (insn->name[0] == 'l') - the_insn.fi[fc].fup |= (OP_IMM_S16 | OP_ENCODE1 | OP_ALIGN4); - else - the_insn.fi[fc].fup |= (OP_IMM_S16 | OP_ENCODE2 | OP_ALIGN4); - goto immediate; - - /* 16-bit immediate, double-word aligned ({p}fld.d, fst.d). */ - case 'L': - the_insn.fi[fc].fup |= (OP_IMM_S16 | OP_ENCODE3 | OP_ALIGN8); - goto immediate; - - /* 16-bit immediate, quad-word aligned (fld.q, fst.q). */ - case 'M': - the_insn.fi[fc].fup |= (OP_IMM_S16 | OP_ENCODE3 | OP_ALIGN16); - - /*FALLTHROUGH*/ - - /* Handle the immediate for either the Intel syntax or - SVR4 syntax. The Intel syntax is "ha%immediate" - whereas SVR4 syntax is "[immediate]@ha". */ - immediate: - if (target_intel_syntax == 0) - { - /* AT&T/SVR4 syntax. */ - if (*s == ' ') - s++; - - /* Note that if i860_get_expression() fails, we will still - have created U entries in the symbol table for the - 'symbols' in the input string. Try not to create U - symbols for registers, etc. */ - if (! i860_get_expression (s)) - s = expr_end; - else - goto error; - - if (strncmp (s, "@ha", 3) == 0) - { - the_insn.fi[fc].fup |= OP_SEL_HA; - s += 3; - } - else if (strncmp (s, "@h", 2) == 0) - { - the_insn.fi[fc].fup |= OP_SEL_H; - s += 2; - } - else if (strncmp (s, "@l", 2) == 0) - { - the_insn.fi[fc].fup |= OP_SEL_L; - s += 2; - } - else if (strncmp (s, "@gotoff", 7) == 0 - || strncmp (s, "@GOTOFF", 7) == 0) - { - as_bad (_("Assembler does not yet support PIC")); - the_insn.fi[fc].fup |= OP_SEL_GOTOFF; - s += 7; - } - else if (strncmp (s, "@got", 4) == 0 - || strncmp (s, "@GOT", 4) == 0) - { - as_bad (_("Assembler does not yet support PIC")); - the_insn.fi[fc].fup |= OP_SEL_GOT; - s += 4; - } - else if (strncmp (s, "@plt", 4) == 0 - || strncmp (s, "@PLT", 4) == 0) - { - as_bad (_("Assembler does not yet support PIC")); - the_insn.fi[fc].fup |= OP_SEL_PLT; - s += 4; - } - - the_insn.expand = insn->expand; - fc++; - - continue; - } - else - { - /* Intel syntax. */ - if (*s == ' ') - s++; - if (strncmp (s, "ha%", 3) == 0) - { - the_insn.fi[fc].fup |= OP_SEL_HA; - s += 3; - } - else if (strncmp (s, "h%", 2) == 0) - { - the_insn.fi[fc].fup |= OP_SEL_H; - s += 2; - } - else if (strncmp (s, "l%", 2) == 0) - { - the_insn.fi[fc].fup |= OP_SEL_L; - s += 2; - } - the_insn.expand = insn->expand; - - /* Note that if i860_get_expression() fails, we will still - have created U entries in the symbol table for the - 'symbols' in the input string. Try not to create U - symbols for registers, etc. */ - if (! i860_get_expression (s)) - s = expr_end; - else - goto error; - - fc++; - continue; - } - break; - - default: - as_fatal (_("failed sanity check.")); - } - break; - } - error: - if (match == 0) - { - /* Args don't match. */ - if (insn[1].name != NULL - && ! strcmp (insn->name, insn[1].name)) - { - ++insn; - s = args_start; - continue; - } - else - { - as_bad (_("Illegal operands for %s"), insn->name); - return; - } - } - break; - } - - /* Set the dual bit on this instruction if necessary. */ - if (dual_mode != DUAL_OFF) - { - if ((opcode & 0xfc000000) == 0x48000000 || opcode == 0xb0000000) - { - /* The instruction is a flop or a fnop, so set its dual bit - (but check that it is 8-byte aligned). */ - if (((frag_now->fr_address + frag_now_fix_octets ()) & 7) == 0) - opcode |= (1 << 9); - else - as_bad (_("'d.%s' must be 8-byte aligned"), insn->name); - - if (dual_mode == DUAL_DDOT) - dual_mode = DUAL_OFF; - else if (dual_mode == DUAL_ONDDOT) - dual_mode = DUAL_ON; - } - else if (dual_mode == DUAL_DDOT || dual_mode == DUAL_ONDDOT) - as_bad (_("Prefix 'd.' invalid for instruction `%s'"), insn->name); - } - - the_insn.opcode = opcode; - - /* Only recognize XP instructions when the user has requested it. */ - if (insn->expand == XP_ONLY && ! target_xp) - as_bad (_("Unknown opcode: `%s'"), insn->name); -} - -static int -i860_get_expression (char *str) -{ - char *save_in; - segT seg; - - save_in = input_line_pointer; - input_line_pointer = str; - seg = expression (&the_insn.fi[fc].exp); - if (seg != absolute_section - && seg != undefined_section - && ! SEG_NORMAL (seg)) - { - the_insn.error = _("bad segment"); - expr_end = input_line_pointer; - input_line_pointer = save_in; - return 1; - } - expr_end = input_line_pointer; - input_line_pointer = save_in; - return 0; -} - -const char * -md_atof (int type, char *litP, int *sizeP) -{ - return ieee_md_atof (type, litP, sizeP, TRUE); -} - -/* Write out in current endian mode. */ -void -md_number_to_chars (char *buf, valueT val, int n) -{ - if (target_big_endian) - number_to_chars_bigendian (buf, val, n); - else - number_to_chars_littleendian (buf, val, n); -} - -/* This should never be called for i860. */ -int -md_estimate_size_before_relax (fragS *fragP ATTRIBUTE_UNUSED, - segT segtype ATTRIBUTE_UNUSED) -{ - as_fatal (_("relaxation not supported\n")); -} - -#ifdef DEBUG_I860 -static void -print_insn (struct i860_it *insn) -{ - if (insn->error) - fprintf (stderr, "ERROR: %s\n", insn->error); - - fprintf (stderr, "opcode = 0x%08lx\t", insn->opcode); - fprintf (stderr, "expand = 0x%x\t", insn->expand); - fprintf (stderr, "reloc = %s\t\n", - bfd_get_reloc_code_name (insn->reloc)); - fprintf (stderr, "exp = {\n"); - fprintf (stderr, "\t\tX_add_symbol = %s\n", - insn->exp.X_add_symbol ? - (S_GET_NAME (insn->exp.X_add_symbol) ? - S_GET_NAME (insn->exp.X_add_symbol) : "???") : "0"); - fprintf (stderr, "\t\tX_op_symbol = %s\n", - insn->exp.X_op_symbol ? - (S_GET_NAME (insn->exp.X_op_symbol) ? - S_GET_NAME (insn->exp.X_op_symbol) : "???") : "0"); - fprintf (stderr, "\t\tX_add_number = %lx\n", - insn->exp.X_add_number); - fprintf (stderr, "}\n"); -} -#endif /* DEBUG_I860 */ - - -#ifdef OBJ_ELF -const char *md_shortopts = "VQ:"; -#else -const char *md_shortopts = ""; -#endif - -#define OPTION_EB (OPTION_MD_BASE + 0) -#define OPTION_EL (OPTION_MD_BASE + 1) -#define OPTION_WARN_EXPAND (OPTION_MD_BASE + 2) -#define OPTION_XP (OPTION_MD_BASE + 3) -#define OPTION_INTEL_SYNTAX (OPTION_MD_BASE + 4) - -struct option md_longopts[] = { - { "EB", no_argument, NULL, OPTION_EB }, - { "EL", no_argument, NULL, OPTION_EL }, - { "mwarn-expand", no_argument, NULL, OPTION_WARN_EXPAND }, - { "mxp", no_argument, NULL, OPTION_XP }, - { "mintel-syntax",no_argument, NULL, OPTION_INTEL_SYNTAX }, - { NULL, no_argument, NULL, 0 } -}; -size_t md_longopts_size = sizeof (md_longopts); - -int -md_parse_option (int c, const char *arg ATTRIBUTE_UNUSED) -{ - switch (c) - { - case OPTION_EB: - target_big_endian = 1; - break; - - case OPTION_EL: - target_big_endian = 0; - break; - - case OPTION_WARN_EXPAND: - target_warn_expand = 1; - break; - - case OPTION_XP: - target_xp = 1; - break; - - case OPTION_INTEL_SYNTAX: - target_intel_syntax = 1; - break; - -#ifdef OBJ_ELF - /* SVR4 argument compatibility (-V): print version ID. */ - case 'V': - print_version_id (); - break; - - /* SVR4 argument compatibility (-Qy, -Qn): controls whether - a .comment section should be emitted or not (ignored). */ - case 'Q': - break; -#endif - - default: - return 0; - } - - return 1; -} - -void -md_show_usage (FILE *stream) -{ - fprintf (stream, _("\ - -EL generate code for little endian mode (default)\n\ - -EB generate code for big endian mode\n\ - -mwarn-expand warn if pseudo operations are expanded\n\ - -mxp enable i860XP support (disabled by default)\n\ - -mintel-syntax enable Intel syntax (default to AT&T/SVR4)\n")); -#ifdef OBJ_ELF - /* SVR4 compatibility flags. */ - fprintf (stream, _("\ - -V print assembler version number\n\ - -Qy, -Qn ignored\n")); -#endif -} - - -/* We have no need to default values of symbols. */ -symbolS * -md_undefined_symbol (char *name ATTRIBUTE_UNUSED) -{ - return 0; -} - -/* The i860 denotes auto-increment with '++'. */ -void -md_operand (expressionS *exp) -{ - char *s; - - for (s = input_line_pointer; *s; s++) - { - if (s[0] == '+' && s[1] == '+') - { - input_line_pointer += 2; - exp->X_op = O_register; - break; - } - } -} - -/* Round up a section size to the appropriate boundary. */ -valueT -md_section_align (segT segment ATTRIBUTE_UNUSED, - valueT size ATTRIBUTE_UNUSED) -{ - /* Byte alignment is fine. */ - return size; -} - -/* On the i860, a PC-relative offset is relative to the address of the - offset plus its size. */ -long -md_pcrel_from (fixS *fixP) -{ - return fixP->fx_size + fixP->fx_where + fixP->fx_frag->fr_address; -} - -/* Determine the relocation needed for non PC-relative 16-bit immediates. - Also adjust the given immediate as necessary. Finally, check that - all constraints (such as alignment) are satisfied. */ -static bfd_reloc_code_real_type -obtain_reloc_for_imm16 (fixS *fix, long *val) -{ - valueT fup = fix->fx_addnumber; - bfd_reloc_code_real_type reloc; - - if (fix->fx_pcrel) - abort (); - - /* Check alignment restrictions. */ - if ((fup & OP_ALIGN2) && (*val & 0x1)) - as_bad_where (fix->fx_file, fix->fx_line, - _("This immediate requires 0 MOD 2 alignment")); - else if ((fup & OP_ALIGN4) && (*val & 0x3)) - as_bad_where (fix->fx_file, fix->fx_line, - _("This immediate requires 0 MOD 4 alignment")); - else if ((fup & OP_ALIGN8) && (*val & 0x7)) - as_bad_where (fix->fx_file, fix->fx_line, - _("This immediate requires 0 MOD 8 alignment")); - else if ((fup & OP_ALIGN16) && (*val & 0xf)) - as_bad_where (fix->fx_file, fix->fx_line, - _("This immediate requires 0 MOD 16 alignment")); - - if (fup & OP_SEL_HA) - { - *val = (*val >> 16) + (*val & 0x8000 ? 1 : 0); - reloc = BFD_RELOC_860_HIGHADJ; - } - else if (fup & OP_SEL_H) - { - *val >>= 16; - reloc = BFD_RELOC_860_HIGH; - } - else if (fup & OP_SEL_L) - { - int num_encode; - if (fup & OP_IMM_SPLIT16) - { - if (fup & OP_ENCODE1) - { - num_encode = 1; - reloc = BFD_RELOC_860_SPLIT1; - } - else if (fup & OP_ENCODE2) - { - num_encode = 2; - reloc = BFD_RELOC_860_SPLIT2; - } - else - { - num_encode = 0; - reloc = BFD_RELOC_860_SPLIT0; - } - } - else - { - if (fup & OP_ENCODE1) - { - num_encode = 1; - reloc = BFD_RELOC_860_LOW1; - } - else if (fup & OP_ENCODE2) - { - num_encode = 2; - reloc = BFD_RELOC_860_LOW2; - } - else if (fup & OP_ENCODE3) - { - num_encode = 3; - reloc = BFD_RELOC_860_LOW3; - } - else - { - num_encode = 0; - reloc = BFD_RELOC_860_LOW0; - } - } - - /* Preserve size encode bits. */ - *val &= ~((1 << num_encode) - 1); - } - else - { - /* No selector. What reloc do we generate (???)? */ - reloc = BFD_RELOC_32; - } - - return reloc; -} - -/* Attempt to simplify or eliminate a fixup. To indicate that a fixup - has been eliminated, set fix->fx_done. If fix->fx_addsy is non-NULL, - we will have to generate a reloc entry. */ - -void -md_apply_fix (fixS *fix, valueT *valP, segT seg ATTRIBUTE_UNUSED) -{ - char *buf; - long val = *valP; - unsigned long insn; - valueT fup; - - buf = fix->fx_frag->fr_literal + fix->fx_where; - - /* Recall that earlier we stored the opcode little-endian. */ - insn = bfd_getl32 (buf); - - /* We stored a fix-up in this oddly-named scratch field. */ - fup = fix->fx_addnumber; - - /* Determine the necessary relocations as well as inserting an - immediate into the instruction. */ - if (fup & OP_IMM_U5) - { - if (val & ~0x1f) - as_bad_where (fix->fx_file, fix->fx_line, - _("5-bit immediate too large")); - if (fix->fx_addsy) - as_bad_where (fix->fx_file, fix->fx_line, - _("5-bit field must be absolute")); - - insn |= (val & 0x1f) << 11; - bfd_putl32 (insn, buf); - fix->fx_r_type = BFD_RELOC_NONE; - fix->fx_done = 1; - } - else if (fup & OP_IMM_S16) - { - fix->fx_r_type = obtain_reloc_for_imm16 (fix, &val); - - /* Insert the immediate. */ - if (fix->fx_addsy) - fix->fx_done = 0; - else - { - insn |= val & 0xffff; - bfd_putl32 (insn, buf); - fix->fx_r_type = BFD_RELOC_NONE; - fix->fx_done = 1; - } - } - else if (fup & OP_IMM_U16) - abort (); - - else if (fup & OP_IMM_SPLIT16) - { - fix->fx_r_type = obtain_reloc_for_imm16 (fix, &val); - - /* Insert the immediate. */ - if (fix->fx_addsy) - fix->fx_done = 0; - else - { - insn |= val & 0x7ff; - insn |= (val & 0xf800) << 5; - bfd_putl32 (insn, buf); - fix->fx_r_type = BFD_RELOC_NONE; - fix->fx_done = 1; - } - } - else if (fup & OP_IMM_BR16) - { - if (val & 0x3) - as_bad_where (fix->fx_file, fix->fx_line, - _("A branch offset requires 0 MOD 4 alignment")); - - val = val >> 2; - - /* Insert the immediate. */ - if (fix->fx_addsy) - { - fix->fx_done = 0; - fix->fx_r_type = BFD_RELOC_860_PC16; - } - else - { - insn |= (val & 0x7ff); - insn |= ((val & 0xf800) << 5); - bfd_putl32 (insn, buf); - fix->fx_r_type = BFD_RELOC_NONE; - fix->fx_done = 1; - } - } - else if (fup & OP_IMM_BR26) - { - if (val & 0x3) - as_bad_where (fix->fx_file, fix->fx_line, - _("A branch offset requires 0 MOD 4 alignment")); - - val >>= 2; - - /* Insert the immediate. */ - if (fix->fx_addsy) - { - fix->fx_r_type = BFD_RELOC_860_PC26; - fix->fx_done = 0; - } - else - { - insn |= (val & 0x3ffffff); - bfd_putl32 (insn, buf); - fix->fx_r_type = BFD_RELOC_NONE; - fix->fx_done = 1; - } - } - else if (fup != OP_NONE) - { - as_bad_where (fix->fx_file, fix->fx_line, - _("Unrecognized fix-up (0x%08lx)"), (unsigned long) fup); - abort (); - } - else - { - /* I believe only fix-ups such as ".long .ep.main-main+0xc8000000" - reach here (???). */ - if (fix->fx_addsy) - { - fix->fx_r_type = BFD_RELOC_32; - fix->fx_done = 0; - } - else - { - insn |= (val & 0xffffffff); - bfd_putl32 (insn, buf); - fix->fx_r_type = BFD_RELOC_NONE; - fix->fx_done = 1; - } - } -} - -/* Generate a machine dependent reloc from a fixup. */ -arelent* -tc_gen_reloc (asection *section ATTRIBUTE_UNUSED, - fixS *fixp) -{ - arelent *reloc; - - reloc = XNEW (arelent); - reloc->sym_ptr_ptr = XNEW (asymbol *); - *reloc->sym_ptr_ptr = symbol_get_bfdsym (fixp->fx_addsy); - reloc->address = fixp->fx_frag->fr_address + fixp->fx_where; - reloc->addend = fixp->fx_offset; - reloc->howto = bfd_reloc_type_lookup (stdoutput, fixp->fx_r_type); - - if (! reloc->howto) - { - as_bad_where (fixp->fx_file, fixp->fx_line, - "Cannot represent %s relocation in object file", - bfd_get_reloc_code_name (fixp->fx_r_type)); - } - return reloc; -} - -/* This is called from HANDLE_ALIGN in write.c. Fill in the contents - of an rs_align_code fragment. */ - -void -i860_handle_align (fragS *fragp) -{ - /* Instructions are always stored little-endian on the i860. */ - static const unsigned char le_nop[] = { 0x00, 0x00, 0x00, 0xA0 }; - - int bytes; - char *p; - - if (fragp->fr_type != rs_align_code) - return; - - bytes = fragp->fr_next->fr_address - fragp->fr_address - fragp->fr_fix; - p = fragp->fr_literal + fragp->fr_fix; - - /* Make sure we are on a 4-byte boundary, in case someone has been - putting data into a text section. */ - if (bytes & 3) - { - int fix = bytes & 3; - memset (p, 0, fix); - p += fix; - fragp->fr_fix += fix; - } - - memcpy (p, le_nop, 4); - fragp->fr_var = 4; -} - -/* This is called after a user-defined label is seen. We check - if the label has a double colon (valid in Intel syntax mode only), - in which case it should be externalized. */ - -void -i860_check_label (symbolS *labelsym) -{ - /* At this point, the current line pointer is sitting on the character - just after the first colon on the label. */ - if (target_intel_syntax && *input_line_pointer == ':') - { - S_SET_EXTERNAL (labelsym); - input_line_pointer++; - } -} diff --git a/gas/config/tc-i860.h b/gas/config/tc-i860.h deleted file mode 100644 index a63f82f..0000000 --- a/gas/config/tc-i860.h +++ /dev/null @@ -1,95 +0,0 @@ -/* tc-i860.h -- Header file for the i860. - Copyright (C) 1991-2018 Free Software Foundation, Inc. - - Brought back from the dead and completely reworked - by Jason Eckhardt <jle@cygnus.com>. - - 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 TC_I860 -#define TC_I860 1 - -enum i860_fix_info -{ - OP_NONE = 0x00000, - OP_IMM_U5 = 0x00001, - OP_IMM_S16 = 0x00002, - OP_IMM_U16 = 0x00004, - OP_IMM_SPLIT16 = 0x00008, - OP_IMM_BR26 = 0x00010, - OP_IMM_BR16 = 0x00020, - OP_ENCODE1 = 0x00040, - OP_ENCODE2 = 0x00080, - OP_ENCODE3 = 0x00100, - OP_SEL_HA = 0x00200, - OP_SEL_H = 0x00400, - OP_SEL_L = 0x00800, - OP_SEL_GOT = 0x01000, - OP_SEL_GOTOFF = 0x02000, - OP_SEL_PLT = 0x04000, - OP_ALIGN2 = 0x08000, - OP_ALIGN4 = 0x10000, - OP_ALIGN8 = 0x20000, - OP_ALIGN16 = 0x40000 -}; - -/* Set the endianness we are using. Default to little endian. */ -#ifndef TARGET_BYTES_BIG_ENDIAN -#define TARGET_BYTES_BIG_ENDIAN 0 -#endif - -/* Whether or not the target is big endian. */ -extern int target_big_endian; - -/* BFD target architecture. */ -#define TARGET_ARCH bfd_arch_i860 - -/* The target BFD format. */ -#ifdef OBJ_ELF -#define TARGET_FORMAT (target_big_endian ? "elf32-i860" : "elf32-i860-little") -#else -#error i860 GAS currently supports only the ELF object format -#endif - -#define WORKING_DOT_WORD -#define DIFF_EXPR_OK - -/* Permit temporary numeric labels. */ -#define LOCAL_LABELS_FB 1 -#define LISTING_HEADER "GAS for i860" - -#define md_convert_frag(b,s,f) abort () - -/* Values passed to md_apply_fix don't include the symbol value. */ -#define MD_APPLY_SYM_VALUE(FIX) 0 - -/* No shared lib support, so we don't need to ensure externally - visible symbols can be overridden. */ -#define EXTERN_FORCE_RELOC 0 - -/* Bits for post-processing of a user defined label to check if - it has a double colon (Intel syntax only). */ -extern void i860_check_label (symbolS *labelsym); -#define tc_check_label(ls) i860_check_label (ls) - -/* Bits for filling in rs_align_code fragments with NOPs. */ -extern void i860_handle_align (struct frag *); -#define HANDLE_ALIGN(fragp) i860_handle_align (fragp) - -#define MAX_MEM_FOR_RS_ALIGN_CODE (3 + 4 + 4) - -#endif /* TC_I860 */ diff --git a/gas/config/tc-i960.c b/gas/config/tc-i960.c deleted file mode 100644 index e6f7504..0000000 --- a/gas/config/tc-i960.c +++ /dev/null @@ -1,2667 +0,0 @@ -/* tc-i960.c - All the i80960-specific stuff - Copyright (C) 1989-2018 Free Software Foundation, Inc. - - This file is part of GAS. - - 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. */ - -/* See comment on md_parse_option for 80960-specific invocation options. */ - -/* There are 4 different lengths of (potentially) symbol-based displacements - in the 80960 instruction set, each of which could require address fix-ups - and (in the case of external symbols) emission of relocation directives: - - 32-bit (MEMB) - This is a standard length for the base assembler and requires no - special action. - - 13-bit (COBR) - This is a non-standard length, but the base assembler has a - hook for bit field address fixups: the fixS structure can - point to a descriptor of the field, in which case our - md_number_to_field() routine gets called to process it. - - I made the hook a little cleaner by having fix_new() (in the base - assembler) return a pointer to the fixS in question. And I made it a - little simpler by storing the field size (in this case 13) instead of - of a pointer to another structure: 80960 displacements are ALWAYS - stored in the low-order bits of a 4-byte word. - - Since the target of a COBR cannot be external, no relocation - directives for this size displacement have to be generated. - But the base assembler had to be modified to issue error - messages if the symbol did turn out to be external. - - 24-bit (CTRL) - Fixups are handled as for the 13-bit case (except that 24 is stored - in the fixS). - - The relocation directive generated is the same as that for the 32-bit - displacement, except that it's PC-relative (the 32-bit displacement - never is). The i80960 version of the linker needs a mod to - distinguish and handle the 24-bit case. - - 12-bit (MEMA) - MEMA formats are always promoted to MEMB (32-bit) if the displacement - is based on a symbol, because it could be relocated at link time. - The only time we use the 12-bit format is if an absolute value of - less than 4096 is specified, in which case we need neither a fixup nor - a relocation directive. */ - -#include "as.h" - -#include "safe-ctype.h" - -#include "opcode/i960.h" - -#if defined (OBJ_AOUT) || defined (OBJ_BOUT) - -#define TC_S_IS_SYSPROC(s) ((1 <= S_GET_OTHER (s)) && (S_GET_OTHER (s) <= 32)) -#define TC_S_IS_BALNAME(s) (S_GET_OTHER (s) == N_BALNAME) -#define TC_S_IS_CALLNAME(s) (S_GET_OTHER (s) == N_CALLNAME) -#define TC_S_IS_BADPROC(s) ((S_GET_OTHER (s) != 0) && !TC_S_IS_CALLNAME (s) && !TC_S_IS_BALNAME (s) && !TC_S_IS_SYSPROC (s)) - -#define TC_S_SET_SYSPROC(s, p) (S_SET_OTHER ((s), (p) + 1)) -#define TC_S_GET_SYSPROC(s) (S_GET_OTHER (s) - 1) - -#define TC_S_FORCE_TO_BALNAME(s) (S_SET_OTHER ((s), N_BALNAME)) -#define TC_S_FORCE_TO_CALLNAME(s) (S_SET_OTHER ((s), N_CALLNAME)) -#define TC_S_FORCE_TO_SYSPROC(s) {;} - -#else /* ! OBJ_A/BOUT */ -#ifdef OBJ_COFF - -#define TC_S_IS_SYSPROC(s) (S_GET_STORAGE_CLASS (s) == C_SCALL) -#define TC_S_IS_BALNAME(s) (SF_GET_BALNAME (s)) -#define TC_S_IS_CALLNAME(s) (SF_GET_CALLNAME (s)) -#define TC_S_IS_BADPROC(s) (TC_S_IS_SYSPROC (s) && TC_S_GET_SYSPROC (s) < 0 && 31 < TC_S_GET_SYSPROC (s)) - -#define TC_S_SET_SYSPROC(s, p) ((s)->sy_symbol.ost_auxent[1].x_sc.x_stindx = (p)) -#define TC_S_GET_SYSPROC(s) ((s)->sy_symbol.ost_auxent[1].x_sc.x_stindx) - -#define TC_S_FORCE_TO_BALNAME(s) (SF_SET_BALNAME (s)) -#define TC_S_FORCE_TO_CALLNAME(s) (SF_SET_CALLNAME (s)) -#define TC_S_FORCE_TO_SYSPROC(s) (S_SET_STORAGE_CLASS ((s), C_SCALL)) - -#else /* ! OBJ_COFF */ -#ifdef OBJ_ELF -#define TC_S_IS_SYSPROC(s) 0 - -#define TC_S_IS_BALNAME(s) 0 -#define TC_S_IS_CALLNAME(s) 0 -#define TC_S_IS_BADPROC(s) 0 - -#define TC_S_SET_SYSPROC(s, p) -#define TC_S_GET_SYSPROC(s) 0 - -#define TC_S_FORCE_TO_BALNAME(s) -#define TC_S_FORCE_TO_CALLNAME(s) -#define TC_S_FORCE_TO_SYSPROC(s) -#else - #error COFF, a.out, b.out, and ELF are the only supported formats. -#endif /* ! OBJ_ELF */ -#endif /* ! OBJ_COFF */ -#endif /* ! OBJ_A/BOUT */ - -extern char *input_line_pointer; - -/* Local i80960 routines. */ -struct memS; -struct regop; - -/* See md_parse_option() for meanings of these options. */ -static char norelax; /* True if -norelax switch seen. */ -static char instrument_branches; /* True if -b switch seen. */ - -/* Characters that always start a comment. - If the pre-processor is disabled, these aren't very useful. */ -const char comment_chars[] = "#"; - -/* Characters that only start a comment at the beginning of - a line. If the line seems to have the form '# 123 filename' - .line and .file directives will appear in the pre-processed output. - - Note that input_file.c hand checks for '#' at the beginning of the - first line of the input file. This is because the compiler outputs - #NO_APP at the beginning of its output. */ - -/* Also note that comments started like this one will always work. */ - -const char line_comment_chars[] = "#"; -const char line_separator_chars[] = ";"; - -/* Chars that can be used to separate mant from exp in floating point nums. */ -const char EXP_CHARS[] = "eE"; - -/* Chars that mean this number is a floating point constant, - as in 0f12.456 or 0d1.2345e12. */ -const char FLT_CHARS[] = "fFdDtT"; - -/* Table used by base assembler to relax addresses based on varying length - instructions. The fields are: - 1) most positive reach of this state, - 2) most negative reach of this state, - 3) how many bytes this mode will add to the size of the current frag - 4) which index into the table to try if we can't fit into this one. - - For i80960, the only application is the (de-)optimization of cobr - instructions into separate compare and branch instructions when a 13-bit - displacement won't hack it. */ -const relax_typeS md_relax_table[] = -{ - {0, 0, 0, 0}, /* State 0 => no more relaxation possible. */ - {4088, -4096, 0, 2}, /* State 1: conditional branch (cobr). */ - {0x800000 - 8, -0x800000, 4, 0}, /* State 2: compare (reg) & branch (ctrl). */ -}; - -/* These are the machine dependent pseudo-ops. - - This table describes all the machine specific pseudo-ops the assembler - has to support. The fields are: - pseudo-op name without dot - function to call to execute this pseudo-op - integer arg to pass to the function. */ -#define S_LEAFPROC 1 -#define S_SYSPROC 2 - -/* Macros to extract info from an 'expressionS' structure 'e'. */ -#define adds(e) e.X_add_symbol -#define offs(e) e.X_add_number - -/* Branch-prediction bits for CTRL/COBR format opcodes. */ -#define BP_MASK 0x00000002 /* Mask for branch-prediction bit. */ -#define BP_TAKEN 0x00000000 /* Value to OR in to predict branch. */ -#define BP_NOT_TAKEN 0x00000002 /* Value to OR in to predict no branch. */ - -/* Some instruction opcodes that we need explicitly. */ -#define BE 0x12000000 -#define BG 0x11000000 -#define BGE 0x13000000 -#define BL 0x14000000 -#define BLE 0x16000000 -#define BNE 0x15000000 -#define BNO 0x10000000 -#define BO 0x17000000 -#define CHKBIT 0x5a002700 -#define CMPI 0x5a002080 -#define CMPO 0x5a002000 - -#define B 0x08000000 -#define BAL 0x0b000000 -#define CALL 0x09000000 -#define CALLS 0x66003800 -#define RET 0x0a000000 - -/* These masks are used to build up a set of MEMB mode bits. */ -#define A_BIT 0x0400 -#define I_BIT 0x0800 -#define MEMB_BIT 0x1000 -#define D_BIT 0x2000 - -/* Mask for the only mode bit in a MEMA instruction (if set, abase reg is - used). */ -#define MEMA_ABASE 0x2000 - -/* Info from which a MEMA or MEMB format instruction can be generated. */ -typedef struct memS - { - /* (First) 32 bits of instruction. */ - long opcode; - /* 0-(none), 12- or, 32-bit displacement needed. */ - int disp; - /* The expression in the source instruction from which the - displacement should be determined. */ - char *e; - } -memS; - -/* The two pieces of info we need to generate a register operand. */ -struct regop - { - int mode; /* 0 =>local/global/spec reg; 1=> literal or fp reg. */ - int special; /* 0 =>not a sfr; 1=> is a sfr (not valid w/mode=0). */ - int n; /* Register number or literal value. */ - }; - -/* Number and assembler mnemonic for all registers that can appear in - operands. */ -static const struct - { - const char *reg_name; - int reg_num; - } -regnames[] = -{ - { "pfp", 0 }, - { "sp", 1 }, - { "rip", 2 }, - { "r3", 3 }, - { "r4", 4 }, - { "r5", 5 }, - { "r6", 6 }, - { "r7", 7 }, - { "r8", 8 }, - { "r9", 9 }, - { "r10", 10 }, - { "r11", 11 }, - { "r12", 12 }, - { "r13", 13 }, - { "r14", 14 }, - { "r15", 15 }, - { "g0", 16 }, - { "g1", 17 }, - { "g2", 18 }, - { "g3", 19 }, - { "g4", 20 }, - { "g5", 21 }, - { "g6", 22 }, - { "g7", 23 }, - { "g8", 24 }, - { "g9", 25 }, - { "g10", 26 }, - { "g11", 27 }, - { "g12", 28 }, - { "g13", 29 }, - { "g14", 30 }, - { "fp", 31 }, - - /* Numbers for special-function registers are for assembler internal - use only: they are scaled back to range [0-31] for binary output. */ -#define SF0 32 - - { "sf0", 32 }, - { "sf1", 33 }, - { "sf2", 34 }, - { "sf3", 35 }, - { "sf4", 36 }, - { "sf5", 37 }, - { "sf6", 38 }, - { "sf7", 39 }, - { "sf8", 40 }, - { "sf9", 41 }, - { "sf10", 42 }, - { "sf11", 43 }, - { "sf12", 44 }, - { "sf13", 45 }, - { "sf14", 46 }, - { "sf15", 47 }, - { "sf16", 48 }, - { "sf17", 49 }, - { "sf18", 50 }, - { "sf19", 51 }, - { "sf20", 52 }, - { "sf21", 53 }, - { "sf22", 54 }, - { "sf23", 55 }, - { "sf24", 56 }, - { "sf25", 57 }, - { "sf26", 58 }, - { "sf27", 59 }, - { "sf28", 60 }, - { "sf29", 61 }, - { "sf30", 62 }, - { "sf31", 63 }, - - /* Numbers for floating point registers are for assembler internal - use only: they are scaled back to [0-3] for binary output. */ -#define FP0 64 - - { "fp0", 64 }, - { "fp1", 65 }, - { "fp2", 66 }, - { "fp3", 67 }, - - { NULL, 0 }, /* END OF LIST */ -}; - -#define IS_RG_REG(n) ((0 <= (n)) && ((n) < SF0)) -#define IS_SF_REG(n) ((SF0 <= (n)) && ((n) < FP0)) -#define IS_FP_REG(n) ((n) >= FP0) - -/* Number and assembler mnemonic for all registers that can appear as - 'abase' (indirect addressing) registers. */ -static const struct -{ - const char *areg_name; - int areg_num; -} -aregs[] = -{ - { "(pfp)", 0 }, - { "(sp)", 1 }, - { "(rip)", 2 }, - { "(r3)", 3 }, - { "(r4)", 4 }, - { "(r5)", 5 }, - { "(r6)", 6 }, - { "(r7)", 7 }, - { "(r8)", 8 }, - { "(r9)", 9 }, - { "(r10)", 10 }, - { "(r11)", 11 }, - { "(r12)", 12 }, - { "(r13)", 13 }, - { "(r14)", 14 }, - { "(r15)", 15 }, - { "(g0)", 16 }, - { "(g1)", 17 }, - { "(g2)", 18 }, - { "(g3)", 19 }, - { "(g4)", 20 }, - { "(g5)", 21 }, - { "(g6)", 22 }, - { "(g7)", 23 }, - { "(g8)", 24 }, - { "(g9)", 25 }, - { "(g10)", 26 }, - { "(g11)", 27 }, - { "(g12)", 28 }, - { "(g13)", 29 }, - { "(g14)", 30 }, - { "(fp)", 31 }, - -#define IPREL 32 - /* For assembler internal use only: this number never appears in binary - output. */ - { "(ip)", IPREL }, - - { NULL, 0 }, /* END OF LIST */ -}; - -/* Hash tables. */ -static struct hash_control *op_hash; /* Opcode mnemonics. */ -static struct hash_control *reg_hash; /* Register name hash table. */ -static struct hash_control *areg_hash; /* Abase register hash table. */ - -/* Architecture for which we are assembling. */ -#define ARCH_ANY 0 /* Default: no architecture checking done. */ -#define ARCH_KA 1 -#define ARCH_KB 2 -#define ARCH_MC 3 -#define ARCH_CA 4 -#define ARCH_JX 5 -#define ARCH_HX 6 -int architecture = ARCH_ANY; /* Architecture requested on invocation line. */ -int iclasses_seen; /* OR of instruction classes (I_* constants) - for which we've actually assembled - instructions. */ - -/* BRANCH-PREDICTION INSTRUMENTATION - - The following supports generation of branch-prediction instrumentation - (turned on by -b switch). The instrumentation collects counts - of branches taken/not-taken for later input to a utility that will - set the branch prediction bits of the instructions in accordance with - the behavior observed. (Note that the KX series does not have - branch-prediction.) - - The instrumentation consists of: - - (1) before and after each conditional branch, a call to an external - routine that increments and steps over an inline counter. The - counter itself, initialized to 0, immediately follows the call - instruction. For each branch, the counter following the branch - is the number of times the branch was not taken, and the difference - between the counters is the number of times it was taken. An - example of an instrumented conditional branch: - - call BR_CNT_FUNC - .word 0 - LBRANCH23: be label - call BR_CNT_FUNC - .word 0 - - (2) a table of pointers to the instrumented branches, so that an - external postprocessing routine can locate all of the counters. - the table begins with a 2-word header: a pointer to the next in - a linked list of such tables (initialized to 0); and a count - of the number of entries in the table (exclusive of the header. - - Note that input source code is expected to already contain calls - an external routine that will link the branch local table into a - list of such tables. */ - -/* Number of branches instrumented so far. Also used to generate - unique local labels for each instrumented branch. */ -static int br_cnt; - -#define BR_LABEL_BASE "LBRANCH" -/* Basename of local labels on instrumented branches, to avoid - conflict with compiler- generated local labels. */ - -#define BR_CNT_FUNC "__inc_branch" -/* Name of the external routine that will increment (and step over) an - inline counter. */ - -#define BR_TAB_NAME "__BRANCH_TABLE__" -/* Name of the table of pointers to branches. A local (i.e., - non-external) symbol. */ - -static void ctrl_fmt (const char *, long, int); - - -void -md_begin (void) -{ - int i; /* Loop counter. */ - const struct i960_opcode *oP; /* Pointer into opcode table. */ - const char *retval; /* Value returned by hash functions. */ - - op_hash = hash_new (); - reg_hash = hash_new (); - areg_hash = hash_new (); - - /* For some reason, the base assembler uses an empty string for "no - error message", instead of a NULL pointer. */ - retval = 0; - - for (oP = i960_opcodes; oP->name && !retval; oP++) - retval = hash_insert (op_hash, oP->name, (void *) oP); - - for (i = 0; regnames[i].reg_name && !retval; i++) - retval = hash_insert (reg_hash, regnames[i].reg_name, - (char *) ®names[i].reg_num); - - for (i = 0; aregs[i].areg_name && !retval; i++) - retval = hash_insert (areg_hash, aregs[i].areg_name, - (char *) &aregs[i].areg_num); - - if (retval) - as_fatal (_("Hashing returned \"%s\"."), retval); -} - -/* parse_expr: parse an expression - - Use base assembler's expression parser to parse an expression. - It, unfortunately, runs off a global which we have to save/restore - in order to make it work for us. - - An empty expression string is treated as an absolute 0. - - Sets O_illegal regardless of expression evaluation if entire input - string is not consumed in the evaluation -- tolerate no dangling junk! */ - -static void -parse_expr (const char *textP, /* Text of expression to be parsed. */ - expressionS *expP) /* Where to put the results of parsing. */ -{ - char *save_in; /* Save global here. */ - symbolS *symP; - - know (textP); - - if (*textP == '\0') - { - /* Treat empty string as absolute 0. */ - expP->X_add_symbol = expP->X_op_symbol = NULL; - expP->X_add_number = 0; - expP->X_op = O_constant; - } - else - { - save_in = input_line_pointer; /* Save global. */ - input_line_pointer = (char *) textP; /* Make parser work for us. */ - - (void) expression (expP); - if ((size_t) (input_line_pointer - textP) != strlen (textP)) - /* Did not consume all of the input. */ - expP->X_op = O_illegal; - - symP = expP->X_add_symbol; - if (symP && (hash_find (reg_hash, S_GET_NAME (symP)))) - /* Register name in an expression. */ - /* FIXME: this isn't much of a check any more. */ - expP->X_op = O_illegal; - - input_line_pointer = save_in; /* Restore global. */ - } -} - -/* emit: output instruction binary - - Output instruction binary, in target byte order, 4 bytes at a time. - Return pointer to where it was placed. */ - -static char * -emit (long instr) /* Word to be output, host byte order. */ -{ - char *toP; /* Where to output it. */ - - toP = frag_more (4); /* Allocate storage. */ - md_number_to_chars (toP, instr, 4); /* Convert to target byte order. */ - return toP; -} - -/* get_cdisp: handle displacement for a COBR or CTRL instruction. - - Parse displacement for a COBR or CTRL instruction. - - If successful, output the instruction opcode and set up for it, - depending on the arg 'var_frag', either: - o an address fixup to be done when all symbol values are known, or - o a varying length code fragment, with address fixup info. This - will be done for cobr instructions that may have to be relaxed - in to compare/branch instructions (8 bytes) if the final - address displacement is greater than 13 bits. */ - -static void -get_cdisp (const char *dispP, /* Displacement as specified in source instruction. */ - const char *ifmtP, /* "COBR" or "CTRL" (for use in error message). */ - long instr, /* Instruction needing the displacement. */ - int numbits, /* # bits of displacement (13 for COBR, 24 for CTRL). */ - int var_frag,/* 1 if varying length code fragment should be emitted; - 0 if an address fix should be emitted. */ - int callj) /* 1 if callj relocation should be done; else 0. */ -{ - expressionS e; /* Parsed expression. */ - fixS *fixP; /* Structure describing needed address fix. */ - char *outP; /* Where instruction binary is output to. */ - - fixP = NULL; - - parse_expr (dispP, &e); - switch (e.X_op) - { - case O_illegal: - as_bad (_("expression syntax error")); - break; - - case O_symbol: - if (S_GET_SEGMENT (e.X_add_symbol) == now_seg - || S_GET_SEGMENT (e.X_add_symbol) == undefined_section) - { - if (var_frag) - { - outP = frag_more (8); /* Allocate worst-case storage. */ - md_number_to_chars (outP, instr, 4); - frag_variant (rs_machine_dependent, 4, 4, 1, - adds (e), offs (e), outP); - } - else - { - /* Set up a new fix structure, so address can be updated - when all symbol values are known. */ - outP = emit (instr); - fixP = fix_new (frag_now, - outP - frag_now->fr_literal, - 4, - adds (e), - offs (e), - 1, - NO_RELOC); - - fixP->fx_tcbit = callj; - - /* We want to modify a bit field when the address is - known. But we don't need all the garbage in the - bit_fix structure. So we're going to lie and store - the number of bits affected instead of a pointer. */ - fixP->fx_bit_fixP = (bit_fixS *) (size_t) numbits; - } - } - else - as_bad (_("attempt to branch into different segment")); - break; - - default: - as_bad (_("target of %s instruction must be a label"), ifmtP); - break; - } -} - -static int -md_chars_to_number (char * val, /* Value in target byte order. */ - int n) /* Number of bytes in the input. */ -{ - int retval; - - for (retval = 0; n--;) - { - retval <<= 8; - retval |= (unsigned char) val[n]; - } - return retval; -} - -/* mema_to_memb: convert a MEMA-format opcode to a MEMB-format opcode. - - There are 2 possible MEMA formats: - - displacement only - - displacement + abase - - They are distinguished by the setting of the MEMA_ABASE bit. */ - -static void -mema_to_memb (char * opcodeP) /* Where to find the opcode, in target byte order. */ -{ - long opcode; /* Opcode in host byte order. */ - long mode; /* Mode bits for MEMB instruction. */ - - opcode = md_chars_to_number (opcodeP, 4); - know (!(opcode & MEMB_BIT)); - - mode = MEMB_BIT | D_BIT; - if (opcode & MEMA_ABASE) - mode |= A_BIT; - - opcode &= 0xffffc000; /* Clear MEMA offset and mode bits. */ - opcode |= mode; /* Set MEMB mode bits. */ - - md_number_to_chars (opcodeP, opcode, 4); -} - -/* targ_has_sfr: - - Return TRUE iff the target architecture supports the specified - special-function register (sfr). */ - -static int -targ_has_sfr (int n) /* Number (0-31) of sfr. */ -{ - switch (architecture) - { - case ARCH_KA: - case ARCH_KB: - case ARCH_MC: - case ARCH_JX: - return 0; - case ARCH_HX: - return ((0 <= n) && (n <= 4)); - case ARCH_CA: - default: - return ((0 <= n) && (n <= 2)); - } -} - -/* Look up a (suspected) register name in the register table and return the - associated register number (or -1 if not found). */ - -static int -get_regnum (char *regname) /* Suspected register name. */ -{ - int *rP; - - rP = (int *) hash_find (reg_hash, regname); - return (rP == NULL) ? -1 : *rP; -} - -/* syntax: Issue a syntax error. */ - -static void -syntax (void) -{ - as_bad (_("syntax error")); -} - -/* parse_regop: parse a register operand. - - In case of illegal operand, issue a message and return some valid - information so instruction processing can continue. */ - -static void -parse_regop (struct regop *regopP, /* Where to put description of register operand. */ - char *optext, /* Text of operand. */ - char opdesc) /* Descriptor byte: what's legal for this operand. */ -{ - int n; /* Register number. */ - expressionS e; /* Parsed expression. */ - - /* See if operand is a register. */ - n = get_regnum (optext); - if (n >= 0) - { - if (IS_RG_REG (n)) - { - /* Global or local register. */ - if (!REG_ALIGN (opdesc, n)) - as_bad (_("unaligned register")); - - regopP->n = n; - regopP->mode = 0; - regopP->special = 0; - return; - } - else if (IS_FP_REG (n) && FP_OK (opdesc)) - { - /* Floating point register, and it's allowed. */ - regopP->n = n - FP0; - regopP->mode = 1; - regopP->special = 0; - return; - } - else if (IS_SF_REG (n) && SFR_OK (opdesc)) - { - /* Special-function register, and it's allowed. */ - regopP->n = n - SF0; - regopP->mode = 0; - regopP->special = 1; - if (!targ_has_sfr (regopP->n)) - as_bad (_("no such sfr in this architecture")); - - return; - } - } - else if (LIT_OK (opdesc)) - { - /* How about a literal? */ - regopP->mode = 1; - regopP->special = 0; - if (FP_OK (opdesc)) - { - /* Floating point literal acceptable. */ - /* Skip over 0f, 0d, or 0e prefix. */ - if ((optext[0] == '0') - && (optext[1] >= 'd') - && (optext[1] <= 'f')) - optext += 2; - - if (!strcmp (optext, "0.0") || !strcmp (optext, "0")) - { - regopP->n = 0x10; - return; - } - - if (!strcmp (optext, "1.0") || !strcmp (optext, "1")) - { - regopP->n = 0x16; - return; - } - } - else - { - /* Fixed point literal acceptable. */ - parse_expr (optext, &e); - if (e.X_op != O_constant - || (offs (e) < 0) || (offs (e) > 31)) - { - as_bad (_("illegal literal")); - offs (e) = 0; - } - regopP->n = offs (e); - return; - } - } - - /* Nothing worked. */ - syntax (); - regopP->mode = 0; /* Register r0 is always a good one. */ - regopP->n = 0; - regopP->special = 0; -} - -/* get_ispec: parse a memory operand for an index specification - - Here, an "index specification" is taken to be anything surrounded - by square brackets and NOT followed by anything else. - - If it's found, detach it from the input string, remove the surrounding - square brackets, and return a pointer to it. Otherwise, return NULL. */ - -static char * -get_ispec (char *textP) /* Pointer to memory operand from source instruction, no white space. */ - -{ - /* Points to start of index specification. */ - char *start; - /* Points to end of index specification. */ - char *end; - - /* Find opening square bracket, if any. */ - start = strchr (textP, '['); - - if (start != NULL) - { - /* Eliminate '[', detach from rest of operand. */ - *start++ = '\0'; - - end = strchr (start, ']'); - - if (end == NULL) - as_bad (_("unmatched '['")); - else - { - /* Eliminate ']' and make sure it was the last thing - in the string. */ - *end = '\0'; - if (*(end + 1) != '\0') - as_bad (_("garbage after index spec ignored")); - } - } - return start; -} - -/* parse_memop: parse a memory operand - - This routine is based on the observation that the 4 mode bits of the - MEMB format, taken individually, have fairly consistent meaning: - - M3 (bit 13): 1 if displacement is present (D_BIT) - M2 (bit 12): 1 for MEMB instructions (MEMB_BIT) - M1 (bit 11): 1 if index is present (I_BIT) - M0 (bit 10): 1 if abase is present (A_BIT) - - So we parse the memory operand and set bits in the mode as we find - things. Then at the end, if we go to MEMB format, we need only set - the MEMB bit (M2) and our mode is built for us. - - Unfortunately, I said "fairly consistent". The exceptions: - - DBIA - 0100 Would seem illegal, but means "abase-only". - - 0101 Would seem to mean "abase-only" -- it means IP-relative. - Must be converted to 0100. - - 0110 Would seem to mean "index-only", but is reserved. - We turn on the D bit and provide a 0 displacement. - - The other thing to observe is that we parse from the right, peeling - things * off as we go: first any index spec, then any abase, then - the displacement. */ - -static void -parse_memop (memS *memP, /* Where to put the results. */ - char *argP, /* Text of the operand to be parsed. */ - int optype) /* MEM1, MEM2, MEM4, MEM8, MEM12, or MEM16. */ -{ - char *indexP; /* Pointer to index specification with "[]" removed. */ - char *p; /* Temp char pointer. */ - char iprel_flag; /* True if this is an IP-relative operand. */ - int regnum; /* Register number. */ - /* Scale factor: 1,2,4,8, or 16. Later converted to internal format - (0,1,2,3,4 respectively). */ - int scale; - int mode; /* MEMB mode bits. */ - int *intP; /* Pointer to register number. */ - - /* The following table contains the default scale factors for each - type of memory instruction. It is accessed using (optype-MEM1) - as an index -- thus it assumes the 'optype' constants are - assigned consecutive values, in the order they appear in this - table. */ - static const int def_scale[] = - { - 1, /* MEM1 */ - 2, /* MEM2 */ - 4, /* MEM4 */ - 8, /* MEM8 */ - -1, /* MEM12 -- no valid default */ - 16 /* MEM16 */ - }; - - iprel_flag = mode = 0; - - /* Any index present? */ - indexP = get_ispec (argP); - if (indexP) - { - p = strchr (indexP, '*'); - if (p == NULL) - { - /* No explicit scale -- use default for this instruction - type and assembler mode. */ - if (flag_mri) - scale = 1; - else - /* GNU960 compatibility */ - scale = def_scale[optype - MEM1]; - } - else - { - *p++ = '\0'; /* Eliminate '*' */ - - /* Now indexP->a '\0'-terminated register name, - and p->a scale factor. */ - - if (!strcmp (p, "16")) - scale = 16; - else if (strchr ("1248", *p) && (p[1] == '\0')) - scale = *p - '0'; - else - scale = -1; - } - - regnum = get_regnum (indexP); /* Get index reg. # */ - if (!IS_RG_REG (regnum)) - { - as_bad (_("invalid index register")); - return; - } - - /* Convert scale to its binary encoding. */ - switch (scale) - { - case 1: - scale = 0 << 7; - break; - case 2: - scale = 1 << 7; - break; - case 4: - scale = 2 << 7; - break; - case 8: - scale = 3 << 7; - break; - case 16: - scale = 4 << 7; - break; - default: - as_bad (_("invalid scale factor")); - return; - }; - - memP->opcode |= scale | regnum; /* Set index bits in opcode. */ - mode |= I_BIT; /* Found a valid index spec. */ - } - - /* Any abase (Register Indirect) specification present? */ - if ((p = strrchr (argP, '(')) != NULL) - { - /* "(" is there -- does it start a legal abase spec? If not, it - could be part of a displacement expression. */ - intP = (int *) hash_find (areg_hash, p); - if (intP != NULL) - { - /* Got an abase here. */ - regnum = *intP; - *p = '\0'; /* Discard register spec. */ - if (regnum == IPREL) - /* We have to special-case ip-rel mode. */ - iprel_flag = 1; - else - { - memP->opcode |= regnum << 14; - mode |= A_BIT; - } - } - } - - /* Any expression present? */ - memP->e = argP; - if (*argP != '\0') - mode |= D_BIT; - - /* Special-case ip-relative addressing. */ - if (iprel_flag) - { - if (mode & I_BIT) - syntax (); - else - { - memP->opcode |= 5 << 10; /* IP-relative mode. */ - memP->disp = 32; - } - return; - } - - /* Handle all other modes. */ - switch (mode) - { - case D_BIT | A_BIT: - /* Go with MEMA instruction format for now (grow to MEMB later - if 12 bits is not enough for the displacement). MEMA format - has a single mode bit: set it to indicate that abase is - present. */ - memP->opcode |= MEMA_ABASE; - memP->disp = 12; - break; - - case D_BIT: - /* Go with MEMA instruction format for now (grow to MEMB later - if 12 bits is not enough for the displacement). */ - memP->disp = 12; - break; - - case A_BIT: - /* For some reason, the bit string for this mode is not - consistent: it should be 0 (exclusive of the MEMB bit), so we - set it "by hand" here. */ - memP->opcode |= MEMB_BIT; - break; - - case A_BIT | I_BIT: - /* set MEMB bit in mode, and OR in mode bits. */ - memP->opcode |= mode | MEMB_BIT; - break; - - case I_BIT: - /* Treat missing displacement as displacement of 0. */ - mode |= D_BIT; - /* Fall through. */ - case D_BIT | A_BIT | I_BIT: - case D_BIT | I_BIT: - /* Set MEMB bit in mode, and OR in mode bits. */ - memP->opcode |= mode | MEMB_BIT; - memP->disp = 32; - break; - - default: - syntax (); - break; - } -} - -/* Generate a MEMA- or MEMB-format instruction. */ - -static void -mem_fmt (char *args[], /* args[0]->opcode mnemonic, args[1-3]->operands. */ - struct i960_opcode *oP,/* Pointer to description of instruction. */ - int callx) /* Is this a callx opcode. */ -{ - int i; /* Loop counter. */ - struct regop regop; /* Description of register operand. */ - char opdesc; /* Operand descriptor byte. */ - memS instr; /* Description of binary to be output. */ - char *outP; /* Where the binary was output to. */ - expressionS exp; /* Parsed expression. */ - /* ->description of deferred address fixup. */ - fixS *fixP; - -#ifdef OBJ_COFF - /* COFF support isn't in place yet for callx relaxing. */ - callx = 0; -#endif - - memset (&instr, '\0', sizeof (memS)); - instr.opcode = oP->opcode; - - /* Process operands. */ - for (i = 1; i <= oP->num_ops; i++) - { - opdesc = oP->operand[i - 1]; - - if (MEMOP (opdesc)) - parse_memop (&instr, args[i], oP->format); - else - { - parse_regop (®op, args[i], opdesc); - instr.opcode |= regop.n << 19; - } - } - - /* Parse the displacement; this must be done before emitting the - opcode, in case it is an expression using `.'. */ - parse_expr (instr.e, &exp); - - /* Output opcode. */ - outP = emit (instr.opcode); - - if (instr.disp == 0) - return; - - /* Process the displacement. */ - switch (exp.X_op) - { - case O_illegal: - as_bad (_("expression syntax error")); - break; - - case O_constant: - if (instr.disp == 32) - (void) emit (offs (exp)); /* Output displacement. */ - else - { - /* 12-bit displacement. */ - if (offs (exp) & ~0xfff) - { - /* Won't fit in 12 bits: convert already-output - instruction to MEMB format, output - displacement. */ - mema_to_memb (outP); - (void) emit (offs (exp)); - } - else - { - /* WILL fit in 12 bits: OR into opcode and - overwrite the binary we already put out. */ - instr.opcode |= offs (exp); - md_number_to_chars (outP, instr.opcode, 4); - } - } - break; - - default: - if (instr.disp == 12) - /* Displacement is dependent on a symbol, whose value - may change at link time. We HAVE to reserve 32 bits. - Convert already-output opcode to MEMB format. */ - mema_to_memb (outP); - - /* Output 0 displacement and set up address fixup for when - this symbol's value becomes known. */ - outP = emit ((long) 0); - fixP = fix_new_exp (frag_now, - outP - frag_now->fr_literal, - 4, &exp, 0, NO_RELOC); - /* Steve's linker relaxing hack. Mark this 32-bit relocation as - being in the instruction stream, specifically as part of a callx - instruction. */ - fixP->fx_bsr = callx; - break; - } -} - -/* targ_has_iclass: - - Return TRUE iff the target architecture supports the indicated - class of instructions. */ - -static int -targ_has_iclass (int ic) /* Instruction class; one of: - I_BASE, I_CX, I_DEC, I_KX, I_FP, I_MIL, I_CASIM, I_CX2, I_HX, I_HX2. */ -{ - iclasses_seen |= ic; - - switch (architecture) - { - case ARCH_KA: - return ic & (I_BASE | I_KX); - case ARCH_KB: - return ic & (I_BASE | I_KX | I_FP | I_DEC); - case ARCH_MC: - return ic & (I_BASE | I_KX | I_FP | I_DEC | I_MIL); - case ARCH_CA: - return ic & (I_BASE | I_CX | I_CX2 | I_CASIM); - case ARCH_JX: - return ic & (I_BASE | I_CX2 | I_JX); - case ARCH_HX: - return ic & (I_BASE | I_CX2 | I_JX | I_HX); - default: - if ((iclasses_seen & (I_KX | I_FP | I_DEC | I_MIL)) - && (iclasses_seen & (I_CX | I_CX2))) - { - as_warn (_("architecture of opcode conflicts with that of earlier instruction(s)")); - iclasses_seen &= ~ic; - } - return 1; - } -} - -/* shift_ok: - Determine if a "shlo" instruction can be used to implement a "ldconst". - This means that some number X < 32 can be shifted left to produce the - constant of interest. - - Return the shift count, or 0 if we can't do it. - Caller calculates X by shifting original constant right 'shift' places. */ - -static int -shift_ok (int n) /* The constant of interest. */ -{ - int shift; /* The shift count. */ - - if (n <= 0) - /* Can't do it for negative numbers. */ - return 0; - - /* Shift 'n' right until a 1 is about to be lost. */ - for (shift = 0; (n & 1) == 0; shift++) - n >>= 1; - - if (n >= 32) - return 0; - - return shift; -} - -/* parse_ldcont: - Parse and replace a 'ldconst' pseudo-instruction with an appropriate - i80960 instruction. - - Assumes the input consists of: - arg[0] opcode mnemonic ('ldconst') - arg[1] first operand (constant) - arg[2] name of register to be loaded - - Replaces opcode and/or operands as appropriate. - - Returns the new number of arguments, or -1 on failure. */ - -static int -parse_ldconst (char *arg[]) /* See above. */ -{ - int n; /* Constant to be loaded. */ - int shift; /* Shift count for "shlo" instruction. */ - static char buf[5]; /* Literal for first operand. */ - static char buf2[5]; /* Literal for second operand. */ - expressionS e; /* Parsed expression. */ - - arg[3] = NULL; /* So we can tell at the end if it got used or not. */ - - parse_expr (arg[1], &e); - switch (e.X_op) - { - default: - /* We're dependent on one or more symbols -- use "lda". */ - arg[0] = (char *) "lda"; - break; - - case O_constant: - /* Try the following mappings: - ldconst 0,<reg> -> mov 0,<reg> - ldconst 31,<reg> -> mov 31,<reg> - ldconst 32,<reg> -> addo 1,31,<reg> - ldconst 62,<reg> -> addo 31,31,<reg> - ldconst 64,<reg> -> shlo 8,3,<reg> - ldconst -1,<reg> -> subo 1,0,<reg> - ldconst -31,<reg> -> subo 31,0,<reg> - - Anything else becomes: - lda xxx,<reg>. */ - n = offs (e); - if ((0 <= n) && (n <= 31)) - arg[0] = (char *) "mov"; - else if ((-31 <= n) && (n <= -1)) - { - arg[0] = (char *) "subo"; - arg[3] = arg[2]; - sprintf (buf, "%d", -n); - arg[1] = buf; - arg[2] = (char *) "0"; - } - else if ((32 <= n) && (n <= 62)) - { - arg[0] = (char *) "addo"; - arg[3] = arg[2]; - arg[1] = (char *) "31"; - sprintf (buf, "%d", n - 31); - arg[2] = buf; - } - else if ((shift = shift_ok (n)) != 0) - { - arg[0] = (char *) "shlo"; - arg[3] = arg[2]; - sprintf (buf, "%d", shift); - arg[1] = buf; - sprintf (buf2, "%d", n >> shift); - arg[2] = buf2; - } - else - arg[0] = (char *) "lda"; - break; - - case O_illegal: - as_bad (_("invalid constant")); - return -1; - break; - } - return (arg[3] == 0) ? 2 : 3; -} - -/* reg_fmt: generate a REG-format instruction. */ - -static void -reg_fmt (char *args[], /* args[0]->opcode mnemonic, args[1-3]->operands. */ - struct i960_opcode *oP)/* Pointer to description of instruction. */ -{ - long instr; /* Binary to be output. */ - struct regop regop; /* Description of register operand. */ - int n_ops; /* Number of operands. */ - - instr = oP->opcode; - n_ops = oP->num_ops; - - if (n_ops >= 1) - { - parse_regop (®op, args[1], oP->operand[0]); - - if ((n_ops == 1) && !(instr & M3)) - { - /* 1-operand instruction in which the dst field should - be used (instead of src1). */ - regop.n <<= 19; - if (regop.special) - regop.mode = regop.special; - regop.mode <<= 13; - regop.special = 0; - } - else - { - /* regop.n goes in bit 0, needs no shifting. */ - regop.mode <<= 11; - regop.special <<= 5; - } - instr |= regop.n | regop.mode | regop.special; - } - - if (n_ops >= 2) - { - parse_regop (®op, args[2], oP->operand[1]); - - if ((n_ops == 2) && !(instr & M3)) - { - /* 2-operand instruction in which the dst field should - be used instead of src2). */ - regop.n <<= 19; - if (regop.special) - regop.mode = regop.special; - regop.mode <<= 13; - regop.special = 0; - } - else - { - regop.n <<= 14; - regop.mode <<= 12; - regop.special <<= 6; - } - instr |= regop.n | regop.mode | regop.special; - } - if (n_ops == 3) - { - parse_regop (®op, args[3], oP->operand[2]); - if (regop.special) - regop.mode = regop.special; - instr |= (regop.n <<= 19) | (regop.mode <<= 13); - } - emit (instr); -} - -/* get_args: break individual arguments out of comma-separated list - - Input assumptions: - - all comments and labels have been removed - - all strings of whitespace have been collapsed to a single blank. - - all character constants ('x') have been replaced with decimal - - Output: - args[0] is untouched. args[1] points to first operand, etc. All args: - - are NULL-terminated - - contain no whitespace - - Return value: - Number of operands (0,1,2, or 3) or -1 on error. */ - -static int -get_args (char *p, /* Pointer to comma-separated operands; Mucked by us. */ - char *args[]) /* Output arg: pointers to operands placed in args[1-3]. - Must accommodate 4 entries (args[0-3]). */ - -{ - int n; /* Number of operands. */ - char *to; - - /* Skip lead white space. */ - while (*p == ' ') - p++; - - if (*p == '\0') - return 0; - - n = 1; - args[1] = p; - - /* Squeeze blanks out by moving non-blanks toward start of string. - Isolate operands, whenever comma is found. */ - to = p; - while (*p != '\0') - { - if (*p == ' ' - && (! ISALNUM (p[1]) - || ! ISALNUM (p[-1]))) - p++; - else if (*p == ',') - { - /* Start of operand. */ - if (n == 3) - { - as_bad (_("too many operands")); - return -1; - } - *to++ = '\0'; /* Terminate argument. */ - args[++n] = to; /* Start next argument. */ - p++; - } - else - *to++ = *p++; - } - *to = '\0'; - return n; -} - -/* i_scan: perform lexical scan of ascii assembler instruction. - - Input assumptions: - - input string is an i80960 instruction (not a pseudo-op) - - all comments and labels have been removed - - all strings of whitespace have been collapsed to a single blank. - - Output: - args[0] points to opcode, other entries point to operands. All strings: - - are NULL-terminated - - contain no whitespace - - have character constants ('x') replaced with a decimal number - - Return value: - Number of operands (0,1,2, or 3) or -1 on error. */ - -static int -i_scan (char *iP, /* Pointer to ascii instruction; Mucked by us. */ - char *args[]) /* Output arg: pointers to opcode and operands placed here. - Must accommodate 4 entries. */ -{ - /* Isolate opcode. */ - if (*(iP) == ' ') - iP++; - - args[0] = iP; - for (; *iP != ' '; iP++) - { - if (*iP == '\0') - { - /* There are no operands. */ - if (args[0] == iP) - { - /* We never moved: there was no opcode either! */ - as_bad (_("missing opcode")); - return -1; - } - return 0; - } - } - *iP++ = '\0'; - return (get_args (iP, args)); -} - -static void -brcnt_emit (void) -{ - /* Emit call to "increment" routine. */ - ctrl_fmt (BR_CNT_FUNC, CALL, 1); - /* Emit inline counter to be incremented. */ - emit (0); -} - -static char * -brlab_next (void) -{ - static char buf[20]; - - sprintf (buf, "%s%d", BR_LABEL_BASE, br_cnt++); - return buf; -} - -static void -ctrl_fmt (const char *targP, /* Pointer to text of lone operand (if any). */ - long opcode, /* Template of instruction. */ - int num_ops) /* Number of operands. */ -{ - int instrument; /* TRUE iff we should add instrumentation to track - how often the branch is taken. */ - - if (num_ops == 0) - emit (opcode); /* Output opcode. */ - else - { - instrument = instrument_branches && (opcode != CALL) - && (opcode != B) && (opcode != RET) && (opcode != BAL); - - if (instrument) - { - brcnt_emit (); - colon (brlab_next ()); - } - - /* The operand MUST be an ip-relative displacement. Parse it - and set up address fix for the instruction we just output. */ - get_cdisp (targP, "CTRL", opcode, 24, 0, 0); - - if (instrument) - brcnt_emit (); - } -} - -static void -cobr_fmt (/* arg[0]->opcode mnemonic, arg[1-3]->operands (ascii) */ - char *arg[], - /* Opcode, with branch-prediction bits already set if necessary. */ - long opcode, - /* Pointer to description of instruction. */ - struct i960_opcode *oP) -{ - long instr; /* 32-bit instruction. */ - struct regop regop; /* Description of register operand. */ - int n; /* Number of operands. */ - int var_frag; /* 1 if varying length code fragment should - be emitted; 0 if an address fix - should be emitted. */ - - instr = opcode; - n = oP->num_ops; - - if (n >= 1) - { - /* First operand (if any) of a COBR is always a register - operand. Parse it. */ - parse_regop (®op, arg[1], oP->operand[0]); - instr |= (regop.n << 19) | (regop.mode << 13); - } - - if (n >= 2) - { - /* Second operand (if any) of a COBR is always a register - operand. Parse it. */ - parse_regop (®op, arg[2], oP->operand[1]); - instr |= (regop.n << 14) | regop.special; - } - - if (n < 3) - emit (instr); - else - { - if (instrument_branches) - { - brcnt_emit (); - colon (brlab_next ()); - } - - /* A third operand to a COBR is always a displacement. Parse - it; if it's relaxable (a cobr "j" directive, or any cobr - other than bbs/bbc when the "-norelax" option is not in use) - set up a variable code fragment; otherwise set up an address - fix. */ - var_frag = !norelax || (oP->format == COJ); /* TRUE or FALSE */ - get_cdisp (arg[3], "COBR", instr, 13, var_frag, 0); - - if (instrument_branches) - brcnt_emit (); - } -} - -/* Assumptions about the passed-in text: - - all comments, labels removed - - text is an instruction - - all white space compressed to single blanks - - all character constants have been replaced with decimal. */ - -void -md_assemble (char *textP) -{ - /* Parsed instruction text, containing NO whitespace: arg[0]->opcode - mnemonic arg[1-3]->operands, with char constants replaced by - decimal numbers. */ - char *args[4]; - /* Number of instruction operands. */ - int n_ops; - /* Pointer to instruction description. */ - struct i960_opcode *oP; - /* TRUE iff opcode mnemonic included branch-prediction suffix (".f" - or ".t"). */ - int branch_predict; - /* Setting of branch-prediction bit(s) to be OR'd into instruction - opcode of CTRL/COBR format instructions. */ - long bp_bits; - /* Offset of last character in opcode mnemonic. */ - int n; - const char *bp_error_msg = _("branch prediction invalid on this opcode"); - - /* Parse instruction into opcode and operands. */ - memset (args, '\0', sizeof (args)); - - n_ops = i_scan (textP, args); - - if (n_ops == -1) - return; /* Error message already issued. */ - - /* Do "macro substitution" (sort of) on 'ldconst' pseudo-instruction. */ - if (!strcmp (args[0], "ldconst")) - { - n_ops = parse_ldconst (args); - if (n_ops == -1) - return; - } - - /* Check for branch-prediction suffix on opcode mnemonic, strip it off. */ - n = strlen (args[0]) - 1; - branch_predict = 0; - bp_bits = 0; - - if (args[0][n - 1] == '.' && (args[0][n] == 't' || args[0][n] == 'f')) - { - /* We could check here to see if the target architecture - supports branch prediction, but why bother? The bit will - just be ignored by processors that don't use it. */ - branch_predict = 1; - bp_bits = (args[0][n] == 't') ? BP_TAKEN : BP_NOT_TAKEN; - args[0][n - 1] = '\0'; /* Strip suffix from opcode mnemonic */ - } - - /* Look up opcode mnemonic in table and check number of operands. - Check that opcode is legal for the target architecture. If all - looks good, assemble instruction. */ - oP = (struct i960_opcode *) hash_find (op_hash, args[0]); - if (!oP || !targ_has_iclass (oP->iclass)) - as_bad (_("invalid opcode, \"%s\"."), args[0]); - else if (n_ops != oP->num_ops) - as_bad (_("improper number of operands. Expecting %d, got %d"), - oP->num_ops, n_ops); - else - { - switch (oP->format) - { - case FBRA: - case CTRL: - ctrl_fmt (args[1], oP->opcode | bp_bits, oP->num_ops); - if (oP->format == FBRA) - /* Now generate a 'bno' to same arg */ - ctrl_fmt (args[1], BNO | bp_bits, 1); - break; - case COBR: - case COJ: - cobr_fmt (args, oP->opcode | bp_bits, oP); - break; - case REG: - if (branch_predict) - as_warn ("%s", bp_error_msg); - reg_fmt (args, oP); - break; - case MEM1: - if (args[0][0] == 'c' && args[0][1] == 'a') - { - if (branch_predict) - as_warn ("%s", bp_error_msg); - mem_fmt (args, oP, 1); - break; - } - /* Fall through. */ - case MEM2: - case MEM4: - case MEM8: - case MEM12: - case MEM16: - if (branch_predict) - as_warn ("%s", bp_error_msg); - mem_fmt (args, oP, 0); - break; - case CALLJ: - if (branch_predict) - as_warn ("%s", bp_error_msg); - /* Output opcode & set up "fixup" (relocation); flag - relocation as 'callj' type. */ - know (oP->num_ops == 1); - get_cdisp (args[1], "CTRL", oP->opcode, 24, 0, 1); - break; - default: - BAD_CASE (oP->format); - break; - } - } -} - -void -md_number_to_chars (char *buf, - valueT value, - int n) -{ - number_to_chars_littleendian (buf, value, n); -} - -const char * -md_atof (int type, char *litP, int *sizeP) -{ - return ieee_md_atof (type, litP, sizeP, FALSE); -} - -static void -md_number_to_imm (char *buf, long val, int n) -{ - md_number_to_chars (buf, val, n); -} - -static void -md_number_to_field (char *instrP, /* Pointer to instruction to be fixed. */ - long val, /* Address fixup value. */ - bit_fixS *bfixP) /* Description of bit field to be fixed up. */ -{ - int numbits; /* Length of bit field to be fixed. */ - long instr; /* 32-bit instruction to be fixed-up. */ - long sign; /* 0 or -1, according to sign bit of 'val'. */ - - /* Convert instruction back to host byte order. */ - instr = md_chars_to_number (instrP, 4); - - /* Surprise! -- we stored the number of bits to be modified rather - than a pointer to a structure. */ - numbits = (int) (size_t) bfixP; - if (numbits == 1) - /* This is a no-op, stuck here by reloc_callj(). */ - return; - - know ((numbits == 13) || (numbits == 24)); - - /* Propagate sign bit of 'val' for the given number of bits. Result - should be all 0 or all 1. */ - sign = val >> ((int) numbits - 1); - if (((val < 0) && (sign != -1)) - || ((val > 0) && (sign != 0))) - as_bad (_("Fixup of %ld too large for field width of %d"), - val, numbits); - else - { - /* Put bit field into instruction and write back in target - * byte order. */ - val &= ~(-(1 << (int) numbits)); /* Clear unused sign bits. */ - instr |= val; - md_number_to_chars (instrP, instr, 4); - } -} - - -/* md_parse_option - Invocation line includes a switch not recognized by the base assembler. - See if it's a processor-specific option. For the 960, these are: - - -norelax: - Conditional branch instructions that require displacements - greater than 13 bits (or that have external targets) should - generate errors. The default is to replace each such - instruction with the corresponding compare (or chkbit) and - branch instructions. Note that the Intel "j" cobr directives - are ALWAYS "de-optimized" in this way when necessary, - regardless of the setting of this option. - - -b: - Add code to collect information about branches taken, for - later optimization of branch prediction bits by a separate - tool. COBR and CNTL format instructions have branch - prediction bits (in the CX architecture); if "BR" represents - an instruction in one of these classes, the following rep- - resents the code generated by the assembler: - - call <increment routine> - .word 0 # pre-counter - Label: BR - call <increment routine> - .word 0 # post-counter - - A table of all such "Labels" is also generated. - - -AKA, -AKB, -AKC, -ASA, -ASB, -AMC, -ACA: - Select the 80960 architecture. Instructions or features not - supported by the selected architecture cause fatal errors. - The default is to generate code for any instruction or feature - that is supported by SOME version of the 960 (even if this - means mixing architectures!). */ - -const char *md_shortopts = "A:b"; -struct option md_longopts[] = -{ -#define OPTION_LINKRELAX (OPTION_MD_BASE) - {"linkrelax", no_argument, NULL, OPTION_LINKRELAX}, - {"link-relax", no_argument, NULL, OPTION_LINKRELAX}, -#define OPTION_NORELAX (OPTION_MD_BASE + 1) - {"norelax", no_argument, NULL, OPTION_NORELAX}, - {"no-relax", no_argument, NULL, OPTION_NORELAX}, - {NULL, no_argument, NULL, 0} -}; -size_t md_longopts_size = sizeof (md_longopts); - -struct tabentry -{ - const char *flag; - int arch; -}; -static const struct tabentry arch_tab[] = -{ - {"KA", ARCH_KA}, - {"KB", ARCH_KB}, - {"SA", ARCH_KA}, /* Synonym for KA. */ - {"SB", ARCH_KB}, /* Synonym for KB. */ - {"KC", ARCH_MC}, /* Synonym for MC. */ - {"MC", ARCH_MC}, - {"CA", ARCH_CA}, - {"JX", ARCH_JX}, - {"HX", ARCH_HX}, - {NULL, 0} -}; - -int -md_parse_option (int c, const char *arg) -{ - switch (c) - { - case OPTION_LINKRELAX: - linkrelax = 1; - flag_keep_locals = 1; - break; - - case OPTION_NORELAX: - norelax = 1; - break; - - case 'b': - instrument_branches = 1; - break; - - case 'A': - { - const struct tabentry *tp; - const char *p = arg; - - for (tp = arch_tab; tp->flag != NULL; tp++) - if (!strcmp (p, tp->flag)) - break; - - if (tp->flag == NULL) - { - as_bad (_("invalid architecture %s"), p); - return 0; - } - else - architecture = tp->arch; - } - break; - - default: - return 0; - } - - return 1; -} - -void -md_show_usage (FILE *stream) -{ - int i; - - fprintf (stream, _("I960 options:\n")); - for (i = 0; arch_tab[i].flag; i++) - fprintf (stream, "%s-A%s", i ? " | " : "", arch_tab[i].flag); - fprintf (stream, _("\n\ - specify variant of 960 architecture\n\ --b add code to collect statistics about branches taken\n\ --link-relax preserve individual alignment directives so linker\n\ - can do relaxing (b.out format only)\n\ --no-relax don't alter compare-and-branch instructions for\n\ - long displacements\n")); -} - -/* relax_cobr: - Replace cobr instruction in a code fragment with equivalent branch and - compare instructions, so it can reach beyond a 13-bit displacement. - Set up an address fix/relocation for the new branch instruction. */ - -/* This "conditional jump" table maps cobr instructions into - equivalent compare and branch opcodes. */ - -static const -struct -{ - long compare; - long branch; -} - -coj[] = -{ /* COBR OPCODE: */ - { CHKBIT, BNO }, /* 0x30 - bbc */ - { CMPO, BG }, /* 0x31 - cmpobg */ - { CMPO, BE }, /* 0x32 - cmpobe */ - { CMPO, BGE }, /* 0x33 - cmpobge */ - { CMPO, BL }, /* 0x34 - cmpobl */ - { CMPO, BNE }, /* 0x35 - cmpobne */ - { CMPO, BLE }, /* 0x36 - cmpoble */ - { CHKBIT, BO }, /* 0x37 - bbs */ - { CMPI, BNO }, /* 0x38 - cmpibno */ - { CMPI, BG }, /* 0x39 - cmpibg */ - { CMPI, BE }, /* 0x3a - cmpibe */ - { CMPI, BGE }, /* 0x3b - cmpibge */ - { CMPI, BL }, /* 0x3c - cmpibl */ - { CMPI, BNE }, /* 0x3d - cmpibne */ - { CMPI, BLE }, /* 0x3e - cmpible */ - { CMPI, BO }, /* 0x3f - cmpibo */ -}; - -static void -relax_cobr (fragS *fragP) /* fragP->fr_opcode is assumed to point to - the cobr instruction, which comes at the - end of the code fragment. */ -{ - int opcode, src1, src2, m1, s2; - /* Bit fields from cobr instruction. */ - long bp_bits; /* Branch prediction bits from cobr instruction. */ - long instr; /* A single i960 instruction. */ - /* ->instruction to be replaced. */ - char *iP; - fixS *fixP; /* Relocation that can be done at assembly time. */ - - /* Pick up & parse cobr instruction. */ - iP = fragP->fr_opcode; - instr = md_chars_to_number (iP, 4); - opcode = ((instr >> 24) & 0xff) - 0x30; /* "-0x30" for table index. */ - src1 = (instr >> 19) & 0x1f; - m1 = (instr >> 13) & 1; - s2 = instr & 1; - src2 = (instr >> 14) & 0x1f; - bp_bits = instr & BP_MASK; - - /* Generate and output compare instruction. */ - instr = coj[opcode].compare - | src1 | (m1 << 11) | (s2 << 6) | (src2 << 14); - md_number_to_chars (iP, instr, 4); - - /* Output branch instruction. */ - md_number_to_chars (iP + 4, coj[opcode].branch | bp_bits, 4); - - /* Set up address fixup/relocation. */ - fixP = fix_new (fragP, - iP + 4 - fragP->fr_literal, - 4, - fragP->fr_symbol, - fragP->fr_offset, - 1, - NO_RELOC); - - fixP->fx_bit_fixP = (bit_fixS *) 24; /* Store size of bit field. */ - - fragP->fr_fix += 4; - frag_wane (fragP); -} - -/* md_convert_frag: - - Called by base assembler after address relaxation is finished: modify - variable fragments according to how much relaxation was done. - - If the fragment substate is still 1, a 13-bit displacement was enough - to reach the symbol in question. Set up an address fixup, but otherwise - leave the cobr instruction alone. - - If the fragment substate is 2, a 13-bit displacement was not enough. - Replace the cobr with a two instructions (a compare and a branch). */ - -void -md_convert_frag (bfd *abfd ATTRIBUTE_UNUSED, - segT sec ATTRIBUTE_UNUSED, - fragS *fragP) -{ - /* Structure describing needed address fix. */ - fixS *fixP; - - switch (fragP->fr_subtype) - { - case 1: - /* Leave single cobr instruction. */ - fixP = fix_new (fragP, - fragP->fr_opcode - fragP->fr_literal, - 4, - fragP->fr_symbol, - fragP->fr_offset, - 1, - NO_RELOC); - - fixP->fx_bit_fixP = (bit_fixS *) 13; /* Size of bit field. */ - break; - case 2: - /* Replace cobr with compare/branch instructions. */ - relax_cobr (fragP); - break; - default: - BAD_CASE (fragP->fr_subtype); - break; - } -} - -/* md_estimate_size_before_relax: How much does it look like *fragP will grow? - - Called by base assembler just before address relaxation. - Return the amount by which the fragment will grow. - - Any symbol that is now undefined will not become defined; cobr's - based on undefined symbols will have to be replaced with a compare - instruction and a branch instruction, and the code fragment will grow - by 4 bytes. */ - -int -md_estimate_size_before_relax (fragS *fragP, segT segment_type) -{ - /* If symbol is undefined in this segment, go to "relaxed" state - (compare and branch instructions instead of cobr) right now. */ - if (S_GET_SEGMENT (fragP->fr_symbol) != segment_type) - { - relax_cobr (fragP); - return 4; - } - - return md_relax_table[fragP->fr_subtype].rlx_length; -} - -#if defined(OBJ_AOUT) | defined(OBJ_BOUT) - -/* md_ri_to_chars: - This routine exists in order to overcome machine byte-order problems - when dealing with bit-field entries in the relocation_info struct. - - But relocation info will be used on the host machine only (only - executable code is actually downloaded to the i80960). Therefore, - we leave it in host byte order. */ - -static void -md_ri_to_chars (char *where, struct relocation_info *ri) -{ - host_number_to_chars (where, ri->r_address, 4); - host_number_to_chars (where + 4, ri->r_index, 3); -#if WORDS_BIGENDIAN - where[7] = (ri->r_pcrel << 7 - | ri->r_length << 5 - | ri->r_extern << 4 - | ri->r_bsr << 3 - | ri->r_disp << 2 - | ri->r_callj << 1 - | ri->nuthin << 0); -#else - where[7] = (ri->r_pcrel << 0 - | ri->r_length << 1 - | ri->r_extern << 3 - | ri->r_bsr << 4 - | ri->r_disp << 5 - | ri->r_callj << 6 - | ri->nuthin << 7); -#endif -} - -#endif /* defined(OBJ_AOUT) | defined(OBJ_BOUT) */ - - -/* brtab_emit: generate the fetch-prediction branch table. - - See the comments above the declaration of 'br_cnt' for details on - branch-prediction instrumentation. - - The code emitted here would be functionally equivalent to the following - example assembler source. - - .data - .align 2 - BR_TAB_NAME: - .word 0 # link to next table - .word 3 # length of table - .word LBRANCH0 # 1st entry in table proper - .word LBRANCH1 - .word LBRANCH2 */ - -void -brtab_emit (void) -{ - int i; - char buf[20]; - /* Where the binary was output to. */ - char *p; - - if (!instrument_branches) - return; - - subseg_set (data_section, 0); /* .data */ - frag_align (2, 0, 0); /* .align 2 */ - record_alignment (now_seg, 2); - colon (BR_TAB_NAME); /* BR_TAB_NAME: */ - emit (0); /* .word 0 #link to next table */ - emit (br_cnt); /* .word n #length of table */ - - for (i = 0; i < br_cnt; i++) - { - sprintf (buf, "%s%d", BR_LABEL_BASE, i); - p = emit (0); - fix_new (frag_now, - p - frag_now->fr_literal, - 4, symbol_find (buf), 0, 0, NO_RELOC); - } -} - -/* s_leafproc: process .leafproc pseudo-op - - .leafproc takes two arguments, the second one is optional: - arg[1]: name of 'call' entry point to leaf procedure - arg[2]: name of 'bal' entry point to leaf procedure - - If the two arguments are identical, or if the second one is missing, - the first argument is taken to be the 'bal' entry point. - - If there are 2 distinct arguments, we must make sure that the 'bal' - entry point immediately follows the 'call' entry point in the linked - list of symbols. */ - -static void -s_leafproc (int n_ops, /* Number of operands. */ - char *args[]) /* args[1]->1st operand, args[2]->2nd operand. */ -{ - symbolS *callP; /* Pointer to leafproc 'call' entry point symbol. */ - symbolS *balP; /* Pointer to leafproc 'bal' entry point symbol. */ - - if ((n_ops != 1) && (n_ops != 2)) - { - as_bad (_("should have 1 or 2 operands")); - return; - } - - /* Find or create symbol for 'call' entry point. */ - callP = symbol_find_or_make (args[1]); - - if (TC_S_IS_CALLNAME (callP)) - as_warn (_("Redefining leafproc %s"), S_GET_NAME (callP)); - - /* If that was the only argument, use it as the 'bal' entry point. - Otherwise, mark it as the 'call' entry point and find or create - another symbol for the 'bal' entry point. */ - if ((n_ops == 1) || !strcmp (args[1], args[2])) - { - TC_S_FORCE_TO_BALNAME (callP); - } - else - { - TC_S_FORCE_TO_CALLNAME (callP); - - balP = symbol_find_or_make (args[2]); - if (TC_S_IS_CALLNAME (balP)) - as_warn (_("Redefining leafproc %s"), S_GET_NAME (balP)); - - TC_S_FORCE_TO_BALNAME (balP); - -#ifndef OBJ_ELF - tc_set_bal_of_call (callP, balP); -#endif - } -} - -/* s_sysproc: process .sysproc pseudo-op - - .sysproc takes two arguments: - arg[1]: name of entry point to system procedure - arg[2]: 'entry_num' (index) of system procedure in the range - [0,31] inclusive. - - For [ab].out, we store the 'entrynum' in the 'n_other' field of - the symbol. Since that entry is normally 0, we bias 'entrynum' - by adding 1 to it. It must be unbiased before it is used. */ - -static void -s_sysproc (int n_ops, /* Number of operands. */ - char *args[]) /* args[1]->1st operand, args[2]->2nd operand. */ -{ - expressionS exp; - symbolS *symP; - - if (n_ops != 2) - { - as_bad (_("should have two operands")); - return; - } - - /* Parse "entry_num" argument and check it for validity. */ - parse_expr (args[2], &exp); - if (exp.X_op != O_constant - || (offs (exp) < 0) - || (offs (exp) > 31)) - { - as_bad (_("'entry_num' must be absolute number in [0,31]")); - return; - } - - /* Find/make symbol and stick entry number (biased by +1) into it. */ - symP = symbol_find_or_make (args[1]); - - if (TC_S_IS_SYSPROC (symP)) - as_warn (_("Redefining entrynum for sysproc %s"), S_GET_NAME (symP)); - - TC_S_SET_SYSPROC (symP, offs (exp)); /* Encode entry number. */ - TC_S_FORCE_TO_SYSPROC (symP); -} - -/* parse_po: parse machine-dependent pseudo-op - - This is a top-level routine for machine-dependent pseudo-ops. It slurps - up the rest of the input line, breaks out the individual arguments, - and dispatches them to the correct handler. */ - -static void -parse_po (int po_num) /* Pseudo-op number: currently S_LEAFPROC or S_SYSPROC. */ -{ - /* Pointers operands, with no embedded whitespace. - arg[0] unused, arg[1-3]->operands. */ - char *args[4]; - int n_ops; /* Number of operands. */ - char *p; /* Pointer to beginning of unparsed argument string. */ - char eol; /* Character that indicated end of line. */ - - extern char is_end_of_line[]; - - /* Advance input pointer to end of line. */ - p = input_line_pointer; - while (!is_end_of_line[(unsigned char) *input_line_pointer]) - input_line_pointer++; - - eol = *input_line_pointer; /* Save end-of-line char. */ - *input_line_pointer = '\0'; /* Terminate argument list. */ - - /* Parse out operands. */ - n_ops = get_args (p, args); - if (n_ops == -1) - return; - - /* Dispatch to correct handler. */ - switch (po_num) - { - case S_SYSPROC: - s_sysproc (n_ops, args); - break; - case S_LEAFPROC: - s_leafproc (n_ops, args); - break; - default: - BAD_CASE (po_num); - break; - } - - /* Restore eol, so line numbers get updated correctly. Base - assembler assumes we leave input pointer pointing at char - following the eol. */ - *input_line_pointer++ = eol; -} - -/* reloc_callj: Relocate a 'callj' instruction - - This is a "non-(GNU)-standard" machine-dependent hook. The base - assembler calls it when it decides it can relocate an address at - assembly time instead of emitting a relocation directive. - - Check to see if the relocation involves a 'callj' instruction to a: - sysproc: Replace the default 'call' instruction with a 'calls' - leafproc: Replace the default 'call' instruction with a 'bal'. - other proc: Do nothing. - - See b.out.h for details on the 'n_other' field in a symbol structure. - - IMPORTANT!: - Assumes the caller has already figured out, in the case of a leafproc, - to use the 'bal' entry point, and has substituted that symbol into the - passed fixup structure. */ - -int -reloc_callj (fixS *fixP) /* Relocation that can be done at assembly time. */ -{ - /* Points to the binary for the instruction being relocated. */ - char *where; - - if (!fixP->fx_tcbit) - /* This wasn't a callj instruction in the first place. */ - return 0; - - where = fixP->fx_frag->fr_literal + fixP->fx_where; - - if (TC_S_IS_SYSPROC (fixP->fx_addsy)) - { - /* Symbol is a .sysproc: replace 'call' with 'calls'. System - procedure number is (other-1). */ - md_number_to_chars (where, CALLS | TC_S_GET_SYSPROC (fixP->fx_addsy), 4); - - /* Nothing else needs to be done for this instruction. Make - sure 'md_number_to_field()' will perform a no-op. */ - fixP->fx_bit_fixP = (bit_fixS *) 1; - } - else if (TC_S_IS_CALLNAME (fixP->fx_addsy)) - { - /* Should not happen: see block comment above. */ - as_fatal (_("Trying to 'bal' to %s"), S_GET_NAME (fixP->fx_addsy)); - } - else if (TC_S_IS_BALNAME (fixP->fx_addsy)) - { - /* Replace 'call' with 'bal'; both instructions have the same - format, so calling code should complete relocation as if - nothing happened here. */ - md_number_to_chars (where, BAL, 4); - } - else if (TC_S_IS_BADPROC (fixP->fx_addsy)) - as_bad (_("Looks like a proc, but can't tell what kind.\n")); - - /* Otherwise Symbol is neither a sysproc nor a leafproc. */ - return 0; -} - -/* Handle the MRI .endian pseudo-op. */ - -static void -s_endian (int ignore ATTRIBUTE_UNUSED) -{ - char *name; - char c; - - c = get_symbol_name (&name); - if (strcasecmp (name, "little") == 0) - ; - else if (strcasecmp (name, "big") == 0) - as_bad (_("big endian mode is not supported")); - else - as_warn (_("ignoring unrecognized .endian type `%s'"), name); - - (void) restore_line_pointer (c); - - demand_empty_rest_of_line (); -} - -/* We have no need to default values of symbols. */ - -symbolS * -md_undefined_symbol (char *name ATTRIBUTE_UNUSED) -{ - return 0; -} - -/* Exactly what point is a PC-relative offset relative TO? - On the i960, they're relative to the address of the instruction, - which we have set up as the address of the fixup too. */ -long -md_pcrel_from (fixS *fixP) -{ - return fixP->fx_where + fixP->fx_frag->fr_address; -} - -void -md_apply_fix (fixS *fixP, - valueT *valP, - segT seg ATTRIBUTE_UNUSED) -{ - long val = *valP; - char *place = fixP->fx_where + fixP->fx_frag->fr_literal; - - if (!fixP->fx_bit_fixP) - { - md_number_to_imm (place, val, fixP->fx_size); - } - else if ((int) (size_t) fixP->fx_bit_fixP == 13 - && fixP->fx_addsy != NULL - && S_GET_SEGMENT (fixP->fx_addsy) == undefined_section) - { - /* This is a COBR instruction. They have only a - 13-bit displacement and are only to be used - for local branches: flag as error, don't generate - relocation. */ - as_bad_where (fixP->fx_file, fixP->fx_line, - _("can't use COBR format with external label")); - fixP->fx_addsy = NULL; - } - else - md_number_to_field (place, val, fixP->fx_bit_fixP); - - if (fixP->fx_addsy == NULL) - fixP->fx_done = 1; -} - -#if defined(OBJ_AOUT) | defined(OBJ_BOUT) -void -tc_bout_fix_to_chars (char *where, - fixS *fixP, - relax_addressT segment_address_in_file) -{ - static const unsigned char nbytes_r_length[] = {42, 0, 1, 42, 2}; - struct relocation_info ri; - symbolS *symbolP; - - memset ((char *) &ri, '\0', sizeof (ri)); - symbolP = fixP->fx_addsy; - know (symbolP != 0 || fixP->fx_r_type != NO_RELOC); - ri.r_bsr = fixP->fx_bsr; /*SAC LD RELAX HACK */ - /* These two 'cuz of NS32K */ - ri.r_callj = fixP->fx_tcbit; - if (fixP->fx_bit_fixP) - ri.r_length = 2; - else - ri.r_length = nbytes_r_length[fixP->fx_size]; - ri.r_pcrel = fixP->fx_pcrel; - ri.r_address = fixP->fx_frag->fr_address + fixP->fx_where - segment_address_in_file; - - if (fixP->fx_r_type != NO_RELOC) - { - switch (fixP->fx_r_type) - { - case rs_align: - ri.r_index = -2; - ri.r_pcrel = 1; - ri.r_length = fixP->fx_size - 1; - break; - case rs_org: - ri.r_index = -2; - ri.r_pcrel = 0; - break; - case rs_fill: - ri.r_index = -1; - break; - default: - abort (); - } - ri.r_extern = 0; - } - else if (linkrelax || !S_IS_DEFINED (symbolP) || fixP->fx_bsr) - { - ri.r_extern = 1; - ri.r_index = symbolP->sy_number; - } - else - { - ri.r_extern = 0; - ri.r_index = S_GET_TYPE (symbolP); - } - - /* Output the relocation information in machine-dependent form. */ - md_ri_to_chars (where, &ri); -} - -#endif /* OBJ_AOUT or OBJ_BOUT */ - -/* Align an address by rounding it up to the specified boundary. */ - -valueT -md_section_align (segT seg, - valueT addr) /* Address to be rounded up. */ -{ - int align; - - align = bfd_get_section_alignment (stdoutput, seg); - return (addr + (1 << align) - 1) & -(1 << align); -} - -extern int coff_flags; - -/* For aout or bout, the bal immediately follows the call. - - For coff, we cheat and store a pointer to the bal symbol in the - second aux entry of the call. */ - -#undef OBJ_ABOUT -#ifdef OBJ_AOUT -#define OBJ_ABOUT -#endif -#ifdef OBJ_BOUT -#define OBJ_ABOUT -#endif - -void -tc_set_bal_of_call (symbolS *callP ATTRIBUTE_UNUSED, - symbolS *balP ATTRIBUTE_UNUSED) -{ - know (TC_S_IS_CALLNAME (callP)); - know (TC_S_IS_BALNAME (balP)); - -#ifdef OBJ_COFF - - callP->sy_tc = balP; - S_SET_NUMBER_AUXILIARY (callP, 2); - -#else /* ! OBJ_COFF */ -#ifdef OBJ_ABOUT - - /* If the 'bal' entry doesn't immediately follow the 'call' - symbol, unlink it from the symbol list and re-insert it. */ - if (symbol_next (callP) != balP) - { - symbol_remove (balP, &symbol_rootP, &symbol_lastP); - symbol_append (balP, callP, &symbol_rootP, &symbol_lastP); - } /* if not in order */ - -#else /* ! OBJ_ABOUT */ - as_fatal ("Only supported for a.out, b.out, or COFF"); -#endif /* ! OBJ_ABOUT */ -#endif /* ! OBJ_COFF */ -} - -symbolS * -tc_get_bal_of_call (symbolS *callP ATTRIBUTE_UNUSED) -{ - symbolS *retval; - - know (TC_S_IS_CALLNAME (callP)); - -#ifdef OBJ_COFF - retval = callP->sy_tc; -#else -#ifdef OBJ_ABOUT - retval = symbol_next (callP); -#else - as_fatal ("Only supported for a.out, b.out, or COFF"); -#endif /* ! OBJ_ABOUT */ -#endif /* ! OBJ_COFF */ - - know (TC_S_IS_BALNAME (retval)); - return retval; -} - -#ifdef OBJ_COFF -void -tc_coff_symbol_emit_hook (symbolS *symbolP ATTRIBUTE_UNUSED) -{ - if (TC_S_IS_CALLNAME (symbolP)) - { - symbolS *balP = tc_get_bal_of_call (symbolP); - - symbolP->sy_symbol.ost_auxent[1].x_bal.x_balntry = S_GET_VALUE (balP); - if (S_GET_STORAGE_CLASS (symbolP) == C_EXT) - S_SET_STORAGE_CLASS (symbolP, C_LEAFEXT); - else - S_SET_STORAGE_CLASS (symbolP, C_LEAFSTAT); - S_SET_DATA_TYPE (symbolP, S_GET_DATA_TYPE (symbolP) | (DT_FCN << N_BTSHFT)); - /* Fix up the bal symbol. */ - S_SET_STORAGE_CLASS (balP, C_LABEL); - } -} -#endif /* OBJ_COFF */ - -void -i960_handle_align (fragS *fragp ATTRIBUTE_UNUSED) -{ - if (!linkrelax) - return; - -#ifndef OBJ_BOUT - as_bad (_("option --link-relax is only supported in b.out format")); - linkrelax = 0; - return; -#else - - /* The text section "ends" with another alignment reloc, to which we - aren't adding padding. */ - if (fragp->fr_next == text_last_frag - || fragp->fr_next == data_last_frag) - return; - - /* alignment directive */ - fix_new (fragp, fragp->fr_fix, fragp->fr_offset, 0, 0, 0, - (int) fragp->fr_type); -#endif /* OBJ_BOUT */ -} - -int -i960_validate_fix (fixS *fixP, segT this_segment_type ATTRIBUTE_UNUSED) -{ - if (fixP->fx_tcbit && TC_S_IS_CALLNAME (fixP->fx_addsy)) - { - /* Relocation should be done via the associated 'bal' - entry point symbol. */ - if (!TC_S_IS_BALNAME (tc_get_bal_of_call (fixP->fx_addsy))) - { - as_bad_where (fixP->fx_file, fixP->fx_line, - _("No 'bal' entry point for leafproc %s"), - S_GET_NAME (fixP->fx_addsy)); - return 0; - } - fixP->fx_addsy = tc_get_bal_of_call (fixP->fx_addsy); - } - - return 1; -} - -/* From cgen.c: */ - -static short -tc_bfd_fix2rtype (fixS *fixP) -{ - if (fixP->fx_pcrel == 0 && fixP->fx_size == 4) - return BFD_RELOC_32; - - if (fixP->fx_pcrel != 0 && fixP->fx_size == 4) - return BFD_RELOC_24_PCREL; - - abort (); - return 0; -} - -/* Translate internal representation of relocation info to BFD target - format. - - FIXME: To what extent can we get all relevant targets to use this? */ - -arelent * -tc_gen_reloc (asection *section ATTRIBUTE_UNUSED, fixS *fixP) -{ - arelent * reloc; - - reloc = XNEW (arelent); - - /* HACK: Is this right? */ - fixP->fx_r_type = tc_bfd_fix2rtype (fixP); - - reloc->howto = bfd_reloc_type_lookup (stdoutput, fixP->fx_r_type); - if (reloc->howto == NULL) - { - as_bad_where (fixP->fx_file, fixP->fx_line, - _("internal error: can't export reloc type %d (`%s')"), - fixP->fx_r_type, - bfd_get_reloc_code_name (fixP->fx_r_type)); - return NULL; - } - - gas_assert (!fixP->fx_pcrel == !reloc->howto->pc_relative); - - reloc->sym_ptr_ptr = XNEW (asymbol *); - *reloc->sym_ptr_ptr = symbol_get_bfdsym (fixP->fx_addsy); - reloc->address = fixP->fx_frag->fr_address + fixP->fx_where; - reloc->addend = fixP->fx_addnumber; - - return reloc; -} - -/* end from cgen.c */ - -const pseudo_typeS md_pseudo_table[] = -{ - {"bss", s_lcomm, 1}, - {"endian", s_endian, 0}, - {"extended", float_cons, 't'}, - {"leafproc", parse_po, S_LEAFPROC}, - {"sysproc", parse_po, S_SYSPROC}, - - {"word", cons, 4}, - {"quad", cons, 16}, - - {0, 0, 0} -}; diff --git a/gas/config/tc-i960.h b/gas/config/tc-i960.h deleted file mode 100644 index 9c71150..0000000 --- a/gas/config/tc-i960.h +++ /dev/null @@ -1,185 +0,0 @@ -/* tc-i960.h - Basic 80960 instruction formats. - Copyright (C) 1989-2018 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 TC_I960 -#define TC_I960 1 - -#ifdef OBJ_ELF -#define TARGET_FORMAT "elf32-i960" -#define TARGET_ARCH bfd_arch_i960 -#endif - -#define TARGET_BYTES_BIG_ENDIAN 0 - -#define WORKING_DOT_WORD - -/* - * The 'COJ' instructions are actually COBR instructions with the 'b' in - * the mnemonic replaced by a 'j'; they are ALWAYS "de-optimized" if necessary: - * if the displacement will not fit in 13 bits, the assembler will replace them - * with the corresponding compare and branch instructions. - * - * All of the 'MEMn' instructions are the same format; the 'n' in the name - * indicates the default index scale factor (the size of the datum operated on). - * - * The FBRA formats are not actually an instruction format. They are the - * "convenience directives" for branching on floating-point comparisons, - * each of which generates 2 instructions (a 'bno' and one other branch). - * - * The CALLJ format is not actually an instruction format. It indicates that - * the instruction generated (a CTRL-format 'call') should have its relocation - * specially flagged for link-time replacement with a 'bal' or 'calls' if - * appropriate. - */ - -/* tailor gas */ -#define LOCAL_LABELS_FB 1 -#define BITFIELD_CONS_EXPRESSIONS - -/* tailor the coff format */ -#define COFF_MAGIC I960ROMAGIC -#define OBJ_COFF_MAX_AUXENTRIES (2) - -/* MEANING OF 'n_other' in the symbol record. - * - * If non-zero, the 'n_other' fields indicates either a leaf procedure or - * a system procedure, as follows: - * - * 1 <= n_other <= 32 : - * The symbol is the entry point to a system procedure. - * 'n_value' is the address of the entry, as for any other - * procedure. The system procedure number (which can be used in - * a 'calls' instruction) is (n_other-1). These entries come from - * '.sysproc' directives. - * - * n_other == N_CALLNAME - * the symbol is the 'call' entry point to a leaf procedure. - * The *next* symbol in the symbol table must be the corresponding - * 'bal' entry point to the procedure (see following). These - * entries come from '.leafproc' directives in which two different - * symbols are specified (the first one is represented here). - * - * - * n_other == N_BALNAME - * the symbol is the 'bal' entry point to a leaf procedure. - * These entries result from '.leafproc' directives in which only - * one symbol is specified, or in which the same symbol is - * specified twice. - * - * Note that an N_CALLNAME entry *must* have a corresponding N_BALNAME entry, - * but not every N_BALNAME entry must have an N_CALLNAME entry. - */ -#define N_CALLNAME ((char)-1) -#define N_BALNAME ((char)-2) - -/* i960 uses a custom relocation record. */ - -/* let obj-aout.h know */ -#define CUSTOM_RELOC_FORMAT 1 -/* let aout_gnu.h know */ -#define N_RELOCATION_INFO_DECLARED 1 -struct relocation_info - { - int r_address; /* File address of item to be relocated */ - unsigned - r_index:24, /* Index of symbol on which relocation is based*/ - r_pcrel:1, /* 1 => relocate PC-relative; else absolute - * On i960, pc-relative implies 24-bit - * address, absolute implies 32-bit. - */ - r_length:2, /* Number of bytes to relocate: - * 0 => 1 byte - * 1 => 2 bytes - * 2 => 4 bytes -- only value used for i960 - */ - r_extern:1, r_bsr:1, /* Something for the GNU NS32K assembler */ - r_disp:1, /* Something for the GNU NS32K assembler */ - r_callj:1, /* 1 if relocation target is an i960 'callj' */ - nuthin:1; /* Unused */ - }; - -/* No shared lib support, so we don't need to ensure externally - visible symbols can be overridden. */ -#define EXTERN_FORCE_RELOC 0 - -/* Makes no sense to use the difference of 2 arbitrary symbols - as the target of a call instruction. */ -#define TC_FORCE_RELOCATION_SUB_SAME(FIX, SEG) \ - (GENERIC_FORCE_RELOCATION_SUB_SAME (FIX, SEG) \ - || (FIX)->fx_tcbit \ - || TC_FORCE_RELOCATION (FIX)) - -/* reloc_callj() may replace a 'call' with a 'calls' or a - 'bal', in which cases it modifies *fixP as appropriate. - In the case of a 'calls', no further work is required. */ -extern int reloc_callj (struct fix *); - -#define TC_FORCE_RELOCATION_ABS(FIX) \ - (TC_FORCE_RELOCATION (FIX) \ - || reloc_callj (FIX)) - -#define TC_FORCE_RELOCATION_LOCAL(FIX) \ - (GENERIC_FORCE_RELOCATION_LOCAL (FIX) \ - || reloc_callj (FIX)) - -#ifdef OBJ_COFF - -/* We store the bal information in the sy_tc field. */ -#define TC_SYMFIELD_TYPE symbolS * - -#endif - -extern int i960_validate_fix (struct fix *, segT); -#define TC_VALIDATE_FIX(FIX,SEGTYPE,LABEL) \ - if (!i960_validate_fix (FIX, SEGTYPE)) goto LABEL - -#define tc_fix_adjustable(FIX) ((FIX)->fx_bsr == 0) - -#ifndef OBJ_ELF -/* Values passed to md_apply_fix sometimes include symbol values. */ -#define MD_APPLY_SYM_VALUE(FIX) tc_fix_adjustable (FIX) -#else -/* Values passed to md_apply_fix don't include the symbol value. */ -#define MD_APPLY_SYM_VALUE(FIX) 0 -#endif - -extern void brtab_emit (void); -#define md_end() brtab_emit () - -extern void tc_set_bal_of_call (symbolS *, symbolS *); - -extern struct symbol *tc_get_bal_of_call (symbolS *); - -extern void i960_handle_align (struct frag *); -#define HANDLE_ALIGN(FRAG) i960_handle_align (FRAG) -#define NO_RELOC -1 - -#define md_operand(x) - -extern const struct relax_type md_relax_table[]; -#define TC_GENERIC_RELAX_TABLE md_relax_table - -#define LINKER_RELAXING_SHRINKS_ONLY - -#define TC_FIX_TYPE struct { unsigned bsr : 1; } -#define fx_bsr tc_fix_data.bsr -#define TC_INIT_FIX_DATA(F) ((F)->tc_fix_data.bsr = 0) - -#endif diff --git a/gas/config/tc-m68k.c b/gas/config/tc-m68k.c index 13fb897..d73d154 100644 --- a/gas/config/tc-m68k.c +++ b/gas/config/tc-m68k.c @@ -5405,7 +5405,7 @@ md_estimate_size_before_relax (fragS *fragP, segT segment) return md_relax_table[fragP->fr_subtype].rlx_length; } -#if defined(OBJ_AOUT) | defined(OBJ_BOUT) +#if defined(OBJ_AOUT) /* the bit-field entries in the relocation_info struct plays hell with the byte-order problems of cross-assembly. So as a hack, I added this mach. dependent ri twiddler. Ugly, but it gets @@ -5433,7 +5433,7 @@ md_ri_to_chars (char *the_bytes, struct reloc_info_generic *ri) #endif -#endif /* OBJ_AOUT or OBJ_BOUT */ +#endif /* OBJ_AOUT */ #ifndef WORKING_DOT_WORD int md_short_jump_size = 4; diff --git a/gas/config/tc-score.c b/gas/config/tc-score.c index 146e86a..8b587c8 100644 --- a/gas/config/tc-score.c +++ b/gas/config/tc-score.c @@ -6217,8 +6217,7 @@ s3_s_score_lcomm (int bytes_p) *p = c; if ( -#if (defined (OBJ_AOUT) || defined (OBJ_MAYBE_AOUT) \ - || defined (OBJ_BOUT) || defined (OBJ_MAYBE_BOUT)) +#if (defined (OBJ_AOUT) || defined (OBJ_MAYBE_AOUT)) #ifdef BFD_ASSEMBLER (OUTPUT_FLAVOR != bfd_target_aout_flavour || (S_GET_OTHER (symbolP) == 0 && S_GET_DESC (symbolP) == 0)) && diff --git a/gas/config/tc-score7.c b/gas/config/tc-score7.c index 9cd6602..12271a3 100644 --- a/gas/config/tc-score7.c +++ b/gas/config/tc-score7.c @@ -6077,8 +6077,7 @@ s7_s_score_lcomm (int bytes_p) *p = c; if ( -#if (defined (OBJ_AOUT) || defined (OBJ_MAYBE_AOUT) \ - || defined (OBJ_BOUT) || defined (OBJ_MAYBE_BOUT)) +#if (defined (OBJ_AOUT) || defined (OBJ_MAYBE_AOUT)) #ifdef BFD_ASSEMBLER (OUTPUT_FLAVOR != bfd_target_aout_flavour || (S_GET_OTHER (symbolP) == 0 && S_GET_DESC (symbolP) == 0)) && diff --git a/gas/config/tc-sparc.c b/gas/config/tc-sparc.c index c21192a..1994452 100644 --- a/gas/config/tc-sparc.c +++ b/gas/config/tc-sparc.c @@ -365,10 +365,6 @@ sparc_target_format (void) #endif #endif -#ifdef OBJ_BOUT - return "b.out.big"; -#endif - #ifdef OBJ_COFF #ifdef TE_LYNX return "coff-sparc-lynx"; diff --git a/gas/configure b/gas/configure index 0504104..a4393b5 100755 --- a/gas/configure +++ b/gas/configure @@ -11936,7 +11936,7 @@ case "${host}" in esac -#We need this for the host. BOUT header is in host order. +#We need this for the host. { $as_echo "$as_me:${as_lineno-$LINENO}: checking whether byte ordering is bigendian" >&5 $as_echo_n "checking whether byte ordering is bigendian... " >&6; } if test "${ac_cv_c_bigendian+set}" = set; then : @@ -12250,11 +12250,6 @@ $as_echo "#define STRICTCOFF 1" >>confdefs.h fi ;; - i860-*-*) - { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: GAS support for ${generic_target} is preliminary and a work in progress" >&5 -$as_echo "$as_me: WARNING: GAS support for ${generic_target} is preliminary and a work in progress" >&2;} - ;; - microblaze*) ;; @@ -12863,9 +12858,6 @@ if test `set . $formats ; shift ; echo $#` -gt 1 ; then aout) $as_echo "#define OBJ_MAYBE_AOUT 1" >>confdefs.h ;; - bout) -$as_echo "#define OBJ_MAYBE_BOUT 1" >>confdefs.h - ;; coff) $as_echo "#define OBJ_MAYBE_COFF 1" >>confdefs.h ;; diff --git a/gas/configure.ac b/gas/configure.ac index 3b0279a..2c4e3eb 100644 --- a/gas/configure.ac +++ b/gas/configure.ac @@ -141,7 +141,7 @@ case "${host}" in esac AC_SUBST(GDBINIT) -#We need this for the host. BOUT header is in host order. +#We need this for the host. AC_C_BIGENDIAN te_file=generic @@ -213,10 +213,6 @@ for this_target in $target $canon_targets ; do fi ;; - i860-*-*) - AC_MSG_WARN(GAS support for ${generic_target} is preliminary and a work in progress) - ;; - microblaze*) ;; @@ -737,7 +733,6 @@ if test `set . $formats ; shift ; echo $#` -gt 1 ; then for fmt in $formats ; do case $fmt in aout) AC_DEFINE(OBJ_MAYBE_AOUT, 1, [a.out support?]) ;; - bout) AC_DEFINE(OBJ_MAYBE_BOUT, 1, [b.out support?]) ;; coff) AC_DEFINE(OBJ_MAYBE_COFF, 1, [COFF support?]) ;; ecoff) AC_DEFINE(OBJ_MAYBE_ECOFF, 1, [ECOFF support?]) ;; elf) AC_DEFINE(OBJ_MAYBE_ELF, 1, [ELF support?]) ;; diff --git a/gas/configure.tgt b/gas/configure.tgt index 6455fbb..0f5626b 100644 --- a/gas/configure.tgt +++ b/gas/configure.tgt @@ -292,10 +292,6 @@ case ${generic_target} in i386-*-rdos*) fmt=elf ;; i386-*-darwin*) fmt=macho ;; - i860-*-*) fmt=elf endian=little ;; - - i960-*-elf*) fmt=elf ;; - ia16-*-elf*) fmt=elf ;; ia64-*-elf*) fmt=elf ;; diff --git a/gas/doc/Makefile.am b/gas/doc/Makefile.am index 1faf805..aee70dd 100644 --- a/gas/doc/Makefile.am +++ b/gas/doc/Makefile.am @@ -60,8 +60,6 @@ CPU_DOCS = \ c-hppa.texi \ c-i370.texi \ c-i386.texi \ - c-i860.texi \ - c-i960.texi \ c-ip2k.texi \ c-lm32.texi \ c-m32c.texi \ diff --git a/gas/doc/Makefile.in b/gas/doc/Makefile.in index 5de99b3..8939093 100644 --- a/gas/doc/Makefile.in +++ b/gas/doc/Makefile.in @@ -335,8 +335,6 @@ CPU_DOCS = \ c-hppa.texi \ c-i370.texi \ c-i386.texi \ - c-i860.texi \ - c-i960.texi \ c-ip2k.texi \ c-lm32.texi \ c-m32c.texi \ diff --git a/gas/doc/all.texi b/gas/doc/all.texi index d3d3719..47d55df 100644 --- a/gas/doc/all.texi +++ b/gas/doc/all.texi @@ -39,8 +39,6 @@ @set HPPA @set I370 @set I80386 -@set I860 -@set I960 @set IA64 @set IP2K @set LM32 diff --git a/gas/doc/as.texinfo b/gas/doc/as.texinfo index 43286e9..dfd436f 100644 --- a/gas/doc/as.texinfo +++ b/gas/doc/as.texinfo @@ -32,7 +32,7 @@ @set COFF-ELF @end ifset @ifset AOUT -@set aout-bout +@set aout @end ifset @ifset ARM/Thumb @set ARM @@ -40,9 +40,6 @@ @ifset Blackfin @set Blackfin @end ifset -@ifset BOUT -@set aout-bout -@end ifset @ifset H8/300 @set H8 @end ifset @@ -337,14 +334,6 @@ gcc(1), ld(1), and the Info entries for @file{binutils} and @file{ld}. [@b{--32}|@b{--x32}|@b{--64}] [@b{-n}] [@b{-march}=@var{CPU}[+@var{EXTENSION}@dots{}]] [@b{-mtune}=@var{CPU}] @end ifset -@ifset I960 - -@emph{Target i960 options:} -@c see md_parse_option in tc-i960.c - [@b{-ACA}|@b{-ACA_A}|@b{-ACB}|@b{-ACC}|@b{-AKA}|@b{-AKB}| - @b{-AKC}|@b{-AMC}] - [@b{-b}] [@b{-no-relax}] -@end ifset @ifset IA64 @emph{Target IA-64 options:} @@ -1069,24 +1058,6 @@ an i386 processor. @end ifset @c man begin OPTIONS -@ifset I960 -The following options are available when @value{AS} is configured for the -Intel 80960 processor. - -@table @gcctabopt -@item -ACA | -ACA_A | -ACB | -ACC | -AKA | -AKB | -AKC | -AMC -Specify which variant of the 960 architecture is the target. - -@item -b -Add code to collect statistics about branches taken. - -@item -no-relax -Do not alter compare-and-branch instructions for long displacements; -error if necessary. - -@end table -@end ifset - @ifset IP2K The following options are available when @value{AS} is configured for the Ubicom IP2K series. @@ -1995,10 +1966,6 @@ For the @value{TARGET} target, @command{@value{AS}} is configured to produce @value{OBJ-NAME} format object files. @end ifclear @c The following should exhaust all configs that set MULTI-OBJ, ideally -@ifset I960 -On the @value{TARGET}, @command{@value{AS}} can be configured to produce either -@code{b.out} or COFF format object files. -@end ifset @ifset HPPA On the @value{TARGET}, @command{@value{AS}} can be configured to produce either SOM or ELF format object files. @@ -2104,16 +2071,7 @@ is itself synthesized from other files. @command{@value{AS}} understands the @kindex .o Every time you run @command{@value{AS}} it produces an output file, which is your assembly language program translated into numbers. This file -is the object file. Its default name is -@ifclear BOUT -@code{a.out}. -@end ifclear -@ifset BOUT -@ifset GENERIC -@code{a.out}, or -@end ifset -@code{b.out} when @command{@value{AS}} is configured for the Intel 80960. -@end ifset +is the object file. Its default name is @code{a.out}. You can give it another name by using the @option{-o} option. Conventionally, object file names end with @file{.o}. The default name is used for historical reasons: older assemblers were capable of assembling self-contained programs @@ -2447,8 +2405,8 @@ displayed for a given single line of source input. The default value is 4. @cindex MRI compatibility mode The @option{-M} or @option{--mri} option selects MRI compatibility mode. This changes the syntax and pseudo-op handling of @command{@value{AS}} to make it -compatible with the @code{ASM68K} or the @code{ASM960} (depending upon the -configured target) assembler from Microtec Research. The exact nature of the +compatible with the @code{ASM68K} assembler from Microtec Research. +The exact nature of the MRI syntax will not be documented here; see the MRI manuals for more information. Note in particular that the handling of macros and macro arguments is somewhat different. The purpose of this option is to permit @@ -2545,30 +2503,6 @@ The m68k @code{OPT} @code{D} option is the default, unlike the MRI assembler. The m68k @code{XREF} pseudo-op is ignored. -@item @code{.debug} pseudo-op - -The i960 @code{.debug} pseudo-op is not supported. - -@item @code{.extended} pseudo-op - -The i960 @code{.extended} pseudo-op is not supported. - -@item @code{.list} pseudo-op. - -The various options of the i960 @code{.list} pseudo-op are not supported. - -@item @code{.optimize} pseudo-op - -The i960 @code{.optimize} pseudo-op is not supported. - -@item @code{.output} pseudo-op - -The i960 @code{.output} pseudo-op is not supported. - -@item @code{.setreal} pseudo-op - -The i960 @code{.setreal} pseudo-op is not supported. - @end itemize @node MD @@ -2602,23 +2536,7 @@ disable this behaviour. @cindex naming object file @cindex object file name There is always one object file output when you run @command{@value{AS}}. By -default it has the name -@ifset GENERIC -@ifset I960 -@file{a.out} (or @file{b.out}, for Intel 960 targets only). -@end ifset -@ifclear I960 -@file{a.out}. -@end ifclear -@end ifset -@ifclear GENERIC -@ifset I960 -@file{b.out}. -@end ifset -@ifclear I960 -@file{a.out}. -@end ifclear -@end ifclear +default it has the name @file{a.out}. You use this option (which takes exactly one filename) to give the object file a different name. @@ -3153,9 +3071,6 @@ are floating point numbers, described below. * Bignums:: Bignums * Flonums:: Flonums @ifclear GENERIC -@ifset I960 -* Bit Fields:: Bit Fields -@end ifset @end ifclear @end menu @@ -3230,16 +3145,12 @@ A letter, to tell @command{@value{AS}} the rest of the number is a flonum. 4.2 assembler seems to allow any of @samp{defghDEFGH}.) @end ignore -On the H8/300, Renesas / SuperH SH, -and AMD 29K architectures, the letter must be +On the H8/300 and Renesas / SuperH SH architectures, the letter must be one of the letters @samp{DFPRSX} (in upper or lower case). On the ARC, the letter must be one of the letters @samp{DFRS} (in upper or lower case). -On the Intel 960 architecture, the letter must be -one of the letters @samp{DFT} (in upper or lower case). - On the HPPA architecture, the letter must be @samp{E} (upper case only). @end ifset @ifclear GENERIC @@ -3252,9 +3163,6 @@ One of the letters @samp{DFPRSX} (in upper or lower case). @ifset HPPA The letter @samp{E} (upper case only). @end ifset -@ifset I960 -One of the letters @samp{DFT} (in upper or lower case). -@end ifset @end ifclear @item @@ -3290,41 +3198,6 @@ present. The floating point number has the usual base-10 value. independently of any floating point hardware in the computer running @command{@value{AS}}. -@ifclear GENERIC -@ifset I960 -@c Bit fields are written as a general facility but are also controlled -@c by a conditional-compilation flag---which is as of now (21mar91) -@c turned on only by the i960 config of GAS. -@node Bit Fields -@subsubsection Bit Fields - -@cindex bit fields -@cindex constants, bit field -You can also define numeric constants as @dfn{bit fields}. -Specify two numbers separated by a colon--- -@example -@var{mask}:@var{value} -@end example -@noindent -@command{@value{AS}} applies a bitwise @sc{and} between @var{mask} and -@var{value}. - -The resulting number is then packed -@ifset GENERIC -@c this conditional paren in case bit fields turned on elsewhere than 960 -(in host-dependent byte order) -@end ifset -into a field whose width depends on which assembler directive has the -bit-field as its argument. Overflow (a result from the bitwise and -requiring more binary digits to represent) is not an error; instead, -more constants are generated, of the specified width, beginning with the -least significant digits.@refill - -The directives @code{.byte}, @code{.hword}, @code{.int}, @code{.long}, -@code{.short}, and @code{.word} accept bit-field arguments. -@end ifset -@end ifclear - @node Sections @chapter Sections and Relocation @cindex sections @@ -3486,7 +3359,7 @@ use of @command{@value{AS}} and have no meaning except during assembly. @cindex sections, named @item named sections @end ifset -@ifset aout-bout +@ifset aout @cindex text section @cindex data section @itemx text section @@ -3495,7 +3368,7 @@ use of @command{@value{AS}} and have no meaning except during assembly. These sections hold your program. @command{@value{AS}} and @code{@value{LD}} treat them as separate but equal sections. Anything you can say of one section is true of another. -@c @ifset aout-bout +@c @ifset aout When the program is running, however, it is customary for the text section to be unalterable. The text section is often shared among processes: it contains @@ -3615,7 +3488,7 @@ it in the expr section. @cindex numbered subsections @cindex grouping data -@ifset aout-bout +@ifset aout Assembled bytes @ifset COFF-ELF conventionally @@ -3627,10 +3500,10 @@ You may have separate groups of data in named sections @end ifset @ifclear GENERIC -@ifclear aout-bout +@ifclear aout data in named sections @end ifclear -@ifset aout-bout +@ifset aout text or data @end ifset @end ifclear @@ -3659,14 +3532,6 @@ On the H8/300 platform, each subsection is zero-padded to a word boundary (two bytes). The same is true on the Renesas SH. @end ifset -@ifset I960 -@c FIXME section padding (alignment)? -@c Rich Pixley says padding here depends on target obj code format; that -@c doesn't seem particularly useful to say without further elaboration, -@c so for now I say nothing about it. If this is a generic BFD issue, -@c these paragraphs might need to vanish from this manual, and be -@c discussed in BFD chapter of binutils (or some such). -@end ifset @end ifclear Subsections appear in your object file in numeric order, lowest numbered @@ -3990,19 +3855,9 @@ would want. @menu * Symbol Value:: Value * Symbol Type:: Type -@ifset aout-bout -@ifset GENERIC +@ifset aout * a.out Symbols:: Symbol Attributes: @code{a.out} @end ifset -@ifclear GENERIC -@ifclear BOUT -* a.out Symbols:: Symbol Attributes: @code{a.out} -@end ifclear -@ifset BOUT -* a.out Symbols:: Symbol Attributes: @code{a.out}, @code{b.out} -@end ifset -@end ifclear -@end ifset @ifset COFF * COFF Symbols:: Symbol Attributes for COFF @end ifset @@ -4043,39 +3898,13 @@ information, any flag settings indicating that a symbol is external, and (optionally), other information for linkers and debuggers. The exact format depends on the object-code output format in use. -@ifset aout-bout -@ifclear GENERIC -@ifset BOUT -@c The following avoids a "widow" subsection title. @group would be -@c better if it were available outside examples. -@need 1000 -@node a.out Symbols -@subsection Symbol Attributes: @code{a.out}, @code{b.out} - -@cindex @code{b.out} symbol attributes -@cindex symbol attributes, @code{b.out} -These symbol attributes appear only when @command{@value{AS}} is configured for -one of the Berkeley-descended object output formats---@code{a.out} or -@code{b.out}. - -@end ifset -@ifclear BOUT -@node a.out Symbols -@subsection Symbol Attributes: @code{a.out} - -@cindex @code{a.out} symbol attributes -@cindex symbol attributes, @code{a.out} - -@end ifclear -@end ifclear -@ifset GENERIC +@ifset aout @node a.out Symbols @subsection Symbol Attributes: @code{a.out} @cindex @code{a.out} symbol attributes @cindex symbol attributes, @code{a.out} -@end ifset @menu * Symbol Desc:: Descriptor * Symbol Other:: Other @@ -4410,7 +4239,7 @@ Some machine configurations provide additional directives. @ifset COFF * Def:: @code{.def @var{name}} @end ifset -@ifset aout-bout +@ifset aout * Desc:: @code{.desc @var{symbol}, @var{abs-expression}} @end ifset @ifset COFF @@ -4594,10 +4423,6 @@ quit also. One day @code{.abort} will not be supported. When producing COFF output, @command{@value{AS}} accepts this directive as a synonym for @samp{.abort}. -@ifset BOUT -When producing @code{b.out} output, @command{@value{AS}} accepts this directive, -but ignores it. -@end ifset @end ifset @node Align @@ -4624,7 +4449,7 @@ required alignment; this can be useful if you want the alignment to be filled with no-op instructions when appropriate. The way the required alignment is specified varies from system to system. -For the arc, hppa, i386 using ELF, i860, iq2000, m68k, or1k, +For the arc, hppa, i386 using ELF, iq2000, m68k, or1k, s390, sparc, tic4x, tic80 and xtensa, the first expression is the alignment request in bytes. For example @samp{.align 8} advances the location counter until it is a multiple of 8. If the location counter @@ -5163,15 +4988,9 @@ The byte ordering is target dependent. @cindex debugging COFF symbols Begin defining debugging information for a symbol @var{name}; the definition extends until the @code{.endef} directive is encountered. -@ifset BOUT - -This directive is only observed when @command{@value{AS}} is configured for COFF -format output; when producing @code{b.out}, @samp{.def} is recognized, -but ignored. -@end ifset @end ifset -@ifset aout-bout +@ifset aout @node Desc @section @code{.desc @var{symbol}, @var{abs-expression}} @@ -5199,12 +5018,6 @@ it, but produces no output, when configured for COFF. This directive is generated by compilers to include auxiliary debugging information in the symbol table. It is only permitted inside @code{.def}/@code{.endef} pairs. -@ifset BOUT - -@samp{.dim} is only meaningful when generating COFF format output; when -@command{@value{AS}} is generating @code{b.out}, it accepts this directive but -ignores it. -@end ifset @end ifset @node Double @@ -5265,12 +5078,6 @@ process anything in the file past the @code{.end} directive. @cindex @code{endef} directive This directive flags the end of a symbol definition begun with @code{.def}. -@ifset BOUT - -@samp{.endef} is only meaningful when generating COFF format output; if -@command{@value{AS}} is configured to generate @code{b.out}, it accepts this -directive but ignores it. -@end ifset @end ifset @node Endfunc @@ -5801,7 +5608,7 @@ assemblers, but ignores it. @cindex @code{line} directive @cindex logical line number -@ifset aout-bout +@ifset aout Change the logical line number. @var{line-number} must be an absolute expression. The next line has that logical line number. Therefore any other statements on the current line (after a statement separator character) are @@ -5886,12 +5693,6 @@ must be an absolute expression. The next line has that logical line number, so any other statements on the current line (after a statement separator character @code{;}) are reported as on logical line number @var{line-number} @minus{} 1. -@ifset BOUT - -This directive is accepted, but ignored, when @command{@value{AS}} is -configured for @code{b.out}; its effect is only associated with COFF -output format. -@end ifset @end ifset @node Loc @@ -6220,7 +6021,7 @@ instruction size limit is set to the maximum supported size. @node Octa @section @code{.octa @var{bignums}} -@c FIXME: double size emitted for "octa" on i960, others? Or warn? +@c FIXME: double size emitted for "octa" on some? Or warn? @cindex @code{octa} directive @cindex integer, 16-byte @cindex sixteen byte integer @@ -6535,12 +6336,6 @@ Set the storage-class value for a symbol. This directive may only be used inside a @code{.def}/@code{.endef} pair. Storage class may flag whether a symbol is static or external, or it may record further symbolic debugging information. -@ifset BOUT - -The @samp{.scl} directive is primarily associated with COFF output; when -configured to generate @code{b.out} output format, @command{@value{AS}} -accepts this directive but ignores it. -@end ifset @end ifset @ifset COFF-ELF @@ -6900,11 +6695,6 @@ For COFF targets, the @code{.size} directive is only permitted inside .size @var{expression} @end smallexample -@ifset BOUT -@samp{.size} is only meaningful when generating COFF format output; when -@command{@value{AS}} is generating @code{b.out}, it accepts this directive but -ignores it. -@end ifset @end ifset @ifset ELF @@ -7172,12 +6962,6 @@ This directive is generated by compilers to include auxiliary debugging information in the symbol table. It is only permitted inside @code{.def}/@code{.endef} pairs. Tags are used to link structure definitions in the symbol table with instances of those structures. -@ifset BOUT - -@samp{.tag} is only used when generating COFF format output; when -@command{@value{AS}} is generating @code{b.out}, it accepts this directive but -ignores it. -@end ifset @end ifset @node Text @@ -7225,11 +7009,6 @@ For COFF targets, this directive is permitted only within This records the integer @var{int} as the type attribute of a symbol table entry. -@ifset BOUT -@samp{.type} is associated only with COFF format output; when -@command{@value{AS}} is configured for @code{b.out} output, it accepts this -directive but ignores it. -@end ifset @end ifset @ifset ELF @@ -7328,11 +7107,6 @@ symbolic debugging format. @xref{Sleb128, ,@code{.sleb128}}. This directive, permitted only within @code{.def}/@code{.endef} pairs, records the address @var{addr} as the value attribute of a symbol table entry. -@ifset BOUT - -@samp{.val} is used only for COFF output; when @command{@value{AS}} is -configured for @code{b.out}, it accepts this directive but ignores it. -@end ifset @end ifset @ifset ELF @@ -7422,7 +7196,7 @@ The size of the number emitted, and its byte order, depend on what target computer the assembly is for. @end ifset -@c on amd29k, i960, sparc the "special treatment to support compilers" doesn't +@c on sparc the "special treatment to support compilers" doesn't @c happen---32-bit addressability, period; no long/short jumps. @ifset DIFF-TBL-KLUGE @cindex difference tables altered @@ -7764,12 +7538,6 @@ subject, see the hardware manufacturer's manual. @ifset I80386 * i386-Dependent:: Intel 80386 and AMD x86-64 Dependent Features @end ifset -@ifset I860 -* i860-Dependent:: Intel 80860 Dependent Features -@end ifset -@ifset I960 -* i960-Dependent:: Intel 80960 Dependent Features -@end ifset @ifset IA64 * IA-64-Dependent:: Intel IA-64 Dependent Features @end ifset @@ -7979,14 +7747,6 @@ family. @include c-i386.texi @end ifset -@ifset I860 -@include c-i860.texi -@end ifset - -@ifset I960 -@include c-i960.texi -@end ifset - @ifset IA64 @include c-ia64.texi @end ifset diff --git a/gas/doc/c-i860.texi b/gas/doc/c-i860.texi deleted file mode 100644 index 6e6726b..0000000 --- a/gas/doc/c-i860.texi +++ /dev/null @@ -1,197 +0,0 @@ -@c Copyright (C) 2000-2018 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 i860-Dependent -@chapter Intel i860 Dependent Features -@end ifset -@ifclear GENERIC -@node Machine Dependencies -@chapter Intel i860 Dependent Features -@end ifclear - -@ignore -@c FIXME: This is basically a stub for i860. There is tons more information -that I will add later (jle@cygnus.com). -@end ignore - -@cindex i860 support -@menu -* Notes-i860:: i860 Notes -* Options-i860:: i860 Command-line Options -* Directives-i860:: i860 Machine Directives -* Opcodes for i860:: i860 Opcodes -* Syntax of i860:: i860 Syntax -@end menu - -@node Notes-i860 -@section i860 Notes -This is a fairly complete i860 assembler which is compatible with the -UNIX System V/860 Release 4 assembler. However, it does not currently -support SVR4 PIC (i.e., @code{@@GOT, @@GOTOFF, @@PLT}). - -Like the SVR4/860 assembler, the output object format is ELF32. Currently, -this is the only supported object format. If there is sufficient interest, -other formats such as COFF may be implemented. - -Both the Intel and AT&T/SVR4 syntaxes are supported, with the latter -being the default. One difference is that AT&T syntax requires the '%' -prefix on register names while Intel syntax does not. Another difference -is in the specification of relocatable expressions. The Intel syntax -is @code{ha%expression} whereas the SVR4 syntax is @code{[expression]@@ha} -(and similarly for the "l" and "h" selectors). -@node Options-i860 -@section i860 Command-line Options -@subsection SVR4 compatibility options -@table @code -@item -V -Print assembler version. -@item -Qy -Ignored. -@item -Qn -Ignored. -@end table -@subsection Other options -@table @code -@item -EL -Select little endian output (this is the default). -@item -EB -Select big endian output. Note that the i860 always reads instructions -as little endian data, so this option only effects data and not -instructions. -@item -mwarn-expand -Emit a warning message if any pseudo-instruction expansions occurred. -For example, a @code{or} instruction with an immediate larger than 16-bits -will be expanded into two instructions. This is a very undesirable feature to -rely on, so this flag can help detect any code where it happens. One -use of it, for instance, has been to find and eliminate any place -where @code{gcc} may emit these pseudo-instructions. -@item -mxp -Enable support for the i860XP instructions and control registers. By default, -this option is disabled so that only the base instruction set (i.e., i860XR) -is supported. -@item -mintel-syntax -The i860 assembler defaults to AT&T/SVR4 syntax. This option enables the -Intel syntax. -@end table - -@node Directives-i860 -@section i860 Machine Directives - -@cindex machine directives, i860 -@cindex i860 machine directives - -@table @code -@cindex @code{dual} directive, i860 -@item .dual -Enter dual instruction mode. While this directive is supported, the -preferred way to use dual instruction mode is to explicitly code -the dual bit with the @code{d.} prefix. -@end table - -@table @code -@cindex @code{enddual} directive, i860 -@item .enddual -Exit dual instruction mode. While this directive is supported, the -preferred way to use dual instruction mode is to explicitly code -the dual bit with the @code{d.} prefix. -@end table - -@table @code -@cindex @code{atmp} directive, i860 -@item .atmp -Change the temporary register used when expanding pseudo operations. The -default register is @code{r31}. -@end table - -The @code{.dual}, @code{.enddual}, and @code{.atmp} directives are available only in the Intel syntax mode. - -Both syntaxes allow for the standard @code{.align} directive. However, -the Intel syntax additionally allows keywords for the alignment -parameter: "@code{.align type}", where `type' is one of @code{.short}, @code{.long}, -@code{.quad}, @code{.single}, @code{.double} representing alignments of 2, 4, -16, 4, and 8, respectively. - -@node Opcodes for i860 -@section i860 Opcodes - -@cindex opcodes, i860 -@cindex i860 opcodes -All of the Intel i860XR and i860XP machine instructions are supported. Please see -either @emph{i860 Microprocessor Programmer's Reference Manual} or @emph{i860 Microprocessor Architecture} for more information. -@subsection Other instruction support (pseudo-instructions) -For compatibility with some other i860 assemblers, a number of -pseudo-instructions are supported. While these are supported, they are -a very undesirable feature that should be avoided -- in particular, when -they result in an expansion to multiple actual i860 instructions. Below -are the pseudo-instructions that result in expansions. -@itemize @bullet -@item Load large immediate into general register: - -The pseudo-instruction @code{mov imm,%rn} (where the immediate does -not fit within a signed 16-bit field) will be expanded into: -@smallexample -orh large_imm@@h,%r0,%rn -or large_imm@@l,%rn,%rn -@end smallexample -@item Load/store with relocatable address expression: - -For example, the pseudo-instruction @code{ld.b addr_exp(%rx),%rn} -will be expanded into: -@smallexample -orh addr_exp@@ha,%rx,%r31 -ld.l addr_exp@@l(%r31),%rn -@end smallexample - -The analogous expansions apply to @code{ld.x, st.x, fld.x, pfld.x, fst.x}, and @code{pst.x} as well. -@item Signed large immediate with add/subtract: - -If any of the arithmetic operations @code{adds, addu, subs, subu} are used -with an immediate larger than 16-bits (signed), then they will be expanded. -For instance, the pseudo-instruction @code{adds large_imm,%rx,%rn} expands to: -@smallexample -orh large_imm@@h,%r0,%r31 -or large_imm@@l,%r31,%r31 -adds %r31,%rx,%rn -@end smallexample -@item Unsigned large immediate with logical operations: - -Logical operations (@code{or, andnot, or, xor}) also result in expansions. -The pseudo-instruction @code{or large_imm,%rx,%rn} results in: -@smallexample -orh large_imm@@h,%rx,%r31 -or large_imm@@l,%r31,%rn -@end smallexample - -Similarly for the others, except for @code{and} which expands to: -@smallexample -andnot (-1 - large_imm)@@h,%rx,%r31 -andnot (-1 - large_imm)@@l,%r31,%rn -@end smallexample -@end itemize - -@node Syntax of i860 -@section i860 Syntax -@menu -* i860-Chars:: Special Characters -@end menu - -@node i860-Chars -@subsection Special Characters - -@cindex line comment character, i860 -@cindex i860 line comment character -The presence of a @samp{#} appearing anywhere on a line indicates the -start of a comment that extends to the end of that line. - -If a @samp{#} appears as the first character of a line then the whole -line is treated as a comment, but in this case the line can also be a -logical line number directive (@pxref{Comments}) or a preprocessor -control command (@pxref{Preprocessing}). - -@cindex line separator, i860 -@cindex statement separator, i860 -@cindex i860 line separator -The @samp{;} character can be used to separate statements on the same -line. diff --git a/gas/doc/c-i960.texi b/gas/doc/c-i960.texi deleted file mode 100644 index 61ff13b..0000000 --- a/gas/doc/c-i960.texi +++ /dev/null @@ -1,324 +0,0 @@ -@c Copyright (C) 1991-2018 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 i960-Dependent -@chapter Intel 80960 Dependent Features -@end ifset -@ifclear GENERIC -@node Machine Dependencies -@chapter Intel 80960 Dependent Features -@end ifclear - -@cindex i960 support -@menu -* Options-i960:: i960 Command-line Options -* Floating Point-i960:: Floating Point -* Directives-i960:: i960 Machine Directives -* Opcodes for i960:: i960 Opcodes -* Syntax of i960:: i960 Syntax -@end menu - -@c FIXME! Add Syntax sec with discussion of bitfields here, at least so -@c long as they're not turned on for other machines than 960. - -@node Options-i960 - -@section i960 Command-line Options - -@cindex i960 options -@cindex options, i960 -@table @code - -@cindex i960 architecture options -@cindex architecture options, i960 -@cindex @code{-A} options, i960 -@item -ACA | -ACA_A | -ACB | -ACC | -AKA | -AKB | -AKC | -AMC -Select the 80960 architecture. Instructions or features not supported -by the selected architecture cause fatal errors. - -@samp{-ACA} is equivalent to @samp{-ACA_A}; @samp{-AKC} is equivalent to -@samp{-AMC}. Synonyms are provided for compatibility with other tools. - -If you do not specify any of these options, @code{@value{AS}} generates code -for any instruction or feature that is supported by @emph{some} version of the -960 (even if this means mixing architectures!). In principle, -@code{@value{AS}} attempts to deduce the minimal sufficient processor type if -none is specified; depending on the object code format, the processor type may -be recorded in the object file. If it is critical that the @code{@value{AS}} -output match a specific architecture, specify that architecture explicitly. - -@cindex @code{-b} option, i960 -@cindex branch recording, i960 -@cindex i960 branch recording -@item -b -Add code to collect information about conditional branches taken, for -later optimization using branch prediction bits. (The conditional branch -instructions have branch prediction bits in the CA, CB, and CC -architectures.) If @var{BR} represents a conditional branch instruction, -the following represents the code generated by the assembler when -@samp{-b} is specified: - -@smallexample - call @var{increment routine} - .word 0 # pre-counter -Label: @var{BR} - call @var{increment routine} - .word 0 # post-counter -@end smallexample - -The counter following a branch records the number of times that branch -was @emph{not} taken; the difference between the two counters is the -number of times the branch @emph{was} taken. - -@cindex @code{gbr960}, i960 postprocessor -@cindex branch statistics table, i960 -A table of every such @code{Label} is also generated, so that the -external postprocessor @code{gbr960} (supplied by Intel) can locate all -the counters. This table is always labeled @samp{__BRANCH_TABLE__}; -this is a local symbol to permit collecting statistics for many separate -object files. The table is word aligned, and begins with a two-word -header. The first word, initialized to 0, is used in maintaining linked -lists of branch tables. The second word is a count of the number of -entries in the table, which follow immediately: each is a word, pointing -to one of the labels illustrated above. - -@c TEXI2ROFF-KILL -@ifinfo -@c END TEXI2ROFF-KILL -@example - +------------+------------+------------+ ... +------------+ - | | | | | | - | *NEXT | COUNT: N | *BRLAB 1 | | *BRLAB N | - | | | | | | - +------------+------------+------------+ ... +------------+ - - __BRANCH_TABLE__ layout -@end example -@c TEXI2ROFF-KILL -@end ifinfo -@need 2000 -@tex -\vskip 1pc -\line{\leftskip=0pt\hskip\tableindent -\boxit{2cm}{\tt *NEXT}\boxit{2cm}{\tt COUNT: \it N}\boxit{2cm}{\tt -*BRLAB 1}\ibox{1cm}{\quad\dots}\boxit{2cm}{\tt *BRLAB \it N}\hfil} -\centerline{\it {\tt \_\_BRANCH\_TABLE\_\_} layout} -@end tex -@c END TEXI2ROFF-KILL - -The first word of the header is used to locate multiple branch tables, -since each object file may contain one. Normally the links are -maintained with a call to an initialization routine, placed at the -beginning of each function in the file. The @sc{gnu} C compiler -generates these calls automatically when you give it a @samp{-b} option. -For further details, see the documentation of @samp{gbr960}. - -@cindex @code{-no-relax} option, i960 -@item -no-relax -Normally, Compare-and-Branch instructions with targets that require -displacements greater than 13 bits (or that have external targets) are -replaced with the corresponding compare (or @samp{chkbit}) and branch -instructions. You can use the @samp{-no-relax} option to specify that -@code{@value{AS}} should generate errors instead, if the target displacement -is larger than 13 bits. - -This option does not affect the Compare-and-Jump instructions; the code -emitted for them is @emph{always} adjusted when necessary (depending on -displacement size), regardless of whether you use @samp{-no-relax}. -@end table - -@node Floating Point-i960 -@section Floating Point - -@cindex floating point, i960 (@sc{ieee}) -@cindex i960 floating point (@sc{ieee}) -@code{@value{AS}} generates @sc{ieee} floating-point numbers for the directives -@samp{.float}, @samp{.double}, @samp{.extended}, and @samp{.single}. - -@node Directives-i960 -@section i960 Machine Directives - -@cindex machine directives, i960 -@cindex i960 machine directives - -@table @code -@cindex @code{bss} directive, i960 -@item .bss @var{symbol}, @var{length}, @var{align} -Reserve @var{length} bytes in the bss section for a local @var{symbol}, -aligned to the power of two specified by @var{align}. @var{length} and -@var{align} must be positive absolute expressions. This directive -differs from @samp{.lcomm} only in that it permits you to specify -an alignment. @xref{Lcomm,,@code{.lcomm}}. -@end table - -@table @code -@cindex @code{extended} directive, i960 -@item .extended @var{flonums} -@code{.extended} expects zero or more flonums, separated by commas; for -each flonum, @samp{.extended} emits an @sc{ieee} extended-format (80-bit) -floating-point number. - -@cindex @code{leafproc} directive, i960 -@item .leafproc @var{call-lab}, @var{bal-lab} -You can use the @samp{.leafproc} directive in conjunction with the -optimized @code{callj} instruction to enable faster calls of leaf -procedures. If a procedure is known to call no other procedures, you -may define an entry point that skips procedure prolog code (and that does -not depend on system-supplied saved context), and declare it as the -@var{bal-lab} using @samp{.leafproc}. If the procedure also has an -entry point that goes through the normal prolog, you can specify that -entry point as @var{call-lab}. - -A @samp{.leafproc} declaration is meant for use in conjunction with the -optimized call instruction @samp{callj}; the directive records the data -needed later to choose between converting the @samp{callj} into a -@code{bal} or a @code{call}. - -@var{call-lab} is optional; if only one argument is present, or if the -two arguments are identical, the single argument is assumed to be the -@code{bal} entry point. - -@cindex @code{sysproc} directive, i960 -@item .sysproc @var{name}, @var{index} -The @samp{.sysproc} directive defines a name for a system procedure. -After you define it using @samp{.sysproc}, you can use @var{name} to -refer to the system procedure identified by @var{index} when calling -procedures with the optimized call instruction @samp{callj}. - -Both arguments are required; @var{index} must be between 0 and 31 -(inclusive). -@end table - -@node Opcodes for i960 -@section i960 Opcodes - -@cindex opcodes, i960 -@cindex i960 opcodes -All Intel 960 machine instructions are supported; -@pxref{Options-i960,,i960 Command-line Options} for a discussion of -selecting the instruction subset for a particular 960 -architecture.@refill - -Some opcodes are processed beyond simply emitting a single corresponding -instruction: @samp{callj}, and Compare-and-Branch or Compare-and-Jump -instructions with target displacements larger than 13 bits. - -@menu -* callj-i960:: @code{callj} -* Compare-and-branch-i960:: Compare-and-Branch -@end menu - -@node callj-i960 -@subsection @code{callj} - -@cindex @code{callj}, i960 pseudo-opcode -@cindex i960 @code{callj} pseudo-opcode -You can write @code{callj} to have the assembler or the linker determine -the most appropriate form of subroutine call: @samp{call}, -@samp{bal}, or @samp{calls}. If the assembly source contains -enough information---a @samp{.leafproc} or @samp{.sysproc} directive -defining the operand---then @code{@value{AS}} translates the -@code{callj}; if not, it simply emits the @code{callj}, leaving it -for the linker to resolve. - -@node Compare-and-branch-i960 -@subsection Compare-and-Branch - -@cindex i960 compare/branch instructions -@cindex compare/branch instructions, i960 -The 960 architectures provide combined Compare-and-Branch instructions -that permit you to store the branch target in the lower 13 bits of the -instruction word itself. However, if you specify a branch target far -enough away that its address won't fit in 13 bits, the assembler can -either issue an error, or convert your Compare-and-Branch instruction -into separate instructions to do the compare and the branch. - -@cindex compare and jump expansions, i960 -@cindex i960 compare and jump expansions -Whether @code{@value{AS}} gives an error or expands the instruction depends -on two choices you can make: whether you use the @samp{-no-relax} option, -and whether you use a ``Compare and Branch'' instruction or a ``Compare -and Jump'' instruction. The ``Jump'' instructions are @emph{always} -expanded if necessary; the ``Branch'' instructions are expanded when -necessary @emph{unless} you specify @code{-no-relax}---in which case -@code{@value{AS}} gives an error instead. - -These are the Compare-and-Branch instructions, their ``Jump'' variants, -and the instruction pairs they may expand into: - -@c TEXI2ROFF-KILL -@ifinfo -@c END TEXI2ROFF-KILL -@example - Compare and - Branch Jump Expanded to - ------ ------ ------------ - bbc chkbit; bno - bbs chkbit; bo - cmpibe cmpije cmpi; be - cmpibg cmpijg cmpi; bg - cmpibge cmpijge cmpi; bge - cmpibl cmpijl cmpi; bl - cmpible cmpijle cmpi; ble - cmpibno cmpijno cmpi; bno - cmpibne cmpijne cmpi; bne - cmpibo cmpijo cmpi; bo - cmpobe cmpoje cmpo; be - cmpobg cmpojg cmpo; bg - cmpobge cmpojge cmpo; bge - cmpobl cmpojl cmpo; bl - cmpoble cmpojle cmpo; ble - cmpobne cmpojne cmpo; bne -@end example -@c TEXI2ROFF-KILL -@end ifinfo -@tex -\hskip\tableindent -\halign{\hfil {\tt #}\quad&\hfil {\tt #}\qquad&{\tt #}\hfil\cr -\omit{\hfil\it Compare and\hfil}\span\omit&\cr -{\it Branch}&{\it Jump}&{\it Expanded to}\cr - bbc& & chkbit; bno\cr - bbs& & chkbit; bo\cr - cmpibe& cmpije& cmpi; be\cr - cmpibg& cmpijg& cmpi; bg\cr - cmpibge& cmpijge& cmpi; bge\cr - cmpibl& cmpijl& cmpi; bl\cr - cmpible& cmpijle& cmpi; ble\cr - cmpibno& cmpijno& cmpi; bno\cr - cmpibne& cmpijne& cmpi; bne\cr - cmpibo& cmpijo& cmpi; bo\cr - cmpobe& cmpoje& cmpo; be\cr - cmpobg& cmpojg& cmpo; bg\cr - cmpobge& cmpojge& cmpo; bge\cr - cmpobl& cmpojl& cmpo; bl\cr - cmpoble& cmpojle& cmpo; ble\cr - cmpobne& cmpojne& cmpo; bne\cr} -@end tex -@c END TEXI2ROFF-KILL - -@node Syntax of i960 -@section Syntax for the i960 -@menu -* i960-Chars:: Special Characters -@end menu - -@node i960-Chars -@subsection Special Characters - -@cindex line comment character, i960 -@cindex i960 line comment character -The presence of a @samp{#} on a line indicates the start of a comment -that extends to the end of the current line. - -If a @samp{#} appears as the first character of a line, the whole line -is treated as a comment, but in this case the line can also be a -logical line number directive (@pxref{Comments}) or a -preprocessor control command (@pxref{Preprocessing}). - -@cindex line separator, i960 -@cindex statement separator, i960 -@cindex i960 line separator -The @samp{;} character can be used to separate statements on the same -line. diff --git a/gas/doc/h8.texi b/gas/doc/h8.texi index 8a88d6b..6291c5d 100644 --- a/gas/doc/h8.texi +++ b/gas/doc/h8.texi @@ -7,7 +7,6 @@ @clear INTERNALS @clear MULTI-OBJ @clear AOUT -@clear BOUT @set COFF @clear ELF @set Renesas-all diff --git a/gas/doc/internals.texi b/gas/doc/internals.texi index 418c700..93352ec 100644 --- a/gas/doc/internals.texi +++ b/gas/doc/internals.texi @@ -1096,11 +1096,6 @@ You may define this macro to parse an expression used in a data allocation pseudo-op such as @code{.word}. You can use this to recognize relocation directives that may appear in such directives. -@item BITFIELD_CONS_EXPRESSION -@cindex BITFIELD_CONS_EXPRESSION -If you define this macro, GAS will recognize bitfield instructions in data -allocation pseudo-ops, as used on the i960. - @item REPEAT_CONS_EXPRESSION @cindex REPEAT_CONS_EXPRESSION If you define this macro, GAS will recognize repeat counts in data allocation @@ -1753,12 +1748,6 @@ no-op instructions, it must be able to expand or shrink the section contents while still preserving intra-section references and meeting alignment requirements. -For the i960 using b.out format, no expansion is done; instead, each -@samp{.align} directive causes extra space to be allocated, enough that when -the linker is relaxing a section and removing unneeded space, it can discard -some or all of this extra padding and cause the following data to be correctly -aligned. - For the H8/300, I think the linker expands calls that can't reach, and doesn't worry about alignment issues; the cpu probably never needs any significant alignment beyond the instruction size. @@ -1302,48 +1302,6 @@ operand (expressionS *expressionP, enum expr_mode mode) } #endif -#ifdef TC_I960 - /* The MRI i960 assembler permits - lda sizeof code,g13 - FIXME: This should use md_parse_name. */ - if (flag_mri - && (strcasecmp (name, "sizeof") == 0 - || strcasecmp (name, "startof") == 0)) - { - int start; - char *buf; - - start = (name[1] == 't' - || name[1] == 'T'); - - *input_line_pointer = c; - SKIP_WHITESPACE_AFTER_NAME (); - - c = get_symbol_name (& name); - if (! *name) - { - as_bad (_("expected symbol name")); - expressionP->X_op = O_absent; - (void) restore_line_pointer (c); - ignore_rest_of_line (); - break; - } - - buf = concat (start ? ".startof." : ".sizeof.", name, - (char *) NULL); - symbolP = symbol_make (buf); - free (buf); - - expressionP->X_op = O_symbol; - expressionP->X_add_symbol = symbolP; - expressionP->X_add_number = 0; - - *input_line_pointer = c; - SKIP_WHITESPACE_AFTER_NAME (); - break; - } -#endif - symbolP = symbol_find_or_make (name); /* If we have an absolute symbol or a reg, then we know its diff --git a/gas/po/POTFILES.in b/gas/po/POTFILES.in index 51bbb5b..f4fe666 100644 --- a/gas/po/POTFILES.in +++ b/gas/po/POTFILES.in @@ -76,10 +76,6 @@ config/tc-i370.c config/tc-i370.h config/tc-i386.c config/tc-i386.h -config/tc-i860.c -config/tc-i860.h -config/tc-i960.c -config/tc-i960.h config/tc-ia64.c config/tc-ia64.h config/tc-ip2k.c @@ -2972,81 +2972,10 @@ s_mri_sect (char *type ATTRIBUTE_UNUSED) demand_empty_rest_of_line (); #else /* ! TC_M68K */ -#ifdef TC_I960 - - char *name; - char c; - segT seg; - - SKIP_WHITESPACE (); - - c = get_symbol_name (& name); - - name = xstrdup (name); - - c = restore_line_pointer (c); - - seg = subseg_new (name, 0); - - if (c != ',') - *type = 'C'; - else - { - char *sectype; - - ++input_line_pointer; - SKIP_WHITESPACE (); - c = get_symbol_name (& sectype); - if (*sectype == '\0') - *type = 'C'; - else if (strcasecmp (sectype, "text") == 0) - *type = 'C'; - else if (strcasecmp (sectype, "data") == 0) - *type = 'D'; - else if (strcasecmp (sectype, "romdata") == 0) - *type = 'R'; - else - as_warn (_("unrecognized section type `%s'"), sectype); - (void) restore_line_pointer (c); - } - - if (*input_line_pointer == ',') - { - char *seccmd; - - ++input_line_pointer; - SKIP_WHITESPACE (); - c = get_symbol_name (& seccmd); - if (strcasecmp (seccmd, "absolute") == 0) - { - as_bad (_("absolute sections are not supported")); - *input_line_pointer = c; - ignore_rest_of_line (); - return; - } - else if (strcasecmp (seccmd, "align") == 0) - { - unsigned int align; - - (void) restore_line_pointer (c); - align = get_absolute_expression (); - record_alignment (seg, align); - } - else - { - as_warn (_("unrecognized section command `%s'"), seccmd); - (void) restore_line_pointer (c); - } - } - - demand_empty_rest_of_line (); - -#else /* ! TC_I960 */ /* The MRI assembler seems to use different forms of .sect for different targets. */ as_bad ("MRI mode not supported for this target"); ignore_rest_of_line (); -#endif /* ! TC_I960 */ #endif /* ! TC_M68K */ } @@ -3978,7 +3907,6 @@ pseudo_set (symbolS *symbolP) /* Some targets need to parse the expression in various fancy ways. You can define TC_PARSE_CONS_EXPRESSION to do whatever you like (for example, the HPPA does this). Otherwise, you can define - BITFIELD_CONS_EXPRESSIONS to permit bitfields to be specified, or REPEAT_CONS_EXPRESSIONS to permit repeat counts. If none of these are defined, which is the normal case, then only simple expressions are permitted. */ @@ -3989,12 +3917,6 @@ parse_mri_cons (expressionS *exp, unsigned int nbytes); #endif #ifndef TC_PARSE_CONS_EXPRESSION -#ifdef BITFIELD_CONS_EXPRESSIONS -#define TC_PARSE_CONS_EXPRESSION(EXP, NBYTES) \ - (parse_bitfield_cons (EXP, NBYTES), TC_PARSE_CONS_RETURN_NONE) -static void -parse_bitfield_cons (expressionS *exp, unsigned int nbytes); -#endif #ifdef REPEAT_CONS_EXPRESSIONS #define TC_PARSE_CONS_EXPRESSION(EXP, NBYTES) \ (parse_repeat_cons (EXP, NBYTES), TC_PARSE_CONS_RETURN_NONE) @@ -4658,136 +4580,6 @@ emit_expr_fix (expressionS *exp, unsigned int nbytes, fragS *frag, char *p, #endif } -#ifdef BITFIELD_CONS_EXPRESSIONS - -/* i960 assemblers, (eg, asm960), allow bitfields after ".byte" as - w:x,y:z, where w and y are bitwidths and x and y are values. They - then pack them all together. We do a little better in that we allow - them in words, longs, etc. and we'll pack them in target byte order - for you. - - The rules are: pack least significant bit first, if a field doesn't - entirely fit, put it in the next unit. Overflowing the bitfield is - explicitly *not* even a warning. The bitwidth should be considered - a "mask". - - To use this function the tc-XXX.h file should define - BITFIELD_CONS_EXPRESSIONS. */ - -static void -parse_bitfield_cons (expressionS *exp, unsigned int nbytes) -{ - unsigned int bits_available = BITS_PER_CHAR * nbytes; - char *hold = input_line_pointer; - - (void) expression (exp); - - if (*input_line_pointer == ':') - { - /* Bitfields. */ - long value = 0; - - for (;;) - { - unsigned long width; - - if (*input_line_pointer != ':') - { - input_line_pointer = hold; - break; - } /* Next piece is not a bitfield. */ - - /* In the general case, we can't allow - full expressions with symbol - differences and such. The relocation - entries for symbols not defined in this - assembly would require arbitrary field - widths, positions, and masks which most - of our current object formats don't - support. - - In the specific case where a symbol - *is* defined in this assembly, we - *could* build fixups and track it, but - this could lead to confusion for the - backends. I'm lazy. I'll take any - SEG_ABSOLUTE. I think that means that - you can use a previous .set or - .equ type symbol. xoxorich. */ - - if (exp->X_op == O_absent) - { - as_warn (_("using a bit field width of zero")); - exp->X_add_number = 0; - exp->X_op = O_constant; - } /* Implied zero width bitfield. */ - - if (exp->X_op != O_constant) - { - *input_line_pointer = '\0'; - as_bad (_("field width \"%s\" too complex for a bitfield"), hold); - *input_line_pointer = ':'; - demand_empty_rest_of_line (); - return; - } /* Too complex. */ - - if ((width = exp->X_add_number) > (BITS_PER_CHAR * nbytes)) - { - as_warn (ngettext ("field width %lu too big to fit in %d byte:" - " truncated to %d bits", - "field width %lu too big to fit in %d bytes:" - " truncated to %d bits", - nbytes), - width, nbytes, (BITS_PER_CHAR * nbytes)); - width = BITS_PER_CHAR * nbytes; - } /* Too big. */ - - if (width > bits_available) - { - /* FIXME-SOMEDAY: backing up and reparsing is wasteful. */ - input_line_pointer = hold; - exp->X_add_number = value; - break; - } /* Won't fit. */ - - /* Skip ':'. */ - hold = ++input_line_pointer; - - (void) expression (exp); - if (exp->X_op != O_constant) - { - char cache = *input_line_pointer; - - *input_line_pointer = '\0'; - as_bad (_("field value \"%s\" too complex for a bitfield"), hold); - *input_line_pointer = cache; - demand_empty_rest_of_line (); - return; - } /* Too complex. */ - - value |= ((~(-(1 << width)) & exp->X_add_number) - << ((BITS_PER_CHAR * nbytes) - bits_available)); - - if ((bits_available -= width) == 0 - || is_it_end_of_statement () - || *input_line_pointer != ',') - { - break; - } /* All the bitfields we're gonna get. */ - - hold = ++input_line_pointer; - (void) expression (exp); - } - - exp->X_add_number = value; - exp->X_op = O_constant; - exp->X_unsigned = 1; - exp->X_extrabit = 0; - } -} - -#endif /* BITFIELD_CONS_EXPRESSIONS */ - /* Handle an MRI style string expression. */ #ifdef TC_M68K diff --git a/gas/symbols.c b/gas/symbols.c index d16e804..08a708b 100644 --- a/gas/symbols.c +++ b/gas/symbols.c @@ -407,8 +407,7 @@ colon (/* Just seen "x:" - rattle symbols & frags. */ } else { -#if (!defined (OBJ_AOUT) && !defined (OBJ_MAYBE_AOUT) \ - && !defined (OBJ_BOUT) && !defined (OBJ_MAYBE_BOUT)) +#if (!defined (OBJ_AOUT) && !defined (OBJ_MAYBE_AOUT)) static const char *od_buf = ""; #else char od_buf[100]; diff --git a/gas/testsuite/gas/all/gas.exp b/gas/testsuite/gas/all/gas.exp index d828d4d..0355a03 100644 --- a/gas/testsuite/gas/all/gas.exp +++ b/gas/testsuite/gas/all/gas.exp @@ -106,7 +106,7 @@ case $target_triplet in { default { # Some targets don't manage to resolve BFD_RELOC_8 for constants. setup_xfail "alpha*-*-*" "*c30*-*-*" "*c4x*-*-*" \ - "d\[13\]0v*-*-*" "i860-*-*" \ + "d\[13\]0v*-*-*" \ "nds32*-*-*" "pdp11-*-*" "xtensa*-*-*" run_dump_test forward } @@ -335,8 +335,7 @@ if { ([istarget *-*-coff*] && ![istarget arm*-*-coff] && ![istarget *c4x*-*-co || [istarget i*86-*-cygwin*] \ || [istarget x86_64-*-mingw*] \ || [istarget i*86-*-*nt] \ - || [istarget i*86-*-interix*] \ - || ([istarget i960-*-vxworks5.*] && ![istarget i960-*-vxworks5.0*]) } { + || [istarget i*86-*-interix*] } { run_dump_test cofftag } @@ -413,10 +412,7 @@ if { ![istarget "powerpc*-*-*"] && ![istarget "rs6000*-*-*"] && ![istarget "s390 run_dump_test byte } -# .quad is 16 bytes on i960. -if { ![istarget "i960-*-*"] } { - run_dump_test quad -} +run_dump_test quad # som doesn't use .data section. case $target_triplet in { @@ -467,9 +463,6 @@ case $target_triplet in { { "mmix-*-*" } { set nop_type 5 } - { "i960-*-*" } { - set nop_type 4 - } { "i370-*-*" } { set nop_type 3 } diff --git a/gas/testsuite/gas/i860/README.i860 b/gas/testsuite/gas/i860/README.i860 deleted file mode 100644 index 47feaa4..0000000 --- a/gas/testsuite/gas/i860/README.i860 +++ /dev/null @@ -1,39 +0,0 @@ - -Testsuite for the i860 version of the GNU assembler ---------------------------------------------------- - -This is a simple testsuite for the i860 assembler. It currently -consists mostly of testcases for checking that every instruction is -parsed correctly and that correct object code is generated (these -are called "blah.s"). The files called "blah-err.s" test for error -conditions. - -The suite includes testcases for the base i860XR instruction set as well -as the enhanced i860XP instructions and control registers. - -The expected results files were generated using the UNIX System V/i860 -Release 4 vendor assembler (/usr/ccs/bin/as -V reports version -"Standard C Development Environment (SCDE) 5.0 12/08/89"). This -way GAS/i860 is tested against a known good assembler. - -TODO: - - Relocation testing is basically non-existent. - - pst.d (pixel store) is the only instruction with no testcase. - - Some pseudo instructions need testcases (mov, all pfmov, etc.). - - More tests for dual instruction mode: check that dual mode has a - proper pair (FLOP/core) of instructions, and other error conditions. - - Most current testcases use the default AT&T/SVR4 syntax; a few simple - tests of the Intel syntax should be added to prevent bitrot (including - relocatable expression syntax, etc). Test file dual03.s uses Intel - syntax lightly (i.e., register names without '%' prefix). - -Contact me (Jason Eckhardt, jle@rice.edu) if you'd like to help. - -Known testsuite failures: - - none. - -Copyright (C) 2012-2018 Free Software Foundation, Inc. - -Copying and distribution of this file, with or without modification, -are permitted in any medium without royalty provided the copyright -notice and this notice are preserved. diff --git a/gas/testsuite/gas/i860/bitwise.d b/gas/testsuite/gas/i860/bitwise.d deleted file mode 100644 index 59954a4..0000000 --- a/gas/testsuite/gas/i860/bitwise.d +++ /dev/null @@ -1,141 +0,0 @@ -#as: -#objdump: -dr -#name: i860 bitwise - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 22 c0 and %r0,%r1,%sp - 4: 00 18 85 c0 and %fp,%r4,%r5 - 8: 00 30 e8 c0 and %r6,%r7,%r8 - c: 00 48 4b c1 and %r9,%r10,%r11 - 10: 00 60 ae c1 and %r12,%r13,%r14 - 14: 00 78 11 c2 and %r15,%r16,%r17 - 18: 00 90 74 c2 and %r18,%r19,%r20 - 1c: 00 a8 d7 c2 and %r21,%r22,%r23 - 20: 00 c0 3a c3 and %r24,%r25,%r26 - 24: 00 d8 9d c3 and %r27,%r28,%r29 - 28: 00 f0 e0 c3 and %r30,%r31,%r0 - 2c: 00 00 22 d0 andnot %r0,%r1,%sp - 30: 00 18 85 d0 andnot %fp,%r4,%r5 - 34: 00 30 e8 d0 andnot %r6,%r7,%r8 - 38: 00 48 4b d1 andnot %r9,%r10,%r11 - 3c: 00 60 ae d1 andnot %r12,%r13,%r14 - 40: 00 78 11 d2 andnot %r15,%r16,%r17 - 44: 00 90 74 d2 andnot %r18,%r19,%r20 - 48: 00 a8 d7 d2 andnot %r21,%r22,%r23 - 4c: 00 c0 3a d3 andnot %r24,%r25,%r26 - 50: 00 d8 9d d3 andnot %r27,%r28,%r29 - 54: 00 f0 e0 d3 andnot %r30,%r31,%r0 - 58: 00 00 22 e0 or %r0,%r1,%sp - 5c: 00 18 85 e0 or %fp,%r4,%r5 - 60: 00 30 e8 e0 or %r6,%r7,%r8 - 64: 00 48 4b e1 or %r9,%r10,%r11 - 68: 00 60 ae e1 or %r12,%r13,%r14 - 6c: 00 78 11 e2 or %r15,%r16,%r17 - 70: 00 90 74 e2 or %r18,%r19,%r20 - 74: 00 a8 d7 e2 or %r21,%r22,%r23 - 78: 00 c0 3a e3 or %r24,%r25,%r26 - 7c: 00 d8 9d e3 or %r27,%r28,%r29 - 80: 00 f0 e0 e3 or %r30,%r31,%r0 - 84: 00 00 22 f0 xor %r0,%r1,%sp - 88: 00 18 85 f0 xor %fp,%r4,%r5 - 8c: 00 30 e8 f0 xor %r6,%r7,%r8 - 90: 00 48 4b f1 xor %r9,%r10,%r11 - 94: 00 60 ae f1 xor %r12,%r13,%r14 - 98: 00 78 11 f2 xor %r15,%r16,%r17 - 9c: 00 90 74 f2 xor %r18,%r19,%r20 - a0: 00 a8 d7 f2 xor %r21,%r22,%r23 - a4: 00 c0 3a f3 xor %r24,%r25,%r26 - a8: 00 d8 9d f3 xor %r27,%r28,%r29 - ac: 00 f0 e0 f3 xor %r30,%r31,%r0 - b0: 00 00 22 c4 and 0x0000,%r1,%sp - b4: 00 20 85 c4 and 0x2000,%r4,%r5 - b8: f5 13 e8 c4 and 0x13f5,%r7,%r8 - bc: 00 80 4b c5 and 0x8000,%r10,%r11 - c0: e8 fd ae c5 and 0xfde8,%r13,%r14 - c4: ff ff 11 c6 and 0xffff,%r16,%r17 - c8: ff ff 74 c6 and 0xffff,%r19,%r20 - cc: cd ab d7 c6 and 0xabcd,%r22,%r23 - d0: 34 12 3a c7 and 0x1234,%r25,%r26 - d4: 00 00 9d c7 and 0x0000,%r28,%r29 - d8: 03 00 e0 c7 and 0x0003,%r31,%r0 - dc: 01 00 22 cc andh 0x0001,%r1,%sp - e0: 01 20 85 cc andh 0x2001,%r4,%r5 - e4: f6 13 e8 cc andh 0x13f6,%r7,%r8 - e8: 01 80 4b cd andh 0x8001,%r10,%r11 - ec: e9 fd ae cd andh 0xfde9,%r13,%r14 - f0: ff ff 11 ce andh 0xffff,%r16,%r17 - f4: ff ff 74 ce andh 0xffff,%r19,%r20 - f8: cd ab d7 ce andh 0xabcd,%r22,%r23 - fc: 34 12 3a cf andh 0x1234,%r25,%r26 - 100: 00 00 9d cf andh 0x0000,%r28,%r29 - 104: 03 00 e0 cf andh 0x0003,%r31,%r0 - 108: 00 00 22 d4 andnot 0x0000,%r1,%sp - 10c: 00 20 85 d4 andnot 0x2000,%r4,%r5 - 110: f5 13 e8 d4 andnot 0x13f5,%r7,%r8 - 114: 00 80 4b d5 andnot 0x8000,%r10,%r11 - 118: e8 fd ae d5 andnot 0xfde8,%r13,%r14 - 11c: ff ff 11 d6 andnot 0xffff,%r16,%r17 - 120: ff ff 74 d6 andnot 0xffff,%r19,%r20 - 124: cd ab d7 d6 andnot 0xabcd,%r22,%r23 - 128: 34 12 3a d7 andnot 0x1234,%r25,%r26 - 12c: 00 00 9d d7 andnot 0x0000,%r28,%r29 - 130: 03 00 e0 d7 andnot 0x0003,%r31,%r0 - 134: 01 00 22 dc andnoth 0x0001,%r1,%sp - 138: 01 20 85 dc andnoth 0x2001,%r4,%r5 - 13c: f6 13 e8 dc andnoth 0x13f6,%r7,%r8 - 140: 01 80 4b dd andnoth 0x8001,%r10,%r11 - 144: e9 fd ae dd andnoth 0xfde9,%r13,%r14 - 148: ff ff 11 de andnoth 0xffff,%r16,%r17 - 14c: ff ff 74 de andnoth 0xffff,%r19,%r20 - 150: cd ab d7 de andnoth 0xabcd,%r22,%r23 - 154: 34 12 3a df andnoth 0x1234,%r25,%r26 - 158: 00 00 9d df andnoth 0x0000,%r28,%r29 - 15c: 03 00 e0 df andnoth 0x0003,%r31,%r0 - 160: 00 00 22 e4 or 0x0000,%r1,%sp - 164: 01 00 85 e4 or 0x0001,%r4,%r5 - 168: 02 00 e8 e4 or 0x0002,%r7,%r8 - 16c: 03 00 4b e5 or 0x0003,%r10,%r11 - 170: e8 fd ae e5 or 0xfde8,%r13,%r14 - 174: ff ff 11 e6 or 0xffff,%r16,%r17 - 178: ff ff 74 e6 or 0xffff,%r19,%r20 - 17c: cd ab d7 e6 or 0xabcd,%r22,%r23 - 180: 34 12 3a e7 or 0x1234,%r25,%r26 - 184: 00 00 9d e7 or 0x0000,%r28,%r29 - 188: 03 00 e0 e7 or 0x0003,%r31,%r0 - 18c: 00 00 22 ec orh 0x0000,%r1,%sp - 190: 01 00 85 ec orh 0x0001,%r4,%r5 - 194: 02 00 e8 ec orh 0x0002,%r7,%r8 - 198: 03 00 4b ed orh 0x0003,%r10,%r11 - 19c: e8 fd ae ed orh 0xfde8,%r13,%r14 - 1a0: ff ff 11 ee orh 0xffff,%r16,%r17 - 1a4: ff ff 74 ee orh 0xffff,%r19,%r20 - 1a8: cd ab d7 ee orh 0xabcd,%r22,%r23 - 1ac: 34 12 3a ef orh 0x1234,%r25,%r26 - 1b0: 00 00 9d ef orh 0x0000,%r28,%r29 - 1b4: 03 00 e0 ef orh 0x0003,%r31,%r0 - 1b8: 00 00 22 f4 xor 0x0000,%r1,%sp - 1bc: 01 00 85 f4 xor 0x0001,%r4,%r5 - 1c0: 02 00 e8 f4 xor 0x0002,%r7,%r8 - 1c4: 03 00 4b f5 xor 0x0003,%r10,%r11 - 1c8: e8 fd ae f5 xor 0xfde8,%r13,%r14 - 1cc: ff ff 11 f6 xor 0xffff,%r16,%r17 - 1d0: ff ff 74 f6 xor 0xffff,%r19,%r20 - 1d4: cd ab d7 f6 xor 0xabcd,%r22,%r23 - 1d8: 34 12 3a f7 xor 0x1234,%r25,%r26 - 1dc: 00 00 9d f7 xor 0x0000,%r28,%r29 - 1e0: 03 00 e0 f7 xor 0x0003,%r31,%r0 - 1e4: 00 00 22 fc xorh 0x0000,%r1,%sp - 1e8: 01 00 85 fc xorh 0x0001,%r4,%r5 - 1ec: 02 00 e8 fc xorh 0x0002,%r7,%r8 - 1f0: 03 00 4b fd xorh 0x0003,%r10,%r11 - 1f4: e8 fd ae fd xorh 0xfde8,%r13,%r14 - 1f8: ff ff 11 fe xorh 0xffff,%r16,%r17 - 1fc: ff ff 74 fe xorh 0xffff,%r19,%r20 - 200: cd ab d7 fe xorh 0xabcd,%r22,%r23 - 204: 34 12 3a ff xorh 0x1234,%r25,%r26 - 208: 00 00 9d ff xorh 0x0000,%r28,%r29 - 20c: 03 00 e0 ff xorh 0x0003,%r31,%r0 diff --git a/gas/testsuite/gas/i860/bitwise.s b/gas/testsuite/gas/i860/bitwise.s deleted file mode 100644 index 531c787..0000000 --- a/gas/testsuite/gas/i860/bitwise.s +++ /dev/null @@ -1,150 +0,0 @@ -# and, andh, andnot, andnoth, or, orh, xor, xorh - - .text - - # Register forms (high variants do not have register forms). - and %r0,%r1,%r2 - and %r3,%r4,%r5 - and %r6,%r7,%r8 - and %r9,%r10,%r11 - and %r12,%r13,%r14 - and %r15,%r16,%r17 - and %r18,%r19,%r20 - and %r21,%r22,%r23 - and %r24,%r25,%r26 - and %r27,%r28,%r29 - and %r30,%r31,%r0 - - andnot %r0,%r1,%r2 - andnot %r3,%r4,%r5 - andnot %r6,%r7,%r8 - andnot %r9,%r10,%r11 - andnot %r12,%r13,%r14 - andnot %r15,%r16,%r17 - andnot %r18,%r19,%r20 - andnot %r21,%r22,%r23 - andnot %r24,%r25,%r26 - andnot %r27,%r28,%r29 - andnot %r30,%r31,%r0 - - or %r0,%r1,%r2 - or %r3,%r4,%r5 - or %r6,%r7,%r8 - or %r9,%r10,%r11 - or %r12,%r13,%r14 - or %r15,%r16,%r17 - or %r18,%r19,%r20 - or %r21,%r22,%r23 - or %r24,%r25,%r26 - or %r27,%r28,%r29 - or %r30,%r31,%r0 - - xor %r0,%r1,%r2 - xor %r3,%r4,%r5 - xor %r6,%r7,%r8 - xor %r9,%r10,%r11 - xor %r12,%r13,%r14 - xor %r15,%r16,%r17 - xor %r18,%r19,%r20 - xor %r21,%r22,%r23 - xor %r24,%r25,%r26 - xor %r27,%r28,%r29 - xor %r30,%r31,%r0 - - # Immediate forms (all) - and 0,%r1,%r2 - and 8192,%r4,%r5 - and 5109,%r7,%r8 - and 32768,%r10,%r11 - and 65000,%r13,%r14 - and 65535,%r16,%r17 - and 0xffff,%r19,%r20 - and 0xabcd,%r22,%r23 - and 0x1234,%r25,%r26 - and 0x0,%r28,%r29 - and 0x3,%r31,%r0 - - andh 1,%r1,%r2 - andh 8193,%r4,%r5 - andh 5110,%r7,%r8 - andh 32769,%r10,%r11 - andh 65001,%r13,%r14 - andh 65535,%r16,%r17 - andh 0xffff,%r19,%r20 - andh 0xabcd,%r22,%r23 - andh 0x1234,%r25,%r26 - andh 0x0,%r28,%r29 - andh 0x3,%r31,%r0 - - andnot 0,%r1,%r2 - andnot 8192,%r4,%r5 - andnot 5109,%r7,%r8 - andnot 32768,%r10,%r11 - andnot 65000,%r13,%r14 - andnot 65535,%r16,%r17 - andnot 0xffff,%r19,%r20 - andnot 0xabcd,%r22,%r23 - andnot 0x1234,%r25,%r26 - andnot 0x0,%r28,%r29 - andnot 0x3,%r31,%r0 - - andnoth 1,%r1,%r2 - andnoth 8193,%r4,%r5 - andnoth 5110,%r7,%r8 - andnoth 32769,%r10,%r11 - andnoth 65001,%r13,%r14 - andnoth 65535,%r16,%r17 - andnoth 0xffff,%r19,%r20 - andnoth 0xabcd,%r22,%r23 - andnoth 0x1234,%r25,%r26 - andnoth 0x0,%r28,%r29 - andnoth 0x3,%r31,%r0 - - or 0,%r1,%r2 - or 1,%r4,%r5 - or 2,%r7,%r8 - or 3,%r10,%r11 - or 65000,%r13,%r14 - or 65535,%r16,%r17 - or 0xffff,%r19,%r20 - or 0xabcd,%r22,%r23 - or 0x1234,%r25,%r26 - or 0x0,%r28,%r29 - or 0x3,%r31,%r0 - - orh 0,%r1,%r2 - orh 1,%r4,%r5 - orh 2,%r7,%r8 - orh 3,%r10,%r11 - orh 65000,%r13,%r14 - orh 65535,%r16,%r17 - orh 0xffff,%r19,%r20 - orh 0xabcd,%r22,%r23 - orh 0x1234,%r25,%r26 - orh 0x0,%r28,%r29 - orh 0x3,%r31,%r0 - - xor 0,%r1,%r2 - xor 1,%r4,%r5 - xor 2,%r7,%r8 - xor 3,%r10,%r11 - xor 65000,%r13,%r14 - xor 65535,%r16,%r17 - xor 0xffff,%r19,%r20 - xor 0xabcd,%r22,%r23 - xor 0x1234,%r25,%r26 - xor 0x0,%r28,%r29 - xor 0x3,%r31,%r0 - - xorh 0,%r1,%r2 - xorh 1,%r4,%r5 - xorh 2,%r7,%r8 - xorh 3,%r10,%r11 - xorh 65000,%r13,%r14 - xorh 65535,%r16,%r17 - xorh 0xffff,%r19,%r20 - xorh 0xabcd,%r22,%r23 - xorh 0x1234,%r25,%r26 - xorh 0x0,%r28,%r29 - xorh 0x3,%r31,%r0 - diff --git a/gas/testsuite/gas/i860/branch.d b/gas/testsuite/gas/i860/branch.d deleted file mode 100644 index eba23d6..0000000 --- a/gas/testsuite/gas/i860/branch.d +++ /dev/null @@ -1,81 +0,0 @@ -#as: -#objdump: -dr -#name: i860 branch - -.*: +file format .* - -Disassembly of section .text: - -00000000 <.text>: - 0: 3d 00 20 b4 bla %r0,%r1,0x000000f8 // 0xf8 - 4: 00 00 00 a0 shl %r0,%r0,%r0 - 8: 3d 28 e0 b7 bla %r5,%r31,0x00000100 // 0x100 - c: 00 00 00 a0 shl %r0,%r0,%r0 - 10: 39 b8 00 b6 bla %r23,%r16,0x000000f8 // 0xf8 - 14: 00 00 00 a0 shl %r0,%r0,%r0 - 18: 39 20 60 b6 bla %r4,%r19,0x00000100 // 0x100 - 1c: 00 00 00 a0 shl %r0,%r0,%r0 - 20: 00 00 00 40 bri %r0 - 24: 00 00 00 a0 shl %r0,%r0,%r0 - 28: 00 08 00 40 bri %r1 - 2c: 00 00 00 a0 shl %r0,%r0,%r0 - 30: 00 f8 00 40 bri %r31 - 34: 00 00 00 a0 shl %r0,%r0,%r0 - 38: 00 08 00 40 bri %r1 - 3c: 00 00 00 a0 shl %r0,%r0,%r0 - 40: 00 60 00 40 bri %r12 - 44: 00 00 00 a0 shl %r0,%r0,%r0 - 48: 00 98 00 40 bri %r19 - 4c: 00 00 00 a0 shl %r0,%r0,%r0 - 50: 02 00 00 4c calli %r0 - 54: 00 00 00 a0 shl %r0,%r0,%r0 - 58: 02 08 00 4c calli %r1 - 5c: 00 00 00 a0 shl %r0,%r0,%r0 - 60: 02 f8 00 4c calli %r31 - 64: 00 00 00 a0 shl %r0,%r0,%r0 - 68: 02 28 00 4c calli %r5 - 6c: 00 00 00 a0 shl %r0,%r0,%r0 - 70: 02 b0 00 4c calli %r22 - 74: 00 00 00 a0 shl %r0,%r0,%r0 - 78: 02 48 00 4c calli %r9 - 7c: 00 00 00 a0 shl %r0,%r0,%r0 - 80: 1d 00 00 68 br 0x000000f8 // 0xf8 - 84: 00 00 00 a0 shl %r0,%r0,%r0 - 88: 1d 00 00 68 br 0x00000100 // 0x100 - 8c: 00 00 00 a0 shl %r0,%r0,%r0 - 90: 00 00 00 68 br 0x00000094 // 0x94 - 90: R_860_PC26 some_fake_extern - 94: 00 00 00 a0 shl %r0,%r0,%r0 - 98: 17 00 00 6c call 0x000000f8 // 0xf8 - 9c: 00 00 00 a0 shl %r0,%r0,%r0 - a0: 17 00 00 6c call 0x00000100 // 0x100 - a4: 00 00 00 a0 shl %r0,%r0,%r0 - a8: 00 00 00 6c call 0x000000ac // 0xac - a8: R_860_PC26 some_fake_extern - ac: 00 00 00 a0 shl %r0,%r0,%r0 - b0: 02 00 00 70 bc 0x000000bc // 0xbc - b4: 10 00 00 70 bc 0x000000f8 // 0xf8 - b8: 00 00 00 70 bc 0x000000bc // 0xbc - b8: R_860_PC26 some_fake_extern - bc: ff ff ff 77 bc.t 0x000000bc // 0xbc - c0: 00 00 00 a0 shl %r0,%r0,%r0 - c4: 0c 00 00 74 bc.t 0x000000f8 // 0xf8 - c8: 00 00 00 a0 shl %r0,%r0,%r0 - cc: 00 00 00 74 bc.t 0x000000d0 // 0xd0 - cc: R_860_PC26 some_fake_extern - d0: 00 00 00 a0 shl %r0,%r0,%r0 - d4: 02 00 00 78 bnc 0x000000e0 // 0xe0 - d8: 07 00 00 78 bnc 0x000000f8 // 0xf8 - dc: 00 00 00 78 bnc 0x000000e0 // 0xe0 - dc: R_860_PC26 some_fake_extern - e0: ff ff ff 7f bnc.t 0x000000e0 // 0xe0 - e4: 00 00 00 a0 shl %r0,%r0,%r0 - e8: 03 00 00 7c bnc.t 0x000000f8 // 0xf8 - ec: 00 00 00 a0 shl %r0,%r0,%r0 - f0: 00 00 00 7c bnc.t 0x000000f4 // 0xf4 - f0: R_860_PC26 some_fake_extern - f4: 00 00 00 a0 shl %r0,%r0,%r0 - f8: 00 00 00 a0 shl %r0,%r0,%r0 - fc: 00 00 00 a0 shl %r0,%r0,%r0 - 100: 00 00 00 a0 shl %r0,%r0,%r0 - 104: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/branch.s b/gas/testsuite/gas/i860/branch.s deleted file mode 100644 index 3df2758..0000000 --- a/gas/testsuite/gas/i860/branch.s +++ /dev/null @@ -1,85 +0,0 @@ -# Branches and calls - - .text - - bla %r0,%r1,.Lsome_label1 - nop - bla %r5,%r31,.Lsome_label2 - nop - bla %r23,%r16,.Lsome_label1 - nop - bla %r4,%r19,.Lsome_label2 - nop - - bri %r0 - nop - bri %r1 - nop - bri %r31 - nop - bri %r1 - nop - bri %r12 - nop - bri %r19 - nop - - calli %r0 - nop - calli %r1 - nop - calli %r31 - nop - calli %r5 - nop - calli %r22 - nop - calli %r9 - nop - - br .Lsome_label1 - nop - br .Lsome_label2 - nop - br some_fake_extern - nop - - call .Lcall_me_now - nop - call .Lcall_me_anytime - nop - call some_fake_extern - nop - - bc .+12 - bc .Lsome_label1 - bc some_fake_extern - - bc.t .+0 - nop - bc.t .Lsome_label1 - nop - bc.t some_fake_extern - nop - - bnc .+12 - bnc .Lsome_label1 - bnc some_fake_extern - - bnc.t .+0 - nop - bnc.t .Lsome_label1 - nop - bnc.t some_fake_extern - nop - - -.Lsome_label1: -.Lcall_me_now: - nop - nop -.Lsome_label2: -.Lcall_me_anytime: - nop - nop - diff --git a/gas/testsuite/gas/i860/bte.d b/gas/testsuite/gas/i860/bte.d deleted file mode 100644 index a8f4404..0000000 --- a/gas/testsuite/gas/i860/bte.d +++ /dev/null @@ -1,62 +0,0 @@ -#as: -#objdump: -dr -#name: i860 bte/btne - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <some_label-0xb8>: - 0: 2d 00 e0 57 btne 0,%r31,0x000000b8 // b8 <some_label> - 4: 2c 08 a0 57 btne 1,%r29,0x000000b8 // b8 <some_label> - 8: 2b 10 60 57 btne 2,%r27,0x000000b8 // b8 <some_label> - c: 2a 18 20 57 btne 3,%r25,0x000000b8 // b8 <some_label> - 10: 29 50 e0 56 btne 10,%r23,0x000000b8 // b8 <some_label> - 14: 28 58 a0 56 btne 11,%r21,0x000000b8 // b8 <some_label> - 18: 27 60 60 56 btne 12,%r19,0x000000b8 // b8 <some_label> - 1c: 26 e8 20 56 btne 29,%r17,0x000000b8 // b8 <some_label> - 20: 25 f0 00 56 btne 30,%r16,0x000000b8 // b8 <some_label> - 24: 24 f8 00 55 btne 31,%r8,0x000000b8 // b8 <some_label> - 28: 00 78 00 54 btne 15,%r0,0x0000002c // 2c <some_label-0x8c> - 28: R_860_PC16 some_fake_extern - 2c: 22 00 e0 5f bte 0,%r31,0x000000b8 // b8 <some_label> - 30: 21 08 a0 5f bte 1,%r29,0x000000b8 // b8 <some_label> - 34: 20 10 60 5f bte 2,%r27,0x000000b8 // b8 <some_label> - 38: 1f 18 20 5f bte 3,%r25,0x000000b8 // b8 <some_label> - 3c: 1e 50 e0 5e bte 10,%r23,0x000000b8 // b8 <some_label> - 40: 1d 58 a0 5e bte 11,%r21,0x000000b8 // b8 <some_label> - 44: 1c 60 60 5e bte 12,%r19,0x000000b8 // b8 <some_label> - 48: 1b e8 20 5e bte 29,%r17,0x000000b8 // b8 <some_label> - 4c: 1a f0 00 5e bte 30,%r16,0x000000b8 // b8 <some_label> - 50: 19 f8 00 5d bte 31,%r8,0x000000b8 // b8 <some_label> - 54: 00 78 00 5c bte 15,%r0,0x00000058 // 58 <some_label-0x60> - 54: R_860_PC16 some_fake_extern - 58: 17 00 e0 53 btne %r0,%r31,0x000000b8 // b8 <some_label> - 5c: 16 08 a0 53 btne %r1,%r29,0x000000b8 // b8 <some_label> - 60: 15 10 60 53 btne %sp,%r27,0x000000b8 // b8 <some_label> - 64: 14 18 20 53 btne %fp,%r25,0x000000b8 // b8 <some_label> - 68: 13 50 e0 52 btne %r10,%r23,0x000000b8 // b8 <some_label> - 6c: 12 58 a0 52 btne %r11,%r21,0x000000b8 // b8 <some_label> - 70: 11 60 60 52 btne %r12,%r19,0x000000b8 // b8 <some_label> - 74: 10 e8 20 52 btne %r29,%r17,0x000000b8 // b8 <some_label> - 78: 0f f0 00 52 btne %r30,%r16,0x000000b8 // b8 <some_label> - 7c: 0e f8 00 51 btne %r31,%r8,0x000000b8 // b8 <some_label> - 80: 00 78 00 50 btne %r15,%r0,0x00000084 // 84 <some_label-0x34> - 80: R_860_PC16 some_fake_extern - 84: 0c 00 e0 5b bte %r0,%r31,0x000000b8 // b8 <some_label> - 88: 0b 08 a0 5b bte %r1,%r29,0x000000b8 // b8 <some_label> - 8c: 0a 10 60 5b bte %sp,%r27,0x000000b8 // b8 <some_label> - 90: 09 18 20 5b bte %fp,%r25,0x000000b8 // b8 <some_label> - 94: 08 50 e0 5a bte %r10,%r23,0x000000b8 // b8 <some_label> - 98: 07 58 a0 5a bte %r11,%r21,0x000000b8 // b8 <some_label> - 9c: 06 60 60 5a bte %r12,%r19,0x000000b8 // b8 <some_label> - a0: 05 e8 20 5a bte %r29,%r17,0x000000b8 // b8 <some_label> - a4: 04 f0 00 5a bte %r30,%r16,0x000000b8 // b8 <some_label> - a8: 03 f8 00 59 bte %r31,%r8,0x000000b8 // b8 <some_label> - ac: 00 78 00 58 bte %r15,%r0,0x000000b0 // b0 <some_label-0x8> - ac: R_860_PC16 some_fake_extern - b0: 00 00 00 a0 shl %r0,%r0,%r0 - b4: 00 00 00 a0 shl %r0,%r0,%r0 - -000000b8 <some_label>: - b8: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/bte.s b/gas/testsuite/gas/i860/bte.s deleted file mode 100644 index cc6e576..0000000 --- a/gas/testsuite/gas/i860/bte.s +++ /dev/null @@ -1,55 +0,0 @@ -# bte, btne - .text - - btne 0,%r31,some_label - btne 1,%r29,some_label - btne 2,%r27,some_label - btne 3,%r25,some_label - btne 10,%r23,some_label - btne 11,%r21,some_label - btne 12,%r19,some_label - btne 29,%r17,some_label - btne 30,%r16,some_label - btne 31,%r8,some_label - btne 15,%r0,some_fake_extern - - bte 0,%r31,some_label - bte 1,%r29,some_label - bte 2,%r27,some_label - bte 3,%r25,some_label - bte 10,%r23,some_label - bte 11,%r21,some_label - bte 12,%r19,some_label - bte 29,%r17,some_label - bte 30,%r16,some_label - bte 31,%r8,some_label - bte 15,%r0,some_fake_extern - - btne %r0,%r31,some_label - btne %r1,%r29,some_label - btne %r2,%r27,some_label - btne %r3,%r25,some_label - btne %r10,%r23,some_label - btne %r11,%r21,some_label - btne %r12,%r19,some_label - btne %r29,%r17,some_label - btne %r30,%r16,some_label - btne %r31,%r8,some_label - btne %r15,%r0,some_fake_extern - - bte %r0,%r31,some_label - bte %r1,%r29,some_label - bte %r2,%r27,some_label - bte %r3,%r25,some_label - bte %r10,%r23,some_label - bte %r11,%r21,some_label - bte %r12,%r19,some_label - bte %r29,%r17,some_label - bte %r30,%r16,some_label - bte %r31,%r8,some_label - bte %r15,%r0,some_fake_extern - - nop - nop -some_label: - nop diff --git a/gas/testsuite/gas/i860/dir-align01.d b/gas/testsuite/gas/i860/dir-align01.d deleted file mode 100644 index bc4f677..0000000 --- a/gas/testsuite/gas/i860/dir-align01.d +++ /dev/null @@ -1,17 +0,0 @@ -#as: -#objdump: -d -#name: i860 dir-align01 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 20 a6 90 adds %r4,%r5,%r6 - 4: 00 00 00 a0 shl %r0,%r0,%r0 - 8: 00 00 00 a0 shl %r0,%r0,%r0 - c: 00 00 00 a0 shl %r0,%r0,%r0 - 10: 00 50 6c 91 adds %r10,%r11,%r12 - 14: a1 b1 1a 4b fmlow.dd %f22,%f24,%f26 - 18: 30 74 f0 49 pfadd.ss %f14,%f15,%f16 - 1c: b0 8c 54 4a pfadd.sd %f17,%f18,%f20 diff --git a/gas/testsuite/gas/i860/dir-align01.s b/gas/testsuite/gas/i860/dir-align01.s deleted file mode 100644 index 595eb3f..0000000 --- a/gas/testsuite/gas/i860/dir-align01.s +++ /dev/null @@ -1,11 +0,0 @@ -# Test that .text section alignments use nops (0xA0000000) to fill -# rather than 0. - .text - adds %r4,%r5,%r6 - .align 16 - adds %r10,%r11,%r12 - fmlow.dd %f22,%f24,%f26 - pfadd.ss %f14,%f15,%f16 - pfadd.sd %f17,%f18,%f20 - - diff --git a/gas/testsuite/gas/i860/dir-intel01.d b/gas/testsuite/gas/i860/dir-intel01.d deleted file mode 100644 index 0951bf3..0000000 --- a/gas/testsuite/gas/i860/dir-intel01.d +++ /dev/null @@ -1,19 +0,0 @@ -#as: -mintel-syntax -#objdump: -d -#name: i860 dir-intel01 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 00 a0 shl %r0,%r0,%r0 - 4: 00 00 00 a0 shl %r0,%r0,%r0 - 8: 30 02 22 48 d.fadd.ss %f0,%f1,%f2 - c: 00 00 00 a0 shl %r0,%r0,%r0 - 10: b0 12 64 48 d.fadd.sd %f2,%f3,%f4 - 14: 00 00 00 a0 shl %r0,%r0,%r0 - 18: b0 33 0a 49 d.fadd.dd %f6,%f8,%f10 - 1c: 00 00 00 a0 shl %r0,%r0,%r0 - 20: 00 00 00 a0 shl %r0,%r0,%r0 - 24: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/dir-intel01.s b/gas/testsuite/gas/i860/dir-intel01.s deleted file mode 100644 index 21aa685..0000000 --- a/gas/testsuite/gas/i860/dir-intel01.s +++ /dev/null @@ -1,19 +0,0 @@ -// Intel assembler directives: -// Test that the .dual and .enddual directives are recognized and -// function (i.e., that the dual bits are set properly). - - .text - - nop - nop - .dual - fadd.ss f0,f1,f2 - nop - fadd.sd f2,f3,f4 - nop - fadd.dd f6,f8,f10 - nop - .enddual - nop - nop - diff --git a/gas/testsuite/gas/i860/dir-intel02.d b/gas/testsuite/gas/i860/dir-intel02.d deleted file mode 100644 index f053967..0000000 --- a/gas/testsuite/gas/i860/dir-intel02.d +++ /dev/null @@ -1,15 +0,0 @@ -#as: -mintel-syntax -#objdump: -d -#name: i860 dir-intel02 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 34 12 1f ec orh 0x1234,%r0,%r31 - 4: 78 56 f8 e7 or 0x5678,%r31,%r24 - 8: 00 c0 28 91 adds %r24,%r9,%r8 - c: f0 f0 05 ec orh 0xf0f0,%r0,%r5 - 10: 5a 5a b8 e4 or 0x5a5a,%r5,%r24 - 14: 00 c0 28 91 adds %r24,%r9,%r8 diff --git a/gas/testsuite/gas/i860/dir-intel02.s b/gas/testsuite/gas/i860/dir-intel02.s deleted file mode 100644 index a1a1613..0000000 --- a/gas/testsuite/gas/i860/dir-intel02.s +++ /dev/null @@ -1,13 +0,0 @@ -// Intel assembler directives: -// Test that the .atmp directive is recognized and functions. - - .text - - .atmp r31 - or 0x12345678,r0,r24 - adds r24,r9,r8 - - .atmp r5 - or 0xf0f05a5a,r0,r24 - adds r24,r9,r8 - diff --git a/gas/testsuite/gas/i860/dir-intel03-err.l b/gas/testsuite/gas/i860/dir-intel03-err.l deleted file mode 100644 index b826128..0000000 --- a/gas/testsuite/gas/i860/dir-intel03-err.l +++ /dev/null @@ -1,5 +0,0 @@ -.*: Assembler messages: -.*:8: Error: Directive .atmp available only with -mintel-syntax option -.*:8: Error: junk at end of line, first unrecognized character is `r' -.*:10: Error: Directive .dual available only with -mintel-syntax option -.*:13: Error: Directive .enddual available only with -mintel-syntax option diff --git a/gas/testsuite/gas/i860/dir-intel03-err.s b/gas/testsuite/gas/i860/dir-intel03-err.s deleted file mode 100644 index b8b0790..0000000 --- a/gas/testsuite/gas/i860/dir-intel03-err.s +++ /dev/null @@ -1,14 +0,0 @@ -# Intel assembler directives: -# The .dual, .enddual, and .atmp directives are valid only -# in Intel syntax mode. Check that we issue an error if in -# AT&T/SVR4 mode. - - .text - - .atmp r31 - - .dual - fsub.ss %f22,%f21,%f13 - nop - .enddual - diff --git a/gas/testsuite/gas/i860/dual01.d b/gas/testsuite/gas/i860/dual01.d deleted file mode 100644 index ee182e0..0000000 --- a/gas/testsuite/gas/i860/dual01.d +++ /dev/null @@ -1,21 +0,0 @@ -#as: -#objdump: -d -#name: i860 dual01 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 00 a0 shl %r0,%r0,%r0 - 4: 00 00 00 a0 shl %r0,%r0,%r0 - 8: b0 47 4c 49 d.pfadd.dd %f8,%f10,%f12 - c: 00 28 c6 90 adds %r5,%r6,%r6 - 10: b0 47 4c 49 d.pfadd.dd %f8,%f10,%f12 - 14: 10 00 58 25 fld.d 16\(%r10\),%f24 - 18: 00 02 00 b0 d.shrd %r0,%r0,%r0 - 1c: 08 00 48 25 fld.d 8\(%r10\),%f8 - 20: 00 02 00 b0 d.shrd %r0,%r0,%r0 - 24: 00 00 50 25 fld.d 0\(%r10\),%f16 - 28: 00 00 00 a0 shl %r0,%r0,%r0 - 2c: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/dual01.s b/gas/testsuite/gas/i860/dual01.s deleted file mode 100644 index e7aa271..0000000 --- a/gas/testsuite/gas/i860/dual01.s +++ /dev/null @@ -1,17 +0,0 @@ -# Test fnop's dual bit (all other floating point operations have their dual -# bit tested in their individual test files). - - .text - .align 8 - nop - nop - d.pfadd.dd %f8,%f10,%f12 - adds %r5,%r6,%r6 - d.pfadd.dd %f8,%f10,%f12 - fld.d 16(%r10),%f24 - d.fnop - fld.d 8(%r10),%f8 - d.fnop - fld.d 0(%r10),%f16 - nop - nop diff --git a/gas/testsuite/gas/i860/dual02-err.l b/gas/testsuite/gas/i860/dual02-err.l deleted file mode 100644 index d43d73e..0000000 --- a/gas/testsuite/gas/i860/dual02-err.l +++ /dev/null @@ -1,2 +0,0 @@ -.*: Assembler messages: -.*:7: Error: 'd\.fadd\.ss' must be 8-byte aligned diff --git a/gas/testsuite/gas/i860/dual02-err.s b/gas/testsuite/gas/i860/dual02-err.s deleted file mode 100644 index 05d1835..0000000 --- a/gas/testsuite/gas/i860/dual02-err.s +++ /dev/null @@ -1,9 +0,0 @@ -# Dual-mode pairs must be aligned on an 8-byte boundary. This tests -# that an error is reported if not properly aligned. - - .text - .align 8 - nop - d.fadd.ss %f3,%f5,%f7 - addu %r4,%r5,%r6 - diff --git a/gas/testsuite/gas/i860/dual03.d b/gas/testsuite/gas/i860/dual03.d deleted file mode 100644 index 30c0130f..0000000 --- a/gas/testsuite/gas/i860/dual03.d +++ /dev/null @@ -1,53 +0,0 @@ -#as: -mintel-syntax -#objdump: -d -#name: i860 dual03 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <L1-0x20>: - 0: 00 00 14 22 fld.d %r0\(%r16\),%f20 - 4: fe ff 15 94 adds -2,%r0,%r21 - 8: 30 06 00 48 d.pfadd.ss %f0,%f0,%f0 - c: fa ff 31 96 adds -6,%r17,%r17 - 10: 30 06 00 48 d.pfadd.ss %f0,%f0,%f0 - 14: 02 a8 20 b6 bla %r21,%r17,0x00000020 // 20 <L1> - 18: 30 06 00 48 d.pfadd.ss %f0,%f0,%f0 - 1c: 09 00 16 26 fld.d 8\(%r16\)\+\+,%f22 - -00000020 <L1>: - 20: 30 a6 de 4b d.pfadd.ss %f20,%f30,%f30 - 24: 06 a8 20 b6 bla %r21,%r17,0x00000040 // 40 <L2> - 28: 30 ae ff 4b d.pfadd.ss %f21,%f31,%f31 - 2c: 09 00 14 26 fld.d 8\(%r16\)\+\+,%f20 - 30: 30 a6 de 4b d.pfadd.ss %f20,%f30,%f30 - 34: 0a 00 00 68 br 0x00000060 // 60 <S> - 38: 30 ae ff 4b d.pfadd.ss %f21,%f31,%f31 - 3c: 00 00 00 a0 shl %r0,%r0,%r0 - -00000040 <L2>: - 40: 30 b6 de 4b d.pfadd.ss %f22,%f30,%f30 - 44: f6 af 3f b6 bla %r21,%r17,0x00000020 // 20 <L1> - 48: 30 be ff 4b d.pfadd.ss %f23,%f31,%f31 - 4c: 09 00 16 26 fld.d 8\(%r16\)\+\+,%f22 - 50: 30 a6 de 4b d.pfadd.ss %f20,%f30,%f30 - 54: 00 00 00 a0 shl %r0,%r0,%r0 - 58: 30 ae ff 4b d.pfadd.ss %f21,%f31,%f31 - 5c: 00 00 00 a0 shl %r0,%r0,%r0 - -00000060 <S>: - 60: 30 b4 de 4b pfadd.ss %f22,%f30,%f30 - 64: fc ff 15 94 adds -4,%r0,%r21 - 68: 30 bc ff 4b pfadd.ss %f23,%f31,%f31 - 6c: 02 a8 20 5a bte %r21,%r17,0x00000078 // 78 <DONE> - 70: 0b 00 14 26 fld.l 8\(%r16\)\+\+,%f20 - 74: 30 a4 de 4b pfadd.ss %f20,%f30,%f30 - -00000078 <DONE>: - 78: 30 04 1e 48 pfadd.ss %f0,%f0,%f30 - 7c: 30 f4 ff 4b pfadd.ss %f30,%f31,%f31 - 80: 30 04 1e 48 pfadd.ss %f0,%f0,%f30 - 84: 30 04 00 48 pfadd.ss %f0,%f0,%f0 - 88: 30 04 1f 48 pfadd.ss %f0,%f0,%f31 - 8c: 30 f0 f0 4b fadd.ss %f30,%f31,%f16 diff --git a/gas/testsuite/gas/i860/dual03.s b/gas/testsuite/gas/i860/dual03.s deleted file mode 100644 index 96c3134..0000000 --- a/gas/testsuite/gas/i860/dual03.s +++ /dev/null @@ -1,46 +0,0 @@ -// A larger dual-mode test, from the programmer's reference manual. -// This uses Intel syntax, as in the manual. - -// Single-precision vector sum - fld.d r0(r16),f20 - mov -2,r21 - d.pfadd.ss f0,f0,f0 - adds -6,r17,r17 - d.pfadd.ss f0,f0,f0 - bla r21,r17,L1 - d.pfadd.ss f0,f0,f0 - fld.d 8(r16)++,f22 -L1: - d.pfadd.ss f20,f30,f30 - bla r21,r17,L2 - d.pfadd.ss f21,f31,f31 - fld.d 8(r16)++,f20 - d.pfadd.ss f20,f30,f30 - br S - d.pfadd.ss f21,f31,f31 - nop -L2: - d.pfadd.ss f22,f30,f30 - bla r21,r17,L1 - d.pfadd.ss f23,f31,f31 - fld.d 8(r16)++,f22 - d.pfadd.ss f20,f30,f30 - nop - d.pfadd.ss f21,f31,f31 - nop -S: - pfadd.ss f22,f30,f30 - mov -4,r21 - pfadd.ss f23,f31,f31 - bte r21,r17,DONE - fld.l 8(r16)++,f20 - pfadd.ss f20,f30,f30 -DONE: - pfadd.ss f0,f0,f30 - pfadd.ss f30,f31,f31 - pfadd.ss f0,f0,f30 - pfadd.ss f0,f0,f0 - pfadd.ss f0,f0,f31 - fadd.ss f30,f31,f16 - - diff --git a/gas/testsuite/gas/i860/fldst01.d b/gas/testsuite/gas/i860/fldst01.d deleted file mode 100644 index b404d3d..0000000 --- a/gas/testsuite/gas/i860/fldst01.d +++ /dev/null @@ -1,73 +0,0 @@ -#as: -#objdump: -dr -#name: i860 fldst01 (fld.l) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 02 00 00 24 fld.l 0\(%r0\),%f0 - 4: 7e 00 3f 24 fld.l 124\(%r1\),%f31 - 8: 02 01 5e 24 fld.l 256\(%sp\),%f30 - c: 02 02 7d 24 fld.l 512\(%fp\),%f29 - 10: 02 04 9c 24 fld.l 1024\(%r4\),%f28 - 14: 02 10 bb 24 fld.l 4096\(%r5\),%f27 - 18: 02 20 da 24 fld.l 8192\(%r6\),%f26 - 1c: 02 40 f9 24 fld.l 16384\(%r7\),%f25 - 20: fe 7f f9 24 fld.l 32764\(%r7\),%f25 - 24: 02 80 f7 24 fld.l -32768\(%r7\),%f23 - 28: 02 c0 02 25 fld.l -16384\(%r8\),%f2 - 2c: 02 e0 23 25 fld.l -8192\(%r9\),%f3 - 30: 02 f0 48 25 fld.l -4096\(%r10\),%f8 - 34: 02 fc 69 25 fld.l -1024\(%r11\),%f9 - 38: 06 fe 8c 25 fld.l -508\(%r12\),%f12 - 3c: 0a ff b3 25 fld.l -248\(%r13\),%f19 - 40: fe ff d5 25 fld.l -4\(%r14\),%f21 - 44: 03 00 00 24 fld.l 0\(%r0\)\+\+,%f0 - 48: 7f 00 21 24 fld.l 124\(%r1\)\+\+,%f1 - 4c: 03 01 42 24 fld.l 256\(%sp\)\+\+,%f2 - 50: 03 02 63 24 fld.l 512\(%fp\)\+\+,%f3 - 54: 03 04 84 24 fld.l 1024\(%r4\)\+\+,%f4 - 58: 03 10 a5 24 fld.l 4096\(%r5\)\+\+,%f5 - 5c: 03 20 c6 24 fld.l 8192\(%r6\)\+\+,%f6 - 60: 03 40 e7 24 fld.l 16384\(%r7\)\+\+,%f7 - 64: ff 7f e8 24 fld.l 32764\(%r7\)\+\+,%f8 - 68: 03 80 e9 24 fld.l -32768\(%r7\)\+\+,%f9 - 6c: 03 c0 0a 25 fld.l -16384\(%r8\)\+\+,%f10 - 70: 03 e0 2b 25 fld.l -8192\(%r9\)\+\+,%f11 - 74: 03 f0 4c 25 fld.l -4096\(%r10\)\+\+,%f12 - 78: 03 fc 6d 25 fld.l -1024\(%r11\)\+\+,%f13 - 7c: 07 fe 8e 25 fld.l -508\(%r12\)\+\+,%f14 - 80: 0b ff af 25 fld.l -248\(%r13\)\+\+,%f15 - 84: ff ff d0 25 fld.l -4\(%r14\)\+\+,%f16 - 88: 02 28 00 20 fld.l %r5\(%r0\),%f0 - 8c: 02 30 3f 20 fld.l %r6\(%r1\),%f31 - 90: 02 38 5e 20 fld.l %r7\(%sp\),%f30 - 94: 02 40 7d 20 fld.l %r8\(%fp\),%f29 - 98: 02 48 9c 20 fld.l %r9\(%r4\),%f28 - 9c: 02 00 bb 20 fld.l %r0\(%r5\),%f27 - a0: 02 08 da 20 fld.l %r1\(%r6\),%f26 - a4: 02 60 f9 20 fld.l %r12\(%r7\),%f25 - a8: 02 68 18 21 fld.l %r13\(%r8\),%f24 - ac: 02 70 37 21 fld.l %r14\(%r9\),%f23 - b0: 02 78 56 21 fld.l %r15\(%r10\),%f22 - b4: 02 80 75 21 fld.l %r16\(%r11\),%f21 - b8: 02 88 94 21 fld.l %r17\(%r12\),%f20 - bc: 02 e0 b3 21 fld.l %r28\(%r13\),%f19 - c0: 02 f8 d2 21 fld.l %r31\(%r14\),%f18 - c4: 03 28 00 20 fld.l %r5\(%r0\)\+\+,%f0 - c8: 03 30 21 20 fld.l %r6\(%r1\)\+\+,%f1 - cc: 03 38 42 20 fld.l %r7\(%sp\)\+\+,%f2 - d0: 03 40 63 20 fld.l %r8\(%fp\)\+\+,%f3 - d4: 03 48 84 20 fld.l %r9\(%r4\)\+\+,%f4 - d8: 03 00 a5 20 fld.l %r0\(%r5\)\+\+,%f5 - dc: 03 08 c6 20 fld.l %r1\(%r6\)\+\+,%f6 - e0: 03 60 e7 20 fld.l %r12\(%r7\)\+\+,%f7 - e4: 03 68 08 21 fld.l %r13\(%r8\)\+\+,%f8 - e8: 03 70 29 21 fld.l %r14\(%r9\)\+\+,%f9 - ec: 03 78 4a 21 fld.l %r15\(%r10\)\+\+,%f10 - f0: 03 80 6b 21 fld.l %r16\(%r11\)\+\+,%f11 - f4: 03 88 8c 21 fld.l %r17\(%r12\)\+\+,%f12 - f8: 03 e0 ad 21 fld.l %r28\(%r13\)\+\+,%f13 - fc: 03 f8 ce 21 fld.l %r31\(%r14\)\+\+,%f14 diff --git a/gas/testsuite/gas/i860/fldst01.s b/gas/testsuite/gas/i860/fldst01.s deleted file mode 100644 index 109cba8..0000000 --- a/gas/testsuite/gas/i860/fldst01.s +++ /dev/null @@ -1,75 +0,0 @@ -# fld.l (no relocations here) - .text - - # Immediate form, no auto-increment. - fld.l 0(%r0),%f0 - fld.l 124(%r1),%f31 - fld.l 256(%r2),%f30 - fld.l 512(%r3),%f29 - fld.l 1024(%r4),%f28 - fld.l 4096(%r5),%f27 - fld.l 8192(%r6),%f26 - fld.l 16384(%r7),%f25 - fld.l 32764(%r7),%f25 - fld.l -32768(%r7),%f23 - fld.l -16384(%r8),%f2 - fld.l -8192(%r9),%f3 - fld.l -4096(%r10),%f8 - fld.l -1024(%r11),%f9 - fld.l -508(%r12),%f12 - fld.l -248(%r13),%f19 - fld.l -4(%r14),%f21 - - # Immediate form, with auto-increment. - fld.l 0(%r0)++,%f0 - fld.l 124(%r1)++,%f1 - fld.l 256(%r2)++,%f2 - fld.l 512(%r3)++,%f3 - fld.l 1024(%r4)++,%f4 - fld.l 4096(%r5)++,%f5 - fld.l 8192(%r6)++,%f6 - fld.l 16384(%r7)++,%f7 - fld.l 32764(%r7)++,%f8 - fld.l -32768(%r7)++,%f9 - fld.l -16384(%r8)++,%f10 - fld.l -8192(%r9)++,%f11 - fld.l -4096(%r10)++,%f12 - fld.l -1024(%r11)++,%f13 - fld.l -508(%r12)++,%f14 - fld.l -248(%r13)++,%f15 - fld.l -4(%r14)++,%f16 - - # Index form, no auto-increment. - fld.l %r5(%r0),%f0 - fld.l %r6(%r1),%f31 - fld.l %r7(%r2),%f30 - fld.l %r8(%r3),%f29 - fld.l %r9(%r4),%f28 - fld.l %r0(%r5),%f27 - fld.l %r1(%r6),%f26 - fld.l %r12(%r7),%f25 - fld.l %r13(%r8),%f24 - fld.l %r14(%r9),%f23 - fld.l %r15(%r10),%f22 - fld.l %r16(%r11),%f21 - fld.l %r17(%r12),%f20 - fld.l %r28(%r13),%f19 - fld.l %r31(%r14),%f18 - - # Index form, with auto-increment. - fld.l %r5(%r0)++,%f0 - fld.l %r6(%r1)++,%f1 - fld.l %r7(%r2)++,%f2 - fld.l %r8(%r3)++,%f3 - fld.l %r9(%r4)++,%f4 - fld.l %r0(%r5)++,%f5 - fld.l %r1(%r6)++,%f6 - fld.l %r12(%r7)++,%f7 - fld.l %r13(%r8)++,%f8 - fld.l %r14(%r9)++,%f9 - fld.l %r15(%r10)++,%f10 - fld.l %r16(%r11)++,%f11 - fld.l %r17(%r12)++,%f12 - fld.l %r28(%r13)++,%f13 - fld.l %r31(%r14)++,%f14 - diff --git a/gas/testsuite/gas/i860/fldst02.d b/gas/testsuite/gas/i860/fldst02.d deleted file mode 100644 index 7a0db94..0000000 --- a/gas/testsuite/gas/i860/fldst02.d +++ /dev/null @@ -1,73 +0,0 @@ -#as: -#objdump: -dr -#name: i860 fldst02 (fld.d) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 00 24 fld.d 0\(%r0\),%f0 - 4: 80 00 3e 24 fld.d 128\(%r1\),%f30 - 8: 00 01 5c 24 fld.d 256\(%sp\),%f28 - c: 00 02 7a 24 fld.d 512\(%fp\),%f26 - 10: 00 04 98 24 fld.d 1024\(%r4\),%f24 - 14: 00 10 b6 24 fld.d 4096\(%r5\),%f22 - 18: 00 20 d4 24 fld.d 8192\(%r6\),%f20 - 1c: 00 40 f2 24 fld.d 16384\(%r7\),%f18 - 20: f8 7f f0 24 fld.d 32760\(%r7\),%f16 - 24: 00 80 ee 24 fld.d -32768\(%r7\),%f14 - 28: 00 c0 0c 25 fld.d -16384\(%r8\),%f12 - 2c: 00 e0 2a 25 fld.d -8192\(%r9\),%f10 - 30: 00 f0 48 25 fld.d -4096\(%r10\),%f8 - 34: 00 fc 66 25 fld.d -1024\(%r11\),%f6 - 38: 00 fe 84 25 fld.d -512\(%r12\),%f4 - 3c: 08 ff a2 25 fld.d -248\(%r13\),%f2 - 40: f8 ff c0 25 fld.d -8\(%r14\),%f0 - 44: 01 00 00 24 fld.d 0\(%r0\)\+\+,%f0 - 48: 81 00 22 24 fld.d 128\(%r1\)\+\+,%f2 - 4c: 01 01 44 24 fld.d 256\(%sp\)\+\+,%f4 - 50: 01 02 66 24 fld.d 512\(%fp\)\+\+,%f6 - 54: 01 04 88 24 fld.d 1024\(%r4\)\+\+,%f8 - 58: 01 10 aa 24 fld.d 4096\(%r5\)\+\+,%f10 - 5c: 01 20 cc 24 fld.d 8192\(%r6\)\+\+,%f12 - 60: 01 40 ee 24 fld.d 16384\(%r7\)\+\+,%f14 - 64: f9 7f f0 24 fld.d 32760\(%r7\)\+\+,%f16 - 68: 01 80 f2 24 fld.d -32768\(%r7\)\+\+,%f18 - 6c: 01 c0 14 25 fld.d -16384\(%r8\)\+\+,%f20 - 70: 01 e0 36 25 fld.d -8192\(%r9\)\+\+,%f22 - 74: 01 f0 58 25 fld.d -4096\(%r10\)\+\+,%f24 - 78: 01 fc 7a 25 fld.d -1024\(%r11\)\+\+,%f26 - 7c: 01 fe 9c 25 fld.d -512\(%r12\)\+\+,%f28 - 80: 09 ff be 25 fld.d -248\(%r13\)\+\+,%f30 - 84: f9 ff d0 25 fld.d -8\(%r14\)\+\+,%f16 - 88: 00 28 00 20 fld.d %r5\(%r0\),%f0 - 8c: 00 30 3e 20 fld.d %r6\(%r1\),%f30 - 90: 00 38 5c 20 fld.d %r7\(%sp\),%f28 - 94: 00 40 7a 20 fld.d %r8\(%fp\),%f26 - 98: 00 48 98 20 fld.d %r9\(%r4\),%f24 - 9c: 00 00 b6 20 fld.d %r0\(%r5\),%f22 - a0: 00 08 d4 20 fld.d %r1\(%r6\),%f20 - a4: 00 60 f2 20 fld.d %r12\(%r7\),%f18 - a8: 00 68 10 21 fld.d %r13\(%r8\),%f16 - ac: 00 70 2e 21 fld.d %r14\(%r9\),%f14 - b0: 00 78 4c 21 fld.d %r15\(%r10\),%f12 - b4: 00 80 6a 21 fld.d %r16\(%r11\),%f10 - b8: 00 88 88 21 fld.d %r17\(%r12\),%f8 - bc: 00 e0 a6 21 fld.d %r28\(%r13\),%f6 - c0: 00 f8 c4 21 fld.d %r31\(%r14\),%f4 - c4: 01 28 00 20 fld.d %r5\(%r0\)\+\+,%f0 - c8: 01 30 22 20 fld.d %r6\(%r1\)\+\+,%f2 - cc: 01 38 44 20 fld.d %r7\(%sp\)\+\+,%f4 - d0: 01 40 66 20 fld.d %r8\(%fp\)\+\+,%f6 - d4: 01 48 88 20 fld.d %r9\(%r4\)\+\+,%f8 - d8: 01 00 aa 20 fld.d %r0\(%r5\)\+\+,%f10 - dc: 01 08 cc 20 fld.d %r1\(%r6\)\+\+,%f12 - e0: 01 60 ee 20 fld.d %r12\(%r7\)\+\+,%f14 - e4: 01 68 10 21 fld.d %r13\(%r8\)\+\+,%f16 - e8: 01 70 32 21 fld.d %r14\(%r9\)\+\+,%f18 - ec: 01 78 54 21 fld.d %r15\(%r10\)\+\+,%f20 - f0: 01 80 76 21 fld.d %r16\(%r11\)\+\+,%f22 - f4: 01 88 98 21 fld.d %r17\(%r12\)\+\+,%f24 - f8: 01 e0 ba 21 fld.d %r28\(%r13\)\+\+,%f26 - fc: 01 f8 de 21 fld.d %r31\(%r14\)\+\+,%f30 diff --git a/gas/testsuite/gas/i860/fldst02.s b/gas/testsuite/gas/i860/fldst02.s deleted file mode 100644 index 50b612b..0000000 --- a/gas/testsuite/gas/i860/fldst02.s +++ /dev/null @@ -1,75 +0,0 @@ -# fld.d (no relocations here) - .text - - # Immediate form, no auto-increment. - fld.d 0(%r0),%f0 - fld.d 128(%r1),%f30 - fld.d 256(%r2),%f28 - fld.d 512(%r3),%f26 - fld.d 1024(%r4),%f24 - fld.d 4096(%r5),%f22 - fld.d 8192(%r6),%f20 - fld.d 16384(%r7),%f18 - fld.d 32760(%r7),%f16 - fld.d -32768(%r7),%f14 - fld.d -16384(%r8),%f12 - fld.d -8192(%r9),%f10 - fld.d -4096(%r10),%f8 - fld.d -1024(%r11),%f6 - fld.d -512(%r12),%f4 - fld.d -248(%r13),%f2 - fld.d -8(%r14),%f0 - - # Immediate form, with auto-increment. - fld.d 0(%r0)++,%f0 - fld.d 128(%r1)++,%f2 - fld.d 256(%r2)++,%f4 - fld.d 512(%r3)++,%f6 - fld.d 1024(%r4)++,%f8 - fld.d 4096(%r5)++,%f10 - fld.d 8192(%r6)++,%f12 - fld.d 16384(%r7)++,%f14 - fld.d 32760(%r7)++,%f16 - fld.d -32768(%r7)++,%f18 - fld.d -16384(%r8)++,%f20 - fld.d -8192(%r9)++,%f22 - fld.d -4096(%r10)++,%f24 - fld.d -1024(%r11)++,%f26 - fld.d -512(%r12)++,%f28 - fld.d -248(%r13)++,%f30 - fld.d -8(%r14)++,%f16 - - # Index form, no auto-increment. - fld.d %r5(%r0),%f0 - fld.d %r6(%r1),%f30 - fld.d %r7(%r2),%f28 - fld.d %r8(%r3),%f26 - fld.d %r9(%r4),%f24 - fld.d %r0(%r5),%f22 - fld.d %r1(%r6),%f20 - fld.d %r12(%r7),%f18 - fld.d %r13(%r8),%f16 - fld.d %r14(%r9),%f14 - fld.d %r15(%r10),%f12 - fld.d %r16(%r11),%f10 - fld.d %r17(%r12),%f8 - fld.d %r28(%r13),%f6 - fld.d %r31(%r14),%f4 - - # Index form, with auto-increment. - fld.d %r5(%r0)++,%f0 - fld.d %r6(%r1)++,%f2 - fld.d %r7(%r2)++,%f4 - fld.d %r8(%r3)++,%f6 - fld.d %r9(%r4)++,%f8 - fld.d %r0(%r5)++,%f10 - fld.d %r1(%r6)++,%f12 - fld.d %r12(%r7)++,%f14 - fld.d %r13(%r8)++,%f16 - fld.d %r14(%r9)++,%f18 - fld.d %r15(%r10)++,%f20 - fld.d %r16(%r11)++,%f22 - fld.d %r17(%r12)++,%f24 - fld.d %r28(%r13)++,%f26 - fld.d %r31(%r14)++,%f30 - diff --git a/gas/testsuite/gas/i860/fldst03.d b/gas/testsuite/gas/i860/fldst03.d deleted file mode 100644 index 033c904..0000000 --- a/gas/testsuite/gas/i860/fldst03.d +++ /dev/null @@ -1,73 +0,0 @@ -#as: -#objdump: -dr -#name: i860 fldst03 (fld.q) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 04 00 00 24 fld.q 0\(%r0\),%f0 - 4: 84 00 3c 24 fld.q 128\(%r1\),%f28 - 8: 04 01 58 24 fld.q 256\(%sp\),%f24 - c: 04 02 74 24 fld.q 512\(%fp\),%f20 - 10: 04 04 90 24 fld.q 1024\(%r4\),%f16 - 14: 04 10 ac 24 fld.q 4096\(%r5\),%f12 - 18: 04 20 c8 24 fld.q 8192\(%r6\),%f8 - 1c: 04 40 e4 24 fld.q 16384\(%r7\),%f4 - 20: f4 7f e0 24 fld.q 32752\(%r7\),%f0 - 24: 04 80 fc 24 fld.q -32768\(%r7\),%f28 - 28: 04 c0 18 25 fld.q -16384\(%r8\),%f24 - 2c: 04 e0 34 25 fld.q -8192\(%r9\),%f20 - 30: 04 f0 50 25 fld.q -4096\(%r10\),%f16 - 34: 04 fc 6c 25 fld.q -1024\(%r11\),%f12 - 38: 04 fe 88 25 fld.q -512\(%r12\),%f8 - 3c: 04 ff a4 25 fld.q -256\(%r13\),%f4 - 40: f4 ff c0 25 fld.q -16\(%r14\),%f0 - 44: 05 00 00 24 fld.q 0\(%r0\)\+\+,%f0 - 48: 85 00 24 24 fld.q 128\(%r1\)\+\+,%f4 - 4c: 05 01 48 24 fld.q 256\(%sp\)\+\+,%f8 - 50: 05 02 6c 24 fld.q 512\(%fp\)\+\+,%f12 - 54: 05 04 90 24 fld.q 1024\(%r4\)\+\+,%f16 - 58: 05 10 b4 24 fld.q 4096\(%r5\)\+\+,%f20 - 5c: 05 20 d8 24 fld.q 8192\(%r6\)\+\+,%f24 - 60: 05 40 fc 24 fld.q 16384\(%r7\)\+\+,%f28 - 64: f5 7f e0 24 fld.q 32752\(%r7\)\+\+,%f0 - 68: 05 80 e4 24 fld.q -32768\(%r7\)\+\+,%f4 - 6c: 05 c0 08 25 fld.q -16384\(%r8\)\+\+,%f8 - 70: 05 e0 2c 25 fld.q -8192\(%r9\)\+\+,%f12 - 74: 05 f0 50 25 fld.q -4096\(%r10\)\+\+,%f16 - 78: 05 fc 74 25 fld.q -1024\(%r11\)\+\+,%f20 - 7c: 05 fe 98 25 fld.q -512\(%r12\)\+\+,%f24 - 80: 05 ff bc 25 fld.q -256\(%r13\)\+\+,%f28 - 84: f5 ff d0 25 fld.q -16\(%r14\)\+\+,%f16 - 88: 04 28 00 20 fld.q %r5\(%r0\),%f0 - 8c: 04 30 34 20 fld.q %r6\(%r1\),%f20 - 90: 04 38 50 20 fld.q %r7\(%sp\),%f16 - 94: 04 40 6c 20 fld.q %r8\(%fp\),%f12 - 98: 04 48 88 20 fld.q %r9\(%r4\),%f8 - 9c: 04 00 a4 20 fld.q %r0\(%r5\),%f4 - a0: 04 08 c0 20 fld.q %r1\(%r6\),%f0 - a4: 04 60 fc 20 fld.q %r12\(%r7\),%f28 - a8: 04 68 18 21 fld.q %r13\(%r8\),%f24 - ac: 04 70 34 21 fld.q %r14\(%r9\),%f20 - b0: 04 78 50 21 fld.q %r15\(%r10\),%f16 - b4: 04 80 6c 21 fld.q %r16\(%r11\),%f12 - b8: 04 88 88 21 fld.q %r17\(%r12\),%f8 - bc: 04 e0 a4 21 fld.q %r28\(%r13\),%f4 - c0: 04 f8 c0 21 fld.q %r31\(%r14\),%f0 - c4: 05 28 00 20 fld.q %r5\(%r0\)\+\+,%f0 - c8: 05 30 24 20 fld.q %r6\(%r1\)\+\+,%f4 - cc: 05 38 48 20 fld.q %r7\(%sp\)\+\+,%f8 - d0: 05 40 6c 20 fld.q %r8\(%fp\)\+\+,%f12 - d4: 05 48 90 20 fld.q %r9\(%r4\)\+\+,%f16 - d8: 05 00 b4 20 fld.q %r0\(%r5\)\+\+,%f20 - dc: 05 08 d8 20 fld.q %r1\(%r6\)\+\+,%f24 - e0: 05 60 fc 20 fld.q %r12\(%r7\)\+\+,%f28 - e4: 05 68 00 21 fld.q %r13\(%r8\)\+\+,%f0 - e8: 05 70 24 21 fld.q %r14\(%r9\)\+\+,%f4 - ec: 05 78 48 21 fld.q %r15\(%r10\)\+\+,%f8 - f0: 05 80 6c 21 fld.q %r16\(%r11\)\+\+,%f12 - f4: 05 88 90 21 fld.q %r17\(%r12\)\+\+,%f16 - f8: 05 e0 b4 21 fld.q %r28\(%r13\)\+\+,%f20 - fc: 05 f8 d8 21 fld.q %r31\(%r14\)\+\+,%f24 diff --git a/gas/testsuite/gas/i860/fldst03.s b/gas/testsuite/gas/i860/fldst03.s deleted file mode 100644 index 7259925..0000000 --- a/gas/testsuite/gas/i860/fldst03.s +++ /dev/null @@ -1,75 +0,0 @@ -# fld.q (no relocations here) - .text - - # Immediate form, no auto-increment. - fld.q 0(%r0),%f0 - fld.q 128(%r1),%f28 - fld.q 256(%r2),%f24 - fld.q 512(%r3),%f20 - fld.q 1024(%r4),%f16 - fld.q 4096(%r5),%f12 - fld.q 8192(%r6),%f8 - fld.q 16384(%r7),%f4 - fld.q 32752(%r7),%f0 - fld.q -32768(%r7),%f28 - fld.q -16384(%r8),%f24 - fld.q -8192(%r9),%f20 - fld.q -4096(%r10),%f16 - fld.q -1024(%r11),%f12 - fld.q -512(%r12),%f8 - fld.q -256(%r13),%f4 - fld.q -16(%r14),%f0 - - # Immediate form, with auto-increment. - fld.q 0(%r0)++,%f0 - fld.q 128(%r1)++,%f4 - fld.q 256(%r2)++,%f8 - fld.q 512(%r3)++,%f12 - fld.q 1024(%r4)++,%f16 - fld.q 4096(%r5)++,%f20 - fld.q 8192(%r6)++,%f24 - fld.q 16384(%r7)++,%f28 - fld.q 32752(%r7)++,%f0 - fld.q -32768(%r7)++,%f4 - fld.q -16384(%r8)++,%f8 - fld.q -8192(%r9)++,%f12 - fld.q -4096(%r10)++,%f16 - fld.q -1024(%r11)++,%f20 - fld.q -512(%r12)++,%f24 - fld.q -256(%r13)++,%f28 - fld.q -16(%r14)++,%f16 - - # Index form, no auto-increment. - fld.q %r5(%r0),%f0 - fld.q %r6(%r1),%f20 - fld.q %r7(%r2),%f16 - fld.q %r8(%r3),%f12 - fld.q %r9(%r4),%f8 - fld.q %r0(%r5),%f4 - fld.q %r1(%r6),%f0 - fld.q %r12(%r7),%f28 - fld.q %r13(%r8),%f24 - fld.q %r14(%r9),%f20 - fld.q %r15(%r10),%f16 - fld.q %r16(%r11),%f12 - fld.q %r17(%r12),%f8 - fld.q %r28(%r13),%f4 - fld.q %r31(%r14),%f0 - - # Index form, with auto-increment. - fld.q %r5(%r0)++,%f0 - fld.q %r6(%r1)++,%f4 - fld.q %r7(%r2)++,%f8 - fld.q %r8(%r3)++,%f12 - fld.q %r9(%r4)++,%f16 - fld.q %r0(%r5)++,%f20 - fld.q %r1(%r6)++,%f24 - fld.q %r12(%r7)++,%f28 - fld.q %r13(%r8)++,%f0 - fld.q %r14(%r9)++,%f4 - fld.q %r15(%r10)++,%f8 - fld.q %r16(%r11)++,%f12 - fld.q %r17(%r12)++,%f16 - fld.q %r28(%r13)++,%f20 - fld.q %r31(%r14)++,%f24 - diff --git a/gas/testsuite/gas/i860/fldst04.d b/gas/testsuite/gas/i860/fldst04.d deleted file mode 100644 index 32559ce..0000000 --- a/gas/testsuite/gas/i860/fldst04.d +++ /dev/null @@ -1,73 +0,0 @@ -#as: -#objdump: -dr -#name: i860 fldst04 (fst.l) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 02 00 00 2c fst.l %f0,0\(%r0\) - 4: 7e 00 3f 2c fst.l %f31,124\(%r1\) - 8: 02 01 5e 2c fst.l %f30,256\(%sp\) - c: 02 02 7d 2c fst.l %f29,512\(%fp\) - 10: 02 04 9c 2c fst.l %f28,1024\(%r4\) - 14: 02 10 bb 2c fst.l %f27,4096\(%r5\) - 18: 02 20 da 2c fst.l %f26,8192\(%r6\) - 1c: 02 40 f9 2c fst.l %f25,16384\(%r7\) - 20: fe 7f f9 2c fst.l %f25,32764\(%r7\) - 24: 02 80 f7 2c fst.l %f23,-32768\(%r7\) - 28: 02 c0 02 2d fst.l %f2,-16384\(%r8\) - 2c: 02 e0 23 2d fst.l %f3,-8192\(%r9\) - 30: 02 f0 48 2d fst.l %f8,-4096\(%r10\) - 34: 02 fc 69 2d fst.l %f9,-1024\(%r11\) - 38: 06 fe 8c 2d fst.l %f12,-508\(%r12\) - 3c: 0a ff b3 2d fst.l %f19,-248\(%r13\) - 40: fe ff d5 2d fst.l %f21,-4\(%r14\) - 44: 03 00 00 2c fst.l %f0,0\(%r0\)\+\+ - 48: 7f 00 21 2c fst.l %f1,124\(%r1\)\+\+ - 4c: 03 01 42 2c fst.l %f2,256\(%sp\)\+\+ - 50: 03 02 63 2c fst.l %f3,512\(%fp\)\+\+ - 54: 03 04 84 2c fst.l %f4,1024\(%r4\)\+\+ - 58: 03 10 a5 2c fst.l %f5,4096\(%r5\)\+\+ - 5c: 03 20 c6 2c fst.l %f6,8192\(%r6\)\+\+ - 60: 03 40 e7 2c fst.l %f7,16384\(%r7\)\+\+ - 64: ff 7f e8 2c fst.l %f8,32764\(%r7\)\+\+ - 68: 03 80 e9 2c fst.l %f9,-32768\(%r7\)\+\+ - 6c: 03 c0 0a 2d fst.l %f10,-16384\(%r8\)\+\+ - 70: 03 e0 2b 2d fst.l %f11,-8192\(%r9\)\+\+ - 74: 03 f0 4c 2d fst.l %f12,-4096\(%r10\)\+\+ - 78: 03 fc 6d 2d fst.l %f13,-1024\(%r11\)\+\+ - 7c: 07 fe 8e 2d fst.l %f14,-508\(%r12\)\+\+ - 80: 0b ff af 2d fst.l %f15,-248\(%r13\)\+\+ - 84: ff ff d0 2d fst.l %f16,-4\(%r14\)\+\+ - 88: 02 28 00 28 fst.l %f0,%r5\(%r0\) - 8c: 02 30 3f 28 fst.l %f31,%r6\(%r1\) - 90: 02 38 5e 28 fst.l %f30,%r7\(%sp\) - 94: 02 40 7d 28 fst.l %f29,%r8\(%fp\) - 98: 02 48 9c 28 fst.l %f28,%r9\(%r4\) - 9c: 02 00 bb 28 fst.l %f27,%r0\(%r5\) - a0: 02 08 da 28 fst.l %f26,%r1\(%r6\) - a4: 02 60 f9 28 fst.l %f25,%r12\(%r7\) - a8: 02 68 18 29 fst.l %f24,%r13\(%r8\) - ac: 02 70 37 29 fst.l %f23,%r14\(%r9\) - b0: 02 78 56 29 fst.l %f22,%r15\(%r10\) - b4: 02 80 75 29 fst.l %f21,%r16\(%r11\) - b8: 02 88 94 29 fst.l %f20,%r17\(%r12\) - bc: 02 e0 b3 29 fst.l %f19,%r28\(%r13\) - c0: 02 f8 d2 29 fst.l %f18,%r31\(%r14\) - c4: 03 28 00 28 fst.l %f0,%r5\(%r0\)\+\+ - c8: 03 30 21 28 fst.l %f1,%r6\(%r1\)\+\+ - cc: 03 38 42 28 fst.l %f2,%r7\(%sp\)\+\+ - d0: 03 40 63 28 fst.l %f3,%r8\(%fp\)\+\+ - d4: 03 48 84 28 fst.l %f4,%r9\(%r4\)\+\+ - d8: 03 00 a5 28 fst.l %f5,%r0\(%r5\)\+\+ - dc: 03 08 c6 28 fst.l %f6,%r1\(%r6\)\+\+ - e0: 03 60 e7 28 fst.l %f7,%r12\(%r7\)\+\+ - e4: 03 68 08 29 fst.l %f8,%r13\(%r8\)\+\+ - e8: 03 70 29 29 fst.l %f9,%r14\(%r9\)\+\+ - ec: 03 78 4a 29 fst.l %f10,%r15\(%r10\)\+\+ - f0: 03 80 6b 29 fst.l %f11,%r16\(%r11\)\+\+ - f4: 03 88 8c 29 fst.l %f12,%r17\(%r12\)\+\+ - f8: 03 e0 ad 29 fst.l %f13,%r28\(%r13\)\+\+ - fc: 03 f8 ce 29 fst.l %f14,%r31\(%r14\)\+\+ diff --git a/gas/testsuite/gas/i860/fldst04.s b/gas/testsuite/gas/i860/fldst04.s deleted file mode 100644 index 7136614..0000000 --- a/gas/testsuite/gas/i860/fldst04.s +++ /dev/null @@ -1,75 +0,0 @@ -# fst.l (no relocations here) - .text - - # Immediate form, no auto-increment. - fst.l %f0,0(%r0) - fst.l %f31,124(%r1) - fst.l %f30,256(%r2) - fst.l %f29,512(%r3) - fst.l %f28,1024(%r4) - fst.l %f27,4096(%r5) - fst.l %f26,8192(%r6) - fst.l %f25,16384(%r7) - fst.l %f25,32764(%r7) - fst.l %f23,-32768(%r7) - fst.l %f2,-16384(%r8) - fst.l %f3,-8192(%r9) - fst.l %f8,-4096(%r10) - fst.l %f9,-1024(%r11) - fst.l %f12,-508(%r12) - fst.l %f19,-248(%r13) - fst.l %f21,-4(%r14) - - # Immediate form, with auto-increment. - fst.l %f0,0(%r0)++ - fst.l %f1,124(%r1)++ - fst.l %f2,256(%r2)++ - fst.l %f3,512(%r3)++ - fst.l %f4,1024(%r4)++ - fst.l %f5,4096(%r5)++ - fst.l %f6,8192(%r6)++ - fst.l %f7,16384(%r7)++ - fst.l %f8,32764(%r7)++ - fst.l %f9,-32768(%r7)++ - fst.l %f10,-16384(%r8)++ - fst.l %f11,-8192(%r9)++ - fst.l %f12,-4096(%r10)++ - fst.l %f13,-1024(%r11)++ - fst.l %f14,-508(%r12)++ - fst.l %f15,-248(%r13)++ - fst.l %f16,-4(%r14)++ - - # Index form, no auto-increment. - fst.l %f0,%r5(%r0) - fst.l %f31,%r6(%r1) - fst.l %f30,%r7(%r2) - fst.l %f29,%r8(%r3) - fst.l %f28,%r9(%r4) - fst.l %f27,%r0(%r5) - fst.l %f26,%r1(%r6) - fst.l %f25,%r12(%r7) - fst.l %f24,%r13(%r8) - fst.l %f23,%r14(%r9) - fst.l %f22,%r15(%r10) - fst.l %f21,%r16(%r11) - fst.l %f20,%r17(%r12) - fst.l %f19,%r28(%r13) - fst.l %f18,%r31(%r14) - - # Index form, with auto-increment. - fst.l %f0,%r5(%r0)++ - fst.l %f1,%r6(%r1)++ - fst.l %f2,%r7(%r2)++ - fst.l %f3,%r8(%r3)++ - fst.l %f4,%r9(%r4)++ - fst.l %f5,%r0(%r5)++ - fst.l %f6,%r1(%r6)++ - fst.l %f7,%r12(%r7)++ - fst.l %f8,%r13(%r8)++ - fst.l %f9,%r14(%r9)++ - fst.l %f10,%r15(%r10)++ - fst.l %f11,%r16(%r11)++ - fst.l %f12,%r17(%r12)++ - fst.l %f13,%r28(%r13)++ - fst.l %f14,%r31(%r14)++ - diff --git a/gas/testsuite/gas/i860/fldst05.d b/gas/testsuite/gas/i860/fldst05.d deleted file mode 100644 index a6187bf..0000000 --- a/gas/testsuite/gas/i860/fldst05.d +++ /dev/null @@ -1,73 +0,0 @@ -#as: -#objdump: -dr -#name: i860 fldst05 (fst.d) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 00 2c fst.d %f0,0\(%r0\) - 4: 80 00 3e 2c fst.d %f30,128\(%r1\) - 8: 00 01 5c 2c fst.d %f28,256\(%sp\) - c: 00 02 7a 2c fst.d %f26,512\(%fp\) - 10: 00 04 98 2c fst.d %f24,1024\(%r4\) - 14: 00 10 b6 2c fst.d %f22,4096\(%r5\) - 18: 00 20 d4 2c fst.d %f20,8192\(%r6\) - 1c: 00 40 f2 2c fst.d %f18,16384\(%r7\) - 20: f8 7f f0 2c fst.d %f16,32760\(%r7\) - 24: 00 80 ee 2c fst.d %f14,-32768\(%r7\) - 28: 00 c0 0c 2d fst.d %f12,-16384\(%r8\) - 2c: 00 e0 2a 2d fst.d %f10,-8192\(%r9\) - 30: 00 f0 48 2d fst.d %f8,-4096\(%r10\) - 34: 00 fc 66 2d fst.d %f6,-1024\(%r11\) - 38: 00 fe 84 2d fst.d %f4,-512\(%r12\) - 3c: 08 ff a2 2d fst.d %f2,-248\(%r13\) - 40: f8 ff c0 2d fst.d %f0,-8\(%r14\) - 44: 01 00 00 2c fst.d %f0,0\(%r0\)\+\+ - 48: 81 00 22 2c fst.d %f2,128\(%r1\)\+\+ - 4c: 01 01 44 2c fst.d %f4,256\(%sp\)\+\+ - 50: 01 02 66 2c fst.d %f6,512\(%fp\)\+\+ - 54: 01 04 88 2c fst.d %f8,1024\(%r4\)\+\+ - 58: 01 10 aa 2c fst.d %f10,4096\(%r5\)\+\+ - 5c: 01 20 cc 2c fst.d %f12,8192\(%r6\)\+\+ - 60: 01 40 ee 2c fst.d %f14,16384\(%r7\)\+\+ - 64: f9 7f f0 2c fst.d %f16,32760\(%r7\)\+\+ - 68: 01 80 f2 2c fst.d %f18,-32768\(%r7\)\+\+ - 6c: 01 c0 14 2d fst.d %f20,-16384\(%r8\)\+\+ - 70: 01 e0 36 2d fst.d %f22,-8192\(%r9\)\+\+ - 74: 01 f0 58 2d fst.d %f24,-4096\(%r10\)\+\+ - 78: 01 fc 7a 2d fst.d %f26,-1024\(%r11\)\+\+ - 7c: 01 fe 9c 2d fst.d %f28,-512\(%r12\)\+\+ - 80: 09 ff be 2d fst.d %f30,-248\(%r13\)\+\+ - 84: f9 ff d0 2d fst.d %f16,-8\(%r14\)\+\+ - 88: 00 28 00 28 fst.d %f0,%r5\(%r0\) - 8c: 00 30 3e 28 fst.d %f30,%r6\(%r1\) - 90: 00 38 5c 28 fst.d %f28,%r7\(%sp\) - 94: 00 40 7a 28 fst.d %f26,%r8\(%fp\) - 98: 00 48 98 28 fst.d %f24,%r9\(%r4\) - 9c: 00 00 b6 28 fst.d %f22,%r0\(%r5\) - a0: 00 08 d4 28 fst.d %f20,%r1\(%r6\) - a4: 00 60 f2 28 fst.d %f18,%r12\(%r7\) - a8: 00 68 10 29 fst.d %f16,%r13\(%r8\) - ac: 00 70 2e 29 fst.d %f14,%r14\(%r9\) - b0: 00 78 4c 29 fst.d %f12,%r15\(%r10\) - b4: 00 80 6a 29 fst.d %f10,%r16\(%r11\) - b8: 00 88 88 29 fst.d %f8,%r17\(%r12\) - bc: 00 e0 a6 29 fst.d %f6,%r28\(%r13\) - c0: 00 f8 c4 29 fst.d %f4,%r31\(%r14\) - c4: 01 28 00 28 fst.d %f0,%r5\(%r0\)\+\+ - c8: 01 30 22 28 fst.d %f2,%r6\(%r1\)\+\+ - cc: 01 38 44 28 fst.d %f4,%r7\(%sp\)\+\+ - d0: 01 40 66 28 fst.d %f6,%r8\(%fp\)\+\+ - d4: 01 48 88 28 fst.d %f8,%r9\(%r4\)\+\+ - d8: 01 00 aa 28 fst.d %f10,%r0\(%r5\)\+\+ - dc: 01 08 cc 28 fst.d %f12,%r1\(%r6\)\+\+ - e0: 01 60 ee 28 fst.d %f14,%r12\(%r7\)\+\+ - e4: 01 68 10 29 fst.d %f16,%r13\(%r8\)\+\+ - e8: 01 70 32 29 fst.d %f18,%r14\(%r9\)\+\+ - ec: 01 78 54 29 fst.d %f20,%r15\(%r10\)\+\+ - f0: 01 80 76 29 fst.d %f22,%r16\(%r11\)\+\+ - f4: 01 88 98 29 fst.d %f24,%r17\(%r12\)\+\+ - f8: 01 e0 ba 29 fst.d %f26,%r28\(%r13\)\+\+ - fc: 01 f8 de 29 fst.d %f30,%r31\(%r14\)\+\+ diff --git a/gas/testsuite/gas/i860/fldst05.s b/gas/testsuite/gas/i860/fldst05.s deleted file mode 100644 index 97032aa..0000000 --- a/gas/testsuite/gas/i860/fldst05.s +++ /dev/null @@ -1,75 +0,0 @@ -# fst.d (no relocations here) - .text - - # Immediate form, no auto-increment. - fst.d %f0,0(%r0) - fst.d %f30,128(%r1) - fst.d %f28,256(%r2) - fst.d %f26,512(%r3) - fst.d %f24,1024(%r4) - fst.d %f22,4096(%r5) - fst.d %f20,8192(%r6) - fst.d %f18,16384(%r7) - fst.d %f16,32760(%r7) - fst.d %f14,-32768(%r7) - fst.d %f12,-16384(%r8) - fst.d %f10,-8192(%r9) - fst.d %f8,-4096(%r10) - fst.d %f6,-1024(%r11) - fst.d %f4,-512(%r12) - fst.d %f2,-248(%r13) - fst.d %f0,-8(%r14) - - # Immediate form, with auto-increment. - fst.d %f0,0(%r0)++ - fst.d %f2,128(%r1)++ - fst.d %f4,256(%r2)++ - fst.d %f6,512(%r3)++ - fst.d %f8,1024(%r4)++ - fst.d %f10,4096(%r5)++ - fst.d %f12,8192(%r6)++ - fst.d %f14,16384(%r7)++ - fst.d %f16,32760(%r7)++ - fst.d %f18,-32768(%r7)++ - fst.d %f20,-16384(%r8)++ - fst.d %f22,-8192(%r9)++ - fst.d %f24,-4096(%r10)++ - fst.d %f26,-1024(%r11)++ - fst.d %f28,-512(%r12)++ - fst.d %f30,-248(%r13)++ - fst.d %f16,-8(%r14)++ - - # Index form, no auto-increment. - fst.d %f0,%r5(%r0) - fst.d %f30,%r6(%r1) - fst.d %f28,%r7(%r2) - fst.d %f26,%r8(%r3) - fst.d %f24,%r9(%r4) - fst.d %f22,%r0(%r5) - fst.d %f20,%r1(%r6) - fst.d %f18,%r12(%r7) - fst.d %f16,%r13(%r8) - fst.d %f14,%r14(%r9) - fst.d %f12,%r15(%r10) - fst.d %f10,%r16(%r11) - fst.d %f8,%r17(%r12) - fst.d %f6,%r28(%r13) - fst.d %f4,%r31(%r14) - - # Index form, with auto-increment. - fst.d %f0,%r5(%r0)++ - fst.d %f2,%r6(%r1)++ - fst.d %f4,%r7(%r2)++ - fst.d %f6,%r8(%r3)++ - fst.d %f8,%r9(%r4)++ - fst.d %f10,%r0(%r5)++ - fst.d %f12,%r1(%r6)++ - fst.d %f14,%r12(%r7)++ - fst.d %f16,%r13(%r8)++ - fst.d %f18,%r14(%r9)++ - fst.d %f20,%r15(%r10)++ - fst.d %f22,%r16(%r11)++ - fst.d %f24,%r17(%r12)++ - fst.d %f26,%r28(%r13)++ - fst.d %f30,%r31(%r14)++ - diff --git a/gas/testsuite/gas/i860/fldst06.d b/gas/testsuite/gas/i860/fldst06.d deleted file mode 100644 index a1f6c5c..0000000 --- a/gas/testsuite/gas/i860/fldst06.d +++ /dev/null @@ -1,73 +0,0 @@ -#as: -#objdump: -dr -#name: i860 fldst06 (fst.q) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 04 00 00 2c fst.q %f0,0\(%r0\) - 4: 84 00 3c 2c fst.q %f28,128\(%r1\) - 8: 04 01 58 2c fst.q %f24,256\(%sp\) - c: 04 02 74 2c fst.q %f20,512\(%fp\) - 10: 04 04 90 2c fst.q %f16,1024\(%r4\) - 14: 04 10 ac 2c fst.q %f12,4096\(%r5\) - 18: 04 20 c8 2c fst.q %f8,8192\(%r6\) - 1c: 04 40 e4 2c fst.q %f4,16384\(%r7\) - 20: f4 7f e0 2c fst.q %f0,32752\(%r7\) - 24: 04 80 fc 2c fst.q %f28,-32768\(%r7\) - 28: 04 c0 18 2d fst.q %f24,-16384\(%r8\) - 2c: 04 e0 34 2d fst.q %f20,-8192\(%r9\) - 30: 04 f0 50 2d fst.q %f16,-4096\(%r10\) - 34: 04 fc 6c 2d fst.q %f12,-1024\(%r11\) - 38: 04 fe 88 2d fst.q %f8,-512\(%r12\) - 3c: 04 ff a4 2d fst.q %f4,-256\(%r13\) - 40: f4 ff c0 2d fst.q %f0,-16\(%r14\) - 44: 05 00 00 2c fst.q %f0,0\(%r0\)\+\+ - 48: 85 00 24 2c fst.q %f4,128\(%r1\)\+\+ - 4c: 05 01 48 2c fst.q %f8,256\(%sp\)\+\+ - 50: 05 02 6c 2c fst.q %f12,512\(%fp\)\+\+ - 54: 05 04 90 2c fst.q %f16,1024\(%r4\)\+\+ - 58: 05 10 b4 2c fst.q %f20,4096\(%r5\)\+\+ - 5c: 05 20 d8 2c fst.q %f24,8192\(%r6\)\+\+ - 60: 05 40 fc 2c fst.q %f28,16384\(%r7\)\+\+ - 64: f5 7f e0 2c fst.q %f0,32752\(%r7\)\+\+ - 68: 05 80 e4 2c fst.q %f4,-32768\(%r7\)\+\+ - 6c: 05 c0 08 2d fst.q %f8,-16384\(%r8\)\+\+ - 70: 05 e0 2c 2d fst.q %f12,-8192\(%r9\)\+\+ - 74: 05 f0 50 2d fst.q %f16,-4096\(%r10\)\+\+ - 78: 05 fc 74 2d fst.q %f20,-1024\(%r11\)\+\+ - 7c: 05 fe 98 2d fst.q %f24,-512\(%r12\)\+\+ - 80: 05 ff bc 2d fst.q %f28,-256\(%r13\)\+\+ - 84: f5 ff d0 2d fst.q %f16,-16\(%r14\)\+\+ - 88: 04 28 00 28 fst.q %f0,%r5\(%r0\) - 8c: 04 30 34 28 fst.q %f20,%r6\(%r1\) - 90: 04 38 50 28 fst.q %f16,%r7\(%sp\) - 94: 04 40 6c 28 fst.q %f12,%r8\(%fp\) - 98: 04 48 88 28 fst.q %f8,%r9\(%r4\) - 9c: 04 00 a4 28 fst.q %f4,%r0\(%r5\) - a0: 04 08 c0 28 fst.q %f0,%r1\(%r6\) - a4: 04 60 fc 28 fst.q %f28,%r12\(%r7\) - a8: 04 68 18 29 fst.q %f24,%r13\(%r8\) - ac: 04 70 34 29 fst.q %f20,%r14\(%r9\) - b0: 04 78 50 29 fst.q %f16,%r15\(%r10\) - b4: 04 80 6c 29 fst.q %f12,%r16\(%r11\) - b8: 04 88 88 29 fst.q %f8,%r17\(%r12\) - bc: 04 e0 a4 29 fst.q %f4,%r28\(%r13\) - c0: 04 f8 c0 29 fst.q %f0,%r31\(%r14\) - c4: 05 28 00 28 fst.q %f0,%r5\(%r0\)\+\+ - c8: 05 30 24 28 fst.q %f4,%r6\(%r1\)\+\+ - cc: 05 38 48 28 fst.q %f8,%r7\(%sp\)\+\+ - d0: 05 40 6c 28 fst.q %f12,%r8\(%fp\)\+\+ - d4: 05 48 90 28 fst.q %f16,%r9\(%r4\)\+\+ - d8: 05 00 b4 28 fst.q %f20,%r0\(%r5\)\+\+ - dc: 05 08 d8 28 fst.q %f24,%r1\(%r6\)\+\+ - e0: 05 60 fc 28 fst.q %f28,%r12\(%r7\)\+\+ - e4: 05 68 00 29 fst.q %f0,%r13\(%r8\)\+\+ - e8: 05 70 24 29 fst.q %f4,%r14\(%r9\)\+\+ - ec: 05 78 48 29 fst.q %f8,%r15\(%r10\)\+\+ - f0: 05 80 6c 29 fst.q %f12,%r16\(%r11\)\+\+ - f4: 05 88 90 29 fst.q %f16,%r17\(%r12\)\+\+ - f8: 05 e0 b4 29 fst.q %f20,%r28\(%r13\)\+\+ - fc: 05 f8 d8 29 fst.q %f24,%r31\(%r14\)\+\+ diff --git a/gas/testsuite/gas/i860/fldst06.s b/gas/testsuite/gas/i860/fldst06.s deleted file mode 100644 index 0bb1476..0000000 --- a/gas/testsuite/gas/i860/fldst06.s +++ /dev/null @@ -1,75 +0,0 @@ -# fst.q (no relocations here) - .text - - # Immediate form, no auto-increment. - fst.q %f0,0(%r0) - fst.q %f28,128(%r1) - fst.q %f24,256(%r2) - fst.q %f20,512(%r3) - fst.q %f16,1024(%r4) - fst.q %f12,4096(%r5) - fst.q %f8,8192(%r6) - fst.q %f4,16384(%r7) - fst.q %f0,32752(%r7) - fst.q %f28,-32768(%r7) - fst.q %f24,-16384(%r8) - fst.q %f20,-8192(%r9) - fst.q %f16,-4096(%r10) - fst.q %f12,-1024(%r11) - fst.q %f8,-512(%r12) - fst.q %f4,-256(%r13) - fst.q %f0,-16(%r14) - - # Immediate form, with auto-increment. - fst.q %f0,0(%r0)++ - fst.q %f4,128(%r1)++ - fst.q %f8,256(%r2)++ - fst.q %f12,512(%r3)++ - fst.q %f16,1024(%r4)++ - fst.q %f20,4096(%r5)++ - fst.q %f24,8192(%r6)++ - fst.q %f28,16384(%r7)++ - fst.q %f0,32752(%r7)++ - fst.q %f4,-32768(%r7)++ - fst.q %f8,-16384(%r8)++ - fst.q %f12,-8192(%r9)++ - fst.q %f16,-4096(%r10)++ - fst.q %f20,-1024(%r11)++ - fst.q %f24,-512(%r12)++ - fst.q %f28,-256(%r13)++ - fst.q %f16,-16(%r14)++ - - # Index form, no auto-increment. - fst.q %f0,%r5(%r0) - fst.q %f20,%r6(%r1) - fst.q %f16,%r7(%r2) - fst.q %f12,%r8(%r3) - fst.q %f8,%r9(%r4) - fst.q %f4,%r0(%r5) - fst.q %f0,%r1(%r6) - fst.q %f28,%r12(%r7) - fst.q %f24,%r13(%r8) - fst.q %f20,%r14(%r9) - fst.q %f16,%r15(%r10) - fst.q %f12,%r16(%r11) - fst.q %f8,%r17(%r12) - fst.q %f4,%r28(%r13) - fst.q %f0,%r31(%r14) - - # Index form, with auto-increment. - fst.q %f0,%r5(%r0)++ - fst.q %f4,%r6(%r1)++ - fst.q %f8,%r7(%r2)++ - fst.q %f12,%r8(%r3)++ - fst.q %f16,%r9(%r4)++ - fst.q %f20,%r0(%r5)++ - fst.q %f24,%r1(%r6)++ - fst.q %f28,%r12(%r7)++ - fst.q %f0,%r13(%r8)++ - fst.q %f4,%r14(%r9)++ - fst.q %f8,%r15(%r10)++ - fst.q %f12,%r16(%r11)++ - fst.q %f16,%r17(%r12)++ - fst.q %f20,%r28(%r13)++ - fst.q %f24,%r31(%r14)++ - diff --git a/gas/testsuite/gas/i860/fldst07.d b/gas/testsuite/gas/i860/fldst07.d deleted file mode 100644 index 4ba66f9..0000000 --- a/gas/testsuite/gas/i860/fldst07.d +++ /dev/null @@ -1,73 +0,0 @@ -#as: -#objdump: -dr -#name: i860 fldst07 (pfld.l) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 02 00 00 64 pfld.l 0\(%r0\),%f0 - 4: 7e 00 3f 64 pfld.l 124\(%r1\),%f31 - 8: 02 01 5e 64 pfld.l 256\(%sp\),%f30 - c: 02 02 7d 64 pfld.l 512\(%fp\),%f29 - 10: 02 04 9c 64 pfld.l 1024\(%r4\),%f28 - 14: 02 10 bb 64 pfld.l 4096\(%r5\),%f27 - 18: 02 20 da 64 pfld.l 8192\(%r6\),%f26 - 1c: 02 40 f9 64 pfld.l 16384\(%r7\),%f25 - 20: fe 7f f9 64 pfld.l 32764\(%r7\),%f25 - 24: 02 80 f7 64 pfld.l -32768\(%r7\),%f23 - 28: 02 c0 02 65 pfld.l -16384\(%r8\),%f2 - 2c: 02 e0 23 65 pfld.l -8192\(%r9\),%f3 - 30: 02 f0 48 65 pfld.l -4096\(%r10\),%f8 - 34: 02 fc 69 65 pfld.l -1024\(%r11\),%f9 - 38: 06 fe 8c 65 pfld.l -508\(%r12\),%f12 - 3c: 0a ff b3 65 pfld.l -248\(%r13\),%f19 - 40: fe ff d5 65 pfld.l -4\(%r14\),%f21 - 44: 03 00 00 64 pfld.l 0\(%r0\)\+\+,%f0 - 48: 7f 00 21 64 pfld.l 124\(%r1\)\+\+,%f1 - 4c: 03 01 42 64 pfld.l 256\(%sp\)\+\+,%f2 - 50: 03 02 63 64 pfld.l 512\(%fp\)\+\+,%f3 - 54: 03 04 84 64 pfld.l 1024\(%r4\)\+\+,%f4 - 58: 03 10 a5 64 pfld.l 4096\(%r5\)\+\+,%f5 - 5c: 03 20 c6 64 pfld.l 8192\(%r6\)\+\+,%f6 - 60: 03 40 e7 64 pfld.l 16384\(%r7\)\+\+,%f7 - 64: ff 7f e8 64 pfld.l 32764\(%r7\)\+\+,%f8 - 68: 03 80 e9 64 pfld.l -32768\(%r7\)\+\+,%f9 - 6c: 03 c0 0a 65 pfld.l -16384\(%r8\)\+\+,%f10 - 70: 03 e0 2b 65 pfld.l -8192\(%r9\)\+\+,%f11 - 74: 03 f0 4c 65 pfld.l -4096\(%r10\)\+\+,%f12 - 78: 03 fc 6d 65 pfld.l -1024\(%r11\)\+\+,%f13 - 7c: 07 fe 8e 65 pfld.l -508\(%r12\)\+\+,%f14 - 80: 0b ff af 65 pfld.l -248\(%r13\)\+\+,%f15 - 84: ff ff d0 65 pfld.l -4\(%r14\)\+\+,%f16 - 88: 02 28 00 60 pfld.l %r5\(%r0\),%f0 - 8c: 02 30 3f 60 pfld.l %r6\(%r1\),%f31 - 90: 02 38 5e 60 pfld.l %r7\(%sp\),%f30 - 94: 02 40 7d 60 pfld.l %r8\(%fp\),%f29 - 98: 02 48 9c 60 pfld.l %r9\(%r4\),%f28 - 9c: 02 00 bb 60 pfld.l %r0\(%r5\),%f27 - a0: 02 08 da 60 pfld.l %r1\(%r6\),%f26 - a4: 02 60 f9 60 pfld.l %r12\(%r7\),%f25 - a8: 02 68 18 61 pfld.l %r13\(%r8\),%f24 - ac: 02 70 37 61 pfld.l %r14\(%r9\),%f23 - b0: 02 78 56 61 pfld.l %r15\(%r10\),%f22 - b4: 02 80 75 61 pfld.l %r16\(%r11\),%f21 - b8: 02 88 94 61 pfld.l %r17\(%r12\),%f20 - bc: 02 e0 b3 61 pfld.l %r28\(%r13\),%f19 - c0: 02 f8 d2 61 pfld.l %r31\(%r14\),%f18 - c4: 03 28 00 60 pfld.l %r5\(%r0\)\+\+,%f0 - c8: 03 30 21 60 pfld.l %r6\(%r1\)\+\+,%f1 - cc: 03 38 42 60 pfld.l %r7\(%sp\)\+\+,%f2 - d0: 03 40 63 60 pfld.l %r8\(%fp\)\+\+,%f3 - d4: 03 48 84 60 pfld.l %r9\(%r4\)\+\+,%f4 - d8: 03 00 a5 60 pfld.l %r0\(%r5\)\+\+,%f5 - dc: 03 08 c6 60 pfld.l %r1\(%r6\)\+\+,%f6 - e0: 03 60 e7 60 pfld.l %r12\(%r7\)\+\+,%f7 - e4: 03 68 08 61 pfld.l %r13\(%r8\)\+\+,%f8 - e8: 03 70 29 61 pfld.l %r14\(%r9\)\+\+,%f9 - ec: 03 78 4a 61 pfld.l %r15\(%r10\)\+\+,%f10 - f0: 03 80 6b 61 pfld.l %r16\(%r11\)\+\+,%f11 - f4: 03 88 8c 61 pfld.l %r17\(%r12\)\+\+,%f12 - f8: 03 e0 ad 61 pfld.l %r28\(%r13\)\+\+,%f13 - fc: 03 f8 ce 61 pfld.l %r31\(%r14\)\+\+,%f14 diff --git a/gas/testsuite/gas/i860/fldst07.s b/gas/testsuite/gas/i860/fldst07.s deleted file mode 100644 index 410b256..0000000 --- a/gas/testsuite/gas/i860/fldst07.s +++ /dev/null @@ -1,75 +0,0 @@ -# pfld.l (no relocations here) - .text - - # Immediate form, no auto-increment. - pfld.l 0(%r0),%f0 - pfld.l 124(%r1),%f31 - pfld.l 256(%r2),%f30 - pfld.l 512(%r3),%f29 - pfld.l 1024(%r4),%f28 - pfld.l 4096(%r5),%f27 - pfld.l 8192(%r6),%f26 - pfld.l 16384(%r7),%f25 - pfld.l 32764(%r7),%f25 - pfld.l -32768(%r7),%f23 - pfld.l -16384(%r8),%f2 - pfld.l -8192(%r9),%f3 - pfld.l -4096(%r10),%f8 - pfld.l -1024(%r11),%f9 - pfld.l -508(%r12),%f12 - pfld.l -248(%r13),%f19 - pfld.l -4(%r14),%f21 - - # Immediate form, with auto-increment. - pfld.l 0(%r0)++,%f0 - pfld.l 124(%r1)++,%f1 - pfld.l 256(%r2)++,%f2 - pfld.l 512(%r3)++,%f3 - pfld.l 1024(%r4)++,%f4 - pfld.l 4096(%r5)++,%f5 - pfld.l 8192(%r6)++,%f6 - pfld.l 16384(%r7)++,%f7 - pfld.l 32764(%r7)++,%f8 - pfld.l -32768(%r7)++,%f9 - pfld.l -16384(%r8)++,%f10 - pfld.l -8192(%r9)++,%f11 - pfld.l -4096(%r10)++,%f12 - pfld.l -1024(%r11)++,%f13 - pfld.l -508(%r12)++,%f14 - pfld.l -248(%r13)++,%f15 - pfld.l -4(%r14)++,%f16 - - # Index form, no auto-increment. - pfld.l %r5(%r0),%f0 - pfld.l %r6(%r1),%f31 - pfld.l %r7(%r2),%f30 - pfld.l %r8(%r3),%f29 - pfld.l %r9(%r4),%f28 - pfld.l %r0(%r5),%f27 - pfld.l %r1(%r6),%f26 - pfld.l %r12(%r7),%f25 - pfld.l %r13(%r8),%f24 - pfld.l %r14(%r9),%f23 - pfld.l %r15(%r10),%f22 - pfld.l %r16(%r11),%f21 - pfld.l %r17(%r12),%f20 - pfld.l %r28(%r13),%f19 - pfld.l %r31(%r14),%f18 - - # Index form, with auto-increment. - pfld.l %r5(%r0)++,%f0 - pfld.l %r6(%r1)++,%f1 - pfld.l %r7(%r2)++,%f2 - pfld.l %r8(%r3)++,%f3 - pfld.l %r9(%r4)++,%f4 - pfld.l %r0(%r5)++,%f5 - pfld.l %r1(%r6)++,%f6 - pfld.l %r12(%r7)++,%f7 - pfld.l %r13(%r8)++,%f8 - pfld.l %r14(%r9)++,%f9 - pfld.l %r15(%r10)++,%f10 - pfld.l %r16(%r11)++,%f11 - pfld.l %r17(%r12)++,%f12 - pfld.l %r28(%r13)++,%f13 - pfld.l %r31(%r14)++,%f14 - diff --git a/gas/testsuite/gas/i860/fldst08.d b/gas/testsuite/gas/i860/fldst08.d deleted file mode 100644 index 272b40d..0000000 --- a/gas/testsuite/gas/i860/fldst08.d +++ /dev/null @@ -1,73 +0,0 @@ -#as: -#objdump: -dr -#name: i860 fldst08 (pfld.d) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 00 64 pfld.d 0\(%r0\),%f0 - 4: 80 00 3e 64 pfld.d 128\(%r1\),%f30 - 8: 00 01 5c 64 pfld.d 256\(%sp\),%f28 - c: 00 02 7a 64 pfld.d 512\(%fp\),%f26 - 10: 00 04 98 64 pfld.d 1024\(%r4\),%f24 - 14: 00 10 b6 64 pfld.d 4096\(%r5\),%f22 - 18: 00 20 d4 64 pfld.d 8192\(%r6\),%f20 - 1c: 00 40 f2 64 pfld.d 16384\(%r7\),%f18 - 20: f8 7f f0 64 pfld.d 32760\(%r7\),%f16 - 24: 00 80 ee 64 pfld.d -32768\(%r7\),%f14 - 28: 00 c0 0c 65 pfld.d -16384\(%r8\),%f12 - 2c: 00 e0 2a 65 pfld.d -8192\(%r9\),%f10 - 30: 00 f0 48 65 pfld.d -4096\(%r10\),%f8 - 34: 00 fc 66 65 pfld.d -1024\(%r11\),%f6 - 38: 00 fe 84 65 pfld.d -512\(%r12\),%f4 - 3c: 08 ff a2 65 pfld.d -248\(%r13\),%f2 - 40: f8 ff c0 65 pfld.d -8\(%r14\),%f0 - 44: 01 00 00 64 pfld.d 0\(%r0\)\+\+,%f0 - 48: 81 00 22 64 pfld.d 128\(%r1\)\+\+,%f2 - 4c: 01 01 44 64 pfld.d 256\(%sp\)\+\+,%f4 - 50: 01 02 66 64 pfld.d 512\(%fp\)\+\+,%f6 - 54: 01 04 88 64 pfld.d 1024\(%r4\)\+\+,%f8 - 58: 01 10 aa 64 pfld.d 4096\(%r5\)\+\+,%f10 - 5c: 01 20 cc 64 pfld.d 8192\(%r6\)\+\+,%f12 - 60: 01 40 ee 64 pfld.d 16384\(%r7\)\+\+,%f14 - 64: f9 7f f0 64 pfld.d 32760\(%r7\)\+\+,%f16 - 68: 01 80 f2 64 pfld.d -32768\(%r7\)\+\+,%f18 - 6c: 01 c0 14 65 pfld.d -16384\(%r8\)\+\+,%f20 - 70: 01 e0 36 65 pfld.d -8192\(%r9\)\+\+,%f22 - 74: 01 f0 58 65 pfld.d -4096\(%r10\)\+\+,%f24 - 78: 01 fc 7a 65 pfld.d -1024\(%r11\)\+\+,%f26 - 7c: 01 fe 9c 65 pfld.d -512\(%r12\)\+\+,%f28 - 80: 09 ff be 65 pfld.d -248\(%r13\)\+\+,%f30 - 84: f9 ff d0 65 pfld.d -8\(%r14\)\+\+,%f16 - 88: 00 28 00 60 pfld.d %r5\(%r0\),%f0 - 8c: 00 30 3e 60 pfld.d %r6\(%r1\),%f30 - 90: 00 38 5c 60 pfld.d %r7\(%sp\),%f28 - 94: 00 40 7a 60 pfld.d %r8\(%fp\),%f26 - 98: 00 48 98 60 pfld.d %r9\(%r4\),%f24 - 9c: 00 00 b6 60 pfld.d %r0\(%r5\),%f22 - a0: 00 08 d4 60 pfld.d %r1\(%r6\),%f20 - a4: 00 60 f2 60 pfld.d %r12\(%r7\),%f18 - a8: 00 68 10 61 pfld.d %r13\(%r8\),%f16 - ac: 00 70 2e 61 pfld.d %r14\(%r9\),%f14 - b0: 00 78 4c 61 pfld.d %r15\(%r10\),%f12 - b4: 00 80 6a 61 pfld.d %r16\(%r11\),%f10 - b8: 00 88 88 61 pfld.d %r17\(%r12\),%f8 - bc: 00 e0 a6 61 pfld.d %r28\(%r13\),%f6 - c0: 00 f8 c4 61 pfld.d %r31\(%r14\),%f4 - c4: 01 28 00 60 pfld.d %r5\(%r0\)\+\+,%f0 - c8: 01 30 22 60 pfld.d %r6\(%r1\)\+\+,%f2 - cc: 01 38 44 60 pfld.d %r7\(%sp\)\+\+,%f4 - d0: 01 40 66 60 pfld.d %r8\(%fp\)\+\+,%f6 - d4: 01 48 88 60 pfld.d %r9\(%r4\)\+\+,%f8 - d8: 01 00 aa 60 pfld.d %r0\(%r5\)\+\+,%f10 - dc: 01 08 cc 60 pfld.d %r1\(%r6\)\+\+,%f12 - e0: 01 60 ee 60 pfld.d %r12\(%r7\)\+\+,%f14 - e4: 01 68 10 61 pfld.d %r13\(%r8\)\+\+,%f16 - e8: 01 70 32 61 pfld.d %r14\(%r9\)\+\+,%f18 - ec: 01 78 54 61 pfld.d %r15\(%r10\)\+\+,%f20 - f0: 01 80 76 61 pfld.d %r16\(%r11\)\+\+,%f22 - f4: 01 88 98 61 pfld.d %r17\(%r12\)\+\+,%f24 - f8: 01 e0 ba 61 pfld.d %r28\(%r13\)\+\+,%f26 - fc: 01 f8 de 61 pfld.d %r31\(%r14\)\+\+,%f30 diff --git a/gas/testsuite/gas/i860/fldst08.s b/gas/testsuite/gas/i860/fldst08.s deleted file mode 100644 index 7ae6cf5..0000000 --- a/gas/testsuite/gas/i860/fldst08.s +++ /dev/null @@ -1,75 +0,0 @@ -# pfld.d (no relocations here) - .text - - # Immediate form, no auto-increment. - pfld.d 0(%r0),%f0 - pfld.d 128(%r1),%f30 - pfld.d 256(%r2),%f28 - pfld.d 512(%r3),%f26 - pfld.d 1024(%r4),%f24 - pfld.d 4096(%r5),%f22 - pfld.d 8192(%r6),%f20 - pfld.d 16384(%r7),%f18 - pfld.d 32760(%r7),%f16 - pfld.d -32768(%r7),%f14 - pfld.d -16384(%r8),%f12 - pfld.d -8192(%r9),%f10 - pfld.d -4096(%r10),%f8 - pfld.d -1024(%r11),%f6 - pfld.d -512(%r12),%f4 - pfld.d -248(%r13),%f2 - pfld.d -8(%r14),%f0 - - # Immediate form, with auto-increment. - pfld.d 0(%r0)++,%f0 - pfld.d 128(%r1)++,%f2 - pfld.d 256(%r2)++,%f4 - pfld.d 512(%r3)++,%f6 - pfld.d 1024(%r4)++,%f8 - pfld.d 4096(%r5)++,%f10 - pfld.d 8192(%r6)++,%f12 - pfld.d 16384(%r7)++,%f14 - pfld.d 32760(%r7)++,%f16 - pfld.d -32768(%r7)++,%f18 - pfld.d -16384(%r8)++,%f20 - pfld.d -8192(%r9)++,%f22 - pfld.d -4096(%r10)++,%f24 - pfld.d -1024(%r11)++,%f26 - pfld.d -512(%r12)++,%f28 - pfld.d -248(%r13)++,%f30 - pfld.d -8(%r14)++,%f16 - - # Index form, no auto-increment. - pfld.d %r5(%r0),%f0 - pfld.d %r6(%r1),%f30 - pfld.d %r7(%r2),%f28 - pfld.d %r8(%r3),%f26 - pfld.d %r9(%r4),%f24 - pfld.d %r0(%r5),%f22 - pfld.d %r1(%r6),%f20 - pfld.d %r12(%r7),%f18 - pfld.d %r13(%r8),%f16 - pfld.d %r14(%r9),%f14 - pfld.d %r15(%r10),%f12 - pfld.d %r16(%r11),%f10 - pfld.d %r17(%r12),%f8 - pfld.d %r28(%r13),%f6 - pfld.d %r31(%r14),%f4 - - # Index form, with auto-increment. - pfld.d %r5(%r0)++,%f0 - pfld.d %r6(%r1)++,%f2 - pfld.d %r7(%r2)++,%f4 - pfld.d %r8(%r3)++,%f6 - pfld.d %r9(%r4)++,%f8 - pfld.d %r0(%r5)++,%f10 - pfld.d %r1(%r6)++,%f12 - pfld.d %r12(%r7)++,%f14 - pfld.d %r13(%r8)++,%f16 - pfld.d %r14(%r9)++,%f18 - pfld.d %r15(%r10)++,%f20 - pfld.d %r16(%r11)++,%f22 - pfld.d %r17(%r12)++,%f24 - pfld.d %r28(%r13)++,%f26 - pfld.d %r31(%r14)++,%f30 - diff --git a/gas/testsuite/gas/i860/float01.d b/gas/testsuite/gas/i860/float01.d deleted file mode 100644 index f614f1a..0000000 --- a/gas/testsuite/gas/i860/float01.d +++ /dev/null @@ -1,69 +0,0 @@ -#as: -#objdump: -dr -#name: i860 float01 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 30 00 22 48 fadd.ss %f0,%f1,%f2 - 4: b0 10 64 48 fadd.sd %f2,%f3,%f4 - 8: b0 31 0a 49 fadd.dd %f6,%f8,%f10 - c: 31 28 c7 48 fsub.ss %f5,%f6,%f7 - 10: b1 40 2a 49 fsub.sd %f8,%f9,%f10 - 14: b1 61 d0 49 fsub.dd %f12,%f14,%f16 - 18: 20 58 8d 49 fmul.ss %f11,%f12,%f13 - 1c: a0 70 f0 49 fmul.sd %f14,%f15,%f16 - 20: a0 91 96 4a fmul.dd %f18,%f20,%f22 - 24: a1 b1 1a 4b fmlow.dd %f22,%f24,%f26 - 28: 30 74 f0 49 pfadd.ss %f14,%f15,%f16 - 2c: b0 8c 54 4a pfadd.sd %f17,%f18,%f20 - 30: b0 b5 1a 4b pfadd.dd %f22,%f24,%f26 - 34: 31 a4 b6 4a pfsub.ss %f20,%f21,%f22 - 38: b1 bc 1a 4b pfsub.sd %f23,%f24,%f26 - 3c: b1 e5 c2 4b pfsub.dd %f28,%f30,%f2 - 40: 20 dc 9d 4b pfmul.ss %f27,%f28,%f29 - 44: a0 f4 e4 4b pfmul.sd %f30,%f31,%f4 - 48: a0 35 08 48 pfmul.dd %f6,%f0,%f8 - 4c: a4 15 9e 48 pfmul3.dd %f2,%f4,%f30 - 50: 30 02 22 48 d.fadd.ss %f0,%f1,%f2 - 54: 00 00 00 a0 shl %r0,%r0,%r0 - 58: b0 12 64 48 d.fadd.sd %f2,%f3,%f4 - 5c: 00 00 00 a0 shl %r0,%r0,%r0 - 60: b0 33 0a 49 d.fadd.dd %f6,%f8,%f10 - 64: 00 00 00 a0 shl %r0,%r0,%r0 - 68: 31 2a c7 48 d.fsub.ss %f5,%f6,%f7 - 6c: 00 00 00 a0 shl %r0,%r0,%r0 - 70: b1 42 2a 49 d.fsub.sd %f8,%f9,%f10 - 74: 00 00 00 a0 shl %r0,%r0,%r0 - 78: b1 63 d0 49 d.fsub.dd %f12,%f14,%f16 - 7c: 00 00 00 a0 shl %r0,%r0,%r0 - 80: 20 5a 8d 49 d.fmul.ss %f11,%f12,%f13 - 84: 00 00 00 a0 shl %r0,%r0,%r0 - 88: a0 72 f0 49 d.fmul.sd %f14,%f15,%f16 - 8c: 00 00 00 a0 shl %r0,%r0,%r0 - 90: a0 93 96 4a d.fmul.dd %f18,%f20,%f22 - 94: 00 00 00 a0 shl %r0,%r0,%r0 - 98: a1 43 4c 49 d.fmlow.dd %f8,%f10,%f12 - 9c: 00 00 00 a0 shl %r0,%r0,%r0 - a0: 30 76 f0 49 d.pfadd.ss %f14,%f15,%f16 - a4: 00 00 00 a0 shl %r0,%r0,%r0 - a8: b0 8e 54 4a d.pfadd.sd %f17,%f18,%f20 - ac: 00 00 00 a0 shl %r0,%r0,%r0 - b0: b0 b7 1a 4b d.pfadd.dd %f22,%f24,%f26 - b4: 00 00 00 a0 shl %r0,%r0,%r0 - b8: 31 a6 b6 4a d.pfsub.ss %f20,%f21,%f22 - bc: 00 00 00 a0 shl %r0,%r0,%r0 - c0: b1 be 1a 4b d.pfsub.sd %f23,%f24,%f26 - c4: 00 00 00 a0 shl %r0,%r0,%r0 - c8: b1 e7 c2 4b d.pfsub.dd %f28,%f30,%f2 - cc: 00 00 00 a0 shl %r0,%r0,%r0 - d0: 20 de 9d 4b d.pfmul.ss %f27,%f28,%f29 - d4: 00 00 00 a0 shl %r0,%r0,%r0 - d8: a0 f6 e4 4b d.pfmul.sd %f30,%f31,%f4 - dc: 00 00 00 a0 shl %r0,%r0,%r0 - e0: a0 37 08 48 d.pfmul.dd %f6,%f0,%f8 - e4: 00 00 00 a0 shl %r0,%r0,%r0 - e8: a4 17 9e 48 d.pfmul3.dd %f2,%f4,%f30 - ec: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/float01.s b/gas/testsuite/gas/i860/float01.s deleted file mode 100644 index 88e3769..0000000 --- a/gas/testsuite/gas/i860/float01.s +++ /dev/null @@ -1,84 +0,0 @@ -# fadd, fsub, fmul, pfmul3, fmlow - - .text - - # Non-pipelined, without dual bit - fadd.ss %f0,%f1,%f2 - fadd.sd %f2,%f3,%f4 - fadd.dd %f6,%f8,%f10 - - fsub.ss %f5,%f6,%f7 - fsub.sd %f8,%f9,%f10 - fsub.dd %f12,%f14,%f16 - - fmul.ss %f11,%f12,%f13 - fmul.sd %f14,%f15,%f16 - fmul.dd %f18,%f20,%f22 - - fmlow.dd %f22,%f24,%f26 - - # Pipelined, without dual bit - pfadd.ss %f14,%f15,%f16 - pfadd.sd %f17,%f18,%f20 - pfadd.dd %f22,%f24,%f26 - - pfsub.ss %f20,%f21,%f22 - pfsub.sd %f23,%f24,%f26 - pfsub.dd %f28,%f30,%f2 - - pfmul.ss %f27,%f28,%f29 - pfmul.sd %f30,%f31,%f4 - pfmul.dd %f6,%f0,%f8 - - pfmul3.dd %f2,%f4,%f30 - - # Non-pipelined, with dual bit - d.fadd.ss %f0,%f1,%f2 - nop - d.fadd.sd %f2,%f3,%f4 - nop - d.fadd.dd %f6,%f8,%f10 - nop - - d.fsub.ss %f5,%f6,%f7 - nop - d.fsub.sd %f8,%f9,%f10 - nop - d.fsub.dd %f12,%f14,%f16 - nop - - d.fmul.ss %f11,%f12,%f13 - nop - d.fmul.sd %f14,%f15,%f16 - nop - d.fmul.dd %f18,%f20,%f22 - nop - - d.fmlow.dd %f8,%f10,%f12 - nop - - # Pipelined, with dual bit - d.pfadd.ss %f14,%f15,%f16 - nop - d.pfadd.sd %f17,%f18,%f20 - nop - d.pfadd.dd %f22,%f24,%f26 - nop - - d.pfsub.ss %f20,%f21,%f22 - nop - d.pfsub.sd %f23,%f24,%f26 - nop - d.pfsub.dd %f28,%f30,%f2 - nop - - d.pfmul.ss %f27,%f28,%f29 - nop - d.pfmul.sd %f30,%f31,%f4 - nop - d.pfmul.dd %f6,%f0,%f8 - nop - - d.pfmul3.dd %f2,%f4,%f30 - nop - diff --git a/gas/testsuite/gas/i860/float02.d b/gas/testsuite/gas/i860/float02.d deleted file mode 100644 index aae176f..0000000 --- a/gas/testsuite/gas/i860/float02.d +++ /dev/null @@ -1,39 +0,0 @@ -#as: -#objdump: -dr -#name: i860 float02 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 22 00 01 48 frcp.ss %f0,%f1 - 4: a2 00 44 48 frcp.sd %f2,%f4 - 8: a2 01 c8 48 frcp.dd %f6,%f8 - c: 23 00 a6 48 frsqr.ss %f5,%f6 - 10: a3 00 0a 49 frsqr.sd %f8,%f10 - 14: a3 01 8e 49 frsqr.dd %f12,%f14 - 18: 33 08 1f 48 famov.ss %f1,%f31 - 1c: 33 11 1e 48 famov.ds %f2,%f30 - 20: b3 38 10 48 famov.sd %f7,%f16 - 24: b3 c1 0c 48 famov.dd %f24,%f12 - 28: 22 02 01 48 d.frcp.ss %f0,%f1 - 2c: 00 00 00 a0 shl %r0,%r0,%r0 - 30: a2 02 5e 48 d.frcp.sd %f2,%f30 - 34: 00 00 00 a0 shl %r0,%r0,%r0 - 38: a2 03 c8 48 d.frcp.dd %f6,%f8 - 3c: 00 00 00 a0 shl %r0,%r0,%r0 - 40: 23 02 a6 48 d.frsqr.ss %f5,%f6 - 44: 00 00 00 a0 shl %r0,%r0,%r0 - 48: a3 02 18 49 d.frsqr.sd %f8,%f24 - 4c: 00 00 00 a0 shl %r0,%r0,%r0 - 50: a3 03 8e 49 d.frsqr.dd %f12,%f14 - 54: 00 00 00 a0 shl %r0,%r0,%r0 - 58: 33 2a 0d 48 d.famov.ss %f5,%f13 - 5c: 00 00 00 a0 shl %r0,%r0,%r0 - 60: 33 f3 15 48 d.famov.ds %f30,%f21 - 64: 00 00 00 a0 shl %r0,%r0,%r0 - 68: b3 ba 16 48 d.famov.sd %f23,%f22 - 6c: 00 00 00 a0 shl %r0,%r0,%r0 - 70: b3 03 0c 48 d.famov.dd %f0,%f12 - 74: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/float02.s b/gas/testsuite/gas/i860/float02.s deleted file mode 100644 index d4a475d..0000000 --- a/gas/testsuite/gas/i860/float02.s +++ /dev/null @@ -1,42 +0,0 @@ -# frcp, frsqr, famov - - .text - - # Without dual bit - frcp.ss %f0,%f1 - frcp.sd %f2,%f4 - frcp.dd %f6,%f8 - - frsqr.ss %f5,%f6 - frsqr.sd %f8,%f10 - frsqr.dd %f12,%f14 - - famov.ss %f1,%f31 - famov.ds %f2,%f30 - famov.sd %f7,%f16 - famov.dd %f24,%f12 - - # With dual bit - d.frcp.ss %f0,%f1 - nop - d.frcp.sd %f2,%f30 - nop - d.frcp.dd %f6,%f8 - nop - - d.frsqr.ss %f5,%f6 - nop - d.frsqr.sd %f8,%f24 - nop - d.frsqr.dd %f12,%f14 - nop - - d.famov.ss %f5,%f13 - nop - d.famov.ds %f30,%f21 - nop - d.famov.sd %f23,%f22 - nop - d.famov.dd %f0,%f12 - nop - diff --git a/gas/testsuite/gas/i860/float03.d b/gas/testsuite/gas/i860/float03.d deleted file mode 100644 index 10f66c2..0000000 --- a/gas/testsuite/gas/i860/float03.d +++ /dev/null @@ -1,51 +0,0 @@ -#as: -#objdump: -dr -#name: i860 float03 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: b2 10 04 48 fix.sd %f2,%f4 - 4: b2 31 08 48 fix.dd %f6,%f8 - 8: ba 40 0a 48 ftrunc.sd %f8,%f10 - c: ba 61 0e 48 ftrunc.dd %f12,%f14 - 10: b2 f4 0e 48 pfix.sd %f30,%f14 - 14: b2 c5 02 48 pfix.dd %f24,%f2 - 18: ba 44 0a 48 pftrunc.sd %f8,%f10 - 1c: ba 65 0e 48 pftrunc.dd %f12,%f14 - 20: 34 04 22 48 pfgt.ss %f0,%f1,%f2 - 24: 34 35 0a 49 pfgt.dd %f6,%f8,%f10 - 28: b4 2c c7 48 pfle.ss %f5,%f6,%f7 - 2c: b4 65 d0 49 pfle.dd %f12,%f14,%f16 - 30: 35 5c 8d 49 pfeq.ss %f11,%f12,%f13 - 34: 35 95 96 4a pfeq.dd %f18,%f20,%f22 - 38: b2 12 1e 48 d.fix.sd %f2,%f30 - 3c: 00 00 00 a0 shl %r0,%r0,%r0 - 40: b2 33 08 48 d.fix.dd %f6,%f8 - 44: 00 00 00 a0 shl %r0,%r0,%r0 - 48: ba 42 18 48 d.ftrunc.sd %f8,%f24 - 4c: 00 00 00 a0 shl %r0,%r0,%r0 - 50: ba 63 0e 48 d.ftrunc.dd %f12,%f14 - 54: 00 00 00 a0 shl %r0,%r0,%r0 - 58: b2 16 1e 48 d.pfix.sd %f2,%f30 - 5c: 00 00 00 a0 shl %r0,%r0,%r0 - 60: b2 37 08 48 d.pfix.dd %f6,%f8 - 64: 00 00 00 a0 shl %r0,%r0,%r0 - 68: ba 46 18 48 d.pftrunc.sd %f8,%f24 - 6c: 00 00 00 a0 shl %r0,%r0,%r0 - 70: ba 67 0e 48 d.pftrunc.dd %f12,%f14 - 74: 00 00 00 a0 shl %r0,%r0,%r0 - 78: 34 06 22 48 d.pfgt.ss %f0,%f1,%f2 - 7c: 00 00 00 a0 shl %r0,%r0,%r0 - 80: 34 37 0a 49 d.pfgt.dd %f6,%f8,%f10 - 84: 00 00 00 a0 shl %r0,%r0,%r0 - 88: b4 2e c7 48 d.pfle.ss %f5,%f6,%f7 - 8c: 00 00 00 a0 shl %r0,%r0,%r0 - 90: b4 67 d0 49 d.pfle.dd %f12,%f14,%f16 - 94: 00 00 00 a0 shl %r0,%r0,%r0 - 98: 35 5e 8d 49 d.pfeq.ss %f11,%f12,%f13 - 9c: 00 00 00 a0 shl %r0,%r0,%r0 - a0: 35 97 96 4a d.pfeq.dd %f18,%f20,%f22 - a4: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/float03.s b/gas/testsuite/gas/i860/float03.s deleted file mode 100644 index 8fd626c..0000000 --- a/gas/testsuite/gas/i860/float03.s +++ /dev/null @@ -1,64 +0,0 @@ -# fix, ftrunc, pfgt, pfle, pfeq - - .text - - # Non-pipelined, without dual bit - fix.sd %f2,%f4 - fix.dd %f6,%f8 - - ftrunc.sd %f8,%f10 - ftrunc.dd %f12,%f14 - - # Pipelined, without dual bit - pfix.sd %f30,%f14 - pfix.dd %f24,%f2 - - pftrunc.sd %f8,%f10 - pftrunc.dd %f12,%f14 - - pfgt.ss %f0,%f1,%f2 - pfgt.dd %f6,%f8,%f10 - - pfle.ss %f5,%f6,%f7 - pfle.dd %f12,%f14,%f16 - - pfeq.ss %f11,%f12,%f13 - pfeq.dd %f18,%f20,%f22 - - # Non-pipelined, with dual bit - d.fix.sd %f2,%f30 - nop - d.fix.dd %f6,%f8 - nop - - d.ftrunc.sd %f8,%f24 - nop - d.ftrunc.dd %f12,%f14 - nop - - # Pipelined, with dual bit - d.pfix.sd %f2,%f30 - nop - d.pfix.dd %f6,%f8 - nop - - d.pftrunc.sd %f8,%f24 - nop - d.pftrunc.dd %f12,%f14 - nop - - d.pfgt.ss %f0,%f1,%f2 - nop - d.pfgt.dd %f6,%f8,%f10 - nop - - d.pfle.ss %f5,%f6,%f7 - nop - d.pfle.dd %f12,%f14,%f16 - nop - - d.pfeq.ss %f11,%f12,%f13 - nop - d.pfeq.dd %f18,%f20,%f22 - nop - diff --git a/gas/testsuite/gas/i860/float04.d b/gas/testsuite/gas/i860/float04.d deleted file mode 100644 index 8640682..0000000 --- a/gas/testsuite/gas/i860/float04.d +++ /dev/null @@ -1,39 +0,0 @@ -#as: -#objdump: -dr -#name: i860 float04 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 40 08 03 48 fxfr %f1,%fp - 4: 40 40 1e 48 fxfr %f8,%r30 - 8: 40 f8 12 48 fxfr %f31,%r18 - c: 00 48 1f 08 ixfr %r9,%f31 - 10: 00 b8 10 08 ixfr %r23,%f16 - 14: 00 00 00 08 ixfr %r0,%f0 - 18: 49 00 22 48 fiadd.ss %f0,%f1,%f2 - 1c: c9 31 0a 49 fiadd.dd %f6,%f8,%f10 - 20: 4d 28 c7 48 fisub.ss %f5,%f6,%f7 - 24: cd 61 d0 49 fisub.dd %f12,%f14,%f16 - 28: 49 74 f0 49 pfiadd.ss %f14,%f15,%f16 - 2c: c9 b5 1a 4b pfiadd.dd %f22,%f24,%f26 - 30: 4d a4 b6 4a pfisub.ss %f20,%f21,%f22 - 34: cd e5 c2 4b pfisub.dd %f28,%f30,%f2 - 38: 49 02 22 48 d.fiadd.ss %f0,%f1,%f2 - 3c: 00 00 00 a0 shl %r0,%r0,%r0 - 40: c9 33 0a 49 d.fiadd.dd %f6,%f8,%f10 - 44: 00 00 00 a0 shl %r0,%r0,%r0 - 48: 4d 2a c7 48 d.fisub.ss %f5,%f6,%f7 - 4c: 00 00 00 a0 shl %r0,%r0,%r0 - 50: cd 63 d0 49 d.fisub.dd %f12,%f14,%f16 - 54: 00 00 00 a0 shl %r0,%r0,%r0 - 58: 49 76 f0 49 d.pfiadd.ss %f14,%f15,%f16 - 5c: 00 00 00 a0 shl %r0,%r0,%r0 - 60: c9 b7 1a 4b d.pfiadd.dd %f22,%f24,%f26 - 64: 00 00 00 a0 shl %r0,%r0,%r0 - 68: 4d a6 b6 4a d.pfisub.ss %f20,%f21,%f22 - 6c: 00 00 00 a0 shl %r0,%r0,%r0 - 70: cd e7 c2 4b d.pfisub.dd %f28,%f30,%f2 - 74: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/float04.s b/gas/testsuite/gas/i860/float04.s deleted file mode 100644 index 5a4aae5..0000000 --- a/gas/testsuite/gas/i860/float04.s +++ /dev/null @@ -1,49 +0,0 @@ -# fxfr, ixfr, fiadd, fisub - - .text - - # ixfr, fxfr - fxfr %f1,%r3 - fxfr %f8,%r30 - fxfr %f31,%r18 - - ixfr %r9,%f31 - ixfr %r23,%f16 - ixfr %r0,%f0 - - # Non-pipelined, without dual bit - fiadd.ss %f0,%f1,%f2 - fiadd.dd %f6,%f8,%f10 - - fisub.ss %f5,%f6,%f7 - fisub.dd %f12,%f14,%f16 - - # Pipelined, without dual bit - pfiadd.ss %f14,%f15,%f16 - pfiadd.dd %f22,%f24,%f26 - - pfisub.ss %f20,%f21,%f22 - pfisub.dd %f28,%f30,%f2 - - # Non-pipelined, with dual bit - d.fiadd.ss %f0,%f1,%f2 - nop - d.fiadd.dd %f6,%f8,%f10 - nop - - d.fisub.ss %f5,%f6,%f7 - nop - d.fisub.dd %f12,%f14,%f16 - nop - - # Pipelined, with dual bit - d.pfiadd.ss %f14,%f15,%f16 - nop - d.pfiadd.dd %f22,%f24,%f26 - nop - - d.pfisub.ss %f20,%f21,%f22 - nop - d.pfisub.dd %f28,%f30,%f2 - nop - diff --git a/gas/testsuite/gas/i860/form.d b/gas/testsuite/gas/i860/form.d deleted file mode 100644 index d713d8c..0000000 --- a/gas/testsuite/gas/i860/form.d +++ /dev/null @@ -1,63 +0,0 @@ -#as: -#objdump: -dr -#name: i860 form/pform - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: da 05 02 48 pform %f0,%f2 - 4: da 15 04 48 pform %f2,%f4 - 8: da 25 06 48 pform %f4,%f6 - c: da 45 0a 48 pform %f8,%f10 - 10: da 65 0e 48 pform %f12,%f14 - 14: da 85 12 48 pform %f16,%f18 - 18: da a5 16 48 pform %f20,%f22 - 1c: da c5 1a 48 pform %f24,%f26 - 20: da e5 1e 48 pform %f28,%f30 - 24: da 01 02 48 form %f0,%f2 - 28: da 11 04 48 form %f2,%f4 - 2c: da 21 06 48 form %f4,%f6 - 30: da 41 0a 48 form %f8,%f10 - 34: da 61 0e 48 form %f12,%f14 - 38: da 81 12 48 form %f16,%f18 - 3c: da a1 16 48 form %f20,%f22 - 40: da c1 1a 48 form %f24,%f26 - 44: da e1 1e 48 form %f28,%f30 - 48: da 07 02 48 d.pform %f0,%f2 - 4c: 00 00 00 a0 shl %r0,%r0,%r0 - 50: da 17 04 48 d.pform %f2,%f4 - 54: 00 00 00 a0 shl %r0,%r0,%r0 - 58: da 27 06 48 d.pform %f4,%f6 - 5c: 00 00 00 a0 shl %r0,%r0,%r0 - 60: da 47 0a 48 d.pform %f8,%f10 - 64: 00 00 00 a0 shl %r0,%r0,%r0 - 68: da 67 0e 48 d.pform %f12,%f14 - 6c: 00 00 00 a0 shl %r0,%r0,%r0 - 70: da 87 12 48 d.pform %f16,%f18 - 74: 00 00 00 a0 shl %r0,%r0,%r0 - 78: da a7 16 48 d.pform %f20,%f22 - 7c: 00 00 00 a0 shl %r0,%r0,%r0 - 80: da c7 1a 48 d.pform %f24,%f26 - 84: 00 00 00 a0 shl %r0,%r0,%r0 - 88: da e7 1e 48 d.pform %f28,%f30 - 8c: 00 00 00 a0 shl %r0,%r0,%r0 - 90: da 03 02 48 d.form %f0,%f2 - 94: 00 00 00 a0 shl %r0,%r0,%r0 - 98: da 13 04 48 d.form %f2,%f4 - 9c: 00 00 00 a0 shl %r0,%r0,%r0 - a0: da 23 06 48 d.form %f4,%f6 - a4: 00 00 00 a0 shl %r0,%r0,%r0 - a8: da 43 0a 48 d.form %f8,%f10 - ac: 00 00 00 a0 shl %r0,%r0,%r0 - b0: da 63 0e 48 d.form %f12,%f14 - b4: 00 00 00 a0 shl %r0,%r0,%r0 - b8: da 83 12 48 d.form %f16,%f18 - bc: 00 00 00 a0 shl %r0,%r0,%r0 - c0: da a3 16 48 d.form %f20,%f22 - c4: 00 00 00 a0 shl %r0,%r0,%r0 - c8: da c3 1a 48 d.form %f24,%f26 - cc: 00 00 00 a0 shl %r0,%r0,%r0 - d0: da e3 1e 48 d.form %f28,%f30 - d4: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/form.s b/gas/testsuite/gas/i860/form.s deleted file mode 100644 index e73dde6..0000000 --- a/gas/testsuite/gas/i860/form.s +++ /dev/null @@ -1,66 +0,0 @@ -# form and pform - - .text - - # pform, no dual bit - pform %f0,%f2 - pform %f2,%f4 - pform %f4,%f6 - pform %f8,%f10 - pform %f12,%f14 - pform %f16,%f18 - pform %f20,%f22 - pform %f24,%f26 - pform %f28,%f30 - - # form, no dual bit - form %f0,%f2 - form %f2,%f4 - form %f4,%f6 - form %f8,%f10 - form %f12,%f14 - form %f16,%f18 - form %f20,%f22 - form %f24,%f26 - form %f28,%f30 - - # pform, with dual bit - d.pform %f0,%f2 - nop - d.pform %f2,%f4 - nop - d.pform %f4,%f6 - nop - d.pform %f8,%f10 - nop - d.pform %f12,%f14 - nop - d.pform %f16,%f18 - nop - d.pform %f20,%f22 - nop - d.pform %f24,%f26 - nop - d.pform %f28,%f30 - nop - - # form, with dual bit - d.form %f0,%f2 - nop - d.form %f2,%f4 - nop - d.form %f4,%f6 - nop - d.form %f8,%f10 - nop - d.form %f12,%f14 - nop - d.form %f16,%f18 - nop - d.form %f20,%f22 - nop - d.form %f24,%f26 - nop - d.form %f28,%f30 - nop - diff --git a/gas/testsuite/gas/i860/i860.exp b/gas/testsuite/gas/i860/i860.exp deleted file mode 100644 index bac5758..0000000 --- a/gas/testsuite/gas/i860/i860.exp +++ /dev/null @@ -1,61 +0,0 @@ -# Copyright (C) 2012-2018 Free Software Foundation, Inc. - -# 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. - -# i860 assembler testsuite. - -if [istarget i860-*-*] { - run_dump_test "bitwise" - run_dump_test "branch" - run_dump_test "bte" - run_dump_test "dir-align01" - run_dump_test "dir-intel01" - run_dump_test "dir-intel02" - run_list_test "dir-intel03-err" "" - run_dump_test "dual01" - run_list_test "dual02-err" "" - run_dump_test "dual03" - run_dump_test "fldst01" - run_dump_test "fldst02" - run_dump_test "fldst03" - run_dump_test "fldst04" - run_dump_test "fldst05" - run_dump_test "fldst06" - run_dump_test "fldst07" - run_dump_test "fldst08" - run_dump_test "float01" - run_dump_test "float02" - run_dump_test "float03" - run_dump_test "float04" - run_dump_test "form" - run_dump_test "iarith" - run_dump_test "ldst01" - run_dump_test "ldst02" - run_dump_test "ldst03" - run_dump_test "ldst04" - run_dump_test "ldst05" - run_dump_test "ldst06" - run_dump_test "pfam" - run_dump_test "pfmam" - run_dump_test "pfmsm" - run_dump_test "pfsm" - run_dump_test "pseudo-ops01" - run_dump_test "regress01" - run_dump_test "shift" - run_dump_test "simd" - run_dump_test "system" - run_dump_test "xp" -} - diff --git a/gas/testsuite/gas/i860/iarith.d b/gas/testsuite/gas/i860/iarith.d deleted file mode 100644 index 9b2a509..0000000 --- a/gas/testsuite/gas/i860/iarith.d +++ /dev/null @@ -1,97 +0,0 @@ -#as: -#objdump: -dr -#name: i860 iarith - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 22 80 addu %r0,%r1,%sp - 4: 00 18 85 80 addu %fp,%r4,%r5 - 8: 00 30 e8 80 addu %r6,%r7,%r8 - c: 00 48 4b 81 addu %r9,%r10,%r11 - 10: 00 f8 ae 81 addu %r31,%r13,%r14 - 14: 00 78 11 82 addu %r15,%r16,%r17 - 18: 00 90 74 82 addu %r18,%r19,%r20 - 1c: 00 a8 d7 82 addu %r21,%r22,%r23 - 20: 00 c0 3f 83 addu %r24,%r25,%r31 - 24: 00 d8 9d 83 addu %r27,%r28,%r29 - 28: 00 f0 e0 83 addu %r30,%r31,%r0 - 2c: 00 00 22 90 adds %r0,%r1,%sp - 30: 00 18 85 90 adds %fp,%r4,%r5 - 34: 00 30 e8 90 adds %r6,%r7,%r8 - 38: 00 48 4b 91 adds %r9,%r10,%r11 - 3c: 00 f8 ae 91 adds %r31,%r13,%r14 - 40: 00 78 11 92 adds %r15,%r16,%r17 - 44: 00 90 74 92 adds %r18,%r19,%r20 - 48: 00 a8 d7 92 adds %r21,%r22,%r23 - 4c: 00 c0 3f 93 adds %r24,%r25,%r31 - 50: 00 d8 9d 93 adds %r27,%r28,%r29 - 54: 00 f0 e0 93 adds %r30,%r31,%r0 - 58: 00 00 22 88 subu %r0,%r1,%sp - 5c: 00 18 85 88 subu %fp,%r4,%r5 - 60: 00 30 e8 88 subu %r6,%r7,%r8 - 64: 00 48 4b 89 subu %r9,%r10,%r11 - 68: 00 f8 ae 89 subu %r31,%r13,%r14 - 6c: 00 78 11 8a subu %r15,%r16,%r17 - 70: 00 90 74 8a subu %r18,%r19,%r20 - 74: 00 a8 d7 8a subu %r21,%r22,%r23 - 78: 00 c0 3f 8b subu %r24,%r25,%r31 - 7c: 00 d8 9d 8b subu %r27,%r28,%r29 - 80: 00 f0 e0 8b subu %r30,%r31,%r0 - 84: 00 00 22 98 subs %r0,%r1,%sp - 88: 00 18 85 98 subs %fp,%r4,%r5 - 8c: 00 30 e8 98 subs %r6,%r7,%r8 - 90: 00 48 4b 99 subs %r9,%r10,%r11 - 94: 00 f8 ae 99 subs %r31,%r13,%r14 - 98: 00 78 11 9a subs %r15,%r16,%r17 - 9c: 00 90 74 9a subs %r18,%r19,%r20 - a0: 00 a8 d7 9a subs %r21,%r22,%r23 - a4: 00 c0 3f 9b subs %r24,%r25,%r31 - a8: 00 d8 9d 9b subs %r27,%r28,%r29 - ac: 00 f0 e0 9b subs %r30,%r31,%r0 - b0: 00 00 22 84 addu 0,%r1,%sp - b4: 00 20 85 84 addu 8192,%r4,%r5 - b8: f5 13 e8 84 addu 5109,%r7,%r8 - bc: ff 7f 4b 85 addu 32767,%r10,%r11 - c0: 00 80 ae 85 addu -32768,%r13,%r14 - c4: 00 e0 11 86 addu -8192,%r16,%r17 - c8: ff ff 74 86 addu -1,%r19,%r20 - cc: cd ab d7 86 addu -21555,%r22,%r23 - d0: 34 12 3a 87 addu 4660,%r25,%r26 - d4: 00 00 9d 87 addu 0,%r28,%r29 - d8: 03 00 e0 87 addu 3,%r31,%r0 - dc: 00 00 22 94 adds 0,%r1,%sp - e0: 00 20 85 94 adds 8192,%r4,%r5 - e4: f5 13 e8 94 adds 5109,%r7,%r8 - e8: ff 7f 4b 95 adds 32767,%r10,%r11 - ec: 00 80 ae 95 adds -32768,%r13,%r14 - f0: 00 e0 11 96 adds -8192,%r16,%r17 - f4: ff ff 74 96 adds -1,%r19,%r20 - f8: cd ab d7 96 adds -21555,%r22,%r23 - fc: 34 12 3a 97 adds 4660,%r25,%r26 - 100: 00 00 9d 97 adds 0,%r28,%r29 - 104: 03 00 e0 97 adds 3,%r31,%r0 - 108: 01 00 22 8c subu 1,%r1,%sp - 10c: 01 20 85 8c subu 8193,%r4,%r5 - 110: f6 13 e8 8c subu 5110,%r7,%r8 - 114: ff 7f 4b 8d subu 32767,%r10,%r11 - 118: 00 80 ae 8d subu -32768,%r13,%r14 - 11c: 00 e0 11 8e subu -8192,%r16,%r17 - 120: ff ff 74 8e subu -1,%r19,%r20 - 124: cd ab d7 8e subu -21555,%r22,%r23 - 128: 34 12 3a 8f subu 4660,%r25,%r26 - 12c: 00 00 9d 8f subu 0,%r28,%r29 - 130: 03 00 e0 8f subu 3,%r31,%r0 - 134: 01 00 22 9c subs 1,%r1,%sp - 138: 01 20 85 9c subs 8193,%r4,%r5 - 13c: f6 13 e8 9c subs 5110,%r7,%r8 - 140: ff 7f 4b 9d subs 32767,%r10,%r11 - 144: 00 80 ae 9d subs -32768,%r13,%r14 - 148: 00 e0 11 9e subs -8192,%r16,%r17 - 14c: ff ff 74 9e subs -1,%r19,%r20 - 150: cd ab d7 9e subs -21555,%r22,%r23 - 154: 34 12 3a 9f subs 4660,%r25,%r26 - 158: 00 00 9d 9f subs 0,%r28,%r29 - 15c: 03 00 e0 9f subs 3,%r31,%r0 diff --git a/gas/testsuite/gas/i860/iarith.s b/gas/testsuite/gas/i860/iarith.s deleted file mode 100644 index 98a360e..0000000 --- a/gas/testsuite/gas/i860/iarith.s +++ /dev/null @@ -1,102 +0,0 @@ -# addu, adds, subu, subs - - .text - - # Register forms - addu %r0,%r1,%r2 - addu %r3,%r4,%r5 - addu %r6,%r7,%r8 - addu %r9,%r10,%r11 - addu %r31,%r13,%r14 - addu %r15,%r16,%r17 - addu %r18,%r19,%r20 - addu %r21,%r22,%r23 - addu %r24,%r25,%r31 - addu %r27,%r28,%r29 - addu %r30,%r31,%r0 - - adds %r0,%r1,%r2 - adds %r3,%r4,%r5 - adds %r6,%r7,%r8 - adds %r9,%r10,%r11 - adds %r31,%r13,%r14 - adds %r15,%r16,%r17 - adds %r18,%r19,%r20 - adds %r21,%r22,%r23 - adds %r24,%r25,%r31 - adds %r27,%r28,%r29 - adds %r30,%r31,%r0 - - subu %r0,%r1,%r2 - subu %r3,%r4,%r5 - subu %r6,%r7,%r8 - subu %r9,%r10,%r11 - subu %r31,%r13,%r14 - subu %r15,%r16,%r17 - subu %r18,%r19,%r20 - subu %r21,%r22,%r23 - subu %r24,%r25,%r31 - subu %r27,%r28,%r29 - subu %r30,%r31,%r0 - - subs %r0,%r1,%r2 - subs %r3,%r4,%r5 - subs %r6,%r7,%r8 - subs %r9,%r10,%r11 - subs %r31,%r13,%r14 - subs %r15,%r16,%r17 - subs %r18,%r19,%r20 - subs %r21,%r22,%r23 - subs %r24,%r25,%r31 - subs %r27,%r28,%r29 - subs %r30,%r31,%r0 - - # Immediate forms (all) - addu 0,%r1,%r2 - addu 8192,%r4,%r5 - addu 5109,%r7,%r8 - addu 32767,%r10,%r11 - addu -32768,%r13,%r14 - addu -8192,%r16,%r17 - addu -1,%r19,%r20 - addu -21555,%r22,%r23 - addu 0x1234,%r25,%r26 - addu 0x0,%r28,%r29 - addu 0x3,%r31,%r0 - - adds 0,%r1,%r2 - adds 8192,%r4,%r5 - adds 5109,%r7,%r8 - adds 32767,%r10,%r11 - adds -32768,%r13,%r14 - adds -8192,%r16,%r17 - adds -1,%r19,%r20 - adds -21555,%r22,%r23 - adds 0x1234,%r25,%r26 - adds 0x0,%r28,%r29 - adds 0x3,%r31,%r0 - - subu 1,%r1,%r2 - subu 8193,%r4,%r5 - subu 5110,%r7,%r8 - subu 32767,%r10,%r11 - subu -32768,%r13,%r14 - subu -8192,%r16,%r17 - subu -1,%r19,%r20 - subu -21555,%r22,%r23 - subu 0x1234,%r25,%r26 - subu 0x0,%r28,%r29 - subu 0x3,%r31,%r0 - - subs 1,%r1,%r2 - subs 8193,%r4,%r5 - subs 5110,%r7,%r8 - subs 32767,%r10,%r11 - subs -32768,%r13,%r14 - subs -8192,%r16,%r17 - subs -1,%r19,%r20 - subs -21555,%r22,%r23 - subs 0x1234,%r25,%r26 - subs 0x0,%r28,%r29 - subs 0x3,%r31,%r0 - diff --git a/gas/testsuite/gas/i860/ldst01.d b/gas/testsuite/gas/i860/ldst01.d deleted file mode 100644 index 6c1330b..0000000 --- a/gas/testsuite/gas/i860/ldst01.d +++ /dev/null @@ -1,39 +0,0 @@ -#as: -#objdump: -dr -#name: i860 ldst01 (ld.l) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 01 00 00 14 ld.l 0\(%r0\),%r0 - 4: 7d 00 3f 14 ld.l 124\(%r1\),%r31 - 8: 01 01 5e 14 ld.l 256\(%sp\),%r30 - c: 01 02 7d 14 ld.l 512\(%fp\),%r29 - 10: 01 04 9c 14 ld.l 1024\(%r4\),%r28 - 14: 01 10 bb 14 ld.l 4096\(%r5\),%r27 - 18: 01 20 da 14 ld.l 8192\(%r6\),%r26 - 1c: 01 40 f9 14 ld.l 16384\(%r7\),%r25 - 20: 01 c0 18 15 ld.l -16384\(%r8\),%r24 - 24: 01 e0 37 15 ld.l -8192\(%r9\),%r23 - 28: 01 f0 56 15 ld.l -4096\(%r10\),%r22 - 2c: 01 fc 75 15 ld.l -1024\(%r11\),%r21 - 30: 05 fe 94 15 ld.l -508\(%r12\),%r20 - 34: 09 ff b3 15 ld.l -248\(%r13\),%r19 - 38: fd ff d2 15 ld.l -4\(%r14\),%r18 - 3c: 01 28 00 10 ld.l %r5\(%r0\),%r0 - 40: 01 30 3f 10 ld.l %r6\(%r1\),%r31 - 44: 01 38 5e 10 ld.l %r7\(%sp\),%r30 - 48: 01 40 7d 10 ld.l %r8\(%fp\),%r29 - 4c: 01 48 9c 10 ld.l %r9\(%r4\),%r28 - 50: 01 00 bb 10 ld.l %r0\(%r5\),%r27 - 54: 01 08 da 10 ld.l %r1\(%r6\),%r26 - 58: 01 60 f9 10 ld.l %r12\(%r7\),%r25 - 5c: 01 68 18 11 ld.l %r13\(%r8\),%r24 - 60: 01 70 37 11 ld.l %r14\(%r9\),%r23 - 64: 01 78 56 11 ld.l %r15\(%r10\),%r22 - 68: 01 80 75 11 ld.l %r16\(%r11\),%r21 - 6c: 01 88 94 11 ld.l %r17\(%r12\),%r20 - 70: 01 e0 b3 11 ld.l %r28\(%r13\),%r19 - 74: 01 f8 d2 11 ld.l %r31\(%r14\),%r18 diff --git a/gas/testsuite/gas/i860/ldst01.s b/gas/testsuite/gas/i860/ldst01.s deleted file mode 100644 index 498f346..0000000 --- a/gas/testsuite/gas/i860/ldst01.s +++ /dev/null @@ -1,35 +0,0 @@ -# ld.l (no relocations here) - .text - - ld.l 0(%r0),%r0 - ld.l 124(%r1),%r31 - ld.l 256(%r2),%r30 - ld.l 512(%r3),%r29 - ld.l 1024(%r4),%r28 - ld.l 4096(%r5),%r27 - ld.l 8192(%r6),%r26 - ld.l 16384(%r7),%r25 - ld.l -16384(%r8),%r24 - ld.l -8192(%r9),%r23 - ld.l -4096(%r10),%r22 - ld.l -1024(%r11),%r21 - ld.l -508(%r12),%r20 - ld.l -248(%r13),%r19 - ld.l -4(%r14),%r18 - - ld.l %r5(%r0),%r0 - ld.l %r6(%r1),%r31 - ld.l %r7(%r2),%r30 - ld.l %r8(%r3),%r29 - ld.l %r9(%r4),%r28 - ld.l %r0(%r5),%r27 - ld.l %r1(%r6),%r26 - ld.l %r12(%r7),%r25 - ld.l %r13(%r8),%r24 - ld.l %r14(%r9),%r23 - ld.l %r15(%r10),%r22 - ld.l %r16(%r11),%r21 - ld.l %r17(%r12),%r20 - ld.l %r28(%r13),%r19 - ld.l %r31(%r14),%r18 - diff --git a/gas/testsuite/gas/i860/ldst02.d b/gas/testsuite/gas/i860/ldst02.d deleted file mode 100644 index ec03ae5..0000000 --- a/gas/testsuite/gas/i860/ldst02.d +++ /dev/null @@ -1,39 +0,0 @@ -#as: -#objdump: -dr -#name: i860 ldst02 (ld.s) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 00 14 ld.s 0\(%r0\),%r0 - 4: 7a 00 3f 14 ld.s 122\(%r1\),%r31 - 8: 02 01 5e 14 ld.s 258\(%sp\),%r30 - c: 00 02 7d 14 ld.s 512\(%fp\),%r29 - 10: 04 04 9c 14 ld.s 1028\(%r4\),%r28 - 14: fa 0f bb 14 ld.s 4090\(%r5\),%r27 - 18: fe 1f da 14 ld.s 8190\(%r6\),%r26 - 1c: 00 40 f9 14 ld.s 16384\(%r7\),%r25 - 20: 00 c0 18 15 ld.s -16384\(%r8\),%r24 - 24: 00 e0 37 15 ld.s -8192\(%r9\),%r23 - 28: 00 f0 56 15 ld.s -4096\(%r10\),%r22 - 2c: 00 fc 75 15 ld.s -1024\(%r11\),%r21 - 30: 04 fe 94 15 ld.s -508\(%r12\),%r20 - 34: 0e ff b3 15 ld.s -242\(%r13\),%r19 - 38: fe ff d2 15 ld.s -2\(%r14\),%r18 - 3c: 00 28 00 10 ld.s %r5\(%r0\),%r0 - 40: 00 30 3f 10 ld.s %r6\(%r1\),%r31 - 44: 00 38 5e 10 ld.s %r7\(%sp\),%r30 - 48: 00 40 7d 10 ld.s %r8\(%fp\),%r29 - 4c: 00 48 9c 10 ld.s %r9\(%r4\),%r28 - 50: 00 00 bb 10 ld.s %r0\(%r5\),%r27 - 54: 00 08 da 10 ld.s %r1\(%r6\),%r26 - 58: 00 60 f9 10 ld.s %r12\(%r7\),%r25 - 5c: 00 68 18 11 ld.s %r13\(%r8\),%r24 - 60: 00 70 37 11 ld.s %r14\(%r9\),%r23 - 64: 00 78 56 11 ld.s %r15\(%r10\),%r22 - 68: 00 80 75 11 ld.s %r16\(%r11\),%r21 - 6c: 00 88 94 11 ld.s %r17\(%r12\),%r20 - 70: 00 e0 b3 11 ld.s %r28\(%r13\),%r19 - 74: 00 f8 d2 11 ld.s %r31\(%r14\),%r18 diff --git a/gas/testsuite/gas/i860/ldst02.s b/gas/testsuite/gas/i860/ldst02.s deleted file mode 100644 index 52c0e1a..0000000 --- a/gas/testsuite/gas/i860/ldst02.s +++ /dev/null @@ -1,35 +0,0 @@ -# ld.s (no relocations here) - .text - - ld.s 0(%r0),%r0 - ld.s 122(%r1),%r31 - ld.s 258(%r2),%r30 - ld.s 512(%r3),%r29 - ld.s 1028(%r4),%r28 - ld.s 4090(%r5),%r27 - ld.s 8190(%r6),%r26 - ld.s 16384(%r7),%r25 - ld.s -16384(%r8),%r24 - ld.s -8192(%r9),%r23 - ld.s -4096(%r10),%r22 - ld.s -1024(%r11),%r21 - ld.s -508(%r12),%r20 - ld.s -242(%r13),%r19 - ld.s -2(%r14),%r18 - - ld.s %r5(%r0),%r0 - ld.s %r6(%r1),%r31 - ld.s %r7(%r2),%r30 - ld.s %r8(%r3),%r29 - ld.s %r9(%r4),%r28 - ld.s %r0(%r5),%r27 - ld.s %r1(%r6),%r26 - ld.s %r12(%r7),%r25 - ld.s %r13(%r8),%r24 - ld.s %r14(%r9),%r23 - ld.s %r15(%r10),%r22 - ld.s %r16(%r11),%r21 - ld.s %r17(%r12),%r20 - ld.s %r28(%r13),%r19 - ld.s %r31(%r14),%r18 - diff --git a/gas/testsuite/gas/i860/ldst03.d b/gas/testsuite/gas/i860/ldst03.d deleted file mode 100644 index f3f0008..0000000 --- a/gas/testsuite/gas/i860/ldst03.d +++ /dev/null @@ -1,43 +0,0 @@ -#as: -#objdump: -dr -#name: i860 ldst03 (ld.b) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 00 04 ld.b 0\(%r0\),%r0 - 4: 01 00 3f 04 ld.b 1\(%r1\),%r31 - 8: 02 00 5e 04 ld.b 2\(%sp\),%r30 - c: 01 02 7d 04 ld.b 513\(%fp\),%r29 - 10: 04 04 9c 04 ld.b 1028\(%r4\),%r28 - 14: fa 0f bb 04 ld.b 4090\(%r5\),%r27 - 18: fe 1f da 04 ld.b 8190\(%r6\),%r26 - 1c: 01 40 f9 04 ld.b 16385\(%r7\),%r25 - 20: 07 7d f9 04 ld.b 32007\(%r7\),%r25 - 24: ff 7f f9 04 ld.b 32767\(%r7\),%r25 - 28: 00 80 f9 04 ld.b -32768\(%r7\),%r25 - 2c: 01 80 f9 04 ld.b -32767\(%r7\),%r25 - 30: 01 c0 18 05 ld.b -16383\(%r8\),%r24 - 34: 5b e0 37 05 ld.b -8101\(%r9\),%r23 - 38: 05 f0 56 05 ld.b -4091\(%r10\),%r22 - 3c: 01 fc 75 05 ld.b -1023\(%r11\),%r21 - 40: 03 fe 94 05 ld.b -509\(%r12\),%r20 - 44: e9 ff b3 05 ld.b -23\(%r13\),%r19 - 48: ff ff d2 05 ld.b -1\(%r14\),%r18 - 4c: 00 28 00 00 ld.b %r5\(%r0\),%r0 - 50: 00 30 3f 00 ld.b %r6\(%r1\),%r31 - 54: 00 38 5e 00 ld.b %r7\(%sp\),%r30 - 58: 00 40 7d 00 ld.b %r8\(%fp\),%r29 - 5c: 00 48 9c 00 ld.b %r9\(%r4\),%r28 - 60: 00 00 bb 00 ld.b %r0\(%r5\),%r27 - 64: 00 08 da 00 ld.b %r1\(%r6\),%r26 - 68: 00 60 f9 00 ld.b %r12\(%r7\),%r25 - 6c: 00 68 18 01 ld.b %r13\(%r8\),%r24 - 70: 00 70 37 01 ld.b %r14\(%r9\),%r23 - 74: 00 78 56 01 ld.b %r15\(%r10\),%r22 - 78: 00 80 75 01 ld.b %r16\(%r11\),%r21 - 7c: 00 88 94 01 ld.b %r17\(%r12\),%r20 - 80: 00 e0 b3 01 ld.b %r28\(%r13\),%r19 - 84: 00 f8 d2 01 ld.b %r31\(%r14\),%r18 diff --git a/gas/testsuite/gas/i860/ldst03.s b/gas/testsuite/gas/i860/ldst03.s deleted file mode 100644 index 055a3b8..0000000 --- a/gas/testsuite/gas/i860/ldst03.s +++ /dev/null @@ -1,39 +0,0 @@ -# ld.b (no relocations here) - .text - - ld.b 0(%r0),%r0 - ld.b 1(%r1),%r31 - ld.b 2(%r2),%r30 - ld.b 513(%r3),%r29 - ld.b 1028(%r4),%r28 - ld.b 4090(%r5),%r27 - ld.b 8190(%r6),%r26 - ld.b 16385(%r7),%r25 - ld.b 32007(%r7),%r25 - ld.b 32767(%r7),%r25 - ld.b -32768(%r7),%r25 - ld.b -32767(%r7),%r25 - ld.b -16383(%r8),%r24 - ld.b -8101(%r9),%r23 - ld.b -4091(%r10),%r22 - ld.b -1023(%r11),%r21 - ld.b -509(%r12),%r20 - ld.b -23(%r13),%r19 - ld.b -1(%r14),%r18 - - ld.b %r5(%r0),%r0 - ld.b %r6(%r1),%r31 - ld.b %r7(%r2),%r30 - ld.b %r8(%r3),%r29 - ld.b %r9(%r4),%r28 - ld.b %r0(%r5),%r27 - ld.b %r1(%r6),%r26 - ld.b %r12(%r7),%r25 - ld.b %r13(%r8),%r24 - ld.b %r14(%r9),%r23 - ld.b %r15(%r10),%r22 - ld.b %r16(%r11),%r21 - ld.b %r17(%r12),%r20 - ld.b %r28(%r13),%r19 - ld.b %r31(%r14),%r18 - diff --git a/gas/testsuite/gas/i860/ldst04.d b/gas/testsuite/gas/i860/ldst04.d deleted file mode 100644 index a9130ac..0000000 --- a/gas/testsuite/gas/i860/ldst04.d +++ /dev/null @@ -1,24 +0,0 @@ -#as: -#objdump: -dr -#name: i860 ldst04 (st.l) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 01 00 00 1c st.l %r0,0\(%r0\) - 4: 7d f8 20 1c st.l %r31,124\(%r1\) - 8: 01 f1 40 1c st.l %r30,256\(%sp\) - c: 01 ea 60 1c st.l %r29,512\(%fp\) - 10: 01 e4 80 1c st.l %r28,1024\(%r4\) - 14: 01 d8 a2 1c st.l %r27,4096\(%r5\) - 18: 01 d0 c4 1c st.l %r26,8192\(%r6\) - 1c: 01 c8 e8 1c st.l %r25,16384\(%r7\) - 20: 01 c0 18 1d st.l %r24,-16384\(%r8\) - 24: 01 b8 3c 1d st.l %r23,-8192\(%r9\) - 28: 01 b0 5e 1d st.l %r22,-4096\(%r10\) - 2c: 01 ac 7f 1d st.l %r21,-1024\(%r11\) - 30: 05 a6 9f 1d st.l %r20,-508\(%r12\) - 34: 09 9f bf 1d st.l %r19,-248\(%r13\) - 38: fd 97 df 1d st.l %r18,-4\(%r14\) diff --git a/gas/testsuite/gas/i860/ldst04.s b/gas/testsuite/gas/i860/ldst04.s deleted file mode 100644 index 8e22b6f..0000000 --- a/gas/testsuite/gas/i860/ldst04.s +++ /dev/null @@ -1,19 +0,0 @@ -# st.l (no relocations here) - .text - - st.l %r0,0(%r0) - st.l %r31,124(%r1) - st.l %r30,256(%r2) - st.l %r29,512(%r3) - st.l %r28,1024(%r4) - st.l %r27,4096(%r5) - st.l %r26,8192(%r6) - st.l %r25,16384(%r7) - st.l %r24,-16384(%r8) - st.l %r23,-8192(%r9) - st.l %r22,-4096(%r10) - st.l %r21,-1024(%r11) - st.l %r20,-508(%r12) - st.l %r19,-248(%r13) - st.l %r18,-4(%r14) - diff --git a/gas/testsuite/gas/i860/ldst05.d b/gas/testsuite/gas/i860/ldst05.d deleted file mode 100644 index e57f822..0000000 --- a/gas/testsuite/gas/i860/ldst05.d +++ /dev/null @@ -1,24 +0,0 @@ -#as: -#objdump: -dr -#name: i860 ldst05 (st.s) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 00 1c st.s %r0,0\(%r0\) - 4: 7a f8 20 1c st.s %r31,122\(%r1\) - 8: 02 f1 40 1c st.s %r30,258\(%sp\) - c: 00 ea 60 1c st.s %r29,512\(%fp\) - 10: 04 e4 80 1c st.s %r28,1028\(%r4\) - 14: fa df a1 1c st.s %r27,4090\(%r5\) - 18: fe d7 c3 1c st.s %r26,8190\(%r6\) - 1c: 00 c8 e8 1c st.s %r25,16384\(%r7\) - 20: 00 c0 18 1d st.s %r24,-16384\(%r8\) - 24: 00 b8 3c 1d st.s %r23,-8192\(%r9\) - 28: 00 b0 5e 1d st.s %r22,-4096\(%r10\) - 2c: 00 ac 7f 1d st.s %r21,-1024\(%r11\) - 30: 04 a6 9f 1d st.s %r20,-508\(%r12\) - 34: 0e 9f bf 1d st.s %r19,-242\(%r13\) - 38: fe 97 df 1d st.s %r18,-2\(%r14\) diff --git a/gas/testsuite/gas/i860/ldst05.s b/gas/testsuite/gas/i860/ldst05.s deleted file mode 100644 index 7f253f4..0000000 --- a/gas/testsuite/gas/i860/ldst05.s +++ /dev/null @@ -1,19 +0,0 @@ -# st.s (no relocations here) - .text - - st.s %r0,0(%r0) - st.s %r31,122(%r1) - st.s %r30,258(%r2) - st.s %r29,512(%r3) - st.s %r28,1028(%r4) - st.s %r27,4090(%r5) - st.s %r26,8190(%r6) - st.s %r25,16384(%r7) - st.s %r24,-16384(%r8) - st.s %r23,-8192(%r9) - st.s %r22,-4096(%r10) - st.s %r21,-1024(%r11) - st.s %r20,-508(%r12) - st.s %r19,-242(%r13) - st.s %r18,-2(%r14) - diff --git a/gas/testsuite/gas/i860/ldst06.d b/gas/testsuite/gas/i860/ldst06.d deleted file mode 100644 index a1c54d1..0000000 --- a/gas/testsuite/gas/i860/ldst06.d +++ /dev/null @@ -1,28 +0,0 @@ -#as: -#objdump: -dr -#name: i860 ldst06 (st.b) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 00 0c st.b %r0,0\(%r0\) - 4: 01 f8 20 0c st.b %r31,1\(%r1\) - 8: 02 f0 40 0c st.b %r30,2\(%sp\) - c: 01 ea 60 0c st.b %r29,513\(%fp\) - 10: 04 e4 80 0c st.b %r28,1028\(%r4\) - 14: fa df a1 0c st.b %r27,4090\(%r5\) - 18: fe d7 c3 0c st.b %r26,8190\(%r6\) - 1c: 01 c8 e8 0c st.b %r25,16385\(%r7\) - 20: 07 cd ef 0c st.b %r25,32007\(%r7\) - 24: ff cf ef 0c st.b %r25,32767\(%r7\) - 28: 00 c8 f0 0c st.b %r25,-32768\(%r7\) - 2c: 01 c8 f0 0c st.b %r25,-32767\(%r7\) - 30: 01 c0 18 0d st.b %r24,-16383\(%r8\) - 34: 5b b8 3c 0d st.b %r23,-8101\(%r9\) - 38: 05 b0 5e 0d st.b %r22,-4091\(%r10\) - 3c: 01 ac 7f 0d st.b %r21,-1023\(%r11\) - 40: 03 a6 9f 0d st.b %r20,-509\(%r12\) - 44: e9 9f bf 0d st.b %r19,-23\(%r13\) - 48: ff 97 df 0d st.b %r18,-1\(%r14\) diff --git a/gas/testsuite/gas/i860/ldst06.s b/gas/testsuite/gas/i860/ldst06.s deleted file mode 100644 index bb817ab..0000000 --- a/gas/testsuite/gas/i860/ldst06.s +++ /dev/null @@ -1,22 +0,0 @@ -# st.b (no relocations here) - .text - - st.b %r0,0(%r0) - st.b %r31,1(%r1) - st.b %r30,2(%r2) - st.b %r29,513(%r3) - st.b %r28,1028(%r4) - st.b %r27,4090(%r5) - st.b %r26,8190(%r6) - st.b %r25,16385(%r7) - st.b %r25,32007(%r7) - st.b %r25,32767(%r7) - st.b %r25,-32768(%r7) - st.b %r25,-32767(%r7) - st.b %r24,-16383(%r8) - st.b %r23,-8101(%r9) - st.b %r22,-4091(%r10) - st.b %r21,-1023(%r11) - st.b %r20,-509(%r12) - st.b %r19,-23(%r13) - st.b %r18,-1(%r14) diff --git a/gas/testsuite/gas/i860/pfam.d b/gas/testsuite/gas/i860/pfam.d deleted file mode 100644 index 2d95081..0000000 --- a/gas/testsuite/gas/i860/pfam.d +++ /dev/null @@ -1,153 +0,0 @@ -#as: -#objdump: -dr -#name: i860 pfam - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 04 22 48 r2p1.ss %f0,%f1,%f2 - 4: 80 1c 85 48 r2p1.sd %f3,%f4,%f5 - 8: 80 05 44 48 r2p1.dd %f0,%f2,%f4 - c: 01 0c 43 48 r2pt.ss %f1,%f2,%f3 - 10: 81 24 a6 48 r2pt.sd %f4,%f5,%f6 - 14: 81 15 86 48 r2pt.dd %f2,%f4,%f6 - 18: 02 14 64 48 r2ap1.ss %f2,%f3,%f4 - 1c: 82 34 e8 48 r2ap1.sd %f6,%f7,%f8 - 20: 82 25 c8 48 r2ap1.dd %f4,%f6,%f8 - 24: 03 1c 85 48 r2apt.ss %f3,%f4,%f5 - 28: 83 3c 09 49 r2apt.sd %f7,%f8,%f9 - 2c: 83 35 0a 49 r2apt.dd %f6,%f8,%f10 - 30: 04 24 a6 48 i2p1.ss %f4,%f5,%f6 - 34: 84 44 2a 49 i2p1.sd %f8,%f9,%f10 - 38: 84 65 d0 49 i2p1.dd %f12,%f14,%f16 - 3c: 05 3c 09 49 i2pt.ss %f7,%f8,%f9 - 40: 85 5c 8d 49 i2pt.sd %f11,%f12,%f13 - 44: 85 75 12 4a i2pt.dd %f14,%f16,%f18 - 48: 06 54 6c 49 i2ap1.ss %f10,%f11,%f12 - 4c: 86 74 f0 49 i2ap1.sd %f14,%f15,%f16 - 50: 86 85 54 4a i2ap1.dd %f16,%f18,%f20 - 54: 07 6c cf 49 i2apt.ss %f13,%f14,%f15 - 58: 87 8c 53 4a i2apt.sd %f17,%f18,%f19 - 5c: 87 95 96 4a i2apt.dd %f18,%f20,%f22 - 60: 08 74 f0 49 rat1p2.ss %f14,%f15,%f16 - 64: 88 a4 b6 4a rat1p2.sd %f20,%f21,%f22 - 68: 88 a5 d8 4a rat1p2.dd %f20,%f22,%f24 - 6c: 09 7c 11 4a m12apm.ss %f15,%f16,%f17 - 70: 89 bc 19 4b m12apm.sd %f23,%f24,%f25 - 74: 89 b5 1a 4b m12apm.dd %f22,%f24,%f26 - 78: 0a 94 74 4a ra1p2.ss %f18,%f19,%f20 - 7c: 8a d4 7c 4b ra1p2.sd %f26,%f27,%f28 - 80: 8a a5 d8 4a ra1p2.dd %f20,%f22,%f24 - 84: 0b 9c 95 4a m12ttpa.ss %f19,%f20,%f21 - 88: 8b ec df 4b m12ttpa.sd %f29,%f30,%f31 - 8c: 8b b5 1a 4b m12ttpa.dd %f22,%f24,%f26 - 90: 0c a4 b6 4a iat1p2.ss %f20,%f21,%f22 - 94: 8c 04 22 48 iat1p2.sd %f0,%f1,%f2 - 98: 8c c5 5c 4b iat1p2.dd %f24,%f26,%f28 - 9c: 0d ac d7 4a m12tpm.ss %f21,%f22,%f23 - a0: 8d 1c 85 48 m12tpm.sd %f3,%f4,%f5 - a4: 8d f5 02 48 m12tpm.dd %f30,%f0,%f2 - a8: 0e b4 f8 4a ia1p2.ss %f22,%f23,%f24 - ac: 8e 34 e8 48 ia1p2.sd %f6,%f7,%f8 - b0: 8e 25 c8 48 ia1p2.dd %f4,%f6,%f8 - b4: 0f bc 19 4b m12tpa.ss %f23,%f24,%f25 - b8: 8f 4c 4b 49 m12tpa.sd %f9,%f10,%f11 - bc: 8f 35 0a 49 m12tpa.dd %f6,%f8,%f10 - c0: 00 06 22 48 d.r2p1.ss %f0,%f1,%f2 - c4: 00 00 00 a0 shl %r0,%r0,%r0 - c8: 80 1e 85 48 d.r2p1.sd %f3,%f4,%f5 - cc: 00 00 00 a0 shl %r0,%r0,%r0 - d0: 80 07 44 48 d.r2p1.dd %f0,%f2,%f4 - d4: 00 00 00 a0 shl %r0,%r0,%r0 - d8: 01 0e 43 48 d.r2pt.ss %f1,%f2,%f3 - dc: 00 00 00 a0 shl %r0,%r0,%r0 - e0: 81 26 a6 48 d.r2pt.sd %f4,%f5,%f6 - e4: 00 00 00 a0 shl %r0,%r0,%r0 - e8: 81 17 86 48 d.r2pt.dd %f2,%f4,%f6 - ec: 00 00 00 a0 shl %r0,%r0,%r0 - f0: 02 16 64 48 d.r2ap1.ss %f2,%f3,%f4 - f4: 00 00 00 a0 shl %r0,%r0,%r0 - f8: 82 36 e8 48 d.r2ap1.sd %f6,%f7,%f8 - fc: 00 00 00 a0 shl %r0,%r0,%r0 - 100: 82 27 c8 48 d.r2ap1.dd %f4,%f6,%f8 - 104: 00 00 00 a0 shl %r0,%r0,%r0 - 108: 03 1e 85 48 d.r2apt.ss %f3,%f4,%f5 - 10c: 00 00 00 a0 shl %r0,%r0,%r0 - 110: 83 3e 09 49 d.r2apt.sd %f7,%f8,%f9 - 114: 00 00 00 a0 shl %r0,%r0,%r0 - 118: 83 37 0a 49 d.r2apt.dd %f6,%f8,%f10 - 11c: 00 00 00 a0 shl %r0,%r0,%r0 - 120: 04 26 a6 48 d.i2p1.ss %f4,%f5,%f6 - 124: 00 00 00 a0 shl %r0,%r0,%r0 - 128: 84 46 2a 49 d.i2p1.sd %f8,%f9,%f10 - 12c: 00 00 00 a0 shl %r0,%r0,%r0 - 130: 84 67 d0 49 d.i2p1.dd %f12,%f14,%f16 - 134: 00 00 00 a0 shl %r0,%r0,%r0 - 138: 05 3e 09 49 d.i2pt.ss %f7,%f8,%f9 - 13c: 00 00 00 a0 shl %r0,%r0,%r0 - 140: 85 5e 8d 49 d.i2pt.sd %f11,%f12,%f13 - 144: 00 00 00 a0 shl %r0,%r0,%r0 - 148: 85 77 12 4a d.i2pt.dd %f14,%f16,%f18 - 14c: 00 00 00 a0 shl %r0,%r0,%r0 - 150: 06 56 6c 49 d.i2ap1.ss %f10,%f11,%f12 - 154: 00 00 00 a0 shl %r0,%r0,%r0 - 158: 86 76 f0 49 d.i2ap1.sd %f14,%f15,%f16 - 15c: 00 00 00 a0 shl %r0,%r0,%r0 - 160: 86 87 54 4a d.i2ap1.dd %f16,%f18,%f20 - 164: 00 00 00 a0 shl %r0,%r0,%r0 - 168: 07 6e cf 49 d.i2apt.ss %f13,%f14,%f15 - 16c: 00 00 00 a0 shl %r0,%r0,%r0 - 170: 87 8e 53 4a d.i2apt.sd %f17,%f18,%f19 - 174: 00 00 00 a0 shl %r0,%r0,%r0 - 178: 87 97 96 4a d.i2apt.dd %f18,%f20,%f22 - 17c: 00 00 00 a0 shl %r0,%r0,%r0 - 180: 08 76 f0 49 d.rat1p2.ss %f14,%f15,%f16 - 184: 00 00 00 a0 shl %r0,%r0,%r0 - 188: 88 a6 b6 4a d.rat1p2.sd %f20,%f21,%f22 - 18c: 00 00 00 a0 shl %r0,%r0,%r0 - 190: 88 a7 d8 4a d.rat1p2.dd %f20,%f22,%f24 - 194: 00 00 00 a0 shl %r0,%r0,%r0 - 198: 09 7e 11 4a d.m12apm.ss %f15,%f16,%f17 - 19c: 00 00 00 a0 shl %r0,%r0,%r0 - 1a0: 89 be 19 4b d.m12apm.sd %f23,%f24,%f25 - 1a4: 00 00 00 a0 shl %r0,%r0,%r0 - 1a8: 89 b7 1a 4b d.m12apm.dd %f22,%f24,%f26 - 1ac: 00 00 00 a0 shl %r0,%r0,%r0 - 1b0: 0a 96 74 4a d.ra1p2.ss %f18,%f19,%f20 - 1b4: 00 00 00 a0 shl %r0,%r0,%r0 - 1b8: 8a d6 7c 4b d.ra1p2.sd %f26,%f27,%f28 - 1bc: 00 00 00 a0 shl %r0,%r0,%r0 - 1c0: 8a a7 d8 4a d.ra1p2.dd %f20,%f22,%f24 - 1c4: 00 00 00 a0 shl %r0,%r0,%r0 - 1c8: 0b 9e 95 4a d.m12ttpa.ss %f19,%f20,%f21 - 1cc: 00 00 00 a0 shl %r0,%r0,%r0 - 1d0: 8b ee df 4b d.m12ttpa.sd %f29,%f30,%f31 - 1d4: 00 00 00 a0 shl %r0,%r0,%r0 - 1d8: 8b b7 1a 4b d.m12ttpa.dd %f22,%f24,%f26 - 1dc: 00 00 00 a0 shl %r0,%r0,%r0 - 1e0: 0c a6 b6 4a d.iat1p2.ss %f20,%f21,%f22 - 1e4: 00 00 00 a0 shl %r0,%r0,%r0 - 1e8: 8c 06 22 48 d.iat1p2.sd %f0,%f1,%f2 - 1ec: 00 00 00 a0 shl %r0,%r0,%r0 - 1f0: 8c c7 5c 4b d.iat1p2.dd %f24,%f26,%f28 - 1f4: 00 00 00 a0 shl %r0,%r0,%r0 - 1f8: 0d ae d7 4a d.m12tpm.ss %f21,%f22,%f23 - 1fc: 00 00 00 a0 shl %r0,%r0,%r0 - 200: 8d 1e 85 48 d.m12tpm.sd %f3,%f4,%f5 - 204: 00 00 00 a0 shl %r0,%r0,%r0 - 208: 8d f7 02 48 d.m12tpm.dd %f30,%f0,%f2 - 20c: 00 00 00 a0 shl %r0,%r0,%r0 - 210: 0e b6 f8 4a d.ia1p2.ss %f22,%f23,%f24 - 214: 00 00 00 a0 shl %r0,%r0,%r0 - 218: 8e 36 e8 48 d.ia1p2.sd %f6,%f7,%f8 - 21c: 00 00 00 a0 shl %r0,%r0,%r0 - 220: 8e 27 c8 48 d.ia1p2.dd %f4,%f6,%f8 - 224: 00 00 00 a0 shl %r0,%r0,%r0 - 228: 0f be 19 4b d.m12tpa.ss %f23,%f24,%f25 - 22c: 00 00 00 a0 shl %r0,%r0,%r0 - 230: 8f 4e 4b 49 d.m12tpa.sd %f9,%f10,%f11 - 234: 00 00 00 a0 shl %r0,%r0,%r0 - 238: 8f 37 0a 49 d.m12tpa.dd %f6,%f8,%f10 - 23c: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/pfam.s b/gas/testsuite/gas/i860/pfam.s deleted file mode 100644 index 4afc28d..0000000 --- a/gas/testsuite/gas/i860/pfam.s +++ /dev/null @@ -1,182 +0,0 @@ -# pfam.p family (p={ss,sd,dd}) - - .text - - # pfam without dual bit. - r2p1.ss %f0,%f1,%f2 - r2p1.sd %f3,%f4,%f5 - r2p1.dd %f0,%f2,%f4 - - r2pt.ss %f1,%f2,%f3 - r2pt.sd %f4,%f5,%f6 - r2pt.dd %f2,%f4,%f6 - - r2ap1.ss %f2,%f3,%f4 - r2ap1.sd %f6,%f7,%f8 - r2ap1.dd %f4,%f6,%f8 - - r2apt.ss %f3,%f4,%f5 - r2apt.sd %f7,%f8,%f9 - r2apt.dd %f6,%f8,%f10 - - i2p1.ss %f4,%f5,%f6 - i2p1.sd %f8,%f9,%f10 - i2p1.dd %f12,%f14,%f16 - - i2pt.ss %f7,%f8,%f9 - i2pt.sd %f11,%f12,%f13 - i2pt.dd %f14,%f16,%f18 - - i2ap1.ss %f10,%f11,%f12 - i2ap1.sd %f14,%f15,%f16 - i2ap1.dd %f16,%f18,%f20 - - i2apt.ss %f13,%f14,%f15 - i2apt.sd %f17,%f18,%f19 - i2apt.dd %f18,%f20,%f22 - - rat1p2.ss %f14,%f15,%f16 - rat1p2.sd %f20,%f21,%f22 - rat1p2.dd %f20,%f22,%f24 - - m12apm.ss %f15,%f16,%f17 - m12apm.sd %f23,%f24,%f25 - m12apm.dd %f22,%f24,%f26 - - ra1p2.ss %f18,%f19,%f20 - ra1p2.sd %f26,%f27,%f28 - ra1p2.dd %f20,%f22,%f24 - - m12ttpa.ss %f19,%f20,%f21 - m12ttpa.sd %f29,%f30,%f31 - m12ttpa.dd %f22,%f24,%f26 - - iat1p2.ss %f20,%f21,%f22 - iat1p2.sd %f0,%f1,%f2 - iat1p2.dd %f24,%f26,%f28 - - m12tpm.ss %f21,%f22,%f23 - m12tpm.sd %f3,%f4,%f5 - m12tpm.dd %f30,%f0,%f2 - - ia1p2.ss %f22,%f23,%f24 - ia1p2.sd %f6,%f7,%f8 - ia1p2.dd %f4,%f6,%f8 - - m12tpa.ss %f23,%f24,%f25 - m12tpa.sd %f9,%f10,%f11 - m12tpa.dd %f6,%f8,%f10 - - # pfam with dual bit. - d.r2p1.ss %f0,%f1,%f2 - nop - d.r2p1.sd %f3,%f4,%f5 - nop - d.r2p1.dd %f0,%f2,%f4 - nop - - d.r2pt.ss %f1,%f2,%f3 - nop - d.r2pt.sd %f4,%f5,%f6 - nop - d.r2pt.dd %f2,%f4,%f6 - nop - - d.r2ap1.ss %f2,%f3,%f4 - nop - d.r2ap1.sd %f6,%f7,%f8 - nop - d.r2ap1.dd %f4,%f6,%f8 - nop - - d.r2apt.ss %f3,%f4,%f5 - nop - d.r2apt.sd %f7,%f8,%f9 - nop - d.r2apt.dd %f6,%f8,%f10 - nop - - d.i2p1.ss %f4,%f5,%f6 - nop - d.i2p1.sd %f8,%f9,%f10 - nop - d.i2p1.dd %f12,%f14,%f16 - nop - - d.i2pt.ss %f7,%f8,%f9 - nop - d.i2pt.sd %f11,%f12,%f13 - nop - d.i2pt.dd %f14,%f16,%f18 - nop - - d.i2ap1.ss %f10,%f11,%f12 - nop - d.i2ap1.sd %f14,%f15,%f16 - nop - d.i2ap1.dd %f16,%f18,%f20 - nop - - d.i2apt.ss %f13,%f14,%f15 - nop - d.i2apt.sd %f17,%f18,%f19 - nop - d.i2apt.dd %f18,%f20,%f22 - nop - - d.rat1p2.ss %f14,%f15,%f16 - nop - d.rat1p2.sd %f20,%f21,%f22 - nop - d.rat1p2.dd %f20,%f22,%f24 - nop - - d.m12apm.ss %f15,%f16,%f17 - nop - d.m12apm.sd %f23,%f24,%f25 - nop - d.m12apm.dd %f22,%f24,%f26 - nop - - d.ra1p2.ss %f18,%f19,%f20 - nop - d.ra1p2.sd %f26,%f27,%f28 - nop - d.ra1p2.dd %f20,%f22,%f24 - nop - - d.m12ttpa.ss %f19,%f20,%f21 - nop - d.m12ttpa.sd %f29,%f30,%f31 - nop - d.m12ttpa.dd %f22,%f24,%f26 - nop - - d.iat1p2.ss %f20,%f21,%f22 - nop - d.iat1p2.sd %f0,%f1,%f2 - nop - d.iat1p2.dd %f24,%f26,%f28 - nop - - d.m12tpm.ss %f21,%f22,%f23 - nop - d.m12tpm.sd %f3,%f4,%f5 - nop - d.m12tpm.dd %f30,%f0,%f2 - nop - - d.ia1p2.ss %f22,%f23,%f24 - nop - d.ia1p2.sd %f6,%f7,%f8 - nop - d.ia1p2.dd %f4,%f6,%f8 - nop - - d.m12tpa.ss %f23,%f24,%f25 - nop - d.m12tpa.sd %f9,%f10,%f11 - nop - d.m12tpa.dd %f6,%f8,%f10 - nop - diff --git a/gas/testsuite/gas/i860/pfmam.d b/gas/testsuite/gas/i860/pfmam.d deleted file mode 100644 index 63f48a4..0000000 --- a/gas/testsuite/gas/i860/pfmam.d +++ /dev/null @@ -1,153 +0,0 @@ -#as: -#objdump: -dr -#name: i860 pfmam - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 22 48 mr2p1.ss %f0,%f1,%f2 - 4: 80 18 85 48 mr2p1.sd %f3,%f4,%f5 - 8: 80 01 44 48 mr2p1.dd %f0,%f2,%f4 - c: 01 08 43 48 mr2pt.ss %f1,%f2,%f3 - 10: 81 20 a6 48 mr2pt.sd %f4,%f5,%f6 - 14: 81 11 86 48 mr2pt.dd %f2,%f4,%f6 - 18: 02 10 64 48 mr2mp1.ss %f2,%f3,%f4 - 1c: 82 30 e8 48 mr2mp1.sd %f6,%f7,%f8 - 20: 82 21 c8 48 mr2mp1.dd %f4,%f6,%f8 - 24: 03 18 85 48 mr2mpt.ss %f3,%f4,%f5 - 28: 83 38 09 49 mr2mpt.sd %f7,%f8,%f9 - 2c: 83 31 0a 49 mr2mpt.dd %f6,%f8,%f10 - 30: 04 20 a6 48 mi2p1.ss %f4,%f5,%f6 - 34: 84 40 2a 49 mi2p1.sd %f8,%f9,%f10 - 38: 84 61 d0 49 mi2p1.dd %f12,%f14,%f16 - 3c: 05 38 09 49 mi2pt.ss %f7,%f8,%f9 - 40: 85 58 8d 49 mi2pt.sd %f11,%f12,%f13 - 44: 85 71 12 4a mi2pt.dd %f14,%f16,%f18 - 48: 06 50 6c 49 mi2mp1.ss %f10,%f11,%f12 - 4c: 86 70 f0 49 mi2mp1.sd %f14,%f15,%f16 - 50: 86 81 54 4a mi2mp1.dd %f16,%f18,%f20 - 54: 07 68 cf 49 mi2mpt.ss %f13,%f14,%f15 - 58: 87 88 53 4a mi2mpt.sd %f17,%f18,%f19 - 5c: 87 91 96 4a mi2mpt.dd %f18,%f20,%f22 - 60: 08 70 f0 49 mrmt1p2.ss %f14,%f15,%f16 - 64: 88 a0 b6 4a mrmt1p2.sd %f20,%f21,%f22 - 68: 88 a1 d8 4a mrmt1p2.dd %f20,%f22,%f24 - 6c: 09 78 11 4a mm12mpm.ss %f15,%f16,%f17 - 70: 89 b8 19 4b mm12mpm.sd %f23,%f24,%f25 - 74: 89 b1 1a 4b mm12mpm.dd %f22,%f24,%f26 - 78: 0a 90 74 4a mrm1p2.ss %f18,%f19,%f20 - 7c: 8a d0 7c 4b mrm1p2.sd %f26,%f27,%f28 - 80: 8a a1 d8 4a mrm1p2.dd %f20,%f22,%f24 - 84: 0b 98 95 4a mm12ttpm.ss %f19,%f20,%f21 - 88: 8b e8 df 4b mm12ttpm.sd %f29,%f30,%f31 - 8c: 8b b1 1a 4b mm12ttpm.dd %f22,%f24,%f26 - 90: 0c a0 b6 4a mimt1p2.ss %f20,%f21,%f22 - 94: 8c 00 22 48 mimt1p2.sd %f0,%f1,%f2 - 98: 8c c1 5c 4b mimt1p2.dd %f24,%f26,%f28 - 9c: 0d a8 d7 4a mm12tpm.ss %f21,%f22,%f23 - a0: 8d 18 85 48 mm12tpm.sd %f3,%f4,%f5 - a4: 8d f1 02 48 mm12tpm.dd %f30,%f0,%f2 - a8: 0e b0 f8 4a mim1p2.ss %f22,%f23,%f24 - ac: 8e 30 e8 48 mim1p2.sd %f6,%f7,%f8 - b0: 8e 21 c8 48 mim1p2.dd %f4,%f6,%f8 - b4: 0f bc 19 4b m12tpa.ss %f23,%f24,%f25 - b8: 8f 4c 4b 49 m12tpa.sd %f9,%f10,%f11 - bc: 8f 35 0a 49 m12tpa.dd %f6,%f8,%f10 - c0: 00 02 22 48 d.mr2p1.ss %f0,%f1,%f2 - c4: 00 00 00 a0 shl %r0,%r0,%r0 - c8: 80 1a 85 48 d.mr2p1.sd %f3,%f4,%f5 - cc: 00 00 00 a0 shl %r0,%r0,%r0 - d0: 80 03 44 48 d.mr2p1.dd %f0,%f2,%f4 - d4: 00 00 00 a0 shl %r0,%r0,%r0 - d8: 01 0a 43 48 d.mr2pt.ss %f1,%f2,%f3 - dc: 00 00 00 a0 shl %r0,%r0,%r0 - e0: 81 22 a6 48 d.mr2pt.sd %f4,%f5,%f6 - e4: 00 00 00 a0 shl %r0,%r0,%r0 - e8: 81 13 86 48 d.mr2pt.dd %f2,%f4,%f6 - ec: 00 00 00 a0 shl %r0,%r0,%r0 - f0: 02 12 64 48 d.mr2mp1.ss %f2,%f3,%f4 - f4: 00 00 00 a0 shl %r0,%r0,%r0 - f8: 82 32 e8 48 d.mr2mp1.sd %f6,%f7,%f8 - fc: 00 00 00 a0 shl %r0,%r0,%r0 - 100: 82 23 c8 48 d.mr2mp1.dd %f4,%f6,%f8 - 104: 00 00 00 a0 shl %r0,%r0,%r0 - 108: 03 1a 85 48 d.mr2mpt.ss %f3,%f4,%f5 - 10c: 00 00 00 a0 shl %r0,%r0,%r0 - 110: 83 3a 09 49 d.mr2mpt.sd %f7,%f8,%f9 - 114: 00 00 00 a0 shl %r0,%r0,%r0 - 118: 83 33 0a 49 d.mr2mpt.dd %f6,%f8,%f10 - 11c: 00 00 00 a0 shl %r0,%r0,%r0 - 120: 04 22 a6 48 d.mi2p1.ss %f4,%f5,%f6 - 124: 00 00 00 a0 shl %r0,%r0,%r0 - 128: 84 42 2a 49 d.mi2p1.sd %f8,%f9,%f10 - 12c: 00 00 00 a0 shl %r0,%r0,%r0 - 130: 84 63 d0 49 d.mi2p1.dd %f12,%f14,%f16 - 134: 00 00 00 a0 shl %r0,%r0,%r0 - 138: 05 3a 09 49 d.mi2pt.ss %f7,%f8,%f9 - 13c: 00 00 00 a0 shl %r0,%r0,%r0 - 140: 85 5a 8d 49 d.mi2pt.sd %f11,%f12,%f13 - 144: 00 00 00 a0 shl %r0,%r0,%r0 - 148: 85 73 12 4a d.mi2pt.dd %f14,%f16,%f18 - 14c: 00 00 00 a0 shl %r0,%r0,%r0 - 150: 06 52 6c 49 d.mi2mp1.ss %f10,%f11,%f12 - 154: 00 00 00 a0 shl %r0,%r0,%r0 - 158: 86 72 f0 49 d.mi2mp1.sd %f14,%f15,%f16 - 15c: 00 00 00 a0 shl %r0,%r0,%r0 - 160: 86 83 54 4a d.mi2mp1.dd %f16,%f18,%f20 - 164: 00 00 00 a0 shl %r0,%r0,%r0 - 168: 07 6a cf 49 d.mi2mpt.ss %f13,%f14,%f15 - 16c: 00 00 00 a0 shl %r0,%r0,%r0 - 170: 87 8a 53 4a d.mi2mpt.sd %f17,%f18,%f19 - 174: 00 00 00 a0 shl %r0,%r0,%r0 - 178: 87 93 96 4a d.mi2mpt.dd %f18,%f20,%f22 - 17c: 00 00 00 a0 shl %r0,%r0,%r0 - 180: 08 72 f0 49 d.mrmt1p2.ss %f14,%f15,%f16 - 184: 00 00 00 a0 shl %r0,%r0,%r0 - 188: 88 a2 b6 4a d.mrmt1p2.sd %f20,%f21,%f22 - 18c: 00 00 00 a0 shl %r0,%r0,%r0 - 190: 88 a3 d8 4a d.mrmt1p2.dd %f20,%f22,%f24 - 194: 00 00 00 a0 shl %r0,%r0,%r0 - 198: 09 7a 11 4a d.mm12mpm.ss %f15,%f16,%f17 - 19c: 00 00 00 a0 shl %r0,%r0,%r0 - 1a0: 89 ba 19 4b d.mm12mpm.sd %f23,%f24,%f25 - 1a4: 00 00 00 a0 shl %r0,%r0,%r0 - 1a8: 89 b3 1a 4b d.mm12mpm.dd %f22,%f24,%f26 - 1ac: 00 00 00 a0 shl %r0,%r0,%r0 - 1b0: 0a 92 74 4a d.mrm1p2.ss %f18,%f19,%f20 - 1b4: 00 00 00 a0 shl %r0,%r0,%r0 - 1b8: 8a d2 7c 4b d.mrm1p2.sd %f26,%f27,%f28 - 1bc: 00 00 00 a0 shl %r0,%r0,%r0 - 1c0: 8a a3 d8 4a d.mrm1p2.dd %f20,%f22,%f24 - 1c4: 00 00 00 a0 shl %r0,%r0,%r0 - 1c8: 0b 9a 95 4a d.mm12ttpm.ss %f19,%f20,%f21 - 1cc: 00 00 00 a0 shl %r0,%r0,%r0 - 1d0: 8b ea df 4b d.mm12ttpm.sd %f29,%f30,%f31 - 1d4: 00 00 00 a0 shl %r0,%r0,%r0 - 1d8: 8b b3 1a 4b d.mm12ttpm.dd %f22,%f24,%f26 - 1dc: 00 00 00 a0 shl %r0,%r0,%r0 - 1e0: 0c a2 b6 4a d.mimt1p2.ss %f20,%f21,%f22 - 1e4: 00 00 00 a0 shl %r0,%r0,%r0 - 1e8: 8c 02 22 48 d.mimt1p2.sd %f0,%f1,%f2 - 1ec: 00 00 00 a0 shl %r0,%r0,%r0 - 1f0: 8c c3 5c 4b d.mimt1p2.dd %f24,%f26,%f28 - 1f4: 00 00 00 a0 shl %r0,%r0,%r0 - 1f8: 0d aa d7 4a d.mm12tpm.ss %f21,%f22,%f23 - 1fc: 00 00 00 a0 shl %r0,%r0,%r0 - 200: 8d 1a 85 48 d.mm12tpm.sd %f3,%f4,%f5 - 204: 00 00 00 a0 shl %r0,%r0,%r0 - 208: 8d f3 02 48 d.mm12tpm.dd %f30,%f0,%f2 - 20c: 00 00 00 a0 shl %r0,%r0,%r0 - 210: 0e b2 f8 4a d.mim1p2.ss %f22,%f23,%f24 - 214: 00 00 00 a0 shl %r0,%r0,%r0 - 218: 8e 32 e8 48 d.mim1p2.sd %f6,%f7,%f8 - 21c: 00 00 00 a0 shl %r0,%r0,%r0 - 220: 8e 23 c8 48 d.mim1p2.dd %f4,%f6,%f8 - 224: 00 00 00 a0 shl %r0,%r0,%r0 - 228: 0f be 19 4b d.m12tpa.ss %f23,%f24,%f25 - 22c: 00 00 00 a0 shl %r0,%r0,%r0 - 230: 8f 4e 4b 49 d.m12tpa.sd %f9,%f10,%f11 - 234: 00 00 00 a0 shl %r0,%r0,%r0 - 238: 8f 37 0a 49 d.m12tpa.dd %f6,%f8,%f10 - 23c: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/pfmam.s b/gas/testsuite/gas/i860/pfmam.s deleted file mode 100644 index ac6a1af..0000000 --- a/gas/testsuite/gas/i860/pfmam.s +++ /dev/null @@ -1,182 +0,0 @@ -# pfmam.p family (p={ss,sd,dd}) - - .text - - # pfmam without dual bit. - mr2p1.ss %f0,%f1,%f2 - mr2p1.sd %f3,%f4,%f5 - mr2p1.dd %f0,%f2,%f4 - - mr2pt.ss %f1,%f2,%f3 - mr2pt.sd %f4,%f5,%f6 - mr2pt.dd %f2,%f4,%f6 - - mr2mp1.ss %f2,%f3,%f4 - mr2mp1.sd %f6,%f7,%f8 - mr2mp1.dd %f4,%f6,%f8 - - mr2mpt.ss %f3,%f4,%f5 - mr2mpt.sd %f7,%f8,%f9 - mr2mpt.dd %f6,%f8,%f10 - - mi2p1.ss %f4,%f5,%f6 - mi2p1.sd %f8,%f9,%f10 - mi2p1.dd %f12,%f14,%f16 - - mi2pt.ss %f7,%f8,%f9 - mi2pt.sd %f11,%f12,%f13 - mi2pt.dd %f14,%f16,%f18 - - mi2mp1.ss %f10,%f11,%f12 - mi2mp1.sd %f14,%f15,%f16 - mi2mp1.dd %f16,%f18,%f20 - - mi2mpt.ss %f13,%f14,%f15 - mi2mpt.sd %f17,%f18,%f19 - mi2mpt.dd %f18,%f20,%f22 - - mrmt1p2.ss %f14,%f15,%f16 - mrmt1p2.sd %f20,%f21,%f22 - mrmt1p2.dd %f20,%f22,%f24 - - mm12mpm.ss %f15,%f16,%f17 - mm12mpm.sd %f23,%f24,%f25 - mm12mpm.dd %f22,%f24,%f26 - - mrm1p2.ss %f18,%f19,%f20 - mrm1p2.sd %f26,%f27,%f28 - mrm1p2.dd %f20,%f22,%f24 - - mm12ttpm.ss %f19,%f20,%f21 - mm12ttpm.sd %f29,%f30,%f31 - mm12ttpm.dd %f22,%f24,%f26 - - mimt1p2.ss %f20,%f21,%f22 - mimt1p2.sd %f0,%f1,%f2 - mimt1p2.dd %f24,%f26,%f28 - - mm12tpm.ss %f21,%f22,%f23 - mm12tpm.sd %f3,%f4,%f5 - mm12tpm.dd %f30,%f0,%f2 - - mim1p2.ss %f22,%f23,%f24 - mim1p2.sd %f6,%f7,%f8 - mim1p2.dd %f4,%f6,%f8 - - m12tpa.ss %f23,%f24,%f25 - m12tpa.sd %f9,%f10,%f11 - m12tpa.dd %f6,%f8,%f10 - - # pfmam with dual bit. - d.mr2p1.ss %f0,%f1,%f2 - nop - d.mr2p1.sd %f3,%f4,%f5 - nop - d.mr2p1.dd %f0,%f2,%f4 - nop - - d.mr2pt.ss %f1,%f2,%f3 - nop - d.mr2pt.sd %f4,%f5,%f6 - nop - d.mr2pt.dd %f2,%f4,%f6 - nop - - d.mr2mp1.ss %f2,%f3,%f4 - nop - d.mr2mp1.sd %f6,%f7,%f8 - nop - d.mr2mp1.dd %f4,%f6,%f8 - nop - - d.mr2mpt.ss %f3,%f4,%f5 - nop - d.mr2mpt.sd %f7,%f8,%f9 - nop - d.mr2mpt.dd %f6,%f8,%f10 - nop - - d.mi2p1.ss %f4,%f5,%f6 - nop - d.mi2p1.sd %f8,%f9,%f10 - nop - d.mi2p1.dd %f12,%f14,%f16 - nop - - d.mi2pt.ss %f7,%f8,%f9 - nop - d.mi2pt.sd %f11,%f12,%f13 - nop - d.mi2pt.dd %f14,%f16,%f18 - nop - - d.mi2mp1.ss %f10,%f11,%f12 - nop - d.mi2mp1.sd %f14,%f15,%f16 - nop - d.mi2mp1.dd %f16,%f18,%f20 - nop - - d.mi2mpt.ss %f13,%f14,%f15 - nop - d.mi2mpt.sd %f17,%f18,%f19 - nop - d.mi2mpt.dd %f18,%f20,%f22 - nop - - d.mrmt1p2.ss %f14,%f15,%f16 - nop - d.mrmt1p2.sd %f20,%f21,%f22 - nop - d.mrmt1p2.dd %f20,%f22,%f24 - nop - - d.mm12mpm.ss %f15,%f16,%f17 - nop - d.mm12mpm.sd %f23,%f24,%f25 - nop - d.mm12mpm.dd %f22,%f24,%f26 - nop - - d.mrm1p2.ss %f18,%f19,%f20 - nop - d.mrm1p2.sd %f26,%f27,%f28 - nop - d.mrm1p2.dd %f20,%f22,%f24 - nop - - d.mm12ttpm.ss %f19,%f20,%f21 - nop - d.mm12ttpm.sd %f29,%f30,%f31 - nop - d.mm12ttpm.dd %f22,%f24,%f26 - nop - - d.mimt1p2.ss %f20,%f21,%f22 - nop - d.mimt1p2.sd %f0,%f1,%f2 - nop - d.mimt1p2.dd %f24,%f26,%f28 - nop - - d.mm12tpm.ss %f21,%f22,%f23 - nop - d.mm12tpm.sd %f3,%f4,%f5 - nop - d.mm12tpm.dd %f30,%f0,%f2 - nop - - d.mim1p2.ss %f22,%f23,%f24 - nop - d.mim1p2.sd %f6,%f7,%f8 - nop - d.mim1p2.dd %f4,%f6,%f8 - nop - - d.m12tpa.ss %f23,%f24,%f25 - nop - d.m12tpa.sd %f9,%f10,%f11 - nop - d.m12tpa.dd %f6,%f8,%f10 - nop - diff --git a/gas/testsuite/gas/i860/pfmsm.d b/gas/testsuite/gas/i860/pfmsm.d deleted file mode 100644 index 65d7e97..0000000 --- a/gas/testsuite/gas/i860/pfmsm.d +++ /dev/null @@ -1,153 +0,0 @@ -#as: -#objdump: -dr -#name: i860 pfmsm - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 10 00 22 48 mr2s1.ss %f0,%f1,%f2 - 4: 90 18 85 48 mr2s1.sd %f3,%f4,%f5 - 8: 90 01 44 48 mr2s1.dd %f0,%f2,%f4 - c: 11 08 43 48 mr2st.ss %f1,%f2,%f3 - 10: 91 20 a6 48 mr2st.sd %f4,%f5,%f6 - 14: 91 11 86 48 mr2st.dd %f2,%f4,%f6 - 18: 12 10 64 48 mr2ms1.ss %f2,%f3,%f4 - 1c: 92 30 e8 48 mr2ms1.sd %f6,%f7,%f8 - 20: 92 21 c8 48 mr2ms1.dd %f4,%f6,%f8 - 24: 13 18 85 48 mr2mst.ss %f3,%f4,%f5 - 28: 93 38 09 49 mr2mst.sd %f7,%f8,%f9 - 2c: 93 31 0a 49 mr2mst.dd %f6,%f8,%f10 - 30: 14 20 a6 48 mi2s1.ss %f4,%f5,%f6 - 34: 94 40 2a 49 mi2s1.sd %f8,%f9,%f10 - 38: 94 61 d0 49 mi2s1.dd %f12,%f14,%f16 - 3c: 15 38 09 49 mi2st.ss %f7,%f8,%f9 - 40: 95 58 8d 49 mi2st.sd %f11,%f12,%f13 - 44: 95 71 12 4a mi2st.dd %f14,%f16,%f18 - 48: 16 50 6c 49 mi2ms1.ss %f10,%f11,%f12 - 4c: 96 70 f0 49 mi2ms1.sd %f14,%f15,%f16 - 50: 96 81 54 4a mi2ms1.dd %f16,%f18,%f20 - 54: 17 68 cf 49 mi2mst.ss %f13,%f14,%f15 - 58: 97 88 53 4a mi2mst.sd %f17,%f18,%f19 - 5c: 97 91 96 4a mi2mst.dd %f18,%f20,%f22 - 60: 18 70 f0 49 mrmt1s2.ss %f14,%f15,%f16 - 64: 98 a0 b6 4a mrmt1s2.sd %f20,%f21,%f22 - 68: 98 a1 d8 4a mrmt1s2.dd %f20,%f22,%f24 - 6c: 19 78 11 4a mm12msm.ss %f15,%f16,%f17 - 70: 99 b8 19 4b mm12msm.sd %f23,%f24,%f25 - 74: 99 b1 1a 4b mm12msm.dd %f22,%f24,%f26 - 78: 1a 90 74 4a mrm1s2.ss %f18,%f19,%f20 - 7c: 9a d0 7c 4b mrm1s2.sd %f26,%f27,%f28 - 80: 9a a1 d8 4a mrm1s2.dd %f20,%f22,%f24 - 84: 1b 98 95 4a mm12ttsm.ss %f19,%f20,%f21 - 88: 9b e8 df 4b mm12ttsm.sd %f29,%f30,%f31 - 8c: 9b b1 1a 4b mm12ttsm.dd %f22,%f24,%f26 - 90: 1c a0 b6 4a mimt1s2.ss %f20,%f21,%f22 - 94: 9c 00 22 48 mimt1s2.sd %f0,%f1,%f2 - 98: 9c c1 5c 4b mimt1s2.dd %f24,%f26,%f28 - 9c: 1d a8 d7 4a mm12tsm.ss %f21,%f22,%f23 - a0: 9d 18 85 48 mm12tsm.sd %f3,%f4,%f5 - a4: 9d f1 02 48 mm12tsm.dd %f30,%f0,%f2 - a8: 1e b0 f8 4a mim1s2.ss %f22,%f23,%f24 - ac: 9e 30 e8 48 mim1s2.sd %f6,%f7,%f8 - b0: 9e 21 c8 48 mim1s2.dd %f4,%f6,%f8 - b4: 1f bc 19 4b m12tsa.ss %f23,%f24,%f25 - b8: 9f 4c 4b 49 m12tsa.sd %f9,%f10,%f11 - bc: 9f 35 0a 49 m12tsa.dd %f6,%f8,%f10 - c0: 10 02 22 48 d.mr2s1.ss %f0,%f1,%f2 - c4: 00 00 00 a0 shl %r0,%r0,%r0 - c8: 90 1a 85 48 d.mr2s1.sd %f3,%f4,%f5 - cc: 00 00 00 a0 shl %r0,%r0,%r0 - d0: 90 03 44 48 d.mr2s1.dd %f0,%f2,%f4 - d4: 00 00 00 a0 shl %r0,%r0,%r0 - d8: 11 0a 43 48 d.mr2st.ss %f1,%f2,%f3 - dc: 00 00 00 a0 shl %r0,%r0,%r0 - e0: 91 22 a6 48 d.mr2st.sd %f4,%f5,%f6 - e4: 00 00 00 a0 shl %r0,%r0,%r0 - e8: 91 13 86 48 d.mr2st.dd %f2,%f4,%f6 - ec: 00 00 00 a0 shl %r0,%r0,%r0 - f0: 12 12 64 48 d.mr2ms1.ss %f2,%f3,%f4 - f4: 00 00 00 a0 shl %r0,%r0,%r0 - f8: 92 32 e8 48 d.mr2ms1.sd %f6,%f7,%f8 - fc: 00 00 00 a0 shl %r0,%r0,%r0 - 100: 92 23 c8 48 d.mr2ms1.dd %f4,%f6,%f8 - 104: 00 00 00 a0 shl %r0,%r0,%r0 - 108: 13 1a 85 48 d.mr2mst.ss %f3,%f4,%f5 - 10c: 00 00 00 a0 shl %r0,%r0,%r0 - 110: 93 3a 09 49 d.mr2mst.sd %f7,%f8,%f9 - 114: 00 00 00 a0 shl %r0,%r0,%r0 - 118: 93 33 0a 49 d.mr2mst.dd %f6,%f8,%f10 - 11c: 00 00 00 a0 shl %r0,%r0,%r0 - 120: 14 22 a6 48 d.mi2s1.ss %f4,%f5,%f6 - 124: 00 00 00 a0 shl %r0,%r0,%r0 - 128: 94 42 2a 49 d.mi2s1.sd %f8,%f9,%f10 - 12c: 00 00 00 a0 shl %r0,%r0,%r0 - 130: 94 63 d0 49 d.mi2s1.dd %f12,%f14,%f16 - 134: 00 00 00 a0 shl %r0,%r0,%r0 - 138: 15 3a 09 49 d.mi2st.ss %f7,%f8,%f9 - 13c: 00 00 00 a0 shl %r0,%r0,%r0 - 140: 95 5a 8d 49 d.mi2st.sd %f11,%f12,%f13 - 144: 00 00 00 a0 shl %r0,%r0,%r0 - 148: 95 73 12 4a d.mi2st.dd %f14,%f16,%f18 - 14c: 00 00 00 a0 shl %r0,%r0,%r0 - 150: 16 52 6c 49 d.mi2ms1.ss %f10,%f11,%f12 - 154: 00 00 00 a0 shl %r0,%r0,%r0 - 158: 96 72 f0 49 d.mi2ms1.sd %f14,%f15,%f16 - 15c: 00 00 00 a0 shl %r0,%r0,%r0 - 160: 96 83 54 4a d.mi2ms1.dd %f16,%f18,%f20 - 164: 00 00 00 a0 shl %r0,%r0,%r0 - 168: 17 6a cf 49 d.mi2mst.ss %f13,%f14,%f15 - 16c: 00 00 00 a0 shl %r0,%r0,%r0 - 170: 97 8a 53 4a d.mi2mst.sd %f17,%f18,%f19 - 174: 00 00 00 a0 shl %r0,%r0,%r0 - 178: 97 93 96 4a d.mi2mst.dd %f18,%f20,%f22 - 17c: 00 00 00 a0 shl %r0,%r0,%r0 - 180: 18 72 f0 49 d.mrmt1s2.ss %f14,%f15,%f16 - 184: 00 00 00 a0 shl %r0,%r0,%r0 - 188: 98 a2 b6 4a d.mrmt1s2.sd %f20,%f21,%f22 - 18c: 00 00 00 a0 shl %r0,%r0,%r0 - 190: 98 a3 d8 4a d.mrmt1s2.dd %f20,%f22,%f24 - 194: 00 00 00 a0 shl %r0,%r0,%r0 - 198: 19 7a 11 4a d.mm12msm.ss %f15,%f16,%f17 - 19c: 00 00 00 a0 shl %r0,%r0,%r0 - 1a0: 99 ba 19 4b d.mm12msm.sd %f23,%f24,%f25 - 1a4: 00 00 00 a0 shl %r0,%r0,%r0 - 1a8: 99 b3 1a 4b d.mm12msm.dd %f22,%f24,%f26 - 1ac: 00 00 00 a0 shl %r0,%r0,%r0 - 1b0: 1a 92 74 4a d.mrm1s2.ss %f18,%f19,%f20 - 1b4: 00 00 00 a0 shl %r0,%r0,%r0 - 1b8: 9a d2 7c 4b d.mrm1s2.sd %f26,%f27,%f28 - 1bc: 00 00 00 a0 shl %r0,%r0,%r0 - 1c0: 9a a3 d8 4a d.mrm1s2.dd %f20,%f22,%f24 - 1c4: 00 00 00 a0 shl %r0,%r0,%r0 - 1c8: 1b 9a 95 4a d.mm12ttsm.ss %f19,%f20,%f21 - 1cc: 00 00 00 a0 shl %r0,%r0,%r0 - 1d0: 9b ea df 4b d.mm12ttsm.sd %f29,%f30,%f31 - 1d4: 00 00 00 a0 shl %r0,%r0,%r0 - 1d8: 9b b3 1a 4b d.mm12ttsm.dd %f22,%f24,%f26 - 1dc: 00 00 00 a0 shl %r0,%r0,%r0 - 1e0: 1c a2 b6 4a d.mimt1s2.ss %f20,%f21,%f22 - 1e4: 00 00 00 a0 shl %r0,%r0,%r0 - 1e8: 9c 02 22 48 d.mimt1s2.sd %f0,%f1,%f2 - 1ec: 00 00 00 a0 shl %r0,%r0,%r0 - 1f0: 9c c3 5c 4b d.mimt1s2.dd %f24,%f26,%f28 - 1f4: 00 00 00 a0 shl %r0,%r0,%r0 - 1f8: 1d aa d7 4a d.mm12tsm.ss %f21,%f22,%f23 - 1fc: 00 00 00 a0 shl %r0,%r0,%r0 - 200: 9d 1a 85 48 d.mm12tsm.sd %f3,%f4,%f5 - 204: 00 00 00 a0 shl %r0,%r0,%r0 - 208: 9d f3 02 48 d.mm12tsm.dd %f30,%f0,%f2 - 20c: 00 00 00 a0 shl %r0,%r0,%r0 - 210: 1e b2 f8 4a d.mim1s2.ss %f22,%f23,%f24 - 214: 00 00 00 a0 shl %r0,%r0,%r0 - 218: 9e 32 e8 48 d.mim1s2.sd %f6,%f7,%f8 - 21c: 00 00 00 a0 shl %r0,%r0,%r0 - 220: 9e 23 c8 48 d.mim1s2.dd %f4,%f6,%f8 - 224: 00 00 00 a0 shl %r0,%r0,%r0 - 228: 1f be 19 4b d.m12tsa.ss %f23,%f24,%f25 - 22c: 00 00 00 a0 shl %r0,%r0,%r0 - 230: 9f 4e 4b 49 d.m12tsa.sd %f9,%f10,%f11 - 234: 00 00 00 a0 shl %r0,%r0,%r0 - 238: 9f 37 0a 49 d.m12tsa.dd %f6,%f8,%f10 - 23c: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/pfmsm.s b/gas/testsuite/gas/i860/pfmsm.s deleted file mode 100644 index 26c9166..0000000 --- a/gas/testsuite/gas/i860/pfmsm.s +++ /dev/null @@ -1,182 +0,0 @@ -# pfmsm.p family (p={ss,sd,dd}) - - .text - - # pfmsm without dual bit - mr2s1.ss %f0,%f1,%f2 - mr2s1.sd %f3,%f4,%f5 - mr2s1.dd %f0,%f2,%f4 - - mr2st.ss %f1,%f2,%f3 - mr2st.sd %f4,%f5,%f6 - mr2st.dd %f2,%f4,%f6 - - mr2ms1.ss %f2,%f3,%f4 - mr2ms1.sd %f6,%f7,%f8 - mr2ms1.dd %f4,%f6,%f8 - - mr2mst.ss %f3,%f4,%f5 - mr2mst.sd %f7,%f8,%f9 - mr2mst.dd %f6,%f8,%f10 - - mi2s1.ss %f4,%f5,%f6 - mi2s1.sd %f8,%f9,%f10 - mi2s1.dd %f12,%f14,%f16 - - mi2st.ss %f7,%f8,%f9 - mi2st.sd %f11,%f12,%f13 - mi2st.dd %f14,%f16,%f18 - - mi2ms1.ss %f10,%f11,%f12 - mi2ms1.sd %f14,%f15,%f16 - mi2ms1.dd %f16,%f18,%f20 - - mi2mst.ss %f13,%f14,%f15 - mi2mst.sd %f17,%f18,%f19 - mi2mst.dd %f18,%f20,%f22 - - mrmt1s2.ss %f14,%f15,%f16 - mrmt1s2.sd %f20,%f21,%f22 - mrmt1s2.dd %f20,%f22,%f24 - - mm12msm.ss %f15,%f16,%f17 - mm12msm.sd %f23,%f24,%f25 - mm12msm.dd %f22,%f24,%f26 - - mrm1s2.ss %f18,%f19,%f20 - mrm1s2.sd %f26,%f27,%f28 - mrm1s2.dd %f20,%f22,%f24 - - mm12ttsm.ss %f19,%f20,%f21 - mm12ttsm.sd %f29,%f30,%f31 - mm12ttsm.dd %f22,%f24,%f26 - - mimt1s2.ss %f20,%f21,%f22 - mimt1s2.sd %f0,%f1,%f2 - mimt1s2.dd %f24,%f26,%f28 - - mm12tsm.ss %f21,%f22,%f23 - mm12tsm.sd %f3,%f4,%f5 - mm12tsm.dd %f30,%f0,%f2 - - mim1s2.ss %f22,%f23,%f24 - mim1s2.sd %f6,%f7,%f8 - mim1s2.dd %f4,%f6,%f8 - - m12tsa.ss %f23,%f24,%f25 - m12tsa.sd %f9,%f10,%f11 - m12tsa.dd %f6,%f8,%f10 - - # pfmsm with dual bit - d.mr2s1.ss %f0,%f1,%f2 - nop - d.mr2s1.sd %f3,%f4,%f5 - nop - d.mr2s1.dd %f0,%f2,%f4 - nop - - d.mr2st.ss %f1,%f2,%f3 - nop - d.mr2st.sd %f4,%f5,%f6 - nop - d.mr2st.dd %f2,%f4,%f6 - nop - - d.mr2ms1.ss %f2,%f3,%f4 - nop - d.mr2ms1.sd %f6,%f7,%f8 - nop - d.mr2ms1.dd %f4,%f6,%f8 - nop - - d.mr2mst.ss %f3,%f4,%f5 - nop - d.mr2mst.sd %f7,%f8,%f9 - nop - d.mr2mst.dd %f6,%f8,%f10 - nop - - d.mi2s1.ss %f4,%f5,%f6 - nop - d.mi2s1.sd %f8,%f9,%f10 - nop - d.mi2s1.dd %f12,%f14,%f16 - nop - - d.mi2st.ss %f7,%f8,%f9 - nop - d.mi2st.sd %f11,%f12,%f13 - nop - d.mi2st.dd %f14,%f16,%f18 - nop - - d.mi2ms1.ss %f10,%f11,%f12 - nop - d.mi2ms1.sd %f14,%f15,%f16 - nop - d.mi2ms1.dd %f16,%f18,%f20 - nop - - d.mi2mst.ss %f13,%f14,%f15 - nop - d.mi2mst.sd %f17,%f18,%f19 - nop - d.mi2mst.dd %f18,%f20,%f22 - nop - - d.mrmt1s2.ss %f14,%f15,%f16 - nop - d.mrmt1s2.sd %f20,%f21,%f22 - nop - d.mrmt1s2.dd %f20,%f22,%f24 - nop - - d.mm12msm.ss %f15,%f16,%f17 - nop - d.mm12msm.sd %f23,%f24,%f25 - nop - d.mm12msm.dd %f22,%f24,%f26 - nop - - d.mrm1s2.ss %f18,%f19,%f20 - nop - d.mrm1s2.sd %f26,%f27,%f28 - nop - d.mrm1s2.dd %f20,%f22,%f24 - nop - - d.mm12ttsm.ss %f19,%f20,%f21 - nop - d.mm12ttsm.sd %f29,%f30,%f31 - nop - d.mm12ttsm.dd %f22,%f24,%f26 - nop - - d.mimt1s2.ss %f20,%f21,%f22 - nop - d.mimt1s2.sd %f0,%f1,%f2 - nop - d.mimt1s2.dd %f24,%f26,%f28 - nop - - d.mm12tsm.ss %f21,%f22,%f23 - nop - d.mm12tsm.sd %f3,%f4,%f5 - nop - d.mm12tsm.dd %f30,%f0,%f2 - nop - - d.mim1s2.ss %f22,%f23,%f24 - nop - d.mim1s2.sd %f6,%f7,%f8 - nop - d.mim1s2.dd %f4,%f6,%f8 - nop - - d.m12tsa.ss %f23,%f24,%f25 - nop - d.m12tsa.sd %f9,%f10,%f11 - nop - d.m12tsa.dd %f6,%f8,%f10 - nop - diff --git a/gas/testsuite/gas/i860/pfsm.d b/gas/testsuite/gas/i860/pfsm.d deleted file mode 100644 index a3655cb..0000000 --- a/gas/testsuite/gas/i860/pfsm.d +++ /dev/null @@ -1,153 +0,0 @@ -#as: -#objdump: -dr -#name: i860 pfsm - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 10 04 22 48 r2s1.ss %f0,%f1,%f2 - 4: 90 1c 85 48 r2s1.sd %f3,%f4,%f5 - 8: 90 05 44 48 r2s1.dd %f0,%f2,%f4 - c: 11 0c 43 48 r2st.ss %f1,%f2,%f3 - 10: 91 24 a6 48 r2st.sd %f4,%f5,%f6 - 14: 91 15 86 48 r2st.dd %f2,%f4,%f6 - 18: 12 14 64 48 r2as1.ss %f2,%f3,%f4 - 1c: 92 34 e8 48 r2as1.sd %f6,%f7,%f8 - 20: 92 25 c8 48 r2as1.dd %f4,%f6,%f8 - 24: 13 1c 85 48 r2ast.ss %f3,%f4,%f5 - 28: 93 3c 09 49 r2ast.sd %f7,%f8,%f9 - 2c: 93 35 0a 49 r2ast.dd %f6,%f8,%f10 - 30: 14 24 a6 48 i2s1.ss %f4,%f5,%f6 - 34: 94 44 2a 49 i2s1.sd %f8,%f9,%f10 - 38: 94 65 d0 49 i2s1.dd %f12,%f14,%f16 - 3c: 15 3c 09 49 i2st.ss %f7,%f8,%f9 - 40: 95 5c 8d 49 i2st.sd %f11,%f12,%f13 - 44: 95 75 12 4a i2st.dd %f14,%f16,%f18 - 48: 16 54 6c 49 i2as1.ss %f10,%f11,%f12 - 4c: 96 74 f0 49 i2as1.sd %f14,%f15,%f16 - 50: 96 85 54 4a i2as1.dd %f16,%f18,%f20 - 54: 17 6c cf 49 i2ast.ss %f13,%f14,%f15 - 58: 97 8c 53 4a i2ast.sd %f17,%f18,%f19 - 5c: 97 95 96 4a i2ast.dd %f18,%f20,%f22 - 60: 18 74 f0 49 rat1s2.ss %f14,%f15,%f16 - 64: 98 a4 b6 4a rat1s2.sd %f20,%f21,%f22 - 68: 98 a5 d8 4a rat1s2.dd %f20,%f22,%f24 - 6c: 19 7c 11 4a m12asm.ss %f15,%f16,%f17 - 70: 99 bc 19 4b m12asm.sd %f23,%f24,%f25 - 74: 99 b5 1a 4b m12asm.dd %f22,%f24,%f26 - 78: 1a 94 74 4a ra1s2.ss %f18,%f19,%f20 - 7c: 9a d4 7c 4b ra1s2.sd %f26,%f27,%f28 - 80: 9a a5 d8 4a ra1s2.dd %f20,%f22,%f24 - 84: 1b 9c 95 4a m12ttsa.ss %f19,%f20,%f21 - 88: 9b ec df 4b m12ttsa.sd %f29,%f30,%f31 - 8c: 9b b5 1a 4b m12ttsa.dd %f22,%f24,%f26 - 90: 1c a4 b6 4a iat1s2.ss %f20,%f21,%f22 - 94: 9c 04 22 48 iat1s2.sd %f0,%f1,%f2 - 98: 9c c5 5c 4b iat1s2.dd %f24,%f26,%f28 - 9c: 1d ac d7 4a m12tsm.ss %f21,%f22,%f23 - a0: 9d 1c 85 48 m12tsm.sd %f3,%f4,%f5 - a4: 9d f5 02 48 m12tsm.dd %f30,%f0,%f2 - a8: 1e b4 f8 4a ia1s2.ss %f22,%f23,%f24 - ac: 9e 34 e8 48 ia1s2.sd %f6,%f7,%f8 - b0: 9e 25 c8 48 ia1s2.dd %f4,%f6,%f8 - b4: 1f bc 19 4b m12tsa.ss %f23,%f24,%f25 - b8: 9f 4c 4b 49 m12tsa.sd %f9,%f10,%f11 - bc: 9f 35 0a 49 m12tsa.dd %f6,%f8,%f10 - c0: 10 06 22 48 d.r2s1.ss %f0,%f1,%f2 - c4: 00 00 00 a0 shl %r0,%r0,%r0 - c8: 90 1e 85 48 d.r2s1.sd %f3,%f4,%f5 - cc: 00 00 00 a0 shl %r0,%r0,%r0 - d0: 90 07 44 48 d.r2s1.dd %f0,%f2,%f4 - d4: 00 00 00 a0 shl %r0,%r0,%r0 - d8: 11 0e 43 48 d.r2st.ss %f1,%f2,%f3 - dc: 00 00 00 a0 shl %r0,%r0,%r0 - e0: 91 26 a6 48 d.r2st.sd %f4,%f5,%f6 - e4: 00 00 00 a0 shl %r0,%r0,%r0 - e8: 91 17 86 48 d.r2st.dd %f2,%f4,%f6 - ec: 00 00 00 a0 shl %r0,%r0,%r0 - f0: 12 16 64 48 d.r2as1.ss %f2,%f3,%f4 - f4: 00 00 00 a0 shl %r0,%r0,%r0 - f8: 92 36 e8 48 d.r2as1.sd %f6,%f7,%f8 - fc: 00 00 00 a0 shl %r0,%r0,%r0 - 100: 92 27 c8 48 d.r2as1.dd %f4,%f6,%f8 - 104: 00 00 00 a0 shl %r0,%r0,%r0 - 108: 13 1e 85 48 d.r2ast.ss %f3,%f4,%f5 - 10c: 00 00 00 a0 shl %r0,%r0,%r0 - 110: 93 3e 09 49 d.r2ast.sd %f7,%f8,%f9 - 114: 00 00 00 a0 shl %r0,%r0,%r0 - 118: 93 37 0a 49 d.r2ast.dd %f6,%f8,%f10 - 11c: 00 00 00 a0 shl %r0,%r0,%r0 - 120: 14 26 a6 48 d.i2s1.ss %f4,%f5,%f6 - 124: 00 00 00 a0 shl %r0,%r0,%r0 - 128: 94 46 2a 49 d.i2s1.sd %f8,%f9,%f10 - 12c: 00 00 00 a0 shl %r0,%r0,%r0 - 130: 94 67 d0 49 d.i2s1.dd %f12,%f14,%f16 - 134: 00 00 00 a0 shl %r0,%r0,%r0 - 138: 15 3e 09 49 d.i2st.ss %f7,%f8,%f9 - 13c: 00 00 00 a0 shl %r0,%r0,%r0 - 140: 95 5e 8d 49 d.i2st.sd %f11,%f12,%f13 - 144: 00 00 00 a0 shl %r0,%r0,%r0 - 148: 95 77 12 4a d.i2st.dd %f14,%f16,%f18 - 14c: 00 00 00 a0 shl %r0,%r0,%r0 - 150: 16 56 6c 49 d.i2as1.ss %f10,%f11,%f12 - 154: 00 00 00 a0 shl %r0,%r0,%r0 - 158: 96 76 f0 49 d.i2as1.sd %f14,%f15,%f16 - 15c: 00 00 00 a0 shl %r0,%r0,%r0 - 160: 96 87 54 4a d.i2as1.dd %f16,%f18,%f20 - 164: 00 00 00 a0 shl %r0,%r0,%r0 - 168: 17 6e cf 49 d.i2ast.ss %f13,%f14,%f15 - 16c: 00 00 00 a0 shl %r0,%r0,%r0 - 170: 97 8e 53 4a d.i2ast.sd %f17,%f18,%f19 - 174: 00 00 00 a0 shl %r0,%r0,%r0 - 178: 97 97 96 4a d.i2ast.dd %f18,%f20,%f22 - 17c: 00 00 00 a0 shl %r0,%r0,%r0 - 180: 18 76 f0 49 d.rat1s2.ss %f14,%f15,%f16 - 184: 00 00 00 a0 shl %r0,%r0,%r0 - 188: 98 a6 b6 4a d.rat1s2.sd %f20,%f21,%f22 - 18c: 00 00 00 a0 shl %r0,%r0,%r0 - 190: 98 a7 d8 4a d.rat1s2.dd %f20,%f22,%f24 - 194: 00 00 00 a0 shl %r0,%r0,%r0 - 198: 19 7e 11 4a d.m12asm.ss %f15,%f16,%f17 - 19c: 00 00 00 a0 shl %r0,%r0,%r0 - 1a0: 99 be 19 4b d.m12asm.sd %f23,%f24,%f25 - 1a4: 00 00 00 a0 shl %r0,%r0,%r0 - 1a8: 99 b7 1a 4b d.m12asm.dd %f22,%f24,%f26 - 1ac: 00 00 00 a0 shl %r0,%r0,%r0 - 1b0: 1a 96 74 4a d.ra1s2.ss %f18,%f19,%f20 - 1b4: 00 00 00 a0 shl %r0,%r0,%r0 - 1b8: 9a d6 7c 4b d.ra1s2.sd %f26,%f27,%f28 - 1bc: 00 00 00 a0 shl %r0,%r0,%r0 - 1c0: 9a a7 d8 4a d.ra1s2.dd %f20,%f22,%f24 - 1c4: 00 00 00 a0 shl %r0,%r0,%r0 - 1c8: 1b 9e 95 4a d.m12ttsa.ss %f19,%f20,%f21 - 1cc: 00 00 00 a0 shl %r0,%r0,%r0 - 1d0: 9b ee df 4b d.m12ttsa.sd %f29,%f30,%f31 - 1d4: 00 00 00 a0 shl %r0,%r0,%r0 - 1d8: 9b b7 1a 4b d.m12ttsa.dd %f22,%f24,%f26 - 1dc: 00 00 00 a0 shl %r0,%r0,%r0 - 1e0: 1c a6 b6 4a d.iat1s2.ss %f20,%f21,%f22 - 1e4: 00 00 00 a0 shl %r0,%r0,%r0 - 1e8: 9c 06 22 48 d.iat1s2.sd %f0,%f1,%f2 - 1ec: 00 00 00 a0 shl %r0,%r0,%r0 - 1f0: 9c c7 5c 4b d.iat1s2.dd %f24,%f26,%f28 - 1f4: 00 00 00 a0 shl %r0,%r0,%r0 - 1f8: 1d ae d7 4a d.m12tsm.ss %f21,%f22,%f23 - 1fc: 00 00 00 a0 shl %r0,%r0,%r0 - 200: 9d 1e 85 48 d.m12tsm.sd %f3,%f4,%f5 - 204: 00 00 00 a0 shl %r0,%r0,%r0 - 208: 9d f7 02 48 d.m12tsm.dd %f30,%f0,%f2 - 20c: 00 00 00 a0 shl %r0,%r0,%r0 - 210: 1e b6 f8 4a d.ia1s2.ss %f22,%f23,%f24 - 214: 00 00 00 a0 shl %r0,%r0,%r0 - 218: 9e 36 e8 48 d.ia1s2.sd %f6,%f7,%f8 - 21c: 00 00 00 a0 shl %r0,%r0,%r0 - 220: 9e 27 c8 48 d.ia1s2.dd %f4,%f6,%f8 - 224: 00 00 00 a0 shl %r0,%r0,%r0 - 228: 1f be 19 4b d.m12tsa.ss %f23,%f24,%f25 - 22c: 00 00 00 a0 shl %r0,%r0,%r0 - 230: 9f 4e 4b 49 d.m12tsa.sd %f9,%f10,%f11 - 234: 00 00 00 a0 shl %r0,%r0,%r0 - 238: 9f 37 0a 49 d.m12tsa.dd %f6,%f8,%f10 - 23c: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/pfsm.s b/gas/testsuite/gas/i860/pfsm.s deleted file mode 100644 index 16ecd97..0000000 --- a/gas/testsuite/gas/i860/pfsm.s +++ /dev/null @@ -1,182 +0,0 @@ -# pfsm.p family (p={ss,sd,dd}) - - .text - - # pfsm without dual bit - r2s1.ss %f0,%f1,%f2 - r2s1.sd %f3,%f4,%f5 - r2s1.dd %f0,%f2,%f4 - - r2st.ss %f1,%f2,%f3 - r2st.sd %f4,%f5,%f6 - r2st.dd %f2,%f4,%f6 - - r2as1.ss %f2,%f3,%f4 - r2as1.sd %f6,%f7,%f8 - r2as1.dd %f4,%f6,%f8 - - r2ast.ss %f3,%f4,%f5 - r2ast.sd %f7,%f8,%f9 - r2ast.dd %f6,%f8,%f10 - - i2s1.ss %f4,%f5,%f6 - i2s1.sd %f8,%f9,%f10 - i2s1.dd %f12,%f14,%f16 - - i2st.ss %f7,%f8,%f9 - i2st.sd %f11,%f12,%f13 - i2st.dd %f14,%f16,%f18 - - i2as1.ss %f10,%f11,%f12 - i2as1.sd %f14,%f15,%f16 - i2as1.dd %f16,%f18,%f20 - - i2ast.ss %f13,%f14,%f15 - i2ast.sd %f17,%f18,%f19 - i2ast.dd %f18,%f20,%f22 - - rat1s2.ss %f14,%f15,%f16 - rat1s2.sd %f20,%f21,%f22 - rat1s2.dd %f20,%f22,%f24 - - m12asm.ss %f15,%f16,%f17 - m12asm.sd %f23,%f24,%f25 - m12asm.dd %f22,%f24,%f26 - - ra1s2.ss %f18,%f19,%f20 - ra1s2.sd %f26,%f27,%f28 - ra1s2.dd %f20,%f22,%f24 - - m12ttsa.ss %f19,%f20,%f21 - m12ttsa.sd %f29,%f30,%f31 - m12ttsa.dd %f22,%f24,%f26 - - iat1s2.ss %f20,%f21,%f22 - iat1s2.sd %f0,%f1,%f2 - iat1s2.dd %f24,%f26,%f28 - - m12tsm.ss %f21,%f22,%f23 - m12tsm.sd %f3,%f4,%f5 - m12tsm.dd %f30,%f0,%f2 - - ia1s2.ss %f22,%f23,%f24 - ia1s2.sd %f6,%f7,%f8 - ia1s2.dd %f4,%f6,%f8 - - m12tsa.ss %f23,%f24,%f25 - m12tsa.sd %f9,%f10,%f11 - m12tsa.dd %f6,%f8,%f10 - - # pfsm with dual bit - d.r2s1.ss %f0,%f1,%f2 - nop - d.r2s1.sd %f3,%f4,%f5 - nop - d.r2s1.dd %f0,%f2,%f4 - nop - - d.r2st.ss %f1,%f2,%f3 - nop - d.r2st.sd %f4,%f5,%f6 - nop - d.r2st.dd %f2,%f4,%f6 - nop - - d.r2as1.ss %f2,%f3,%f4 - nop - d.r2as1.sd %f6,%f7,%f8 - nop - d.r2as1.dd %f4,%f6,%f8 - nop - - d.r2ast.ss %f3,%f4,%f5 - nop - d.r2ast.sd %f7,%f8,%f9 - nop - d.r2ast.dd %f6,%f8,%f10 - nop - - d.i2s1.ss %f4,%f5,%f6 - nop - d.i2s1.sd %f8,%f9,%f10 - nop - d.i2s1.dd %f12,%f14,%f16 - nop - - d.i2st.ss %f7,%f8,%f9 - nop - d.i2st.sd %f11,%f12,%f13 - nop - d.i2st.dd %f14,%f16,%f18 - nop - - d.i2as1.ss %f10,%f11,%f12 - nop - d.i2as1.sd %f14,%f15,%f16 - nop - d.i2as1.dd %f16,%f18,%f20 - nop - - d.i2ast.ss %f13,%f14,%f15 - nop - d.i2ast.sd %f17,%f18,%f19 - nop - d.i2ast.dd %f18,%f20,%f22 - nop - - d.rat1s2.ss %f14,%f15,%f16 - nop - d.rat1s2.sd %f20,%f21,%f22 - nop - d.rat1s2.dd %f20,%f22,%f24 - nop - - d.m12asm.ss %f15,%f16,%f17 - nop - d.m12asm.sd %f23,%f24,%f25 - nop - d.m12asm.dd %f22,%f24,%f26 - nop - - d.ra1s2.ss %f18,%f19,%f20 - nop - d.ra1s2.sd %f26,%f27,%f28 - nop - d.ra1s2.dd %f20,%f22,%f24 - nop - - d.m12ttsa.ss %f19,%f20,%f21 - nop - d.m12ttsa.sd %f29,%f30,%f31 - nop - d.m12ttsa.dd %f22,%f24,%f26 - nop - - d.iat1s2.ss %f20,%f21,%f22 - nop - d.iat1s2.sd %f0,%f1,%f2 - nop - d.iat1s2.dd %f24,%f26,%f28 - nop - - d.m12tsm.ss %f21,%f22,%f23 - nop - d.m12tsm.sd %f3,%f4,%f5 - nop - d.m12tsm.dd %f30,%f0,%f2 - nop - - d.ia1s2.ss %f22,%f23,%f24 - nop - d.ia1s2.sd %f6,%f7,%f8 - nop - d.ia1s2.dd %f4,%f6,%f8 - nop - - d.m12tsa.ss %f23,%f24,%f25 - nop - d.m12tsa.sd %f9,%f10,%f11 - nop - d.m12tsa.dd %f6,%f8,%f10 - nop - diff --git a/gas/testsuite/gas/i860/pseudo-ops01.d b/gas/testsuite/gas/i860/pseudo-ops01.d deleted file mode 100644 index 3131e2e..0000000 --- a/gas/testsuite/gas/i860/pseudo-ops01.d +++ /dev/null @@ -1,14 +0,0 @@ -#as: -#objdump: -d -#name: i860 pseudo-ops01 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 49 28 06 48 fiadd\.ss %f5,%f0,%f6 - 4: c9 41 0a 48 fiadd\.dd %f8,%f0,%f10 - 8: b3 18 14 48 famov\.sd %f3,%f20 - c: 33 c1 09 48 famov\.ds %f24,%f9 - 10: 33 e5 03 48 pfamov\.ds %f28,%f3 diff --git a/gas/testsuite/gas/i860/pseudo-ops01.s b/gas/testsuite/gas/i860/pseudo-ops01.s deleted file mode 100644 index 4b88925..0000000 --- a/gas/testsuite/gas/i860/pseudo-ops01.s +++ /dev/null @@ -1,10 +0,0 @@ -# Test some assembler pseudo-operations: -# Floating point moves. - - .text - fmov.ss %f5,%f6 - fmov.dd %f8,%f10 - fmov.sd %f3,%f20 - fmov.ds %f24,%f9 - pfmov.ds %f28,%f3 - diff --git a/gas/testsuite/gas/i860/regress01.d b/gas/testsuite/gas/i860/regress01.d deleted file mode 100644 index 1ddfa4b..0000000 --- a/gas/testsuite/gas/i860/regress01.d +++ /dev/null @@ -1,21 +0,0 @@ -#as: -#objdump: -dr -#name: i860 regress01 - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: f2 ff 50 2c fst.l %f16,-16\(%sp\) - 4: f2 ff 54 2c fst.l %f20,-16\(%sp\) - 8: f2 ff 58 2c fst.l %f24,-16\(%sp\) - c: f3 ff 50 2c fst.l %f16,-16\(%sp\)\+\+ - 10: f3 ff 54 2c fst.l %f20,-16\(%sp\)\+\+ - 14: f3 ff 58 2c fst.l %f24,-16\(%sp\)\+\+ - 18: f4 ff 50 2c fst.q %f16,-16\(%sp\) - 1c: f4 ff 54 2c fst.q %f20,-16\(%sp\) - 20: f4 ff 58 2c fst.q %f24,-16\(%sp\) - 24: f5 ff 50 2c fst.q %f16,-16\(%sp\)\+\+ - 28: f5 ff 54 2c fst.q %f20,-16\(%sp\)\+\+ - 2c: f5 ff 58 2c fst.q %f24,-16\(%sp\)\+\+ diff --git a/gas/testsuite/gas/i860/regress01.s b/gas/testsuite/gas/i860/regress01.s deleted file mode 100644 index 002c3bd..0000000 --- a/gas/testsuite/gas/i860/regress01.s +++ /dev/null @@ -1,19 +0,0 @@ -# Test fst.* with and without auto-increment. - - .text - - fst.l %f16,-16(%sp) - fst.l %f20,-16(%sp) - fst.l %f24,-16(%sp) - - fst.l %f16,-16(%sp)++ - fst.l %f20,-16(%sp)++ - fst.l %f24,-16(%sp)++ - - fst.q %f16,-16(%sp) - fst.q %f20,-16(%sp) - fst.q %f24,-16(%sp) - - fst.q %f16,-16(%sp)++ - fst.q %f20,-16(%sp)++ - fst.q %f24,-16(%sp)++ diff --git a/gas/testsuite/gas/i860/shift.d b/gas/testsuite/gas/i860/shift.d deleted file mode 100644 index e48ba16..0000000 --- a/gas/testsuite/gas/i860/shift.d +++ /dev/null @@ -1,86 +0,0 @@ -#as: -#objdump: -dr -#name: i860 shift - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 22 a0 shl %r0,%r1,%sp - 4: 00 18 85 a0 shl %fp,%r4,%r5 - 8: 00 30 e8 a0 shl %r6,%r7,%r8 - c: 00 48 4b a1 shl %r9,%r10,%r11 - 10: 00 f8 ae a1 shl %r31,%r13,%r14 - 14: 00 78 11 a2 shl %r15,%r16,%r17 - 18: 00 90 74 a2 shl %r18,%r19,%r20 - 1c: 00 a8 d7 a2 shl %r21,%r22,%r23 - 20: 00 c0 3f a3 shl %r24,%r25,%r31 - 24: 00 d8 9d a3 shl %r27,%r28,%r29 - 28: 00 f0 e0 a3 shl %r30,%r31,%r0 - 2c: 00 00 22 a8 shr %r0,%r1,%sp - 30: 00 18 85 a8 shr %fp,%r4,%r5 - 34: 00 30 e8 a8 shr %r6,%r7,%r8 - 38: 00 48 4b a9 shr %r9,%r10,%r11 - 3c: 00 f8 ae a9 shr %r31,%r13,%r14 - 40: 00 78 11 aa shr %r15,%r16,%r17 - 44: 00 90 74 aa shr %r18,%r19,%r20 - 48: 00 a8 d7 aa shr %r21,%r22,%r23 - 4c: 00 c0 3f ab shr %r24,%r25,%r31 - 50: 00 d8 9d ab shr %r27,%r28,%r29 - 54: 00 f0 e0 ab shr %r30,%r31,%r0 - 58: 00 00 22 b8 shra %r0,%r1,%sp - 5c: 00 18 85 b8 shra %fp,%r4,%r5 - 60: 00 30 e8 b8 shra %r6,%r7,%r8 - 64: 00 48 4b b9 shra %r9,%r10,%r11 - 68: 00 f8 ae b9 shra %r31,%r13,%r14 - 6c: 00 78 11 ba shra %r15,%r16,%r17 - 70: 00 90 74 ba shra %r18,%r19,%r20 - 74: 00 a8 d7 ba shra %r21,%r22,%r23 - 78: 00 c0 3f bb shra %r24,%r25,%r31 - 7c: 00 d8 9d bb shra %r27,%r28,%r29 - 80: 00 f0 e0 bb shra %r30,%r31,%r0 - 84: 00 00 22 b0 shrd %r0,%r1,%sp - 88: 00 18 85 b0 shrd %fp,%r4,%r5 - 8c: 00 30 e8 b0 shrd %r6,%r7,%r8 - 90: 00 48 4b b1 shrd %r9,%r10,%r11 - 94: 00 f8 ae b1 shrd %r31,%r13,%r14 - 98: 00 78 11 b2 shrd %r15,%r16,%r17 - 9c: 00 90 74 b2 shrd %r18,%r19,%r20 - a0: 00 a8 d7 b2 shrd %r21,%r22,%r23 - a4: 00 c0 3f b3 shrd %r24,%r25,%r31 - a8: 00 d8 9d b3 shrd %r27,%r28,%r29 - ac: 00 f0 e0 b3 shrd %r30,%r31,%r0 - b0: 00 00 22 a4 shl 0,%r1,%sp - b4: 00 20 85 a4 shl 8192,%r4,%r5 - b8: f5 13 e8 a4 shl 5109,%r7,%r8 - bc: ff 7f 4b a5 shl 32767,%r10,%r11 - c0: 00 80 ae a5 shl -32768,%r13,%r14 - c4: 00 e0 11 a6 shl -8192,%r16,%r17 - c8: ff ff 74 a6 shl -1,%r19,%r20 - cc: cd ab d7 a6 shl -21555,%r22,%r23 - d0: 34 12 3a a7 shl 4660,%r25,%r26 - d4: 00 00 9d a7 shl 0,%r28,%r29 - d8: 03 00 e0 a7 shl 3,%r31,%r0 - dc: 00 00 22 ac shr 0,%r1,%sp - e0: 00 20 85 ac shr 8192,%r4,%r5 - e4: f5 13 e8 ac shr 5109,%r7,%r8 - e8: ff 7f 4b ad shr 32767,%r10,%r11 - ec: 00 80 ae ad shr -32768,%r13,%r14 - f0: 00 e0 11 ae shr -8192,%r16,%r17 - f4: ff ff 74 ae shr -1,%r19,%r20 - f8: cd ab d7 ae shr -21555,%r22,%r23 - fc: 34 12 3a af shr 4660,%r25,%r26 - 100: 00 00 9d af shr 0,%r28,%r29 - 104: 03 00 e0 af shr 3,%r31,%r0 - 108: 01 00 22 bc shra 1,%r1,%sp - 10c: 01 20 85 bc shra 8193,%r4,%r5 - 110: f6 13 e8 bc shra 5110,%r7,%r8 - 114: ff 7f 4b bd shra 32767,%r10,%r11 - 118: 00 80 ae bd shra -32768,%r13,%r14 - 11c: 00 e0 11 be shra -8192,%r16,%r17 - 120: ff ff 74 be shra -1,%r19,%r20 - 124: cd ab d7 be shra -21555,%r22,%r23 - 128: 34 12 3a bf shra 4660,%r25,%r26 - 12c: 00 00 9d bf shra 0,%r28,%r29 - 130: 03 00 e0 bf shra 3,%r31,%r0 diff --git a/gas/testsuite/gas/i860/shift.s b/gas/testsuite/gas/i860/shift.s deleted file mode 100644 index 0d0d189..0000000 --- a/gas/testsuite/gas/i860/shift.s +++ /dev/null @@ -1,90 +0,0 @@ -# shl, shr, shra, shrd - - .text - - # Register forms (all) - shl %r0,%r1,%r2 - shl %r3,%r4,%r5 - shl %r6,%r7,%r8 - shl %r9,%r10,%r11 - shl %r31,%r13,%r14 - shl %r15,%r16,%r17 - shl %r18,%r19,%r20 - shl %r21,%r22,%r23 - shl %r24,%r25,%r31 - shl %r27,%r28,%r29 - shl %r30,%r31,%r0 - - shr %r0,%r1,%r2 - shr %r3,%r4,%r5 - shr %r6,%r7,%r8 - shr %r9,%r10,%r11 - shr %r31,%r13,%r14 - shr %r15,%r16,%r17 - shr %r18,%r19,%r20 - shr %r21,%r22,%r23 - shr %r24,%r25,%r31 - shr %r27,%r28,%r29 - shr %r30,%r31,%r0 - - shra %r0,%r1,%r2 - shra %r3,%r4,%r5 - shra %r6,%r7,%r8 - shra %r9,%r10,%r11 - shra %r31,%r13,%r14 - shra %r15,%r16,%r17 - shra %r18,%r19,%r20 - shra %r21,%r22,%r23 - shra %r24,%r25,%r31 - shra %r27,%r28,%r29 - shra %r30,%r31,%r0 - - shrd %r0,%r1,%r2 - shrd %r3,%r4,%r5 - shrd %r6,%r7,%r8 - shrd %r9,%r10,%r11 - shrd %r31,%r13,%r14 - shrd %r15,%r16,%r17 - shrd %r18,%r19,%r20 - shrd %r21,%r22,%r23 - shrd %r24,%r25,%r31 - shrd %r27,%r28,%r29 - shrd %r30,%r31,%r0 - - # Immediate forms (shrd does not have an immediate form) - shl 0,%r1,%r2 - shl 8192,%r4,%r5 - shl 5109,%r7,%r8 - shl 32767,%r10,%r11 - shl -32768,%r13,%r14 - shl -8192,%r16,%r17 - shl -1,%r19,%r20 - shl -21555,%r22,%r23 - shl 0x1234,%r25,%r26 - shl 0x0,%r28,%r29 - shl 0x3,%r31,%r0 - - shr 0,%r1,%r2 - shr 8192,%r4,%r5 - shr 5109,%r7,%r8 - shr 32767,%r10,%r11 - shr -32768,%r13,%r14 - shr -8192,%r16,%r17 - shr -1,%r19,%r20 - shr -21555,%r22,%r23 - shr 0x1234,%r25,%r26 - shr 0x0,%r28,%r29 - shr 0x3,%r31,%r0 - - shra 1,%r1,%r2 - shra 8193,%r4,%r5 - shra 5110,%r7,%r8 - shra 32767,%r10,%r11 - shra -32768,%r13,%r14 - shra -8192,%r16,%r17 - shra -1,%r19,%r20 - shra -21555,%r22,%r23 - shra 0x1234,%r25,%r26 - shra 0x0,%r28,%r29 - shra 0x3,%r31,%r0 - diff --git a/gas/testsuite/gas/i860/simd.d b/gas/testsuite/gas/i860/simd.d deleted file mode 100644 index 2885196..0000000 --- a/gas/testsuite/gas/i860/simd.d +++ /dev/null @@ -1,105 +0,0 @@ -#as: -#objdump: -dr -#name: i860 simd - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: d7 05 48 48 pfzchkl %f0,%f2,%f8 - 4: d7 15 90 48 pfzchkl %f2,%f4,%f16 - 8: d7 25 cd 48 pfzchkl %f4,%f6,%f13 - c: d7 45 52 49 pfzchkl %f8,%f10,%f18 - 10: df 65 de 49 pfzchks %f12,%f14,%f30 - 14: df 85 54 4a pfzchks %f16,%f18,%f20 - 18: df a5 dc 4a pfzchks %f20,%f22,%f28 - 1c: df c5 5e 4b pfzchks %f24,%f26,%f30 - 20: d0 05 48 48 pfaddp %f0,%f2,%f8 - 24: d0 15 90 48 pfaddp %f2,%f4,%f16 - 28: d0 25 cd 48 pfaddp %f4,%f6,%f13 - 2c: d0 45 52 49 pfaddp %f8,%f10,%f18 - 30: d1 65 de 49 pfaddz %f12,%f14,%f30 - 34: d1 85 54 4a pfaddz %f16,%f18,%f20 - 38: d1 a5 dc 4a pfaddz %f20,%f22,%f28 - 3c: d1 c5 5e 4b pfaddz %f24,%f26,%f30 - 40: d7 61 44 48 fzchkl %f12,%f2,%f4 - 44: d7 b1 82 48 fzchkl %f22,%f4,%f2 - 48: d7 21 d2 48 fzchkl %f4,%f6,%f18 - 4c: d7 41 5c 49 fzchkl %f8,%f10,%f28 - 50: df 61 c6 49 fzchks %f12,%f14,%f6 - 54: df 81 54 4a fzchks %f16,%f18,%f20 - 58: df a1 dc 4a fzchks %f20,%f22,%f28 - 5c: df c1 5e 4b fzchks %f24,%f26,%f30 - 60: d0 61 44 48 faddp %f12,%f2,%f4 - 64: d0 b1 82 48 faddp %f22,%f4,%f2 - 68: d0 21 d2 48 faddp %f4,%f6,%f18 - 6c: d0 41 5c 49 faddp %f8,%f10,%f28 - 70: d1 61 c6 49 faddz %f12,%f14,%f6 - 74: d1 81 54 4a faddz %f16,%f18,%f20 - 78: d1 a1 dc 4a faddz %f20,%f22,%f28 - 7c: d1 c1 5e 4b faddz %f24,%f26,%f30 - 80: d7 07 52 48 d.pfzchkl %f0,%f2,%f18 - 84: 00 00 00 a0 shl %r0,%r0,%r0 - 88: d7 17 8c 48 d.pfzchkl %f2,%f4,%f12 - 8c: 00 00 00 a0 shl %r0,%r0,%r0 - 90: d7 27 de 48 d.pfzchkl %f4,%f6,%f30 - 94: 00 00 00 a0 shl %r0,%r0,%r0 - 98: d7 47 44 49 d.pfzchkl %f8,%f10,%f4 - 9c: 00 00 00 a0 shl %r0,%r0,%r0 - a0: df 67 ce 49 d.pfzchks %f12,%f14,%f14 - a4: 00 00 00 a0 shl %r0,%r0,%r0 - a8: df 87 46 4a d.pfzchks %f16,%f18,%f6 - ac: 00 00 00 a0 shl %r0,%r0,%r0 - b0: df a7 ca 4a d.pfzchks %f20,%f22,%f10 - b4: 00 00 00 a0 shl %r0,%r0,%r0 - b8: df c7 48 4b d.pfzchks %f24,%f26,%f8 - bc: 00 00 00 a0 shl %r0,%r0,%r0 - c0: d0 07 52 48 d.pfaddp %f0,%f2,%f18 - c4: 00 00 00 a0 shl %r0,%r0,%r0 - c8: d0 17 80 48 d.pfaddp %f2,%f4,%f0 - cc: 00 00 00 a0 shl %r0,%r0,%r0 - d0: d0 27 de 48 d.pfaddp %f4,%f6,%f30 - d4: 00 00 00 a0 shl %r0,%r0,%r0 - d8: d0 47 44 49 d.pfaddp %f8,%f10,%f4 - dc: 00 00 00 a0 shl %r0,%r0,%r0 - e0: d1 67 ce 49 d.pfaddz %f12,%f14,%f14 - e4: 00 00 00 a0 shl %r0,%r0,%r0 - e8: d1 87 46 4a d.pfaddz %f16,%f18,%f6 - ec: 00 00 00 a0 shl %r0,%r0,%r0 - f0: d1 a7 ca 4a d.pfaddz %f20,%f22,%f10 - f4: 00 00 00 a0 shl %r0,%r0,%r0 - f8: d1 c7 48 4b d.pfaddz %f24,%f26,%f8 - fc: 00 00 00 a0 shl %r0,%r0,%r0 - 100: d7 03 4a 48 d.fzchkl %f0,%f2,%f10 - 104: 00 00 00 a0 shl %r0,%r0,%r0 - 108: d7 13 92 48 d.fzchkl %f2,%f4,%f18 - 10c: 00 00 00 a0 shl %r0,%r0,%r0 - 110: d7 23 cc 48 d.fzchkl %f4,%f6,%f12 - 114: 00 00 00 a0 shl %r0,%r0,%r0 - 118: d7 43 4e 49 d.fzchkl %f8,%f10,%f14 - 11c: 00 00 00 a0 shl %r0,%r0,%r0 - 120: df 63 d0 49 d.fzchks %f12,%f14,%f16 - 124: 00 00 00 a0 shl %r0,%r0,%r0 - 128: df 83 4c 4a d.fzchks %f16,%f18,%f12 - 12c: 00 00 00 a0 shl %r0,%r0,%r0 - 130: df a3 d0 4a d.fzchks %f20,%f22,%f16 - 134: 00 00 00 a0 shl %r0,%r0,%r0 - 138: df c3 5e 4b d.fzchks %f24,%f26,%f30 - 13c: 00 00 00 a0 shl %r0,%r0,%r0 - 140: d0 03 4a 48 d.faddp %f0,%f2,%f10 - 144: 00 00 00 a0 shl %r0,%r0,%r0 - 148: d0 13 92 48 d.faddp %f2,%f4,%f18 - 14c: 00 00 00 a0 shl %r0,%r0,%r0 - 150: d0 23 cc 48 d.faddp %f4,%f6,%f12 - 154: 00 00 00 a0 shl %r0,%r0,%r0 - 158: d0 43 4e 49 d.faddp %f8,%f10,%f14 - 15c: 00 00 00 a0 shl %r0,%r0,%r0 - 160: d1 63 d0 49 d.faddz %f12,%f14,%f16 - 164: 00 00 00 a0 shl %r0,%r0,%r0 - 168: d1 83 4c 4a d.faddz %f16,%f18,%f12 - 16c: 00 00 00 a0 shl %r0,%r0,%r0 - 170: d1 a3 d0 4a d.faddz %f20,%f22,%f16 - 174: 00 00 00 a0 shl %r0,%r0,%r0 - 178: d1 c3 5e 4b d.faddz %f24,%f26,%f30 - 17c: 00 00 00 a0 shl %r0,%r0,%r0 diff --git a/gas/testsuite/gas/i860/simd.s b/gas/testsuite/gas/i860/simd.s deleted file mode 100644 index 4f252dd..0000000 --- a/gas/testsuite/gas/i860/simd.s +++ /dev/null @@ -1,119 +0,0 @@ -# fzchkl, fzchks, faddp, faddz - - .text - - # Pipelined, without dual bit - pfzchkl %f0,%f2,%f8 - pfzchkl %f2,%f4,%f16 - pfzchkl %f4,%f6,%f13 - pfzchkl %f8,%f10,%f18 - - pfzchks %f12,%f14,%f30 - pfzchks %f16,%f18,%f20 - pfzchks %f20,%f22,%f28 - pfzchks %f24,%f26,%f30 - - pfaddp %f0,%f2,%f8 - pfaddp %f2,%f4,%f16 - pfaddp %f4,%f6,%f13 - pfaddp %f8,%f10,%f18 - - pfaddz %f12,%f14,%f30 - pfaddz %f16,%f18,%f20 - pfaddz %f20,%f22,%f28 - pfaddz %f24,%f26,%f30 - - # Non-pipelined, without dual bit - fzchkl %f12,%f2,%f4 - fzchkl %f22,%f4,%f2 - fzchkl %f4,%f6,%f18 - fzchkl %f8,%f10,%f28 - - fzchks %f12,%f14,%f6 - fzchks %f16,%f18,%f20 - fzchks %f20,%f22,%f28 - fzchks %f24,%f26,%f30 - - faddp %f12,%f2,%f4 - faddp %f22,%f4,%f2 - faddp %f4,%f6,%f18 - faddp %f8,%f10,%f28 - - faddz %f12,%f14,%f6 - faddz %f16,%f18,%f20 - faddz %f20,%f22,%f28 - faddz %f24,%f26,%f30 - - # Pipelined, with dual bit - d.pfzchkl %f0,%f2,%f18 - nop - d.pfzchkl %f2,%f4,%f12 - nop - d.pfzchkl %f4,%f6,%f30 - nop - d.pfzchkl %f8,%f10,%f4 - nop - - d.pfzchks %f12,%f14,%f14 - nop - d.pfzchks %f16,%f18,%f6 - nop - d.pfzchks %f20,%f22,%f10 - nop - d.pfzchks %f24,%f26,%f8 - nop - - d.pfaddp %f0,%f2,%f18 - nop - d.pfaddp %f2,%f4,%f0 - nop - d.pfaddp %f4,%f6,%f30 - nop - d.pfaddp %f8,%f10,%f4 - nop - - d.pfaddz %f12,%f14,%f14 - nop - d.pfaddz %f16,%f18,%f6 - nop - d.pfaddz %f20,%f22,%f10 - nop - d.pfaddz %f24,%f26,%f8 - nop - - # Non-pipelined, with dual bit - d.fzchkl %f0,%f2,%f10 - nop - d.fzchkl %f2,%f4,%f18 - nop - d.fzchkl %f4,%f6,%f12 - nop - d.fzchkl %f8,%f10,%f14 - nop - - d.fzchks %f12,%f14,%f16 - nop - d.fzchks %f16,%f18,%f12 - nop - d.fzchks %f20,%f22,%f16 - nop - d.fzchks %f24,%f26,%f30 - nop - - d.faddp %f0,%f2,%f10 - nop - d.faddp %f2,%f4,%f18 - nop - d.faddp %f4,%f6,%f12 - nop - d.faddp %f8,%f10,%f14 - nop - - d.faddz %f12,%f14,%f16 - nop - d.faddz %f16,%f18,%f12 - nop - d.faddz %f20,%f22,%f16 - nop - d.faddz %f24,%f26,%f30 - nop diff --git a/gas/testsuite/gas/i860/system.d b/gas/testsuite/gas/i860/system.d deleted file mode 100644 index a797961..0000000 --- a/gas/testsuite/gas/i860/system.d +++ /dev/null @@ -1,72 +0,0 @@ -#as: -#objdump: -dr -#name: i860 system - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 01 00 00 4c lock - 4: 07 00 00 4c unlock - 8: 04 00 00 4c intovr - c: 00 00 00 44 trap %r0,%r0,%r0 - 10: 00 f8 ff 47 trap %r31,%r31,%r31 - 14: 00 08 b2 44 trap %r1,%r5,%r18 - 18: 00 f8 86 46 trap %r31,%r20,%r6 - 1c: 00 00 01 30 ld.c %fir,%r1 - 20: 00 00 1f 30 ld.c %fir,%r31 - 24: 00 00 25 30 ld.c %psr,%r5 - 28: 00 00 3e 30 ld.c %psr,%r30 - 2c: 00 00 4a 30 ld.c %dirbase,%r10 - 30: 00 00 42 30 ld.c %dirbase,%sp - 34: 00 00 75 30 ld.c %db,%r21 - 38: 00 00 60 30 ld.c %db,%r0 - 3c: 00 00 9c 30 ld.c %fsr,%r28 - 40: 00 00 8c 30 ld.c %fsr,%r12 - 44: 00 00 bf 30 ld.c %epsr,%r31 - 48: 00 00 a6 30 ld.c %epsr,%r6 - 4c: 00 00 00 38 st.c %r0,%fir - 50: 00 f0 00 38 st.c %r30,%fir - 54: 00 38 20 38 st.c %r7,%psr - 58: 00 f8 20 38 st.c %r31,%psr - 5c: 00 58 40 38 st.c %r11,%dirbase - 60: 00 18 40 38 st.c %fp,%dirbase - 64: 00 b0 60 38 st.c %r22,%db - 68: 00 78 60 38 st.c %r15,%db - 6c: 00 e8 80 38 st.c %r29,%fsr - 70: 00 68 80 38 st.c %r13,%fsr - 74: 00 20 a0 38 st.c %r4,%epsr - 78: 00 30 a0 38 st.c %r6,%epsr - 7c: 04 00 00 34 flush 0\(%r0\) - 80: 84 00 20 34 flush 128\(%r1\) - 84: 04 01 40 34 flush 256\(%sp\) - 88: 04 02 60 34 flush 512\(%fp\) - 8c: 04 04 80 34 flush 1024\(%r4\) - 90: 04 10 a0 34 flush 4096\(%r5\) - 94: 04 20 c0 34 flush 8192\(%r6\) - 98: 04 40 e0 34 flush 16384\(%r7\) - 9c: 04 c0 00 35 flush -16384\(%r8\) - a0: 04 e0 20 35 flush -8192\(%r9\) - a4: 04 f0 40 35 flush -4096\(%r10\) - a8: 04 fc 60 35 flush -1024\(%r11\) - ac: 04 fe 80 35 flush -512\(%r12\) - b0: 0c ff a0 35 flush -248\(%r13\) - b4: e4 ff c0 35 flush -32\(%r14\) - b8: f4 ff c0 35 flush -16\(%r14\) - bc: 05 00 00 34 flush 0\(%r0\)\+\+ - c0: 85 00 20 34 flush 128\(%r1\)\+\+ - c4: 05 01 40 34 flush 256\(%sp\)\+\+ - c8: 05 02 60 34 flush 512\(%fp\)\+\+ - cc: 05 04 80 34 flush 1024\(%r4\)\+\+ - d0: 05 10 c0 36 flush 4096\(%r22\)\+\+ - d4: 05 20 e0 36 flush 8192\(%r23\)\+\+ - d8: 05 40 00 37 flush 16384\(%r24\)\+\+ - dc: 05 c0 20 37 flush -16384\(%r25\)\+\+ - e0: 05 e0 40 37 flush -8192\(%r26\)\+\+ - e4: 05 f0 60 37 flush -4096\(%r27\)\+\+ - e8: 05 fc 80 37 flush -1024\(%r28\)\+\+ - ec: 05 fe a0 37 flush -512\(%r29\)\+\+ - f0: 0d ff c0 37 flush -248\(%r30\)\+\+ - f4: 25 00 e0 37 flush 32\(%r31\)\+\+ - f8: 15 00 e0 37 flush 16\(%r31\)\+\+ diff --git a/gas/testsuite/gas/i860/system.s b/gas/testsuite/gas/i860/system.s deleted file mode 100644 index 62bcbfc..0000000 --- a/gas/testsuite/gas/i860/system.s +++ /dev/null @@ -1,76 +0,0 @@ -# System and privileged instructions -# ld.c, st.c, flush, lock, unlock, intovr, trap - - .text - - lock - unlock - intovr - - trap %r0,%r0,%r0 - trap %r31,%r31,%r31 - trap %r1,%r5,%r18 - trap %r31,%r20,%r6 - - ld.c %fir,%r1 - ld.c %fir,%r31 - ld.c %psr,%r5 - ld.c %psr,%r30 - ld.c %dirbase,%r10 - ld.c %dirbase,%r2 - ld.c %db,%r21 - ld.c %db,%r0 - ld.c %fsr,%r28 - ld.c %fsr,%r12 - ld.c %epsr,%r31 - ld.c %epsr,%r6 - - st.c %r0,%fir - st.c %r30,%fir - st.c %r7,%psr - st.c %r31,%psr - st.c %r11,%dirbase - st.c %r3,%dirbase - st.c %r22,%db - st.c %r15,%db - st.c %r29,%fsr - st.c %r13,%fsr - st.c %r4,%epsr - st.c %r6,%epsr - - # Flush, no auto-increment. - flush 0(%r0) - flush 128(%r1) - flush 256(%r2) - flush 512(%r3) - flush 1024(%r4) - flush 4096(%r5) - flush 8192(%r6) - flush 16384(%r7) - flush -16384(%r8) - flush -8192(%r9) - flush -4096(%r10) - flush -1024(%r11) - flush -512(%r12) - flush -248(%r13) - flush -32(%r14) - flush -16(%r14) - - # Flush, auto-increment. - flush 0(%r0)++ - flush 128(%r1)++ - flush 256(%r2)++ - flush 512(%r3)++ - flush 1024(%r4)++ - flush 4096(%r22)++ - flush 8192(%r23)++ - flush 16384(%r24)++ - flush -16384(%r25)++ - flush -8192(%r26)++ - flush -4096(%r27)++ - flush -1024(%r28)++ - flush -512(%r29)++ - flush -248(%r30)++ - flush 32(%r31)++ - flush 16(%r31)++ - diff --git a/gas/testsuite/gas/i860/xp.d b/gas/testsuite/gas/i860/xp.d deleted file mode 100644 index 6dad997..0000000 --- a/gas/testsuite/gas/i860/xp.d +++ /dev/null @@ -1,241 +0,0 @@ -#as: -mxp -#objdump: -dr -#name: i860 xp (XP-only instructions) - -.*: +file format .* - -Disassembly of section \.text: - -00000000 <\.text>: - 0: 00 00 df 30 ld.c %bear,%r31 - 4: 00 00 c0 30 ld.c %bear,%r0 - 8: 00 00 e5 30 ld.c %ccr,%r5 - c: 00 00 fe 30 ld.c %ccr,%r30 - 10: 00 00 0a 31 ld.c %p0,%r10 - 14: 00 00 02 31 ld.c %p0,%sp - 18: 00 00 35 31 ld.c %p1,%r21 - 1c: 00 00 20 31 ld.c %p1,%r0 - 20: 00 00 5c 31 ld.c %p2,%r28 - 24: 00 00 4c 31 ld.c %p2,%r12 - 28: 00 00 7f 31 ld.c %p3,%r31 - 2c: 00 00 66 31 ld.c %p3,%r6 - 30: 00 00 c0 38 st.c %r0,%bear - 34: 00 f0 c0 38 st.c %r30,%bear - 38: 00 38 e0 38 st.c %r7,%ccr - 3c: 00 f8 e0 38 st.c %r31,%ccr - 40: 00 58 00 39 st.c %r11,%p0 - 44: 00 18 00 39 st.c %fp,%p0 - 48: 00 b0 20 39 st.c %r22,%p1 - 4c: 00 78 20 39 st.c %r15,%p1 - 50: 00 e8 40 39 st.c %r29,%p2 - 54: 00 68 40 39 st.c %r13,%p2 - 58: 00 20 60 39 st.c %r4,%p3 - 5c: 00 30 60 39 st.c %r6,%p3 - 60: 0a 04 05 4c ldint.l %r0,%r5 - 64: 0a 04 df 4c ldint.l %r6,%r31 - 68: 0a 04 fe 4c ldint.l %r7,%r30 - 6c: 0a 04 1d 4d ldint.l %r8,%r29 - 70: 0a 04 3c 4d ldint.l %r9,%r28 - 74: 0a 04 1b 4c ldint.l %r0,%r27 - 78: 0a 04 3a 4c ldint.l %r1,%r26 - 7c: 0a 04 99 4d ldint.l %r12,%r25 - 80: 0a 04 b8 4d ldint.l %r13,%r24 - 84: 0a 04 d7 4d ldint.l %r14,%r23 - 88: 0a 04 f6 4d ldint.l %r15,%r22 - 8c: 0a 04 15 4e ldint.l %r16,%r21 - 90: 0a 04 34 4e ldint.l %r17,%r20 - 94: 0a 04 93 4f ldint.l %r28,%r19 - 98: 0a 04 f2 4f ldint.l %r31,%r18 - 9c: 0a 02 05 4c ldint.s %r0,%r5 - a0: 0a 02 df 4c ldint.s %r6,%r31 - a4: 0a 02 fe 4c ldint.s %r7,%r30 - a8: 0a 02 1d 4d ldint.s %r8,%r29 - ac: 0a 02 3c 4d ldint.s %r9,%r28 - b0: 0a 02 1b 4c ldint.s %r0,%r27 - b4: 0a 02 3a 4c ldint.s %r1,%r26 - b8: 0a 02 99 4d ldint.s %r12,%r25 - bc: 0a 02 b8 4d ldint.s %r13,%r24 - c0: 0a 02 d7 4d ldint.s %r14,%r23 - c4: 0a 02 f6 4d ldint.s %r15,%r22 - c8: 0a 02 15 4e ldint.s %r16,%r21 - cc: 0a 02 34 4e ldint.s %r17,%r20 - d0: 0a 02 93 4f ldint.s %r28,%r19 - d4: 0a 02 f2 4f ldint.s %r31,%r18 - d8: 0a 00 05 4c ldint.b %r0,%r5 - dc: 0a 00 df 4c ldint.b %r6,%r31 - e0: 0a 00 fe 4c ldint.b %r7,%r30 - e4: 0a 00 1d 4d ldint.b %r8,%r29 - e8: 0a 00 3c 4d ldint.b %r9,%r28 - ec: 0a 00 1b 4c ldint.b %r0,%r27 - f0: 0a 00 3a 4c ldint.b %r1,%r26 - f4: 0a 00 99 4d ldint.b %r12,%r25 - f8: 0a 00 b8 4d ldint.b %r13,%r24 - fc: 0a 00 d7 4d ldint.b %r14,%r23 - 100: 0a 00 f6 4d ldint.b %r15,%r22 - 104: 0a 00 15 4e ldint.b %r16,%r21 - 108: 0a 00 34 4e ldint.b %r17,%r20 - 10c: 0a 00 93 4f ldint.b %r28,%r19 - 110: 0a 00 f2 4f ldint.b %r31,%r18 - 114: 08 04 05 4c ldio.l %r0,%r5 - 118: 08 04 df 4c ldio.l %r6,%r31 - 11c: 08 04 fe 4c ldio.l %r7,%r30 - 120: 08 04 1d 4d ldio.l %r8,%r29 - 124: 08 04 3c 4d ldio.l %r9,%r28 - 128: 08 04 1b 4c ldio.l %r0,%r27 - 12c: 08 04 3a 4c ldio.l %r1,%r26 - 130: 08 04 99 4d ldio.l %r12,%r25 - 134: 08 04 b8 4d ldio.l %r13,%r24 - 138: 08 04 d7 4d ldio.l %r14,%r23 - 13c: 08 04 f6 4d ldio.l %r15,%r22 - 140: 08 04 15 4e ldio.l %r16,%r21 - 144: 08 04 34 4e ldio.l %r17,%r20 - 148: 08 04 93 4f ldio.l %r28,%r19 - 14c: 08 04 f2 4f ldio.l %r31,%r18 - 150: 08 02 05 4c ldio.s %r0,%r5 - 154: 08 02 df 4c ldio.s %r6,%r31 - 158: 08 02 fe 4c ldio.s %r7,%r30 - 15c: 08 02 1d 4d ldio.s %r8,%r29 - 160: 08 02 3c 4d ldio.s %r9,%r28 - 164: 08 02 1b 4c ldio.s %r0,%r27 - 168: 08 02 3a 4c ldio.s %r1,%r26 - 16c: 08 02 99 4d ldio.s %r12,%r25 - 170: 08 02 b8 4d ldio.s %r13,%r24 - 174: 08 02 d7 4d ldio.s %r14,%r23 - 178: 08 02 f6 4d ldio.s %r15,%r22 - 17c: 08 02 15 4e ldio.s %r16,%r21 - 180: 08 02 34 4e ldio.s %r17,%r20 - 184: 08 02 93 4f ldio.s %r28,%r19 - 188: 08 02 f2 4f ldio.s %r31,%r18 - 18c: 08 00 05 4c ldio.b %r0,%r5 - 190: 08 00 df 4c ldio.b %r6,%r31 - 194: 08 00 fe 4c ldio.b %r7,%r30 - 198: 08 00 1d 4d ldio.b %r8,%r29 - 19c: 08 00 3c 4d ldio.b %r9,%r28 - 1a0: 08 00 1b 4c ldio.b %r0,%r27 - 1a4: 08 00 3a 4c ldio.b %r1,%r26 - 1a8: 08 00 99 4d ldio.b %r12,%r25 - 1ac: 08 00 b8 4d ldio.b %r13,%r24 - 1b0: 08 00 d7 4d ldio.b %r14,%r23 - 1b4: 08 00 f6 4d ldio.b %r15,%r22 - 1b8: 08 00 15 4e ldio.b %r16,%r21 - 1bc: 08 00 34 4e ldio.b %r17,%r20 - 1c0: 08 00 93 4f ldio.b %r28,%r19 - 1c4: 08 00 f2 4f ldio.b %r31,%r18 - 1c8: 09 04 a0 4c stio.l %r0,%r5 - 1cc: 09 34 e0 4f stio.l %r6,%r31 - 1d0: 09 3c c0 4f stio.l %r7,%r30 - 1d4: 09 44 a0 4f stio.l %r8,%r29 - 1d8: 09 4c 80 4f stio.l %r9,%r28 - 1dc: 09 04 60 4f stio.l %r0,%r27 - 1e0: 09 0c 40 4f stio.l %r1,%r26 - 1e4: 09 64 20 4f stio.l %r12,%r25 - 1e8: 09 6c 00 4f stio.l %r13,%r24 - 1ec: 09 74 e0 4e stio.l %r14,%r23 - 1f0: 09 7c c0 4e stio.l %r15,%r22 - 1f4: 09 84 a0 4e stio.l %r16,%r21 - 1f8: 09 8c 80 4e stio.l %r17,%r20 - 1fc: 09 e4 60 4e stio.l %r28,%r19 - 200: 09 fc 40 4e stio.l %r31,%r18 - 204: 09 02 a0 4c stio.s %r0,%r5 - 208: 09 32 e0 4f stio.s %r6,%r31 - 20c: 09 3a c0 4f stio.s %r7,%r30 - 210: 09 42 a0 4f stio.s %r8,%r29 - 214: 09 4a 80 4f stio.s %r9,%r28 - 218: 09 02 60 4f stio.s %r0,%r27 - 21c: 09 0a 40 4f stio.s %r1,%r26 - 220: 09 62 20 4f stio.s %r12,%r25 - 224: 09 6a 00 4f stio.s %r13,%r24 - 228: 09 72 e0 4e stio.s %r14,%r23 - 22c: 09 7a c0 4e stio.s %r15,%r22 - 230: 09 82 a0 4e stio.s %r16,%r21 - 234: 09 8a 80 4e stio.s %r17,%r20 - 238: 09 e2 60 4e stio.s %r28,%r19 - 23c: 09 fa 40 4e stio.s %r31,%r18 - 240: 09 00 a0 4c stio.b %r0,%r5 - 244: 09 30 e0 4f stio.b %r6,%r31 - 248: 09 38 c0 4f stio.b %r7,%r30 - 24c: 09 40 a0 4f stio.b %r8,%r29 - 250: 09 48 80 4f stio.b %r9,%r28 - 254: 09 00 60 4f stio.b %r0,%r27 - 258: 09 08 40 4f stio.b %r1,%r26 - 25c: 09 60 20 4f stio.b %r12,%r25 - 260: 09 68 00 4f stio.b %r13,%r24 - 264: 09 70 e0 4e stio.b %r14,%r23 - 268: 09 78 c0 4e stio.b %r15,%r22 - 26c: 09 80 a0 4e stio.b %r16,%r21 - 270: 09 88 80 4e stio.b %r17,%r20 - 274: 09 e0 60 4e stio.b %r28,%r19 - 278: 09 f8 40 4e stio.b %r31,%r18 - 27c: 0b 00 00 4c scyc.b %r0 - 280: 0b 00 a0 4c scyc.b %r5 - 284: 0b 00 c0 4c scyc.b %r6 - 288: 0b 00 a0 4d scyc.b %r13 - 28c: 0b 00 c0 4d scyc.b %r14 - 290: 0b 00 80 4f scyc.b %r28 - 294: 0b 00 a0 4f scyc.b %r29 - 298: 0b 00 c0 4f scyc.b %r30 - 29c: 0b 00 e0 4f scyc.b %r31 - 2a0: 04 00 00 64 pfld.q 0\(%r0\),%f0 - 2a4: 84 00 3c 64 pfld.q 128\(%r1\),%f28 - 2a8: 04 01 58 64 pfld.q 256\(%sp\),%f24 - 2ac: 04 02 74 64 pfld.q 512\(%fp\),%f20 - 2b0: 04 04 90 64 pfld.q 1024\(%r4\),%f16 - 2b4: 04 10 ac 64 pfld.q 4096\(%r5\),%f12 - 2b8: 04 20 c8 64 pfld.q 8192\(%r6\),%f8 - 2bc: 04 40 e4 64 pfld.q 16384\(%r7\),%f4 - 2c0: fc 7f e0 64 pfld.q 32760\(%r7\),%f0 - 2c4: 04 80 fc 64 pfld.q -32768\(%r7\),%f28 - 2c8: 04 c0 18 65 pfld.q -16384\(%r8\),%f24 - 2cc: 04 e0 34 65 pfld.q -8192\(%r9\),%f20 - 2d0: 04 f0 50 65 pfld.q -4096\(%r10\),%f16 - 2d4: 04 fc 6c 65 pfld.q -1024\(%r11\),%f12 - 2d8: 04 fe 88 65 pfld.q -512\(%r12\),%f8 - 2dc: 0c ff a4 65 pfld.q -248\(%r13\),%f4 - 2e0: fc ff c0 65 pfld.q -8\(%r14\),%f0 - 2e4: 05 00 00 64 pfld.q 0\(%r0\)\+\+,%f0 - 2e8: 85 00 24 64 pfld.q 128\(%r1\)\+\+,%f4 - 2ec: 05 01 48 64 pfld.q 256\(%sp\)\+\+,%f8 - 2f0: 05 02 6c 64 pfld.q 512\(%fp\)\+\+,%f12 - 2f4: 05 04 90 64 pfld.q 1024\(%r4\)\+\+,%f16 - 2f8: 05 10 b4 64 pfld.q 4096\(%r5\)\+\+,%f20 - 2fc: 05 20 d8 64 pfld.q 8192\(%r6\)\+\+,%f24 - 300: 05 40 fc 64 pfld.q 16384\(%r7\)\+\+,%f28 - 304: fd 7f e0 64 pfld.q 32760\(%r7\)\+\+,%f0 - 308: 05 80 e4 64 pfld.q -32768\(%r7\)\+\+,%f4 - 30c: 05 c0 08 65 pfld.q -16384\(%r8\)\+\+,%f8 - 310: 05 e0 2c 65 pfld.q -8192\(%r9\)\+\+,%f12 - 314: 05 f0 50 65 pfld.q -4096\(%r10\)\+\+,%f16 - 318: 05 fc 74 65 pfld.q -1024\(%r11\)\+\+,%f20 - 31c: 05 fe 98 65 pfld.q -512\(%r12\)\+\+,%f24 - 320: 0d ff bc 65 pfld.q -248\(%r13\)\+\+,%f28 - 324: fd ff d0 65 pfld.q -8\(%r14\)\+\+,%f16 - 328: 04 28 1c 60 pfld.q %r5\(%r0\),%f28 - 32c: 04 30 38 60 pfld.q %r6\(%r1\),%f24 - 330: 04 38 54 60 pfld.q %r7\(%sp\),%f20 - 334: 04 40 70 60 pfld.q %r8\(%fp\),%f16 - 338: 04 48 8c 60 pfld.q %r9\(%r4\),%f12 - 33c: 04 00 a8 60 pfld.q %r0\(%r5\),%f8 - 340: 04 08 c4 60 pfld.q %r1\(%r6\),%f4 - 344: 04 60 e0 60 pfld.q %r12\(%r7\),%f0 - 348: 04 68 1c 61 pfld.q %r13\(%r8\),%f28 - 34c: 04 70 38 61 pfld.q %r14\(%r9\),%f24 - 350: 04 78 54 61 pfld.q %r15\(%r10\),%f20 - 354: 04 80 70 61 pfld.q %r16\(%r11\),%f16 - 358: 04 88 8c 61 pfld.q %r17\(%r12\),%f12 - 35c: 04 e0 a8 61 pfld.q %r28\(%r13\),%f8 - 360: 04 f8 c4 61 pfld.q %r31\(%r14\),%f4 - 364: 05 28 00 60 pfld.q %r5\(%r0\)\+\+,%f0 - 368: 05 30 24 60 pfld.q %r6\(%r1\)\+\+,%f4 - 36c: 05 38 48 60 pfld.q %r7\(%sp\)\+\+,%f8 - 370: 05 40 6c 60 pfld.q %r8\(%fp\)\+\+,%f12 - 374: 05 48 90 60 pfld.q %r9\(%r4\)\+\+,%f16 - 378: 05 00 b4 60 pfld.q %r0\(%r5\)\+\+,%f20 - 37c: 05 08 d8 60 pfld.q %r1\(%r6\)\+\+,%f24 - 380: 05 60 fc 60 pfld.q %r12\(%r7\)\+\+,%f28 - 384: 05 68 00 61 pfld.q %r13\(%r8\)\+\+,%f0 - 388: 05 70 24 61 pfld.q %r14\(%r9\)\+\+,%f4 - 38c: 05 78 48 61 pfld.q %r15\(%r10\)\+\+,%f8 - 390: 05 80 6c 61 pfld.q %r16\(%r11\)\+\+,%f12 - 394: 05 88 90 61 pfld.q %r17\(%r12\)\+\+,%f16 - 398: 05 e0 b4 61 pfld.q %r28\(%r13\)\+\+,%f20 - 39c: 05 f8 d8 61 pfld.q %r31\(%r14\)\+\+,%f24 diff --git a/gas/testsuite/gas/i860/xp.s b/gas/testsuite/gas/i860/xp.s deleted file mode 100644 index 406c8f0..0000000 --- a/gas/testsuite/gas/i860/xp.s +++ /dev/null @@ -1,266 +0,0 @@ -# This tests the XP-only instructions: -# ldint.x, ldio.x, stio.x, scyc.b, pfld.q -# And control registers: -# %bear, %ccr, %p0, %p1, %p2, %p3 - - .text - - # XP-only control registers - ld.c %bear,%r31 - ld.c %bear,%r0 - ld.c %ccr,%r5 - ld.c %ccr,%r30 - ld.c %p0,%r10 - ld.c %p0,%r2 - ld.c %p1,%r21 - ld.c %p1,%r0 - ld.c %p2,%r28 - ld.c %p2,%r12 - ld.c %p3,%r31 - ld.c %p3,%r6 - - st.c %r0,%bear - st.c %r30,%bear - st.c %r7,%ccr - st.c %r31,%ccr - st.c %r11,%p0 - st.c %r3,%p0 - st.c %r22,%p1 - st.c %r15,%p1 - st.c %r29,%p2 - st.c %r13,%p2 - st.c %r4,%p3 - st.c %r6,%p3 - - # ldint.{s,b,l} - ldint.l %r0,%r5 - ldint.l %r6,%r31 - ldint.l %r7,%r30 - ldint.l %r8,%r29 - ldint.l %r9,%r28 - ldint.l %r0,%r27 - ldint.l %r1,%r26 - ldint.l %r12,%r25 - ldint.l %r13,%r24 - ldint.l %r14,%r23 - ldint.l %r15,%r22 - ldint.l %r16,%r21 - ldint.l %r17,%r20 - ldint.l %r28,%r19 - ldint.l %r31,%r18 - - ldint.s %r0,%r5 - ldint.s %r6,%r31 - ldint.s %r7,%r30 - ldint.s %r8,%r29 - ldint.s %r9,%r28 - ldint.s %r0,%r27 - ldint.s %r1,%r26 - ldint.s %r12,%r25 - ldint.s %r13,%r24 - ldint.s %r14,%r23 - ldint.s %r15,%r22 - ldint.s %r16,%r21 - ldint.s %r17,%r20 - ldint.s %r28,%r19 - ldint.s %r31,%r18 - - ldint.b %r0,%r5 - ldint.b %r6,%r31 - ldint.b %r7,%r30 - ldint.b %r8,%r29 - ldint.b %r9,%r28 - ldint.b %r0,%r27 - ldint.b %r1,%r26 - ldint.b %r12,%r25 - ldint.b %r13,%r24 - ldint.b %r14,%r23 - ldint.b %r15,%r22 - ldint.b %r16,%r21 - ldint.b %r17,%r20 - ldint.b %r28,%r19 - ldint.b %r31,%r18 - - # ldio.{s,b,l} - ldio.l %r0,%r5 - ldio.l %r6,%r31 - ldio.l %r7,%r30 - ldio.l %r8,%r29 - ldio.l %r9,%r28 - ldio.l %r0,%r27 - ldio.l %r1,%r26 - ldio.l %r12,%r25 - ldio.l %r13,%r24 - ldio.l %r14,%r23 - ldio.l %r15,%r22 - ldio.l %r16,%r21 - ldio.l %r17,%r20 - ldio.l %r28,%r19 - ldio.l %r31,%r18 - - ldio.s %r0,%r5 - ldio.s %r6,%r31 - ldio.s %r7,%r30 - ldio.s %r8,%r29 - ldio.s %r9,%r28 - ldio.s %r0,%r27 - ldio.s %r1,%r26 - ldio.s %r12,%r25 - ldio.s %r13,%r24 - ldio.s %r14,%r23 - ldio.s %r15,%r22 - ldio.s %r16,%r21 - ldio.s %r17,%r20 - ldio.s %r28,%r19 - ldio.s %r31,%r18 - - ldio.b %r0,%r5 - ldio.b %r6,%r31 - ldio.b %r7,%r30 - ldio.b %r8,%r29 - ldio.b %r9,%r28 - ldio.b %r0,%r27 - ldio.b %r1,%r26 - ldio.b %r12,%r25 - ldio.b %r13,%r24 - ldio.b %r14,%r23 - ldio.b %r15,%r22 - ldio.b %r16,%r21 - ldio.b %r17,%r20 - ldio.b %r28,%r19 - ldio.b %r31,%r18 - - # stio.{s,b,l} - stio.l %r0,%r5 - stio.l %r6,%r31 - stio.l %r7,%r30 - stio.l %r8,%r29 - stio.l %r9,%r28 - stio.l %r0,%r27 - stio.l %r1,%r26 - stio.l %r12,%r25 - stio.l %r13,%r24 - stio.l %r14,%r23 - stio.l %r15,%r22 - stio.l %r16,%r21 - stio.l %r17,%r20 - stio.l %r28,%r19 - stio.l %r31,%r18 - - stio.s %r0,%r5 - stio.s %r6,%r31 - stio.s %r7,%r30 - stio.s %r8,%r29 - stio.s %r9,%r28 - stio.s %r0,%r27 - stio.s %r1,%r26 - stio.s %r12,%r25 - stio.s %r13,%r24 - stio.s %r14,%r23 - stio.s %r15,%r22 - stio.s %r16,%r21 - stio.s %r17,%r20 - stio.s %r28,%r19 - stio.s %r31,%r18 - - stio.b %r0,%r5 - stio.b %r6,%r31 - stio.b %r7,%r30 - stio.b %r8,%r29 - stio.b %r9,%r28 - stio.b %r0,%r27 - stio.b %r1,%r26 - stio.b %r12,%r25 - stio.b %r13,%r24 - stio.b %r14,%r23 - stio.b %r15,%r22 - stio.b %r16,%r21 - stio.b %r17,%r20 - stio.b %r28,%r19 - stio.b %r31,%r18 - - # scyc.b - scyc.b %r0 - scyc.b %r5 - scyc.b %r6 - scyc.b %r13 - scyc.b %r14 - scyc.b %r28 - scyc.b %r29 - scyc.b %r30 - scyc.b %r31 - - # pfld.q - # Immediate form, no auto-increment. - pfld.q 0(%r0),%f0 - pfld.q 128(%r1),%f28 - pfld.q 256(%r2),%f24 - pfld.q 512(%r3),%f20 - pfld.q 1024(%r4),%f16 - pfld.q 4096(%r5),%f12 - pfld.q 8192(%r6),%f8 - pfld.q 16384(%r7),%f4 - pfld.q 32760(%r7),%f0 - pfld.q -32768(%r7),%f28 - pfld.q -16384(%r8),%f24 - pfld.q -8192(%r9),%f20 - pfld.q -4096(%r10),%f16 - pfld.q -1024(%r11),%f12 - pfld.q -512(%r12),%f8 - pfld.q -248(%r13),%f4 - pfld.q -8(%r14),%f0 - - # Immediate form, with auto-increment. - pfld.q 0(%r0)++,%f0 - pfld.q 128(%r1)++,%f4 - pfld.q 256(%r2)++,%f8 - pfld.q 512(%r3)++,%f12 - pfld.q 1024(%r4)++,%f16 - pfld.q 4096(%r5)++,%f20 - pfld.q 8192(%r6)++,%f24 - pfld.q 16384(%r7)++,%f28 - pfld.q 32760(%r7)++,%f0 - pfld.q -32768(%r7)++,%f4 - pfld.q -16384(%r8)++,%f8 - pfld.q -8192(%r9)++,%f12 - pfld.q -4096(%r10)++,%f16 - pfld.q -1024(%r11)++,%f20 - pfld.q -512(%r12)++,%f24 - pfld.q -248(%r13)++,%f28 - pfld.q -8(%r14)++,%f16 - - # Index form, no auto-increment. - pfld.q %r5(%r0),%f28 - pfld.q %r6(%r1),%f24 - pfld.q %r7(%r2),%f20 - pfld.q %r8(%r3),%f16 - pfld.q %r9(%r4),%f12 - pfld.q %r0(%r5),%f8 - pfld.q %r1(%r6),%f4 - pfld.q %r12(%r7),%f0 - pfld.q %r13(%r8),%f28 - pfld.q %r14(%r9),%f24 - pfld.q %r15(%r10),%f20 - pfld.q %r16(%r11),%f16 - pfld.q %r17(%r12),%f12 - pfld.q %r28(%r13),%f8 - pfld.q %r31(%r14),%f4 - - # Index form, with auto-increment. - pfld.q %r5(%r0)++,%f0 - pfld.q %r6(%r1)++,%f4 - pfld.q %r7(%r2)++,%f8 - pfld.q %r8(%r3)++,%f12 - pfld.q %r9(%r4)++,%f16 - pfld.q %r0(%r5)++,%f20 - pfld.q %r1(%r6)++,%f24 - pfld.q %r12(%r7)++,%f28 - pfld.q %r13(%r8)++,%f0 - pfld.q %r14(%r9)++,%f4 - pfld.q %r15(%r10)++,%f8 - pfld.q %r16(%r11)++,%f12 - pfld.q %r17(%r12)++,%f16 - pfld.q %r28(%r13)++,%f20 - pfld.q %r31(%r14)++,%f24 - - diff --git a/gas/testsuite/gas/lns/lns.exp b/gas/testsuite/gas/lns/lns.exp index 5ccf120..dcf593c 100644 --- a/gas/testsuite/gas/lns/lns.exp +++ b/gas/testsuite/gas/lns/lns.exp @@ -26,7 +26,6 @@ run_dump_test "lns-duplicate" # defined a macro... if { ![istarget i370-*-*] - && ![istarget i960-*-*] && ![istarget s390*-*-*] } { # Use alternate file for targets using DW_LNS_fixed_advance_pc opcodes. diff --git a/gas/testsuite/gas/symver/symver.exp b/gas/testsuite/gas/symver/symver.exp index 87e3cc8..c40fc9a 100644 --- a/gas/testsuite/gas/symver/symver.exp +++ b/gas/testsuite/gas/symver/symver.exp @@ -46,11 +46,6 @@ if { [is_elf_format] } then { return } - # not yet supported by i960 - if {[istarget "i960-*-*"]} { - return - } - run_dump_test "symver0" run_dump_test "symver1" run_error_test "symver2" "" diff --git a/gas/write.c b/gas/write.c index 4c8e42b..2d0bbe4 100644 --- a/gas/write.c +++ b/gas/write.c @@ -926,9 +926,7 @@ fixup_segment (fixS *fixP, segT this_segment) /* If the linker is doing the relaxing, we must not do any fixups. Well, strictly speaking that's not true -- we could do any that - are PC-relative and don't cross regions that could change size. - And for the i960 we might be able to turn callx/callj into bal - anyways in cases where we know the maximum displacement. */ + are PC-relative and don't cross regions that could change size. */ if (linkrelax && TC_LINKRELAX_FIXUP (this_segment)) { for (; fixP; fixP = fixP->fx_next) diff --git a/gas/write.h b/gas/write.h index 3c6f259..4f510d6 100644 --- a/gas/write.h +++ b/gas/write.h @@ -106,10 +106,6 @@ struct fix struct fix *fx_next; /* If NULL, no bitfix's to do. */ - /* Only i960-coff and ns32k use this, and i960-coff stores an - integer. This can probably be folded into tc_fix_data, below. - @@ Alpha also uses it, but only to disable certain relocation - processing. */ bit_fixS *fx_bit_fixP; bfd_reloc_code_real_type fx_r_type; diff --git a/include/ChangeLog b/include/ChangeLog index 74e6a53..41d785a 100644 --- a/include/ChangeLog +++ b/include/ChangeLog @@ -1,3 +1,18 @@ +2018-04-11 Alan Modra <amodra@gmail.com> + + * aout/adobe.h: Delete. + * aout/reloc.h: Delete. + * coff/i860.h: Delete. + * coff/i960.h: Delete. + * elf/i860.h: Delete. + * elf/i960.h: Delete. + * opcode/i860.h: Delete. + * opcode/i960.h: Delete. + * aout/aout64.h (enum reloc_type): Trim off 29k and other unused values. + * aout/ar.h (ARMAGB): Remove. + * coff/internal.h (struct internal_aouthdr, struct internal_scnhdr, + union internal_auxent): Remove i960 support. + 2018-04-09 Alan Modra <amodra@gmail.com> * elf/ppc.h (R_PPC_PLTSEQ, R_PPC_PLTCALL): Define. diff --git a/include/aout/adobe.h b/include/aout/adobe.h deleted file mode 100644 index 33770f9..0000000 --- a/include/aout/adobe.h +++ /dev/null @@ -1,319 +0,0 @@ -/* `a.out.adobe' differences from standard a.out files - - Copyright (C) 2001-2018 Free Software Foundation, Inc. - - 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. */ - -#ifndef __A_OUT_ADOBE_H__ -#define __A_OUT_ADOBE_H__ - -#define BYTES_IN_WORD 4 - -/* Struct external_exec is the same. */ - -/* This is the layout on disk of the 32-bit or 64-bit exec header. */ - -struct external_exec -{ - bfd_byte e_info[4]; /* Magic number and stuff. */ - bfd_byte e_text[BYTES_IN_WORD]; /* Length of text section in bytes. */ - bfd_byte e_data[BYTES_IN_WORD]; /* Length of data section in bytes. */ - bfd_byte e_bss[BYTES_IN_WORD]; /* Length of bss area in bytes. */ - bfd_byte e_syms[BYTES_IN_WORD]; /* Length of symbol table in bytes. */ - bfd_byte e_entry[BYTES_IN_WORD]; /* Start address. */ - bfd_byte e_trsize[BYTES_IN_WORD]; /* Length of text relocation info. */ - bfd_byte e_drsize[BYTES_IN_WORD]; /* Length of data relocation info. */ -}; - -#define EXEC_BYTES_SIZE (4 + BYTES_IN_WORD * 7) - -/* Magic numbers for a.out files. */ - -#undef ZMAGIC -#define ZMAGIC 0xAD0BE /* Cute, eh? */ -#undef OMAGIC -#undef NMAGIC - -#define N_BADMAG(x) ((x)->a_info != ZMAGIC) - -/* By default, segment size is constant. But some machines override this - to be a function of the a.out header (e.g. machine type). */ -#ifndef N_SEGSIZE -#define N_SEGSIZE(x) SEGMENT_SIZE -#endif -#undef N_SEGSIZE /* FIXMEXXXX */ - -/* Segment information for the a.out.Adobe format is specified after the - file header. It contains N segment descriptors, followed by one with - a type of zero. - - The actual text of the segments starts at N_TXTOFF in the file, - regardless of how many or how few segment headers there are. */ - -struct external_segdesc -{ - unsigned char e_type[1]; - unsigned char e_size[3]; - unsigned char e_virtbase[4]; - unsigned char e_filebase[4]; -}; - -struct internal_segdesc -{ - unsigned int a_type:8; /* Segment type N_TEXT, N_DATA, 0. */ - unsigned int a_size:24; /* Segment size. */ - bfd_vma a_virtbase; /* Virtual address. */ - unsigned int a_filebase; /* Base address in object file. */ -}; - -#define N_TXTADDR(x) is_this_really_unused? - -/* This is documented to be at 1024, but appears to really be at 2048. - FIXME?! */ -#define N_TXTOFF(x) 2048 - -#define N_TXTSIZE(x) ((x)->a_text) - -#define N_DATADDR(x) is_this_really_unused? - -#define N_BSSADDR(x) is_this_really_unused? - -/* Offsets of the various portions of the file after the text segment. */ - -#define N_DATOFF(x) ( N_TXTOFF(x) + N_TXTSIZE(x) ) -#define N_TRELOFF(x) ( N_DATOFF(x) + (x)->a_data ) -#define N_DRELOFF(x) ( N_TRELOFF(x) + (x)->a_trsize ) -#define N_SYMOFF(x) ( N_DRELOFF(x) + (x)->a_drsize ) -#define N_STROFF(x) ( N_SYMOFF(x) + (x)->a_syms ) - -/* Symbols. */ -struct external_nlist -{ - bfd_byte e_strx[BYTES_IN_WORD]; /* Index into string table of name. */ - bfd_byte e_type[1]; /* Type of symbol. */ - bfd_byte e_other[1]; /* Misc info (usually empty). */ - bfd_byte e_desc[2]; /* Description field. */ - bfd_byte e_value[BYTES_IN_WORD]; /* Value of symbol. */ -}; - -#define EXTERNAL_NLIST_SIZE (BYTES_IN_WORD+4+BYTES_IN_WORD) - -struct internal_nlist -{ - unsigned long n_strx; /* Index into string table of name. */ - unsigned char n_type; /* Type of symbol. */ - unsigned char n_other; /* Misc info (usually empty). */ - unsigned short n_desc; /* Description field. */ - bfd_vma n_value; /* Value of symbol. */ -}; - -/* The n_type field is the symbol type, containing: */ - -#define N_UNDF 0 /* Undefined symbol. */ -#define N_ABS 2 /* Absolute symbol -- defined at particular addr. */ -#define N_TEXT 4 /* Text sym -- defined at offset in text seg. */ -#define N_DATA 6 /* Data sym -- defined at offset in data seg. */ -#define N_BSS 8 /* BSS sym -- defined at offset in zero'd seg. */ -#define N_COMM 0x12 /* Common symbol (visible after shared lib dynlink). */ -#define N_FN 0x1f /* File name of .o file. */ -#define N_FN_SEQ 0x0C /* N_FN from Sequent compilers (sigh). */ -/* Note: N_EXT can only be usefully OR-ed with N_UNDF, N_ABS, N_TEXT, - N_DATA, or N_BSS. When the low-order bit of other types is set, - (e.g. N_WARNING versus N_FN), they are two different types. */ -#define N_EXT 1 /* External symbol (as opposed to local-to-this-file). */ -#define N_TYPE 0x1e -#define N_STAB 0xe0 /* If any of these bits are on, it's a debug symbol. */ - -#define N_INDR 0x0a - -/* The following symbols refer to set elements. - All the N_SET[ATDB] symbols with the same name form one set. - Space is allocated for the set in the text section, and each set - elements value is stored into one word of the space. - The first word of the space is the length of the set (number of elements). - - The address of the set is made into an N_SETV symbol - whose name is the same as the name of the set. - This symbol acts like a N_DATA global symbol - in that it can satisfy undefined external references. */ - -/* These appear as input to LD, in a .o file. */ -#define N_SETA 0x14 /* Absolute set element symbol. */ -#define N_SETT 0x16 /* Text set element symbol. */ -#define N_SETD 0x18 /* Data set element symbol. */ -#define N_SETB 0x1A /* Bss set element symbol. */ - -/* This is output from LD. */ -#define N_SETV 0x1C /* Pointer to set vector in data area. */ - -/* Warning symbol. The text gives a warning message, the next symbol - in the table will be undefined. When the symbol is referenced, the - message is printed. */ - -#define N_WARNING 0x1e - -/* Relocations - - There are two types of relocation flavours for a.out systems, - standard and extended. The standard form is used on systems where the - instruction has room for all the bits of an offset to the operand, whilst - the extended form is used when an address operand has to be split over n - instructions. Eg, on the 68k, each move instruction can reference - the target with a displacement of 16 or 32 bits. On the sparc, move - instructions use an offset of 14 bits, so the offset is stored in - the reloc field, and the data in the section is ignored. */ - -/* This structure describes a single relocation to be performed. - The text-relocation section of the file is a vector of these structures, - all of which apply to the text section. - Likewise, the data-relocation section applies to the data section. */ - -struct reloc_std_external -{ - bfd_byte r_address[BYTES_IN_WORD]; /* Offset of data to relocate. */ - bfd_byte r_index[3]; /* Symbol table index of symbol. */ - bfd_byte r_type[1]; /* Relocation type. */ -}; - -#define RELOC_STD_BITS_PCREL_BIG 0x80 -#define RELOC_STD_BITS_PCREL_LITTLE 0x01 - -#define RELOC_STD_BITS_LENGTH_BIG 0x60 -#define RELOC_STD_BITS_LENGTH_SH_BIG 5 /* To shift to units place. */ -#define RELOC_STD_BITS_LENGTH_LITTLE 0x06 -#define RELOC_STD_BITS_LENGTH_SH_LITTLE 1 - -#define RELOC_STD_BITS_EXTERN_BIG 0x10 -#define RELOC_STD_BITS_EXTERN_LITTLE 0x08 - -#define RELOC_STD_BITS_BASEREL_BIG 0x08 -#define RELOC_STD_BITS_BASEREL_LITTLE 0x08 - -#define RELOC_STD_BITS_JMPTABLE_BIG 0x04 -#define RELOC_STD_BITS_JMPTABLE_LITTLE 0x04 - -#define RELOC_STD_BITS_RELATIVE_BIG 0x02 -#define RELOC_STD_BITS_RELATIVE_LITTLE 0x02 - -#define RELOC_STD_SIZE (BYTES_IN_WORD + 3 + 1) /* Bytes per relocation entry. */ - -struct reloc_std_internal -{ - bfd_vma r_address; /* Address (within segment) to be relocated. */ - /* The meaning of r_symbolnum depends on r_extern. */ - unsigned int r_symbolnum:24; - /* Nonzero means value is a pc-relative offset - and it should be relocated for changes in its own address - as well as for changes in the symbol or section specified. */ - unsigned int r_pcrel:1; - /* Length (as exponent of 2) of the field to be relocated. - Thus, a value of 2 indicates 1<<2 bytes. */ - unsigned int r_length:2; - /* 1 => relocate with value of symbol. - r_symbolnum is the index of the symbol - in files the symbol table. - 0 => relocate with the address of a segment. - r_symbolnum is N_TEXT, N_DATA, N_BSS or N_ABS - (the N_EXT bit may be set also, but signifies nothing). */ - unsigned int r_extern:1; - /* The next three bits are for SunOS shared libraries, and seem to - be undocumented. */ - unsigned int r_baserel:1; /* Linkage table relative. */ - unsigned int r_jmptable:1; /* pc-relative to jump table. */ - unsigned int r_relative:1; /* "relative relocation". */ - /* unused */ - unsigned int r_pad:1; /* Padding -- set to zero. */ -}; - - -/* EXTENDED RELOCS */ - -struct reloc_ext_external -{ - bfd_byte r_address[BYTES_IN_WORD]; /* Offset of data to relocate. */ - bfd_byte r_index[3]; /* Symbol table index of symbol. */ - bfd_byte r_type[1]; /* Relocation type. */ - bfd_byte r_addend[BYTES_IN_WORD]; /* Datum addend. */ -}; - -#define RELOC_EXT_BITS_EXTERN_BIG 0x80 -#define RELOC_EXT_BITS_EXTERN_LITTLE 0x01 - -#define RELOC_EXT_BITS_TYPE_BIG 0x1F -#define RELOC_EXT_BITS_TYPE_SH_BIG 0 -#define RELOC_EXT_BITS_TYPE_LITTLE 0xF8 -#define RELOC_EXT_BITS_TYPE_SH_LITTLE 3 - -/* Bytes per relocation entry */ -#define RELOC_EXT_SIZE (BYTES_IN_WORD + 3 + 1 + BYTES_IN_WORD) - -enum reloc_type -{ - /* Simple relocations. */ - RELOC_8, /* data[0:7] = addend + sv */ - RELOC_16, /* data[0:15] = addend + sv */ - RELOC_32, /* data[0:31] = addend + sv */ - /* PC-rel displacement. */ - RELOC_DISP8, /* data[0:7] = addend - pc + sv */ - RELOC_DISP16, /* data[0:15] = addend - pc + sv */ - RELOC_DISP32, /* data[0:31] = addend - pc + sv */ - /* Special. */ - RELOC_WDISP30, /* data[0:29] = (addend + sv - pc)>>2 */ - RELOC_WDISP22, /* data[0:21] = (addend + sv - pc)>>2 */ - RELOC_HI22, /* data[0:21] = (addend + sv)>>10 */ - RELOC_22, /* data[0:21] = (addend + sv) */ - RELOC_13, /* data[0:12] = (addend + sv) */ - RELOC_LO10, /* data[0:9] = (addend + sv) */ - RELOC_SFA_BASE, - RELOC_SFA_OFF13, - /* P.I.C. (base-relative). */ - RELOC_BASE10, /* Not sure - maybe we can do this the */ - RELOC_BASE13, /* right way now. */ - RELOC_BASE22, - /* For some sort of pc-rel P.I.C. (?) */ - RELOC_PC10, - RELOC_PC22, - /* P.I.C. jump table. */ - RELOC_JMP_TBL, - /* Reputedly for shared libraries somehow. */ - RELOC_SEGOFF16, - RELOC_GLOB_DAT, - RELOC_JMP_SLOT, - RELOC_RELATIVE, - - RELOC_11, - RELOC_WDISP2_14, - RELOC_WDISP19, - RELOC_HHI22, /* data[0:21] = (addend + sv) >> 42 */ - RELOC_HLO10, /* data[0:9] = (addend + sv) >> 32 */ - - /* 29K relocation types */ - RELOC_JUMPTARG, - RELOC_CONST, - RELOC_CONSTH, - - NO_RELOC -}; - -struct reloc_internal -{ - bfd_vma r_address; /* Offset of data to relocate. */ - long r_index; /* Symbol table index of symbol. */ - enum reloc_type r_type; /* Relocation type. */ - bfd_vma r_addend; /* Datum addend. */ -}; - -#endif /* __A_OUT_ADOBE_H__ */ diff --git a/include/aout/aout64.h b/include/aout/aout64.h index 0e7ced7..a0827d5 100644 --- a/include/aout/aout64.h +++ b/include/aout/aout64.h @@ -476,25 +476,7 @@ enum reloc_type RELOC_11, RELOC_WDISP2_14, RELOC_WDISP19, - RELOC_HHI22, /* data[0:21] = (addend + sv) >> 42 */ - RELOC_HLO10, /* data[0:9] = (addend + sv) >> 32 */ - - /* 29K relocation types. */ - RELOC_JUMPTARG, - RELOC_CONST, - RELOC_CONSTH, - - /* All the new ones I can think of, for sparc v9. */ - RELOC_64, /* data[0:63] = addend + sv */ - RELOC_DISP64, /* data[0:63] = addend - pc + sv */ - RELOC_WDISP21, /* data[0:20] = (addend + sv - pc)>>2 */ - RELOC_DISP21, /* data[0:20] = addend - pc + sv */ - RELOC_DISP14, /* data[0:13] = addend - pc + sv */ - /* Q . - What are the other ones, - Since this is a clean slate, can we throw away the ones we dont - understand ? Should we sort the values ? What about using a - microcode format like the 68k ? */ + NO_RELOC }; diff --git a/include/aout/ar.h b/include/aout/ar.h index d9e3bc6..905fcbc 100644 --- a/include/aout/ar.h +++ b/include/aout/ar.h @@ -28,7 +28,6 @@ compatible with existing BSDish archives. */ #define ARMAG "!<arch>\012" /* For COFF and a.out archives. */ -#define ARMAGB "!<bout>\012" /* For b.out archives. */ #define ARMAGT "!<thin>\012" /* For thin archives. */ #define SARMAG 8 #define ARFMAG "`\012" diff --git a/include/aout/reloc.h b/include/aout/reloc.h deleted file mode 100644 index 2249107f..0000000 --- a/include/aout/reloc.h +++ /dev/null @@ -1,67 +0,0 @@ -/* reloc.h -- Header file for relocation information. - Copyright (C) 1989-2018 Free Software Foundation, Inc. - - 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. */ - -/* Relocation types for a.out files using reloc_info_extended - (SPARC and AMD 29000). */ - -#ifndef _RELOC_H_READ_ -#define _RELOC_H_READ_ 1 - -enum reloc_type - { - RELOC_8, RELOC_16, RELOC_32, /* simple relocations */ - RELOC_DISP8, RELOC_DISP16, RELOC_DISP32, /* pc-rel displacement */ - RELOC_WDISP30, RELOC_WDISP22, - RELOC_HI22, RELOC_22, - RELOC_13, RELOC_LO10, - RELOC_SFA_BASE, RELOC_SFA_OFF13, - RELOC_BASE10, RELOC_BASE13, RELOC_BASE22, /* P.I.C. (base-relative) */ - RELOC_PC10, RELOC_PC22, /* for some sort of pc-rel P.I.C. (?) */ - RELOC_JMP_TBL, /* P.I.C. jump table */ - RELOC_SEGOFF16, /* reputedly for shared libraries somehow */ - RELOC_GLOB_DAT, RELOC_JMP_SLOT, RELOC_RELATIVE, - RELOC_11, - RELOC_WDISP2_14, - RELOC_WDISP19, - RELOC_HHI22, - RELOC_HLO10, - - /* 29K relocation types */ - RELOC_JUMPTARG, RELOC_CONST, RELOC_CONSTH, - - RELOC_WDISP14, RELOC_WDISP21, - - NO_RELOC - }; - -#define RELOC_TYPE_NAMES \ -"8", "16", "32", "DISP8", \ -"DISP16", "DISP32", "WDISP30", "WDISP22", \ -"HI22", "22", "13", "LO10", \ -"SFA_BASE", "SFAOFF13", "BASE10", "BASE13", \ -"BASE22", "PC10", "PC22", "JMP_TBL", \ -"SEGOFF16", "GLOB_DAT", "JMP_SLOT", "RELATIVE", \ -"11", "WDISP2_14", "WDISP19", "HHI22", \ -"HLO10", \ -"JUMPTARG", "CONST", "CONSTH", "WDISP14", \ -"WDISP21", \ -"NO_RELOC" - -#endif /* _RELOC_H_READ_ */ - -/* end of reloc.h */ diff --git a/include/coff/i860.h b/include/coff/i860.h deleted file mode 100644 index 3afa38f..0000000 --- a/include/coff/i860.h +++ /dev/null @@ -1,87 +0,0 @@ -/* COFF information for the Intel i860. - - Copyright (C) 2001-2018 Free Software Foundation, Inc. - - 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. */ - -/* This file was hacked from i386.h [dolan@ssd.intel.com] */ - -#define L_LNNO_SIZE 2 -#include "coff/external.h" - -/* Bits for f_flags: - F_RELFLG relocation info stripped from file - F_EXEC file is executable (no unresolved external references) - F_LNNO line numbers stripped from file - F_LSYMS local symbols stripped from file - F_AR32WR file has byte ordering of an AR32WR machine (e.g. vax). */ - -#define F_RELFLG (0x0001) -#define F_EXEC (0x0002) -#define F_LNNO (0x0004) -#define F_LSYMS (0x0008) - -#define I860MAGIC 0x14d - -#define I860BADMAG(x) ((x).f_magic != I860MAGIC) - -#undef AOUTSZ -#define AOUTSZ 36 - -/* FIXME: What are the a.out magic numbers? */ - -#define _ETEXT "etext" - -/********************** RELOCATION DIRECTIVES **********************/ - -struct external_reloc -{ - char r_vaddr[4]; - char r_symndx[4]; - char r_type[2]; -}; - -#define RELOC struct external_reloc -#define RELSZ 10 - -/* The relocation directory entry types. - PAIR : The low half that follows relates to the preceding HIGH[ADJ]. - HIGH : The high half of a 32-bit constant. - LOWn : The low half, insn bits 15..(n-1), 2^n-byte aligned. - SPLITn : The low half, insn bits 20..16 and 10..(n-1), 2^n-byte aligned. - HIGHADJ: Similar to HIGH, but with adjustment. - BRADDR : 26-bit branch displacement. - - Note: The Intel assembler manual lists LOW4 as one of the - relocation types, but it appears to be useless for the i860. - We will recognize it anyway, just in case it actually appears in - any object files. */ - -enum { - COFF860_R_PAIR = 0x1c, - COFF860_R_HIGH = 0x1e, - COFF860_R_LOW0 = 0x1f, - COFF860_R_LOW1 = 0x20, - COFF860_R_LOW2 = 0x21, - COFF860_R_LOW3 = 0x22, - COFF860_R_LOW4 = 0x23, - COFF860_R_SPLIT0 = 0x24, - COFF860_R_SPLIT1 = 0x25, - COFF860_R_SPLIT2 = 0x26, - COFF860_R_HIGHADJ = 0x27, - COFF860_R_BRADDR = 0x28 -}; - diff --git a/include/coff/i960.h b/include/coff/i960.h deleted file mode 100644 index 19d35f9..0000000 --- a/include/coff/i960.h +++ /dev/null @@ -1,320 +0,0 @@ -/* coff information for 80960. Origins: Intel corp, natch. - - Copyright (C) 2001-2018 Free Software Foundation, Inc. - - 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. */ - -/* NOTE: Tagentries (cf TAGBITS) are no longer used by the 960 */ - -/********************** FILE HEADER **********************/ - -struct external_filehdr -{ - char f_magic[2]; /* magic number */ - char f_nscns[2]; /* number of sections */ - char f_timdat[4]; /* time & date stamp */ - char f_symptr[4]; /* file pointer to symtab */ - char f_nsyms[4]; /* number of symtab entries */ - char f_opthdr[2]; /* sizeof(optional hdr) */ - char f_flags[2]; /* flags */ -}; - -#define OMAGIC (0407) /* old impure format. data immediately - follows text. both sections are rw. */ -#define NMAGIC (0410) /* split i&d, read-only text */ - -/* -* Intel 80960 (I960) processor flags. -* F_I960TYPE == mask for processor type field. -*/ - -#define F_I960TYPE (0xf000) -#define F_I960CORE (0x1000) -#define F_I960KB (0x2000) -#define F_I960SB (0x2000) -#define F_I960MC (0x3000) -#define F_I960XA (0x4000) -#define F_I960CA (0x5000) -#define F_I960KA (0x6000) -#define F_I960SA (0x6000) -#define F_I960JX (0x7000) -#define F_I960HX (0x8000) - - -/** i80960 Magic Numbers -*/ - -#define I960ROMAGIC (0x160) /* read-only text segments */ -#define I960RWMAGIC (0x161) /* read-write text segments */ - -#define I960BADMAG(x) (((x).f_magic!=I960ROMAGIC) && ((x).f_magic!=I960RWMAGIC)) - -#define FILHDR struct external_filehdr -#define FILHSZ 20 - -/********************** AOUT "OPTIONAL HEADER" **********************/ - -typedef struct -{ - unsigned long phys_addr; - unsigned long bitarray; -} TAGBITS; - -typedef struct -{ - char magic[2]; /* type of file */ - char vstamp[2]; /* version stamp */ - char tsize[4]; /* text size in bytes, padded to FW bdry*/ - char dsize[4]; /* initialized data " " */ - char bsize[4]; /* uninitialized data " " */ - char entry[4]; /* entry pt. */ - char text_start[4]; /* base of text used for this file */ - char data_start[4]; /* base of data used for this file */ - char tagentries[4]; /* number of tag entries to follow */ -} -AOUTHDR; - -/* return a pointer to the tag bits array */ - -#define TAGPTR(aout) ((TAGBITS *) (&(aout.tagentries)+1)) - -/* compute size of a header */ - -/*#define AOUTSZ(aout) (sizeof(AOUTHDR)+(aout.tagentries*sizeof(TAGBITS)))*/ -#define AOUTSZ 32 -#define AOUTHDRSZ 32 - - -/********************** SECTION HEADER **********************/ - -struct external_scnhdr -{ - char s_name[8]; /* section name */ - char s_paddr[4]; /* physical address, aliased s_nlib */ - char s_vaddr[4]; /* virtual address */ - char s_size[4]; /* section size */ - char s_scnptr[4]; /* file ptr to raw data for section */ - char s_relptr[4]; /* file ptr to relocation */ - char s_lnnoptr[4]; /* file ptr to line numbers */ - char s_nreloc[2]; /* number of relocation entries */ - char s_nlnno[2]; /* number of line number entries*/ - char s_flags[4]; /* flags */ - char s_align[4]; /* section alignment */ -}; - - -#define SCNHDR struct external_scnhdr -#define SCNHSZ 44 - -/* - * names of "special" sections - */ -#define _TEXT ".text" -#define _DATA ".data" -#define _BSS ".bss" - -/********************** LINE NUMBERS **********************/ - -/* 1 line number entry for every "breakpointable" source line in a section. - * Line numbers are grouped on a per function basis; first entry in a function - * grouping will have l_lnno = 0 and in place of physical address will be the - * symbol table index of the function name. - */ -struct external_lineno -{ - union - { - char l_symndx[4]; /* function name symbol index, iff l_lnno == 0*/ - char l_paddr[4]; /* (physical) address of line number */ - } l_addr; - - char l_lnno[2]; /* line number */ - char padding[2]; /* force alignment */ -}; - - -#define LINENO struct external_lineno -#define LINESZ 8 - -/********************** SYMBOLS **********************/ - -#define E_SYMNMLEN 8 /* # characters in a symbol name */ -#define E_FILNMLEN 14 /* # characters in a file name */ -#define E_DIMNUM 4 /* # array dimensions in auxiliary entry */ - -struct external_syment -{ - union - { - char e_name[E_SYMNMLEN]; - - struct - { - char e_zeroes[4]; - char e_offset[4]; - } e; - } e; - - char e_value[4]; - char e_scnum[2]; - char e_flags[2]; - char e_type[4]; - char e_sclass[1]; - char e_numaux[1]; - char pad2[2]; -}; - -#define N_BTMASK (0x1f) -#define N_TMASK (0x60) -#define N_BTSHFT (5) -#define N_TSHIFT (2) - -union external_auxent -{ - struct - { - char x_tagndx[4]; /* str, un, or enum tag indx */ - - union - { - struct - { - char x_lnno[2]; /* declaration line number */ - char x_size[2]; /* str/union/array size */ - } x_lnsz; - - char x_fsize[4]; /* size of function */ - - } x_misc; - - union - { - struct /* if ISFCN, tag, or .bb */ - { - char x_lnnoptr[4]; /* ptr to fcn line # */ - char x_endndx[4]; /* entry ndx past block end */ - } x_fcn; - - struct /* if ISARY, up to 4 dimen. */ - { - char x_dimen[E_DIMNUM][2]; - } x_ary; - - } x_fcnary; - - char x_tvndx[2]; /* tv index */ - - } x_sym; - - union - { - char x_fname[E_FILNMLEN]; - - struct - { - char x_zeroes[4]; - char x_offset[4]; - } x_n; - - } x_file; - - struct - { - char x_scnlen[4]; /* section length */ - char x_nreloc[2]; /* # relocation entries */ - char x_nlinno[2]; /* # line numbers */ - - } x_scn; - - struct - { - char x_tvfill[4]; /* tv fill value */ - char x_tvlen[2]; /* length of .tv */ - char x_tvran[2][2]; /* tv range */ - - } x_tv; /* info about .tv section (in auxent of symbol .tv)) */ - - /****************************************** - * I960-specific *2nd* aux. entry formats - ******************************************/ - struct - { - /* This is a very old typo that keeps getting propagated. */ -#define x_stdindx x_stindx - char x_stindx[4]; /* sys. table entry */ - } x_sc; /* system call entry */ - - struct - { - char x_balntry[4]; /* BAL entry point */ - } x_bal; /* BAL-callable function */ - - struct - { - char x_timestamp[4]; /* time stamp */ - char x_idstring[20]; /* producer identity string */ - - } x_ident; /* Producer ident info */ -}; - -#define SYMENT struct external_syment -#define SYMESZ 24 -#define AUXENT union external_auxent -#define AUXESZ 24 - -# define _ETEXT "_etext" - -/********************** RELOCATION DIRECTIVES **********************/ - -struct external_reloc -{ - char r_vaddr[4]; - char r_symndx[4]; - char r_type[2]; - char pad[2]; -}; - -/* r_type values for the i960. */ - -/* The i960 uses R_RELLONG, which is defined in internal.h as 0x11. - It is an absolute 32 bit relocation. */ - -#define R_IPRMED (0x19) /* 24-bit ip-relative relocation */ -#define R_OPTCALL (0x1b) /* 32-bit optimizable call (leafproc/sysproc) */ -#define R_OPTCALLX (0x1c) /* 64-bit optimizable call (leafproc/sysproc) */ - -/* The following relocation types are defined use by relaxing linkers, - which convert 32 bit calls (which require a 64 bit instruction) - into 24 bit calls (which require a 32 bit instruction) when - possible. It will be possible whenever the target of the call is - within a 24 bit range of the call instruction. - - It is always safe to ignore these relocations. They only serve to - mark points which the relaxing linker will have to consider. The - assembler must ensure that the correct code is generated even if - the relocations are ignored. In particular, this means that the - R_IPR13 relocation may not appear with an external symbol. */ - -#define R_IPR13 (0x1d) /* 13 bit ip-relative branch */ -#define R_ALIGN (0x1e) /* alignment marker. This has no - associated symbol. Instead, the - r_symndx field indicates the - require alignment at this point in - the file. It must be a power of 2. */ - -#define RELOC struct external_reloc -#define RELSZ 12 - diff --git a/include/coff/internal.h b/include/coff/internal.h index 81a84c8..2b7737d 100644 --- a/include/coff/internal.h +++ b/include/coff/internal.h @@ -257,9 +257,6 @@ struct internal_aouthdr bfd_vma text_start; /* base of text used for this file */ bfd_vma data_start; /* base of data used for this file */ - /* i960 stuff */ - unsigned long tagentries; /* number of tag entries to follow */ - /* RS/6000 stuff */ bfd_vma o_toc; /* address of TOC */ short o_snentry; /* section number for entry point */ @@ -416,7 +413,6 @@ struct internal_scnhdr unsigned long s_nreloc; /* number of relocation entries */ unsigned long s_nlnno; /* number of line number entries*/ long s_flags; /* flags */ - long s_align; /* used on I960 */ unsigned char s_page; /* TI COFF load page */ }; @@ -668,28 +664,6 @@ union internal_auxent /* 14 ??? */ #define XMC_TC0 15 /* Read-write TOC anchor */ #define XMC_TD 16 /* Read-write data in TOC */ - - /****************************************** - * I960-specific *2nd* aux. entry formats - ******************************************/ - struct - { - /* This is a very old typo that keeps getting propagated. */ -#define x_stdindx x_stindx - long x_stindx; /* sys. table entry */ - } x_sc; /* system call entry */ - - struct - { - unsigned long x_balntry; /* BAL entry point */ - } x_bal; /* BAL-callable function */ - - struct - { - unsigned long x_timestamp; /* time stamp */ - char x_idstring[20]; /* producer identity string */ - } x_ident; /* Producer ident info */ - }; /********************** RELOCATION DIRECTIVES **********************/ diff --git a/include/elf/i860.h b/include/elf/i860.h deleted file mode 100644 index 7762c1d..0000000 --- a/include/elf/i860.h +++ /dev/null @@ -1,66 +0,0 @@ -/* i860 ELF support for BFD. - Copyright (C) 2000-2018 Free Software Foundation, Inc. - - Contributed by Jason Eckhardt <jle@cygnus.com>. - - 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. */ - -#ifndef _ELF_I860_H -#define _ELF_I860_H - -/* Note: i860 ELF is defined to use only RELA relocations. */ - -#include "elf/reloc-macros.h" - -START_RELOC_NUMBERS (elf_i860_reloc_type) - RELOC_NUMBER (R_860_NONE, 0x00) /* No reloc */ - RELOC_NUMBER (R_860_32, 0x01) /* S+A */ - RELOC_NUMBER (R_860_COPY, 0x02) /* No calculation */ - RELOC_NUMBER (R_860_GLOB_DAT, 0x03) /* S, Create GOT entry */ - RELOC_NUMBER (R_860_JUMP_SLOT, 0x04) /* S+A, Create PLT entry */ - RELOC_NUMBER (R_860_RELATIVE, 0x05) /* B+A, Adj by program base */ - RELOC_NUMBER (R_860_PC26, 0x30) /* (S+A-P) >> 2 */ - RELOC_NUMBER (R_860_PLT26, 0x31) /* (L+A-P) >> 2 */ - RELOC_NUMBER (R_860_PC16, 0x32) /* (S+A-P) >> 2 */ - RELOC_NUMBER (R_860_LOW0, 0x40) /* S+A */ - RELOC_NUMBER (R_860_SPLIT0, 0x42) /* S+A */ - RELOC_NUMBER (R_860_LOW1, 0x44) /* S+A */ - RELOC_NUMBER (R_860_SPLIT1, 0x46) /* S+A */ - RELOC_NUMBER (R_860_LOW2, 0x48) /* S+A */ - RELOC_NUMBER (R_860_SPLIT2, 0x4A) /* S+A */ - RELOC_NUMBER (R_860_LOW3, 0x4C) /* S+A */ - RELOC_NUMBER (R_860_LOGOT0, 0x50) /* G */ - RELOC_NUMBER (R_860_SPGOT0, 0x52) /* G */ - RELOC_NUMBER (R_860_LOGOT1, 0x54) /* G */ - RELOC_NUMBER (R_860_SPGOT1, 0x56) /* G */ - RELOC_NUMBER (R_860_LOGOTOFF0, 0x60) /* O */ - RELOC_NUMBER (R_860_SPGOTOFF0, 0x62) /* O */ - RELOC_NUMBER (R_860_LOGOTOFF1, 0x64) /* O */ - RELOC_NUMBER (R_860_SPGOTOFF1, 0x66) /* O */ - RELOC_NUMBER (R_860_LOGOTOFF2, 0x68) /* O */ - RELOC_NUMBER (R_860_LOGOTOFF3, 0x6C) /* O */ - RELOC_NUMBER (R_860_LOPC, 0x70) /* (S+A-P) >> 2 */ - RELOC_NUMBER (R_860_HIGHADJ, 0x80) /* hiadj(S+A) */ - RELOC_NUMBER (R_860_HAGOT, 0x90) /* hiadj(G) */ - RELOC_NUMBER (R_860_HAGOTOFF, 0xA0) /* hiadj(O) */ - RELOC_NUMBER (R_860_HAPC, 0xB0) /* hiadj((S+A-P) >> 2) */ - RELOC_NUMBER (R_860_HIGH, 0xC0) /* (S+A) >> 16 */ - RELOC_NUMBER (R_860_HIGOT, 0xD0) /* G >> 16 */ - RELOC_NUMBER (R_860_HIGOTOFF, 0xE0) /* O */ -END_RELOC_NUMBERS (R_860_max) - -#endif diff --git a/include/elf/i960.h b/include/elf/i960.h deleted file mode 100644 index 1b9a587..0000000 --- a/include/elf/i960.h +++ /dev/null @@ -1,37 +0,0 @@ -/* Intel 960 ELF support for BFD. - Copyright (C) 1999-2018 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. */ - -#ifndef _ELF_I960_H -#define _ELF_I960_H - -#include "elf/reloc-macros.h" - - -START_RELOC_NUMBERS (elf_i960_reloc_type) - RELOC_NUMBER (R_960_NONE, 0) - RELOC_NUMBER (R_960_12, 1) - RELOC_NUMBER (R_960_32, 2) - RELOC_NUMBER (R_960_IP24, 3) - RELOC_NUMBER (R_960_SUB, 4) - RELOC_NUMBER (R_960_OPTCALL, 5) - RELOC_NUMBER (R_960_OPTCALLX, 6) - RELOC_NUMBER (R_960_OPTCALLXA, 7) -END_RELOC_NUMBERS (R_960_max) - -#endif /* _ELF_I960_H */ diff --git a/include/opcode/i860.h b/include/opcode/i860.h deleted file mode 100644 index 3a0e57f..0000000 --- a/include/opcode/i860.h +++ /dev/null @@ -1,506 +0,0 @@ -/* Table of opcodes for the i860. - Copyright (C) 1989-2018 Free Software Foundation, Inc. - - This file is part of the GNU opcodes library. - - GAS/GDB 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/GDB 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 or GDB; see the file COPYING3. If not, write to - the Free Software Foundation, 51 Franklin Street - Fifth Floor, - Boston, MA 02110-1301, USA. */ - -/* Structure of an opcode table entry. */ -struct i860_opcode -{ - /* The opcode name. */ - const char *name; - - /* Bits that must be set. */ - unsigned long match; - - /* Bits that must not be set. */ - unsigned long lose; - - const char *args; - - /* Nonzero if this is a possible expand-instruction. */ - char expand; -}; - - -enum expand_type -{ - E_MOV = 1, E_ADDR, E_U32, E_AND, E_S32, E_DELAY, XP_ONLY -}; - - -/* All i860 opcodes are 32 bits, except for the pseudo-instructions - and the operations utilizing a 32-bit address expression, an - unsigned 32-bit constant, or a signed 32-bit constant. - These opcodes are expanded into a two-instruction sequence for - any situation where the immediate operand does not fit in 32 bits. - In the case of the add and subtract operations the expansion is - to a three-instruction sequence (ex: orh, or, adds). In cases - where the address is to be relocated, the instruction is - expanded to handle the worse case, this could be optimized at - the final link if the actual address were known. - - The pseudoinstructions are: mov, fmov, pmov, nop, and fnop. - These instructions are implemented as a one or two instruction - sequence of other operations. - - The match component is a mask saying which bits must match a - particular opcode in order for an instruction to be an instance - of that opcode. - - The args component is a string containing one character - for each operand of the instruction. - -Kinds of operands: - # Number used by optimizer. It is ignored. - 1 src1 integer register. - 2 src2 integer register. - d dest register. - c ctrlreg control register. - i 16 bit immediate. - I 16 bit immediate, aligned 2^0. (ld.b) - J 16 bit immediate, aligned 2^1. (ld.s) - K 16 bit immediate, aligned 2^2. (ld.l, {p}fld.l, fst.l) - L 16 bit immediate, aligned 2^3. ({p}fld.d, fst.d) - M 16 bit immediate, aligned 2^4. ({p}fld.q, fst.q) - 5 5 bit immediate. - l lbroff 26 bit PC relative immediate. - r sbroff 16 bit PC relative immediate. - s split 16 bit immediate. - S split 16 bit immediate, aligned 2^0. (st.b) - T split 16 bit immediate, aligned 2^1. (st.s) - U split 16 bit immediate, aligned 2^2. (st.l) - e src1 floating point register. - f src2 floating point register. - g dest floating point register. */ - - -/* The order of the opcodes in this table is significant. The assembler - requires that all instances of the same mnemonic must be consecutive. - If they aren't, the assembler will not function properly. - - The order of opcodes does not affect the disassembler. */ - -static const struct i860_opcode i860_opcodes[] = -{ -/* REG-Format Instructions. */ -{ "ld.c", 0x30000000, 0xcc000000, "c,d", 0 }, /* ld.c csrc2,idest */ -{ "ld.b", 0x00000000, 0xfc000000, "1(2),d", 0 }, /* ld.b isrc1(isrc2),idest */ -{ "ld.b", 0x04000000, 0xf8000000, "I(2),d", E_ADDR }, /* ld.b #const(isrc2),idest */ -{ "ld.s", 0x10000000, 0xec000001, "1(2),d", 0 }, /* ld.s isrc1(isrc2),idest */ -{ "ld.s", 0x14000000, 0xe8000001, "J(2),d", E_ADDR }, /* ld.s #const(isrc2),idest */ -{ "ld.l", 0x10000001, 0xec000000, "1(2),d", 0 }, /* ld.l isrc1(isrc2),idest */ -{ "ld.l", 0x14000001, 0xe8000000, "K(2),d", E_ADDR }, /* ld.l #const(isrc2),idest */ - -{ "st.c", 0x38000000, 0xc4000000, "1,c", 0 }, /* st.c isrc1ni,csrc2 */ -{ "st.b", 0x0c000000, 0xf0000000, "1,S(2)", E_ADDR }, /* st.b isrc1ni,#const(isrc2) */ -{ "st.s", 0x1c000000, 0xe0000001, "1,T(2)", E_ADDR }, /* st.s isrc1ni,#const(isrc2) */ -{ "st.l", 0x1c000001, 0xe0000000, "1,U(2)", E_ADDR }, /* st.l isrc1ni,#const(isrc2) */ - -{ "ixfr", 0x08000000, 0xf4000000, "1,g", 0 }, /* ixfr isrc1ni,fdest */ - -{ "fld.l", 0x20000002, 0xdc000001, "1(2),g", 0 }, /* fld.l isrc1(isrc2),fdest */ -{ "fld.l", 0x24000002, 0xd8000001, "K(2),g", E_ADDR }, /* fld.l #const(isrc2),fdest */ -{ "fld.l", 0x20000003, 0xdc000000, "1(2)++,g", 0 }, /* fld.l isrc1(isrc2)++,fdest */ -{ "fld.l", 0x24000003, 0xd8000000, "K(2)++,g", E_ADDR }, /* fld.l #const(isrc2)++,fdest */ -{ "fld.d", 0x20000000, 0xdc000007, "1(2),g", 0 }, /* fld.d isrc1(isrc2),fdest */ -{ "fld.d", 0x24000000, 0xd8000007, "L(2),g", E_ADDR }, /* fld.d #const(isrc2),fdest */ -{ "fld.d", 0x20000001, 0xdc000006, "1(2)++,g", 0 }, /* fld.d isrc1(isrc2)++,fdest */ -{ "fld.d", 0x24000001, 0xd8000006, "L(2)++,g", E_ADDR }, /* fld.d #const(isrc2)++,fdest */ -{ "fld.q", 0x20000004, 0xdc000003, "1(2),g", 0 }, /* fld.q isrc1(isrc2),fdest */ -{ "fld.q", 0x24000004, 0xd8000003, "M(2),g", E_ADDR }, /* fld.q #const(isrc2),fdest */ -{ "fld.q", 0x20000005, 0xdc000002, "1(2)++,g", 0 }, /* fld.q isrc1(isrc2)++,fdest */ -{ "fld.q", 0x24000005, 0xd8000002, "M(2)++,g", E_ADDR }, /* fld.q #const(isrc2)++,fdest */ - -{ "pfld.l", 0x60000002, 0x9c000001, "1(2),g", 0 }, /* pfld.l isrc1(isrc2),fdest */ -{ "pfld.l", 0x64000002, 0x98000001, "K(2),g", E_ADDR }, /* pfld.l #const(isrc2),fdest */ -{ "pfld.l", 0x60000003, 0x9c000000, "1(2)++,g", 0 }, /* pfld.l isrc1(isrc2)++,fdest */ -{ "pfld.l", 0x64000003, 0x98000000, "K(2)++,g", E_ADDR }, /* pfld.l #const(isrc2)++,fdest */ -{ "pfld.d", 0x60000000, 0x9c000007, "1(2),g", 0 }, /* pfld.d isrc1(isrc2),fdest */ -{ "pfld.d", 0x64000000, 0x98000007, "L(2),g", E_ADDR }, /* pfld.d #const(isrc2),fdest */ -{ "pfld.d", 0x60000001, 0x9c000006, "1(2)++,g", 0 }, /* pfld.d isrc1(isrc2)++,fdest */ -{ "pfld.d", 0x64000001, 0x98000006, "L(2)++,g", E_ADDR }, /* pfld.d #const(isrc2)++,fdest */ -{ "pfld.q", 0x60000004, 0x9c000003, "1(2),g", XP_ONLY }, /* pfld.q isrc1(isrc2),fdest */ -{ "pfld.q", 0x64000004, 0x98000003, "L(2),g", XP_ONLY }, /* pfld.q #const(isrc2),fdest */ -{ "pfld.q", 0x60000005, 0x9c000002, "1(2)++,g", XP_ONLY }, /* pfld.q isrc1(isrc2)++,fdest */ -{ "pfld.q", 0x64000005, 0x98000002, "L(2)++,g", XP_ONLY }, /* pfld.q #const(isrc2)++,fdest */ - -{ "fst.l", 0x28000002, 0xd4000001, "g,1(2)", 0 }, /* fst.l fdest,isrc1(isrc2) */ -{ "fst.l", 0x2c000002, 0xd0000001, "g,K(2)", E_ADDR }, /* fst.l fdest,#const(isrc2) */ -{ "fst.l", 0x28000003, 0xd4000000, "g,1(2)++", 0 }, /* fst.l fdest,isrc1(isrc2)++ */ -{ "fst.l", 0x2c000003, 0xd0000000, "g,K(2)++", E_ADDR }, /* fst.l fdest,#const(isrc2)++ */ -{ "fst.d", 0x28000000, 0xd4000007, "g,1(2)", 0 }, /* fst.d fdest,isrc1(isrc2) */ -{ "fst.d", 0x2c000000, 0xd0000007, "g,L(2)", E_ADDR }, /* fst.d fdest,#const(isrc2) */ -{ "fst.d", 0x28000001, 0xd4000006, "g,1(2)++", 0 }, /* fst.d fdest,isrc1(isrc2)++ */ -{ "fst.d", 0x2c000001, 0xd0000006, "g,L(2)++", E_ADDR }, /* fst.d fdest,#const(isrc2)++ */ -{ "fst.q", 0x28000004, 0xd4000003, "g,1(2)", 0 }, /* fst.d fdest,isrc1(isrc2) */ -{ "fst.q", 0x2c000004, 0xd0000003, "g,M(2)", E_ADDR }, /* fst.d fdest,#const(isrc2) */ -{ "fst.q", 0x28000005, 0xd4000002, "g,1(2)++", 0 }, /* fst.d fdest,isrc1(isrc2)++ */ -{ "fst.q", 0x2c000005, 0xd0000002, "g,M(2)++", E_ADDR }, /* fst.d fdest,#const(isrc2)++ */ - -{ "pst.d", 0x3c000000, 0xc0000007, "g,L(2)", E_ADDR }, /* pst.d fdest,#const(isrc2) */ -{ "pst.d", 0x3c000001, 0xc0000006, "g,L(2)++", E_ADDR }, /* pst.d fdest,#const(isrc2)++ */ - -{ "addu", 0x80000000, 0x7c000000, "1,2,d", 0 }, /* addu isrc1,isrc2,idest */ -{ "addu", 0x84000000, 0x78000000, "i,2,d", E_S32 }, /* addu #const,isrc2,idest */ -{ "adds", 0x90000000, 0x6c000000, "1,2,d", 0 }, /* adds isrc1,isrc2,idest */ -{ "adds", 0x94000000, 0x68000000, "i,2,d", E_S32 }, /* adds #const,isrc2,idest */ -{ "subu", 0x88000000, 0x74000000, "1,2,d", 0 }, /* subu isrc1,isrc2,idest */ -{ "subu", 0x8c000000, 0x70000000, "i,2,d", E_S32 }, /* subu #const,isrc2,idest */ -{ "subs", 0x98000000, 0x64000000, "1,2,d", 0 }, /* subs isrc1,isrc2,idest */ -{ "subs", 0x9c000000, 0x60000000, "i,2,d", E_S32 }, /* subs #const,isrc2,idest */ - -{ "shl", 0xa0000000, 0x5c000000, "1,2,d", 0 }, /* shl isrc1,isrc2,idest */ -{ "shl", 0xa4000000, 0x58000000, "i,2,d", 0 }, /* shl #const,isrc2,idest */ -{ "shr", 0xa8000000, 0x54000000, "1,2,d", 0 }, /* shr isrc1,isrc2,idest */ -{ "shr", 0xac000000, 0x50000000, "i,2,d", 0 }, /* shr #const,isrc2,idest */ -{ "shrd", 0xb0000000, 0x4c000000, "1,2,d", 0 }, /* shrd isrc1,isrc2,idest */ -{ "shra", 0xb8000000, 0x44000000, "1,2,d", 0 }, /* shra isrc1,isrc2,idest */ -{ "shra", 0xbc000000, 0x40000000, "i,2,d", 0 }, /* shra #const,isrc2,idest */ - -{ "mov", 0xa0000000, 0x5c00f800, "2,d", 0 }, /* shl r0,isrc2,idest */ -{ "mov", 0x94000000, 0x69e00000, "i,d", E_MOV }, /* adds #const,r0,idest */ -{ "nop", 0xa0000000, 0x5ffff800, "", 0 }, /* shl r0,r0,r0 */ -{ "fnop", 0xb0000000, 0x4ffff800, "", 0 }, /* shrd r0,r0,r0 */ - -{ "trap", 0x44000000, 0xb8000000, "1,2,d", 0 }, /* trap isrc1ni,isrc2,idest */ - -{ "flush", 0x34000004, 0xc81f0003, "L(2)", E_ADDR }, /* flush #const(isrc2) */ -{ "flush", 0x34000005, 0xc81f0002, "L(2)++", E_ADDR }, /* flush #const(isrc2)++ */ - -{ "and", 0xc0000000, 0x3c000000, "1,2,d", 0 }, /* and isrc1,isrc2,idest */ -{ "and", 0xc4000000, 0x38000000, "i,2,d", E_AND }, /* and #const,isrc2,idest */ -{ "andh", 0xcc000000, 0x30000000, "i,2,d", 0 }, /* andh #const,isrc2,idest */ -{ "andnot", 0xd0000000, 0x2c000000, "1,2,d", 0 }, /* andnot isrc1,isrc2,idest */ -{ "andnot", 0xd4000000, 0x28000000, "i,2,d", E_U32 }, /* andnot #const,isrc2,idest */ -{ "andnoth", 0xdc000000, 0x20000000, "i,2,d", 0 }, /* andnoth #const,isrc2,idest */ -{ "or", 0xe0000000, 0x1c000000, "1,2,d", 0 }, /* or isrc1,isrc2,idest */ -{ "or", 0xe4000000, 0x18000000, "i,2,d", E_U32 }, /* or #const,isrc2,idest */ -{ "orh", 0xec000000, 0x10000000, "i,2,d", 0 }, /* orh #const,isrc2,idest */ -{ "xor", 0xf0000000, 0x0c000000, "1,2,d", 0 }, /* xor isrc1,isrc2,idest */ -{ "xor", 0xf4000000, 0x08000000, "i,2,d", E_U32 }, /* xor #const,isrc2,idest */ -{ "xorh", 0xfc000000, 0x00000000, "i,2,d", 0 }, /* xorh #const,isrc2,idest */ - -{ "bte", 0x58000000, 0xa4000000, "1,2,r", 0 }, /* bte isrc1s,isrc2,sbroff */ -{ "bte", 0x5c000000, 0xa0000000, "5,2,r", 0 }, /* bte #const5,isrc2,sbroff */ -{ "btne", 0x50000000, 0xac000000, "1,2,r", 0 }, /* btne isrc1s,isrc2,sbroff */ -{ "btne", 0x54000000, 0xa8000000, "5,2,r", 0 }, /* btne #const5,isrc2,sbroff */ -{ "bla", 0xb4000000, 0x48000000, "1,2,r", E_DELAY }, /* bla isrc1s,isrc2,sbroff */ -{ "bri", 0x40000000, 0xbc000000, "1", E_DELAY }, /* bri isrc1ni */ - -/* Core Escape Instruction Format */ -{ "lock", 0x4c000001, 0xb000001e, "", 0 }, /* lock set BL in dirbase */ -{ "calli", 0x4c000002, 0xb000001d, "1", E_DELAY }, /* calli isrc1ni */ -{ "intovr", 0x4c000004, 0xb000001b, "", 0 }, /* intovr trap on integer overflow */ -{ "unlock", 0x4c000007, 0xb0000018, "", 0 }, /* unlock clear BL in dirbase */ -{ "ldio.l", 0x4c000408, 0xb00003f7, "2,d", XP_ONLY }, /* ldio.l isrc2,idest */ -{ "ldio.s", 0x4c000208, 0xb00005f7, "2,d", XP_ONLY }, /* ldio.s isrc2,idest */ -{ "ldio.b", 0x4c000008, 0xb00007f7, "2,d", XP_ONLY }, /* ldio.b isrc2,idest */ -{ "stio.l", 0x4c000409, 0xb00003f6, "1,2", XP_ONLY }, /* stio.l isrc1ni,isrc2 */ -{ "stio.s", 0x4c000209, 0xb00005f6, "1,2", XP_ONLY }, /* stio.s isrc1ni,isrc2 */ -{ "stio.b", 0x4c000009, 0xb00007f6, "1,2", XP_ONLY }, /* stio.b isrc1ni,isrc2 */ -{ "ldint.l", 0x4c00040a, 0xb00003f5, "2,d", XP_ONLY }, /* ldint.l isrc2,idest */ -{ "ldint.s", 0x4c00020a, 0xb00005f5, "2,d", XP_ONLY }, /* ldint.s isrc2,idest */ -{ "ldint.b", 0x4c00000a, 0xb00007f5, "2,d", XP_ONLY }, /* ldint.b isrc2,idest */ -{ "scyc.b", 0x4c00000b, 0xb00007f4, "2", XP_ONLY }, /* scyc.b isrc2 */ - -/* CTRL-Format Instructions */ -{ "br", 0x68000000, 0x94000000, "l", E_DELAY }, /* br lbroff */ -{ "call", 0x6c000000, 0x90000000, "l", E_DELAY }, /* call lbroff */ -{ "bc", 0x70000000, 0x8c000000, "l", 0 }, /* bc lbroff */ -{ "bc.t", 0x74000000, 0x88000000, "l", E_DELAY }, /* bc.t lbroff */ -{ "bnc", 0x78000000, 0x84000000, "l", 0 }, /* bnc lbroff */ -{ "bnc.t", 0x7c000000, 0x80000000, "l", E_DELAY }, /* bnc.t lbroff */ - -/* Floating Point Escape Instruction Format - pfam.p fsrc1,fsrc2,fdest. */ -{ "r2p1.ss", 0x48000400, 0xb40001ff, "e,f,g", 0 }, -{ "r2p1.sd", 0x48000480, 0xb400017f, "e,f,g", 0 }, -{ "r2p1.dd", 0x48000580, 0xb400007f, "e,f,g", 0 }, -{ "r2pt.ss", 0x48000401, 0xb40001fe, "e,f,g", 0 }, -{ "r2pt.sd", 0x48000481, 0xb400017e, "e,f,g", 0 }, -{ "r2pt.dd", 0x48000581, 0xb400007e, "e,f,g", 0 }, -{ "r2ap1.ss", 0x48000402, 0xb40001fd, "e,f,g", 0 }, -{ "r2ap1.sd", 0x48000482, 0xb400017d, "e,f,g", 0 }, -{ "r2ap1.dd", 0x48000582, 0xb400007d, "e,f,g", 0 }, -{ "r2apt.ss", 0x48000403, 0xb40001fc, "e,f,g", 0 }, -{ "r2apt.sd", 0x48000483, 0xb400017c, "e,f,g", 0 }, -{ "r2apt.dd", 0x48000583, 0xb400007c, "e,f,g", 0 }, -{ "i2p1.ss", 0x48000404, 0xb40001fb, "e,f,g", 0 }, -{ "i2p1.sd", 0x48000484, 0xb400017b, "e,f,g", 0 }, -{ "i2p1.dd", 0x48000584, 0xb400007b, "e,f,g", 0 }, -{ "i2pt.ss", 0x48000405, 0xb40001fa, "e,f,g", 0 }, -{ "i2pt.sd", 0x48000485, 0xb400017a, "e,f,g", 0 }, -{ "i2pt.dd", 0x48000585, 0xb400007a, "e,f,g", 0 }, -{ "i2ap1.ss", 0x48000406, 0xb40001f9, "e,f,g", 0 }, -{ "i2ap1.sd", 0x48000486, 0xb4000179, "e,f,g", 0 }, -{ "i2ap1.dd", 0x48000586, 0xb4000079, "e,f,g", 0 }, -{ "i2apt.ss", 0x48000407, 0xb40001f8, "e,f,g", 0 }, -{ "i2apt.sd", 0x48000487, 0xb4000178, "e,f,g", 0 }, -{ "i2apt.dd", 0x48000587, 0xb4000078, "e,f,g", 0 }, -{ "rat1p2.ss", 0x48000408, 0xb40001f7, "e,f,g", 0 }, -{ "rat1p2.sd", 0x48000488, 0xb4000177, "e,f,g", 0 }, -{ "rat1p2.dd", 0x48000588, 0xb4000077, "e,f,g", 0 }, -{ "m12apm.ss", 0x48000409, 0xb40001f6, "e,f,g", 0 }, -{ "m12apm.sd", 0x48000489, 0xb4000176, "e,f,g", 0 }, -{ "m12apm.dd", 0x48000589, 0xb4000076, "e,f,g", 0 }, -{ "ra1p2.ss", 0x4800040a, 0xb40001f5, "e,f,g", 0 }, -{ "ra1p2.sd", 0x4800048a, 0xb4000175, "e,f,g", 0 }, -{ "ra1p2.dd", 0x4800058a, 0xb4000075, "e,f,g", 0 }, -{ "m12ttpa.ss", 0x4800040b, 0xb40001f4, "e,f,g", 0 }, -{ "m12ttpa.sd", 0x4800048b, 0xb4000174, "e,f,g", 0 }, -{ "m12ttpa.dd", 0x4800058b, 0xb4000074, "e,f,g", 0 }, -{ "iat1p2.ss", 0x4800040c, 0xb40001f3, "e,f,g", 0 }, -{ "iat1p2.sd", 0x4800048c, 0xb4000173, "e,f,g", 0 }, -{ "iat1p2.dd", 0x4800058c, 0xb4000073, "e,f,g", 0 }, -{ "m12tpm.ss", 0x4800040d, 0xb40001f2, "e,f,g", 0 }, -{ "m12tpm.sd", 0x4800048d, 0xb4000172, "e,f,g", 0 }, -{ "m12tpm.dd", 0x4800058d, 0xb4000072, "e,f,g", 0 }, -{ "ia1p2.ss", 0x4800040e, 0xb40001f1, "e,f,g", 0 }, -{ "ia1p2.sd", 0x4800048e, 0xb4000171, "e,f,g", 0 }, -{ "ia1p2.dd", 0x4800058e, 0xb4000071, "e,f,g", 0 }, -{ "m12tpa.ss", 0x4800040f, 0xb40001f0, "e,f,g", 0 }, -{ "m12tpa.sd", 0x4800048f, 0xb4000170, "e,f,g", 0 }, -{ "m12tpa.dd", 0x4800058f, 0xb4000070, "e,f,g", 0 }, - -/* Floating Point Escape Instruction Format - pfsm.p fsrc1,fsrc2,fdest. */ -{ "r2s1.ss", 0x48000410, 0xb40001ef, "e,f,g", 0 }, -{ "r2s1.sd", 0x48000490, 0xb400016f, "e,f,g", 0 }, -{ "r2s1.dd", 0x48000590, 0xb400006f, "e,f,g", 0 }, -{ "r2st.ss", 0x48000411, 0xb40001ee, "e,f,g", 0 }, -{ "r2st.sd", 0x48000491, 0xb400016e, "e,f,g", 0 }, -{ "r2st.dd", 0x48000591, 0xb400006e, "e,f,g", 0 }, -{ "r2as1.ss", 0x48000412, 0xb40001ed, "e,f,g", 0 }, -{ "r2as1.sd", 0x48000492, 0xb400016d, "e,f,g", 0 }, -{ "r2as1.dd", 0x48000592, 0xb400006d, "e,f,g", 0 }, -{ "r2ast.ss", 0x48000413, 0xb40001ec, "e,f,g", 0 }, -{ "r2ast.sd", 0x48000493, 0xb400016c, "e,f,g", 0 }, -{ "r2ast.dd", 0x48000593, 0xb400006c, "e,f,g", 0 }, -{ "i2s1.ss", 0x48000414, 0xb40001eb, "e,f,g", 0 }, -{ "i2s1.sd", 0x48000494, 0xb400016b, "e,f,g", 0 }, -{ "i2s1.dd", 0x48000594, 0xb400006b, "e,f,g", 0 }, -{ "i2st.ss", 0x48000415, 0xb40001ea, "e,f,g", 0 }, -{ "i2st.sd", 0x48000495, 0xb400016a, "e,f,g", 0 }, -{ "i2st.dd", 0x48000595, 0xb400006a, "e,f,g", 0 }, -{ "i2as1.ss", 0x48000416, 0xb40001e9, "e,f,g", 0 }, -{ "i2as1.sd", 0x48000496, 0xb4000169, "e,f,g", 0 }, -{ "i2as1.dd", 0x48000596, 0xb4000069, "e,f,g", 0 }, -{ "i2ast.ss", 0x48000417, 0xb40001e8, "e,f,g", 0 }, -{ "i2ast.sd", 0x48000497, 0xb4000168, "e,f,g", 0 }, -{ "i2ast.dd", 0x48000597, 0xb4000068, "e,f,g", 0 }, -{ "rat1s2.ss", 0x48000418, 0xb40001e7, "e,f,g", 0 }, -{ "rat1s2.sd", 0x48000498, 0xb4000167, "e,f,g", 0 }, -{ "rat1s2.dd", 0x48000598, 0xb4000067, "e,f,g", 0 }, -{ "m12asm.ss", 0x48000419, 0xb40001e6, "e,f,g", 0 }, -{ "m12asm.sd", 0x48000499, 0xb4000166, "e,f,g", 0 }, -{ "m12asm.dd", 0x48000599, 0xb4000066, "e,f,g", 0 }, -{ "ra1s2.ss", 0x4800041a, 0xb40001e5, "e,f,g", 0 }, -{ "ra1s2.sd", 0x4800049a, 0xb4000165, "e,f,g", 0 }, -{ "ra1s2.dd", 0x4800059a, 0xb4000065, "e,f,g", 0 }, -{ "m12ttsa.ss", 0x4800041b, 0xb40001e4, "e,f,g", 0 }, -{ "m12ttsa.sd", 0x4800049b, 0xb4000164, "e,f,g", 0 }, -{ "m12ttsa.dd", 0x4800059b, 0xb4000064, "e,f,g", 0 }, -{ "iat1s2.ss", 0x4800041c, 0xb40001e3, "e,f,g", 0 }, -{ "iat1s2.sd", 0x4800049c, 0xb4000163, "e,f,g", 0 }, -{ "iat1s2.dd", 0x4800059c, 0xb4000063, "e,f,g", 0 }, -{ "m12tsm.ss", 0x4800041d, 0xb40001e2, "e,f,g", 0 }, -{ "m12tsm.sd", 0x4800049d, 0xb4000162, "e,f,g", 0 }, -{ "m12tsm.dd", 0x4800059d, 0xb4000062, "e,f,g", 0 }, -{ "ia1s2.ss", 0x4800041e, 0xb40001e1, "e,f,g", 0 }, -{ "ia1s2.sd", 0x4800049e, 0xb4000161, "e,f,g", 0 }, -{ "ia1s2.dd", 0x4800059e, 0xb4000061, "e,f,g", 0 }, -{ "m12tsa.ss", 0x4800041f, 0xb40001e0, "e,f,g", 0 }, -{ "m12tsa.sd", 0x4800049f, 0xb4000160, "e,f,g", 0 }, -{ "m12tsa.dd", 0x4800059f, 0xb4000060, "e,f,g", 0 }, - -/* Floating Point Escape Instruction Format - pfmam.p fsrc1,fsrc2,fdest. */ -{ "mr2p1.ss", 0x48000000, 0xb40005ff, "e,f,g", 0 }, -{ "mr2p1.sd", 0x48000080, 0xb400057f, "e,f,g", 0 }, -{ "mr2p1.dd", 0x48000180, 0xb400047f, "e,f,g", 0 }, -{ "mr2pt.ss", 0x48000001, 0xb40005fe, "e,f,g", 0 }, -{ "mr2pt.sd", 0x48000081, 0xb400057e, "e,f,g", 0 }, -{ "mr2pt.dd", 0x48000181, 0xb400047e, "e,f,g", 0 }, -{ "mr2mp1.ss", 0x48000002, 0xb40005fd, "e,f,g", 0 }, -{ "mr2mp1.sd", 0x48000082, 0xb400057d, "e,f,g", 0 }, -{ "mr2mp1.dd", 0x48000182, 0xb400047d, "e,f,g", 0 }, -{ "mr2mpt.ss", 0x48000003, 0xb40005fc, "e,f,g", 0 }, -{ "mr2mpt.sd", 0x48000083, 0xb400057c, "e,f,g", 0 }, -{ "mr2mpt.dd", 0x48000183, 0xb400047c, "e,f,g", 0 }, -{ "mi2p1.ss", 0x48000004, 0xb40005fb, "e,f,g", 0 }, -{ "mi2p1.sd", 0x48000084, 0xb400057b, "e,f,g", 0 }, -{ "mi2p1.dd", 0x48000184, 0xb400047b, "e,f,g", 0 }, -{ "mi2pt.ss", 0x48000005, 0xb40005fa, "e,f,g", 0 }, -{ "mi2pt.sd", 0x48000085, 0xb400057a, "e,f,g", 0 }, -{ "mi2pt.dd", 0x48000185, 0xb400047a, "e,f,g", 0 }, -{ "mi2mp1.ss", 0x48000006, 0xb40005f9, "e,f,g", 0 }, -{ "mi2mp1.sd", 0x48000086, 0xb4000579, "e,f,g", 0 }, -{ "mi2mp1.dd", 0x48000186, 0xb4000479, "e,f,g", 0 }, -{ "mi2mpt.ss", 0x48000007, 0xb40005f8, "e,f,g", 0 }, -{ "mi2mpt.sd", 0x48000087, 0xb4000578, "e,f,g", 0 }, -{ "mi2mpt.dd", 0x48000187, 0xb4000478, "e,f,g", 0 }, -{ "mrmt1p2.ss", 0x48000008, 0xb40005f7, "e,f,g", 0 }, -{ "mrmt1p2.sd", 0x48000088, 0xb4000577, "e,f,g", 0 }, -{ "mrmt1p2.dd", 0x48000188, 0xb4000477, "e,f,g", 0 }, -{ "mm12mpm.ss", 0x48000009, 0xb40005f6, "e,f,g", 0 }, -{ "mm12mpm.sd", 0x48000089, 0xb4000576, "e,f,g", 0 }, -{ "mm12mpm.dd", 0x48000189, 0xb4000476, "e,f,g", 0 }, -{ "mrm1p2.ss", 0x4800000a, 0xb40005f5, "e,f,g", 0 }, -{ "mrm1p2.sd", 0x4800008a, 0xb4000575, "e,f,g", 0 }, -{ "mrm1p2.dd", 0x4800018a, 0xb4000475, "e,f,g", 0 }, -{ "mm12ttpm.ss",0x4800000b, 0xb40005f4, "e,f,g", 0 }, -{ "mm12ttpm.sd",0x4800008b, 0xb4000574, "e,f,g", 0 }, -{ "mm12ttpm.dd",0x4800018b, 0xb4000474, "e,f,g", 0 }, -{ "mimt1p2.ss", 0x4800000c, 0xb40005f3, "e,f,g", 0 }, -{ "mimt1p2.sd", 0x4800008c, 0xb4000573, "e,f,g", 0 }, -{ "mimt1p2.dd", 0x4800018c, 0xb4000473, "e,f,g", 0 }, -{ "mm12tpm.ss", 0x4800000d, 0xb40005f2, "e,f,g", 0 }, -{ "mm12tpm.sd", 0x4800008d, 0xb4000572, "e,f,g", 0 }, -{ "mm12tpm.dd", 0x4800018d, 0xb4000472, "e,f,g", 0 }, -{ "mim1p2.ss", 0x4800000e, 0xb40005f1, "e,f,g", 0 }, -{ "mim1p2.sd", 0x4800008e, 0xb4000571, "e,f,g", 0 }, -{ "mim1p2.dd", 0x4800018e, 0xb4000471, "e,f,g", 0 }, - -/* Floating Point Escape Instruction Format - pfmsm.p fsrc1,fsrc2,fdest. */ -{ "mr2s1.ss", 0x48000010, 0xb40005ef, "e,f,g", 0 }, -{ "mr2s1.sd", 0x48000090, 0xb400056f, "e,f,g", 0 }, -{ "mr2s1.dd", 0x48000190, 0xb400046f, "e,f,g", 0 }, -{ "mr2st.ss", 0x48000011, 0xb40005ee, "e,f,g", 0 }, -{ "mr2st.sd", 0x48000091, 0xb400056e, "e,f,g", 0 }, -{ "mr2st.dd", 0x48000191, 0xb400046e, "e,f,g", 0 }, -{ "mr2ms1.ss", 0x48000012, 0xb40005ed, "e,f,g", 0 }, -{ "mr2ms1.sd", 0x48000092, 0xb400056d, "e,f,g", 0 }, -{ "mr2ms1.dd", 0x48000192, 0xb400046d, "e,f,g", 0 }, -{ "mr2mst.ss", 0x48000013, 0xb40005ec, "e,f,g", 0 }, -{ "mr2mst.sd", 0x48000093, 0xb400056c, "e,f,g", 0 }, -{ "mr2mst.dd", 0x48000193, 0xb400046c, "e,f,g", 0 }, -{ "mi2s1.ss", 0x48000014, 0xb40005eb, "e,f,g", 0 }, -{ "mi2s1.sd", 0x48000094, 0xb400056b, "e,f,g", 0 }, -{ "mi2s1.dd", 0x48000194, 0xb400046b, "e,f,g", 0 }, -{ "mi2st.ss", 0x48000015, 0xb40005ea, "e,f,g", 0 }, -{ "mi2st.sd", 0x48000095, 0xb400056a, "e,f,g", 0 }, -{ "mi2st.dd", 0x48000195, 0xb400046a, "e,f,g", 0 }, -{ "mi2ms1.ss", 0x48000016, 0xb40005e9, "e,f,g", 0 }, -{ "mi2ms1.sd", 0x48000096, 0xb4000569, "e,f,g", 0 }, -{ "mi2ms1.dd", 0x48000196, 0xb4000469, "e,f,g", 0 }, -{ "mi2mst.ss", 0x48000017, 0xb40005e8, "e,f,g", 0 }, -{ "mi2mst.sd", 0x48000097, 0xb4000568, "e,f,g", 0 }, -{ "mi2mst.dd", 0x48000197, 0xb4000468, "e,f,g", 0 }, -{ "mrmt1s2.ss", 0x48000018, 0xb40005e7, "e,f,g", 0 }, -{ "mrmt1s2.sd", 0x48000098, 0xb4000567, "e,f,g", 0 }, -{ "mrmt1s2.dd", 0x48000198, 0xb4000467, "e,f,g", 0 }, -{ "mm12msm.ss", 0x48000019, 0xb40005e6, "e,f,g", 0 }, -{ "mm12msm.sd", 0x48000099, 0xb4000566, "e,f,g", 0 }, -{ "mm12msm.dd", 0x48000199, 0xb4000466, "e,f,g", 0 }, -{ "mrm1s2.ss", 0x4800001a, 0xb40005e5, "e,f,g", 0 }, -{ "mrm1s2.sd", 0x4800009a, 0xb4000565, "e,f,g", 0 }, -{ "mrm1s2.dd", 0x4800019a, 0xb4000465, "e,f,g", 0 }, -{ "mm12ttsm.ss",0x4800001b, 0xb40005e4, "e,f,g", 0 }, -{ "mm12ttsm.sd",0x4800009b, 0xb4000564, "e,f,g", 0 }, -{ "mm12ttsm.dd",0x4800019b, 0xb4000464, "e,f,g", 0 }, -{ "mimt1s2.ss", 0x4800001c, 0xb40005e3, "e,f,g", 0 }, -{ "mimt1s2.sd", 0x4800009c, 0xb4000563, "e,f,g", 0 }, -{ "mimt1s2.dd", 0x4800019c, 0xb4000463, "e,f,g", 0 }, -{ "mm12tsm.ss", 0x4800001d, 0xb40005e2, "e,f,g", 0 }, -{ "mm12tsm.sd", 0x4800009d, 0xb4000562, "e,f,g", 0 }, -{ "mm12tsm.dd", 0x4800019d, 0xb4000462, "e,f,g", 0 }, -{ "mim1s2.ss", 0x4800001e, 0xb40005e1, "e,f,g", 0 }, -{ "mim1s2.sd", 0x4800009e, 0xb4000561, "e,f,g", 0 }, -{ "mim1s2.dd", 0x4800019e, 0xb4000461, "e,f,g", 0 }, - -{ "fmul.ss", 0x48000020, 0xb40005df, "e,f,g", 0 }, /* fmul.p fsrc1,fsrc2,fdest */ -{ "fmul.sd", 0x480000a0, 0xb400055f, "e,f,g", 0 }, /* fmul.p fsrc1,fsrc2,fdest */ -{ "fmul.dd", 0x480001a0, 0xb400045f, "e,f,g", 0 }, /* fmul.p fsrc1,fsrc2,fdest */ -{ "pfmul.ss", 0x48000420, 0xb40001df, "e,f,g", 0 }, /* pfmul.p fsrc1,fsrc2,fdest */ -{ "pfmul.sd", 0x480004a0, 0xb400015f, "e,f,g", 0 }, /* pfmul.p fsrc1,fsrc2,fdest */ -{ "pfmul.dd", 0x480005a0, 0xb400005f, "e,f,g", 0 }, /* pfmul.p fsrc1,fsrc2,fdest */ -{ "pfmul3.dd", 0x480005a4, 0xb400005b, "e,f,g", 0 }, /* pfmul3.p fsrc1,fsrc2,fdest */ -{ "fmlow.dd", 0x480001a1, 0xb400045e, "e,f,g", 0 }, /* fmlow.dd fsrc1,fsrc2,fdest */ -{ "frcp.ss", 0x48000022, 0xb40005dd, "f,g", 0 }, /* frcp.p fsrc2,fdest */ -{ "frcp.sd", 0x480000a2, 0xb400055d, "f,g", 0 }, /* frcp.p fsrc2,fdest */ -{ "frcp.dd", 0x480001a2, 0xb400045d, "f,g", 0 }, /* frcp.p fsrc2,fdest */ -{ "frsqr.ss", 0x48000023, 0xb40005dc, "f,g", 0 }, /* frsqr.p fsrc2,fdest */ -{ "frsqr.sd", 0x480000a3, 0xb400055c, "f,g", 0 }, /* frsqr.p fsrc2,fdest */ -{ "frsqr.dd", 0x480001a3, 0xb400045c, "f,g", 0 }, /* frsqr.p fsrc2,fdest */ -{ "fadd.ss", 0x48000030, 0xb40005cf, "e,f,g", 0 }, /* fadd.p fsrc1,fsrc2,fdest */ -{ "fadd.sd", 0x480000b0, 0xb400054f, "e,f,g", 0 }, /* fadd.p fsrc1,fsrc2,fdest */ -{ "fadd.dd", 0x480001b0, 0xb400044f, "e,f,g", 0 }, /* fadd.p fsrc1,fsrc2,fdest */ -{ "pfadd.ss", 0x48000430, 0xb40001cf, "e,f,g", 0 }, /* pfadd.p fsrc1,fsrc2,fdest */ -{ "pfadd.sd", 0x480004b0, 0xb400014f, "e,f,g", 0 }, /* pfadd.p fsrc1,fsrc2,fdest */ -{ "pfadd.dd", 0x480005b0, 0xb400004f, "e,f,g", 0 }, /* pfadd.p fsrc1,fsrc2,fdest */ -{ "fsub.ss", 0x48000031, 0xb40005ce, "e,f,g", 0 }, /* fsub.p fsrc1,fsrc2,fdest */ -{ "fsub.sd", 0x480000b1, 0xb400054e, "e,f,g", 0 }, /* fsub.p fsrc1,fsrc2,fdest */ -{ "fsub.dd", 0x480001b1, 0xb400044e, "e,f,g", 0 }, /* fsub.p fsrc1,fsrc2,fdest */ -{ "pfsub.ss", 0x48000431, 0xb40001ce, "e,f,g", 0 }, /* pfsub.p fsrc1,fsrc2,fdest */ -{ "pfsub.sd", 0x480004b1, 0xb400014e, "e,f,g", 0 }, /* pfsub.p fsrc1,fsrc2,fdest */ -{ "pfsub.dd", 0x480005b1, 0xb400004e, "e,f,g", 0 }, /* pfsub.p fsrc1,fsrc2,fdest */ -{ "fix.sd", 0x480000b2, 0xb400054d, "e,g", 0 }, /* fix.p fsrc1,fdest */ -{ "fix.dd", 0x480001b2, 0xb400044d, "e,g", 0 }, /* fix.p fsrc1,fdest */ -{ "pfix.sd", 0x480004b2, 0xb400014d, "e,g", 0 }, /* pfix.p fsrc1,fdest */ -{ "pfix.dd", 0x480005b2, 0xb400004d, "e,g", 0 }, /* pfix.p fsrc1,fdest */ -{ "famov.ss", 0x48000033, 0xb40005cc, "e,g", 0 }, /* famov.p fsrc1,fdest */ -{ "famov.ds", 0x48000133, 0xb40004cc, "e,g", 0 }, /* famov.p fsrc1,fdest */ -{ "famov.sd", 0x480000b3, 0xb400054c, "e,g", 0 }, /* famov.p fsrc1,fdest */ -{ "famov.dd", 0x480001b3, 0xb400044c, "e,g", 0 }, /* famov.p fsrc1,fdest */ -{ "pfamov.ss", 0x48000433, 0xb40001cc, "e,g", 0 }, /* pfamov.p fsrc1,fdest */ -{ "pfamov.ds", 0x48000533, 0xb40000cc, "e,g", 0 }, /* pfamov.p fsrc1,fdest */ -{ "pfamov.sd", 0x480004b3, 0xb400014c, "e,g", 0 }, /* pfamov.p fsrc1,fdest */ -{ "pfamov.dd", 0x480005b3, 0xb400004c, "e,g", 0 }, /* pfamov.p fsrc1,fdest */ -/* Opcode pfgt has R bit cleared; pfle has R bit set. */ -{ "pfgt.ss", 0x48000434, 0xb40001cb, "e,f,g", 0 }, /* pfgt.p fsrc1,fsrc2,fdest */ -{ "pfgt.dd", 0x48000534, 0xb40000cb, "e,f,g", 0 }, /* pfgt.p fsrc1,fsrc2,fdest */ -/* Opcode pfgt has R bit cleared; pfle has R bit set. */ -{ "pfle.ss", 0x480004b4, 0xb400014b, "e,f,g", 0 }, /* pfle.p fsrc1,fsrc2,fdest */ -{ "pfle.dd", 0x480005b4, 0xb400004b, "e,f,g", 0 }, /* pfle.p fsrc1,fsrc2,fdest */ -{ "pfeq.ss", 0x48000435, 0xb40001ca, "e,f,g", 0 }, /* pfeq.p fsrc1,fsrc2,fdest */ -{ "pfeq.dd", 0x48000535, 0xb40000ca, "e,f,g", 0 }, /* pfeq.p fsrc1,fsrc2,fdest */ -{ "ftrunc.sd", 0x480000ba, 0xb4000545, "e,g", 0 }, /* ftrunc.p fsrc1,fdest */ -{ "ftrunc.dd", 0x480001ba, 0xb4000445, "e,g", 0 }, /* ftrunc.p fsrc1,fdest */ -{ "pftrunc.sd", 0x480004ba, 0xb4000145, "e,g", 0 }, /* pftrunc.p fsrc1,fdest */ -{ "pftrunc.dd", 0x480005ba, 0xb4000045, "e,g", 0 }, /* pftrunc.p fsrc1,fdest */ -{ "fxfr", 0x48000040, 0xb40005bf, "e,d", 0 }, /* fxfr fsrc1,idest */ -{ "fiadd.ss", 0x48000049, 0xb40005b6, "e,f,g", 0 }, /* fiadd.w fsrc1,fsrc2,fdest */ -{ "fiadd.dd", 0x480001c9, 0xb4000436, "e,f,g", 0 }, /* fiadd.w fsrc1,fsrc2,fdest */ -{ "pfiadd.ss", 0x48000449, 0xb40001b6, "e,f,g", 0 }, /* pfiadd.w fsrc1,fsrc2,fdest */ -{ "pfiadd.dd", 0x480005c9, 0xb4000036, "e,f,g", 0 }, /* pfiadd.w fsrc1,fsrc2,fdest */ -{ "fisub.ss", 0x4800004d, 0xb40005b2, "e,f,g", 0 }, /* fisub.w fsrc1,fsrc2,fdest */ -{ "fisub.dd", 0x480001cd, 0xb4000432, "e,f,g", 0 }, /* fisub.w fsrc1,fsrc2,fdest */ -{ "pfisub.ss", 0x4800044d, 0xb40001b2, "e,f,g", 0 }, /* pfisub.w fsrc1,fsrc2,fdest */ -{ "pfisub.dd", 0x480005cd, 0xb4000032, "e,f,g", 0 }, /* pfisub.w fsrc1,fsrc2,fdest */ -{ "fzchkl", 0x480001d7, 0xb4000428, "e,f,g", 0 }, /* fzchkl fsrc1,fsrc2,fdest */ -{ "pfzchkl", 0x480005d7, 0xb4000028, "e,f,g", 0 }, /* pfzchkl fsrc1,fsrc2,fdest */ -{ "fzchks", 0x480001df, 0xb4000420, "e,f,g", 0 }, /* fzchks fsrc1,fsrc2,fdest */ -{ "pfzchks", 0x480005df, 0xb4000020, "e,f,g", 0 }, /* pfzchks fsrc1,fsrc2,fdest */ -{ "faddp", 0x480001d0, 0xb400042f, "e,f,g", 0 }, /* faddp fsrc1,fsrc2,fdest */ -{ "pfaddp", 0x480005d0, 0xb400002f, "e,f,g", 0 }, /* pfaddp fsrc1,fsrc2,fdest */ -{ "faddz", 0x480001d1, 0xb400042e, "e,f,g", 0 }, /* faddz fsrc1,fsrc2,fdest */ -{ "pfaddz", 0x480005d1, 0xb400002e, "e,f,g", 0 }, /* pfaddz fsrc1,fsrc2,fdest */ -{ "form", 0x480001da, 0xb4000425, "e,g", 0 }, /* form fsrc1,fdest */ -{ "pform", 0x480005da, 0xb4000025, "e,g", 0 }, /* pform fsrc1,fdest */ - -/* Floating point pseudo-instructions. */ -{ "fmov.ss", 0x48000049, 0xb7e005b6, "e,g", 0 }, /* fiadd.ss fsrc1,f0,fdest */ -{ "fmov.dd", 0x480001c9, 0xb7e00436, "e,g", 0 }, /* fiadd.dd fsrc1,f0,fdest */ -{ "fmov.sd", 0x480000b3, 0xb400054c, "e,g", 0 }, /* famov.sd fsrc1,fdest */ -{ "fmov.ds", 0x48000133, 0xb40004cc, "e,g", 0 }, /* famov.ds fsrc1,fdest */ -{ "pfmov.ds", 0x48000533, 0xb40000cc, "e,g", 0 }, /* pfamov.ds fsrc1,fdest */ -{ "pfmov.dd", 0x480005c9, 0xb7e00036, "e,g", 0 }, /* pfiadd.dd fsrc1,f0,fdest */ -{ 0, 0, 0, 0, 0 }, - -}; - -#define NUMOPCODES ((sizeof i860_opcodes)/(sizeof i860_opcodes[0])) - - diff --git a/include/opcode/i960.h b/include/opcode/i960.h deleted file mode 100644 index 2c7193c..0000000 --- a/include/opcode/i960.h +++ /dev/null @@ -1,525 +0,0 @@ -/* Basic 80960 instruction formats. - - Copyright (C) 2001-2018 Free Software Foundation, Inc. - - 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, 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. */ - -/* The 'COJ' instructions are actually COBR instructions with the 'b' in - the mnemonic replaced by a 'j'; they are ALWAYS "de-optimized" if - necessary: if the displacement will not fit in 13 bits, the assembler will - replace them with the corresponding compare and branch instructions. - - All of the 'MEMn' instructions are the same format; the 'n' in the name - indicates the default index scale factor (the size of the datum operated on). - - The FBRA formats are not actually an instruction format. They are the - "convenience directives" for branching on floating-point comparisons, - each of which generates 2 instructions (a 'bno' and one other branch). - - The CALLJ format is not actually an instruction format. It indicates that - the instruction generated (a CTRL-format 'call') should have its relocation - specially flagged for link-time replacement with a 'bal' or 'calls' if - appropriate. */ - -#define CTRL 0 -#define COBR 1 -#define COJ 2 -#define REG 3 -#define MEM1 4 -#define MEM2 5 -#define MEM4 6 -#define MEM8 7 -#define MEM12 8 -#define MEM16 9 -#define FBRA 10 -#define CALLJ 11 - -/* Masks for the mode bits in REG format instructions */ -#define M1 0x0800 -#define M2 0x1000 -#define M3 0x2000 - -/* Generate the 12-bit opcode for a REG format instruction by placing the - * high 8 bits in instruction bits 24-31, the low 4 bits in instruction bits - * 7-10. - */ - -#define REG_OPC(opc) ((opc & 0xff0) << 20) | ((opc & 0xf) << 7) - -/* Generate a template for a REG format instruction: place the opcode bits - * in the appropriate fields and OR in mode bits for the operands that will not - * be used. I.e., - * set m1=1, if src1 will not be used - * set m2=1, if src2 will not be used - * set m3=1, if dst will not be used - * - * Setting the "unused" mode bits to 1 speeds up instruction execution(!). - * The information is also useful to us because some 1-operand REG instructions - * use the src1 field, others the dst field; and some 2-operand REG instructions - * use src1/src2, others src1/dst. The set mode bits enable us to distinguish. - */ -#define R_0(opc) ( REG_OPC(opc) | M1 | M2 | M3 ) /* No operands */ -#define R_1(opc) ( REG_OPC(opc) | M2 | M3 ) /* 1 operand: src1 */ -#define R_1D(opc) ( REG_OPC(opc) | M1 | M2 ) /* 1 operand: dst */ -#define R_2(opc) ( REG_OPC(opc) | M3 ) /* 2 ops: src1/src2 */ -#define R_2D(opc) ( REG_OPC(opc) | M2 ) /* 2 ops: src1/dst */ -#define R_3(opc) ( REG_OPC(opc) ) /* 3 operands */ - -/* DESCRIPTOR BYTES FOR REGISTER OPERANDS - * - * Interpret names as follows: - * R: global or local register only - * RS: global, local, or (if target allows) special-function register only - * RL: global or local register, or integer literal - * RSL: global, local, or (if target allows) special-function register; - * or integer literal - * F: global, local, or floating-point register - * FL: global, local, or floating-point register; or literal (including - * floating point) - * - * A number appended to a name indicates that registers must be aligned, - * as follows: - * 2: register number must be multiple of 2 - * 4: register number must be multiple of 4 - */ - -#define SFR 0x10 /* Mask for the "sfr-OK" bit */ -#define LIT 0x08 /* Mask for the "literal-OK" bit */ -#define FP 0x04 /* Mask for "floating-point-OK" bit */ - -/* This macro ors the bits together. Note that 'align' is a mask - * for the low 0, 1, or 2 bits of the register number, as appropriate. - */ -#define OP(align,lit,fp,sfr) ( align | lit | fp | sfr ) - -#define R OP( 0, 0, 0, 0 ) -#define RS OP( 0, 0, 0, SFR ) -#define RL OP( 0, LIT, 0, 0 ) -#define RSL OP( 0, LIT, 0, SFR ) -#define F OP( 0, 0, FP, 0 ) -#define FL OP( 0, LIT, FP, 0 ) -#define R2 OP( 1, 0, 0, 0 ) -#define RL2 OP( 1, LIT, 0, 0 ) -#define F2 OP( 1, 0, FP, 0 ) -#define FL2 OP( 1, LIT, FP, 0 ) -#define R4 OP( 3, 0, 0, 0 ) -#define RL4 OP( 3, LIT, 0, 0 ) -#define F4 OP( 3, 0, FP, 0 ) -#define FL4 OP( 3, LIT, FP, 0 ) - -#define M 0x7f /* Memory operand (MEMA & MEMB format instructions) */ - -/* Macros to extract info from the register operand descriptor byte 'od'. - */ -#define SFR_OK(od) (od & SFR) /* TRUE if sfr operand allowed */ -#define LIT_OK(od) (od & LIT) /* TRUE if literal operand allowed */ -#define FP_OK(od) (od & FP) /* TRUE if floating-point op allowed */ -#define REG_ALIGN(od,n) ((od & 0x3 & n) == 0) - /* TRUE if reg #n is properly aligned */ -#define MEMOP(od) (od == M) /* TRUE if operand is a memory operand*/ - -/* Description of a single i80960 instruction */ -struct i960_opcode { - long opcode; /* 32 bits, constant fields filled in, rest zeroed */ - const char *name; /* Assembler mnemonic */ - short iclass; /* Class: see #defines below */ - char format; /* REG, COBR, CTRL, MEMn, COJ, FBRA, or CALLJ */ - char num_ops; /* Number of operands */ - char operand[3];/* Operand descriptors; same order as assembler instr */ -}; - -/* Classes of 960 instructions: - * - each instruction falls into one class. - * - each target architecture supports one or more classes. - * - * EACH CONSTANT MUST CONTAIN 1 AND ONLY 1 SET BIT!: see targ_has_iclass(). - */ -#define I_BASE 0x01 /* 80960 base instruction set */ -#define I_CX 0x02 /* 80960Cx instruction */ -#define I_DEC 0x04 /* Decimal instruction */ -#define I_FP 0x08 /* Floating point instruction */ -#define I_KX 0x10 /* 80960Kx instruction */ -#define I_MIL 0x20 /* Military instruction */ -#define I_CASIM 0x40 /* CA simulator instruction */ -#define I_CX2 0x80 /* Cx/Jx/Hx instructions */ -#define I_JX 0x100 /* Jx/Hx instruction */ -#define I_HX 0x200 /* Hx instructions */ - -/****************************************************************************** - * - * TABLE OF i960 INSTRUCTION DESCRIPTIONS - * - ******************************************************************************/ - -const struct i960_opcode i960_opcodes[] = { - - /* if a CTRL instruction has an operand, it's always a displacement */ - - /* callj default=='call' */ - { 0x09000000, "callj", I_BASE, CALLJ, 1, { 0, 0, 0 } }, - { 0x08000000, "b", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x09000000, "call", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x0a000000, "ret", I_BASE, CTRL, 0, { 0, 0, 0 } }, - { 0x0b000000, "bal", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x10000000, "bno", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* bf same as bno */ - { 0x10000000, "bf", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* bru same as bno */ - { 0x10000000, "bru", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x11000000, "bg", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* brg same as bg */ - { 0x11000000, "brg", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x12000000, "be", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* bre same as be */ - { 0x12000000, "bre", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x13000000, "bge", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* brge same as bge */ - { 0x13000000, "brge", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x14000000, "bl", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* brl same as bl */ - { 0x14000000, "brl", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x15000000, "bne", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* brlg same as bne */ - { 0x15000000, "brlg", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x16000000, "ble", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* brle same as ble */ - { 0x16000000, "brle", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x17000000, "bo", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* bt same as bo */ - { 0x17000000, "bt", I_BASE, CTRL, 1, { 0, 0, 0 } }, - /* bro same as bo */ - { 0x17000000, "bro", I_BASE, CTRL, 1, { 0, 0, 0 } }, - { 0x18000000, "faultno", I_BASE, CTRL, 0, { 0, 0, 0 } }, - /* faultf same as faultno */ - { 0x18000000, "faultf", I_BASE, CTRL, 0, { 0, 0, 0 } }, - { 0x19000000, "faultg", I_BASE, CTRL, 0, { 0, 0, 0 } }, - { 0x1a000000, "faulte", I_BASE, CTRL, 0, { 0, 0, 0 } }, - { 0x1b000000, "faultge", I_BASE, CTRL, 0, { 0, 0, 0 } }, - { 0x1c000000, "faultl", I_BASE, CTRL, 0, { 0, 0, 0 } }, - { 0x1d000000, "faultne", I_BASE, CTRL, 0, { 0, 0, 0 } }, - { 0x1e000000, "faultle", I_BASE, CTRL, 0, { 0, 0, 0 } }, - { 0x1f000000, "faulto", I_BASE, CTRL, 0, { 0, 0, 0 } }, - /* faultt syn for faulto */ - { 0x1f000000, "faultt", I_BASE, CTRL, 0, { 0, 0, 0 } }, - - { 0x01000000, "syscall", I_CASIM,CTRL, 0, { 0, 0, 0 } }, - - /* If a COBR (or COJ) has 3 operands, the last one is always a - * displacement and does not appear explicitly in the table. - */ - - { 0x20000000, "testno", I_BASE, COBR, 1, { R, 0, 0 } }, - { 0x21000000, "testg", I_BASE, COBR, 1, { R, 0, 0 } }, - { 0x22000000, "teste", I_BASE, COBR, 1, { R, 0, 0 } }, - { 0x23000000, "testge", I_BASE, COBR, 1, { R, 0, 0 } }, - { 0x24000000, "testl", I_BASE, COBR, 1, { R, 0, 0 } }, - { 0x25000000, "testne", I_BASE, COBR, 1, { R, 0, 0 } }, - { 0x26000000, "testle", I_BASE, COBR, 1, { R, 0, 0 } }, - { 0x27000000, "testo", I_BASE, COBR, 1, { R, 0, 0 } }, - { 0x30000000, "bbc", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x31000000, "cmpobg", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x32000000, "cmpobe", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x33000000, "cmpobge", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x34000000, "cmpobl", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x35000000, "cmpobne", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x36000000, "cmpoble", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x37000000, "bbs", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x38000000, "cmpibno", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x39000000, "cmpibg", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x3a000000, "cmpibe", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x3b000000, "cmpibge", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x3c000000, "cmpibl", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x3d000000, "cmpibne", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x3e000000, "cmpible", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x3f000000, "cmpibo", I_BASE, COBR, 3, { RL, RS, 0 } }, - { 0x31000000, "cmpojg", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x32000000, "cmpoje", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x33000000, "cmpojge", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x34000000, "cmpojl", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x35000000, "cmpojne", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x36000000, "cmpojle", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x38000000, "cmpijno", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x39000000, "cmpijg", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x3a000000, "cmpije", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x3b000000, "cmpijge", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x3c000000, "cmpijl", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x3d000000, "cmpijne", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x3e000000, "cmpijle", I_BASE, COJ, 3, { RL, RS, 0 } }, - { 0x3f000000, "cmpijo", I_BASE, COJ, 3, { RL, RS, 0 } }, - - { 0x80000000, "ldob", I_BASE, MEM1, 2, { M, R, 0 } }, - { 0x82000000, "stob", I_BASE, MEM1, 2, { R, M, 0 } }, - { 0x84000000, "bx", I_BASE, MEM1, 1, { M, 0, 0 } }, - { 0x85000000, "balx", I_BASE, MEM1, 2, { M, R, 0 } }, - { 0x86000000, "callx", I_BASE, MEM1, 1, { M, 0, 0 } }, - { 0x88000000, "ldos", I_BASE, MEM2, 2, { M, R, 0 } }, - { 0x8a000000, "stos", I_BASE, MEM2, 2, { R, M, 0 } }, - { 0x8c000000, "lda", I_BASE, MEM1, 2, { M, R, 0 } }, - { 0x90000000, "ld", I_BASE, MEM4, 2, { M, R, 0 } }, - { 0x92000000, "st", I_BASE, MEM4, 2, { R, M, 0 } }, - { 0x98000000, "ldl", I_BASE, MEM8, 2, { M, R2, 0 } }, - { 0x9a000000, "stl", I_BASE, MEM8, 2, { R2, M, 0 } }, - { 0xa0000000, "ldt", I_BASE, MEM12, 2, { M, R4, 0 } }, - { 0xa2000000, "stt", I_BASE, MEM12, 2, { R4, M, 0 } }, - { 0xb0000000, "ldq", I_BASE, MEM16, 2, { M, R4, 0 } }, - { 0xb2000000, "stq", I_BASE, MEM16, 2, { R4, M, 0 } }, - { 0xc0000000, "ldib", I_BASE, MEM1, 2, { M, R, 0 } }, - { 0xc2000000, "stib", I_BASE, MEM1, 2, { R, M, 0 } }, - { 0xc8000000, "ldis", I_BASE, MEM2, 2, { M, R, 0 } }, - { 0xca000000, "stis", I_BASE, MEM2, 2, { R, M, 0 } }, - - { R_3(0x580), "notbit", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x581), "and", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x582), "andnot", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x583), "setbit", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x584), "notand", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x586), "xor", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x587), "or", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x588), "nor", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x589), "xnor", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_2D(0x58a), "not", I_BASE, REG, 2, { RSL,RS, 0 } }, - { R_3(0x58b), "ornot", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x58c), "clrbit", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x58d), "notor", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x58e), "nand", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x58f), "alterbit", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x590), "addo", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x591), "addi", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x592), "subo", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x593), "subi", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x598), "shro", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x59a), "shrdi", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x59b), "shri", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x59c), "shlo", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x59d), "rotate", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x59e), "shli", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_2(0x5a0), "cmpo", I_BASE, REG, 2, { RSL,RSL, 0 } }, - { R_2(0x5a1), "cmpi", I_BASE, REG, 2, { RSL,RSL, 0 } }, - { R_2(0x5a2), "concmpo", I_BASE, REG, 2, { RSL,RSL, 0 } }, - { R_2(0x5a3), "concmpi", I_BASE, REG, 2, { RSL,RSL, 0 } }, - { R_3(0x5a4), "cmpinco", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x5a5), "cmpinci", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x5a6), "cmpdeco", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x5a7), "cmpdeci", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_2(0x5ac), "scanbyte", I_BASE, REG, 2, { RSL,RSL, 0 } }, - { R_2(0x5ae), "chkbit", I_BASE, REG, 2, { RSL,RSL, 0 } }, - { R_3(0x5b0), "addc", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x5b2), "subc", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_2D(0x5cc), "mov", I_BASE, REG, 2, { RSL,RS, 0 } }, - { R_2D(0x5dc), "movl", I_BASE, REG, 2, { RL2,R2, 0 } }, - { R_2D(0x5ec), "movt", I_BASE, REG, 2, { RL4,R4, 0 } }, - { R_2D(0x5fc), "movq", I_BASE, REG, 2, { RL4,R4, 0 } }, - { R_3(0x610), "atmod", I_BASE, REG, 3, { RS, RSL,R } }, - { R_3(0x612), "atadd", I_BASE, REG, 3, { RS, RSL,RS } }, - { R_2D(0x640), "spanbit", I_BASE, REG, 2, { RSL,RS, 0 } }, - { R_2D(0x641), "scanbit", I_BASE, REG, 2, { RSL,RS, 0 } }, - { R_3(0x645), "modac", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x650), "modify", I_BASE, REG, 3, { RSL,RSL,R } }, - { R_3(0x651), "extract", I_BASE, REG, 3, { RSL,RSL,R } }, - { R_3(0x654), "modtc", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x655), "modpc", I_BASE, REG, 3, { RSL,RSL,R } }, - { R_1(0x660), "calls", I_BASE, REG, 1, { RSL, 0, 0 } }, - { R_0(0x66b), "mark", I_BASE, REG, 0, { 0, 0, 0 } }, - { R_0(0x66c), "fmark", I_BASE, REG, 0, { 0, 0, 0 } }, - { R_0(0x66d), "flushreg", I_BASE, REG, 0, { 0, 0, 0 } }, - { R_0(0x66f), "syncf", I_BASE, REG, 0, { 0, 0, 0 } }, - { R_3(0x670), "emul", I_BASE, REG, 3, { RSL,RSL,R2 } }, - { R_3(0x671), "ediv", I_BASE, REG, 3, { RSL,RL2,RS } }, - { R_2D(0x672), "cvtadr", I_CASIM,REG, 2, { RL, R2, 0 } }, - { R_3(0x701), "mulo", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x708), "remo", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x70b), "divo", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x741), "muli", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x748), "remi", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x749), "modi", I_BASE, REG, 3, { RSL,RSL,RS } }, - { R_3(0x74b), "divi", I_BASE, REG, 3, { RSL,RSL,RS } }, - - /* Floating-point instructions */ - - { R_2D(0x674), "cvtir", I_FP, REG, 2, { RL, F, 0 } }, - { R_2D(0x675), "cvtilr", I_FP, REG, 2, { RL, F, 0 } }, - { R_3(0x676), "scalerl", I_FP, REG, 3, { RL, FL2,F2 } }, - { R_3(0x677), "scaler", I_FP, REG, 3, { RL, FL, F } }, - { R_3(0x680), "atanr", I_FP, REG, 3, { FL, FL, F } }, - { R_3(0x681), "logepr", I_FP, REG, 3, { FL, FL, F } }, - { R_3(0x682), "logr", I_FP, REG, 3, { FL, FL, F } }, - { R_3(0x683), "remr", I_FP, REG, 3, { FL, FL, F } }, - { R_2(0x684), "cmpor", I_FP, REG, 2, { FL, FL, 0 } }, - { R_2(0x685), "cmpr", I_FP, REG, 2, { FL, FL, 0 } }, - { R_2D(0x688), "sqrtr", I_FP, REG, 2, { FL, F, 0 } }, - { R_2D(0x689), "expr", I_FP, REG, 2, { FL, F, 0 } }, - { R_2D(0x68a), "logbnr", I_FP, REG, 2, { FL, F, 0 } }, - { R_2D(0x68b), "roundr", I_FP, REG, 2, { FL, F, 0 } }, - { R_2D(0x68c), "sinr", I_FP, REG, 2, { FL, F, 0 } }, - { R_2D(0x68d), "cosr", I_FP, REG, 2, { FL, F, 0 } }, - { R_2D(0x68e), "tanr", I_FP, REG, 2, { FL, F, 0 } }, - { R_1(0x68f), "classr", I_FP, REG, 1, { FL, 0, 0 } }, - { R_3(0x690), "atanrl", I_FP, REG, 3, { FL2,FL2,F2 } }, - { R_3(0x691), "logeprl", I_FP, REG, 3, { FL2,FL2,F2 } }, - { R_3(0x692), "logrl", I_FP, REG, 3, { FL2,FL2,F2 } }, - { R_3(0x693), "remrl", I_FP, REG, 3, { FL2,FL2,F2 } }, - { R_2(0x694), "cmporl", I_FP, REG, 2, { FL2,FL2, 0 } }, - { R_2(0x695), "cmprl", I_FP, REG, 2, { FL2,FL2, 0 } }, - { R_2D(0x698), "sqrtrl", I_FP, REG, 2, { FL2,F2, 0 } }, - { R_2D(0x699), "exprl", I_FP, REG, 2, { FL2,F2, 0 } }, - { R_2D(0x69a), "logbnrl", I_FP, REG, 2, { FL2,F2, 0 } }, - { R_2D(0x69b), "roundrl", I_FP, REG, 2, { FL2,F2, 0 } }, - { R_2D(0x69c), "sinrl", I_FP, REG, 2, { FL2,F2, 0 } }, - { R_2D(0x69d), "cosrl", I_FP, REG, 2, { FL2,F2, 0 } }, - { R_2D(0x69e), "tanrl", I_FP, REG, 2, { FL2,F2, 0 } }, - { R_1(0x69f), "classrl", I_FP, REG, 1, { FL2, 0, 0 } }, - { R_2D(0x6c0), "cvtri", I_FP, REG, 2, { FL, R, 0 } }, - { R_2D(0x6c1), "cvtril", I_FP, REG, 2, { FL, R2, 0 } }, - { R_2D(0x6c2), "cvtzri", I_FP, REG, 2, { FL, R, 0 } }, - { R_2D(0x6c3), "cvtzril", I_FP, REG, 2, { FL, R2, 0 } }, - { R_2D(0x6c9), "movr", I_FP, REG, 2, { FL, F, 0 } }, - { R_2D(0x6d9), "movrl", I_FP, REG, 2, { FL2,F2, 0 } }, - { R_2D(0x6e1), "movre", I_FP, REG, 2, { FL4,F4, 0 } }, - { R_3(0x6e2), "cpysre", I_FP, REG, 3, { FL4,FL4,F4 } }, - { R_3(0x6e3), "cpyrsre", I_FP, REG, 3, { FL4,FL4,F4 } }, - { R_3(0x78b), "divr", I_FP, REG, 3, { FL, FL, F } }, - { R_3(0x78c), "mulr", I_FP, REG, 3, { FL, FL, F } }, - { R_3(0x78d), "subr", I_FP, REG, 3, { FL, FL, F } }, - { R_3(0x78f), "addr", I_FP, REG, 3, { FL, FL, F } }, - { R_3(0x79b), "divrl", I_FP, REG, 3, { FL2,FL2,F2 } }, - { R_3(0x79c), "mulrl", I_FP, REG, 3, { FL2,FL2,F2 } }, - { R_3(0x79d), "subrl", I_FP, REG, 3, { FL2,FL2,F2 } }, - { R_3(0x79f), "addrl", I_FP, REG, 3, { FL2,FL2,F2 } }, - - /* These are the floating point branch instructions. Each actually - * generates 2 branch instructions: the first a CTRL instruction with - * the indicated opcode, and the second a 'bno'. - */ - - { 0x12000000, "brue", I_FP, FBRA, 1, { 0, 0, 0 } }, - { 0x11000000, "brug", I_FP, FBRA, 1, { 0, 0, 0 } }, - { 0x13000000, "bruge", I_FP, FBRA, 1, { 0, 0, 0 } }, - { 0x14000000, "brul", I_FP, FBRA, 1, { 0, 0, 0 } }, - { 0x16000000, "brule", I_FP, FBRA, 1, { 0, 0, 0 } }, - { 0x15000000, "brulg", I_FP, FBRA, 1, { 0, 0, 0 } }, - - - /* Decimal instructions */ - - { R_3(0x642), "daddc", I_DEC, REG, 3, { RSL,RSL,RS } }, - { R_3(0x643), "dsubc", I_DEC, REG, 3, { RSL,RSL,RS } }, - { R_2D(0x644), "dmovt", I_DEC, REG, 2, { RSL,RS, 0 } }, - - - /* KX extensions */ - - { R_2(0x600), "synmov", I_KX, REG, 2, { R, R, 0 } }, - { R_2(0x601), "synmovl", I_KX, REG, 2, { R, R, 0 } }, - { R_2(0x602), "synmovq", I_KX, REG, 2, { R, R, 0 } }, - { R_2D(0x615), "synld", I_KX, REG, 2, { R, R, 0 } }, - - - /* MC extensions */ - - { R_3(0x603), "cmpstr", I_MIL, REG, 3, { R, R, RL } }, - { R_3(0x604), "movqstr", I_MIL, REG, 3, { R, R, RL } }, - { R_3(0x605), "movstr", I_MIL, REG, 3, { R, R, RL } }, - { R_2D(0x613), "inspacc", I_MIL, REG, 2, { R, R, 0 } }, - { R_2D(0x614), "ldphy", I_MIL, REG, 2, { R, R, 0 } }, - { R_3(0x617), "fill", I_MIL, REG, 3, { R, RL, RL } }, - { R_2D(0x646), "condrec", I_MIL, REG, 2, { R, R, 0 } }, - { R_2D(0x656), "receive", I_MIL, REG, 2, { R, R, 0 } }, - { R_3(0x662), "send", I_MIL, REG, 3, { R, RL, R } }, - { R_1(0x663), "sendserv", I_MIL, REG, 1, { R, 0, 0 } }, - { R_1(0x664), "resumprcs", I_MIL, REG, 1, { R, 0, 0 } }, - { R_1(0x665), "schedprcs", I_MIL, REG, 1, { R, 0, 0 } }, - { R_0(0x666), "saveprcs", I_MIL, REG, 0, { 0, 0, 0 } }, - { R_1(0x668), "condwait", I_MIL, REG, 1, { R, 0, 0 } }, - { R_1(0x669), "wait", I_MIL, REG, 1, { R, 0, 0 } }, - { R_1(0x66a), "signal", I_MIL, REG, 1, { R, 0, 0 } }, - { R_1D(0x673), "ldtime", I_MIL, REG, 1, { R2, 0, 0 } }, - - - /* CX extensions */ - - { R_3(0x5d8), "eshro", I_CX2, REG, 3, { RSL,RSL,RS } }, - { R_3(0x630), "sdma", I_CX, REG, 3, { RSL,RSL,RL } }, - { R_3(0x631), "udma", I_CX, REG, 0, { 0, 0, 0 } }, - { R_3(0x659), "sysctl", I_CX2, REG, 3, { RSL,RSL,RL } }, - - - /* Jx extensions. */ - { R_3(0x780), "addono", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x790), "addog", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7a0), "addoe", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7b0), "addoge", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7c0), "addol", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7d0), "addone", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7e0), "addole", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7f0), "addoo", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x781), "addino", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x791), "addig", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7a1), "addie", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7b1), "addige", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7c1), "addil", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7d1), "addine", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7e1), "addile", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7f1), "addio", I_JX, REG, 3, { RSL,RSL,RS } }, - - { R_2D(0x5ad), "bswap", I_JX, REG, 2, { RSL, RS, 0 } }, - - { R_2(0x594), "cmpob", I_JX, REG, 2, { RSL,RSL, 0 } }, - { R_2(0x595), "cmpib", I_JX, REG, 2, { RSL,RSL, 0 } }, - { R_2(0x596), "cmpos", I_JX, REG, 2, { RSL,RSL, 0 } }, - { R_2(0x597), "cmpis", I_JX, REG, 2, { RSL,RSL, 0 } }, - - { R_3(0x784), "selno", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x794), "selg", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7a4), "sele", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7b4), "selge", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7c4), "sell", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7d4), "selne", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7e4), "selle", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7f4), "selo", I_JX, REG, 3, { RSL,RSL,RS } }, - - { R_3(0x782), "subono", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x792), "subog", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7a2), "suboe", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7b2), "suboge", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7c2), "subol", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7d2), "subone", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7e2), "subole", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7f2), "suboo", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x783), "subino", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x793), "subig", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7a3), "subie", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7b3), "subige", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7c3), "subil", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7d3), "subine", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7e3), "subile", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_3(0x7f3), "subio", I_JX, REG, 3, { RSL,RSL,RS } }, - - { R_3(0x65c), "dcctl", I_JX, REG, 3, { RSL,RSL,RL } }, - { R_3(0x65b), "icctl", I_JX, REG, 3, { RSL,RSL,RS } }, - { R_2D(0x658), "intctl", I_JX, REG, 2, { RSL, RS, 0 } }, - { R_0(0x5b4), "intdis", I_JX, REG, 0, { 0, 0, 0 } }, - { R_0(0x5b5), "inten", I_JX, REG, 0, { 0, 0, 0 } }, - { R_0(0x65d), "halt", I_JX, REG, 1, { RSL, 0, 0 } }, - - /* Hx extensions. */ - { 0xac000000, "dcinva", I_HX, MEM1, 1, { M, 0, 0 } }, - - /* END OF TABLE */ - - { 0, NULL, 0, 0, 0, { 0, 0, 0 } } -}; - - /* end of i960-opcode.h */ diff --git a/ld/ChangeLog b/ld/ChangeLog index 08c4d0d..f8260c0 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,5 +1,76 @@ 2018-04-11 Alan Modra <amodra@gmail.com> + * emulparams/coff_i860.sh: Delete. + * emulparams/elf32_i860.sh: Delete. + * emulparams/elf32_i960.sh: Delete. + * emulparams/gld960.sh: Delete. + * emulparams/gld960coff.sh: Delete. + * emulparams/lnk960.sh: Delete. + * emultempl/gld960.em: Delete. + * emultempl/gld960c.em: Delete. + * emultempl/lnk960.em: Delete. + * scripttempl/i860coff.sc: Delete. + * scripttempl/i960.sc: Delete. + * ld.texinfo: Remove i960 support. + * Makefile.am: Remove i860 and i960 support. + * configure.tgt: Likewise. + * testsuite/ld-discard/extern.d: Likewise. + * testsuite/ld-discard/start.d: Likewise. + * testsuite/ld-discard/static.d: Likewise. + * testsuite/ld-elf/compressed1d.d: Likewise. + * testsuite/ld-elf/group1.d: Likewise. + * testsuite/ld-elf/group3b.d: Likewise. + * testsuite/ld-elf/group8a.d: Likewise. + * testsuite/ld-elf/group8b.d: Likewise. + * testsuite/ld-elf/group9a.d: Likewise. + * testsuite/ld-elf/group9b.d: Likewise. + * testsuite/ld-elf/linkonce2.d: Likewise. + * testsuite/ld-elf/merge.d: Likewise. + * testsuite/ld-elf/merge2.d: Likewise. + * testsuite/ld-elf/merge3.d: Likewise. + * testsuite/ld-elf/orphan-10.d: Likewise. + * testsuite/ld-elf/orphan-11.d: Likewise. + * testsuite/ld-elf/orphan-12.d: Likewise. + * testsuite/ld-elf/orphan-9.d: Likewise. + * testsuite/ld-elf/orphan-region.d: Likewise. + * testsuite/ld-elf/orphan.d: Likewise. + * testsuite/ld-elf/orphan3.d: Likewise. + * testsuite/ld-elf/pr12851.d: Likewise. + * testsuite/ld-elf/pr12975.d: Likewise. + * testsuite/ld-elf/pr13177.d: Likewise. + * testsuite/ld-elf/pr13195.d: Likewise. + * testsuite/ld-elf/pr17550a.d: Likewise. + * testsuite/ld-elf/pr17550b.d: Likewise. + * testsuite/ld-elf/pr17550c.d: Likewise. + * testsuite/ld-elf/pr17550d.d: Likewise. + * testsuite/ld-elf/pr17615.d: Likewise. + * testsuite/ld-elf/pr20528a.d: Likewise. + * testsuite/ld-elf/pr20528b.d: Likewise. + * testsuite/ld-elf/pr21562a.d: Likewise. + * testsuite/ld-elf/pr21562b.d: Likewise. + * testsuite/ld-elf/pr21562c.d: Likewise. + * testsuite/ld-elf/pr21562d.d: Likewise. + * testsuite/ld-elf/pr21562i.d: Likewise. + * testsuite/ld-elf/pr21562j.d: Likewise. + * testsuite/ld-elf/pr21562k.d: Likewise. + * testsuite/ld-elf/pr21562l.d: Likewise. + * testsuite/ld-elf/pr21562m.d: Likewise. + * testsuite/ld-elf/pr21562n.d: Likewise. + * testsuite/ld-elf/pr22677.d: Likewise. + * testsuite/ld-elf/pr22836-1a.d: Likewise. + * testsuite/ld-elf/pr22836-1b.d: Likewise. + * testsuite/ld-elf/pr349.d: Likewise. + * testsuite/ld-elf/sec-to-seg.exp: Likewise. + * testsuite/ld-elf/sec64k.exp: Likewise. + * testsuite/ld-elf/warn1.d: Likewise. + * testsuite/ld-elf/warn2.d: Likewise. + * testsuite/ld-elf/warn3.d: Likewise. + * testsuite/lib/ld-lib.exp: Likewise. + * Makefile.in: Regenerate. + * po/BLD-POTFILES.in: Regenerate. + +2018-04-11 Alan Modra <amodra@gmail.com> + * testsuite/ld-elf/shared.exp (AFLAGS_PIC): Add -mpic for nds32. 2018-04-09 Alan Modra <amodra@gmail.com> diff --git a/ld/Makefile.am b/ld/Makefile.am index d94fce7..aa1c69d 100644 --- a/ld/Makefile.am +++ b/ld/Makefile.am @@ -209,7 +209,6 @@ ALL_EMULATION_SOURCES = \ eavrxmega6.c \ eavrxmega7.c \ eavrtiny.c \ - ecoff_i860.c \ ecoff_sparc.c \ ecrisaout.c \ ecriself.c \ @@ -220,8 +219,6 @@ ALL_EMULATION_SOURCES = \ ed30velf.c \ edelta68.c \ eelf32_dlx.c \ - eelf32_i860.c \ - eelf32_i960.c \ eelf32_sparc.c \ eelf32_sparc_sol2.c \ eelf32_sparc_vxworks.c \ @@ -297,8 +294,6 @@ ALL_EMULATION_SOURCES = \ eelf_i386_vxworks.c \ eelf_iamcu.c \ eelf_s390.c \ - egld960.c \ - egld960coff.c \ eh8300.c \ eh8300elf.c \ eh8300elf_linux.c \ @@ -343,7 +338,6 @@ ALL_EMULATION_SOURCES = \ ei386nw.c \ ei386pe.c \ ei386pe_posix.c \ - elnk960.c \ em32relf.c \ em32relf_linux.c \ em32rlelf.c \ @@ -927,9 +921,6 @@ eavrtiny.c: $(srcdir)/emulparams/avrtiny.sh \ $(srcdir)/emultempl/avrelf.em $(ELF_DEPS) $(srcdir)/scripttempl/avr.sc \ ${GEN_DEPENDS} -ecoff_i860.c: $(srcdir)/emulparams/coff_i860.sh \ - $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/i860coff.sc ${GEN_DEPENDS} - ecoff_sparc.c: $(srcdir)/emulparams/coff_sparc.sh \ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sparccoff.sc ${GEN_DEPENDS} @@ -960,12 +951,6 @@ edelta68.c: $(srcdir)/emulparams/delta68.sh \ eelf32_dlx.c: $(srcdir)/emulparams/elf32_dlx.sh \ $(ELF_GEN_DEPS) $(srcdir)/scripttempl/dlx.sc ${GEN_DEPENDS} -eelf32_i860.c: $(srcdir)/emulparams/elf32_i860.sh \ - $(ELF_GEN_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} - -eelf32_i960.c: $(srcdir)/emulparams/elf32_i960.sh \ - $(ELF_GEN_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} - eelf32_sparc.c: $(srcdir)/emulparams/elf32_sparc.sh \ $(ELF_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} @@ -1378,12 +1363,6 @@ eelf_iamcu.c: $(srcdir)/emulparams/elf_iamcu.sh \ eelf_s390.c: $(srcdir)/emulparams/elf_s390.sh \ $(ELF_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} -egld960.c: $(srcdir)/emulparams/gld960.sh \ - $(srcdir)/emultempl/gld960.em $(srcdir)/scripttempl/i960.sc ${GEN_DEPENDS} - -egld960coff.c: $(srcdir)/emulparams/gld960coff.sh \ - $(srcdir)/emultempl/gld960c.em $(srcdir)/scripttempl/i960.sc ${GEN_DEPENDS} - eh8300.c: $(srcdir)/emulparams/h8300.sh \ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/h8300.sc ${GEN_DEPENDS} @@ -1533,9 +1512,6 @@ ei386pe_posix.c: $(srcdir)/emulparams/i386pe_posix.sh \ ei386pep.c: $(srcdir)/emulparams/i386pep.sh \ $(srcdir)/emultempl/pep.em $(srcdir)/scripttempl/pep.sc ${GEN_DEPENDS} -elnk960.c: $(srcdir)/emulparams/lnk960.sh \ - $(srcdir)/emultempl/lnk960.em $(srcdir)/scripttempl/i960.sc ${GEN_DEPENDS} - em32relf.c: $(srcdir)/emulparams/m32relf.sh \ $(ELF_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} diff --git a/ld/Makefile.in b/ld/Makefile.in index 704694b..2cd0535 100644 --- a/ld/Makefile.in +++ b/ld/Makefile.in @@ -578,7 +578,6 @@ ALL_EMULATION_SOURCES = \ eavrxmega6.c \ eavrxmega7.c \ eavrtiny.c \ - ecoff_i860.c \ ecoff_sparc.c \ ecrisaout.c \ ecriself.c \ @@ -589,8 +588,6 @@ ALL_EMULATION_SOURCES = \ ed30velf.c \ edelta68.c \ eelf32_dlx.c \ - eelf32_i860.c \ - eelf32_i960.c \ eelf32_sparc.c \ eelf32_sparc_sol2.c \ eelf32_sparc_vxworks.c \ @@ -666,8 +663,6 @@ ALL_EMULATION_SOURCES = \ eelf_i386_vxworks.c \ eelf_iamcu.c \ eelf_s390.c \ - egld960.c \ - egld960coff.c \ eh8300.c \ eh8300elf.c \ eh8300elf_linux.c \ @@ -712,7 +707,6 @@ ALL_EMULATION_SOURCES = \ ei386nw.c \ ei386pe.c \ ei386pe_posix.c \ - elnk960.c \ em32relf.c \ em32relf_linux.c \ em32rlelf.c \ @@ -1188,7 +1182,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eavrxmega5.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eavrxmega6.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eavrxmega7.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ecoff_i860.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ecoff_sparc.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ecrisaout.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ecriself.Po@am__quote@ @@ -1199,8 +1192,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ed30velf.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/edelta68.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32_dlx.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32_i860.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32_i960.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32_sparc.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32_sparc_sol2.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf32_sparc_vxworks.Po@am__quote@ @@ -1333,8 +1324,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf_x86_64_fbsd.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf_x86_64_nacl.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eelf_x86_64_sol2.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/egld960.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/egld960coff.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eh8300.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eh8300elf.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/eh8300elf_linux.Po@am__quote@ @@ -1381,7 +1370,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ei386pe.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ei386pe_posix.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ei386pep.Po@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/elnk960.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/em32relf.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/em32relf_linux.Po@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/em32rlelf.Po@am__quote@ @@ -2491,9 +2479,6 @@ eavrtiny.c: $(srcdir)/emulparams/avrtiny.sh \ $(srcdir)/emultempl/avrelf.em $(ELF_DEPS) $(srcdir)/scripttempl/avr.sc \ ${GEN_DEPENDS} -ecoff_i860.c: $(srcdir)/emulparams/coff_i860.sh \ - $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/i860coff.sc ${GEN_DEPENDS} - ecoff_sparc.c: $(srcdir)/emulparams/coff_sparc.sh \ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sparccoff.sc ${GEN_DEPENDS} @@ -2524,12 +2509,6 @@ edelta68.c: $(srcdir)/emulparams/delta68.sh \ eelf32_dlx.c: $(srcdir)/emulparams/elf32_dlx.sh \ $(ELF_GEN_DEPS) $(srcdir)/scripttempl/dlx.sc ${GEN_DEPENDS} -eelf32_i860.c: $(srcdir)/emulparams/elf32_i860.sh \ - $(ELF_GEN_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} - -eelf32_i960.c: $(srcdir)/emulparams/elf32_i960.sh \ - $(ELF_GEN_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} - eelf32_sparc.c: $(srcdir)/emulparams/elf32_sparc.sh \ $(ELF_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} @@ -2942,12 +2921,6 @@ eelf_iamcu.c: $(srcdir)/emulparams/elf_iamcu.sh \ eelf_s390.c: $(srcdir)/emulparams/elf_s390.sh \ $(ELF_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} -egld960.c: $(srcdir)/emulparams/gld960.sh \ - $(srcdir)/emultempl/gld960.em $(srcdir)/scripttempl/i960.sc ${GEN_DEPENDS} - -egld960coff.c: $(srcdir)/emulparams/gld960coff.sh \ - $(srcdir)/emultempl/gld960c.em $(srcdir)/scripttempl/i960.sc ${GEN_DEPENDS} - eh8300.c: $(srcdir)/emulparams/h8300.sh \ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/h8300.sc ${GEN_DEPENDS} @@ -3097,9 +3070,6 @@ ei386pe_posix.c: $(srcdir)/emulparams/i386pe_posix.sh \ ei386pep.c: $(srcdir)/emulparams/i386pep.sh \ $(srcdir)/emultempl/pep.em $(srcdir)/scripttempl/pep.sc ${GEN_DEPENDS} -elnk960.c: $(srcdir)/emulparams/lnk960.sh \ - $(srcdir)/emultempl/lnk960.em $(srcdir)/scripttempl/i960.sc ${GEN_DEPENDS} - em32relf.c: $(srcdir)/emulparams/m32relf.sh \ $(ELF_DEPS) $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} diff --git a/ld/configure.tgt b/ld/configure.tgt index 7897448..f06ae05 100644 --- a/ld/configure.tgt +++ b/ld/configure.tgt @@ -404,17 +404,6 @@ x86_64-*-nacl*) targ_emul=elf32_x86_64_nacl targ_extra_libpath=$targ_extra_emuls tdir_elf_i386_nacl=`echo ${targ_alias} | sed -e 's/x86_64/i386/'` ;; -i860-*-coff) targ_emul=coff_i860 ;; -i860-stardent-sysv4* | i860-stardent-elf*) - targ_emul=elf32_i860 - ;; -i960-wrs-vxworks5.0*) targ_emul=gld960 ;; -i960-wrs-vxworks5*) targ_emul=gld960coff ;; -i960-wrs-vxworks*) targ_emul=gld960 ;; -i960-*-coff) targ_emul=gld960coff ;; -i960-intel-nindy) targ_emul=gld960 ;; -i960-*-elf*) targ_emul=elf32_i960 - ;; ia16-*-elf*) targ_emul=elf_i386 targ_extra_emuls=i386msdos ;; ia64-*-elf*) targ_emul=elf64_ia64 ;; ia64-*-freebsd* | ia64-*-kfreebsd*-gnu) diff --git a/ld/emulparams/coff_i860.sh b/ld/emulparams/coff_i860.sh deleted file mode 100644 index 03b6493..0000000 --- a/ld/emulparams/coff_i860.sh +++ /dev/null @@ -1,5 +0,0 @@ -SCRIPT_NAME=i860coff -OUTPUT_FORMAT="coff-i860" -PAGE_SIZE=0x1000 -MAXPAGESIZE=0x1000 -ARCH=i860 diff --git a/ld/emulparams/elf32_i860.sh b/ld/emulparams/elf32_i860.sh deleted file mode 100644 index 482e3d1..0000000 --- a/ld/emulparams/elf32_i860.sh +++ /dev/null @@ -1,12 +0,0 @@ -# A work in progress... -SCRIPT_NAME=elf -TEMPLATE_NAME=generic -EXTRA_EM_FILE=genelf -OUTPUT_FORMAT="elf32-i860-little" -BIG_OUTPUT_FORMAT="elf32-i860" -LITTLE_OUTPUT_FORMAT="elf32-i860-little" -NO_REL_RELOCS=yes -TEXT_START_ADDR=0 -PAGE_SIZE=0x1000 -MAXPAGESIZE="CONSTANT (MAXPAGESIZE)" -ARCH=i860 diff --git a/ld/emulparams/elf32_i960.sh b/ld/emulparams/elf32_i960.sh deleted file mode 100644 index dd05a8f..0000000 --- a/ld/emulparams/elf32_i960.sh +++ /dev/null @@ -1,10 +0,0 @@ -SCRIPT_NAME=elf -TEMPLATE_NAME=generic -EXTRA_EM_FILE=genelf -OUTPUT_FORMAT="elf32-i960" -NO_RELA_RELOCS=yes -ARCH=i960 -MACHINE= -TEXT_START_ADDR=0 -EMBEDDED=yes -MAXPAGESIZE="CONSTANT (MAXPAGESIZE)" diff --git a/ld/emulparams/gld960.sh b/ld/emulparams/gld960.sh deleted file mode 100644 index 1e03965..0000000 --- a/ld/emulparams/gld960.sh +++ /dev/null @@ -1,7 +0,0 @@ -SCRIPT_NAME=i960 -OUTPUT_FORMAT="" -TEXT_START_ADDR=0 -TARGET_PAGE_SIZE=128 -ARCH=i960 -TEMPLATE_NAME=gld960 -GLD_STYLE=1 diff --git a/ld/emulparams/gld960coff.sh b/ld/emulparams/gld960coff.sh deleted file mode 100644 index 65b0dca..0000000 --- a/ld/emulparams/gld960coff.sh +++ /dev/null @@ -1,19 +0,0 @@ -SCRIPT_NAME=i960 -OUTPUT_FORMAT="" -TEXT_START_ADDR=0 -TARGET_PAGE_SIZE=128 -ARCH=i960 -TEMPLATE_NAME=gld960c -GLD_STYLE=1 -COFF_CTORS=' - ___CTOR_LIST__ = .; - LONG((___CTOR_END__ - ___CTOR_LIST__) / 4 - 2) - *(.ctors) - LONG(0) - ___CTOR_END__ = .; - ___DTOR_LIST__ = .; - LONG((___DTOR_END__ - ___DTOR_LIST__) / 4 - 2) - *(.dtors) - LONG(0) - ___DTOR_END__ = .; -' diff --git a/ld/emulparams/lnk960.sh b/ld/emulparams/lnk960.sh deleted file mode 100644 index 4a650f7..0000000 --- a/ld/emulparams/lnk960.sh +++ /dev/null @@ -1,6 +0,0 @@ -SCRIPT_NAME=i960 -OUTPUT_FORMAT="" -TEXT_START_ADDR=0 -TARGET_PAGE_SIZE=128 -ARCH=i960 -TEMPLATE_NAME=lnk960 diff --git a/ld/emultempl/gld960.em b/ld/emultempl/gld960.em deleted file mode 100644 index f0f7b04..0000000 --- a/ld/emultempl/gld960.em +++ /dev/null @@ -1,155 +0,0 @@ -# This shell script emits a C file. -*- C -*- -# It does some substitutions. -fragment <<EOF -/* Copyright (C) 1991-2018 Free Software Foundation, Inc. - - This file is part of the GNU Binutils. - - 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. */ - - -/* Emulate the Intel's port of gld. */ - -#include "sysdep.h" -#include "bfd.h" -#include "libiberty.h" -#include "bfdlink.h" - -#include "ld.h" -#include "ldmisc.h" -#include "ldmain.h" - -#include "ldexp.h" -#include "ldlang.h" -#include "ldfile.h" -#include "ldemul.h" - -static void gld960_before_parse (void) -{ - char *env ; - env = getenv("G960LIB"); - if (env) { - ldfile_add_library_path(env, FALSE); - } - env = getenv("G960BASE"); - if (env) - ldfile_add_library_path (concat (env, "/lib", (const char *) NULL), FALSE); - ldfile_output_architecture = bfd_arch_i960; -} - -static void -gld960_set_output_arch (void) -{ - bfd_set_arch_mach (link_info.output_bfd, - ldfile_output_architecture, bfd_mach_i960_core); -} - -static char * -gld960_choose_target (int argc ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED) -{ - char *from_outside = getenv(TARGET_ENVIRON); - output_filename = "b.out"; - - if (from_outside != (char *)NULL) - return from_outside; - - return "b.out.little"; -} - -static char * -gld960_get_script (int *isfile) -EOF - -if test x"$COMPILE_IN" = xyes -then -# Scripts compiled in. - -# sed commands to quote an ld script as a C string. -sc="-f stringify.sed" - -fragment <<EOF -{ - *isfile = 0; - - if (bfd_link_relocatable (&link_info) && config.build_constructors) - return -EOF -sed $sc ldscripts/${EMULATION_NAME}.xu >> e${EMULATION_NAME}.c -echo ' ; else if (bfd_link_relocatable (&link_info)) return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.xr >> e${EMULATION_NAME}.c -echo ' ; else if (!config.text_read_only) return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.xbn >> e${EMULATION_NAME}.c -echo ' ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.xn >> e${EMULATION_NAME}.c -echo ' ; else return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.x >> e${EMULATION_NAME}.c -echo '; }' >> e${EMULATION_NAME}.c - -else -# Scripts read from the filesystem. - -fragment <<EOF -{ - *isfile = 1; - - if (bfd_link_relocatable (&link_info) && config.build_constructors) - return "ldscripts/${EMULATION_NAME}.xu"; - else if (bfd_link_relocatable (&link_info)) - return "ldscripts/${EMULATION_NAME}.xr"; - else if (!config.text_read_only) - return "ldscripts/${EMULATION_NAME}.xbn"; - else if (!config.magic_demand_paged) - return "ldscripts/${EMULATION_NAME}.xn"; - else - return "ldscripts/${EMULATION_NAME}.x"; -} -EOF - -fi - -fragment <<EOF - -struct ld_emulation_xfer_struct ld_gld960_emulation = -{ - gld960_before_parse, - syslib_default, - hll_default, - after_parse_default, - after_open_default, - after_check_relocs_default, - after_allocation_default, - gld960_set_output_arch, - gld960_choose_target, - before_allocation_default, - gld960_get_script, - "960", - "", - finish_default, - NULL, /* create output section statements */ - NULL, /* open dynamic archive */ - NULL, /* place orphan */ - NULL, /* set symbols */ - NULL, /* parse args */ - NULL, /* add_options */ - NULL, /* handle_option */ - NULL, /* unrecognized file */ - NULL, /* list options */ - NULL, /* recognized file */ - NULL, /* find_potential_libraries */ - NULL, /* new_vers_pattern */ - NULL /* extra_map_file_text */ -}; -EOF diff --git a/ld/emultempl/gld960c.em b/ld/emultempl/gld960c.em deleted file mode 100644 index 5507e10..0000000 --- a/ld/emultempl/gld960c.em +++ /dev/null @@ -1,168 +0,0 @@ -# This shell script emits a C file. -*- C -*- -# It does some substitutions. -fragment <<EOF -/* Copyright (C) 1991-2018 Free Software Foundation, Inc. - - This file is part of the GNU Binutils. - - 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. */ - - -/* Emulate the Intel's port of gld. */ - -#include "sysdep.h" -#include "bfd.h" -#include "libiberty.h" -#include "safe-ctype.h" -#include "bfdlink.h" - -#include "ld.h" -#include "ldmisc.h" -#include "ldmain.h" - -#include "ldexp.h" -#include "ldlang.h" -#include "ldfile.h" -#include "ldemul.h" - -static void gld960_before_parse (void) -{ - char *env ; - env = getenv("G960LIB"); - if (env) { - ldfile_add_library_path(env, FALSE); - } - env = getenv("G960BASE"); - if (env) - ldfile_add_library_path (concat (env, "/lib", (const char *) NULL), - FALSE); - ldfile_output_architecture = bfd_arch_i960; -} - -static void -gld960_set_output_arch (void) -{ - if (ldfile_output_machine_name != NULL - && *ldfile_output_machine_name != '\0') - { - char *s, *s1; - - s = concat ("i960:", ldfile_output_machine_name, (char *) NULL); - for (s1 = s; *s1 != '\0'; s1++) - *s1 = TOLOWER (*s1); - ldfile_set_output_arch (s, bfd_arch_unknown); - free (s); - } - - set_output_arch_default (); -} - -static char * -gld960_choose_target (int argc ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED) -{ - char *from_outside = getenv(TARGET_ENVIRON); - output_filename = "b.out"; - - if (from_outside != (char *)NULL) - return from_outside; - - return "coff-Intel-little"; -} - -static char * -gld960_get_script (int *isfile) -EOF - -if test x"$COMPILE_IN" = xyes -then -# Scripts compiled in. - -# sed commands to quote an ld script as a C string. -sc="-f stringify.sed" - -fragment <<EOF -{ - *isfile = 0; - - if (bfd_link_relocatable (&link_info) && config.build_constructors) - return -EOF -sed $sc ldscripts/${EMULATION_NAME}.xu >> e${EMULATION_NAME}.c -echo ' ; else if (bfd_link_relocatable (&link_info)) return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.xr >> e${EMULATION_NAME}.c -echo ' ; else if (!config.text_read_only) return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.xbn >> e${EMULATION_NAME}.c -echo ' ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.xn >> e${EMULATION_NAME}.c -echo ' ; else return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.x >> e${EMULATION_NAME}.c -echo '; }' >> e${EMULATION_NAME}.c - -else -# Scripts read from the filesystem. - -fragment <<EOF -{ - *isfile = 1; - - if (bfd_link_relocatable (&link_info) && config.build_constructors) - return "ldscripts/${EMULATION_NAME}.xu"; - else if (bfd_link_relocatable (&link_info)) - return "ldscripts/${EMULATION_NAME}.xr"; - else if (!config.text_read_only) - return "ldscripts/${EMULATION_NAME}.xbn"; - else if (!config.magic_demand_paged) - return "ldscripts/${EMULATION_NAME}.xn"; - else - return "ldscripts/${EMULATION_NAME}.x"; -} -EOF - -fi - -fragment <<EOF - -struct ld_emulation_xfer_struct ld_gld960coff_emulation = -{ - gld960_before_parse, - syslib_default, - hll_default, - after_parse_default, - after_open_default, - after_check_relocs_default, - after_allocation_default, - gld960_set_output_arch, - gld960_choose_target, - before_allocation_default, - gld960_get_script, - "960coff", - "", - finish_default, - NULL, /* create output section statements */ - NULL, /* open dynamic archive */ - NULL, /* place orphan */ - NULL, /* set symbols */ - NULL, /* parse args */ - NULL, /* add_options */ - NULL, /* handle_option */ - NULL, /* unrecognized file */ - NULL, /* list options */ - NULL, /* recognized file */ - NULL, /* find_potential_libraries */ - NULL, /* new_vers_pattern */ - NULL /* extra_map_file_text */ -}; -EOF diff --git a/ld/emultempl/lnk960.em b/ld/emultempl/lnk960.em deleted file mode 100644 index b9ba51d..0000000 --- a/ld/emultempl/lnk960.em +++ /dev/null @@ -1,349 +0,0 @@ -# This shell script emits a C file. -*- C -*- -# It does some substitutions. -fragment <<EOF -/* intel coff loader emulation specific stuff - Copyright (C) 1991-2018 Free Software Foundation, Inc. - Written by Steve Chamberlain steve@cygnus.com - - This file is part of the GNU Binutils. - - 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 "libiberty.h" -#include "bfd.h" -#include "bfdlink.h" - -/*#include "archures.h"*/ -#include "ld.h" -#include "ldmain.h" -#include "ldmisc.h" -#include "ldexp.h" -#include "ldlang.h" -#include "ldfile.h" -#include "ldemul.h" - -typedef struct lib_list { - char *name; - struct lib_list *next; -} lib_list_type; - -static lib_list_type *hll_list; -static lib_list_type **hll_list_tail = &hll_list; - -static lib_list_type *syslib_list; -static lib_list_type **syslib_list_tail = &syslib_list; - - -static void -append (lib_list_type ***list, char *name) -{ - lib_list_type *element = (lib_list_type *) xmalloc (sizeof (lib_list_type)); - - element->name = name; - element->next = (lib_list_type *) NULL; - **list = element; - *list = &element->next; - -} - -static bfd_boolean had_hll = FALSE; -static bfd_boolean had_hll_name = FALSE; - -static void -lnk960_hll (char *name) -{ - had_hll = TRUE; - if (name != (char *) NULL) - { - had_hll_name = TRUE; - append (&hll_list_tail, name); - } -} - -static void -lnk960_syslib (char *name) -{ - append (&syslib_list_tail, name); -} - - -static void -lnk960_before_parse (void) -{ - char *name = getenv ("I960BASE"); - - if (name == (char *) NULL) - { - name = getenv("G960BASE"); - if (name == (char *) NULL) - einfo (_("%F%P: I960BASE and G960BASE not set\n")); - } - - ldfile_add_library_path (concat (name, "/lib", (const char *) NULL), FALSE); - ldfile_output_architecture = bfd_arch_i960; - ldfile_output_machine = bfd_mach_i960_core; -} - -static void -add_on (lib_list_type *list, lang_input_file_enum_type search) -{ - while (list) - { - lang_add_input_file (list->name, search, (char *) NULL); - list = list->next; - } -} - -static void -lnk960_after_parse (void) -{ - /* If there has been no arch, default to -KB */ - if (ldfile_output_machine_name[0] == 0) - ldfile_add_arch ("KB"); - - /* if there has been no hll list then add our own */ - - if (had_hll && !had_hll_name) - { - append (&hll_list_tail, "cg"); - if (ldfile_output_machine == bfd_mach_i960_ka_sa - || ldfile_output_machine == bfd_mach_i960_ca) - append (&hll_list_tail, "fpg"); - } - - add_on (hll_list, lang_input_file_is_l_enum); - add_on (syslib_list, lang_input_file_is_search_file_enum); -} - -/* Create a symbol with the given name with the value of the - address of first byte of the section named. - - If the symbol already exists, then do nothing. */ - -static void -symbol_at_beginning_of (const char *secname, const char *name) -{ - struct bfd_link_hash_entry *h; - - h = bfd_link_hash_lookup (link_info.hash, name, TRUE, TRUE, TRUE); - if (h == NULL) - einfo (_("%F%P: bfd_link_hash_lookup failed: %E\n")); - - if (h->type == bfd_link_hash_new - || h->type == bfd_link_hash_undefined) - { - asection *sec; - - h->type = bfd_link_hash_defined; - - sec = bfd_get_section_by_name (link_info.output_bfd, secname); - if (sec == NULL) - sec = bfd_abs_section_ptr; - h->u.def.value = 0; - h->u.def.section = sec; - } -} - -/* Create a symbol with the given name with the value of the - address of the first byte after the end of the section named. - - If the symbol already exists, then do nothing. */ - -static void -symbol_at_end_of (const char *secname, const char *name) -{ - struct bfd_link_hash_entry *h; - - h = bfd_link_hash_lookup (link_info.hash, name, TRUE, TRUE, TRUE); - if (h == NULL) - einfo (_("%F%P: bfd_link_hash_lookup failed: %E\n")); - - if (h->type == bfd_link_hash_new - || h->type == bfd_link_hash_undefined) - { - asection *sec; - - h->type = bfd_link_hash_defined; - - sec = bfd_get_section_by_name (link_info.output_bfd, secname); - if (sec == NULL) - sec = bfd_abs_section_ptr; - h->u.def.value = sec->size; - h->u.def.section = sec; - } -} - -static void -lnk960_after_allocation (void) -{ - if (!bfd_link_relocatable (&link_info)) - { - symbol_at_end_of (".text", "_etext"); - symbol_at_end_of (".data", "_edata"); - symbol_at_beginning_of (".bss", "_bss_start"); - symbol_at_end_of (".bss", "_end"); - } -} - - -static struct - { - unsigned long number; - char *name; - } -machine_table[] = -{ - { bfd_mach_i960_core ,"CORE" }, - { bfd_mach_i960_kb_sb ,"KB" }, - { bfd_mach_i960_kb_sb ,"SB" }, - { bfd_mach_i960_mc ,"MC" }, - { bfd_mach_i960_xa ,"XA" }, - { bfd_mach_i960_ca ,"CA" }, - { bfd_mach_i960_ka_sa ,"KA" }, - { bfd_mach_i960_ka_sa ,"SA" }, - { bfd_mach_i960_jx ,"JX" }, - { bfd_mach_i960_hx ,"HX" }, - - { bfd_mach_i960_core ,"core" }, - { bfd_mach_i960_kb_sb ,"kb" }, - { bfd_mach_i960_kb_sb ,"sb" }, - { bfd_mach_i960_mc ,"mc" }, - { bfd_mach_i960_xa ,"xa" }, - { bfd_mach_i960_ca ,"ca" }, - { bfd_mach_i960_ka_sa ,"ka" }, - { bfd_mach_i960_ka_sa ,"sa" }, - { bfd_mach_i960_jx ,"jx" }, - { bfd_mach_i960_hx ,"hx" }, - - { 0, (char *) NULL } -}; - -static void -lnk960_set_output_arch (void) -{ - /* Set the output architecture and machine if possible */ - unsigned int i; - ldfile_output_machine = bfd_mach_i960_core; - for (i= 0; machine_table[i].name != (char*) NULL; i++) - { - if (strcmp (ldfile_output_machine_name, machine_table[i].name) == 0) - { - ldfile_output_machine = machine_table[i].number; - break; - } - } - bfd_set_arch_mach (link_info.output_bfd, ldfile_output_architecture, - ldfile_output_machine); -} - -static char * -lnk960_choose_target (int argc ATTRIBUTE_UNUSED, char **argv ATTRIBUTE_UNUSED) -{ - char *from_outside = getenv (TARGET_ENVIRON); - if (from_outside != (char *) NULL) - return from_outside; -#ifdef LNK960_LITTLE - return "coff-Intel-little"; -#else - return "coff-Intel-big"; -#endif -} - -static char * -lnk960_get_script (int *isfile) -EOF - -if test x"$COMPILE_IN" = xyes -then -# Scripts compiled in. - -# sed commands to quote an ld script as a C string. -sc="-f stringify.sed" - -fragment <<EOF -{ - *isfile = 0; - - if (bfd_link_relocatable (&link_info) && config.build_constructors) - return -EOF -sed $sc ldscripts/${EMULATION_NAME}.xu >> e${EMULATION_NAME}.c -echo ' ; else if (bfd_link_relocatable (&link_info)) return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.xr >> e${EMULATION_NAME}.c -echo ' ; else if (!config.text_read_only) return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.xbn >> e${EMULATION_NAME}.c -echo ' ; else if (!config.magic_demand_paged) return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.xn >> e${EMULATION_NAME}.c -echo ' ; else return' >> e${EMULATION_NAME}.c -sed $sc ldscripts/${EMULATION_NAME}.x >> e${EMULATION_NAME}.c -echo '; }' >> e${EMULATION_NAME}.c - -else -# Scripts read from the filesystem. - -fragment <<EOF -{ - *isfile = 1; - - if (bfd_link_relocatable (&link_info) && config.build_constructors) - return "ldscripts/${EMULATION_NAME}.xu"; - else if (bfd_link_relocatable (&link_info)) - return "ldscripts/${EMULATION_NAME}.xr"; - else if (!config.text_read_only) - return "ldscripts/${EMULATION_NAME}.xbn"; - else if (!config.magic_demand_paged) - return "ldscripts/${EMULATION_NAME}.xn"; - else - return "ldscripts/${EMULATION_NAME}.x"; -} -EOF - -fi - -fragment <<EOF - -struct ld_emulation_xfer_struct ld_lnk960_emulation = -{ - lnk960_before_parse, - lnk960_syslib, - lnk960_hll, - lnk960_after_parse, - after_open_default, - after_check_relocs_default, - lnk960_after_allocation, - lnk960_set_output_arch, - lnk960_choose_target, - before_allocation_default, - lnk960_get_script, - "lnk960", - "", - finish_default, - NULL, /* create output section statements */ - NULL, /* open dynamic archive */ - NULL, /* place orphan */ - NULL, /* set symbols */ - NULL, /* parse args */ - NULL, /* add_options */ - NULL, /* handle_option */ - NULL, /* unrecognized file */ - NULL, /* list options */ - NULL, /* recognized file */ - NULL, /* find_potential_libraries */ - NULL, /* new_vers_pattern */ - NULL /* extra_map_file_text */ -}; -EOF diff --git a/ld/ld.texinfo b/ld/ld.texinfo index 9425c65..cd7aa6d 100644 --- a/ld/ld.texinfo +++ b/ld/ld.texinfo @@ -23,7 +23,6 @@ @set C6X @set H8300 @set HPPA -@set I960 @set M68HC11 @set M68K @set MIPS @@ -135,9 +134,6 @@ in the section entitled ``GNU Free Documentation License''. @ifset Renesas * Renesas:: ld and other Renesas micros @end ifset -@ifset I960 -* i960:: ld and the Intel 960 family -@end ifset @ifset ARM * ARM:: ld and the ARM family @end ifset @@ -381,23 +377,6 @@ it will add a corresponding @code{DT_DEPAUDIT} entry in the output file. This option is only meaningful on ELF platforms supporting the rtld-audit interface. -@ifset I960 -@cindex architectures -@kindex -A @var{arch} -@item -A @var{architecture} -@kindex --architecture=@var{arch} -@itemx --architecture=@var{architecture} -In the current release of @command{ld}, this option is useful only for the -Intel 960 family of architectures. In that @command{ld} configuration, the -@var{architecture} argument identifies the particular architecture in -the 960 family, enabling some safeguards and modifying the -archive-library search path. @xref{i960,,@command{ld} and the Intel 960 -family}, for details. - -Future releases of @command{ld} may support similar functionality for -other architecture families. -@end ifset - @ifclear SingleFormat @cindex binary input format @kindex -b @var{format} @@ -1860,9 +1839,6 @@ This option is only supported on a few targets. @ifset H8300 @xref{H8/300,,@command{ld} and the H8/300}. @end ifset -@ifset I960 -@xref{i960,, @command{ld} and the Intel 960 family}. -@end ifset @ifset XTENSA @xref{Xtensa,, @command{ld} and Xtensa Processors}. @end ifset @@ -6562,9 +6538,6 @@ functionality are not listed. @ifset H8300 * H8/300:: @command{ld} and the H8/300 @end ifset -@ifset I960 -* i960:: @command{ld} and the Intel 960 family -@end ifset @ifset M68HC11 * M68HC11/68HC12:: @code{ld} and the Motorola 68HC11 and 68HC12 families @end ifset @@ -6690,63 +6663,6 @@ options are required for these chips. @end ifset @end ifclear -@ifset I960 -@ifclear GENERIC -@raisesections -@end ifclear - -@node i960 -@section @command{ld} and the Intel 960 Family - -@cindex i960 support - -You can use the @samp{-A@var{architecture}} command line option to -specify one of the two-letter names identifying members of the 960 -family; the option specifies the desired output target, and warns of any -incompatible instructions in the input files. It also modifies the -linker's search strategy for archive libraries, to support the use of -libraries specific to each particular architecture, by including in the -search loop names suffixed with the string identifying the architecture. - -For example, if your @command{ld} command line included @w{@samp{-ACA}} as -well as @w{@samp{-ltry}}, the linker would look (in its built-in search -paths, and in any paths you specify with @samp{-L}) for a library with -the names - -@smallexample -@group -try -libtry.a -tryca -libtryca.a -@end group -@end smallexample - -@noindent -The first two possibilities would be considered in any event; the last -two are due to the use of @w{@samp{-ACA}}. - -You can meaningfully use @samp{-A} more than once on a command line, since -the 960 architecture family allows combination of target architectures; each -use will add another pair of name variants to search for when @w{@samp{-l}} -specifies a library. - -@cindex @option{--relax} on i960 -@cindex relaxing on i960 -@command{ld} supports the @samp{--relax} option for the i960 family. If -you specify @samp{--relax}, @command{ld} finds all @code{balx} and -@code{calx} instructions whose targets are within 24 bits, and turns -them into 24-bit program-counter relative @code{bal} and @code{cal} -instructions, respectively. @command{ld} also turns @code{cal} -instructions into @code{bal} instructions when it determines that the -target subroutine is a leaf routine (that is, the target subroutine does -not itself call any subroutines). - -@ifclear GENERIC -@lowersections -@end ifclear -@end ifset - @ifset ARM @ifclear GENERIC @raisesections diff --git a/ld/po/BLD-POTFILES.in b/ld/po/BLD-POTFILES.in index 050e3ca..33280c4 100644 --- a/ld/po/BLD-POTFILES.in +++ b/ld/po/BLD-POTFILES.in @@ -66,7 +66,6 @@ eavrxmega4.c eavrxmega5.c eavrxmega6.c eavrxmega7.c -ecoff_i860.c ecoff_sparc.c ecrisaout.c ecriself.c @@ -77,8 +76,6 @@ ed30v_o.c ed30velf.c edelta68.c eelf32_dlx.c -eelf32_i860.c -eelf32_i960.c eelf32_sparc.c eelf32_sparc_sol2.c eelf32_sparc_vxworks.c @@ -211,8 +208,6 @@ eelf_x86_64_cloudabi.c eelf_x86_64_fbsd.c eelf_x86_64_nacl.c eelf_x86_64_sol2.c -egld960.c -egld960coff.c eh8300.c eh8300elf.c eh8300elf_linux.c @@ -259,7 +254,6 @@ ei386nw.c ei386pe.c ei386pe_posix.c ei386pep.c -elnk960.c em32relf.c em32relf_linux.c em32rlelf.c diff --git a/ld/scripttempl/i860coff.sc b/ld/scripttempl/i860coff.sc deleted file mode 100644 index f809426..0000000 --- a/ld/scripttempl/i860coff.sc +++ /dev/null @@ -1,54 +0,0 @@ -# Copyright (C) 2014-2018 Free Software Foundation, Inc. -# -# Copying and distribution of this file, with or without modification, -# are permitted in any medium without royalty provided the copyright -# notice and this notice are preserved. - -cat <<EOF -/* Copyright (C) 2014-2018 Free Software Foundation, Inc. - - Copying and distribution of this script, with or without modification, - are permitted in any medium without royalty provided the copyright - notice and this notice are preserved. */ - -OUTPUT_FORMAT("${OUTPUT_FORMAT}") -${LIB_SEARCH_DIRS} -PROVIDE (__stack = 0); -SECTIONS -{ - .text ${RELOCATING+ 0x1000000} : { - *(.text) - ${CONSTRUCTING+ . = ALIGN(4);} - ${RELOCATING+ etext = .;} - ${CONSTRUCTING+ __CTOR_LIST__ = .;} - ${CONSTRUCTING+ LONG((__CTOR_END__ - __CTOR_LIST__) / 4 - 2)} - ${CONSTRUCTING+ *(.ctors)} - ${CONSTRUCTING+ LONG(0)} - ${CONSTRUCTING+ __CTOR_END__ = .;} - ${CONSTRUCTING+ __DTOR_LIST__ = .;} - ${CONSTRUCTING+ LONG((__DTOR_END__ - __DTOR_LIST__) / 4 - 2)} - ${CONSTRUCTING+ *(.dtors)} - ${CONSTRUCTING+ LONG(0)} - ${CONSTRUCTING+ __DTOR_END__ = .;} - } - .data : { - *(.data) - ${RELOCATING+ edata = .}; - } - .bss : { - ${RELOCATING+ __bss_start = .}; - *(.bss) - *(COMMON) - ${RELOCATING+ end = ALIGN(0x8)}; - ${RELOCATING+ _end = ALIGN(0x8)}; - } - .stab 0 ${RELOCATING+(NOLOAD)} : - { - [ .stab ] - } - .stabstr 0 ${RELOCATING+(NOLOAD)} : - { - [ .stabstr ] - } -} -EOF diff --git a/ld/scripttempl/i960.sc b/ld/scripttempl/i960.sc deleted file mode 100644 index 647ae86..0000000 --- a/ld/scripttempl/i960.sc +++ /dev/null @@ -1,37 +0,0 @@ -# Copyright (C) 2014-2018 Free Software Foundation, Inc. -# -# Copying and distribution of this file, with or without modification, -# are permitted in any medium without royalty provided the copyright -# notice and this notice are preserved. - -cat <<EOF -/* Copyright (C) 2014-2018 Free Software Foundation, Inc. - - Copying and distribution of this script, with or without modification, - are permitted in any medium without royalty provided the copyright - notice and this notice are preserved. */ - -SECTIONS -{ - .text : - { - ${GLD_STYLE+ CREATE_OBJECT_SYMBOLS} - *(.text) - ${RELOCATING+ _etext = .}; - ${CONSTRUCTING+${COFF_CTORS}} - } - .data : - { - *(.data) - ${CONSTRUCTING+CONSTRUCTORS} - ${RELOCATING+ _edata = .}; - } - .bss : - { - ${RELOCATING+ _bss_start = .}; - *(.bss) - *(COMMON) - ${RELOCATING+ _end = .}; - } -} -EOF diff --git a/ld/testsuite/ld-discard/extern.d b/ld/testsuite/ld-discard/extern.d index 9932ebc..50112e4 100644 --- a/ld/testsuite/ld-discard/extern.d +++ b/ld/testsuite/ld-discard/extern.d @@ -2,7 +2,7 @@ #ld: -T discard.ld #error: .*data.* referenced in section `\.text' of tmpdir/extern.o: defined in discarded section `\.data\.exit' of tmpdir/extern.o #objdump: -p -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* #xfail: m68hc12-*-* m6812-*-* #pass # The expected warning used to start with "`data' referenced..." but diff --git a/ld/testsuite/ld-discard/start.d b/ld/testsuite/ld-discard/start.d index d846bc7..e8ce59d 100644 --- a/ld/testsuite/ld-discard/start.d +++ b/ld/testsuite/ld-discard/start.d @@ -3,6 +3,6 @@ #ld: -T discard.ld #error: `data' referenced in section `\.text' of tmpdir/start.o: defined in discarded section `\.data\.exit' of tmpdir/exit.o #objdump: -p -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* #xfail: m68hc12-*-* m6812-*-* #pass diff --git a/ld/testsuite/ld-discard/static.d b/ld/testsuite/ld-discard/static.d index 3f61bb3..7a299cc 100644 --- a/ld/testsuite/ld-discard/static.d +++ b/ld/testsuite/ld-discard/static.d @@ -2,6 +2,6 @@ #ld: -T discard.ld #error: `(\.data\.exit|data)' referenced in section `\.text' of tmpdir/static.o: defined in discarded section `\.data\.exit' of tmpdir/static.o #objdump: -p -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* #xfail: m68hc12-*-* m6812-*-* #pass diff --git a/ld/testsuite/ld-elf/compressed1d.d b/ld/testsuite/ld-elf/compressed1d.d index 5c5592d..f3211de 100644 --- a/ld/testsuite/ld-elf/compressed1d.d +++ b/ld/testsuite/ld-elf/compressed1d.d @@ -2,7 +2,7 @@ #as: --compress-debug-sections=none #ld: -r --compress-debug-sections=zlib-gnu #readelf: -SW -#notarget: d30v-*-* dlx-*-* fr30-*-* frv-*-* ft32-*-* i370-*-* i860-*-* iq2000-*-* mn10200-*-* moxie-*-* msp430-*-* mt-*-* or1k-*-* pj-*-* riscv*-*-* +#notarget: d30v-*-* dlx-*-* fr30-*-* frv-*-* ft32-*-* i370-*-* iq2000-*-* mn10200-*-* moxie-*-* msp430-*-* mt-*-* or1k-*-* pj-*-* riscv*-*-* # Not all ELF targets use the elf.em emulation... # RISC-V has linker relaxations that delete code, so text label subtractions # do not get resolved at assembly time, which results in a compressed section. diff --git a/ld/testsuite/ld-elf/group1.d b/ld/testsuite/ld-elf/group1.d index e355cd8..c2d67b9 100644 --- a/ld/testsuite/ld-elf/group1.d +++ b/ld/testsuite/ld-elf/group1.d @@ -2,7 +2,7 @@ #source: group1b.s #ld: -T group.ld #readelf: -s -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* *-*-solaris* +#xfail: d30v-*-* dlx-*-* pj*-*-* *-*-solaris* # generic linker targets don't comply with all symbol merging rules Symbol table '.symtab' contains .* entries: diff --git a/ld/testsuite/ld-elf/group3b.d b/ld/testsuite/ld-elf/group3b.d index a242c40..bb8813f 100644 --- a/ld/testsuite/ld-elf/group3b.d +++ b/ld/testsuite/ld-elf/group3b.d @@ -2,7 +2,7 @@ #source: group3a.s #ld: -T group.ld #readelf: -s -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* # generic linker targets don't comply with all symbol merging rules Symbol table '.symtab' contains .* entries: diff --git a/ld/testsuite/ld-elf/group8a.d b/ld/testsuite/ld-elf/group8a.d index 52112e9..835ca56 100644 --- a/ld/testsuite/ld-elf/group8a.d +++ b/ld/testsuite/ld-elf/group8a.d @@ -1,8 +1,8 @@ #source: group8.s #ld: -r --gc-sections --entry foo #readelf: -g --wide -#notarget: d30v-*-* dlx-*-* i960-*-* pj*-*-* pru-*-* -#notarget: hppa64-*-* i370-*-* i860-*-* ia64-*-* mep-*-* mn10200-*-* +#notarget: d30v-*-* dlx-*-* pj*-*-* pru-*-* +#notarget: hppa64-*-* i370-*-* ia64-*-* mep-*-* mn10200-*-* #xfail: cr16-*-* crx-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others # cr16 and crx use non-standard scripts with memory regions, which don't play diff --git a/ld/testsuite/ld-elf/group8b.d b/ld/testsuite/ld-elf/group8b.d index 15714a7..6a17e87 100644 --- a/ld/testsuite/ld-elf/group8b.d +++ b/ld/testsuite/ld-elf/group8b.d @@ -1,8 +1,8 @@ #source: group8.s #ld: -r --gc-sections --entry bar #readelf: -g --wide -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* pru-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* pru-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* #xfail: cr16-*-* crx-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others # cr16 and crx use non-standard scripts with memory regions, which don't play diff --git a/ld/testsuite/ld-elf/group9a.d b/ld/testsuite/ld-elf/group9a.d index 291164f..ac887d4 100644 --- a/ld/testsuite/ld-elf/group9a.d +++ b/ld/testsuite/ld-elf/group9a.d @@ -1,8 +1,8 @@ #source: group9.s #ld: -r --gc-sections --entry foo #readelf: -g --wide -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* pru-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* pru-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* #xfail: cr16-*-* crx-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others # cr16 and crx use non-standard scripts with memory regions, which don't play diff --git a/ld/testsuite/ld-elf/group9b.d b/ld/testsuite/ld-elf/group9b.d index 54b0d7a..d6c980f 100644 --- a/ld/testsuite/ld-elf/group9b.d +++ b/ld/testsuite/ld-elf/group9b.d @@ -1,8 +1,8 @@ #source: group9.s #ld: -r --gc-sections --entry bar #readelf: -g --wide -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* pru-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* pru-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* #xfail: cr16-*-* crx-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others # cr16 and crx use non-standard scripts with memory regions, which don't play diff --git a/ld/testsuite/ld-elf/linkonce2.d b/ld/testsuite/ld-elf/linkonce2.d index 7668b32..ea16ce1 100644 --- a/ld/testsuite/ld-elf/linkonce2.d +++ b/ld/testsuite/ld-elf/linkonce2.d @@ -2,7 +2,7 @@ #source: linkonce1b.s #ld: -emit-relocs #objdump: -r -#notarget: arc*-*-* d30v-*-* dlx-*-* i960-*-* pj*-*-* +#notarget: arc*-*-* d30v-*-* dlx-*-* pj*-*-* # generic elf targets don't emit relocs .*: file format .* diff --git a/ld/testsuite/ld-elf/merge.d b/ld/testsuite/ld-elf/merge.d index 5cd075f..b457445 100644 --- a/ld/testsuite/ld-elf/merge.d +++ b/ld/testsuite/ld-elf/merge.d @@ -3,7 +3,7 @@ #objdump: -s #xfail: "bfin-*-*" "cr16-*-*" "cris*-*-*" "crx-*-*" "d10v-*-*" "d30v-*-*" #xfail: "dlx-*-*" "fr30-*-*" "frv-*-*" "hppa*64*-*-*" "h8300-*-*" "score-*-*" -#xfail: "i370-*-*" "i860-*-*" "i960-*-*" "ip2k-*-*" "iq2000-*-*" "lm32-*-*" +#xfail: "i370-*-*" "ip2k-*-*" "iq2000-*-*" "lm32-*-*" #xfail: "mcore-*-*" "mn102*-*-*" "ms1-*-*" "mep-*-*" "m68hc11-*-*" "nios2-*-*" #xfail: "or32-*-*" "pj-*-*" "tic6x-*-*" "vax-*-*" "xstormy16-*-*" #xfail: "xtensa*-*-*" "metag-*-*" "ft32-*-*" "pru-*-*" diff --git a/ld/testsuite/ld-elf/merge2.d b/ld/testsuite/ld-elf/merge2.d index e5f887d..8ac1648 100644 --- a/ld/testsuite/ld-elf/merge2.d +++ b/ld/testsuite/ld-elf/merge2.d @@ -2,7 +2,7 @@ #ld: -T merge.ld #objdump: -s #xfail: "d30v-*-*" "dlx-*-*" "hppa64-*-*" -#xfail: "i960-*-*" "ip2k-*-*" "pj-*-*" +#xfail: "ip2k-*-*" "pj-*-*" .*: file format .*elf.* diff --git a/ld/testsuite/ld-elf/merge3.d b/ld/testsuite/ld-elf/merge3.d index a14ee25..b9ae79c 100644 --- a/ld/testsuite/ld-elf/merge3.d +++ b/ld/testsuite/ld-elf/merge3.d @@ -2,7 +2,7 @@ #ld: -T merge.ld #objdump: -s #xfail: "d30v-*-*" "dlx-*-*" "hppa64-*-*" -#xfail: "i960-*-*" "ip2k-*-*" "pj-*-*" +#xfail: "ip2k-*-*" "pj-*-*" .*: file format .*elf.* diff --git a/ld/testsuite/ld-elf/orphan-10.d b/ld/testsuite/ld-elf/orphan-10.d index 1dbec42..a5cf6d9 100644 --- a/ld/testsuite/ld-elf/orphan-10.d +++ b/ld/testsuite/ld-elf/orphan-10.d @@ -1,7 +1,7 @@ #source: orphan-10.s #ld: -N -T orphan-9.ld #objdump: -h -#notarget: d30v-* dlx-* fr30-* frv-* ft32-* i860-* i960-* iq2000-* mn10200-* moxie-* ms1-* msp430-* mt-* pj-* +#notarget: d30v-* dlx-* fr30-* frv-* ft32-* iq2000-* mn10200-* moxie-* ms1-* msp430-* mt-* pj-* #... . \.text 0+(08|10) [0-9a-f]+ 0+200 .* diff --git a/ld/testsuite/ld-elf/orphan-11.d b/ld/testsuite/ld-elf/orphan-11.d index 3daefba..15eb5fb 100644 --- a/ld/testsuite/ld-elf/orphan-11.d +++ b/ld/testsuite/ld-elf/orphan-11.d @@ -1,7 +1,7 @@ #source: orphan-11.s #ld: -T orphan-11.ld --orphan-handling=error #objdump: -wh -#notarget: d30v-* dlx-* fr30-* frv-* ft32-* i860-* i960-* iq2000-* mn10200-* moxie-* ms1-* msp430-* mt-* pj-* +#notarget: d30v-* dlx-* fr30-* frv-* ft32-* iq2000-* mn10200-* moxie-* ms1-* msp430-* mt-* pj-* #... . \.text .* diff --git a/ld/testsuite/ld-elf/orphan-12.d b/ld/testsuite/ld-elf/orphan-12.d index 71a8c93..ff75345 100644 --- a/ld/testsuite/ld-elf/orphan-12.d +++ b/ld/testsuite/ld-elf/orphan-12.d @@ -1,7 +1,7 @@ #source: orphan-12.s #ld: -T orphan-11.ld --strip-debug --orphan-handling=error #objdump: -wh -#notarget: d30v-* dlx-* fr30-* frv-* ft32-* i860-* i960-* iq2000-* mn10200-* moxie-* ms1-* msp430-* mt-* pj-* +#notarget: d30v-* dlx-* fr30-* frv-* ft32-* iq2000-* mn10200-* moxie-* ms1-* msp430-* mt-* pj-* #... . \.text .* diff --git a/ld/testsuite/ld-elf/orphan-9.d b/ld/testsuite/ld-elf/orphan-9.d index 790cff1..637e8c5 100644 --- a/ld/testsuite/ld-elf/orphan-9.d +++ b/ld/testsuite/ld-elf/orphan-9.d @@ -1,7 +1,7 @@ #source: orphan-9.s #ld: -N -T orphan-9.ld #objdump: -h -#notarget: d30v-* dlx-* fr30-* frv-* ft32-* i860-* i960-* iq2000-* mn10200-* moxie-* ms1-* msp430-* mt-* pj-* +#notarget: d30v-* dlx-* fr30-* frv-* ft32-* iq2000-* mn10200-* moxie-* ms1-* msp430-* mt-* pj-* #... . \.text 0+(08|10) [0-9a-f]+ 0+200 .* diff --git a/ld/testsuite/ld-elf/orphan-region.d b/ld/testsuite/ld-elf/orphan-region.d index a74caf7..7af263a 100644 --- a/ld/testsuite/ld-elf/orphan-region.d +++ b/ld/testsuite/ld-elf/orphan-region.d @@ -1,7 +1,7 @@ #source: orphan-region.s #ld: -T orphan-region.ld -N -z stack-size=0 #readelf: -S -l --wide -#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* i860-*-* i960-*-* +#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* #xfail: iq*-*-* mn10200-*-* moxie-*-* msp*-*-* mt-*-* pj*-*-* #xfail: spu-*-* hppa*64*-*-* *-*-nacl* # if not using elf32.em, you don't get fancy orphan handling diff --git a/ld/testsuite/ld-elf/orphan.d b/ld/testsuite/ld-elf/orphan.d index d03281e..2d10e27 100644 --- a/ld/testsuite/ld-elf/orphan.d +++ b/ld/testsuite/ld-elf/orphan.d @@ -1,7 +1,7 @@ #source: orphan.s #ld: -T orphan.ld #readelf: -S --wide -#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* i860-*-* i960-*-* +#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* #xfail: iq*-*-* mn10200-*-* moxie-*-* msp*-*-* mt-*-* pj*-*-* # if not using elf32.em, you don't get fancy orphan handling diff --git a/ld/testsuite/ld-elf/orphan3.d b/ld/testsuite/ld-elf/orphan3.d index 3331e3f..2c96f64 100644 --- a/ld/testsuite/ld-elf/orphan3.d +++ b/ld/testsuite/ld-elf/orphan3.d @@ -7,7 +7,7 @@ #ld: #readelf: -S --wide #xfail: "d30v-*-*" "dlx-*-*" "fr30-*-*" "frv-*-elf" "ft32-*-*" -#xfail: "i860-*-*" "i960-*-*" "iq2000-*-*" "mn10200-*-*" "msp430-*-*" "mt-*-*" +#xfail: "iq2000-*-*" "mn10200-*-*" "msp430-*-*" "mt-*-*" #xfail: "pj-*-*" #xfail: "xstormy16-*-*" diff --git a/ld/testsuite/ld-elf/pr12851.d b/ld/testsuite/ld-elf/pr12851.d index 7126e68..67e4b4d 100644 --- a/ld/testsuite/ld-elf/pr12851.d +++ b/ld/testsuite/ld-elf/pr12851.d @@ -2,8 +2,8 @@ #source: start.s #ld: --gc-sections #readelf: -s --wide -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* pru-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* pru-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr12975.d b/ld/testsuite/ld-elf/pr12975.d index 9cdc767..f1eba66 100644 --- a/ld/testsuite/ld-elf/pr12975.d +++ b/ld/testsuite/ld-elf/pr12975.d @@ -1,8 +1,8 @@ #ld: --gc-sections -shared -version-script pr12975.t #readelf: -s --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #failif diff --git a/ld/testsuite/ld-elf/pr13177.d b/ld/testsuite/ld-elf/pr13177.d index 29bd374..f0d7c53 100644 --- a/ld/testsuite/ld-elf/pr13177.d +++ b/ld/testsuite/ld-elf/pr13177.d @@ -2,8 +2,8 @@ #ld: --gc-sections -shared #readelf: -s -D --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #failif diff --git a/ld/testsuite/ld-elf/pr13195.d b/ld/testsuite/ld-elf/pr13195.d index 53e41a9..0906825 100644 --- a/ld/testsuite/ld-elf/pr13195.d +++ b/ld/testsuite/ld-elf/pr13195.d @@ -1,8 +1,8 @@ #ld: --gc-sections -shared -version-script pr13195.t #readelf: -s --wide -D #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr17550a.d b/ld/testsuite/ld-elf/pr17550a.d index c8f0424..47caa8a 100644 --- a/ld/testsuite/ld-elf/pr17550a.d +++ b/ld/testsuite/ld-elf/pr17550a.d @@ -2,7 +2,7 @@ #source: pr17550-2.s #ld: -r #readelf: -s --wide -#notarget: alpha-*-* cr16-*-* crx-*-* d30v-*-* dlx-*-* i960-*-* pj*-*-* +#notarget: alpha-*-* cr16-*-* crx-*-* d30v-*-* dlx-*-* pj*-*-* # Disabled on alpha because alpha has a different .set directive. # cr16 and crx use non-standard scripts with memory regions, which don't # play well with comdat group sections under ld -r. Generic linker diff --git a/ld/testsuite/ld-elf/pr17550b.d b/ld/testsuite/ld-elf/pr17550b.d index d189747..9fa4881 100644 --- a/ld/testsuite/ld-elf/pr17550b.d +++ b/ld/testsuite/ld-elf/pr17550b.d @@ -2,7 +2,7 @@ #source: pr17550-1.s #ld: -r #readelf: -s --wide -#notarget: alpha-*-* cr16-*-* crx-*-* d30v-*-* dlx-*-* i960-*-* pj*-*-* +#notarget: alpha-*-* cr16-*-* crx-*-* d30v-*-* dlx-*-* pj*-*-* # Disabled on alpha because alpha has a different .set directive. # cr16 and crx use non-standard scripts with memory regions, which don't # play well with comdat group sections under ld -r. Generic linker diff --git a/ld/testsuite/ld-elf/pr17550c.d b/ld/testsuite/ld-elf/pr17550c.d index 23a83f1..bf18e208 100644 --- a/ld/testsuite/ld-elf/pr17550c.d +++ b/ld/testsuite/ld-elf/pr17550c.d @@ -2,7 +2,7 @@ #source: pr17550-3.s #ld: -r #error: .*: defined in discarded section `\.data\[foo_group\]' -#notarget: alpha-*-* cr16-*-* crx-*-* d30v-*-* dlx-*-* i960-*-* pj*-*-* +#notarget: alpha-*-* cr16-*-* crx-*-* d30v-*-* dlx-*-* pj*-*-* # Disabled on alpha because alpha has a different .set directive. # cr16 and crx use non-standard scripts with memory regions, which don't # play well with comdat group sections under ld -r. Generic linker diff --git a/ld/testsuite/ld-elf/pr17550d.d b/ld/testsuite/ld-elf/pr17550d.d index e8fad96..70c112f 100644 --- a/ld/testsuite/ld-elf/pr17550d.d +++ b/ld/testsuite/ld-elf/pr17550d.d @@ -2,7 +2,7 @@ #source: pr17550-4.s #ld: -r #readelf: -s --wide -#notarget: alpha-*-* cr16-*-* crx-*-* d30v-*-* dlx-*-* i960-*-* pj*-*-* +#notarget: alpha-*-* cr16-*-* crx-*-* d30v-*-* dlx-*-* pj*-*-* # Disabled on alpha because alpha has a different .set directive. # cr16 and crx use non-standard scripts with memory regions, which don't # play well with comdat group sections under ld -r. Generic linker diff --git a/ld/testsuite/ld-elf/pr17615.d b/ld/testsuite/ld-elf/pr17615.d index dbacbf0..fb7779c 100644 --- a/ld/testsuite/ld-elf/pr17615.d +++ b/ld/testsuite/ld-elf/pr17615.d @@ -1,8 +1,8 @@ #ld: --gc-sections -shared #readelf: -S --wide --dyn-syms #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr20528a.d b/ld/testsuite/ld-elf/pr20528a.d index 8ffb816..8b56e11 100644 --- a/ld/testsuite/ld-elf/pr20528a.d +++ b/ld/testsuite/ld-elf/pr20528a.d @@ -2,7 +2,7 @@ #source: pr20528b.s #ld: -r #readelf: -S --wide -#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* i860-*-* i960-*-* +#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* #xfail: iq*-*-* mn10200-*-* moxie-*-* msp*-*-* mt-*-* pj*-*-* #... diff --git a/ld/testsuite/ld-elf/pr20528b.d b/ld/testsuite/ld-elf/pr20528b.d index 80f0aa5..34fd9fb 100644 --- a/ld/testsuite/ld-elf/pr20528b.d +++ b/ld/testsuite/ld-elf/pr20528b.d @@ -2,7 +2,7 @@ #source: pr20528a.s #ld: -r #readelf: -S --wide -#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* i860-*-* i960-*-* +#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* #xfail: iq*-*-* mn10200-*-* moxie-*-* msp*-*-* mt-*-* pj*-*-* #... diff --git a/ld/testsuite/ld-elf/pr21562a.d b/ld/testsuite/ld-elf/pr21562a.d index 9fe6daa..d742756 100644 --- a/ld/testsuite/ld-elf/pr21562a.d +++ b/ld/testsuite/ld-elf/pr21562a.d @@ -1,8 +1,8 @@ #ld: -shared -z defs --gc-sections #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr21562b.d b/ld/testsuite/ld-elf/pr21562b.d index 72d4644..5312fc7 100644 --- a/ld/testsuite/ld-elf/pr21562b.d +++ b/ld/testsuite/ld-elf/pr21562b.d @@ -1,8 +1,8 @@ #ld: -shared -z defs --gc-sections #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr21562c.d b/ld/testsuite/ld-elf/pr21562c.d index 2ef8378..eb2063a 100644 --- a/ld/testsuite/ld-elf/pr21562c.d +++ b/ld/testsuite/ld-elf/pr21562c.d @@ -2,8 +2,8 @@ #ld: -shared -z defs --gc-sections -T pr21562a.t #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr21562d.d b/ld/testsuite/ld-elf/pr21562d.d index 47a8fce..ab59d8f 100644 --- a/ld/testsuite/ld-elf/pr21562d.d +++ b/ld/testsuite/ld-elf/pr21562d.d @@ -2,8 +2,8 @@ #ld: -shared -z defs --gc-sections -T pr21562a.t #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr21562i.d b/ld/testsuite/ld-elf/pr21562i.d index 3ce3bf1..16974b2 100644 --- a/ld/testsuite/ld-elf/pr21562i.d +++ b/ld/testsuite/ld-elf/pr21562i.d @@ -2,8 +2,8 @@ #ld: -shared -z defs --gc-sections -T pr21562b.t #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr21562j.d b/ld/testsuite/ld-elf/pr21562j.d index 415c845..88f655a 100644 --- a/ld/testsuite/ld-elf/pr21562j.d +++ b/ld/testsuite/ld-elf/pr21562j.d @@ -2,8 +2,8 @@ #ld: -shared -z defs --gc-sections -T pr21562b.t #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr21562k.d b/ld/testsuite/ld-elf/pr21562k.d index 68e6e3c..e2316ea 100644 --- a/ld/testsuite/ld-elf/pr21562k.d +++ b/ld/testsuite/ld-elf/pr21562k.d @@ -2,8 +2,8 @@ #ld: -shared -z defs --gc-sections -T pr21562c.t #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr21562l.d b/ld/testsuite/ld-elf/pr21562l.d index 4c408a2..82791e6 100644 --- a/ld/testsuite/ld-elf/pr21562l.d +++ b/ld/testsuite/ld-elf/pr21562l.d @@ -2,8 +2,8 @@ #ld: -shared -z defs --gc-sections -T pr21562c.t #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr21562m.d b/ld/testsuite/ld-elf/pr21562m.d index 4d1b390..b401d98 100644 --- a/ld/testsuite/ld-elf/pr21562m.d +++ b/ld/testsuite/ld-elf/pr21562m.d @@ -2,8 +2,8 @@ #ld: -shared -z defs --gc-sections -T pr21562d.t #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr21562n.d b/ld/testsuite/ld-elf/pr21562n.d index d31e1f3..74d9744 100644 --- a/ld/testsuite/ld-elf/pr21562n.d +++ b/ld/testsuite/ld-elf/pr21562n.d @@ -2,8 +2,8 @@ #ld: -shared -z defs --gc-sections -T pr21562d.t #readelf: -s -S --wide #target: *-*-linux* *-*-gnu* -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* # generic linker targets don't support --gc-sections, nor do a bunch of others #... diff --git a/ld/testsuite/ld-elf/pr22677.d b/ld/testsuite/ld-elf/pr22677.d index c477dee..4558ec7 100644 --- a/ld/testsuite/ld-elf/pr22677.d +++ b/ld/testsuite/ld-elf/pr22677.d @@ -1,7 +1,7 @@ #ld: -r --gc-sections -u foo #readelf: -S --wide -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* pru-*-* -#xfail: hppa64-*-* i370-*-* i860-*-* mep-*-* mn10200-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* pru-*-* +#xfail: hppa64-*-* i370-*-* mep-*-* mn10200-*-* #xfail: cr16-*-* crx-*-* msp430-*-* # msp430 puts the init_array and fini_array inside the .rodata section. # generic linker targets don't support --gc-sections, nor do a bunch of diff --git a/ld/testsuite/ld-elf/pr22836-1a.d b/ld/testsuite/ld-elf/pr22836-1a.d index 4acf45d..bd2d0f4 100644 --- a/ld/testsuite/ld-elf/pr22836-1a.d +++ b/ld/testsuite/ld-elf/pr22836-1a.d @@ -1,7 +1,7 @@ #source: pr22836-1.s #ld: -r -s #readelf: -g --wide -#xfail: d30v-*-* dlx-*-* i960-*-* pj-*-* +#xfail: d30v-*-* dlx-*-* pj-*-* # Targets using the generic linker don't properly support comdat group sections There are no section groups in this file\. diff --git a/ld/testsuite/ld-elf/pr22836-1b.d b/ld/testsuite/ld-elf/pr22836-1b.d index 30d6fa3..2a332bc 100644 --- a/ld/testsuite/ld-elf/pr22836-1b.d +++ b/ld/testsuite/ld-elf/pr22836-1b.d @@ -1,7 +1,7 @@ #source: pr22836-1.s #ld: -r -S #readelf: -g --wide -#xfail: d30v-*-* dlx-*-* i960-*-* pj-*-* +#xfail: d30v-*-* dlx-*-* pj-*-* # Targets using the generic linker don't properly support comdat group sections There are no section groups in this file\. diff --git a/ld/testsuite/ld-elf/pr349.d b/ld/testsuite/ld-elf/pr349.d index 565e387..b56683d 100644 --- a/ld/testsuite/ld-elf/pr349.d +++ b/ld/testsuite/ld-elf/pr349.d @@ -2,7 +2,7 @@ #source: pr349-2.s #ld: -r #readelf: -S -#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* i860-*-* i960-*-* +#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* #xfail: iq*-*-* mn10200-*-* moxie-*-* msp*-*-* mt-*-* pj*-*-* # if not using elf32.em, you don't get fancy section handling diff --git a/ld/testsuite/ld-elf/sec-to-seg.exp b/ld/testsuite/ld-elf/sec-to-seg.exp index 1b887bb..becad1b 100644 --- a/ld/testsuite/ld-elf/sec-to-seg.exp +++ b/ld/testsuite/ld-elf/sec-to-seg.exp @@ -80,7 +80,6 @@ if { [istarget avr-*-*] || [istarget dlx-*-*] || [istarget ft32-*-*] || [istarget h8300-*-*] - || [istarget i960-*-*] || [istarget ip2k-*-*] || [istarget m32r-*-*] || [istarget m88k-*-*] diff --git a/ld/testsuite/ld-elf/sec64k.exp b/ld/testsuite/ld-elf/sec64k.exp index b99473f..2495cb8 100644 --- a/ld/testsuite/ld-elf/sec64k.exp +++ b/ld/testsuite/ld-elf/sec64k.exp @@ -31,7 +31,6 @@ if ![is_elf_format] { # before local symbols, so don't bother testing them. if { [istarget "d30v-*-*"] || [istarget "dlx-*-*"] - || [istarget "i960-*-*"] || [istarget "pj*-*-*"] } { return } diff --git a/ld/testsuite/ld-elf/warn1.d b/ld/testsuite/ld-elf/warn1.d index 1ee4a5d..9c5ab86 100644 --- a/ld/testsuite/ld-elf/warn1.d +++ b/ld/testsuite/ld-elf/warn1.d @@ -5,7 +5,7 @@ #warning: ^[^\n]*\): warning: witty one-liner$ #readelf: -s #notarget: "sparc64-*-solaris2*" "sparcv9-*-solaris2*" -#xfail: "d30v-*-*" "dlx-*-*" "i960-*-*" "pj-*-*" +#xfail: "d30v-*-*" "dlx-*-*" "pj-*-*" # Check that warnings are generated for the .gnu.warning.SYMBOL # construct and that the symbol still appears as expected. diff --git a/ld/testsuite/ld-elf/warn2.d b/ld/testsuite/ld-elf/warn2.d index 4e723dd..cee842a 100644 --- a/ld/testsuite/ld-elf/warn2.d +++ b/ld/testsuite/ld-elf/warn2.d @@ -5,7 +5,7 @@ #warning: ^[^\n]*\.[obj]+: warning: function 'Foo' used$ #readelf: -s #notarget: "sparc64-*-solaris2*" "sparcv9-*-solaris2*" -#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* i860-*-* i960-*-* +#xfail: d30v-*-* dlx-*-* fr30-*-* frv-*-elf ft32-*-* #xfail: iq*-*-* mn10200-*-* moxie-*-* msp*-*-* mt-*-* pj*-*-* # if not using elf32.em, you don't get fancy section handling diff --git a/ld/testsuite/ld-elf/warn3.d b/ld/testsuite/ld-elf/warn3.d index 358dca6..a0acd4b 100644 --- a/ld/testsuite/ld-elf/warn3.d +++ b/ld/testsuite/ld-elf/warn3.d @@ -2,7 +2,7 @@ #ld: tmpdir/symbol3w.o tmpdir/symbol3.a #warning: .*: warning: badsym warning$ #readelf: -s -#xfail: d30v-*-* dlx-*-* i960-*-* pj*-*-* +#xfail: d30v-*-* dlx-*-* pj*-*-* # generic linker targets don't support .gnu.warning sections. # Check that warnings are generated for the symbols in .gnu.warning diff --git a/ld/testsuite/lib/ld-lib.exp b/ld/testsuite/lib/ld-lib.exp index 3d645ba..7b1862b 100644 --- a/ld/testsuite/lib/ld-lib.exp +++ b/ld/testsuite/lib/ld-lib.exp @@ -1775,13 +1775,11 @@ proc check_gc_sections_available { } { # advertised by ld's options. if { [istarget d30v-*-*] || [istarget dlx-*-*] - || [istarget i960-*-*] || [istarget pj*-*-*] || [istarget pru*-*-*] || [istarget alpha-*-*] || [istarget hppa*64-*-*] || [istarget i370-*-*] - || [istarget i860-*-*] || [istarget ia64-*-*] || [istarget mep-*-*] || [istarget mn10200-*-*] } { @@ -1834,8 +1832,6 @@ proc is_generic_elf { } { || [istarget "fr30-*-*"] || ([istarget "frv-*-*"] && ![istarget "frv-*-linux*"]) || [istarget "ft32-*-*"] - || [istarget "i860-*-*"] - || [istarget "i960-*-*"] || [istarget "iq2000-*-*"] || [istarget "mn10200-*-*"] || [istarget "moxie-*-*"] diff --git a/opcodes/ChangeLog b/opcodes/ChangeLog index 3add69b..105ebb9 100644 --- a/opcodes/ChangeLog +++ b/opcodes/ChangeLog @@ -1,3 +1,15 @@ +2018-04-11 Alan Modra <amodra@gmail.com> + + * opcodes/i860-dis.c: Delete. + * opcodes/i960-dis.c: Delete. + * Makefile.am: Remove i860 and i960 support. + * configure.ac: Likewise. + * disassemble.c: Likewise. + * disassemble.h: Likewise. + * Makefile.in: Regenerate. + * configure: Regenerate. + * po/POTFILES.in: Regenerate. + 2018-04-04 H.J. Lu <hongjiu.lu@intel.com> PR binutils/23025 diff --git a/opcodes/Makefile.am b/opcodes/Makefile.am index 1b269a8..f7c3813 100644 --- a/opcodes/Makefile.am +++ b/opcodes/Makefile.am @@ -144,8 +144,6 @@ TARGET_LIBOPCODES_CFILES = \ i370-opc.c \ i386-dis.c \ i386-opc.c \ - i860-dis.c \ - i960-dis.c \ ia64-dis.c \ ia64-opc.c \ ip2k-asm.c \ diff --git a/opcodes/Makefile.in b/opcodes/Makefile.in index baa07b9..22f8029 100644 --- a/opcodes/Makefile.in +++ b/opcodes/Makefile.in @@ -446,8 +446,6 @@ TARGET_LIBOPCODES_CFILES = \ i370-opc.c \ i386-dis.c \ i386-opc.c \ - i860-dis.c \ - i960-dis.c \ ia64-dis.c \ ia64-opc.c \ ip2k-asm.c \ @@ -855,8 +853,6 @@ distclean-compile: @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/i370-opc.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/i386-dis.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/i386-opc.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/i860-dis.Plo@am__quote@ -@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/i960-dis.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-dis.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ia64-opc.Plo@am__quote@ @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ip2k-asm.Plo@am__quote@ diff --git a/opcodes/configure b/opcodes/configure index 37b0eb0..b0f1840 100755 --- a/opcodes/configure +++ b/opcodes/configure @@ -12650,8 +12650,6 @@ if test x${all_targets} = xfalse ; then bfd_i370_arch) ta="$ta i370-dis.lo i370-opc.lo" ;; bfd_i386_arch|bfd_iamcu_arch|bfd_l1om_arch|bfd_k1om_arch) ta="$ta i386-dis.lo i386-opc.lo" ;; - bfd_i860_arch) ta="$ta i860-dis.lo" ;; - bfd_i960_arch) ta="$ta i960-dis.lo" ;; bfd_ia64_arch) ta="$ta ia64-dis.lo ia64-opc.lo" ;; bfd_ip2k_arch) ta="$ta ip2k-asm.lo ip2k-desc.lo ip2k-dis.lo ip2k-ibld.lo ip2k-opc.lo" using_cgen=yes ;; bfd_epiphany_arch) ta="$ta epiphany-asm.lo epiphany-desc.lo epiphany-dis.lo epiphany-ibld.lo epiphany-opc.lo" using_cgen=yes ;; diff --git a/opcodes/configure.ac b/opcodes/configure.ac index 481d72d..19fbd10 100644 --- a/opcodes/configure.ac +++ b/opcodes/configure.ac @@ -274,8 +274,6 @@ if test x${all_targets} = xfalse ; then bfd_i370_arch) ta="$ta i370-dis.lo i370-opc.lo" ;; bfd_i386_arch|bfd_iamcu_arch|bfd_l1om_arch|bfd_k1om_arch) ta="$ta i386-dis.lo i386-opc.lo" ;; - bfd_i860_arch) ta="$ta i860-dis.lo" ;; - bfd_i960_arch) ta="$ta i960-dis.lo" ;; bfd_ia64_arch) ta="$ta ia64-dis.lo ia64-opc.lo" ;; bfd_ip2k_arch) ta="$ta ip2k-asm.lo ip2k-desc.lo ip2k-dis.lo ip2k-ibld.lo ip2k-opc.lo" using_cgen=yes ;; bfd_epiphany_arch) ta="$ta epiphany-asm.lo epiphany-desc.lo epiphany-dis.lo epiphany-ibld.lo epiphany-opc.lo" using_cgen=yes ;; diff --git a/opcodes/disassemble.c b/opcodes/disassemble.c index 9fbf603..2991293 100644 --- a/opcodes/disassemble.c +++ b/opcodes/disassemble.c @@ -45,8 +45,6 @@ #define ARCH_hppa #define ARCH_i370 #define ARCH_i386 -#define ARCH_i860 -#define ARCH_i960 #define ARCH_ia64 #define ARCH_ip2k #define ARCH_iq2000 @@ -222,16 +220,6 @@ disassembler (enum bfd_architecture a, disassemble = print_insn_i386; break; #endif -#ifdef ARCH_i860 - case bfd_arch_i860: - disassemble = print_insn_i860; - break; -#endif -#ifdef ARCH_i960 - case bfd_arch_i960: - disassemble = print_insn_i960; - break; -#endif #ifdef ARCH_ia64 case bfd_arch_ia64: disassemble = print_insn_ia64; diff --git a/opcodes/disassemble.h b/opcodes/disassemble.h index ee7a9c8..7d84cbc 100644 --- a/opcodes/disassemble.h +++ b/opcodes/disassemble.h @@ -48,8 +48,6 @@ extern int print_insn_i370 (bfd_vma, disassemble_info *); extern int print_insn_i386 (bfd_vma, disassemble_info *); extern int print_insn_i386_att (bfd_vma, disassemble_info *); extern int print_insn_i386_intel (bfd_vma, disassemble_info *); -extern int print_insn_i860 (bfd_vma, disassemble_info *); -extern int print_insn_i960 (bfd_vma, disassemble_info *); extern int print_insn_ia64 (bfd_vma, disassemble_info *); extern int print_insn_ip2k (bfd_vma, disassemble_info *); extern int print_insn_iq2000 (bfd_vma, disassemble_info *); diff --git a/opcodes/i860-dis.c b/opcodes/i860-dis.c deleted file mode 100644 index 5211dcd..0000000 --- a/opcodes/i860-dis.c +++ /dev/null @@ -1,286 +0,0 @@ -/* Disassembler for the i860. - Copyright (C) 2000-2018 Free Software Foundation, Inc. - - Contributed by Jason Eckhardt <jle@cygnus.com>. - - This file is part of the GNU opcodes library. - - This library 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. - - It 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 "disassemble.h" -#include "opcode/i860.h" - -/* Later we should probably choose the prefix based on which OS flavor. */ -#define I860_REG_PREFIX "%" - -/* Integer register names (encoded as 0..31 in the instruction). */ -static const char *const grnames[] = - {"r0", "r1", "sp", "fp", "r4", "r5", "r6", "r7", - "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15", - "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23", - "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31"}; - -/* FP register names (encoded as 0..31 in the instruction). */ -static const char *const frnames[] = - {"f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7", - "f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15", - "f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23", - "f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31"}; - -/* Control/status register names (encoded as 0..11 in the instruction). - Registers bear, ccr, p0, p1, p2 and p3 are XP only. */ -static const char *const crnames[] = - {"fir", "psr", "dirbase", "db", "fsr", "epsr", "bear", "ccr", - "p0", "p1", "p2", "p3", "--", "--", "--", "--" }; - - - -/* True if opcode is xor, xorh, and, andh, or, orh, andnot, andnoth. */ -#define BITWISE_OP(op) ((op) == 0x30 || (op) == 0x31 \ - || (op) == 0x34 || (op) == 0x35 \ - || (op) == 0x38 || (op) == 0x39 \ - || (op) == 0x3c || (op) == 0x3d \ - || (op) == 0x33 || (op) == 0x37 \ - || (op) == 0x3b || (op) == 0x3f) - - -/* Sign extend N-bit number. */ -static int -sign_ext (unsigned int x, int n) -{ - int t; - t = x >> (n - 1); - t = ((-t) << n) | x; - return t; -} - - -/* Print a PC-relative branch offset. VAL is the sign extended value - from the branch instruction. */ -static void -print_br_address (disassemble_info *info, bfd_vma memaddr, long val) -{ - - long adj = (long)memaddr + 4 + (val << 2); - - (*info->fprintf_func) (info->stream, "0x%08lx", adj); - - /* Attempt to obtain a symbol for the target address. */ - - if (info->print_address_func && adj != 0) - { - (*info->fprintf_func) (info->stream, "\t// "); - (*info->print_address_func) (adj, info); - } -} - - -/* Print one instruction. */ -int -print_insn_i860 (bfd_vma memaddr, disassemble_info *info) -{ - bfd_byte buff[4]; - unsigned int insn, i; - int status; - const struct i860_opcode *opcode = 0; - - status = (*info->read_memory_func) (memaddr, buff, sizeof (buff), info); - if (status != 0) - { - (*info->memory_error_func) (status, memaddr, info); - return -1; - } - - /* Note that i860 instructions are always accessed as little endian - data, regardless of the endian mode of the i860. */ - insn = bfd_getl32 (buff); - - status = 0; - i = 0; - while (i860_opcodes[i].name != NULL) - { - opcode = &i860_opcodes[i]; - if ((insn & opcode->match) == opcode->match - && (insn & opcode->lose) == 0) - { - status = 1; - break; - } - ++i; - } - - if (status == 0) - { - /* Instruction not in opcode table. */ - (*info->fprintf_func) (info->stream, ".long %#08x", insn); - } - else - { - const char *s; - int val; - - /* If this a flop (or a shrd) and its dual bit is set, - prefix with 'd.'. */ - if (((insn & 0xfc000000) == 0x48000000 - || (insn & 0xfc000000) == 0xb0000000) - && (insn & 0x200)) - (*info->fprintf_func) (info->stream, "d.%s\t", opcode->name); - else - (*info->fprintf_func) (info->stream, "%s\t", opcode->name); - - for (s = opcode->args; *s; s++) - { - switch (*s) - { - /* Integer register (src1). */ - case '1': - (*info->fprintf_func) (info->stream, "%s%s", I860_REG_PREFIX, - grnames[(insn >> 11) & 0x1f]); - break; - - /* Integer register (src2). */ - case '2': - (*info->fprintf_func) (info->stream, "%s%s", I860_REG_PREFIX, - grnames[(insn >> 21) & 0x1f]); - break; - - /* Integer destination register. */ - case 'd': - (*info->fprintf_func) (info->stream, "%s%s", I860_REG_PREFIX, - grnames[(insn >> 16) & 0x1f]); - break; - - /* Floating-point register (src1). */ - case 'e': - (*info->fprintf_func) (info->stream, "%s%s", I860_REG_PREFIX, - frnames[(insn >> 11) & 0x1f]); - break; - - /* Floating-point register (src2). */ - case 'f': - (*info->fprintf_func) (info->stream, "%s%s", I860_REG_PREFIX, - frnames[(insn >> 21) & 0x1f]); - break; - - /* Floating-point destination register. */ - case 'g': - (*info->fprintf_func) (info->stream, "%s%s", I860_REG_PREFIX, - frnames[(insn >> 16) & 0x1f]); - break; - - /* Control register. */ - case 'c': - (*info->fprintf_func) (info->stream, "%s%s", I860_REG_PREFIX, - crnames[(insn >> 21) & 0xf]); - break; - - /* 16-bit immediate (sign extend, except for bitwise ops). */ - case 'i': - if (BITWISE_OP ((insn & 0xfc000000) >> 26)) - (*info->fprintf_func) (info->stream, "0x%04x", - (unsigned int) (insn & 0xffff)); - else - (*info->fprintf_func) (info->stream, "%d", - sign_ext ((insn & 0xffff), 16)); - break; - - /* 16-bit immediate, aligned (2^0, ld.b). */ - case 'I': - (*info->fprintf_func) (info->stream, "%d", - sign_ext ((insn & 0xffff), 16)); - break; - - /* 16-bit immediate, aligned (2^1, ld.s). */ - case 'J': - (*info->fprintf_func) (info->stream, "%d", - sign_ext ((insn & 0xfffe), 16)); - break; - - /* 16-bit immediate, aligned (2^2, ld.l, {p}fld.l, fst.l). */ - case 'K': - (*info->fprintf_func) (info->stream, "%d", - sign_ext ((insn & 0xfffc), 16)); - break; - - /* 16-bit immediate, aligned (2^3, {p}fld.d, fst.d). */ - case 'L': - (*info->fprintf_func) (info->stream, "%d", - sign_ext ((insn & 0xfff8), 16)); - break; - - /* 16-bit immediate, aligned (2^4, {p}fld.q, fst.q). */ - case 'M': - (*info->fprintf_func) (info->stream, "%d", - sign_ext ((insn & 0xfff0), 16)); - break; - - /* 5-bit immediate (zero extend). */ - case '5': - (*info->fprintf_func) (info->stream, "%d", - ((insn >> 11) & 0x1f)); - break; - - /* Split 16 bit immediate (20..16:10..0). */ - case 's': - val = ((insn >> 5) & 0xf800) | (insn & 0x07ff); - (*info->fprintf_func) (info->stream, "%d", - sign_ext (val, 16)); - break; - - /* Split 16 bit immediate, aligned. (2^0, st.b). */ - case 'S': - val = ((insn >> 5) & 0xf800) | (insn & 0x07ff); - (*info->fprintf_func) (info->stream, "%d", - sign_ext (val, 16)); - break; - - /* Split 16 bit immediate, aligned. (2^1, st.s). */ - case 'T': - val = ((insn >> 5) & 0xf800) | (insn & 0x07fe); - (*info->fprintf_func) (info->stream, "%d", - sign_ext (val, 16)); - break; - - /* Split 16 bit immediate, aligned. (2^2, st.l). */ - case 'U': - val = ((insn >> 5) & 0xf800) | (insn & 0x07fc); - (*info->fprintf_func) (info->stream, "%d", - sign_ext (val, 16)); - break; - - /* 26-bit PC relative immediate (lbroff). */ - case 'l': - val = sign_ext ((insn & 0x03ffffff), 26); - print_br_address (info, memaddr, val); - break; - - /* 16-bit PC relative immediate (sbroff). */ - case 'r': - val = sign_ext ((((insn >> 5) & 0xf800) | (insn & 0x07ff)), 16); - print_br_address (info, memaddr, val); - break; - - default: - (*info->fprintf_func) (info->stream, "%c", *s); - break; - } - } - } - - return sizeof (insn); -} - diff --git a/opcodes/i960-dis.c b/opcodes/i960-dis.c deleted file mode 100644 index 6cb3485..0000000 --- a/opcodes/i960-dis.c +++ /dev/null @@ -1,932 +0,0 @@ -/* Disassemble i80960 instructions. - Copyright (C) 1990-2018 Free Software Foundation, Inc. - - This file is part of the GNU opcodes library. - - This library 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. - - It 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; see the file COPYING. If not, write to the - Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA - 02110-1301, USA. */ - -#include "sysdep.h" -#include "disassemble.h" - -static const char *const reg_names[] = { -/* 0 */ "pfp", "sp", "rip", "r3", "r4", "r5", "r6", "r7", -/* 8 */ "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15", -/* 16 */ "g0", "g1", "g2", "g3", "g4", "g5", "g6", "g7", -/* 24 */ "g8", "g9", "g10", "g11", "g12", "g13", "g14", "fp", -/* 32 */ "pc", "ac", "ip", "tc", "fp0", "fp1", "fp2", "fp3" -}; - - -static FILE *stream; /* Output goes here */ -static struct disassemble_info *info; -static void print_addr (bfd_vma); -static void ctrl (bfd_vma, unsigned long, unsigned long); -static void cobr (bfd_vma, unsigned long, unsigned long); -static void reg (unsigned long); -static int mem (bfd_vma, unsigned long, unsigned long, int); -static void ea (bfd_vma, int, const char *, const char *, int, unsigned int); -static void dstop (int, int, int); -static void regop (int, int, int, int); -static void invalid (int); -static int pinsn (bfd_vma, unsigned long, unsigned long); -static void put_abs (unsigned long, unsigned long); - - -/* Print the i960 instruction at address 'memaddr' in debugged memory, - on INFO->STREAM. Returns length of the instruction, in bytes. */ - -int -print_insn_i960 (bfd_vma memaddr, struct disassemble_info *info_arg) -{ - unsigned int word1, word2 = 0xdeadbeef; - bfd_byte buffer[8]; - int status; - - info = info_arg; - stream = info->stream; - - /* Read word1. Only read word2 if the instruction - needs it, to prevent reading past the end of a section. */ - - status = (*info->read_memory_func) (memaddr, (bfd_byte *) buffer, 4, info); - if (status != 0) - { - (*info->memory_error_func) (status, memaddr, info); - return -1; - } - - word1 = bfd_getl32 (buffer); - - /* Divide instruction set into classes based on high 4 bits of opcode. */ - switch ( (word1 >> 28) & 0xf ) - { - default: - break; - case 0x8: - case 0x9: - case 0xa: - case 0xb: - case 0xc: - /* Read word2. */ - status = (*info->read_memory_func) - (memaddr + 4, (bfd_byte *) (buffer + 4), 4, info); - if (status != 0) - { - (*info->memory_error_func) (status, memaddr, info); - return -1; - } - word2 = bfd_getl32 (buffer + 4); - break; - } - - return pinsn( memaddr, word1, word2 ); -} - -#define IN_GDB - -/***************************************************************************** - * All code below this point should be identical with that of - * the disassembler in gdmp960. - - A noble sentiment, but at least in cosmetic ways (info->fprintf_func), it - just ain't so. -kingdon, 31 Mar 93 - *****************************************************************************/ - -struct tabent { - char *name; - short numops; -}; - -struct sparse_tabent { - int opcode; - char *name; - short numops; -}; - -static int -pinsn (bfd_vma memaddr, unsigned long word1, unsigned long word2) -{ - int instr_len; - - instr_len = 4; - put_abs (word1, word2); - - /* Divide instruction set into classes based on high 4 bits of opcode. */ - switch ((word1 >> 28) & 0xf) - { - case 0x0: - case 0x1: - ctrl (memaddr, word1, word2); - break; - case 0x2: - case 0x3: - cobr (memaddr, word1, word2); - break; - case 0x5: - case 0x6: - case 0x7: - reg (word1); - break; - case 0x8: - case 0x9: - case 0xa: - case 0xb: - case 0xc: - instr_len = mem (memaddr, word1, word2, 0); - break; - default: - /* Invalid instruction, print as data word. */ - invalid (word1); - break; - } - return instr_len; -} - -/* CTRL format.. */ - -static void -ctrl (bfd_vma memaddr, unsigned long word1, unsigned long word2 ATTRIBUTE_UNUSED) -{ - int i; - static const struct tabent ctrl_tab[] = { - { NULL, 0, }, /* 0x00 */ - { NULL, 0, }, /* 0x01 */ - { NULL, 0, }, /* 0x02 */ - { NULL, 0, }, /* 0x03 */ - { NULL, 0, }, /* 0x04 */ - { NULL, 0, }, /* 0x05 */ - { NULL, 0, }, /* 0x06 */ - { NULL, 0, }, /* 0x07 */ - { "b", 1, }, /* 0x08 */ - { "call", 1, }, /* 0x09 */ - { "ret", 0, }, /* 0x0a */ - { "bal", 1, }, /* 0x0b */ - { NULL, 0, }, /* 0x0c */ - { NULL, 0, }, /* 0x0d */ - { NULL, 0, }, /* 0x0e */ - { NULL, 0, }, /* 0x0f */ - { "bno", 1, }, /* 0x10 */ - { "bg", 1, }, /* 0x11 */ - { "be", 1, }, /* 0x12 */ - { "bge", 1, }, /* 0x13 */ - { "bl", 1, }, /* 0x14 */ - { "bne", 1, }, /* 0x15 */ - { "ble", 1, }, /* 0x16 */ - { "bo", 1, }, /* 0x17 */ - { "faultno", 0, }, /* 0x18 */ - { "faultg", 0, }, /* 0x19 */ - { "faulte", 0, }, /* 0x1a */ - { "faultge", 0, }, /* 0x1b */ - { "faultl", 0, }, /* 0x1c */ - { "faultne", 0, }, /* 0x1d */ - { "faultle", 0, }, /* 0x1e */ - { "faulto", 0, }, /* 0x1f */ - }; - - i = (word1 >> 24) & 0xff; - if ((ctrl_tab[i].name == NULL) || ((word1 & 1) != 0)) - { - invalid (word1); - return; - } - - (*info->fprintf_func) (stream, "%s", ctrl_tab[i].name); - if (word1 & 2) - /* Predicts branch not taken. */ - (*info->fprintf_func) (stream, ".f"); - - if (ctrl_tab[i].numops == 1) - { - /* Extract displacement and convert to address. */ - word1 &= 0x00ffffff; - - if (word1 & 0x00800000) - { - /* Sign bit is set. */ - word1 |= (-1 & ~0xffffff); /* Sign extend. */ - } - - (*info->fprintf_func) (stream, "\t"); - print_addr (word1 + memaddr); - } -} - -/* COBR format. */ - -static void -cobr (bfd_vma memaddr, unsigned long word1, unsigned long word2 ATTRIBUTE_UNUSED) -{ - int src1; - int src2; - int i; - - static const struct tabent cobr_tab[] = { - { "testno", 1, }, /* 0x20 */ - { "testg", 1, }, /* 0x21 */ - { "teste", 1, }, /* 0x22 */ - { "testge", 1, }, /* 0x23 */ - { "testl", 1, }, /* 0x24 */ - { "testne", 1, }, /* 0x25 */ - { "testle", 1, }, /* 0x26 */ - { "testo", 1, }, /* 0x27 */ - { NULL, 0, }, /* 0x28 */ - { NULL, 0, }, /* 0x29 */ - { NULL, 0, }, /* 0x2a */ - { NULL, 0, }, /* 0x2b */ - { NULL, 0, }, /* 0x2c */ - { NULL, 0, }, /* 0x2d */ - { NULL, 0, }, /* 0x2e */ - { NULL, 0, }, /* 0x2f */ - { "bbc", 3, }, /* 0x30 */ - { "cmpobg", 3, }, /* 0x31 */ - { "cmpobe", 3, }, /* 0x32 */ - { "cmpobge",3, }, /* 0x33 */ - { "cmpobl", 3, }, /* 0x34 */ - { "cmpobne",3, }, /* 0x35 */ - { "cmpoble",3, }, /* 0x36 */ - { "bbs", 3, }, /* 0x37 */ - { "cmpibno",3, }, /* 0x38 */ - { "cmpibg", 3, }, /* 0x39 */ - { "cmpibe", 3, }, /* 0x3a */ - { "cmpibge",3, }, /* 0x3b */ - { "cmpibl", 3, }, /* 0x3c */ - { "cmpibne",3, }, /* 0x3d */ - { "cmpible",3, }, /* 0x3e */ - { "cmpibo", 3, }, /* 0x3f */ - }; - - i = ((word1 >> 24) & 0xff) - 0x20; - if (cobr_tab[i].name == NULL) - { - invalid (word1); - return; - } - - (*info->fprintf_func) (stream, "%s", cobr_tab[i].name); - - /* Predicts branch not taken. */ - if (word1 & 2) - (*info->fprintf_func) (stream, ".f"); - - (*info->fprintf_func) (stream, "\t"); - - src1 = (word1 >> 19) & 0x1f; - src2 = (word1 >> 14) & 0x1f; - - if (word1 & 0x02000) - /* M1 is 1 */ - (*info->fprintf_func) (stream, "%d", src1); - else - (*info->fprintf_func) (stream, "%s", reg_names[src1]); - - if (cobr_tab[i].numops > 1) - { - if (word1 & 1) - /* S2 is 1. */ - (*info->fprintf_func) (stream, ",sf%d,", src2); - else - /* S1 is 0. */ - (*info->fprintf_func) (stream, ",%s,", reg_names[src2]); - - /* Extract displacement and convert to address. */ - word1 &= 0x00001ffc; - if (word1 & 0x00001000) - /* Negative displacement. */ - word1 |= (-1 & ~0x1fff); /* Sign extend. */ - - print_addr (memaddr + word1); - } -} - -/* MEM format. */ -/* Returns instruction length: 4 or 8. */ - -static int -mem (bfd_vma memaddr, unsigned long word1, unsigned long word2, int noprint) -{ - int i, j; - int len; - int mode; - int offset; - const char *reg1, *reg2, *reg3; - - /* This lookup table is too sparse to make it worth typing in, but not - so large as to make a sparse array necessary. We create the table - at runtime. */ - - /* NOTE: In this table, the meaning of 'numops' is: - 1: single operand - 2: 2 operands, load instruction - -2: 2 operands, store instruction. */ - static struct tabent *mem_tab; - /* Opcodes of 0x8X, 9X, aX, bX, and cX must be in the table. */ -#define MEM_MIN 0x80 -#define MEM_MAX 0xcf -#define MEM_SIZ ( * sizeof(struct tabent)) - - static const struct sparse_tabent mem_init[] = { - { 0x80, "ldob", 2 }, - { 0x82, "stob", -2 }, - { 0x84, "bx", 1 }, - { 0x85, "balx", 2 }, - { 0x86, "callx", 1 }, - { 0x88, "ldos", 2 }, - { 0x8a, "stos", -2 }, - { 0x8c, "lda", 2 }, - { 0x90, "ld", 2 }, - { 0x92, "st", -2 }, - { 0x98, "ldl", 2 }, - { 0x9a, "stl", -2 }, - { 0xa0, "ldt", 2 }, - { 0xa2, "stt", -2 }, - { 0xac, "dcinva", 1 }, - { 0xb0, "ldq", 2 }, - { 0xb2, "stq", -2 }, - { 0xc0, "ldib", 2 }, - { 0xc2, "stib", -2 }, - { 0xc8, "ldis", 2 }, - { 0xca, "stis", -2 }, - { 0, NULL, 0 } - }; - static struct tabent mem_tab_buf[MEM_MAX - MEM_MIN + 1]; - - if (mem_tab == NULL) - { - mem_tab = mem_tab_buf; - - for (i = 0; mem_init[i].opcode != 0; i++) - { - j = mem_init[i].opcode - MEM_MIN; - mem_tab[j].name = mem_init[i].name; - mem_tab[j].numops = mem_init[i].numops; - } - } - - i = ((word1 >> 24) & 0xff) - MEM_MIN; - mode = (word1 >> 10) & 0xf; - - if ((mem_tab[i].name != NULL) /* Valid instruction */ - && ((mode == 5) || (mode >= 12))) - /* With 32-bit displacement. */ - len = 8; - else - len = 4; - - if (noprint) - return len; - - if ((mem_tab[i].name == NULL) || (mode == 6)) - { - invalid (word1); - return len; - } - - (*info->fprintf_func) (stream, "%s\t", mem_tab[i].name); - - reg1 = reg_names[ (word1 >> 19) & 0x1f ]; /* MEMB only */ - reg2 = reg_names[ (word1 >> 14) & 0x1f ]; - reg3 = reg_names[ word1 & 0x1f ]; /* MEMB only */ - offset = word1 & 0xfff; /* MEMA only */ - - switch (mem_tab[i].numops) - { - case 2: /* LOAD INSTRUCTION */ - if (mode & 4) - { /* MEMB FORMAT */ - ea (memaddr, mode, reg2, reg3, word1, word2); - (*info->fprintf_func) (stream, ",%s", reg1); - } - else - { /* MEMA FORMAT */ - (*info->fprintf_func) (stream, "0x%x", (unsigned) offset); - - if (mode & 8) - (*info->fprintf_func) (stream, "(%s)", reg2); - - (*info->fprintf_func)(stream, ",%s", reg1); - } - break; - - case -2: /* STORE INSTRUCTION */ - if (mode & 4) - { - /* MEMB FORMAT */ - (*info->fprintf_func) (stream, "%s,", reg1); - ea (memaddr, mode, reg2, reg3, word1, word2); - } - else - { - /* MEMA FORMAT */ - (*info->fprintf_func) (stream, "%s,0x%x", reg1, (unsigned) offset); - - if (mode & 8) - (*info->fprintf_func) (stream, "(%s)", reg2); - } - break; - - case 1: /* BX/CALLX INSTRUCTION */ - if (mode & 4) - { - /* MEMB FORMAT */ - ea (memaddr, mode, reg2, reg3, word1, word2); - } - else - { - /* MEMA FORMAT */ - (*info->fprintf_func) (stream, "0x%x", (unsigned) offset); - if (mode & 8) - (*info->fprintf_func) (stream, "(%s)", reg2); - } - break; - } - - return len; -} - -/* REG format. */ - -static void -reg (unsigned long word1) -{ - int i, j; - int opcode; - int fp; - int m1, m2, m3; - int s1, s2; - int src, src2, dst; - char *mnemp; - - /* This lookup table is too sparse to make it worth typing in, but not - so large as to make a sparse array necessary. We create the table - at runtime. */ - - /* NOTE: In this table, the meaning of 'numops' is: - 1: single operand, which is NOT a destination. - -1: single operand, which IS a destination. - 2: 2 operands, the 2nd of which is NOT a destination. - -2: 2 operands, the 2nd of which IS a destination. - 3: 3 operands - - If an opcode mnemonic begins with "F", it is a floating-point - opcode (the "F" is not printed). */ - - static struct tabent *reg_tab; - static const struct sparse_tabent reg_init[] = - { -#define REG_MIN 0x580 - { 0x580, "notbit", 3 }, - { 0x581, "and", 3 }, - { 0x582, "andnot", 3 }, - { 0x583, "setbit", 3 }, - { 0x584, "notand", 3 }, - { 0x586, "xor", 3 }, - { 0x587, "or", 3 }, - { 0x588, "nor", 3 }, - { 0x589, "xnor", 3 }, - { 0x58a, "not", -2 }, - { 0x58b, "ornot", 3 }, - { 0x58c, "clrbit", 3 }, - { 0x58d, "notor", 3 }, - { 0x58e, "nand", 3 }, - { 0x58f, "alterbit", 3 }, - { 0x590, "addo", 3 }, - { 0x591, "addi", 3 }, - { 0x592, "subo", 3 }, - { 0x593, "subi", 3 }, - { 0x594, "cmpob", 2 }, - { 0x595, "cmpib", 2 }, - { 0x596, "cmpos", 2 }, - { 0x597, "cmpis", 2 }, - { 0x598, "shro", 3 }, - { 0x59a, "shrdi", 3 }, - { 0x59b, "shri", 3 }, - { 0x59c, "shlo", 3 }, - { 0x59d, "rotate", 3 }, - { 0x59e, "shli", 3 }, - { 0x5a0, "cmpo", 2 }, - { 0x5a1, "cmpi", 2 }, - { 0x5a2, "concmpo", 2 }, - { 0x5a3, "concmpi", 2 }, - { 0x5a4, "cmpinco", 3 }, - { 0x5a5, "cmpinci", 3 }, - { 0x5a6, "cmpdeco", 3 }, - { 0x5a7, "cmpdeci", 3 }, - { 0x5ac, "scanbyte", 2 }, - { 0x5ad, "bswap", -2 }, - { 0x5ae, "chkbit", 2 }, - { 0x5b0, "addc", 3 }, - { 0x5b2, "subc", 3 }, - { 0x5b4, "intdis", 0 }, - { 0x5b5, "inten", 0 }, - { 0x5cc, "mov", -2 }, - { 0x5d8, "eshro", 3 }, - { 0x5dc, "movl", -2 }, - { 0x5ec, "movt", -2 }, - { 0x5fc, "movq", -2 }, - { 0x600, "synmov", 2 }, - { 0x601, "synmovl", 2 }, - { 0x602, "synmovq", 2 }, - { 0x603, "cmpstr", 3 }, - { 0x604, "movqstr", 3 }, - { 0x605, "movstr", 3 }, - { 0x610, "atmod", 3 }, - { 0x612, "atadd", 3 }, - { 0x613, "inspacc", -2 }, - { 0x614, "ldphy", -2 }, - { 0x615, "synld", -2 }, - { 0x617, "fill", 3 }, - { 0x630, "sdma", 3 }, - { 0x631, "udma", 0 }, - { 0x640, "spanbit", -2 }, - { 0x641, "scanbit", -2 }, - { 0x642, "daddc", 3 }, - { 0x643, "dsubc", 3 }, - { 0x644, "dmovt", -2 }, - { 0x645, "modac", 3 }, - { 0x646, "condrec", -2 }, - { 0x650, "modify", 3 }, - { 0x651, "extract", 3 }, - { 0x654, "modtc", 3 }, - { 0x655, "modpc", 3 }, - { 0x656, "receive", -2 }, - { 0x658, "intctl", -2 }, - { 0x659, "sysctl", 3 }, - { 0x65b, "icctl", 3 }, - { 0x65c, "dcctl", 3 }, - { 0x65d, "halt", 0 }, - { 0x660, "calls", 1 }, - { 0x662, "send", 3 }, - { 0x663, "sendserv", 1 }, - { 0x664, "resumprcs", 1 }, - { 0x665, "schedprcs", 1 }, - { 0x666, "saveprcs", 0 }, - { 0x668, "condwait", 1 }, - { 0x669, "wait", 1 }, - { 0x66a, "signal", 1 }, - { 0x66b, "mark", 0 }, - { 0x66c, "fmark", 0 }, - { 0x66d, "flushreg", 0 }, - { 0x66f, "syncf", 0 }, - { 0x670, "emul", 3 }, - { 0x671, "ediv", 3 }, - { 0x673, "ldtime", -1 }, - { 0x674, "Fcvtir", -2 }, - { 0x675, "Fcvtilr", -2 }, - { 0x676, "Fscalerl", 3 }, - { 0x677, "Fscaler", 3 }, - { 0x680, "Fatanr", 3 }, - { 0x681, "Flogepr", 3 }, - { 0x682, "Flogr", 3 }, - { 0x683, "Fremr", 3 }, - { 0x684, "Fcmpor", 2 }, - { 0x685, "Fcmpr", 2 }, - { 0x688, "Fsqrtr", -2 }, - { 0x689, "Fexpr", -2 }, - { 0x68a, "Flogbnr", -2 }, - { 0x68b, "Froundr", -2 }, - { 0x68c, "Fsinr", -2 }, - { 0x68d, "Fcosr", -2 }, - { 0x68e, "Ftanr", -2 }, - { 0x68f, "Fclassr", 1 }, - { 0x690, "Fatanrl", 3 }, - { 0x691, "Flogeprl", 3 }, - { 0x692, "Flogrl", 3 }, - { 0x693, "Fremrl", 3 }, - { 0x694, "Fcmporl", 2 }, - { 0x695, "Fcmprl", 2 }, - { 0x698, "Fsqrtrl", -2 }, - { 0x699, "Fexprl", -2 }, - { 0x69a, "Flogbnrl", -2 }, - { 0x69b, "Froundrl", -2 }, - { 0x69c, "Fsinrl", -2 }, - { 0x69d, "Fcosrl", -2 }, - { 0x69e, "Ftanrl", -2 }, - { 0x69f, "Fclassrl", 1 }, - { 0x6c0, "Fcvtri", -2 }, - { 0x6c1, "Fcvtril", -2 }, - { 0x6c2, "Fcvtzri", -2 }, - { 0x6c3, "Fcvtzril", -2 }, - { 0x6c9, "Fmovr", -2 }, - { 0x6d9, "Fmovrl", -2 }, - { 0x6e1, "Fmovre", -2 }, - { 0x6e2, "Fcpysre", 3 }, - { 0x6e3, "Fcpyrsre", 3 }, - { 0x701, "mulo", 3 }, - { 0x708, "remo", 3 }, - { 0x70b, "divo", 3 }, - { 0x741, "muli", 3 }, - { 0x748, "remi", 3 }, - { 0x749, "modi", 3 }, - { 0x74b, "divi", 3 }, - { 0x780, "addono", 3 }, - { 0x781, "addino", 3 }, - { 0x782, "subono", 3 }, - { 0x783, "subino", 3 }, - { 0x784, "selno", 3 }, - { 0x78b, "Fdivr", 3 }, - { 0x78c, "Fmulr", 3 }, - { 0x78d, "Fsubr", 3 }, - { 0x78f, "Faddr", 3 }, - { 0x790, "addog", 3 }, - { 0x791, "addig", 3 }, - { 0x792, "subog", 3 }, - { 0x793, "subig", 3 }, - { 0x794, "selg", 3 }, - { 0x79b, "Fdivrl", 3 }, - { 0x79c, "Fmulrl", 3 }, - { 0x79d, "Fsubrl", 3 }, - { 0x79f, "Faddrl", 3 }, - { 0x7a0, "addoe", 3 }, - { 0x7a1, "addie", 3 }, - { 0x7a2, "suboe", 3 }, - { 0x7a3, "subie", 3 }, - { 0x7a4, "sele", 3 }, - { 0x7b0, "addoge", 3 }, - { 0x7b1, "addige", 3 }, - { 0x7b2, "suboge", 3 }, - { 0x7b3, "subige", 3 }, - { 0x7b4, "selge", 3 }, - { 0x7c0, "addol", 3 }, - { 0x7c1, "addil", 3 }, - { 0x7c2, "subol", 3 }, - { 0x7c3, "subil", 3 }, - { 0x7c4, "sell", 3 }, - { 0x7d0, "addone", 3 }, - { 0x7d1, "addine", 3 }, - { 0x7d2, "subone", 3 }, - { 0x7d3, "subine", 3 }, - { 0x7d4, "selne", 3 }, - { 0x7e0, "addole", 3 }, - { 0x7e1, "addile", 3 }, - { 0x7e2, "subole", 3 }, - { 0x7e3, "subile", 3 }, - { 0x7e4, "selle", 3 }, - { 0x7f0, "addoo", 3 }, - { 0x7f1, "addio", 3 }, - { 0x7f2, "suboo", 3 }, - { 0x7f3, "subio", 3 }, - { 0x7f4, "selo", 3 }, -#define REG_MAX 0x7f4 - { 0, NULL, 0 } - }; - static struct tabent reg_tab_buf[REG_MAX - REG_MIN + 1]; - - if (reg_tab == NULL) - { - reg_tab = reg_tab_buf; - - for (i = 0; reg_init[i].opcode != 0; i++) - { - j = reg_init[i].opcode - REG_MIN; - reg_tab[j].name = reg_init[i].name; - reg_tab[j].numops = reg_init[i].numops; - } - } - - opcode = ((word1 >> 20) & 0xff0) | ((word1 >> 7) & 0xf); - i = opcode - REG_MIN; - - if ((opcode<REG_MIN) || (opcode>REG_MAX) || (reg_tab[i].name==NULL)) - { - invalid (word1); - return; - } - - mnemp = reg_tab[i].name; - if (*mnemp == 'F') - { - fp = 1; - mnemp++; - } - else - { - fp = 0; - } - - (*info->fprintf_func) (stream, "%s", mnemp); - - s1 = (word1 >> 5) & 1; - s2 = (word1 >> 6) & 1; - m1 = (word1 >> 11) & 1; - m2 = (word1 >> 12) & 1; - m3 = (word1 >> 13) & 1; - src = word1 & 0x1f; - src2 = (word1 >> 14) & 0x1f; - dst = (word1 >> 19) & 0x1f; - - if (reg_tab[i].numops != 0) - { - (*info->fprintf_func) (stream, "\t"); - - switch (reg_tab[i].numops) - { - case 1: - regop (m1, s1, src, fp); - break; - case -1: - dstop (m3, dst, fp); - break; - case 2: - regop (m1, s1, src, fp); - (*info->fprintf_func) (stream, ","); - regop (m2, s2, src2, fp); - break; - case -2: - regop (m1, s1, src, fp); - (*info->fprintf_func) (stream, ","); - dstop (m3, dst, fp); - break; - case 3: - regop (m1, s1, src, fp); - (*info->fprintf_func) (stream, ","); - regop (m2, s2, src2, fp); - (*info->fprintf_func) (stream, ","); - dstop (m3, dst, fp); - break; - } - } -} - -/* Print out effective address for memb instructions. */ - -static void -ea (bfd_vma memaddr, int mode, const char *reg2, const char *reg3, int word1, - unsigned int word2) -{ - int scale; - static const int scale_tab[] = { 1, 2, 4, 8, 16 }; - - scale = (word1 >> 7) & 0x07; - - if ((scale > 4) || (((word1 >> 5) & 0x03) != 0)) - { - invalid (word1); - return; - } - scale = scale_tab[scale]; - - switch (mode) - { - case 4: /* (reg) */ - (*info->fprintf_func)( stream, "(%s)", reg2 ); - break; - case 5: /* displ+8(ip) */ - print_addr (word2 + 8 + memaddr); - break; - case 7: /* (reg)[index*scale] */ - if (scale == 1) - (*info->fprintf_func) (stream, "(%s)[%s]", reg2, reg3); - else - (*info->fprintf_func) (stream, "(%s)[%s*%d]", reg2, reg3, scale); - break; - case 12: /* displacement */ - print_addr ((bfd_vma) word2); - break; - case 13: /* displ(reg) */ - print_addr ((bfd_vma) word2); - (*info->fprintf_func) (stream, "(%s)", reg2); - break; - case 14: /* displ[index*scale] */ - print_addr ((bfd_vma) word2); - if (scale == 1) - (*info->fprintf_func) (stream, "[%s]", reg3); - else - (*info->fprintf_func) (stream, "[%s*%d]", reg3, scale); - break; - case 15: /* displ(reg)[index*scale] */ - print_addr ((bfd_vma) word2); - if (scale == 1) - (*info->fprintf_func) (stream, "(%s)[%s]", reg2, reg3); - else - (*info->fprintf_func) (stream, "(%s)[%s*%d]", reg2, reg3, scale); - break; - default: - invalid (word1); - return; - } -} - - -/* Register Instruction Operand. */ - -static void -regop (int mode, int spec, int fp_reg, int fp) -{ - if (fp) - { - /* Floating point instruction. */ - if (mode == 1) - { - /* FP operand. */ - switch (fp_reg) - { - case 0: (*info->fprintf_func) (stream, "fp0"); - break; - case 1: (*info->fprintf_func) (stream, "fp1"); - break; - case 2: (*info->fprintf_func) (stream, "fp2"); - break; - case 3: (*info->fprintf_func) (stream, "fp3"); - break; - case 16: (*info->fprintf_func) (stream, "0f0.0"); - break; - case 22: (*info->fprintf_func) (stream, "0f1.0"); - break; - default: (*info->fprintf_func) (stream, "?"); - break; - } - } - else - { - /* Non-FP register. */ - (*info->fprintf_func) (stream, "%s", reg_names[fp_reg]); - } - } - else - { - /* Not floating point. */ - if (mode == 1) - { - /* Literal. */ - (*info->fprintf_func) (stream, "%d", fp_reg); - } - else - { - /* Register. */ - if (spec == 0) - (*info->fprintf_func) (stream, "%s", reg_names[fp_reg]); - else - (*info->fprintf_func) (stream, "sf%d", fp_reg); - } - } -} - -/* Register Instruction Destination Operand. */ - -static void -dstop (int mode, int dest_reg, int fp) -{ - /* 'dst' operand can't be a literal. On non-FP instructions, register - mode is assumed and "m3" acts as if were "s3"; on FP-instructions, - sf registers are not allowed so m3 acts normally. */ - if (fp) - regop (mode, 0, dest_reg, fp); - else - regop (0, mode, dest_reg, fp); -} - -static void -invalid (int word1) -{ - (*info->fprintf_func) (stream, ".word\t0x%08x", (unsigned) word1); -} - -static void -print_addr (bfd_vma a) -{ - (*info->print_address_func) (a, info); -} - -static void -put_abs (unsigned long word1 ATTRIBUTE_UNUSED, - unsigned long word2 ATTRIBUTE_UNUSED) -{ -#ifdef IN_GDB - return; -#else - int len; - - switch ((word1 >> 28) & 0xf) - { - case 0x8: - case 0x9: - case 0xa: - case 0xb: - case 0xc: - /* MEM format instruction. */ - len = mem (0, word1, word2, 1); - break; - default: - len = 4; - break; - } - - if (len == 8) - (*info->fprintf_func) (stream, "%08x %08x\t", word1, word2); - else - (*info->fprintf_func) (stream, "%08x \t", word1); -#endif -} diff --git a/opcodes/po/POTFILES.in b/opcodes/po/POTFILES.in index cb1b513..3a1fbd8 100644 --- a/opcodes/po/POTFILES.in +++ b/opcodes/po/POTFILES.in @@ -70,8 +70,6 @@ i386-init.h i386-opc.c i386-opc.h i386-tbl.h -i860-dis.c -i960-dis.c ia64-asmtab.c ia64-asmtab.h ia64-dis.c |