NS32K changes from Ian Dall.
Note: Some of the ns32k-specific files do require gcc to compile at present. This will be fixed.
This commit is contained in:
parent
8e3ff82354
commit
1fb83be62b
9 changed files with 608 additions and 76 deletions
|
@ -1,3 +1,99 @@
|
|||
Thu Jul 14 15:12:24 1994 Ken Raeburn (raeburn@cujo.cygnus.com)
|
||||
|
||||
* reloc.c (enum bfd_reloc_code_real, bfd_type, struct
|
||||
reloc_howto_struct, reloc_howto_type, HOWTO, HOWTO2): Copied
|
||||
changes over from bfd-in2.h so they get generated properly next
|
||||
time someone runs "make headers".
|
||||
* bfd-in2.h: Rebuilt.
|
||||
|
||||
* targets.c (netbsd532_vec, pc532mach_vec): Declare const.
|
||||
(m88kmach3_vec): Restore deleted declaration.
|
||||
|
||||
* configure.in: Alphabetize target vector names.
|
||||
|
||||
* config/pc532mach.mh: New file.
|
||||
(HDEPFILES, HDEFINES): Define here.
|
||||
* config/pc532-mach.mt (HDEPFILES, HDEFINES): Deleted.
|
||||
* config/ns32k-netbsd.mt (HDEPFILES, HDEFINES): Deleted.
|
||||
|
||||
Sun Jul 10 00:04:20 1994 Ian Dall (dall@hfrd.dsto.gov.au)
|
||||
|
||||
* pc532-mach.c: New File. pc532-mach a.out format.
|
||||
|
||||
* netbsd532.c: New file. pc532-netbsd532 a.out format.
|
||||
|
||||
* hosts/pc532mach.h: New file. pc532-mach host support.
|
||||
|
||||
* cpu-ns32k.c: New file. ns32k support cpu specific code rather
|
||||
than format specific code.
|
||||
|
||||
* config/pc532-mach.mt: New file. Support for pc532-mach target.
|
||||
|
||||
* config/ns32k-netbsd.mt: New file. Support for netbsd532 target.
|
||||
|
||||
* aout-ns32k.c, aout-ns32k.h: New files supporting aout format for
|
||||
ns32k series.
|
||||
|
||||
* targets.c: Add netbsd532_vec and pc532machaout_vec into
|
||||
bfd_target_vector array. Move netbsd386_vec to alphabetic order
|
||||
location.
|
||||
|
||||
* reloc.c (_bfd_final_link_relocate) Add support for
|
||||
special_function1 in howto.
|
||||
|
||||
* libaout.h: add M_NS32032, M_NS32532, M_532_NETBSD entries in
|
||||
machine_type enum.
|
||||
|
||||
* configure.in: add pc532mach_vec and netbsd532_vec entries.
|
||||
|
||||
* config.bfd: add pc532mach host entries. Use for both
|
||||
ns32k-pc532-mach and ns32k-pc532-netbsd.
|
||||
|
||||
* config.bfd: it doesn't work to use i386-mach3 for ns32k*-*-mach.
|
||||
add ns32k-pc532-mach* and ns32k-*-netbsd* entries.
|
||||
|
||||
* bfd-in2.h: Add ns32k specific relocations to bfd_reloc_code_real
|
||||
enum.
|
||||
|
||||
* bfd-in2.h: Add special_function1 to struct howto. Change HOWTO
|
||||
and NEWHOWTO macros to make special_function1 NULL. Neww HOWTO2
|
||||
macro.
|
||||
|
||||
* bfd-in2.h: Split definition of struct reloc_howto_struct
|
||||
and corresponding typedef into two statements.
|
||||
|
||||
* bfd-in2.h: Add entry bfd_arch_ns32k to bfd_architecture enum.
|
||||
|
||||
* archures.c: Add bfd_ns32k_arch prototype, and entry in
|
||||
archures_init_table.
|
||||
|
||||
* aoutx.h (aout_link_reloc_link_order): Allow for target dependent
|
||||
MY_put_reloc macro. Allow for target dependent special_function1
|
||||
to apply the relocation.
|
||||
|
||||
* aoutx.h (aout_link_input_section_std): Allow for target
|
||||
dependent determination of reloc howto. Allow for target dependent
|
||||
special_function1 to apply the relocation.
|
||||
|
||||
* aoutx.h (get_reloc_upper_bound): Detect bss and return 0.
|
||||
|
||||
* aoutx.h (slurp_reloc_table): Detect bss and succesfully read
|
||||
zero reloc entries.
|
||||
|
||||
* aoutx.h (machine_type): Add bfd_arch_ns32k case.
|
||||
|
||||
* aoutx.h: Stat to determine executable status if STAT_FOR_EXEC
|
||||
is defined (not just MACH). Use fstat instead of stat and check
|
||||
for fstat error.
|
||||
|
||||
* aoutx.h: Allow target dependent swap_std_reloc_{in,out}.
|
||||
|
||||
* aoutx.h: Allow CTORS reloc info to be in target dependent reloc
|
||||
table.
|
||||
|
||||
* aout-target.h: Apply SWAP_MAGIC (if defined) after
|
||||
swap_exec_header_in, otherwise we have magic in the wrong order.
|
||||
|
||||
Thu Jul 14 11:47:27 1994 Stan Shebs (shebs@andros.cygnus.com)
|
||||
|
||||
* coff-sparc.c (sparccoff_vec): Have leading underscores.
|
||||
|
|
17
bfd/aout-ns32k.h
Normal file
17
bfd/aout-ns32k.h
Normal file
|
@ -0,0 +1,17 @@
|
|||
/* Written by Ian Dall
|
||||
* 5-Jun-94
|
||||
*/
|
||||
#define MYNS(OP) CAT(ns32kaout_,OP)
|
||||
CONST struct reloc_howto_struct *
|
||||
MYNS(bfd_reloc_type_lookup)
|
||||
PARAMS((bfd *abfd AND
|
||||
bfd_reloc_code_real_type code));
|
||||
|
||||
boolean
|
||||
MYNS(write_object_contents)
|
||||
PARAMS((bfd *abfd));
|
||||
|
||||
/* Avoid multiple definitions from aoutx if supporting standard a.out format(s)
|
||||
* as well as this one
|
||||
*/
|
||||
#define NAME(x,y) CAT3(ns32kaout, _32_, y)
|
|
@ -748,7 +748,7 @@ typedef struct sec
|
|||
multiple times, the value of a symbol is the amount of
|
||||
space it requires, and the largest symbol value is the one
|
||||
used). Most targets have exactly one of these (which we
|
||||
translate to bfd_com_section), but ECOFF has two. */
|
||||
translate to bfd_com_section_ptr), but ECOFF has two. */
|
||||
#define SEC_IS_COMMON 0x8000
|
||||
|
||||
/* The section contains only debugging information. For
|
||||
|
@ -883,28 +883,36 @@ typedef struct sec
|
|||
struct bfd_link_order *link_order_tail;
|
||||
} asection ;
|
||||
|
||||
|
||||
/* These sections are global, and are managed by BFD. The application
|
||||
and target back end are not permitted to change the values in
|
||||
these sections. */
|
||||
these sections. New code should use the section_ptr macros rather
|
||||
than referring directly to the const sections. The const sections
|
||||
may eventually vanish. */
|
||||
#define BFD_ABS_SECTION_NAME "*ABS*"
|
||||
#define BFD_UND_SECTION_NAME "*UND*"
|
||||
#define BFD_COM_SECTION_NAME "*COM*"
|
||||
#define BFD_IND_SECTION_NAME "*IND*"
|
||||
|
||||
/* the absolute section */
|
||||
extern asection bfd_abs_section;
|
||||
extern const asection bfd_abs_section;
|
||||
#define bfd_abs_section_ptr ((asection *) &bfd_abs_section)
|
||||
#define bfd_is_abs_section(sec) ((sec) == bfd_abs_section_ptr)
|
||||
/* Pointer to the undefined section */
|
||||
extern asection bfd_und_section;
|
||||
extern const asection bfd_und_section;
|
||||
#define bfd_und_section_ptr ((asection *) &bfd_und_section)
|
||||
#define bfd_is_und_section(sec) ((sec) == bfd_und_section_ptr)
|
||||
/* Pointer to the common section */
|
||||
extern asection bfd_com_section;
|
||||
extern const asection bfd_com_section;
|
||||
#define bfd_com_section_ptr ((asection *) &bfd_com_section)
|
||||
/* Pointer to the indirect section */
|
||||
extern asection bfd_ind_section;
|
||||
extern const asection bfd_ind_section;
|
||||
#define bfd_ind_section_ptr ((asection *) &bfd_ind_section)
|
||||
#define bfd_is_ind_section(sec) ((sec) == bfd_ind_section_ptr)
|
||||
|
||||
extern struct symbol_cache_entry *bfd_abs_symbol;
|
||||
extern struct symbol_cache_entry *bfd_com_symbol;
|
||||
extern struct symbol_cache_entry *bfd_und_symbol;
|
||||
extern struct symbol_cache_entry *bfd_ind_symbol;
|
||||
extern const struct symbol_cache_entry * const bfd_abs_symbol;
|
||||
extern const struct symbol_cache_entry * const bfd_com_symbol;
|
||||
extern const struct symbol_cache_entry * const bfd_und_symbol;
|
||||
extern const struct symbol_cache_entry * const bfd_ind_symbol;
|
||||
#define bfd_get_section_size_before_reloc(section) \
|
||||
(section->reloc_done ? (abort(),1): (section)->_raw_size)
|
||||
#define bfd_get_section_size_after_reloc(section) \
|
||||
|
@ -999,6 +1007,7 @@ enum bfd_architecture
|
|||
bfd_arch_h8500, /* Hitachi H8/500 */
|
||||
bfd_arch_sh, /* Hitachi SH */
|
||||
bfd_arch_alpha, /* Dec Alpha */
|
||||
bfd_arch_ns32k, /* National Semiconductors ns32000 */
|
||||
bfd_arch_last
|
||||
};
|
||||
|
||||
|
@ -1133,7 +1142,9 @@ enum complain_overflow
|
|||
complain_overflow_unsigned
|
||||
};
|
||||
|
||||
typedef struct reloc_howto_struct
|
||||
typedef unsigned char bfd_byte;
|
||||
|
||||
struct reloc_howto_struct
|
||||
{
|
||||
/* The type field has mainly a documetary use - the back end can
|
||||
do what it wants with it, though normally the back end's
|
||||
|
@ -1183,6 +1194,17 @@ typedef struct reloc_howto_struct
|
|||
bfd *output_bfd,
|
||||
char **error_message));
|
||||
|
||||
|
||||
/* If this field is non null, then the supplied function is
|
||||
called rather than the normal function. This is similar
|
||||
to special_function (previous), but takes different arguments,
|
||||
and is used for the new linking code. */
|
||||
bfd_reloc_status_type (*special_function1)
|
||||
PARAMS((const reloc_howto_type *howto,
|
||||
bfd *input_bfd,
|
||||
bfd_vma relocation,
|
||||
bfd_byte *location));
|
||||
|
||||
/* The textual name of the relocation type. */
|
||||
char *name;
|
||||
|
||||
|
@ -1213,9 +1235,12 @@ typedef struct reloc_howto_struct
|
|||
empty (e.g., m88k bcs); this flag signals the fact.*/
|
||||
boolean pcrel_offset;
|
||||
|
||||
} reloc_howto_type;
|
||||
};
|
||||
typedef struct reloc_howto_struct reloc_howto_type;
|
||||
#define HOWTO(C, R,S,B, P, BI, O, SF, NAME, INPLACE, MASKSRC, MASKDST, PC) \
|
||||
{(unsigned)C,R,S,B, P, BI, O,SF,NAME,INPLACE,MASKSRC,MASKDST,PC}
|
||||
{(unsigned)C,R,S,B, P, BI, O,SF, 0,NAME,INPLACE,MASKSRC,MASKDST,PC}
|
||||
#define HOWTO2(C, R,S,B, P, BI, O, SF, SF1,NAME, INPLACE, MASKSRC, MASKDST, PC) \
|
||||
{(unsigned)C,R,S,B, P, BI, O,SF, SF1,NAME,INPLACE,MASKSRC,MASKDST,PC}
|
||||
#define NEWHOWTO( FUNCTION, NAME,SIZE,REL,IN) HOWTO(0,0,SIZE,0,REL,0,complain_overflow_dont,FUNCTION, NAME,false,0,0,IN)
|
||||
|
||||
#define HOWTO_PREPARE(relocation, symbol) \
|
||||
|
@ -1232,8 +1257,6 @@ typedef struct reloc_howto_struct
|
|||
int
|
||||
bfd_get_reloc_size PARAMS ((const reloc_howto_type *));
|
||||
|
||||
typedef unsigned char bfd_byte;
|
||||
|
||||
typedef struct relent_chain {
|
||||
arelent relent;
|
||||
struct relent_chain *next;
|
||||
|
@ -1418,6 +1441,20 @@ typedef enum bfd_reloc_code_real
|
|||
BFD_RELOC_386_GOTOFF,
|
||||
BFD_RELOC_386_GOTPC,
|
||||
|
||||
/* ns32k relocations */
|
||||
BFD_RELOC_NS32K_IMM_8,
|
||||
BFD_RELOC_NS32K_IMM_16,
|
||||
BFD_RELOC_NS32K_IMM_32,
|
||||
BFD_RELOC_NS32K_IMM_8_PCREL,
|
||||
BFD_RELOC_NS32K_IMM_16_PCREL,
|
||||
BFD_RELOC_NS32K_IMM_32_PCREL,
|
||||
BFD_RELOC_NS32K_DISP_8,
|
||||
BFD_RELOC_NS32K_DISP_16,
|
||||
BFD_RELOC_NS32K_DISP_32,
|
||||
BFD_RELOC_NS32K_DISP_8_PCREL,
|
||||
BFD_RELOC_NS32K_DISP_16_PCREL,
|
||||
BFD_RELOC_NS32K_DISP_32_PCREL,
|
||||
|
||||
/* PowerPC/POWER (RS/6000) relocs. */
|
||||
/* 26 bit relative branch. Low two bits must be zero. High 24
|
||||
bits installed in bits 6 through 29 of instruction. */
|
||||
|
|
115
bfd/config.bfd
115
bfd/config.bfd
|
@ -4,10 +4,19 @@
|
|||
# Convert a canonical host type into a BFD host type.
|
||||
# Call with canonical name as the argument.
|
||||
# Echos the result.
|
||||
# If second argument is _, echoes whether underscores are stripped.
|
||||
|
||||
canon="$1"
|
||||
cpu=`echo $canon | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'`
|
||||
|
||||
# The binutils c++filt program wants to know whether underscores are
|
||||
# stripped or not. It uses this information to choose a default.
|
||||
# This information is duplicated in the symbol_leading_char field of
|
||||
# the BFD target vector, but c++filt does not deal with object files
|
||||
# and is not linked against libbfd.a. It is not terribly important
|
||||
# that c++filt get this right; it is just convenient.
|
||||
strip_underscore=no
|
||||
|
||||
# WHEN ADDING ENTRIES TO THIS MATRIX:
|
||||
# Make sure that the left side always has two dashes. Otherwise you
|
||||
# can get spurious matches. Even for unambiguous cases, do this as a
|
||||
|
@ -16,14 +25,14 @@ cpu=`echo $canon | sed 's/^\(.*\)-\(.*\)-\(.*\)$/\1/'`
|
|||
case "${canon}" in
|
||||
alpha-*-netware*) bfd_name=alpha-nlm ;;
|
||||
alpha-*-*) bfd_name=alphaosf ;;
|
||||
a29k-*-ebmon*) bfd_name=a29k-coff ;;
|
||||
a29k-*-udi*) bfd_name=a29k-coff ;;
|
||||
a29k-*-aout*) bfd_name=a29k-aout ;;
|
||||
a29k-*-coff*) bfd_name=a29k-coff ;;
|
||||
a29k-*-sym1*) bfd_name=a29k-coff ;;
|
||||
h8300*-*-*) bfd_name=h8300-coff ;;
|
||||
h8500-*-*) bfd_name=h8500-coff ;;
|
||||
sh-*-*) bfd_name=sh-coff ;;
|
||||
a29k-*-ebmon*) bfd_name=a29k-coff strip_underscore=yes ;;
|
||||
a29k-*-udi*) bfd_name=a29k-coff strip_underscore=yes ;;
|
||||
a29k-*-aout*) bfd_name=a29k-aout strip_underscore=yes ;;
|
||||
a29k-*-coff*) bfd_name=a29k-coff strip_underscore=yes ;;
|
||||
a29k-*-sym1*) bfd_name=a29k-coff strip_underscore=yes ;;
|
||||
h8300*-*-*) bfd_name=h8300-coff strip_underscore=yes ;;
|
||||
h8500-*-*) bfd_name=h8500-coff strip_underscore=yes ;;
|
||||
sh-*-*) bfd_name=sh-coff strip_underscore=yes ;;
|
||||
hppa*-*-*elf*) bfd_name=hppa-elf ;;
|
||||
hppa*-*-bsd*) bfd_name=hppabsd ;;
|
||||
hppa*-*-hpux*) bfd_name=hppahpux ;;
|
||||
|
@ -35,95 +44,99 @@ case "${canon}" in
|
|||
i[34]86-*-sysv*) bfd_name=i386-coff ;;
|
||||
i[34]86-*-isc*) bfd_name=i386-coff ;;
|
||||
i[34]86-*-sco*) bfd_name=i386-coff ;;
|
||||
i[34]86-sequent-bsd*) bfd_name=i386-dynix ;;
|
||||
i[34]86-*-bsd*) bfd_name=i386-bsd ;;
|
||||
i[34]86-sequent-bsd*) bfd_name=i386-dynix strip_underscore=yes ;;
|
||||
i[34]86-*-bsd*) bfd_name=i386-bsd strip_underscore=yes ;;
|
||||
i[34]86-*-coff) bfd_name=i386-coff ;;
|
||||
i[34]86-*-aix*) bfd_name=i386-coff ;;
|
||||
i[34]86-*-elf) bfd_name=i386-elf ;;
|
||||
i[34]86-*-netbsd*) bfd_name=i386-netbsd ;;
|
||||
i[34]86-*-netbsd*) bfd_name=i386-netbsd strip_underscore=yes ;;
|
||||
i[34]86-*-netware*) bfd_name=i386-nlm ;;
|
||||
i[34]86-*-linux*) bfd_name=i386-linux ;;
|
||||
i[34]86-*-linux*) bfd_name=i386-linux strip_underscore=yes ;;
|
||||
i[34]86-*-lynxos*) bfd_name=i386-lynx ;;
|
||||
i[34]86-*-gnu*) bfd_name=i386-mach3 ;;
|
||||
i[34]86-*-mach*) bfd_name=i386-mach3 ;;
|
||||
i[34]86-*-osf1mk*) bfd_name=i386-mach3 ;;
|
||||
i[34]86-*-os9k) bfd_name=i386-os9k;;
|
||||
i[34]86-*-gnu*) bfd_name=i386-mach3 strip_underscore=yes ;;
|
||||
i[34]86-*-mach*) bfd_name=i386-mach3 strip_underscore=yes ;;
|
||||
i[34]86-*-osf1mk*) bfd_name=i386-mach3 strip_underscore=yes ;;
|
||||
i[34]86-*-os9k) bfd_name=i386-os9k ;;
|
||||
i[34]86-none-*) bfd_name=i386-coff ;;
|
||||
i960-*-vxworks4*) bfd_name=i960-bout ;;
|
||||
i960-*-vxworks5.0) bfd_name=i960-bout ;;
|
||||
i960-*-vxworks5.*) bfd_name=i960-coff ;;
|
||||
i960-*-vxworks*) bfd_name=i960-bout ;;
|
||||
i960-*-aout*) bfd_name=i960-bout ;;
|
||||
i960-*-bout*) bfd_name=i960-bout ;;
|
||||
i960-*-coff*) bfd_name=i960-coff ;;
|
||||
i960-*-nindy*) bfd_name=i960-bout ;;
|
||||
i960-*-vxworks4*) bfd_name=i960-bout strip_underscore=yes ;;
|
||||
i960-*-vxworks5.0) bfd_name=i960-bout strip_underscore=yes ;;
|
||||
i960-*-vxworks5.*) bfd_name=i960-coff strip_underscore=yes ;;
|
||||
i960-*-vxworks*) bfd_name=i960-bout strip_underscore=yes ;;
|
||||
i960-*-aout*) bfd_name=i960-bout strip_underscore=yes ;;
|
||||
i960-*-bout*) bfd_name=i960-bout strip_underscore=yes ;;
|
||||
i960-*-coff*) bfd_name=i960-coff strip_underscore=yes ;;
|
||||
i960-*-nindy*) bfd_name=i960-bout strip_underscore=yes ;;
|
||||
m68*-apollo-*) bfd_name=apollo ;;
|
||||
m68*-bull-sysv*) bfd_name=u68k-coff ;;
|
||||
m68*-hp-bsd*) bfd_name=hp300bsd ;;
|
||||
m68*-*-aout*) bfd_name=m68k-0aout ;;
|
||||
m68*-hp-bsd*) bfd_name=hp300bsd strip_underscore=yes ;;
|
||||
m68*-*-aout*) bfd_name=m68k-0aout strip_underscore=yes ;;
|
||||
m68*-*-coff*) bfd_name=m68k-coff ;;
|
||||
m68*-*-hpux*) bfd_name=hp300hpux ;;
|
||||
m68*-*-hpux*) bfd_name=hp300hpux strip_underscore=yes ;;
|
||||
m68*-*-lynxos*) bfd_name=m68k-lynx ;;
|
||||
m68*-*-os68k*) bfd_name=m68k-aout ;;
|
||||
m68*-*-sunos*) bfd_name=m68k-aout ;;
|
||||
m68*-*-os68k*) bfd_name=m68k-aout strip_underscore=yes ;;
|
||||
m68*-*-sunos*) bfd_name=m68k-aout strip_underscore=yes ;;
|
||||
m68*-*-sysv4*) bfd_name=m68k-elf ;;
|
||||
m68*-*-sysv*) bfd_name=m68k-coff ;;
|
||||
m68*-*-vxworks*) bfd_name=m68k-aout ;;
|
||||
m68*-ericsson-*) bfd_name=m68k-ose ;;
|
||||
m68*-netx-*) bfd_name=m68k-aout ;;
|
||||
m68*-*-vxworks*) bfd_name=m68k-aout strip_underscore=yes ;;
|
||||
m68*-ericsson-*) bfd_name=m68k-ose strip_underscore=yes ;;
|
||||
m68*-netx-*) bfd_name=m68k-aout strip_underscore=yes ;;
|
||||
|
||||
m88*-*-sysv4*) bfd_name=m88k-elf ;;
|
||||
# DGUX used to use COFF, but now (Jan 94) I believe it uses ELF by default.
|
||||
m88*-*-dgux*) bfd_name=m88k-elf ;;
|
||||
m88*-*-*) bfd_name=m88k-coff ;;
|
||||
m88*-*-mach3*) bfd_name=m88k-mach3 ;;
|
||||
m88*-*-sysv4*) bfd_name=m88k-elf ;;
|
||||
m88*-*-*) bfd_name=m88k-coff strip_underscore=yes ;;
|
||||
|
||||
mips*-big-*) bfd_name=bigmips ;;
|
||||
mips*-dec-bsd*) bfd_name=mipsdecbsd ;;
|
||||
mips*-dec-bsd*) bfd_name=mipsdecbsd strip_underscore=yes ;;
|
||||
mips*-dec-mach3*) bfd_name=mips-mach3 ;;
|
||||
mips*-dec-*) bfd_name=decstation ;;
|
||||
mips*el-*-ecoff*) bfd_name=decstation ;;
|
||||
mips*-*-ecoff*) bfd_name=bigmips ;;
|
||||
mips*-*-irix5*) bfd_name=mipsbelf ;;
|
||||
mips*-sgi-*) bfd_name=bigmips ;;
|
||||
mips*-*-mach3*) bfd_name=mips-mach3 ;;
|
||||
mips*-*-sysv4*) bfd_name=mipsbelf ;;
|
||||
mips*-*-sysv*) bfd_name=riscos ;;
|
||||
mips*-*-riscos*) bfd_name=riscos ;;
|
||||
mips*-*-bsd*) bfd_name=bigmips ;; # Sony News
|
||||
mips*el-*-elf*) bfd_name=mipslelf ;;
|
||||
mips*-*-elf*) bfd_name=mipsbelf ;;
|
||||
# Apparently this is similar enough to 386 mach to use the same target.
|
||||
ns32*-*-mach*) bfd_name=i386-mach3 ;;
|
||||
ns32k-pc532-mach*) bfd_name=pc532-mach strip_underscore=yes;;
|
||||
ns32k-*-netbsd*) bfd_name=ns32k-netbsd strip_underscore=yes;;
|
||||
powerpc-*-aix*) bfd_name=rs6000 ;;
|
||||
powerpc-*-elf*) bfd_name=ppc-elf ;;
|
||||
powerpc-*-sysv4*) bfd_name=ppc-elf ;;
|
||||
powerpc-*-netware*) bfd_name=ppc-nlm ;;
|
||||
rs6000-*-*) bfd_name=rs6000 ;;
|
||||
sparc-*-lynxos*) bfd_name=sparc-lynx ;;
|
||||
sparc-*-solaris2*) bfd_name=sparc-elf ;;
|
||||
sparc-*-sysv4*) bfd_name=sparc-elf ;;
|
||||
sparc64-*-aout*) bfd_name=sparc-aout ;;
|
||||
sparc64-*-aout*) bfd_name=sparc-aout strip_underscore=yes ;;
|
||||
sparc64-*-elf*) bfd_name=sparc64-elf ;;
|
||||
sparc-*-netware*) bfd_name=sparc-nlm ;;
|
||||
sparc*-*-coff*) bfd_name=sparc-coff ;;
|
||||
sparc*-*-*) bfd_name=sparc-aout ;;
|
||||
tahoe-*-*) bfd_name=tahoe ;;
|
||||
sparc*-*-*) bfd_name=sparc-aout strip_underscore=yes ;;
|
||||
tahoe-*-*) bfd_name=tahoe strip_underscore=yes ;;
|
||||
vax-*-vms*) bfd_name=vax-vms ;;
|
||||
vax-*-*) bfd_name=vax ;;
|
||||
vax-*-*) bfd_name=vax strip_underscore=yes ;;
|
||||
we32k-*-*) bfd_name=we32k ;;
|
||||
z8k*-*-*) bfd_name=z8k-coff ;;
|
||||
z8k*-*-*) bfd_name=z8k-coff strip_underscore=yes ;;
|
||||
|
||||
*-*-aout*) bfd_name=${cpu}-aout ;;
|
||||
*-*-bsd*) bfd_name=${cpu}-aout ;;
|
||||
*-*-aout*) bfd_name=${cpu}-aout strip_underscore=yes ;;
|
||||
*-*-bsd*) bfd_name=${cpu}-aout strip_underscore=yes ;;
|
||||
*-*-netware*) bfd_name=${cpu}-nlm ;;
|
||||
*-*-sysv4*) bfd_name=${cpu}-elf ;;
|
||||
*-*-solaris2*) bfd_name=${cpu}-elf ;;
|
||||
*-*-vsta*) bfd_name=${cpu}-aout ;;
|
||||
*-*-vsta*) bfd_name=${cpu}-aout strip_underscore=yes ;;
|
||||
*-*-go32*) bfd_name=${cpu}-coff ;;
|
||||
*-*-sysv*) bfd_name=${cpu}-coff ;;
|
||||
|
||||
*-*-aout64*) bfd_name=${cpu}-aout64 ;;
|
||||
*-*-aout64*) bfd_name=${cpu}-aout64 strip_underscore=yes ;;
|
||||
*-*-elf64*) bfd_name=${cpu}-elf64 ;;
|
||||
|
||||
*-adobe-*) bfd_name=adobe ;;
|
||||
*-sony-*) bfd_name=news ;;
|
||||
*-adobe-*) bfd_name=adobe strip_underscore=yes ;;
|
||||
*-sony-*) bfd_name=news strip_underscore=yes ;;
|
||||
*-intel-*) bfd_name=${cpu}-coff ;;
|
||||
*-stratus-*) bfd_name=${cpu}-elf ;;
|
||||
*-cbm-*) bfd_name=${cpu}-elf ;;
|
||||
|
@ -134,4 +147,8 @@ case "${canon}" in
|
|||
*) bfd_name=$canon ;;
|
||||
esac
|
||||
|
||||
echo $bfd_name
|
||||
if [ "x$2" = "x_" ]; then
|
||||
echo $strip_underscore
|
||||
else
|
||||
echo $bfd_name
|
||||
fi
|
||||
|
|
|
@ -37,7 +37,7 @@ i[34]86-*-sysv4*) my_host=i386v4 ;;
|
|||
i[34]86-*-sysv*) my_host=i386v ;;
|
||||
i[34]86-*-solaris*) my_host=i386v ;;
|
||||
i[34]86-*-sco*) my_host=i386sco ;;
|
||||
i[34]86-*-mach*) my_host=i386mach3 ;;
|
||||
i[34]86-*-mach3*) my_host=i386mach3 ;;
|
||||
i[34]86-*-osf1mk*) my_host=i386osf1mk ;;
|
||||
i[34]86-*-msdos*) my_host=dose ;;
|
||||
i[34]86-*-linux*) my_host=i386linux ;;
|
||||
|
@ -48,10 +48,13 @@ i[34]86-*-aix*) my_host=i386aix ;;
|
|||
i860-*-*) my_host=stratus ;;
|
||||
|
||||
mips-dec-bsd*) my_host=mipsbsd ;;
|
||||
mips-dec-mach3*) my_host=mipsmach3 ;;
|
||||
mips-dec-*) my_host=decstation ;;
|
||||
mips-sgi-irix3*) my_host=irix3 ;;
|
||||
mips-sgi-irix4*) my_host=irix4 ;;
|
||||
mips-sgi-irix5*) my_host=irix5 ;;
|
||||
mips-*-mach3*) my_host=mipsmach3 ;;
|
||||
mips-*-sysv4*) my_host=sysv4 ;;
|
||||
mips-*-sysv*) my_host=riscos ;;
|
||||
mips-*-riscos*) my_host=riscos ;;
|
||||
mips-sony-bsd*) my_host=news-mips ;;
|
||||
|
@ -73,9 +76,10 @@ m88*-*-sysv4*) my_host=delta88v4 ;;
|
|||
m88*-motorola-sysv*) my_host=delta88 ;;
|
||||
m88*-harris-*) my_host=harris ;;
|
||||
m88*-*-dgux*) my_host=dgux ;;
|
||||
m88*-*-mach3*) my_host=m88kmach3 ;;
|
||||
|
||||
# Apparently the same config file as for 386 works.
|
||||
ns32k-*-mach*) my_host=i386mach3 ;;
|
||||
ns32k-pc532-mach) my_host=pc532mach ;;
|
||||
ns32k-pc532-netbsd*) my_host=pc532mach ;;
|
||||
|
||||
romp-*-*) my_host=rtbsd ;;
|
||||
|
||||
|
|
34
bfd/hosts/pc532mach.h
Normal file
34
bfd/hosts/pc532mach.h
Normal file
|
@ -0,0 +1,34 @@
|
|||
#include "hosts/std-host.h"
|
||||
|
||||
#include <machine/vmparam.h>
|
||||
#include <sys/param.h>
|
||||
#undef BYTE_SIZE /* Was in bits. We define it later in bytes */
|
||||
|
||||
/* This is an ugly way to hack around the incorrect
|
||||
* definition of UPAGES in ns532/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 ns532, i386 and i860. UPAGES is used only in trad-core.c.
|
||||
*/
|
||||
#if UPAGES == 16
|
||||
#undef UPAGES
|
||||
#define UPAGES 2
|
||||
#endif
|
||||
|
||||
#if UPAGES != 2
|
||||
#error UPAGES is neither 2 nor 16
|
||||
#endif
|
||||
|
||||
#define HAVE_STRERROR
|
||||
|
||||
#define HOST_PAGE_SIZE 1
|
||||
#define HOST_SEGMENT_SIZE NBPG
|
||||
#define HOST_MACHINE_ARCH bfd_arch_ns32k
|
||||
#define HOST_TEXT_START_ADDR USRTEXT
|
||||
#define HOST_STACK_END_ADDR USRSTACK
|
||||
|
||||
/* Not declared in errno.h on Mach3. */
|
||||
|
||||
extern int errno;
|
189
bfd/netbsd532.c
Normal file
189
bfd/netbsd532.c
Normal file
|
@ -0,0 +1,189 @@
|
|||
/* BFD back-end for NetBSD/532 a.out-ish binaries.
|
||||
Copyright (C) 1990, 1991, 1992 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 2 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., 675 Mass Ave, Cambridge, MA 02139, USA. */
|
||||
/*
|
||||
* Created by Ian Dall
|
||||
* 5-Jun-94
|
||||
*
|
||||
* Largely a copy of netbsd386.c plus some code from aout-pc532-mach.c
|
||||
*/
|
||||
|
||||
#define BYTES_IN_WORD 4
|
||||
#define ARCH 32
|
||||
|
||||
/* ZMAGIC files never include the header in the text. */
|
||||
#define N_HEADER_IN_TEXT(x) 1
|
||||
|
||||
#define PAGE_SIZE 0x1000
|
||||
|
||||
/* ZMAGIC files start at address 0. This does not apply to QMAGIC. */
|
||||
#define TEXT_START_ADDR PAGE_SIZE
|
||||
#define N_SHARED_LIB(x) 0
|
||||
|
||||
/* Use a_entry of 0 to distinguish object files from OMAGIC executables */
|
||||
#define N_TXTADDR(x) \
|
||||
((N_MAGIC(x) == OMAGIC) && \
|
||||
((x).a_entry < TEXT_START_ADDR) ? 0 : /* object file or NMAGIC */\
|
||||
N_SHARED_LIB(x) ? 0 : \
|
||||
N_HEADER_IN_TEXT(x) ? \
|
||||
TEXT_START_ADDR + EXEC_BYTES_SIZE : /* no padding */\
|
||||
TEXT_START_ADDR /* a page of padding */\
|
||||
)
|
||||
|
||||
#define SEGMENT_SIZE PAGE_SIZE
|
||||
|
||||
#define DEFAULT_ARCH bfd_arch_ns32k
|
||||
|
||||
#define MY(OP) CAT(netbsd532_,OP)
|
||||
/* This needs to start with a.out so GDB knows it is an a.out variant. */
|
||||
#define TARGETNAME "a.out-netbsd-532"
|
||||
#define MACHTYPE_OK(mtype) ((mtype) == M_532_NETBSD)
|
||||
|
||||
#define N_MAGIC(ex) \
|
||||
( (((ex).a_info)&0xffff0000) ? ((((ex).a_info))&0xffff) : ((ex).a_info))
|
||||
#define N_MACHTYPE(ex) \
|
||||
( (((ex).a_info)&0xffff0000) ? (((((ex).a_info))>>16)&0x03ff) : 0 )
|
||||
#define N_FLAGS(ex) \
|
||||
( (((ex).a_info)&0xffff0000) ? ((((ex).a_info)>>26)&0x3f) : 0 )
|
||||
#define N_SET_INFO(ex, mag,mid,flag) \
|
||||
( (ex).a_info = htonl( (((flag)&0x3f)<<26) | (((mid)&0x03ff)<<16) | \
|
||||
(((mag)&0xffff)) ) )
|
||||
#define N_SET_MAGIC(exec,magic) \
|
||||
((exec).a_info = (((exec).a_info & ~0xffff) | ((magic) & 0xffff)))
|
||||
#define N_SET_MACHTYPE(exec,machtype) \
|
||||
((exec).a_info = \
|
||||
(((exec).a_info & ~(0x3ff<<16)) | (((machtype)&0xff) << 16)))
|
||||
#define N_SET_FLAGS(exec, flags) \
|
||||
((exec).a_info = \
|
||||
(((exec).a_info & ~(0x3f<<26)) | (((flags)&0x3f) << 26)))
|
||||
|
||||
#define N_MAG(MAG) ((MAG) == o_magic? OMAGIC: ((MAG) == z_magic? ZMAGIC: ((MAG) == n_magic? NMAGIC: 0)))
|
||||
|
||||
#define WRITE_HEADERS(abfd, execp) \
|
||||
{ \
|
||||
bfd_size_type text_size; /* dummy vars */ \
|
||||
int mag; \
|
||||
file_ptr text_end; \
|
||||
if (adata(abfd).magic == undecided_magic) \
|
||||
NAME(aout,adjust_sizes_and_vmas) (abfd, &text_size, &text_end); \
|
||||
mag = adata(abfd).magic; \
|
||||
N_SET_INFO(*execp, N_MAG(mag), M_532_NETBSD, aout_backend_info (abfd)->exec_hdr_flags); \
|
||||
\
|
||||
execp->a_syms = bfd_get_symcount (abfd) * EXTERNAL_NLIST_SIZE; \
|
||||
execp->a_entry = bfd_get_start_address (abfd); \
|
||||
\
|
||||
execp->a_trsize = ((obj_textsec (abfd)->reloc_count) * \
|
||||
obj_reloc_entry_size (abfd)); \
|
||||
execp->a_drsize = ((obj_datasec (abfd)->reloc_count) * \
|
||||
obj_reloc_entry_size (abfd)); \
|
||||
NAME(aout,swap_exec_header_out) (abfd, execp, &exec_bytes); \
|
||||
\
|
||||
if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0) return false; \
|
||||
if (bfd_write ((PTR) &exec_bytes, 1, EXEC_BYTES_SIZE, abfd) \
|
||||
!= EXEC_BYTES_SIZE) \
|
||||
return false; \
|
||||
/* Now write out reloc info, followed by syms and strings */ \
|
||||
\
|
||||
if (bfd_get_outsymbols (abfd) != (asymbol **) NULL \
|
||||
&& bfd_get_symcount (abfd) != 0) \
|
||||
{ \
|
||||
if (bfd_seek (abfd, (file_ptr)(N_SYMOFF(*execp)), SEEK_SET) \
|
||||
!= 0) \
|
||||
return false; \
|
||||
\
|
||||
if (! NAME(aout,write_syms)(abfd)) return false; \
|
||||
\
|
||||
if (bfd_seek (abfd, (file_ptr)(N_TRELOFF(*execp)), SEEK_SET) \
|
||||
!= 0) \
|
||||
return false; \
|
||||
\
|
||||
if (!NAME(aout,squirt_out_relocs) (abfd, obj_textsec (abfd))) \
|
||||
return false; \
|
||||
if (bfd_seek (abfd, (file_ptr)(N_DRELOFF(*execp)), SEEK_SET) \
|
||||
!= 0) \
|
||||
return false; \
|
||||
\
|
||||
if (!NAME(aout,squirt_out_relocs)(abfd, obj_datasec (abfd))) \
|
||||
return false; \
|
||||
} \
|
||||
}
|
||||
|
||||
|
||||
#include "bfd.h"
|
||||
#include "sysdep.h"
|
||||
#include "aout-ns32k.h"
|
||||
#include "libbfd.h"
|
||||
#include "libaout.h"
|
||||
|
||||
|
||||
/* On NetBSD, the magic number is always in ntohl's "network" (big-endian)
|
||||
format. */
|
||||
#define SWAP_MAGIC(ext) bfd_getb32 (ext)
|
||||
|
||||
#include "aout/aout64.h"
|
||||
|
||||
/* Forward declaration. Defined in aout-target.h */
|
||||
static boolean MY(set_sizes)();
|
||||
|
||||
static CONST struct aout_backend_data MY(backend_data) = {
|
||||
0, /* zmagic contiguous */
|
||||
1, /* text incl header */
|
||||
0,
|
||||
0, /* text vma? */
|
||||
MY(set_sizes),
|
||||
0, /* exec header is counted */
|
||||
};
|
||||
|
||||
#define MY_backend_data &MY(backend_data)
|
||||
|
||||
|
||||
/* We can`t use the MYNS macro here for cpp reasons too subtle
|
||||
* for me -- IWD
|
||||
*/
|
||||
#define MY_bfd_reloc_type_lookup ns32kaout_bfd_reloc_type_lookup
|
||||
|
||||
/* libaout doesn't use NAME for these ... */
|
||||
#define MY_get_section_contents aout_32_get_section_contents
|
||||
|
||||
static boolean
|
||||
MY(write_object_contents) (abfd)
|
||||
bfd *abfd;
|
||||
{
|
||||
struct external_exec exec_bytes;
|
||||
struct internal_exec *execp = exec_hdr (abfd);
|
||||
|
||||
#if CHOOSE_RELOC_SIZE
|
||||
CHOOSE_RELOC_SIZE(abfd);
|
||||
#else
|
||||
obj_reloc_entry_size (abfd) = RELOC_STD_SIZE;
|
||||
#endif
|
||||
|
||||
BFD_ASSERT(bfd_get_arch(abfd) == bfd_arch_ns32k);
|
||||
BFD_ASSERT(bfd_get_mach(abfd) == 32532);
|
||||
N_SET_MACHTYPE (*execp, M_532_NETBSD);
|
||||
|
||||
N_SET_FLAGS (*execp, aout_backend_info (abfd)->exec_hdr_flags);
|
||||
|
||||
WRITE_HEADERS(abfd, execp);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
#define MY_write_object_contents MY(write_object_contents)
|
||||
|
||||
#include "aout-target.h"
|
101
bfd/pc532-mach.c
Normal file
101
bfd/pc532-mach.c
Normal file
|
@ -0,0 +1,101 @@
|
|||
/* Written by Ian Dall
|
||||
* 19-Apr-94
|
||||
*
|
||||
* Formerly part of aout-pc532-mach.c. Split out to allow more
|
||||
* flexibility with multiple formats.
|
||||
*
|
||||
*/
|
||||
/* This architecture has N_TXTOFF and N_TXTADDR defined as if
|
||||
* N_HEADER_IN_TEXT, but the a_text entry (text size) does not include the
|
||||
* space for the header. So we have N_HEADER_IN_TEXT defined to
|
||||
* 1 and specially define our own N_TXTSIZE
|
||||
*/
|
||||
|
||||
#define N_HEADER_IN_TEXT(x) 1
|
||||
#define N_TXTSIZE(x) ((x).a_text)
|
||||
|
||||
|
||||
#define TEXT_START_ADDR 0x10000 /* from old ld */
|
||||
#define PAGE_SIZE 0x1000 /* from old ld, 032 & 532 are really 512/4k */
|
||||
|
||||
/* Use a_entry of 0 to distinguish object files from OMAGIC executables */
|
||||
#define N_TXTADDR(x) \
|
||||
(N_MAGIC(x) == OMAGIC ? \
|
||||
((x).a_entry < TEXT_START_ADDR? 0: TEXT_START_ADDR): \
|
||||
(N_MAGIC(x) == NMAGIC? TEXT_START_ADDR: \
|
||||
TEXT_START_ADDR + EXEC_BYTES_SIZE))
|
||||
|
||||
#define ARCH 32
|
||||
|
||||
#define SEGMENT_SIZE PAGE_SIZE
|
||||
|
||||
#define N_SHARED_LIB(x) 0
|
||||
#define SEGMENT_SIZE PAGE_SIZE
|
||||
#define DEFAULT_ARCH bfd_arch_ns32k
|
||||
|
||||
#define MY(OP) CAT(pc532mach_,OP)
|
||||
|
||||
#define TARGETNAME "a.out-pc532-mach"
|
||||
|
||||
#include "bfd.h"
|
||||
#include "sysdep.h"
|
||||
#include "aout-ns32k.h"
|
||||
#include "libaout.h"
|
||||
#include "libbfd.h"
|
||||
#include "aout/aout64.h"
|
||||
|
||||
/* We can`t use the MYNS macro here for cpp reasons too subtle
|
||||
* for me -- IWD
|
||||
*/
|
||||
#define MY_bfd_reloc_type_lookup ns32kaout_bfd_reloc_type_lookup
|
||||
|
||||
/* libaout doesn't use NAME for these ... */
|
||||
#define MY_get_section_contents aout_32_get_section_contents
|
||||
|
||||
/* Forward declaration. Defined in aout-target.h */
|
||||
static boolean MY(set_sizes)();
|
||||
|
||||
static CONST struct aout_backend_data MY(backend_data) = {
|
||||
0, /* zmagic contiguous */
|
||||
1, /* text incl header */
|
||||
0,
|
||||
0, /* text vma? */
|
||||
MY(set_sizes),
|
||||
1, /* exec header is not counted */
|
||||
};
|
||||
|
||||
#define MY_backend_data &MY(backend_data)
|
||||
|
||||
static boolean
|
||||
MY(write_object_contents) (abfd)
|
||||
bfd *abfd;
|
||||
{
|
||||
struct external_exec exec_bytes;
|
||||
struct internal_exec *execp = exec_hdr (abfd);
|
||||
|
||||
#if CHOOSE_RELOC_SIZE
|
||||
CHOOSE_RELOC_SIZE(abfd);
|
||||
#else
|
||||
obj_reloc_entry_size (abfd) = RELOC_STD_SIZE;
|
||||
#endif
|
||||
|
||||
BFD_ASSERT(bfd_get_arch(abfd) == bfd_arch_ns32k);
|
||||
switch (bfd_get_mach(abfd)) {
|
||||
case 32032:
|
||||
N_SET_MACHTYPE (*execp, M_NS32032);
|
||||
break;
|
||||
case 32532:
|
||||
default:
|
||||
N_SET_MACHTYPE (*execp, M_NS32532);
|
||||
break;
|
||||
}
|
||||
N_SET_FLAGS (*execp, aout_backend_info (abfd)->exec_hdr_flags);
|
||||
|
||||
WRITE_HEADERS(abfd, execp);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
#define MY_write_object_contents MY(write_object_contents)
|
||||
|
||||
#include "aout-target.h"
|
53
bfd/reloc.c
53
bfd/reloc.c
|
@ -282,7 +282,9 @@ SUBSUBSECTION
|
|||
CODE_FRAGMENT
|
||||
.struct symbol_cache_entry; {* Forward declaration *}
|
||||
.
|
||||
.typedef struct reloc_howto_struct
|
||||
.typedef unsigned char bfd_byte;
|
||||
.
|
||||
.struct reloc_howto_struct
|
||||
.{
|
||||
. {* The type field has mainly a documetary use - the back end can
|
||||
. do what it wants with it, though normally the back end's
|
||||
|
@ -332,6 +334,17 @@ CODE_FRAGMENT
|
|||
. bfd *output_bfd,
|
||||
. char **error_message));
|
||||
.
|
||||
.
|
||||
. {* If this field is non null, then the supplied function is
|
||||
. called rather than the normal function. This is similar
|
||||
. to special_function (previous), but takes different arguments,
|
||||
. and is used for the new linking code. *}
|
||||
. bfd_reloc_status_type (*special_function1)
|
||||
. PARAMS((const reloc_howto_type *howto,
|
||||
. bfd *input_bfd,
|
||||
. bfd_vma relocation,
|
||||
. bfd_byte *location));
|
||||
.
|
||||
. {* The textual name of the relocation type. *}
|
||||
. char *name;
|
||||
.
|
||||
|
@ -362,7 +375,8 @@ CODE_FRAGMENT
|
|||
. empty (e.g., m88k bcs); this flag signals the fact.*}
|
||||
. boolean pcrel_offset;
|
||||
.
|
||||
.} reloc_howto_type;
|
||||
.};
|
||||
.typedef struct reloc_howto_struct reloc_howto_type;
|
||||
|
||||
*/
|
||||
|
||||
|
@ -375,7 +389,9 @@ DESCRIPTION
|
|||
|
||||
|
||||
.#define HOWTO(C, R,S,B, P, BI, O, SF, NAME, INPLACE, MASKSRC, MASKDST, PC) \
|
||||
. {(unsigned)C,R,S,B, P, BI, O,SF,NAME,INPLACE,MASKSRC,MASKDST,PC}
|
||||
. {(unsigned)C,R,S,B, P, BI, O,SF, 0,NAME,INPLACE,MASKSRC,MASKDST,PC}
|
||||
.#define HOWTO2(C, R,S,B, P, BI, O, SF, SF1,NAME, INPLACE, MASKSRC, MASKDST, PC) \
|
||||
. {(unsigned)C,R,S,B, P, BI, O,SF, SF1,NAME,INPLACE,MASKSRC,MASKDST,PC}
|
||||
|
||||
DESCRIPTION
|
||||
And will be replaced with the totally magic way. But for the
|
||||
|
@ -437,8 +453,6 @@ DESCRIPTION
|
|||
|
||||
How relocs are tied together in an <<asection>>:
|
||||
|
||||
.typedef unsigned char bfd_byte;
|
||||
.
|
||||
.typedef struct relent_chain {
|
||||
. arelent relent;
|
||||
. struct relent_chain *next;
|
||||
|
@ -500,7 +514,7 @@ bfd_perform_relocation (abfd, reloc_entry, data, input_section, output_bfd,
|
|||
asymbol *symbol;
|
||||
|
||||
symbol = *(reloc_entry->sym_ptr_ptr);
|
||||
if ((symbol->section == &bfd_abs_section)
|
||||
if (bfd_is_abs_section (symbol->section)
|
||||
&& output_bfd != (bfd *) NULL)
|
||||
{
|
||||
reloc_entry->address += input_section->output_offset;
|
||||
|
@ -510,7 +524,7 @@ bfd_perform_relocation (abfd, reloc_entry, data, input_section, output_bfd,
|
|||
/* If we are not producing relocateable output, return an error if
|
||||
the symbol is not defined. An undefined weak symbol is
|
||||
considered to have a value of zero (SVR4 ABI, p. 4-27). */
|
||||
if (symbol->section == &bfd_und_section
|
||||
if (bfd_is_und_section (symbol->section)
|
||||
&& (symbol->flags & BSF_WEAK) == 0
|
||||
&& output_bfd == (bfd *) NULL)
|
||||
flag = bfd_reloc_undefined;
|
||||
|
@ -618,7 +632,9 @@ bfd_perform_relocation (abfd, reloc_entry, data, input_section, output_bfd,
|
|||
|
||||
/* WTF?? */
|
||||
if (abfd->xvec->flavour == bfd_target_coff_flavour
|
||||
&& strcmp (abfd->xvec->name, "aixcoff-rs6000") != 0)
|
||||
&& strcmp (abfd->xvec->name, "aixcoff-rs6000") != 0
|
||||
&& strcmp (abfd->xvec->name, "coff-Intel-little") != 0
|
||||
&& strcmp (abfd->xvec->name, "coff-Intel-big") != 0)
|
||||
{
|
||||
#if 1
|
||||
/* For m68k-coff, the addend was being subtracted twice during
|
||||
|
@ -977,6 +993,13 @@ _bfd_final_link_relocate (howto, input_bfd, input_section, contents, address,
|
|||
relocation -= address;
|
||||
}
|
||||
|
||||
if(howto->special_function1) {
|
||||
bfd_reloc_status_type cont;
|
||||
cont = (*howto->special_function1)(howto, input_bfd, relocation,
|
||||
contents + address);
|
||||
if (cont != bfd_reloc_continue)
|
||||
return cont;
|
||||
}
|
||||
return _bfd_relocate_contents (howto, input_bfd, relocation,
|
||||
contents + address);
|
||||
}
|
||||
|
@ -1371,6 +1394,20 @@ CODE_FRAGMENT
|
|||
. BFD_RELOC_386_GOTOFF,
|
||||
. BFD_RELOC_386_GOTPC,
|
||||
.
|
||||
. {* ns32k relocations *}
|
||||
. BFD_RELOC_NS32K_IMM_8,
|
||||
. BFD_RELOC_NS32K_IMM_16,
|
||||
. BFD_RELOC_NS32K_IMM_32,
|
||||
. BFD_RELOC_NS32K_IMM_8_PCREL,
|
||||
. BFD_RELOC_NS32K_IMM_16_PCREL,
|
||||
. BFD_RELOC_NS32K_IMM_32_PCREL,
|
||||
. BFD_RELOC_NS32K_DISP_8,
|
||||
. BFD_RELOC_NS32K_DISP_16,
|
||||
. BFD_RELOC_NS32K_DISP_32,
|
||||
. BFD_RELOC_NS32K_DISP_8_PCREL,
|
||||
. BFD_RELOC_NS32K_DISP_16_PCREL,
|
||||
. BFD_RELOC_NS32K_DISP_32_PCREL,
|
||||
.
|
||||
. {* PowerPC/POWER (RS/6000) relocs. *}
|
||||
. {* 26 bit relative branch. Low two bits must be zero. High 24
|
||||
. bits installed in bits 6 through 29 of instruction. *}
|
||||
|
|
Loading…
Add table
Reference in a new issue