aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIan Lance Taylor <ian@airs.com>1992-12-21 21:17:54 +0000
committerIan Lance Taylor <ian@airs.com>1992-12-21 21:17:54 +0000
commit60ac749cab2e4a1033080b4ac27124fbcd136fa5 (patch)
tree9f84b41c995bac07d02c8a20d21d4def072627df
parent5998e36203c87968a03f0cb127e58375abcf1e55 (diff)
downloadgdb-60ac749cab2e4a1033080b4ac27124fbcd136fa5.zip
gdb-60ac749cab2e4a1033080b4ac27124fbcd136fa5.tar.gz
gdb-60ac749cab2e4a1033080b4ac27124fbcd136fa5.tar.bz2
Mon Dec 21 12:40:10 1992 Ian Lance Taylor (ian@cygnus.com)
* Patches from Minh Tran-le <mtranle@paris.intellicorp.com>. * configure.in (i386-*-isc*, i386-*-aix*): New targets. * configure.host (i386-*-isc*, i386-*-aix*): New hosts. * hosts/i386isc.h, config/i386isc.mh: New files for Interactive Unix. * hosts/i386aix.h, config/i386aix.mh: New files for AIX on PS/2. * aix386-core.c: New file for handling core files on AIX on PS/2. * targets.c: if AIX386_CORE, use aix386_core_vec. * coffcode.h (coff_real_object_p): check for I386SVMAGIC as well as I386MAGIC.
-rw-r--r--bfd/.Sanitize1
-rw-r--r--bfd/ChangeLog14
-rw-r--r--bfd/coffcode.h7
-rw-r--r--bfd/configure.host74
-rw-r--r--bfd/configure.in8
-rw-r--r--bfd/hosts/.Sanitize2
-rw-r--r--bfd/hosts/i386aix.h63
-rw-r--r--bfd/hosts/i386isc.h60
-rw-r--r--bfd/targets.c203
9 files changed, 303 insertions, 129 deletions
diff --git a/bfd/.Sanitize b/bfd/.Sanitize
index b180b4a..addee21 100644
--- a/bfd/.Sanitize
+++ b/bfd/.Sanitize
@@ -30,6 +30,7 @@ Makefile.dos
Makefile.in
TODO
VERSION
+aix386-core.c
aout32.c
aout64.c
aoutf1.h
diff --git a/bfd/ChangeLog b/bfd/ChangeLog
index b681127..dc98ac4 100644
--- a/bfd/ChangeLog
+++ b/bfd/ChangeLog
@@ -1,8 +1,20 @@
+Mon Dec 21 12:40:10 1992 Ian Lance Taylor (ian@cygnus.com)
+
+ * Patches from Minh Tran-le <mtranle@paris.intellicorp.com>.
+ * configure.in (i386-*-isc*, i386-*-aix*): New targets.
+ * configure.host (i386-*-isc*, i386-*-aix*): New hosts.
+ * hosts/i386isc.h, config/i386isc.mh: New files for Interactive
+ Unix.
+ * hosts/i386aix.h, config/i386aix.mh: New files for AIX on PS/2.
+ * aix386-core.c: New file for handling core files on AIX on PS/2.
+ * targets.c: if AIX386_CORE, use aix386_core_vec.
+ * coffcode.h (coff_real_object_p): check for I386SVMAGIC as well
+ as I386MAGIC.
+
Fri Dec 18 10:20:27 1992 Steve Chamberlain (sac@thepub.cygnus.com)
* aoutf1.h (sunos4_write_object_contents): set flags to 0, fixing
1927.
-
Thu Dec 17 00:36:24 1992 John Gilmore (gnu@cygnus.com)
diff --git a/bfd/coffcode.h b/bfd/coffcode.h
index 1269879..2386acf 100644
--- a/bfd/coffcode.h
+++ b/bfd/coffcode.h
@@ -458,9 +458,9 @@ INTERNAL_DEFINITION
CODE_FRAGMENT
-.typedef struct {
Special entry points for gdb to swap in coff symbol table parts
-
+.typedef struct
+.{
. void (*_bfd_coff_swap_aux_in) PARAMS ((
. bfd *abfd ,
. PTR ext,
@@ -1188,6 +1188,9 @@ machine = 0;
switch (internal_f->f_magic) {
#ifdef I386MAGIC
case I386MAGIC:
+#ifdef I386SVMAGIC
+ case I386SVMAGIC: /* System V C Compiler aix ps2 */
+#endif
arch = bfd_arch_i386;
machine = 0;
break;
diff --git a/bfd/configure.host b/bfd/configure.host
new file mode 100644
index 0000000..6857b0d
--- /dev/null
+++ b/bfd/configure.host
@@ -0,0 +1,74 @@
+# This file is a shell script that supplies the information necessary
+# to tailor a template configure script into the configure script
+# appropriate for this directory. For more information, check any
+# existing configure script.
+
+# Since the "bfd/hosts" directory is shared by the bfd, opcodes, and
+# binutils directories (at least), the index to it is also shared.
+# This is that index. Each configure.in file should source this file
+# in its per-host part.
+
+case "${host}" in
+# 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
+# convention, else the table becomes a real mess to understand and maintain.
+#
+# Note that these entries cannot be fully alphabetical. Don't try.
+# The order of matching is critical when multiple lines could match.
+
+a29k-*-*) my_host=ultra3 ;;
+
+hppa*-hp-hpux) my_host=hppahpux ;;
+hppa*-hp-bsd) my_host=hppabsd ;;
+
+i[34]86-*-bsd) my_host=i386bsd ;;
+i[34]86-ncr*-sysv4*) my_host=ncr3000 ;;
+i[34]86-*-go32) my_host=go32 ;;
+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=i386v ;;
+i[34]86-*-mach*) my_host=i386mach ;;
+i[34]86-*-msdos*) my_host=dose ;;
+i[34]86-*-linux) my_host=i386linux ;;
+i[34]86-*-isc*) my_host=i386isc ;;
+i[34]86-*-aix*) my_host=i386aix ;;
+
+i860-*-*) my_host=stratus ;;
+
+mips-dec-*) my_host=decstation ;;
+mips-sgi-irix3) my_host=irix3 ;;
+mips-sgi-irix4) my_host=irix4 ;;
+
+m68*-cbm-amigados) my_host=amigados ;;
+m68*-cbm-sysv4*) my_host=amix ;;
+m68*-hp-hpux) my_host=hp300 ;;
+m68*-hp-bsd) my_host=hp300bsd ;;
+m68*-sony-*) my_host=news ;;
+m68*-sun-*) my_host=sun3 ;;
+m68*-apollo*-sysv*) my_host=apollov68 ;;
+m68*-apollo*-bsd*) my_host=apollo68 ;;
+
+m88k-motorola-*) my_host=delta88 ;;
+m88k-harris-*) my_host=harris ;;
+m88k-*-dgux) my_host=dgux ;;
+
+romp-*-*) my_host=rtbsd ;;
+
+rs6000-*-*) my_host=rs6000 ;;
+
+sparc-*-sunos64) my_host=sparc-ll ;;
+sparc-*-sysv4*) my_host=sysv4 ;;
+sparc-*-solaris2*) my_host=solaris2 ;;
+sparc-*-sysv64) my_host=sysv4-ll ;;
+sparc-*-*) my_host=sparc ;;
+
+tahoe-*-*) my_host=tahoe ;;
+
+vax-*-ultrix*) my_host=vaxult ;;
+vax-*-*) my_host=vaxbsd ;;
+
+we32k-*-*) my_host=we32k ;;
+
+esac
diff --git a/bfd/configure.in b/bfd/configure.in
index 03040af..7acef62 100644
--- a/bfd/configure.in
+++ b/bfd/configure.in
@@ -47,8 +47,10 @@ case "${target}" in
hppa*-*-hpux) bfd_target=hppahpux ;;
i[34]86-*-sysv4*) bfd_target=i386-elf ;;
i[34]86-*-sysv*) bfd_target=i386-coff ;;
- i[34]86-*-sco*) bfd_target=i386-coff ;;
+ i[34]86-*-isc*) bfd_target=i386-coff ;;
+ i[34]86-*-sco*) bfd_target=i386-sco ;;
i[34]86-*-bsd*) bfd_target=i386-bsd ;;
+ i[34]86-*-aix*) bfd_target=i386-coff ;;
i[34]86-none-*) bfd_target=i386-coff ;;
i960-*-vxworks) bfd_target=i960-bout ;;
i960-*-aout) bfd_target=i960-bout ;;
@@ -69,8 +71,7 @@ case "${target}" in
rs6000-*-*) bfd_target=rs6000 ;;
sparc-*-solaris2*) bfd_target=sparc-elf ;;
sparc-*-sysv4*) bfd_target=sparc-elf ;;
- sparc-*-*) bfd_target=sparc-aout ;;
- sparclite-*-*) bfd_target=sparc-aout ;;
+ sparc*-*-*) bfd_target=sparc-aout ;;
tahoe-*-*) bfd_target=tahoe ;;
vax-*-*) bfd_target=vax ;;
we32k-*-*) bfd_target=we32k ;;
@@ -83,7 +84,6 @@ case "${target}" in
*-*-go32) bfd_target=${target_cpu}-aout ;;
*-*-linux*) bfd_target=${target_cpu}-linux ;;
*-*-sysv*) bfd_target=${target_cpu}-coff ;;
- *-*-scosysv*) bfd_target=${target_cpu}-coff ;;
*-adobe-*) bfd_target=adobe ;;
*-sony-*) bfd_target=news ;;
diff --git a/bfd/hosts/.Sanitize b/bfd/hosts/.Sanitize
index 3956c65..a02f2d5 100644
--- a/bfd/hosts/.Sanitize
+++ b/bfd/hosts/.Sanitize
@@ -38,7 +38,9 @@ hp300bsd.h
hp300.h
hppabsd.h
hppahpux.h
+i386aix.h
i386bsd.h
+i386isc.h
i386linux.h
i386mach.h
i386v.h
diff --git a/bfd/hosts/i386aix.h b/bfd/hosts/i386aix.h
new file mode 100644
index 0000000..ce1a8c6
--- /dev/null
+++ b/bfd/hosts/i386aix.h
@@ -0,0 +1,63 @@
+/* i386 AIX 1.2.x host system */
+/* From Minh Tran-Le <TRANLE@INTELLICORP.COM>. */
+
+#include <fcntl.h>
+#include <errno.h>
+#include <stdio.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <utime.h>
+#include <ctype.h>
+#include <string.h>
+#include <sys/file.h>
+
+#ifndef O_ACCMODE
+#define O_ACCMODE (O_RDONLY | O_WRONLY | O_RDWR)
+#endif
+#define SEEK_SET 0
+#define SEEK_CUR 1
+
+#define POSIX_UTIME
+
+extern void EXFUN(abort,(void));
+extern int EXFUN(close,(int));
+extern void EXFUN(exit,(int));
+extern int EXFUN(fclose,(FILE*));
+extern void EXFUN(free,(PTR));
+extern int EXFUN(fseek,(FILE*, long, int));
+extern PTR EXFUN(malloc,(unsigned));
+extern void EXFUN(perror,(CONST char *));
+extern int EXFUN(qsort,(void *data,int els, int siz, int func()));
+extern PTR EXFUN(realloc, (PTR, unsigned));
+
+extern char *getenv();
+extern int chmod();
+extern int fstat();
+extern int stat();
+
+extern char *ctime();
+extern int _flsbuf();
+extern int fclose();
+extern int utimes();
+extern int vfprintf();
+extern long atol();
+extern int fputc();
+extern int unlink();
+
+/* EXACT TYPES */
+typedef char int8e_type;
+typedef unsigned char uint8e_type;
+typedef short int16e_type;
+typedef unsigned short uint16e_type;
+typedef int int32e_type;
+typedef unsigned int uint32e_type;
+
+/* CORRECT SIZE OR GREATER */
+typedef char int8_type;
+typedef unsigned char uint8_type;
+typedef short int16_type;
+typedef unsigned short uint16_type;
+typedef int int32_type;
+typedef unsigned int uint32_type;
+
+#include "fopen-same.h"
diff --git a/bfd/hosts/i386isc.h b/bfd/hosts/i386isc.h
new file mode 100644
index 0000000..c16cf9c
--- /dev/null
+++ b/bfd/hosts/i386isc.h
@@ -0,0 +1,60 @@
+/* Host configuration file for Interactive Unix 3.2 */
+/* From Minh Tran-Le <TRANLE@INTELLICORP.COM>. */
+#include <fcntl.h>
+#include <errno.h>
+#include <stdio.h>
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <ctype.h>
+#include <string.h>
+#include <unistd.h>
+
+#ifndef O_ACCMODE
+#define O_ACCMODE (O_RDONLY | O_WRONLY | O_RDWR)
+#endif
+#ifndef SEEK_SET
+#define SEEK_SET 0
+#define SEEK_CUR 1
+#endif
+
+#define USE_UTIME
+
+/* Some things that need to be defined in order to make code written for
+ BSD Unix compile under System V Unix. */
+
+/*#include <memory.h>*/
+#define bcmp(b1,b2,len) memcmp(b1,b2,len)
+#define bcopy(src,dst,len) memcpy(dst,src,len)
+#define bzero(s,n) memset(s,0,n)
+
+#include <string.h>
+#define index(s,c) strchr(s,c)
+#define rindex(s,c) strrchr(s,c)
+
+#ifndef DONTDECLARE_MALLOC
+extern PTR EXFUN(malloc,(unsigned));
+extern PTR EXFUN(realloc, (PTR, unsigned));
+extern void EXFUN(free,(PTR));
+#endif
+
+/* EXACT TYPES */
+typedef char int8e_type;
+typedef unsigned char uint8e_type;
+typedef short int16e_type;
+typedef unsigned short uint16e_type;
+typedef int int32e_type;
+typedef unsigned int uint32e_type;
+
+/* CORRECT SIZE OR GREATER */
+typedef char int8_type;
+typedef unsigned char uint8_type;
+typedef short int16_type;
+typedef unsigned short uint16_type;
+typedef int int32_type;
+typedef unsigned int uint32_type;
+
+#include "fopen-same.h"
+
+#ifndef fileno
+#define fileno(fp) ((fp)->_file)
+#endif
diff --git a/bfd/targets.c b/bfd/targets.c
index 2b31886..57ff69a 100644
--- a/bfd/targets.c
+++ b/bfd/targets.c
@@ -90,15 +90,6 @@ DESCRIPTION
Every BFD points to a target structure with its <<xvec>>
member.
- Shortcut for declaring fields which are prototyped function
- pointers, while avoiding anguish on compilers that don't
- support protos.
-
-.#define SDEF(ret, name, arglist) \
-. PROTO(ret,(*name),arglist)
-.#define SDEF_FMT(ret, name, arglist) \
-. PROTO(ret,(*name[bfd_type_end]),arglist)
-
These macros are used to dispatch to functions through the
bfd_target vector. They are used in a number of macros further
down in @file{bfd.h}, and are also used when calling various
@@ -177,7 +168,7 @@ The pad character for filenames within an archive header.
The maximum number of characters in an archive header.
-. unsigned short ar_max_namelen;
+. unsigned short ar_max_namelen;
The minimum alignment restriction for any section.
@@ -187,36 +178,36 @@ Entries for byte swapping for data. These are different to the other
entry points, since they don't take BFD as first arg. Certain other handlers
could do the same.
-. SDEF (bfd_vma, bfd_getx64, (bfd_byte *));
-. SDEF (void, bfd_putx64, (bfd_vma, bfd_byte *));
-. SDEF (bfd_vma, bfd_getx32, (bfd_byte *));
-. SDEF (void, bfd_putx32, (bfd_vma, bfd_byte *));
-. SDEF (bfd_vma, bfd_getx16, (bfd_byte *));
-. SDEF (void, bfd_putx16, (bfd_vma, bfd_byte *));
+. bfd_vma (*bfd_getx64) PARAMS ((bfd_byte *));
+. void (*bfd_putx64) PARAMS ((bfd_vma, bfd_byte *));
+. bfd_vma (*bfd_getx32) PARAMS ((bfd_byte *));
+. void (*bfd_putx32) PARAMS ((bfd_vma, bfd_byte *));
+. bfd_vma (*bfd_getx16) PARAMS ((bfd_byte *));
+. void (*bfd_putx16) PARAMS ((bfd_vma, bfd_byte *));
Byte swapping for the headers
-. SDEF (bfd_vma, bfd_h_getx64, (bfd_byte *));
-. SDEF (void, bfd_h_putx64, (bfd_vma, bfd_byte *));
-. SDEF (bfd_vma, bfd_h_getx32, (bfd_byte *));
-. SDEF (void, bfd_h_putx32, (bfd_vma, bfd_byte *));
-. SDEF (bfd_vma, bfd_h_getx16, (bfd_byte *));
-. SDEF (void, bfd_h_putx16, (bfd_vma, bfd_byte *));
+. bfd_vma (*bfd_h_getx64) PARAMS ((bfd_byte *));
+. void (*bfd_h_putx64) PARAMS ((bfd_vma, bfd_byte *));
+. bfd_vma (*bfd_h_getx32) PARAMS ((bfd_byte *));
+. void (*bfd_h_putx32) PARAMS ((bfd_vma, bfd_byte *));
+. bfd_vma (*bfd_h_getx16) PARAMS ((bfd_byte *));
+. void (*bfd_h_putx16) PARAMS ((bfd_vma, bfd_byte *));
-Format dependent routines, these turn into vectors of entry points
-within the target vector structure; one for each format to check.
+Format dependent routines: these are vectors of entry points
+within the target vector structure, one for each format to check.
Check the format of a file being read. Return bfd_target * or zero.
-. SDEF_FMT (struct bfd_target *, _bfd_check_format, (bfd *));
+. struct bfd_target * (*_bfd_check_format[bfd_type_end]) PARAMS ((bfd *));
Set the format of a file being written.
-. SDEF_FMT (boolean, _bfd_set_format, (bfd *));
+. boolean (*_bfd_set_format[bfd_type_end]) PARAMS ((bfd *));
Write cached information into a file being written, at bfd_close.
-. SDEF_FMT (boolean, _bfd_write_contents, (bfd *));
+. boolean (*_bfd_write_contents[bfd_type_end]) PARAMS ((bfd *));
The following functions are defined in <<JUMP_TABLE>>. The idea is
that the back end writer of <<foo>> names all the routines
@@ -225,16 +216,16 @@ in this structure in the right order.
Core file entry points
-. SDEF (char *, _core_file_failing_command, (bfd *));
-. SDEF (int, _core_file_failing_signal, (bfd *));
-. SDEF (boolean, _core_file_matches_executable_p, (bfd *, bfd *));
+. char * (*_core_file_failing_command) PARAMS ((bfd *));
+. int (*_core_file_failing_signal) PARAMS ((bfd *));
+. boolean (*_core_file_matches_executable_p) PARAMS ((bfd *, bfd *));
Archive entry points
-. SDEF (boolean, _bfd_slurp_armap, (bfd *));
-. SDEF (boolean, _bfd_slurp_extended_name_table, (bfd *));
-. SDEF (void, _bfd_truncate_arname, (bfd *, CONST char *, char *));
-. SDEF (boolean, write_armap, (bfd *arch,
+. boolean (*_bfd_slurp_armap) PARAMS ((bfd *));
+. boolean (*_bfd_slurp_extended_name_table) PARAMS ((bfd *));
+. void (*_bfd_truncate_arname) PARAMS ((bfd *, CONST char *, char *));
+. boolean (*write_armap) PARAMS ((bfd *arch,
. unsigned int elength,
. struct orl *map,
. unsigned int orl_count,
@@ -242,111 +233,63 @@ Archive entry points
Standard stuff.
-. SDEF (boolean, _close_and_cleanup, (bfd *));
-. SDEF (boolean, _bfd_set_section_contents, (bfd *, sec_ptr, PTR,
+. boolean (*_close_and_cleanup) PARAMS ((bfd *));
+. boolean (*_bfd_set_section_contents) PARAMS ((bfd *, sec_ptr, PTR,
. file_ptr, bfd_size_type));
-. SDEF (boolean, _bfd_get_section_contents, (bfd *, sec_ptr, PTR,
+. boolean (*_bfd_get_section_contents) PARAMS ((bfd *, sec_ptr, PTR,
. file_ptr, bfd_size_type));
-. SDEF (boolean, _new_section_hook, (bfd *, sec_ptr));
+. boolean (*_new_section_hook) PARAMS ((bfd *, sec_ptr));
Symbols and relocations
-. SDEF (unsigned int, _get_symtab_upper_bound, (bfd *));
-. SDEF (unsigned int, _bfd_canonicalize_symtab,
-. (bfd *, struct symbol_cache_entry **));
-. SDEF (unsigned int, _get_reloc_upper_bound, (bfd *, sec_ptr));
-. SDEF (unsigned int, _bfd_canonicalize_reloc, (bfd *, sec_ptr, arelent **,
-. struct symbol_cache_entry**));
-. SDEF (struct symbol_cache_entry *, _bfd_make_empty_symbol, (bfd *));
-. SDEF (void, _bfd_print_symbol, (bfd *, PTR, struct symbol_cache_entry *,
+. unsigned int (*_get_symtab_upper_bound) PARAMS ((bfd *));
+. unsigned int (*_bfd_canonicalize_symtab) PARAMS ((bfd *,
+. struct symbol_cache_entry **));
+. unsigned int (*_get_reloc_upper_bound) PARAMS ((bfd *, sec_ptr));
+. unsigned int (*_bfd_canonicalize_reloc) PARAMS ((bfd *, sec_ptr, arelent **,
+. struct symbol_cache_entry **));
+. struct symbol_cache_entry *
+. (*_bfd_make_empty_symbol) PARAMS ((bfd *));
+. void (*_bfd_print_symbol) PARAMS ((bfd *, PTR,
+. struct symbol_cache_entry *,
. bfd_print_symbol_type));
.#define bfd_print_symbol(b,p,s,e) BFD_SEND(b, _bfd_print_symbol, (b,p,s,e))
-. SDEF (alent *, _get_lineno, (bfd *, struct symbol_cache_entry *));
-.
-. SDEF (boolean, _bfd_set_arch_mach, (bfd *, enum bfd_architecture,
-. unsigned long));
-.
-. SDEF (bfd *, openr_next_archived_file, (bfd *arch, bfd *prev));
-. SDEF (boolean, _bfd_find_nearest_line,
-. (bfd *abfd, struct sec *section,
-. struct symbol_cache_entry **symbols,bfd_vma offset,
-. CONST char **file, CONST char **func, unsigned int *line));
-. SDEF (int, _bfd_stat_arch_elt, (bfd *, struct stat *));
-.
-. SDEF (int, _bfd_sizeof_headers, (bfd *, boolean));
-.
-. SDEF (void, _bfd_debug_info_start, (bfd *));
-. SDEF (void, _bfd_debug_info_end, (bfd *));
-. SDEF (void, _bfd_debug_info_accumulate, (bfd *, struct sec *));
-. SDEF (bfd_byte *, _bfd_get_relocated_section_contents, (bfd*,struct bfd_seclet *, bfd_byte *data));
-. SDEF (boolean,_bfd_relax_section,(bfd *, struct sec *, struct symbol_cache_entry **));
-Special entry points for gdb to swap in coff symbol table parts
-
-. SDEF(void, _bfd_coff_swap_aux_in,(
-. bfd *abfd ,
-. PTR ext,
-. int type,
-. int class ,
-. PTR in));
-.
-. SDEF(void, _bfd_coff_swap_sym_in,(
-. bfd *abfd ,
-. PTR ext,
-. PTR in));
-.
-. SDEF(void, _bfd_coff_swap_lineno_in, (
-. bfd *abfd,
-. PTR ext,
-. PTR in));
-.
-Special entry points for gas to swap coff parts
-
-. SDEF(unsigned int, _bfd_coff_swap_aux_out,(
-. bfd *abfd,
-. PTR in,
-. int type,
-. int class,
-. PTR ext));
-.
-. SDEF(unsigned int, _bfd_coff_swap_sym_out,(
-. bfd *abfd,
-. PTR in,
-. PTR ext));
+. alent * (*_get_lineno) PARAMS ((bfd *, struct symbol_cache_entry *));
.
-. SDEF(unsigned int, _bfd_coff_swap_lineno_out,(
-. bfd *abfd,
-. PTR in,
-. PTR ext));
+. boolean (*_bfd_set_arch_mach) PARAMS ((bfd *, enum bfd_architecture,
+. unsigned long));
.
-. SDEF(unsigned int, _bfd_coff_swap_reloc_out,(
-. bfd *abfd,
-. PTR src,
-. PTR dst));
+. bfd * (*openr_next_archived_file) PARAMS ((bfd *arch, bfd *prev));
+.
+. boolean (*_bfd_find_nearest_line) PARAMS ((bfd *abfd,
+. struct sec *section, struct symbol_cache_entry **symbols,
+. bfd_vma offset, CONST char **file, CONST char **func,
+. unsigned int *line));
+.
+. int (*_bfd_stat_arch_elt) PARAMS ((bfd *, struct stat *));
.
-. SDEF(unsigned int, _bfd_coff_swap_filehdr_out,(
-. bfd *abfd,
-. PTR in,
-. PTR out));
+. int (*_bfd_sizeof_headers) PARAMS ((bfd *, boolean));
.
-. SDEF(unsigned int, _bfd_coff_swap_aouthdr_out,(
-. bfd *abfd,
-. PTR in,
-. PTR out));
+. void (*_bfd_debug_info_start) PARAMS ((bfd *));
+. void (*_bfd_debug_info_end) PARAMS ((bfd *));
+. void (*_bfd_debug_info_accumulate) PARAMS ((bfd *, struct sec *));
.
-. SDEF(unsigned int, _bfd_coff_swap_scnhdr_out,(
-. bfd *abfd,
-. PTR in,
-. PTR out));
+. bfd_byte * (*_bfd_get_relocated_section_contents) PARAMS ((bfd *,
+. struct bfd_seclet *, bfd_byte *data));
.
+. boolean (*_bfd_relax_section) PARAMS ((bfd *, struct sec *,
+. struct symbol_cache_entry **));
+
. {* See documentation on reloc types. *}
-. SDEF (CONST struct reloc_howto_struct *,
-. reloc_type_lookup,
-. (bfd *abfd, bfd_reloc_code_real_type code));
+. CONST struct reloc_howto_struct *
+. (*reloc_type_lookup) PARAMS ((bfd *abfd,
+. bfd_reloc_code_real_type code));
.
-. {* Complete and utter crock, currently used for the assembler
+. {* Back-door to allow format-aware applications to create debug symbols
+. while using BFD for everything else. Currently used by the assembler
. when creating COFF files. *}
-. SDEF (asymbol *, _bfd_make_debug_symbol, (
+. asymbol * (*_bfd_make_debug_symbol) PARAMS ((
. bfd *abfd,
. void *ptr,
. unsigned long size));
@@ -372,9 +315,17 @@ above COFF-specific fields.
#ifdef TRAD_CORE
#define SELECT_VECS &DEFAULT_VECTOR,&trad_core_vec
#else
+#ifdef SCO_CORE
+#define SELECT_VECS &DEFAULT_VECTOR,&sco_core_vec
+#else
+#ifdef AIX386_CORE
+#define SELECT_VECS &DEFAULT_VECTOR,&aix386_core_vec
+#else
#define SELECT_VECS &DEFAULT_VECTOR
#endif
#endif
+#endif
+#endif
/* All known xvecs. They are listed a second time below, since
we can't intermix extern's and initializers. */
@@ -400,6 +351,8 @@ extern bfd_target i386aout_vec;
extern bfd_target i386linux_vec;
extern bfd_target a29kcoff_big_vec;
extern bfd_target trad_core_vec;
+extern bfd_target sco_core_vec;
+extern bfd_target aix386_core_vec;
extern bfd_target rs6000coff_vec;
extern bfd_target h8300coff_vec;
extern bfd_target z8kcoff_vec;
@@ -467,6 +420,12 @@ bfd_target *target_vector[] = {
#ifdef TRAD_CORE
&trad_core_vec,
#endif
+#ifdef SCO_CORE
+ &sco_core_vec,
+#endif
+#ifdef AIX386_CORE
+ &aix386_core_vec,
+#endif
NULL, /* end of list marker */
};