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