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