diff options
author | Ian Lance Taylor <ian@airs.com> | 1993-12-30 19:51:41 +0000 |
---|---|---|
committer | Ian Lance Taylor <ian@airs.com> | 1993-12-30 19:51:41 +0000 |
commit | 4a6afc88bb00a7da893e2437d1d3c068c435a85e (patch) | |
tree | 7c15b83d41350f8d615b564bb20f9c52093f8dcf /ld/emultempl | |
parent | 9a0418eb7b625b7381965fd850786e06e34e1816 (diff) | |
download | gdb-4a6afc88bb00a7da893e2437d1d3c068c435a85e.zip gdb-4a6afc88bb00a7da893e2437d1d3c068c435a85e.tar.gz gdb-4a6afc88bb00a7da893e2437d1d3c068c435a85e.tar.bz2 |
A major rewrite to move the bulk of the linker into BFD so that
more efficient backend code can be written for specific object
files.
* lderror.c, lderror.h, ldindr.c, ldindr.h, ldsym.c, ldsym.h,
ldwarn.c, ldwarn.h, relax.c, relax.h: Removed.
* ldctor.c, ldctor.h: Complete rewrite.
* ldwrite.c, ldwrite.h: Complete rewrite.
* ld.h (strip_symbols_type, strip_symbols): Removed. Use
link_info.strip instead. Changed all uses.
(discard_locals_type, discard_locals): Removed. Use
link_info.discard instead. Changed all uses.
(ld_config_type): Removed relocateable_output field; use
link_info.relocateable instead; changed all uses. Added stats
field.
(set_asymbol_chain, get_asymbol_chain, get_loader_symbol,
set_loader_symbol): Removed.
* ldexp.h (node_class): Added etree_rel.
(etree_type): Added rel field.
* ldexp.c (exp_print_token): Bracketed table initialization.
(exp_relop): New function.
(fold_name): Use linker hash table rather than ldsym functions.
(exp_fold_tree): Likewise. Also, handle etree_rel case.
(exp_print_tree): Handle etree_rel.
* ldgram.y (strip_symbols, discard_locals): Removed.
(OPTION_stats, OPTION_no_keep_memory): New tokens. Handle them.
(REL): New token. Does not appear in grammar, but needed for
expression code.
(file): Don't call lang_final; it's called by main anyhow.
* ldlex.l: Accept -stats and -no-keep-memory options.
* ldlang.h (fill_type): Make unsigned int, not unsigned short.
* ldlang.c: Consistently use fill_type for fill argument.
(lang_init_script_file, script_file): Removed.
(create_object_symbols): Removed. Use
link_info.create_object_symbols_section instead. Changed all
uses.
(lang_add_keepsyms_file): Removed.
(lookup_name): Call bfd_link_add_symbols instead of
ldmain_open_file_read_symbol.
(wild): Don't iterate over script_file.
(open_output): Create link hash table.
(lang_place_undefineds): Rewrote.
(lang_size_sections): Handle relaxing (doesn't work yet).
(lang_relocate_globals): Removed.
(lang_finish): Use link hash table rather than ldsym functions.
(lang_common): Rewrote.
(lang_one_common): New function.
(ldlang_add_file): Add file to link_info.input_bfds list. Set
usrdata.
(create_symbol): Removed.
(lang_process): Don't call lang_init_script_file. Call
ldctor_build_sets rather than find_constructors. Don't call
lang_relocate_globals.
(lang_abs_symbol_at_beginning_of): Rewrote.
(lang_abs_symbol_at_end_of): Rewrote.
* ldmain.c (had_y): Removed.
(lprefix, lprefix_len): Removed; use link_info fields instead.
Changed all uses.
(multiple_def_count, commons_pending, undefined_global_sym_count,
total_symbols_seen, total_files_seen): Removed.
(link_callbacks, link_info): New variables.
(main): Initialize link_info. Don't call init_bfd_error_vector or
ldsym_init. Don't set now unused variables. Handle -stats.
(get_emulation): Removed obsolete and nonfunctional GNU960 code.
(add_ysym): Rewrote.
(read_entry_symbols, refize, enter_global_ref, enter_file_symbols,
search_library, gnu960_check_format, decode_library_subfile,
linear_library, symdef_library, clear_syms, subfile_wanted_p):
Removed.
(add_keepsyms_file, add_archive_element, multiple_definition,
multiple_common, add_to_set, warning_callback, undefined_symbol,
reloc_overflow, reloc_dangerous, unattached_reloc, notice_ysym):
New functions.
* ldmisc.c (vfinfo): Accept a string for %T, not a symbol. Don't
require symbols for %C; look them up instead.
* emultempl/hppaosf.em: Pass link_info to
hppa_look_for_stubs_in_section.
* Makefile.in: Rebuilt dependencies.
(CFILES): Removed lderror.c, ldindr.c, ldsym.c, ldwarn.c, and
relax.c.
(HFILES): Removed lderror.h, ldindr.h, ldsym.h, ldwarn.h, and
relax.h.
(EMULATION_OFILES): Depend on bfdlink.h, ldmain.h, ldexp.h,
ldlang.h and ldctor.h.
* Makefile.in (ldlex.c): Don't depend on ldgram.h. Remove
declarations of free and malloc from flex output. Change malloc
to ldmalloc in flex output.
Diffstat (limited to 'ld/emultempl')
-rw-r--r-- | ld/emultempl/hppaosf.em | 43 | ||||
-rw-r--r-- | ld/emultempl/m88kbcs.em | 28 |
2 files changed, 23 insertions, 48 deletions
diff --git a/ld/emultempl/hppaosf.em b/ld/emultempl/hppaosf.em index 0bd2318..e363722 100644 --- a/ld/emultempl/hppaosf.em +++ b/ld/emultempl/hppaosf.em @@ -2,7 +2,7 @@ # It does some substitutions. cat >em_${EMULATION_NAME}.c <<EOF /* An emulation for HP PA-RISC OSF/1 linkers. - Copyright (C) 1991 Free Software Foundation, Inc. + Copyright (C) 1991, 1993 Free Software Foundation, Inc. Written by Steve Chamberlain steve@cygnus.com This file is part of GLD, the Gnu Linker. @@ -23,7 +23,7 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "bfd.h" #include "sysdep.h" - +#include "bfdlink.h" #include "ld.h" #include "config.h" @@ -32,22 +32,13 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "ldexp.h" #include "ldlang.h" #include "ldmisc.h" - -extern boolean lang_float_flag; - - -extern enum bfd_architecture ldfile_output_architecture; -extern unsigned long ldfile_output_machine; -extern char *ldfile_output_machine_name; - -extern bfd *output_bfd; +#include "ldmain.h" +#include "ldctor.h" static void hppaosf_before_parse() { - extern char *lprefix; - extern unsigned int lprefix_len; - lprefix = "L$"; - lprefix_len = 2; + link_info.lprefix = "L$"; + link_info.lprefix_len = 2; ldfile_output_architecture = bfd_arch_hppa; } @@ -56,10 +47,6 @@ static lang_input_statement_type *stub_file = 0; static lang_input_section_type *stub_input_section = NULL; -extern lang_statement_list_type *stat_ptr; -/* List of statements needed to handle constructors */ -extern lang_statement_list_type constructor_list; - static void hppaosf_search_for_padding_statements(s,prev) lang_statement_union_type *s; @@ -112,9 +99,8 @@ static void hppaosf_finish() { extern asymbol *hppa_look_for_stubs_in_section(); - extern ld_config_type config; - if (config.relocateable_output == false) + if (link_info.relocateable == false) { /* check for needed stubs */ LANG_FOR_EACH_INPUT_SECTION @@ -128,7 +114,8 @@ hppaosf_finish() output_bfd, section, statement->asymbols, - &new_sym_cnt); + &new_sym_cnt, + &link_info); if ( (new_sym_cnt > 0) && syms ) { @@ -245,13 +232,11 @@ $s/$/n}"/ cat >>em_${EMULATION_NAME}.c <<EOF { - extern ld_config_type config; - *isfile = 0; - if (config.relocateable_output == true && config.build_constructors == true) + if (link_info.relocateable == true && config.build_constructors == true) return `sed "$sc" ldscripts/${EMULATION_NAME}.xu`; - else if (config.relocateable_output == true) + else if (link_info.relocateable == true) return `sed "$sc" ldscripts/${EMULATION_NAME}.xr`; else if (!config.text_read_only) return `sed "$sc" ldscripts/${EMULATION_NAME}.xbn`; @@ -267,13 +252,11 @@ else cat >>em_${EMULATION_NAME}.c <<EOF { - extern ld_config_type config; - *isfile = 1; - if (config.relocateable_output == true && config.build_constructors == true) + if (link_info.relocateable == true && config.build_constructors == true) return "ldscripts/${EMULATION_NAME}.xu"; - else if (config.relocateable_output == true) + else if (link_info.relocateable == true) return "ldscripts/${EMULATION_NAME}.xr"; else if (!config.text_read_only) return "ldscripts/${EMULATION_NAME}.xbn"; diff --git a/ld/emultempl/m88kbcs.em b/ld/emultempl/m88kbcs.em index 77b726f..a142450 100644 --- a/ld/emultempl/m88kbcs.em +++ b/ld/emultempl/m88kbcs.em @@ -4,7 +4,7 @@ cat >em_${EMULATION_NAME}.c <<EOF /* This file is is generated by a shell script. DO NOT EDIT! */ /* emulate the original gld for the given ${EMULATION_NAME} - Copyright (C) 1991 Free Software Foundation, Inc. + Copyright (C) 1991, 1993 Free Software Foundation, Inc. Written by Steve Chamberlain steve@cygnus.com This file is part of GLD, the Gnu Linker. @@ -27,24 +27,20 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "bfd.h" #include "sysdep.h" +#include "bfdlink.h" + #include "ld.h" #include "config.h" #include "ldemul.h" #include "ldfile.h" #include "ldmisc.h" - -extern boolean lang_float_flag; - -extern enum bfd_architecture ldfile_output_architecture; -extern unsigned long ldfile_output_machine; -extern char *ldfile_output_machine_name; +#include "ldmain.h" static void gld${EMULATION_NAME}_before_parse() { - extern char *lprefix; - lprefix = "@"; - lprefix_len = 1; + link_info.lprefix = "@"; + link_info.lprefix_len = 1; ldfile_output_architecture = bfd_arch_${ARCH}; } @@ -67,13 +63,11 @@ $s/$/n}"/ cat >>em_${EMULATION_NAME}.c <<EOF { - extern ld_config_type config; - *isfile = 0; - if (config.relocateable_output == true && config.build_constructors == true) + if (link_info.relocateable == true && config.build_constructors == true) return `sed "$sc" ldscripts/${EMULATION_NAME}.xu`; - else if (config.relocateable_output == true) + else if (link_info.relocateable == true) return `sed "$sc" ldscripts/${EMULATION_NAME}.xr`; else if (!config.text_read_only) return `sed "$sc" ldscripts/${EMULATION_NAME}.xbn`; @@ -89,13 +83,11 @@ else cat >>em_${EMULATION_NAME}.c <<EOF { - extern ld_config_type config; - *isfile = 1; - if (config.relocateable_output == true && config.build_constructors == true) + if (link_info.relocateable == true && config.build_constructors == true) return "ldscripts/${EMULATION_NAME}.xu"; - else if (config.relocateable_output == true) + else if (link_info.relocateable == true) return "ldscripts/${EMULATION_NAME}.xr"; else if (!config.text_read_only) return "ldscripts/${EMULATION_NAME}.xbn"; |