Home | History | Annotate | Line # | Download | only in ld
ldmain.c revision 1.5
      1 /* Main program of GNU linker.
      2    Copyright (C) 1991-2015 Free Software Foundation, Inc.
      3    Written by Steve Chamberlain steve (at) cygnus.com
      4 
      5    This file is part of the GNU Binutils.
      6 
      7    This program is free software; you can redistribute it and/or modify
      8    it under the terms of the GNU General Public License as published by
      9    the Free Software Foundation; either version 3 of the License, or
     10    (at your option) any later version.
     11 
     12    This program is distributed in the hope that it will be useful,
     13    but WITHOUT ANY WARRANTY; without even the implied warranty of
     14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     15    GNU General Public License for more details.
     16 
     17    You should have received a copy of the GNU General Public License
     18    along with this program; if not, write to the Free Software
     19    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
     20    MA 02110-1301, USA.  */
     21 
     22 #include "sysdep.h"
     23 #include "bfd.h"
     24 #include "safe-ctype.h"
     25 #include "libiberty.h"
     26 #include "progress.h"
     27 #include "bfdlink.h"
     28 #include "filenames.h"
     29 
     30 #include "ld.h"
     31 #include "ldmain.h"
     32 #include "ldmisc.h"
     33 #include "ldwrite.h"
     34 #include "ldexp.h"
     35 #include "ldlang.h"
     36 #include <ldgram.h>
     37 #include "ldlex.h"
     38 #include "ldfile.h"
     39 #include "ldemul.h"
     40 #include "ldctor.h"
     41 #ifdef ENABLE_PLUGINS
     42 #include "plugin.h"
     43 #include "plugin-api.h"
     44 #endif /* ENABLE_PLUGINS */
     45 
     46 /* Somewhere above, sys/stat.h got included.  */
     47 #if !defined(S_ISDIR) && defined(S_IFDIR)
     48 #define	S_ISDIR(m) (((m) & S_IFMT) == S_IFDIR)
     49 #endif
     50 
     51 #include <string.h>
     52 
     53 #ifdef HAVE_SBRK
     54 #if !HAVE_DECL_SBRK
     55 extern void *sbrk ();
     56 #endif
     57 #endif
     58 
     59 #ifndef TARGET_SYSTEM_ROOT
     60 #define TARGET_SYSTEM_ROOT ""
     61 #endif
     62 
     63 /* EXPORTS */
     64 
     65 FILE *saved_script_handle = NULL;
     66 FILE *previous_script_handle = NULL;
     67 bfd_boolean force_make_executable = FALSE;
     68 
     69 char *default_target;
     70 const char *output_filename = "a.out";
     71 
     72 /* Name this program was invoked by.  */
     73 char *program_name;
     74 
     75 /* The prefix for system library directories.  */
     76 const char *ld_sysroot;
     77 
     78 /* The canonical representation of ld_sysroot.  */
     79 char * ld_canon_sysroot;
     80 int ld_canon_sysroot_len;
     81 
     82 /* Set by -G argument, for targets like MIPS ELF.  */
     83 int g_switch_value = 8;
     84 
     85 /* Nonzero means print names of input files as processed.  */
     86 bfd_boolean trace_files;
     87 
     88 /* Nonzero means report actions taken by the linker, and describe the linker script in use.  */
     89 bfd_boolean verbose;
     90 
     91 /* Nonzero means version number was printed, so exit successfully
     92    instead of complaining if no input files are given.  */
     93 bfd_boolean version_printed;
     94 
     95 /* TRUE if we should demangle symbol names.  */
     96 bfd_boolean demangling;
     97 
     98 args_type command_line;
     99 
    100 ld_config_type config;
    101 
    102 sort_type sort_section;
    103 
    104 static const char *get_sysroot
    105   (int, char **);
    106 static char *get_emulation
    107   (int, char **);
    108 static bfd_boolean add_archive_element
    109   (struct bfd_link_info *, bfd *, const char *, bfd **);
    110 static bfd_boolean multiple_definition
    111   (struct bfd_link_info *, struct bfd_link_hash_entry *,
    112    bfd *, asection *, bfd_vma);
    113 static bfd_boolean multiple_common
    114   (struct bfd_link_info *, struct bfd_link_hash_entry *,
    115    bfd *, enum bfd_link_hash_type, bfd_vma);
    116 static bfd_boolean add_to_set
    117   (struct bfd_link_info *, struct bfd_link_hash_entry *,
    118    bfd_reloc_code_real_type, bfd *, asection *, bfd_vma);
    119 static bfd_boolean constructor_callback
    120   (struct bfd_link_info *, bfd_boolean, const char *, bfd *,
    121    asection *, bfd_vma);
    122 static bfd_boolean warning_callback
    123   (struct bfd_link_info *, const char *, const char *, bfd *,
    124    asection *, bfd_vma);
    125 static void warning_find_reloc
    126   (bfd *, asection *, void *);
    127 static bfd_boolean undefined_symbol
    128   (struct bfd_link_info *, const char *, bfd *, asection *, bfd_vma,
    129    bfd_boolean);
    130 static bfd_boolean reloc_overflow
    131   (struct bfd_link_info *, struct bfd_link_hash_entry *, const char *,
    132    const char *, bfd_vma, bfd *, asection *, bfd_vma);
    133 static bfd_boolean reloc_dangerous
    134   (struct bfd_link_info *, const char *, bfd *, asection *, bfd_vma);
    135 static bfd_boolean unattached_reloc
    136   (struct bfd_link_info *, const char *, bfd *, asection *, bfd_vma);
    137 static bfd_boolean notice
    138   (struct bfd_link_info *, struct bfd_link_hash_entry *,
    139    struct bfd_link_hash_entry *, bfd *, asection *, bfd_vma, flagword);
    140 
    141 static struct bfd_link_callbacks link_callbacks =
    142 {
    143   add_archive_element,
    144   multiple_definition,
    145   multiple_common,
    146   add_to_set,
    147   constructor_callback,
    148   warning_callback,
    149   undefined_symbol,
    150   reloc_overflow,
    151   reloc_dangerous,
    152   unattached_reloc,
    153   notice,
    154   einfo,
    155   info_msg,
    156   minfo,
    157   ldlang_override_segment_assignment
    158 };
    159 
    160 static bfd_assert_handler_type default_bfd_assert_handler;
    161 
    162 struct bfd_link_info link_info;
    163 
    164 static void
    166 ld_cleanup (void)
    167 {
    168   bfd_cache_close_all ();
    169 #ifdef ENABLE_PLUGINS
    170   plugin_call_cleanup ();
    171 #endif
    172   if (output_filename && delete_output_file_on_failure)
    173     unlink_if_ordinary (output_filename);
    174 }
    175 
    176 /* If there's a BFD assertion, we'll notice and exit with an error
    177    unless otherwise instructed.  */
    178 
    179 static void
    180 ld_bfd_assert_handler (const char *fmt, const char *bfdver,
    181 		       const char *file, int line)
    182 {
    183   (*default_bfd_assert_handler) (fmt, bfdver, file, line);
    184   config.make_executable = FALSE;
    185 }
    186 
    187 int
    188 main (int argc, char **argv)
    189 {
    190   char *emulation;
    191   long start_time = get_run_time ();
    192 #ifdef HAVE_SBRK
    193   char *start_sbrk = (char *) sbrk (0);
    194 #endif
    195 
    196 #if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
    197   setlocale (LC_MESSAGES, "");
    198 #endif
    199 #if defined (HAVE_SETLOCALE)
    200   setlocale (LC_CTYPE, "");
    201 #endif
    202   bindtextdomain (PACKAGE, LOCALEDIR);
    203   textdomain (PACKAGE);
    204 
    205   program_name = argv[0];
    206   xmalloc_set_program_name (program_name);
    207 
    208   START_PROGRESS (program_name, 0);
    209 
    210   expandargv (&argc, &argv);
    211 
    212   bfd_init ();
    213 
    214   bfd_set_error_program_name (program_name);
    215 
    216   /* We want to notice and fail on those nasty BFD assertions which are
    217      likely to signal incorrect output being generated but otherwise may
    218      leave no trace.  */
    219   default_bfd_assert_handler = bfd_set_assert_handler (ld_bfd_assert_handler);
    220 
    221   xatexit (ld_cleanup);
    222 
    223   /* Set up the sysroot directory.  */
    224   ld_sysroot = get_sysroot (argc, argv);
    225   if (*ld_sysroot)
    226     ld_canon_sysroot = lrealpath (ld_sysroot);
    227   if (ld_canon_sysroot)
    228     ld_canon_sysroot_len = strlen (ld_canon_sysroot);
    229   else
    230     ld_canon_sysroot_len = -1;
    231 
    232   /* Set the default BFD target based on the configured target.  Doing
    233      this permits the linker to be configured for a particular target,
    234      and linked against a shared BFD library which was configured for
    235      a different target.  The macro TARGET is defined by Makefile.  */
    236   if (! bfd_set_default_target (TARGET))
    237     {
    238       einfo (_("%X%P: can't set BFD default target to `%s': %E\n"), TARGET);
    239       xexit (1);
    240     }
    241 
    242 #if YYDEBUG
    243   {
    244     extern int yydebug;
    245     yydebug = 1;
    246   }
    247 #endif
    248 
    249   config.build_constructors = TRUE;
    250   config.rpath_separator = ':';
    251   config.split_by_reloc = (unsigned) -1;
    252   config.split_by_file = (bfd_size_type) -1;
    253   config.make_executable = TRUE;
    254   config.magic_demand_paged = TRUE;
    255   config.text_read_only = TRUE;
    256   link_info.disable_target_specific_optimizations = -1;
    257 
    258   command_line.warn_mismatch = TRUE;
    259   command_line.warn_search_mismatch = TRUE;
    260   command_line.check_section_addresses = -1;
    261 
    262   /* We initialize DEMANGLING based on the environment variable
    263      COLLECT_NO_DEMANGLE.  The gcc collect2 program will demangle the
    264      output of the linker, unless COLLECT_NO_DEMANGLE is set in the
    265      environment.  Acting the same way here lets us provide the same
    266      interface by default.  */
    267   demangling = getenv ("COLLECT_NO_DEMANGLE") == NULL;
    268 
    269   link_info.allow_undefined_version = TRUE;
    270   link_info.keep_memory = TRUE;
    271   link_info.combreloc = TRUE;
    272   link_info.strip_discarded = TRUE;
    273   link_info.emit_hash = TRUE;
    274   link_info.callbacks = &link_callbacks;
    275   link_info.input_bfds_tail = &link_info.input_bfds;
    276   /* SVR4 linkers seem to set DT_INIT and DT_FINI based on magic _init
    277      and _fini symbols.  We are compatible.  */
    278   link_info.init_function = "_init";
    279   link_info.fini_function = "_fini";
    280   link_info.relax_pass = 1;
    281   link_info.extern_protected_data = -1;
    282   link_info.pei386_auto_import = -1;
    283   link_info.spare_dynamic_tags = 5;
    284   link_info.path_separator = ':';
    285 #ifdef DEFAULT_FLAG_COMPRESS_DEBUG
    286   link_info.compress_debug = COMPRESS_DEBUG_GABI_ZLIB;
    287 #endif
    288 
    289   ldfile_add_arch ("");
    290   emulation = get_emulation (argc, argv);
    291   ldemul_choose_mode (emulation);
    292   default_target = ldemul_choose_target (argc, argv);
    293   config.maxpagesize = bfd_emul_get_maxpagesize (default_target);
    294   config.commonpagesize = bfd_emul_get_commonpagesize (default_target);
    295   lang_init ();
    296   ldexp_init ();
    297   ldemul_before_parse ();
    298   lang_has_input_file = FALSE;
    299   parse_args (argc, argv);
    300 
    301   if (config.hash_table_size != 0)
    302     bfd_hash_set_default_size (config.hash_table_size);
    303 
    304 #ifdef ENABLE_PLUGINS
    305   /* Now all the plugin arguments have been gathered, we can load them.  */
    306   plugin_load_plugins ();
    307 #endif /* ENABLE_PLUGINS */
    308 
    309   ldemul_set_symbols ();
    310 
    311   /* If we have not already opened and parsed a linker script,
    312      try the default script from command line first.  */
    313   if (saved_script_handle == NULL
    314       && command_line.default_script != NULL)
    315     {
    316       ldfile_open_command_file (command_line.default_script);
    317       parser_input = input_script;
    318       yyparse ();
    319     }
    320 
    321   /* If we have not already opened and parsed a linker script
    322      read the emulation's appropriate default script.  */
    323   if (saved_script_handle == NULL)
    324     {
    325       int isfile;
    326       char *s = ldemul_get_script (&isfile);
    327 
    328       if (isfile)
    329 	ldfile_open_default_command_file (s);
    330       else
    331 	{
    332 	  lex_string = s;
    333 	  lex_redirect (s, _("built in linker script"), 1);
    334 	}
    335       parser_input = input_script;
    336       yyparse ();
    337       lex_string = NULL;
    338     }
    339 
    340   if (verbose)
    341     {
    342       if (saved_script_handle)
    343 	info_msg (_("using external linker script:"));
    344       else
    345 	info_msg (_("using internal linker script:"));
    346       info_msg ("\n==================================================\n");
    347 
    348       if (saved_script_handle)
    349 	{
    350 	  static const int ld_bufsz = 8193;
    351 	  size_t n;
    352 	  char *buf = (char *) xmalloc (ld_bufsz);
    353 
    354 	  rewind (saved_script_handle);
    355 	  while ((n = fread (buf, 1, ld_bufsz - 1, saved_script_handle)) > 0)
    356 	    {
    357 	      buf[n] = 0;
    358 	      info_msg (buf);
    359 	    }
    360 	  rewind (saved_script_handle);
    361 	  free (buf);
    362 	}
    363       else
    364 	{
    365 	  int isfile;
    366 
    367 	  info_msg (ldemul_get_script (&isfile));
    368 	}
    369 
    370       info_msg ("\n==================================================\n");
    371     }
    372 
    373   if (command_line.print_output_format)
    374     info_msg ("%s\n", lang_get_output_target ());
    375 
    376   lang_final ();
    377 
    378   /* If the only command line argument has been -v or --version or --verbose
    379      then ignore any input files provided by linker scripts and exit now.
    380      We do not want to create an output file when the linker is just invoked
    381      to provide version information.  */
    382   if (argc == 2 && version_printed)
    383     xexit (0);
    384 
    385   if (!lang_has_input_file)
    386     {
    387       if (version_printed || command_line.print_output_format)
    388 	xexit (0);
    389       einfo (_("%P%F: no input files\n"));
    390     }
    391 
    392   if (trace_files)
    393     info_msg (_("%P: mode %s\n"), emulation);
    394 
    395   ldemul_after_parse ();
    396 
    397   if (config.map_filename)
    398     {
    399       if (strcmp (config.map_filename, "-") == 0)
    400 	{
    401 	  config.map_file = stdout;
    402 	}
    403       else
    404 	{
    405 	  config.map_file = fopen (config.map_filename, FOPEN_WT);
    406 	  if (config.map_file == (FILE *) NULL)
    407 	    {
    408 	      bfd_set_error (bfd_error_system_call);
    409 	      einfo (_("%P%F: cannot open map file %s: %E\n"),
    410 		     config.map_filename);
    411 	    }
    412 	}
    413     }
    414 
    415   lang_process ();
    416 
    417   /* Print error messages for any missing symbols, for any warning
    418      symbols, and possibly multiple definitions.  */
    419   if (bfd_link_relocatable (&link_info))
    420     link_info.output_bfd->flags &= ~EXEC_P;
    421   else
    422     link_info.output_bfd->flags |= EXEC_P;
    423 
    424   if ((link_info.compress_debug & COMPRESS_DEBUG))
    425     {
    426       link_info.output_bfd->flags |= BFD_COMPRESS;
    427       if (link_info.compress_debug == COMPRESS_DEBUG_GABI_ZLIB)
    428 	link_info.output_bfd->flags |= BFD_COMPRESS_GABI;
    429     }
    430 
    431   ldwrite ();
    432 
    433   if (config.map_file != NULL)
    434     lang_map ();
    435   if (command_line.cref)
    436     output_cref (config.map_file != NULL ? config.map_file : stdout);
    437   if (nocrossref_list != NULL)
    438     check_nocrossrefs ();
    439   if (command_line.print_memory_usage)
    440     lang_print_memory_usage ();
    441 #if 0
    442   {
    443     struct bfd_link_hash_entry * h;
    444 
    445     h = bfd_link_hash_lookup (link_info.hash, "__image_base__", 0,0,1);
    446     fprintf (stderr, "lookup = %p val %lx\n", h, h ? h->u.def.value : 1);
    447   }
    448 #endif
    449   ldexp_finish ();
    450   lang_finish ();
    451 
    452   /* Even if we're producing relocatable output, some non-fatal errors should
    453      be reported in the exit status.  (What non-fatal errors, if any, do we
    454      want to ignore for relocatable output?)  */
    455   if (!config.make_executable && !force_make_executable)
    456     {
    457       if (trace_files)
    458 	einfo (_("%P: link errors found, deleting executable `%s'\n"),
    459 	       output_filename);
    460 
    461       /* The file will be removed by ld_cleanup.  */
    462       xexit (1);
    463     }
    464   else
    465     {
    466       if (! bfd_close (link_info.output_bfd))
    467 	einfo (_("%F%B: final close failed: %E\n"), link_info.output_bfd);
    468 
    469       /* If the --force-exe-suffix is enabled, and we're making an
    470 	 executable file and it doesn't end in .exe, copy it to one
    471 	 which does.  */
    472       if (!bfd_link_relocatable (&link_info)
    473 	  && command_line.force_exe_suffix)
    474 	{
    475 	  int len = strlen (output_filename);
    476 
    477 	  if (len < 4
    478 	      || (strcasecmp (output_filename + len - 4, ".exe") != 0
    479 		  && strcasecmp (output_filename + len - 4, ".dll") != 0))
    480 	    {
    481 	      FILE *src;
    482 	      FILE *dst;
    483 	      const int bsize = 4096;
    484 	      char *buf = (char *) xmalloc (bsize);
    485 	      int l;
    486 	      char *dst_name = (char *) xmalloc (len + 5);
    487 
    488 	      strcpy (dst_name, output_filename);
    489 	      strcat (dst_name, ".exe");
    490 	      src = fopen (output_filename, FOPEN_RB);
    491 	      dst = fopen (dst_name, FOPEN_WB);
    492 
    493 	      if (!src)
    494 		einfo (_("%P%F: unable to open for source of copy `%s'\n"),
    495 		       output_filename);
    496 	      if (!dst)
    497 		einfo (_("%P%F: unable to open for destination of copy `%s'\n"),
    498 		       dst_name);
    499 	      while ((l = fread (buf, 1, bsize, src)) > 0)
    500 		{
    501 		  int done = fwrite (buf, 1, l, dst);
    502 
    503 		  if (done != l)
    504 		    einfo (_("%P: Error writing file `%s'\n"), dst_name);
    505 		}
    506 
    507 	      fclose (src);
    508 	      if (fclose (dst) == EOF)
    509 		einfo (_("%P: Error closing file `%s'\n"), dst_name);
    510 	      free (dst_name);
    511 	      free (buf);
    512 	    }
    513 	}
    514     }
    515 
    516   END_PROGRESS (program_name);
    517 
    518   if (config.stats)
    519     {
    520 #ifdef HAVE_SBRK
    521       char *lim = (char *) sbrk (0);
    522 #endif
    523       long run_time = get_run_time () - start_time;
    524 
    525       fflush (stdout);
    526       fprintf (stderr, _("%s: total time in link: %ld.%06ld\n"),
    527 	       program_name, run_time / 1000000, run_time % 1000000);
    528 #ifdef HAVE_SBRK
    529       fprintf (stderr, _("%s: data size %ld\n"), program_name,
    530 	       (long) (lim - start_sbrk));
    531 #endif
    532       fflush (stderr);
    533     }
    534 
    535   /* Prevent ld_cleanup from doing anything, after a successful link.  */
    536   output_filename = NULL;
    537 
    538   xexit (0);
    539   return 0;
    540 }
    541 
    542 /* If the configured sysroot is relocatable, try relocating it based on
    543    default prefix FROM.  Return the relocated directory if it exists,
    544    otherwise return null.  */
    545 
    546 static char *
    547 get_relative_sysroot (const char *from ATTRIBUTE_UNUSED)
    548 {
    549 #ifdef TARGET_SYSTEM_ROOT_RELOCATABLE
    550   char *path;
    551   struct stat s;
    552 
    553   path = make_relative_prefix (program_name, from, TARGET_SYSTEM_ROOT);
    554   if (path)
    555     {
    556       if (stat (path, &s) == 0 && S_ISDIR (s.st_mode))
    557 	return path;
    558       free (path);
    559     }
    560 #endif
    561   return 0;
    562 }
    563 
    564 /* Return the sysroot directory.  Return "" if no sysroot is being used.  */
    565 
    566 static const char *
    567 get_sysroot (int argc, char **argv)
    568 {
    569   int i;
    570   const char *path;
    571 
    572   for (i = 1; i < argc; i++)
    573     if (CONST_STRNEQ (argv[i], "--sysroot="))
    574       return argv[i] + strlen ("--sysroot=");
    575 
    576   path = get_relative_sysroot (BINDIR);
    577   if (path)
    578     return path;
    579 
    580   path = get_relative_sysroot (TOOLBINDIR);
    581   if (path)
    582     return path;
    583 
    584   return TARGET_SYSTEM_ROOT;
    585 }
    586 
    587 /* We need to find any explicitly given emulation in order to initialize the
    588    state that's needed by the lex&yacc argument parser (parse_args).  */
    589 
    590 static char *
    591 get_emulation (int argc, char **argv)
    592 {
    593   char *emulation;
    594   int i;
    595 
    596   emulation = getenv (EMULATION_ENVIRON);
    597   if (emulation == NULL)
    598     emulation = DEFAULT_EMULATION;
    599 
    600   for (i = 1; i < argc; i++)
    601     {
    602       if (CONST_STRNEQ (argv[i], "-m"))
    603 	{
    604 	  if (argv[i][2] == '\0')
    605 	    {
    606 	      /* -m EMUL */
    607 	      if (i < argc - 1)
    608 		{
    609 		  emulation = argv[i + 1];
    610 		  i++;
    611 		}
    612 	      else
    613 		einfo (_("%P%F: missing argument to -m\n"));
    614 	    }
    615 	  else if (strcmp (argv[i], "-mips1") == 0
    616 		   || strcmp (argv[i], "-mips2") == 0
    617 		   || strcmp (argv[i], "-mips3") == 0
    618 		   || strcmp (argv[i], "-mips4") == 0
    619 		   || strcmp (argv[i], "-mips5") == 0
    620 		   || strcmp (argv[i], "-mips32") == 0
    621 		   || strcmp (argv[i], "-mips32r2") == 0
    622 		   || strcmp (argv[i], "-mips32r6") == 0
    623 		   || strcmp (argv[i], "-mips64") == 0
    624 		   || strcmp (argv[i], "-mips64r2") == 0
    625 		   || strcmp (argv[i], "-mips64r6") == 0)
    626 	    {
    627 	      /* FIXME: The arguments -mips1, -mips2, -mips3, etc. are
    628 		 passed to the linker by some MIPS compilers.  They
    629 		 generally tell the linker to use a slightly different
    630 		 library path.  Perhaps someday these should be
    631 		 implemented as emulations; until then, we just ignore
    632 		 the arguments and hope that nobody ever creates
    633 		 emulations named ips1, ips2 or ips3.  */
    634 	    }
    635 	  else if (strcmp (argv[i], "-m486") == 0)
    636 	    {
    637 	      /* FIXME: The argument -m486 is passed to the linker on
    638 		 some Linux systems.  Hope that nobody creates an
    639 		 emulation named 486.  */
    640 	    }
    641 	  else
    642 	    {
    643 	      /* -mEMUL */
    644 	      emulation = &argv[i][2];
    645 	    }
    646 	}
    647     }
    648 
    649   return emulation;
    650 }
    651 
    652 void
    653 add_ysym (const char *name)
    654 {
    655   if (link_info.notice_hash == NULL)
    656     {
    657       link_info.notice_hash =
    658           (struct bfd_hash_table *) xmalloc (sizeof (struct bfd_hash_table));
    659       if (!bfd_hash_table_init_n (link_info.notice_hash,
    660 				  bfd_hash_newfunc,
    661 				  sizeof (struct bfd_hash_entry),
    662 				  61))
    663 	einfo (_("%P%F: bfd_hash_table_init failed: %E\n"));
    664     }
    665 
    666   if (bfd_hash_lookup (link_info.notice_hash, name, TRUE, TRUE) == NULL)
    667     einfo (_("%P%F: bfd_hash_lookup failed: %E\n"));
    668 }
    669 
    670 void
    671 add_ignoresym (struct bfd_link_info *info, const char *name)
    672 {
    673   if (info->ignore_hash == NULL)
    674     {
    675       info->ignore_hash = xmalloc (sizeof (struct bfd_hash_table));
    676       if (! bfd_hash_table_init_n (info->ignore_hash,
    677 				   bfd_hash_newfunc,
    678 				   sizeof (struct bfd_hash_entry),
    679 				   61))
    680 	einfo (_("%P%F: bfd_hash_table_init failed: %E\n"));
    681     }
    682 
    683   if (bfd_hash_lookup (info->ignore_hash, name, TRUE, TRUE) == NULL)
    684     einfo (_("%P%F: bfd_hash_lookup failed: %E\n"));
    685 }
    686 
    687 /* Record a symbol to be wrapped, from the --wrap option.  */
    688 
    689 void
    690 add_wrap (const char *name)
    691 {
    692   if (link_info.wrap_hash == NULL)
    693     {
    694       link_info.wrap_hash =
    695           (struct bfd_hash_table *) xmalloc (sizeof (struct bfd_hash_table));
    696       if (!bfd_hash_table_init_n (link_info.wrap_hash,
    697 				  bfd_hash_newfunc,
    698 				  sizeof (struct bfd_hash_entry),
    699 				  61))
    700 	einfo (_("%P%F: bfd_hash_table_init failed: %E\n"));
    701     }
    702 
    703   if (bfd_hash_lookup (link_info.wrap_hash, name, TRUE, TRUE) == NULL)
    704     einfo (_("%P%F: bfd_hash_lookup failed: %E\n"));
    705 }
    706 
    707 /* Handle the -retain-symbols-file option.  */
    708 
    709 void
    710 add_keepsyms_file (const char *filename)
    711 {
    712   FILE *file;
    713   char *buf;
    714   size_t bufsize;
    715   int c;
    716 
    717   if (link_info.strip == strip_some)
    718     einfo (_("%X%P: error: duplicate retain-symbols-file\n"));
    719 
    720   file = fopen (filename, "r");
    721   if (file == NULL)
    722     {
    723       bfd_set_error (bfd_error_system_call);
    724       einfo ("%X%P: %s: %E\n", filename);
    725       return;
    726     }
    727 
    728   link_info.keep_hash = (struct bfd_hash_table *)
    729       xmalloc (sizeof (struct bfd_hash_table));
    730   if (!bfd_hash_table_init (link_info.keep_hash, bfd_hash_newfunc,
    731 			    sizeof (struct bfd_hash_entry)))
    732     einfo (_("%P%F: bfd_hash_table_init failed: %E\n"));
    733 
    734   bufsize = 100;
    735   buf = (char *) xmalloc (bufsize);
    736 
    737   c = getc (file);
    738   while (c != EOF)
    739     {
    740       while (ISSPACE (c))
    741 	c = getc (file);
    742 
    743       if (c != EOF)
    744 	{
    745 	  size_t len = 0;
    746 
    747 	  while (! ISSPACE (c) && c != EOF)
    748 	    {
    749 	      buf[len] = c;
    750 	      ++len;
    751 	      if (len >= bufsize)
    752 		{
    753 		  bufsize *= 2;
    754 		  buf = (char *) xrealloc (buf, bufsize);
    755 		}
    756 	      c = getc (file);
    757 	    }
    758 
    759 	  buf[len] = '\0';
    760 
    761 	  if (bfd_hash_lookup (link_info.keep_hash, buf, TRUE, TRUE) == NULL)
    762 	    einfo (_("%P%F: bfd_hash_lookup for insertion failed: %E\n"));
    763 	}
    764     }
    765 
    766   if (link_info.strip != strip_none)
    767     einfo (_("%P: `-retain-symbols-file' overrides `-s' and `-S'\n"));
    768 
    769   free (buf);
    770   link_info.strip = strip_some;
    771   fclose (file);
    772 }
    773 
    774 /* Callbacks from the BFD linker routines.  */
    776 
    777 /* This is called when BFD has decided to include an archive member in
    778    a link.  */
    779 
    780 static bfd_boolean
    781 add_archive_element (struct bfd_link_info *info,
    782 		     bfd *abfd,
    783 		     const char *name,
    784 		     bfd **subsbfd ATTRIBUTE_UNUSED)
    785 {
    786   lang_input_statement_type *input;
    787   lang_input_statement_type orig_input;
    788 
    789   input = (lang_input_statement_type *)
    790       xcalloc (1, sizeof (lang_input_statement_type));
    791   input->filename = abfd->filename;
    792   input->local_sym_name = abfd->filename;
    793   input->the_bfd = abfd;
    794 
    795   /* Save the original data for trace files/tries below, as plugins
    796      (if enabled) may possibly alter it to point to a replacement
    797      BFD, but we still want to output the original BFD filename.  */
    798   orig_input = *input;
    799 #ifdef ENABLE_PLUGINS
    800   if (link_info.lto_plugin_active && !no_more_claiming)
    801     {
    802       /* We must offer this archive member to the plugins to claim.  */
    803       plugin_maybe_claim (input);
    804       if (input->flags.claimed)
    805 	{
    806 	  input->flags.claim_archive = TRUE;
    807 	  *subsbfd = input->the_bfd;
    808 	}
    809     }
    810 #endif /* ENABLE_PLUGINS */
    811 
    812   ldlang_add_file (input);
    813 
    814   if (config.map_file != NULL)
    815     {
    816       static bfd_boolean header_printed;
    817       struct bfd_link_hash_entry *h;
    818       bfd *from;
    819       int len;
    820 
    821       h = bfd_link_hash_lookup (info->hash, name, FALSE, FALSE, TRUE);
    822 
    823       if (h == NULL)
    824 	from = NULL;
    825       else
    826 	{
    827 	  switch (h->type)
    828 	    {
    829 	    default:
    830 	      from = NULL;
    831 	      break;
    832 
    833 	    case bfd_link_hash_defined:
    834 	    case bfd_link_hash_defweak:
    835 	      from = h->u.def.section->owner;
    836 	      break;
    837 
    838 	    case bfd_link_hash_undefined:
    839 	    case bfd_link_hash_undefweak:
    840 	      from = h->u.undef.abfd;
    841 	      break;
    842 
    843 	    case bfd_link_hash_common:
    844 	      from = h->u.c.p->section->owner;
    845 	      break;
    846 	    }
    847 	}
    848 
    849       if (! header_printed)
    850 	{
    851 	  char buf[100];
    852 
    853 	  sprintf (buf, _("Archive member included "
    854 			  "to satisfy reference by file (symbol)\n\n"));
    855 	  minfo ("%s", buf);
    856 	  header_printed = TRUE;
    857 	}
    858 
    859       if (bfd_my_archive (abfd) == NULL)
    860 	{
    861 	  minfo ("%s", bfd_get_filename (abfd));
    862 	  len = strlen (bfd_get_filename (abfd));
    863 	}
    864       else
    865 	{
    866 	  minfo ("%s(%s)", bfd_get_filename (bfd_my_archive (abfd)),
    867 		 bfd_get_filename (abfd));
    868 	  len = (strlen (bfd_get_filename (bfd_my_archive (abfd)))
    869 		 + strlen (bfd_get_filename (abfd))
    870 		 + 2);
    871 	}
    872 
    873       if (len >= 29)
    874 	{
    875 	  print_nl ();
    876 	  len = 0;
    877 	}
    878       while (len < 30)
    879 	{
    880 	  print_space ();
    881 	  ++len;
    882 	}
    883 
    884       if (from != NULL)
    885 	minfo ("%B ", from);
    886       if (h != NULL)
    887 	minfo ("(%T)\n", h->root.string);
    888       else
    889 	minfo ("(%s)\n", name);
    890     }
    891 
    892   if (trace_files || verbose)
    893     info_msg ("%I\n", &orig_input);
    894   return TRUE;
    895 }
    896 
    897 /* This is called when BFD has discovered a symbol which is defined
    898    multiple times.  */
    899 
    900 static bfd_boolean
    901 multiple_definition (struct bfd_link_info *info,
    902 		     struct bfd_link_hash_entry *h,
    903 		     bfd *nbfd,
    904 		     asection *nsec,
    905 		     bfd_vma nval)
    906 {
    907   const char *name;
    908   bfd *obfd;
    909   asection *osec;
    910   bfd_vma oval;
    911 
    912   if (info->allow_multiple_definition)
    913     return TRUE;
    914 
    915   switch (h->type)
    916     {
    917     case bfd_link_hash_defined:
    918       osec = h->u.def.section;
    919       oval = h->u.def.value;
    920       obfd = h->u.def.section->owner;
    921       break;
    922     case bfd_link_hash_indirect:
    923       osec = bfd_ind_section_ptr;
    924       oval = 0;
    925       obfd = NULL;
    926       break;
    927     default:
    928       abort ();
    929     }
    930 
    931   /* Ignore a redefinition of an absolute symbol to the
    932      same value; it's harmless.  */
    933   if (h->type == bfd_link_hash_defined
    934       && bfd_is_abs_section (osec)
    935       && bfd_is_abs_section (nsec)
    936       && nval == oval)
    937     return TRUE;
    938 
    939   /* If either section has the output_section field set to
    940      bfd_abs_section_ptr, it means that the section is being
    941      discarded, and this is not really a multiple definition at all.
    942      FIXME: It would be cleaner to somehow ignore symbols defined in
    943      sections which are being discarded.  */
    944   if ((osec->output_section != NULL
    945        && ! bfd_is_abs_section (osec)
    946        && bfd_is_abs_section (osec->output_section))
    947       || (nsec->output_section != NULL
    948 	  && ! bfd_is_abs_section (nsec)
    949 	  && bfd_is_abs_section (nsec->output_section)))
    950     return TRUE;
    951 
    952   name = h->root.string;
    953   if (nbfd == NULL)
    954     {
    955       nbfd = obfd;
    956       nsec = osec;
    957       nval = oval;
    958       obfd = NULL;
    959     }
    960   einfo (_("%X%C: multiple definition of `%T'\n"),
    961 	 nbfd, nsec, nval, name);
    962   if (obfd != NULL)
    963     einfo (_("%D: first defined here\n"), obfd, osec, oval);
    964 
    965   if (RELAXATION_ENABLED_BY_USER)
    966     {
    967       einfo (_("%P: Disabling relaxation: it will not work with multiple definitions\n"));
    968       DISABLE_RELAXATION;
    969     }
    970 
    971   return TRUE;
    972 }
    973 
    974 /* This is called when there is a definition of a common symbol, or
    975    when a common symbol is found for a symbol that is already defined,
    976    or when two common symbols are found.  We only do something if
    977    -warn-common was used.  */
    978 
    979 static bfd_boolean
    980 multiple_common (struct bfd_link_info *info ATTRIBUTE_UNUSED,
    981 		 struct bfd_link_hash_entry *h,
    982 		 bfd *nbfd,
    983 		 enum bfd_link_hash_type ntype,
    984 		 bfd_vma nsize)
    985 {
    986   const char *name;
    987   bfd *obfd;
    988   enum bfd_link_hash_type otype;
    989   bfd_vma osize;
    990 
    991   if (!config.warn_common)
    992     return TRUE;
    993 
    994   name = h->root.string;
    995   otype = h->type;
    996   if (otype == bfd_link_hash_common)
    997     {
    998       obfd = h->u.c.p->section->owner;
    999       osize = h->u.c.size;
   1000     }
   1001   else if (otype == bfd_link_hash_defined
   1002 	   || otype == bfd_link_hash_defweak)
   1003     {
   1004       obfd = h->u.def.section->owner;
   1005       osize = 0;
   1006     }
   1007   else
   1008     {
   1009       /* FIXME: It would nice if we could report the BFD which defined
   1010 	 an indirect symbol, but we don't have anywhere to store the
   1011 	 information.  */
   1012       obfd = NULL;
   1013       osize = 0;
   1014     }
   1015 
   1016   if (ntype == bfd_link_hash_defined
   1017       || ntype == bfd_link_hash_defweak
   1018       || ntype == bfd_link_hash_indirect)
   1019     {
   1020       ASSERT (otype == bfd_link_hash_common);
   1021       einfo (_("%B: warning: definition of `%T' overriding common\n"),
   1022 	     nbfd, name);
   1023       if (obfd != NULL)
   1024 	einfo (_("%B: warning: common is here\n"), obfd);
   1025     }
   1026   else if (otype == bfd_link_hash_defined
   1027 	   || otype == bfd_link_hash_defweak
   1028 	   || otype == bfd_link_hash_indirect)
   1029     {
   1030       ASSERT (ntype == bfd_link_hash_common);
   1031       einfo (_("%B: warning: common of `%T' overridden by definition\n"),
   1032 	     nbfd, name);
   1033       if (obfd != NULL)
   1034 	einfo (_("%B: warning: defined here\n"), obfd);
   1035     }
   1036   else
   1037     {
   1038       ASSERT (otype == bfd_link_hash_common && ntype == bfd_link_hash_common);
   1039       if (osize > nsize)
   1040 	{
   1041 	  einfo (_("%B: warning: common of `%T' overridden by larger common\n"),
   1042 		 nbfd, name);
   1043 	  if (obfd != NULL)
   1044 	    einfo (_("%B: warning: larger common is here\n"), obfd);
   1045 	}
   1046       else if (nsize > osize)
   1047 	{
   1048 	  einfo (_("%B: warning: common of `%T' overriding smaller common\n"),
   1049 		 nbfd, name);
   1050 	  if (obfd != NULL)
   1051 	    einfo (_("%B: warning: smaller common is here\n"), obfd);
   1052 	}
   1053       else
   1054 	{
   1055 	  einfo (_("%B: warning: multiple common of `%T'\n"), nbfd, name);
   1056 	  if (obfd != NULL)
   1057 	    einfo (_("%B: warning: previous common is here\n"), obfd);
   1058 	}
   1059     }
   1060 
   1061   return TRUE;
   1062 }
   1063 
   1064 /* This is called when BFD has discovered a set element.  H is the
   1065    entry in the linker hash table for the set.  SECTION and VALUE
   1066    represent a value which should be added to the set.  */
   1067 
   1068 static bfd_boolean
   1069 add_to_set (struct bfd_link_info *info ATTRIBUTE_UNUSED,
   1070 	    struct bfd_link_hash_entry *h,
   1071 	    bfd_reloc_code_real_type reloc,
   1072 	    bfd *abfd,
   1073 	    asection *section,
   1074 	    bfd_vma value)
   1075 {
   1076   if (config.warn_constructors)
   1077     einfo (_("%P: warning: global constructor %s used\n"),
   1078 	   h->root.string);
   1079 
   1080   if (! config.build_constructors)
   1081     return TRUE;
   1082 
   1083   ldctor_add_set_entry (h, reloc, NULL, section, value);
   1084 
   1085   if (h->type == bfd_link_hash_new)
   1086     {
   1087       h->type = bfd_link_hash_undefined;
   1088       h->u.undef.abfd = abfd;
   1089       /* We don't call bfd_link_add_undef to add this to the list of
   1090 	 undefined symbols because we are going to define it
   1091 	 ourselves.  */
   1092     }
   1093 
   1094   return TRUE;
   1095 }
   1096 
   1097 /* This is called when BFD has discovered a constructor.  This is only
   1098    called for some object file formats--those which do not handle
   1099    constructors in some more clever fashion.  This is similar to
   1100    adding an element to a set, but less general.  */
   1101 
   1102 static bfd_boolean
   1103 constructor_callback (struct bfd_link_info *info,
   1104 		      bfd_boolean constructor,
   1105 		      const char *name,
   1106 		      bfd *abfd,
   1107 		      asection *section,
   1108 		      bfd_vma value)
   1109 {
   1110   char *s;
   1111   struct bfd_link_hash_entry *h;
   1112   char set_name[1 + sizeof "__CTOR_LIST__"];
   1113 
   1114   if (config.warn_constructors)
   1115     einfo (_("%P: warning: global constructor %s used\n"), name);
   1116 
   1117   if (! config.build_constructors)
   1118     return TRUE;
   1119 
   1120   /* Ensure that BFD_RELOC_CTOR exists now, so that we can give a
   1121      useful error message.  */
   1122   if (bfd_reloc_type_lookup (info->output_bfd, BFD_RELOC_CTOR) == NULL
   1123       && (bfd_link_relocatable (info)
   1124 	  || bfd_reloc_type_lookup (abfd, BFD_RELOC_CTOR) == NULL))
   1125     einfo (_("%P%F: BFD backend error: BFD_RELOC_CTOR unsupported\n"));
   1126 
   1127   s = set_name;
   1128   if (bfd_get_symbol_leading_char (abfd) != '\0')
   1129     *s++ = bfd_get_symbol_leading_char (abfd);
   1130   if (constructor)
   1131     strcpy (s, "__CTOR_LIST__");
   1132   else
   1133     strcpy (s, "__DTOR_LIST__");
   1134 
   1135   h = bfd_link_hash_lookup (info->hash, set_name, TRUE, TRUE, TRUE);
   1136   if (h == (struct bfd_link_hash_entry *) NULL)
   1137     einfo (_("%P%F: bfd_link_hash_lookup failed: %E\n"));
   1138   if (h->type == bfd_link_hash_new)
   1139     {
   1140       h->type = bfd_link_hash_undefined;
   1141       h->u.undef.abfd = abfd;
   1142       /* We don't call bfd_link_add_undef to add this to the list of
   1143 	 undefined symbols because we are going to define it
   1144 	 ourselves.  */
   1145     }
   1146 
   1147   ldctor_add_set_entry (h, BFD_RELOC_CTOR, name, section, value);
   1148   return TRUE;
   1149 }
   1150 
   1151 /* A structure used by warning_callback to pass information through
   1152    bfd_map_over_sections.  */
   1153 
   1154 struct warning_callback_info
   1155 {
   1156   bfd_boolean found;
   1157   const char *warning;
   1158   const char *symbol;
   1159   asymbol **asymbols;
   1160 };
   1161 
   1162 /* Look through the relocs to see if we can find a plausible address
   1163    for SYMBOL in ABFD.  Return TRUE if found.  Otherwise return FALSE.  */
   1164 
   1165 static bfd_boolean
   1166 symbol_warning (const char *warning, const char *symbol, bfd *abfd)
   1167 {
   1168   struct warning_callback_info cinfo;
   1169 
   1170   if (!bfd_generic_link_read_symbols (abfd))
   1171     einfo (_("%B%F: could not read symbols: %E\n"), abfd);
   1172 
   1173   cinfo.found = FALSE;
   1174   cinfo.warning = warning;
   1175   cinfo.symbol = symbol;
   1176   cinfo.asymbols = bfd_get_outsymbols (abfd);
   1177   bfd_map_over_sections (abfd, warning_find_reloc, &cinfo);
   1178   return cinfo.found;
   1179 }
   1180 
   1181 /* This is called when there is a reference to a warning symbol.  */
   1182 
   1183 static bfd_boolean
   1184 warning_callback (struct bfd_link_info *info ATTRIBUTE_UNUSED,
   1185 		  const char *warning,
   1186 		  const char *symbol,
   1187 		  bfd *abfd,
   1188 		  asection *section,
   1189 		  bfd_vma address)
   1190 {
   1191   /* This is a hack to support warn_multiple_gp.  FIXME: This should
   1192      have a cleaner interface, but what?  */
   1193   if (! config.warn_multiple_gp
   1194       && strcmp (warning, "using multiple gp values") == 0)
   1195     return TRUE;
   1196 
   1197   if (section != NULL)
   1198     einfo ("%C: %s%s\n", abfd, section, address, _("warning: "), warning);
   1199   else if (abfd == NULL)
   1200     einfo ("%P: %s%s\n", _("warning: "), warning);
   1201   else if (symbol == NULL)
   1202     einfo ("%B: %s%s\n", abfd, _("warning: "), warning);
   1203   else if (! symbol_warning (warning, symbol, abfd))
   1204     {
   1205       bfd *b;
   1206       /* Search all input files for a reference to SYMBOL.  */
   1207       for (b = info->input_bfds; b; b = b->link.next)
   1208 	if (b != abfd && symbol_warning (warning, symbol, b))
   1209 	  return TRUE;
   1210       einfo ("%B: %s%s\n", abfd, _("warning: "), warning);
   1211     }
   1212 
   1213   return TRUE;
   1214 }
   1215 
   1216 /* This is called by warning_callback for each section.  It checks the
   1217    relocs of the section to see if it can find a reference to the
   1218    symbol which triggered the warning.  If it can, it uses the reloc
   1219    to give an error message with a file and line number.  */
   1220 
   1221 static void
   1222 warning_find_reloc (bfd *abfd, asection *sec, void *iarg)
   1223 {
   1224   struct warning_callback_info *info = (struct warning_callback_info *) iarg;
   1225   long relsize;
   1226   arelent **relpp;
   1227   long relcount;
   1228   arelent **p, **pend;
   1229 
   1230   if (info->found)
   1231     return;
   1232 
   1233   relsize = bfd_get_reloc_upper_bound (abfd, sec);
   1234   if (relsize < 0)
   1235     einfo (_("%B%F: could not read relocs: %E\n"), abfd);
   1236   if (relsize == 0)
   1237     return;
   1238 
   1239   relpp = (arelent **) xmalloc (relsize);
   1240   relcount = bfd_canonicalize_reloc (abfd, sec, relpp, info->asymbols);
   1241   if (relcount < 0)
   1242     einfo (_("%B%F: could not read relocs: %E\n"), abfd);
   1243 
   1244   p = relpp;
   1245   pend = p + relcount;
   1246   for (; p < pend && *p != NULL; p++)
   1247     {
   1248       arelent *q = *p;
   1249 
   1250       if (q->sym_ptr_ptr != NULL
   1251 	  && *q->sym_ptr_ptr != NULL
   1252 	  && strcmp (bfd_asymbol_name (*q->sym_ptr_ptr), info->symbol) == 0)
   1253 	{
   1254 	  /* We found a reloc for the symbol we are looking for.  */
   1255 	  einfo ("%C: %s%s\n", abfd, sec, q->address, _("warning: "),
   1256 		 info->warning);
   1257 	  info->found = TRUE;
   1258 	  break;
   1259 	}
   1260     }
   1261 
   1262   free (relpp);
   1263 }
   1264 
   1265 /* This is called when an undefined symbol is found.  */
   1266 
   1267 static bfd_boolean
   1268 undefined_symbol (struct bfd_link_info *info,
   1269 		  const char *name,
   1270 		  bfd *abfd,
   1271 		  asection *section,
   1272 		  bfd_vma address,
   1273 		  bfd_boolean error)
   1274 {
   1275   static char *error_name;
   1276   static unsigned int error_count;
   1277 
   1278 #define MAX_ERRORS_IN_A_ROW 5
   1279 
   1280   if (info->ignore_hash != NULL
   1281       && bfd_hash_lookup (info->ignore_hash, name, FALSE, FALSE) != NULL)
   1282     return TRUE;
   1283 
   1284   if (config.warn_once)
   1285     {
   1286       /* Only warn once about a particular undefined symbol.  */
   1287       add_ignoresym (info, name);
   1288     }
   1289 
   1290   /* We never print more than a reasonable number of errors in a row
   1291      for a single symbol.  */
   1292   if (error_name != NULL
   1293       && strcmp (name, error_name) == 0)
   1294     ++error_count;
   1295   else
   1296     {
   1297       error_count = 0;
   1298       if (error_name != NULL)
   1299 	free (error_name);
   1300       error_name = xstrdup (name);
   1301     }
   1302 
   1303   if (section != NULL)
   1304     {
   1305       if (error_count < MAX_ERRORS_IN_A_ROW)
   1306 	{
   1307 	  if (error)
   1308 	    einfo (_("%X%C: undefined reference to `%T'\n"),
   1309 		   abfd, section, address, name);
   1310 	  else
   1311 	    einfo (_("%C: warning: undefined reference to `%T'\n"),
   1312 		   abfd, section, address, name);
   1313 	}
   1314       else if (error_count == MAX_ERRORS_IN_A_ROW)
   1315 	{
   1316 	  if (error)
   1317 	    einfo (_("%X%D: more undefined references to `%T' follow\n"),
   1318 		   abfd, section, address, name);
   1319 	  else
   1320 	    einfo (_("%D: warning: more undefined references to `%T' follow\n"),
   1321 		   abfd, section, address, name);
   1322 	}
   1323       else if (error)
   1324 	einfo ("%X");
   1325     }
   1326   else
   1327     {
   1328       if (error_count < MAX_ERRORS_IN_A_ROW)
   1329 	{
   1330 	  if (error)
   1331 	    einfo (_("%X%B: undefined reference to `%T'\n"),
   1332 		   abfd, name);
   1333 	  else
   1334 	    einfo (_("%B: warning: undefined reference to `%T'\n"),
   1335 		   abfd, name);
   1336 	}
   1337       else if (error_count == MAX_ERRORS_IN_A_ROW)
   1338 	{
   1339 	  if (error)
   1340 	    einfo (_("%X%B: more undefined references to `%T' follow\n"),
   1341 		   abfd, name);
   1342 	  else
   1343 	    einfo (_("%B: warning: more undefined references to `%T' follow\n"),
   1344 		   abfd, name);
   1345 	}
   1346       else if (error)
   1347 	einfo ("%X");
   1348     }
   1349 
   1350   return TRUE;
   1351 }
   1352 
   1353 /* Counter to limit the number of relocation overflow error messages
   1354    to print.  Errors are printed as it is decremented.  When it's
   1355    called and the counter is zero, a final message is printed
   1356    indicating more relocations were omitted.  When it gets to -1, no
   1357    such errors are printed.  If it's initially set to a value less
   1358    than -1, all such errors will be printed (--verbose does this).  */
   1359 
   1360 int overflow_cutoff_limit = 10;
   1361 
   1362 /* This is called when a reloc overflows.  */
   1363 
   1364 static bfd_boolean
   1365 reloc_overflow (struct bfd_link_info *info,
   1366 		struct bfd_link_hash_entry *entry,
   1367 		const char *name,
   1368 		const char *reloc_name,
   1369 		bfd_vma addend,
   1370 		bfd *abfd,
   1371 		asection *section,
   1372 		bfd_vma address)
   1373 {
   1374   if (overflow_cutoff_limit == -1)
   1375     return TRUE;
   1376 
   1377   einfo ("%X%H:", abfd, section, address);
   1378 
   1379   if (overflow_cutoff_limit >= 0
   1380       && overflow_cutoff_limit-- == 0)
   1381     {
   1382       einfo (_(" additional relocation overflows omitted from the output\n"));
   1383       return TRUE;
   1384     }
   1385 
   1386   if (entry)
   1387     {
   1388       while (entry->type == bfd_link_hash_indirect
   1389 	     || entry->type == bfd_link_hash_warning)
   1390 	entry = entry->u.i.link;
   1391       switch (entry->type)
   1392 	{
   1393 	case bfd_link_hash_undefined:
   1394 	case bfd_link_hash_undefweak:
   1395 	  einfo (_(" relocation truncated to fit: %s against undefined symbol `%T'"),
   1396 		 reloc_name, entry->root.string);
   1397 	  break;
   1398 	case bfd_link_hash_defined:
   1399 	case bfd_link_hash_defweak:
   1400 	  einfo (_(" relocation truncated to fit: %s against symbol `%T' defined in %A section in %B"),
   1401 		 reloc_name, entry->root.string,
   1402 		 entry->u.def.section,
   1403 		 entry->u.def.section == bfd_abs_section_ptr
   1404 		 ? info->output_bfd : entry->u.def.section->owner);
   1405 	  break;
   1406 	default:
   1407 	  abort ();
   1408 	  break;
   1409 	}
   1410     }
   1411   else
   1412     einfo (_(" relocation truncated to fit: %s against `%T'"),
   1413 	   reloc_name, name);
   1414   if (addend != 0)
   1415     einfo ("+%v", addend);
   1416   einfo ("\n");
   1417   return TRUE;
   1418 }
   1419 
   1420 /* This is called when a dangerous relocation is made.  */
   1421 
   1422 static bfd_boolean
   1423 reloc_dangerous (struct bfd_link_info *info ATTRIBUTE_UNUSED,
   1424 		 const char *message,
   1425 		 bfd *abfd,
   1426 		 asection *section,
   1427 		 bfd_vma address)
   1428 {
   1429   einfo (_("%X%H: dangerous relocation: %s\n"),
   1430 	 abfd, section, address, message);
   1431   return TRUE;
   1432 }
   1433 
   1434 /* This is called when a reloc is being generated attached to a symbol
   1435    that is not being output.  */
   1436 
   1437 static bfd_boolean
   1438 unattached_reloc (struct bfd_link_info *info ATTRIBUTE_UNUSED,
   1439 		  const char *name,
   1440 		  bfd *abfd,
   1441 		  asection *section,
   1442 		  bfd_vma address)
   1443 {
   1444   einfo (_("%X%H: reloc refers to symbol `%T' which is not being output\n"),
   1445 	 abfd, section, address, name);
   1446   return TRUE;
   1447 }
   1448 
   1449 /* This is called if link_info.notice_all is set, or when a symbol in
   1450    link_info.notice_hash is found.  Symbols are put in notice_hash
   1451    using the -y option, while notice_all is set if the --cref option
   1452    has been supplied, or if there are any NOCROSSREFS sections in the
   1453    linker script; and if plugins are active, since they need to monitor
   1454    all references from non-IR files.  */
   1455 
   1456 static bfd_boolean
   1457 notice (struct bfd_link_info *info,
   1458 	struct bfd_link_hash_entry *h,
   1459 	struct bfd_link_hash_entry *inh ATTRIBUTE_UNUSED,
   1460 	bfd *abfd,
   1461 	asection *section,
   1462 	bfd_vma value,
   1463 	flagword flags ATTRIBUTE_UNUSED)
   1464 {
   1465   const char *name;
   1466 
   1467   if (h == NULL)
   1468     {
   1469       if (command_line.cref || nocrossref_list != NULL)
   1470 	return handle_asneeded_cref (abfd, (enum notice_asneeded_action) value);
   1471       return TRUE;
   1472     }
   1473 
   1474   name = h->root.string;
   1475   if (info->notice_hash != NULL
   1476       && bfd_hash_lookup (info->notice_hash, name, FALSE, FALSE) != NULL)
   1477     {
   1478       if (bfd_is_und_section (section))
   1479 	einfo ("%B: reference to %s\n", abfd, name);
   1480       else
   1481 	einfo ("%B: definition of %s\n", abfd, name);
   1482     }
   1483 
   1484   if (command_line.cref || nocrossref_list != NULL)
   1485     add_cref (name, abfd, section, value);
   1486 
   1487   return TRUE;
   1488 }
   1489