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