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