2 Copyright 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
3 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2010, 2011, 2012
4 Free Software Foundation, Inc.
5 Written by Steve Chamberlain of Cygnus Support.
7 This file is part of the GNU Binutils.
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
22 MA 02110-1301, USA. */
27 #include "libiberty.h"
28 #include "filenames.h"
43 %A section name from a section
44 %B filename from a bfd
45 %C clever filename:linenumber with function
46 %D like %C, but no function name
47 %E current bfd error or errno
49 %G like %D, but only function name
50 %H like %C but in addition emit section+offset
51 %I filename from a lang_input_statement_type
53 %R info about a relent
54 %S print script file and linenumber from etree_type.
57 %W hex bfd_vma with 0x with no leading zeros taking up 8 spaces
58 %X no object output, fail return
59 %d integer, like printf
61 %lu unsigned long, like printf
62 %p native (host) void* pointer, like printf
63 %s arbitrary string, like printf
64 %u integer, like printf
65 %v hex bfd_vma, no leading zeros
69 vfinfo (FILE *fp
, const char *fmt
, va_list arg
, bfd_boolean is_warning
)
71 bfd_boolean fatal
= FALSE
;
75 while (*fmt
!= '%' && *fmt
!= '\0')
92 /* no object output, fail return */
93 config
.make_executable
= FALSE
;
99 bfd_vma value
= va_arg (arg
, bfd_vma
);
100 fprintf_vma (fp
, value
);
105 /* hex bfd_vma, no leading zeros */
109 bfd_vma value
= va_arg (arg
, bfd_vma
);
110 sprintf_vma (p
, value
);
120 /* hex bfd_vma with 0x with no leading zeroes taking up
128 value
= va_arg (arg
, bfd_vma
);
129 sprintf_vma (buf
, value
);
130 for (p
= buf
; *p
== '0'; ++p
)
140 fprintf (fp
, "0x%s", p
);
147 const char *name
= va_arg (arg
, const char *);
149 if (name
== NULL
|| *name
== 0)
151 fprintf (fp
, _("no symbol"));
158 demangled
= bfd_demangle (link_info
.output_bfd
, name
,
159 DMGL_ANSI
| DMGL_PARAMS
);
160 if (demangled
!= NULL
)
162 fprintf (fp
, "%s", demangled
);
167 fprintf (fp
, "%s", name
);
172 /* section name from a section */
174 asection
*sec
= va_arg (arg
, asection
*);
175 bfd
*abfd
= sec
->owner
;
176 const char *group
= NULL
;
177 struct coff_comdat_info
*ci
;
179 fprintf (fp
, "%s", sec
->name
);
181 && bfd_get_flavour (abfd
) == bfd_target_elf_flavour
182 && elf_next_in_group (sec
) != NULL
183 && (sec
->flags
& SEC_GROUP
) == 0)
184 group
= elf_group_name (sec
);
185 else if (abfd
!= NULL
186 && bfd_get_flavour (abfd
) == bfd_target_coff_flavour
187 && (ci
= bfd_coff_get_comdat_section (sec
->owner
,
191 fprintf (fp
, "[%s]", group
);
196 /* filename from a bfd */
198 bfd
*abfd
= va_arg (arg
, bfd
*);
201 fprintf (fp
, "%s generated", program_name
);
202 else if (abfd
->my_archive
)
203 fprintf (fp
, "%s(%s)", abfd
->my_archive
->filename
,
206 fprintf (fp
, "%s", abfd
->filename
);
211 /* Error is fatal. */
216 /* Print program name. */
217 fprintf (fp
, "%s", program_name
);
221 /* current bfd error or errno */
222 fprintf (fp
, "%s", bfd_errmsg (bfd_get_error ()));
226 /* filename from a lang_input_statement_type */
228 lang_input_statement_type
*i
;
230 i
= va_arg (arg
, lang_input_statement_type
*);
231 if (bfd_my_archive (i
->the_bfd
) != NULL
)
233 bfd_get_filename (bfd_my_archive (i
->the_bfd
)));
234 fprintf (fp
, "%s", i
->local_sym_name
);
235 if (bfd_my_archive (i
->the_bfd
) == NULL
236 && filename_cmp (i
->local_sym_name
, i
->filename
) != 0)
237 fprintf (fp
, " (%s)", i
->filename
);
242 /* Print script file and linenumber. */
245 etree_type
*tp
= va_arg (arg
, etree_type
*);
250 tp
->type
.filename
= ldlex_filename ();
251 tp
->type
.lineno
= lineno
;
253 if (tp
->type
.filename
!= NULL
)
254 fprintf (fp
, "%s:%u", tp
->type
.filename
, tp
->type
.lineno
);
259 /* Print all that's interesting about a relent. */
261 arelent
*relent
= va_arg (arg
, arelent
*);
263 lfinfo (fp
, "%s+0x%v (type %s)",
264 (*(relent
->sym_ptr_ptr
))->name
,
266 relent
->howto
->name
);
274 /* Clever filename:linenumber with function name if possible.
275 The arguments are a BFD, a section, and an offset. */
277 static bfd
*last_bfd
;
278 static char *last_file
= NULL
;
279 static char *last_function
= NULL
;
283 asymbol
**asymbols
= NULL
;
284 const char *filename
;
285 const char *functionname
;
286 unsigned int linenumber
;
287 bfd_boolean discard_last
;
290 abfd
= va_arg (arg
, bfd
*);
291 section
= va_arg (arg
, asection
*);
292 offset
= va_arg (arg
, bfd_vma
);
296 if (!bfd_generic_link_read_symbols (abfd
))
297 einfo (_("%B%F: could not read symbols: %E\n"), abfd
);
299 asymbols
= bfd_get_outsymbols (abfd
);
302 /* The GNU Coding Standard requires that error messages
305 source-file-name:lineno: message
307 We do not always have a line number available so if
308 we cannot find them we print out the section name and
312 && bfd_find_nearest_line (abfd
, section
, asymbols
, offset
,
313 &filename
, &functionname
,
316 if (functionname
!= NULL
317 && (fmt
[-1] == 'C' || fmt
[-1] == 'H'))
319 /* Detect the case where we are printing out a
320 message for the same function as the last
321 call to vinfo ("%C"). In this situation do
322 not print out the ABFD filename or the
323 function name again. Note - we do still
324 print out the source filename, as this will
325 allow programs that parse the linker's output
326 (eg emacs) to correctly locate multiple
327 errors in the same source file. */
330 || last_function
== NULL
333 && filename_cmp (last_file
, filename
) != 0)
334 || strcmp (last_function
, functionname
) != 0)
336 lfinfo (fp
, _("%B: In function `%T':\n"),
340 if (last_file
!= NULL
)
344 last_file
= xstrdup (filename
);
345 if (last_function
!= NULL
)
346 free (last_function
);
347 last_function
= xstrdup (functionname
);
349 discard_last
= FALSE
;
352 lfinfo (fp
, "%B:", abfd
);
354 if (filename
!= NULL
)
355 fprintf (fp
, "%s:", filename
);
357 done
= fmt
[-1] != 'H';
358 if (functionname
!= NULL
&& fmt
[-1] == 'G')
359 lfinfo (fp
, "%T", functionname
);
360 else if (filename
!= NULL
&& linenumber
!= 0)
361 fprintf (fp
, "%u%s", linenumber
, ":" + done
);
367 lfinfo (fp
, "%B:", abfd
);
371 lfinfo (fp
, "(%A+0x%v)", section
, offset
);
376 if (last_file
!= NULL
)
381 if (last_function
!= NULL
)
383 free (last_function
);
384 last_function
= NULL
;
391 /* native (host) void* pointer, like printf */
392 fprintf (fp
, "%p", va_arg (arg
, void *));
396 /* arbitrary string, like printf */
397 fprintf (fp
, "%s", va_arg (arg
, char *));
401 /* integer, like printf */
402 fprintf (fp
, "%d", va_arg (arg
, int));
406 /* unsigned integer, like printf */
407 fprintf (fp
, "%u", va_arg (arg
, unsigned int));
413 fprintf (fp
, "%ld", va_arg (arg
, long));
417 else if (*fmt
== 'u')
419 fprintf (fp
, "%lu", va_arg (arg
, unsigned long));
426 fprintf (fp
, "%%%c", fmt
[-1]);
432 if (is_warning
&& config
.fatal_warnings
)
433 config
.make_executable
= FALSE
;
439 /* Format info message and print on stdout. */
441 /* (You would think this should be called just "info", but then you
442 would be hosed by LynxOS, which defines that name in its libc.) */
445 info_msg (const char *fmt
, ...)
450 vfinfo (stdout
, fmt
, arg
, FALSE
);
454 /* ('e' for error.) Format info message and print on stderr. */
457 einfo (const char *fmt
, ...)
463 vfinfo (stderr
, fmt
, arg
, TRUE
);
469 info_assert (const char *file
, unsigned int line
)
471 einfo (_("%F%P: internal error %s %d\n"), file
, line
);
474 /* ('m' for map) Format info message and print on map. */
477 minfo (const char *fmt
, ...)
479 if (config
.map_file
!= NULL
)
484 vfinfo (config
.map_file
, fmt
, arg
, FALSE
);
490 lfinfo (FILE *file
, const char *fmt
, ...)
495 vfinfo (file
, fmt
, arg
, FALSE
);
499 /* Functions to print the link map. */
504 fprintf (config
.map_file
, " ");
510 fprintf (config
.map_file
, "\n");
513 /* A more or less friendly abort message. In ld.h abort is defined to
514 call this function. */
517 ld_abort (const char *file
, int line
, const char *fn
)
520 einfo (_("%P: internal error: aborting at %s line %d in %s\n"),
523 einfo (_("%P: internal error: aborting at %s line %d\n"),
525 einfo (_("%P%F: please report this bug\n"));