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