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