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/ldemul.c | |
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/ldemul.c')
-rw-r--r-- | ld/ldemul.c | 155 |
1 files changed, 92 insertions, 63 deletions
diff --git a/ld/ldemul.c b/ld/ldemul.c index eafe26c..0e950d8 100644 --- a/ld/ldemul.c +++ b/ld/ldemul.c @@ -1,10 +1,11 @@ -/* Copyright (C) 1991 Free Software Foundation, Inc. +/* ldemul.c -- clearing house for ld emulation states + Copyright (C) 1991, 1993 Free Software Foundation, Inc. This file is part of GLD, the Gnu Linker. GLD 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 1, or (at your option) +the Free Software Foundation; either version 2, or (at your option) any later version. GLD is distributed in the hope that it will be useful, @@ -16,14 +17,6 @@ You should have received a copy of the GNU General Public License along with GLD; see the file COPYING. If not, write to the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ -/* - * $Id$ - */ - -/* - * clearing house for ld emulation states - */ - #include "bfd.h" #include "sysdep.h" @@ -31,30 +24,22 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "ld.h" #include "ldemul.h" #include "ldmisc.h" - -extern ld_emulation_xfer_type ld_lnk960_emulation; -extern ld_emulation_xfer_type ld_gldm88kbcs_emulation; -extern ld_emulation_xfer_type ld_gld_emulation; -extern ld_emulation_xfer_type ld_vanilla_emulation; -extern ld_emulation_xfer_type ld_gld68k_emulation; -extern ld_emulation_xfer_type ld_gld960_emulation; -extern ld_emulation_xfer_type ld_gld29k_emulation; -extern ld_emulation_xfer_type ld_gldnews_emulation; -extern ld_emulation_xfer_type ld_h8300hds_emulation; - +#include "ldfile.h" +#include "ldmain.h" +#include "ldemul-list.h" ld_emulation_xfer_type *ld_emulation; void ldemul_hll(name) -char *name; + char *name; { ld_emulation->hll(name); } void ldemul_syslib(name) -char *name; + char *name; { ld_emulation->syslib(name); } @@ -80,9 +65,8 @@ ldemul_after_allocation() void ldemul_before_allocation() { - if (ld_emulation->before_allocation) { + if (ld_emulation->before_allocation) ld_emulation->before_allocation(); - } } @@ -92,56 +76,101 @@ ldemul_set_output_arch() ld_emulation->set_output_arch(); } +void +ldemul_finish() +{ + if (ld_emulation->finish) + ld_emulation->finish(); +} + +void +ldemul_create_output_section_statements() +{ + if (ld_emulation->create_output_section_statements) + ld_emulation->create_output_section_statements(); +} + +char * +ldemul_get_script(isfile) + int *isfile; +{ + return ld_emulation->get_script(isfile); +} + char * ldemul_choose_target() { return ld_emulation->choose_target(); } +/* The default choose_target function. */ + char * -ldemul_get_script() +ldemul_default_target() { - return ld_emulation->get_script(); + char *from_outside = getenv(TARGET_ENVIRON); + if (from_outside != (char *)NULL) + return from_outside; + return ld_emulation->target_name; +} + +void +after_parse_default() +{ + } void -ldemul_choose_mode(target) -char *target; -{ - if (strcmp(target,LNK960_EMULATION_NAME)==0) { - ld_emulation = &ld_lnk960_emulation; - } - else if (strcmp(target,GLD960_EMULATION_NAME)==0) { - ld_emulation = &ld_gld960_emulation; - } - else if (strcmp(target,GLDM88KBCS_EMULATION_NAME)==0) { - ld_emulation = &ld_gldm88kbcs_emulation; - } -#ifndef GNU960 - else if (strcmp(target,GLD_EMULATION_NAME)==0) { - ld_emulation = &ld_gld_emulation; - } - else if (strcmp(target,VANILLA_EMULATION_NAME)==0) { - ld_emulation = &ld_vanilla_emulation; - } - else if (strcmp(target,H8300HDS_EMULATION_NAME)==0) { - ld_emulation = &ld_h8300hds_emulation; - } - - else if (strcmp(target,GLD68K_EMULATION_NAME)==0) { - ld_emulation = &ld_gld68k_emulation; - } - else if (strcmp(target,GLD29K_EMULATION_NAME)==0) { - ld_emulation = &ld_gld29k_emulation; - } - else if (strcmp(target,GLDNEWS_EMULATION_NAME)==0) { - ld_emulation = &ld_gldnews_emulation; - } -#endif - else { - info("%P%F unrecognised emulation mode: %s\n",target); - } +after_allocation_default() +{ + +} + +void +before_allocation_default() +{ + +} + +void +set_output_arch_default() +{ + /* Set the output architecture and machine if possible */ + bfd_set_arch_mach(output_bfd, + ldfile_output_architecture, ldfile_output_machine); } +void +syslib_default(ignore) + char *ignore; +{ + info_msg ("%S SYSLIB ignored\n"); +} +void +hll_default(ignore) + char *ignore; +{ + info_msg ("%S HLL ignored\n"); +} +ld_emulation_xfer_type *ld_emulations[] = { EMULATION_LIST }; + +void +ldemul_choose_mode(target) + char *target; +{ + ld_emulation_xfer_type **eptr = ld_emulations; + /* Ignore "gld" prefix. */ + if (target[0] == 'g' && target[1] == 'l' && target[2] == 'd') + target += 3; + for (; *eptr; eptr++) + { + if (strcmp(target, (*eptr)->emulation_name) == 0) + { + ld_emulation = *eptr; + return; + } + } + einfo("%P%F: unrecognised emulation mode: %s\n",target); +} |