]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blob - ld/ldmain.c
Improve plugin error handling
[thirdparty/binutils-gdb.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, 2012
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 report actions taken by the linker, and describe the linker script in use. */
92 bfd_boolean verbose;
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 /* TRUE if we should demangle symbol names. */
99 bfd_boolean demangling;
100
101 args_type command_line;
102
103 ld_config_type config;
104
105 sort_type sort_section;
106
107 static const char *get_sysroot
108 (int, char **);
109 static char *get_emulation
110 (int, char **);
111 static bfd_boolean add_archive_element
112 (struct bfd_link_info *, bfd *, const char *, bfd **);
113 static bfd_boolean multiple_definition
114 (struct bfd_link_info *, struct bfd_link_hash_entry *,
115 bfd *, asection *, bfd_vma);
116 static bfd_boolean multiple_common
117 (struct bfd_link_info *, struct bfd_link_hash_entry *,
118 bfd *, enum bfd_link_hash_type, bfd_vma);
119 static bfd_boolean add_to_set
120 (struct bfd_link_info *, struct bfd_link_hash_entry *,
121 bfd_reloc_code_real_type, bfd *, asection *, bfd_vma);
122 static bfd_boolean constructor_callback
123 (struct bfd_link_info *, bfd_boolean, const char *, bfd *,
124 asection *, bfd_vma);
125 static bfd_boolean warning_callback
126 (struct bfd_link_info *, const char *, const char *, bfd *,
127 asection *, bfd_vma);
128 static void warning_find_reloc
129 (bfd *, asection *, void *);
130 static bfd_boolean undefined_symbol
131 (struct bfd_link_info *, const char *, bfd *, asection *, bfd_vma,
132 bfd_boolean);
133 static bfd_boolean reloc_overflow
134 (struct bfd_link_info *, struct bfd_link_hash_entry *, const char *,
135 const char *, bfd_vma, bfd *, asection *, bfd_vma);
136 static bfd_boolean reloc_dangerous
137 (struct bfd_link_info *, const char *, bfd *, asection *, bfd_vma);
138 static bfd_boolean unattached_reloc
139 (struct bfd_link_info *, const char *, bfd *, asection *, bfd_vma);
140 static bfd_boolean notice
141 (struct bfd_link_info *, struct bfd_link_hash_entry *,
142 bfd *, asection *, bfd_vma, flagword, const char *);
143
144 static struct bfd_link_callbacks link_callbacks =
145 {
146 add_archive_element,
147 multiple_definition,
148 multiple_common,
149 add_to_set,
150 constructor_callback,
151 warning_callback,
152 undefined_symbol,
153 reloc_overflow,
154 reloc_dangerous,
155 unattached_reloc,
156 notice,
157 einfo,
158 info_msg,
159 minfo,
160 ldlang_override_segment_assignment
161 };
162
163 static bfd_assert_handler_type default_bfd_assert_handler;
164
165 struct bfd_link_info link_info;
166 \f
167 static void
168 ld_cleanup (void)
169 {
170 bfd_cache_close_all ();
171 #ifdef ENABLE_PLUGINS
172 plugin_call_cleanup ();
173 #endif
174 if (output_filename && delete_output_file_on_failure)
175 unlink_if_ordinary (output_filename);
176 }
177
178 /* If there's a BFD assertion, we'll notice and exit with an error
179 unless otherwise instructed. */
180
181 static void
182 ld_bfd_assert_handler (const char *fmt, const char *bfdver,
183 const char *file, int line)
184 {
185 (*default_bfd_assert_handler) (fmt, bfdver, file, line);
186 config.make_executable = FALSE;
187 }
188
189 int
190 main (int argc, char **argv)
191 {
192 char *emulation;
193 long start_time = get_run_time ();
194 #ifdef HAVE_SBRK
195 char *start_sbrk = (char *) sbrk (0);
196 #endif
197
198 #if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
199 setlocale (LC_MESSAGES, "");
200 #endif
201 #if defined (HAVE_SETLOCALE)
202 setlocale (LC_CTYPE, "");
203 #endif
204 bindtextdomain (PACKAGE, LOCALEDIR);
205 textdomain (PACKAGE);
206
207 program_name = argv[0];
208 xmalloc_set_program_name (program_name);
209
210 START_PROGRESS (program_name, 0);
211
212 expandargv (&argc, &argv);
213
214 bfd_init ();
215
216 bfd_set_error_program_name (program_name);
217
218 /* We want to notice and fail on those nasty BFD assertions which are
219 likely to signal incorrect output being generated but otherwise may
220 leave no trace. */
221 default_bfd_assert_handler = bfd_set_assert_handler (ld_bfd_assert_handler);
222
223 xatexit (ld_cleanup);
224
225 /* Set up the sysroot directory. */
226 ld_sysroot = get_sysroot (argc, argv);
227 if (*ld_sysroot)
228 {
229 if (*TARGET_SYSTEM_ROOT == 0)
230 {
231 einfo ("%P%F: this linker was not configured to use sysroots\n");
232 ld_sysroot = "";
233 }
234 else
235 ld_canon_sysroot = lrealpath (ld_sysroot);
236 }
237 if (ld_canon_sysroot)
238 ld_canon_sysroot_len = strlen (ld_canon_sysroot);
239 else
240 ld_canon_sysroot_len = -1;
241
242 /* Set the default BFD target based on the configured target. Doing
243 this permits the linker to be configured for a particular target,
244 and linked against a shared BFD library which was configured for
245 a different target. The macro TARGET is defined by Makefile. */
246 if (! bfd_set_default_target (TARGET))
247 {
248 einfo (_("%X%P: can't set BFD default target to `%s': %E\n"), TARGET);
249 xexit (1);
250 }
251
252 #if YYDEBUG
253 {
254 extern int yydebug;
255 yydebug = 1;
256 }
257 #endif
258
259 config.build_constructors = TRUE;
260 config.rpath_separator = ':';
261 config.split_by_reloc = (unsigned) -1;
262 config.split_by_file = (bfd_size_type) -1;
263 config.make_executable = TRUE;
264 config.magic_demand_paged = TRUE;
265 config.text_read_only = TRUE;
266 link_info.disable_target_specific_optimizations = -1;
267
268 command_line.warn_mismatch = TRUE;
269 command_line.warn_search_mismatch = TRUE;
270 command_line.check_section_addresses = -1;
271
272 /* We initialize DEMANGLING based on the environment variable
273 COLLECT_NO_DEMANGLE. The gcc collect2 program will demangle the
274 output of the linker, unless COLLECT_NO_DEMANGLE is set in the
275 environment. Acting the same way here lets us provide the same
276 interface by default. */
277 demangling = getenv ("COLLECT_NO_DEMANGLE") == NULL;
278
279 link_info.allow_undefined_version = TRUE;
280 link_info.keep_memory = TRUE;
281 link_info.combreloc = TRUE;
282 link_info.strip_discarded = TRUE;
283 link_info.emit_hash = TRUE;
284 link_info.callbacks = &link_callbacks;
285 link_info.input_bfds_tail = &link_info.input_bfds;
286 /* SVR4 linkers seem to set DT_INIT and DT_FINI based on magic _init
287 and _fini symbols. We are compatible. */
288 link_info.init_function = "_init";
289 link_info.fini_function = "_fini";
290 link_info.relax_pass = 1;
291 link_info.pei386_auto_import = -1;
292 link_info.spare_dynamic_tags = 5;
293 link_info.path_separator = ':';
294
295 ldfile_add_arch ("");
296 emulation = get_emulation (argc, argv);
297 ldemul_choose_mode (emulation);
298 default_target = ldemul_choose_target (argc, argv);
299 config.maxpagesize = bfd_emul_get_maxpagesize (default_target);
300 config.commonpagesize = bfd_emul_get_commonpagesize (default_target);
301 lang_init ();
302 ldemul_before_parse ();
303 lang_has_input_file = FALSE;
304 parse_args (argc, argv);
305
306 if (config.hash_table_size != 0)
307 bfd_hash_set_default_size (config.hash_table_size);
308
309 #ifdef ENABLE_PLUGINS
310 /* Now all the plugin arguments have been gathered, we can load them. */
311 plugin_load_plugins ();
312 #endif /* ENABLE_PLUGINS */
313
314 ldemul_set_symbols ();
315
316 /* If we have not already opened and parsed a linker script,
317 try the default script from command line first. */
318 if (saved_script_handle == NULL
319 && command_line.default_script != NULL)
320 {
321 ldfile_open_command_file (command_line.default_script);
322 parser_input = input_script;
323 yyparse ();
324 }
325
326 /* If we have not already opened and parsed a linker script
327 read the emulation's appropriate default script. */
328 if (saved_script_handle == NULL)
329 {
330 int isfile;
331 char *s = ldemul_get_script (&isfile);
332
333 if (isfile)
334 ldfile_open_default_command_file (s);
335 else
336 {
337 lex_string = s;
338 lex_redirect (s, _("built in linker script"), 1);
339 }
340 parser_input = input_script;
341 yyparse ();
342 lex_string = NULL;
343 }
344
345 if (verbose)
346 {
347 if (saved_script_handle)
348 info_msg (_("using external linker script:"));
349 else
350 info_msg (_("using internal linker script:"));
351 info_msg ("\n==================================================\n");
352
353 if (saved_script_handle)
354 {
355 static const int ld_bufsz = 8193;
356 size_t n;
357 char *buf = (char *) xmalloc (ld_bufsz);
358
359 rewind (saved_script_handle);
360 while ((n = fread (buf, 1, ld_bufsz - 1, saved_script_handle)) > 0)
361 {
362 buf[n] = 0;
363 info_msg (buf);
364 }
365 rewind (saved_script_handle);
366 free (buf);
367 }
368 else
369 {
370 int isfile;
371
372 info_msg (ldemul_get_script (&isfile));
373 }
374
375 info_msg ("\n==================================================\n");
376 }
377
378 if (command_line.print_output_format)
379 info_msg ("%s\n", lang_get_output_target ());
380
381 lang_final ();
382
383 if (!lang_has_input_file)
384 {
385 if (version_printed || command_line.print_output_format)
386 xexit (0);
387 einfo (_("%P%F: no input files\n"));
388 }
389
390 if (trace_files)
391 info_msg (_("%P: mode %s\n"), emulation);
392
393 ldemul_after_parse ();
394
395 if (config.map_filename)
396 {
397 if (strcmp (config.map_filename, "-") == 0)
398 {
399 config.map_file = stdout;
400 }
401 else
402 {
403 config.map_file = fopen (config.map_filename, FOPEN_WT);
404 if (config.map_file == (FILE *) NULL)
405 {
406 bfd_set_error (bfd_error_system_call);
407 einfo (_("%P%F: cannot open map file %s: %E\n"),
408 config.map_filename);
409 }
410 }
411 }
412
413 lang_process ();
414
415 /* Print error messages for any missing symbols, for any warning
416 symbols, and possibly multiple definitions. */
417 if (link_info.relocatable)
418 link_info.output_bfd->flags &= ~EXEC_P;
419 else
420 link_info.output_bfd->flags |= EXEC_P;
421
422 ldwrite ();
423
424 if (config.map_file != NULL)
425 lang_map ();
426 if (command_line.cref)
427 output_cref (config.map_file != NULL ? config.map_file : stdout);
428 if (nocrossref_list != NULL)
429 check_nocrossrefs ();
430
431 lang_finish ();
432
433 /* Even if we're producing relocatable output, some non-fatal errors should
434 be reported in the exit status. (What non-fatal errors, if any, do we
435 want to ignore for relocatable output?) */
436 if (!config.make_executable && !force_make_executable)
437 {
438 if (trace_files)
439 einfo (_("%P: link errors found, deleting executable `%s'\n"),
440 output_filename);
441
442 /* The file will be removed by ld_cleanup. */
443 xexit (1);
444 }
445 else
446 {
447 if (! bfd_close (link_info.output_bfd))
448 einfo (_("%F%B: final close failed: %E\n"), link_info.output_bfd);
449
450 /* If the --force-exe-suffix is enabled, and we're making an
451 executable file and it doesn't end in .exe, copy it to one
452 which does. */
453 if (! link_info.relocatable && command_line.force_exe_suffix)
454 {
455 int len = strlen (output_filename);
456
457 if (len < 4
458 || (strcasecmp (output_filename + len - 4, ".exe") != 0
459 && strcasecmp (output_filename + len - 4, ".dll") != 0))
460 {
461 FILE *src;
462 FILE *dst;
463 const int bsize = 4096;
464 char *buf = (char *) xmalloc (bsize);
465 int l;
466 char *dst_name = (char *) xmalloc (len + 5);
467
468 strcpy (dst_name, output_filename);
469 strcat (dst_name, ".exe");
470 src = fopen (output_filename, FOPEN_RB);
471 dst = fopen (dst_name, FOPEN_WB);
472
473 if (!src)
474 einfo (_("%X%P: unable to open for source of copy `%s'\n"),
475 output_filename);
476 if (!dst)
477 einfo (_("%X%P: unable to open for destination of copy `%s'\n"),
478 dst_name);
479 while ((l = fread (buf, 1, bsize, src)) > 0)
480 {
481 int done = fwrite (buf, 1, l, dst);
482
483 if (done != l)
484 einfo (_("%P: Error writing file `%s'\n"), dst_name);
485 }
486
487 fclose (src);
488 if (fclose (dst) == EOF)
489 einfo (_("%P: Error closing file `%s'\n"), dst_name);
490 free (dst_name);
491 free (buf);
492 }
493 }
494 }
495
496 END_PROGRESS (program_name);
497
498 if (config.stats)
499 {
500 #ifdef HAVE_SBRK
501 char *lim = (char *) sbrk (0);
502 #endif
503 long run_time = get_run_time () - start_time;
504
505 fflush (stdout);
506 fprintf (stderr, _("%s: total time in link: %ld.%06ld\n"),
507 program_name, run_time / 1000000, run_time % 1000000);
508 #ifdef HAVE_SBRK
509 fprintf (stderr, _("%s: data size %ld\n"), program_name,
510 (long) (lim - start_sbrk));
511 #endif
512 fflush (stderr);
513 }
514
515 /* Prevent ld_cleanup from doing anything, after a successful link. */
516 output_filename = NULL;
517
518 xexit (0);
519 return 0;
520 }
521
522 /* If the configured sysroot is relocatable, try relocating it based on
523 default prefix FROM. Return the relocated directory if it exists,
524 otherwise return null. */
525
526 static char *
527 get_relative_sysroot (const char *from ATTRIBUTE_UNUSED)
528 {
529 #ifdef TARGET_SYSTEM_ROOT_RELOCATABLE
530 char *path;
531 struct stat s;
532
533 path = make_relative_prefix (program_name, from, TARGET_SYSTEM_ROOT);
534 if (path)
535 {
536 if (stat (path, &s) == 0 && S_ISDIR (s.st_mode))
537 return path;
538 free (path);
539 }
540 #endif
541 return 0;
542 }
543
544 /* Return the sysroot directory. Return "" if no sysroot is being used. */
545
546 static const char *
547 get_sysroot (int argc, char **argv)
548 {
549 int i;
550 const char *path;
551
552 for (i = 1; i < argc; i++)
553 if (CONST_STRNEQ (argv[i], "--sysroot="))
554 return argv[i] + strlen ("--sysroot=");
555
556 path = get_relative_sysroot (BINDIR);
557 if (path)
558 return path;
559
560 path = get_relative_sysroot (TOOLBINDIR);
561 if (path)
562 return path;
563
564 return TARGET_SYSTEM_ROOT;
565 }
566
567 /* We need to find any explicitly given emulation in order to initialize the
568 state that's needed by the lex&yacc argument parser (parse_args). */
569
570 static char *
571 get_emulation (int argc, char **argv)
572 {
573 char *emulation;
574 int i;
575
576 emulation = getenv (EMULATION_ENVIRON);
577 if (emulation == NULL)
578 emulation = DEFAULT_EMULATION;
579
580 for (i = 1; i < argc; i++)
581 {
582 if (CONST_STRNEQ (argv[i], "-m"))
583 {
584 if (argv[i][2] == '\0')
585 {
586 /* -m EMUL */
587 if (i < argc - 1)
588 {
589 emulation = argv[i + 1];
590 i++;
591 }
592 else
593 einfo (_("%P%F: missing argument to -m\n"));
594 }
595 else if (strcmp (argv[i], "-mips1") == 0
596 || strcmp (argv[i], "-mips2") == 0
597 || strcmp (argv[i], "-mips3") == 0
598 || strcmp (argv[i], "-mips4") == 0
599 || strcmp (argv[i], "-mips5") == 0
600 || strcmp (argv[i], "-mips32") == 0
601 || strcmp (argv[i], "-mips32r2") == 0
602 || strcmp (argv[i], "-mips64") == 0
603 || strcmp (argv[i], "-mips64r2") == 0)
604 {
605 /* FIXME: The arguments -mips1, -mips2, -mips3, etc. are
606 passed to the linker by some MIPS compilers. They
607 generally tell the linker to use a slightly different
608 library path. Perhaps someday these should be
609 implemented as emulations; until then, we just ignore
610 the arguments and hope that nobody ever creates
611 emulations named ips1, ips2 or ips3. */
612 }
613 else if (strcmp (argv[i], "-m486") == 0)
614 {
615 /* FIXME: The argument -m486 is passed to the linker on
616 some Linux systems. Hope that nobody creates an
617 emulation named 486. */
618 }
619 else
620 {
621 /* -mEMUL */
622 emulation = &argv[i][2];
623 }
624 }
625 }
626
627 return emulation;
628 }
629
630 void
631 add_ysym (const char *name)
632 {
633 if (link_info.notice_hash == NULL)
634 {
635 link_info.notice_hash =
636 (struct bfd_hash_table *) xmalloc (sizeof (struct bfd_hash_table));
637 if (!bfd_hash_table_init_n (link_info.notice_hash,
638 bfd_hash_newfunc,
639 sizeof (struct bfd_hash_entry),
640 61))
641 einfo (_("%P%F: bfd_hash_table_init failed: %E\n"));
642 }
643
644 if (bfd_hash_lookup (link_info.notice_hash, name, TRUE, TRUE) == NULL)
645 einfo (_("%P%F: bfd_hash_lookup failed: %E\n"));
646 }
647
648 void
649 add_ignoresym (struct bfd_link_info *info, const char *name)
650 {
651 if (info->ignore_hash == NULL)
652 {
653 info->ignore_hash = xmalloc (sizeof (struct bfd_hash_table));
654 if (! bfd_hash_table_init_n (info->ignore_hash,
655 bfd_hash_newfunc,
656 sizeof (struct bfd_hash_entry),
657 61))
658 einfo (_("%P%F: bfd_hash_table_init failed: %E\n"));
659 }
660
661 if (bfd_hash_lookup (info->ignore_hash, name, TRUE, TRUE) == NULL)
662 einfo (_("%P%F: bfd_hash_lookup failed: %E\n"));
663 }
664
665 /* Record a symbol to be wrapped, from the --wrap option. */
666
667 void
668 add_wrap (const char *name)
669 {
670 if (link_info.wrap_hash == NULL)
671 {
672 link_info.wrap_hash =
673 (struct bfd_hash_table *) xmalloc (sizeof (struct bfd_hash_table));
674 if (!bfd_hash_table_init_n (link_info.wrap_hash,
675 bfd_hash_newfunc,
676 sizeof (struct bfd_hash_entry),
677 61))
678 einfo (_("%P%F: bfd_hash_table_init failed: %E\n"));
679 }
680
681 if (bfd_hash_lookup (link_info.wrap_hash, name, TRUE, TRUE) == NULL)
682 einfo (_("%P%F: bfd_hash_lookup failed: %E\n"));
683 }
684
685 /* Handle the -retain-symbols-file option. */
686
687 void
688 add_keepsyms_file (const char *filename)
689 {
690 FILE *file;
691 char *buf;
692 size_t bufsize;
693 int c;
694
695 if (link_info.strip == strip_some)
696 einfo (_("%X%P: error: duplicate retain-symbols-file\n"));
697
698 file = fopen (filename, "r");
699 if (file == NULL)
700 {
701 bfd_set_error (bfd_error_system_call);
702 einfo ("%X%P: %s: %E\n", filename);
703 return;
704 }
705
706 link_info.keep_hash = (struct bfd_hash_table *)
707 xmalloc (sizeof (struct bfd_hash_table));
708 if (!bfd_hash_table_init (link_info.keep_hash, bfd_hash_newfunc,
709 sizeof (struct bfd_hash_entry)))
710 einfo (_("%P%F: bfd_hash_table_init failed: %E\n"));
711
712 bufsize = 100;
713 buf = (char *) xmalloc (bufsize);
714
715 c = getc (file);
716 while (c != EOF)
717 {
718 while (ISSPACE (c))
719 c = getc (file);
720
721 if (c != EOF)
722 {
723 size_t len = 0;
724
725 while (! ISSPACE (c) && c != EOF)
726 {
727 buf[len] = c;
728 ++len;
729 if (len >= bufsize)
730 {
731 bufsize *= 2;
732 buf = (char *) xrealloc (buf, bufsize);
733 }
734 c = getc (file);
735 }
736
737 buf[len] = '\0';
738
739 if (bfd_hash_lookup (link_info.keep_hash, buf, TRUE, TRUE) == NULL)
740 einfo (_("%P%F: bfd_hash_lookup for insertion failed: %E\n"));
741 }
742 }
743
744 if (link_info.strip != strip_none)
745 einfo (_("%P: `-retain-symbols-file' overrides `-s' and `-S'\n"));
746
747 free (buf);
748 link_info.strip = strip_some;
749 }
750 \f
751 /* Callbacks from the BFD linker routines. */
752
753 /* This is called when BFD has decided to include an archive member in
754 a link. */
755
756 static bfd_boolean
757 add_archive_element (struct bfd_link_info *info,
758 bfd *abfd,
759 const char *name,
760 bfd **subsbfd ATTRIBUTE_UNUSED)
761 {
762 lang_input_statement_type *input;
763 lang_input_statement_type orig_input;
764
765 input = (lang_input_statement_type *)
766 xcalloc (1, sizeof (lang_input_statement_type));
767 input->filename = abfd->filename;
768 input->local_sym_name = abfd->filename;
769 input->the_bfd = abfd;
770
771 /* Save the original data for trace files/tries below, as plugins
772 (if enabled) may possibly alter it to point to a replacement
773 BFD, but we still want to output the original BFD filename. */
774 orig_input = *input;
775 #ifdef ENABLE_PLUGINS
776 if (plugin_active_plugins_p () && !no_more_claiming)
777 {
778 /* We must offer this archive member to the plugins to claim. */
779 const char *filename = (bfd_my_archive (abfd) != NULL
780 ? bfd_my_archive (abfd)->filename : abfd->filename);
781 int fd = open (filename, O_RDONLY | O_BINARY);
782 if (fd >= 0)
783 {
784 struct ld_plugin_input_file file;
785
786 /* Offset and filesize must refer to the individual archive
787 member, not the whole file, and must exclude the header.
788 Fortunately for us, that is how the data is stored in the
789 origin field of the bfd and in the arelt_data. */
790 file.name = filename;
791 file.offset = abfd->origin;
792 file.filesize = arelt_size (abfd);
793 file.fd = fd;
794 plugin_maybe_claim (&file, input);
795 if (input->flags.claimed)
796 {
797 input->flags.claim_archive = TRUE;
798 *subsbfd = input->the_bfd;
799 }
800 }
801 }
802 #endif /* ENABLE_PLUGINS */
803
804 ldlang_add_file (input);
805
806 if (config.map_file != NULL)
807 {
808 static bfd_boolean header_printed;
809 struct bfd_link_hash_entry *h;
810 bfd *from;
811 int len;
812
813 h = bfd_link_hash_lookup (info->hash, name, FALSE, FALSE, TRUE);
814
815 if (h == NULL)
816 from = NULL;
817 else
818 {
819 switch (h->type)
820 {
821 default:
822 from = NULL;
823 break;
824
825 case bfd_link_hash_defined:
826 case bfd_link_hash_defweak:
827 from = h->u.def.section->owner;
828 break;
829
830 case bfd_link_hash_undefined:
831 case bfd_link_hash_undefweak:
832 from = h->u.undef.abfd;
833 break;
834
835 case bfd_link_hash_common:
836 from = h->u.c.p->section->owner;
837 break;
838 }
839 }
840
841 if (! header_printed)
842 {
843 char buf[100];
844
845 sprintf (buf, _("Archive member included because of file (symbol)\n\n"));
846 minfo ("%s", buf);
847 header_printed = TRUE;
848 }
849
850 if (bfd_my_archive (abfd) == NULL)
851 {
852 minfo ("%s", bfd_get_filename (abfd));
853 len = strlen (bfd_get_filename (abfd));
854 }
855 else
856 {
857 minfo ("%s(%s)", bfd_get_filename (bfd_my_archive (abfd)),
858 bfd_get_filename (abfd));
859 len = (strlen (bfd_get_filename (bfd_my_archive (abfd)))
860 + strlen (bfd_get_filename (abfd))
861 + 2);
862 }
863
864 if (len >= 29)
865 {
866 print_nl ();
867 len = 0;
868 }
869 while (len < 30)
870 {
871 print_space ();
872 ++len;
873 }
874
875 if (from != NULL)
876 minfo ("%B ", from);
877 if (h != NULL)
878 minfo ("(%T)\n", h->root.string);
879 else
880 minfo ("(%s)\n", name);
881 }
882
883 if (trace_files || verbose)
884 info_msg ("%I\n", &orig_input);
885 return TRUE;
886 }
887
888 /* This is called when BFD has discovered a symbol which is defined
889 multiple times. */
890
891 static bfd_boolean
892 multiple_definition (struct bfd_link_info *info,
893 struct bfd_link_hash_entry *h,
894 bfd *nbfd,
895 asection *nsec,
896 bfd_vma nval)
897 {
898 const char *name;
899 bfd *obfd;
900 asection *osec;
901 bfd_vma oval;
902
903 if (info->allow_multiple_definition)
904 return TRUE;
905
906 switch (h->type)
907 {
908 case bfd_link_hash_defined:
909 osec = h->u.def.section;
910 oval = h->u.def.value;
911 obfd = h->u.def.section->owner;
912 break;
913 case bfd_link_hash_indirect:
914 osec = bfd_ind_section_ptr;
915 oval = 0;
916 obfd = NULL;
917 break;
918 default:
919 abort ();
920 }
921
922 /* Ignore a redefinition of an absolute symbol to the
923 same value; it's harmless. */
924 if (h->type == bfd_link_hash_defined
925 && bfd_is_abs_section (osec)
926 && bfd_is_abs_section (nsec)
927 && nval == oval)
928 return TRUE;
929
930 /* If either section has the output_section field set to
931 bfd_abs_section_ptr, it means that the section is being
932 discarded, and this is not really a multiple definition at all.
933 FIXME: It would be cleaner to somehow ignore symbols defined in
934 sections which are being discarded. */
935 if ((osec->output_section != NULL
936 && ! bfd_is_abs_section (osec)
937 && bfd_is_abs_section (osec->output_section))
938 || (nsec->output_section != NULL
939 && ! bfd_is_abs_section (nsec)
940 && bfd_is_abs_section (nsec->output_section)))
941 return TRUE;
942
943 name = h->root.string;
944 if (nbfd == NULL)
945 {
946 nbfd = obfd;
947 nsec = osec;
948 nval = oval;
949 obfd = NULL;
950 }
951 einfo (_("%X%C: multiple definition of `%T'\n"),
952 nbfd, nsec, nval, name);
953 if (obfd != NULL)
954 einfo (_("%D: first defined here\n"), obfd, osec, oval);
955
956 if (RELAXATION_ENABLED)
957 {
958 einfo (_("%P: Disabling relaxation: it will not work with multiple definitions\n"));
959 link_info.disable_target_specific_optimizations = -1;
960 }
961
962 return TRUE;
963 }
964
965 /* This is called when there is a definition of a common symbol, or
966 when a common symbol is found for a symbol that is already defined,
967 or when two common symbols are found. We only do something if
968 -warn-common was used. */
969
970 static bfd_boolean
971 multiple_common (struct bfd_link_info *info ATTRIBUTE_UNUSED,
972 struct bfd_link_hash_entry *h,
973 bfd *nbfd,
974 enum bfd_link_hash_type ntype,
975 bfd_vma nsize)
976 {
977 const char *name;
978 bfd *obfd;
979 enum bfd_link_hash_type otype;
980 bfd_vma osize;
981
982 if (!config.warn_common)
983 return TRUE;
984
985 name = h->root.string;
986 otype = h->type;
987 if (otype == bfd_link_hash_common)
988 {
989 obfd = h->u.c.p->section->owner;
990 osize = h->u.c.size;
991 }
992 else if (otype == bfd_link_hash_defined
993 || otype == bfd_link_hash_defweak)
994 {
995 obfd = h->u.def.section->owner;
996 osize = 0;
997 }
998 else
999 {
1000 /* FIXME: It would nice if we could report the BFD which defined
1001 an indirect symbol, but we don't have anywhere to store the
1002 information. */
1003 obfd = NULL;
1004 osize = 0;
1005 }
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 (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,
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 (info->ignore_hash != NULL
1263 && bfd_hash_lookup (info->ignore_hash, name, FALSE, FALSE) != NULL)
1264 return TRUE;
1265
1266 if (config.warn_once)
1267 {
1268 /* Only warn once about a particular undefined symbol. */
1269 add_ignoresym (info, name);
1270 }
1271
1272 /* We never print more than a reasonable number of errors in a row
1273 for a single symbol. */
1274 if (error_name != NULL
1275 && strcmp (name, error_name) == 0)
1276 ++error_count;
1277 else
1278 {
1279 error_count = 0;
1280 if (error_name != NULL)
1281 free (error_name);
1282 error_name = xstrdup (name);
1283 }
1284
1285 if (section != NULL)
1286 {
1287 if (error_count < MAX_ERRORS_IN_A_ROW)
1288 {
1289 if (error)
1290 einfo (_("%X%C: undefined reference to `%T'\n"),
1291 abfd, section, address, name);
1292 else
1293 einfo (_("%C: warning: undefined reference to `%T'\n"),
1294 abfd, section, address, name);
1295 }
1296 else if (error_count == MAX_ERRORS_IN_A_ROW)
1297 {
1298 if (error)
1299 einfo (_("%X%D: more undefined references to `%T' follow\n"),
1300 abfd, section, address, name);
1301 else
1302 einfo (_("%D: warning: more undefined references to `%T' follow\n"),
1303 abfd, section, address, name);
1304 }
1305 else if (error)
1306 einfo ("%X");
1307 }
1308 else
1309 {
1310 if (error_count < MAX_ERRORS_IN_A_ROW)
1311 {
1312 if (error)
1313 einfo (_("%X%B: undefined reference to `%T'\n"),
1314 abfd, name);
1315 else
1316 einfo (_("%B: warning: undefined reference to `%T'\n"),
1317 abfd, name);
1318 }
1319 else if (error_count == MAX_ERRORS_IN_A_ROW)
1320 {
1321 if (error)
1322 einfo (_("%X%B: more undefined references to `%T' follow\n"),
1323 abfd, name);
1324 else
1325 einfo (_("%B: warning: more undefined references to `%T' follow\n"),
1326 abfd, name);
1327 }
1328 else if (error)
1329 einfo ("%X");
1330 }
1331
1332 return TRUE;
1333 }
1334
1335 /* Counter to limit the number of relocation overflow error messages
1336 to print. Errors are printed as it is decremented. When it's
1337 called and the counter is zero, a final message is printed
1338 indicating more relocations were omitted. When it gets to -1, no
1339 such errors are printed. If it's initially set to a value less
1340 than -1, all such errors will be printed (--verbose does this). */
1341
1342 int overflow_cutoff_limit = 10;
1343
1344 /* This is called when a reloc overflows. */
1345
1346 static bfd_boolean
1347 reloc_overflow (struct bfd_link_info *info,
1348 struct bfd_link_hash_entry *entry,
1349 const char *name,
1350 const char *reloc_name,
1351 bfd_vma addend,
1352 bfd *abfd,
1353 asection *section,
1354 bfd_vma address)
1355 {
1356 if (overflow_cutoff_limit == -1)
1357 return TRUE;
1358
1359 einfo ("%X%H:", abfd, section, address);
1360
1361 if (overflow_cutoff_limit >= 0
1362 && overflow_cutoff_limit-- == 0)
1363 {
1364 einfo (_(" additional relocation overflows omitted from the output\n"));
1365 return TRUE;
1366 }
1367
1368 if (entry)
1369 {
1370 while (entry->type == bfd_link_hash_indirect
1371 || entry->type == bfd_link_hash_warning)
1372 entry = entry->u.i.link;
1373 switch (entry->type)
1374 {
1375 case bfd_link_hash_undefined:
1376 case bfd_link_hash_undefweak:
1377 einfo (_(" relocation truncated to fit: %s against undefined symbol `%T'"),
1378 reloc_name, entry->root.string);
1379 break;
1380 case bfd_link_hash_defined:
1381 case bfd_link_hash_defweak:
1382 einfo (_(" relocation truncated to fit: %s against symbol `%T' defined in %A section in %B"),
1383 reloc_name, entry->root.string,
1384 entry->u.def.section,
1385 entry->u.def.section == bfd_abs_section_ptr
1386 ? info->output_bfd : entry->u.def.section->owner);
1387 break;
1388 default:
1389 abort ();
1390 break;
1391 }
1392 }
1393 else
1394 einfo (_(" relocation truncated to fit: %s against `%T'"),
1395 reloc_name, name);
1396 if (addend != 0)
1397 einfo ("+%v", addend);
1398 einfo ("\n");
1399 return TRUE;
1400 }
1401
1402 /* This is called when a dangerous relocation is made. */
1403
1404 static bfd_boolean
1405 reloc_dangerous (struct bfd_link_info *info ATTRIBUTE_UNUSED,
1406 const char *message,
1407 bfd *abfd,
1408 asection *section,
1409 bfd_vma address)
1410 {
1411 einfo (_("%X%H: dangerous relocation: %s\n"),
1412 abfd, section, address, message);
1413 return TRUE;
1414 }
1415
1416 /* This is called when a reloc is being generated attached to a symbol
1417 that is not being output. */
1418
1419 static bfd_boolean
1420 unattached_reloc (struct bfd_link_info *info ATTRIBUTE_UNUSED,
1421 const char *name,
1422 bfd *abfd,
1423 asection *section,
1424 bfd_vma address)
1425 {
1426 einfo (_("%X%H: reloc refers to symbol `%T' which is not being output\n"),
1427 abfd, section, address, name);
1428 return TRUE;
1429 }
1430
1431 /* This is called if link_info.notice_all is set, or when a symbol in
1432 link_info.notice_hash is found. Symbols are put in notice_hash
1433 using the -y option, while notice_all is set if the --cref option
1434 has been supplied, or if there are any NOCROSSREFS sections in the
1435 linker script; and if plugins are active, since they need to monitor
1436 all references from non-IR files. */
1437
1438 static bfd_boolean
1439 notice (struct bfd_link_info *info,
1440 struct bfd_link_hash_entry *h,
1441 bfd *abfd,
1442 asection *section,
1443 bfd_vma value,
1444 flagword flags ATTRIBUTE_UNUSED,
1445 const char *string ATTRIBUTE_UNUSED)
1446 {
1447 const char *name;
1448
1449 if (h == NULL)
1450 {
1451 if (command_line.cref || nocrossref_list != NULL)
1452 return handle_asneeded_cref (abfd, (enum notice_asneeded_action) value);
1453 return TRUE;
1454 }
1455
1456 name = h->root.string;
1457 if (info->notice_hash != NULL
1458 && bfd_hash_lookup (info->notice_hash, name, FALSE, FALSE) != NULL)
1459 {
1460 if (bfd_is_und_section (section))
1461 einfo ("%B: reference to %s\n", abfd, name);
1462 else
1463 einfo ("%B: definition of %s\n", abfd, name);
1464 }
1465
1466 if (command_line.cref || nocrossref_list != NULL)
1467 add_cref (name, abfd, section, value);
1468
1469 return TRUE;
1470 }