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