mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-11-25 11:04:18 +08:00
2c3fc38946
* archive.c: Likewise. * cache.c: Likewise. * cisco-core.c: Likewise. * coff-alpha.c: Likewise. * coff-apollo.c: Likewise. * coff-aux.c: Likewise. * coff-h8300.c: Likewise. * coff-h8500.c: Likewise. * coff-i386.c: Likewise. * coff-i960.c: Likewise. * coff-ia64.c: Likewise. * coff-m68k.c: Likewise. * coff-m88k.c: Likewise. * coff-mcore.c: Likewise. * coff-mips.c: Likewise. * coff-or32.c: Likewise. * coff-ppc.c: Likewise. * coff-rs6000.c: Likewise. * coff-sh.c: Likewise. * coff-sparc.c: Likewise. * coff-stgo32.c: Likewise. * coff-tic30.c: Likewise. * coff-tic4x.c: Likewise. * coff-tic54x.c: Likewise. * coff-tic80.c: Likewise. * coff-w65.c: Likewise. * cofflink.c: Likewise. * cpu-arc.c: Likewise. * cpu-cris.c: Likewise. * cpu-h8500.c: Likewise. * cpu-i960.c: Likewise. * cpu-msp430.c: Likewise. * cpu-ns32k.c: Likewise. * cpu-powerpc.c: Likewise. * cpu-rs6000.c: Likewise. * cpu-tic4x.c: Likewise. * cpu-w65.c: Likewise. * ecoff.c: Likewise. * ecofflink.c: Likewise. * elf-m10200.c: Likewise. * elf32-bfin.c: Likewise. * elf32-cris.c: Likewise. * elf32-crx.c: Likewise. * elf32-fr30.c: Likewise. * elf32-frv.c: Likewise. * elf32-h8300.c: Likewise. * elf32-i960.c: Likewise. * elf32-m32c.c: Likewise. * elf32-m68hc11.c: Likewise. * elf32-m68hc12.c: Likewise. * elf32-m68hc1x.c: Likewise. * elf32-m68k.c: Likewise. * elf32-mcore.c: Likewise. * elf32-rl78.c: Likewise. * elf32-rx.c: Likewise. * elf32-s390.c: Likewise. * elf32-vax.c: Likewise. * elf64-alpha.c: Likewise. * elf64-mmix.c: Likewise. * elf64-s390.c: Likewise. * elf64-sparc.c: Likewise. * elfnn-ia64.c: Likewise. * elfxx-mips.c: Likewise. * elfxx-sparc.c: Likewise. * hash.c: Likewise. * hp300hpux.c: Likewise. * hppabsd-core.c: Likewise. * hpux-core.c: Likewise. * i386dynix.c: Likewise. * i386linux.c: Likewise. * i386lynx.c: Likewise. * i386mach3.c: Likewise. * i386msdos.c: Likewise. * i386os9k.c: Likewise. * irix-core.c: Likewise. * lynx-core.c: Likewise. * m68klinux.c: Likewise. * mach-o.h: Likewise. * mipsbsd.c: Likewise. * netbsd-core.c: Likewise. * nlm32-i386.c: Likewise. * osf-core.c: Likewise. * pc532-mach.c: Likewise. * pef.c: Likewise. * ppcboot.c: Likewise. * ptrace-core.c: Likewise. * reloc16.c: Likewise. * sco5-core.c: Likewise. * som.h: Likewise. * sparclinux.c: Likewise. * sparclynx.c: Likewise. * ticoff.h: Likewise. * trad-core.c: Likewise. * vms-lib.c: Likewise. * xsym.h: Likewise.
122 lines
4.1 KiB
C
122 lines
4.1 KiB
C
/* BFD back-end for Apollo 68000 COFF binaries.
|
|
Copyright 1990, 1991, 1992, 1993, 1994, 1999, 2000, 2001, 2002, 2003,
|
|
2005, 2007, 2008, 2012 Free Software Foundation, Inc.
|
|
By Troy Rollo (troy@cbme.unsw.edu.au)
|
|
Based on m68k standard COFF version 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 "coff/apollo.h"
|
|
#include "coff/internal.h"
|
|
#include "libcoff.h"
|
|
|
|
#define COFF_DEFAULT_SECTION_ALIGNMENT_POWER (3)
|
|
|
|
#ifdef ONLY_DECLARE_RELOCS
|
|
extern reloc_howto_type apollocoff_howto_table[];
|
|
#else
|
|
reloc_howto_type apollocoff_howto_table[] =
|
|
{
|
|
HOWTO (R_RELBYTE, 0, 0, 8, FALSE, 0, complain_overflow_bitfield, 0, "8", TRUE, 0x000000ff,0x000000ff, FALSE),
|
|
HOWTO (R_RELWORD, 0, 1, 16, FALSE, 0, complain_overflow_bitfield, 0, "16", TRUE, 0x0000ffff,0x0000ffff, FALSE),
|
|
HOWTO (R_RELLONG, 0, 2, 32, FALSE, 0, complain_overflow_bitfield, 0, "32", TRUE, 0xffffffff,0xffffffff, FALSE),
|
|
HOWTO (R_PCRBYTE, 0, 0, 8, TRUE, 0, complain_overflow_signed, 0, "DISP8", TRUE, 0x000000ff,0x000000ff, FALSE),
|
|
HOWTO (R_PCRWORD, 0, 1, 16, TRUE, 0, complain_overflow_signed, 0, "DISP16", TRUE, 0x0000ffff,0x0000ffff, FALSE),
|
|
HOWTO (R_PCRLONG, 0, 2, 32, TRUE, 0, complain_overflow_signed, 0, "DISP32", TRUE, 0xffffffff,0xffffffff, FALSE),
|
|
HOWTO (R_RELLONG_NEG, 0, -2, 32, FALSE, 0, complain_overflow_bitfield, 0, "-32", TRUE, 0xffffffff,0xffffffff, FALSE),
|
|
};
|
|
#endif /* not ONLY_DECLARE_RELOCS */
|
|
|
|
#ifndef BADMAG
|
|
#define BADMAG(x) M68KBADMAG(x)
|
|
#endif
|
|
#define APOLLO_M68 1 /* Customize coffcode.h */
|
|
|
|
/* Turn a howto into a reloc number. */
|
|
|
|
extern void apollo_rtype2howto (arelent *, int);
|
|
extern int apollo_howto2rtype (reloc_howto_type *);
|
|
#ifndef ONLY_DECLARE_RELOCS
|
|
|
|
void
|
|
apollo_rtype2howto (arelent *internal, int relocentry)
|
|
{
|
|
switch (relocentry)
|
|
{
|
|
case R_RELBYTE: internal->howto = apollocoff_howto_table + 0; break;
|
|
case R_RELWORD: internal->howto = apollocoff_howto_table + 1; break;
|
|
case R_RELLONG: internal->howto = apollocoff_howto_table + 2; break;
|
|
case R_PCRBYTE: internal->howto = apollocoff_howto_table + 3; break;
|
|
case R_PCRWORD: internal->howto = apollocoff_howto_table + 4; break;
|
|
case R_PCRLONG: internal->howto = apollocoff_howto_table + 5; break;
|
|
case R_RELLONG_NEG: internal->howto = apollocoff_howto_table + 6; break;
|
|
}
|
|
}
|
|
|
|
int
|
|
apollo_howto2rtype (reloc_howto_type *internal)
|
|
{
|
|
if (internal->pc_relative)
|
|
{
|
|
switch (internal->bitsize)
|
|
{
|
|
case 32: return R_PCRLONG;
|
|
case 16: return R_PCRWORD;
|
|
case 8: return R_PCRBYTE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
switch (internal->bitsize)
|
|
{
|
|
case 32: return R_RELLONG;
|
|
case 16: return R_RELWORD;
|
|
case 8: return R_RELBYTE;
|
|
}
|
|
}
|
|
return R_RELLONG;
|
|
}
|
|
#endif /* not ONLY_DECLARE_RELOCS */
|
|
|
|
#define RTYPE2HOWTO(internal, relocentry) \
|
|
apollo_rtype2howto (internal, (relocentry)->r_type)
|
|
|
|
#define SELECT_RELOC(external, internal) \
|
|
external.r_type = apollo_howto2rtype (internal);
|
|
|
|
#define bfd_pe_print_pdata NULL
|
|
|
|
#include "coffcode.h"
|
|
|
|
#ifndef TARGET_SYM
|
|
#define TARGET_SYM apollocoff_vec
|
|
#endif
|
|
|
|
#ifndef TARGET_NAME
|
|
#define TARGET_NAME "apollo-m68k"
|
|
#endif
|
|
|
|
#ifdef NAMES_HAVE_UNDERSCORE
|
|
CREATE_BIG_COFF_TARGET_VEC (TARGET_SYM, TARGET_NAME, 0, 0, '_', NULL, COFF_SWAP_TABLE)
|
|
#else
|
|
CREATE_BIG_COFF_TARGET_VEC (TARGET_SYM, TARGET_NAME, 0, 0, 0, NULL, COFF_SWAP_TABLE)
|
|
#endif
|