PR binutils/15033
[deliverable/binutils-gdb.git] / binutils / nm.c
CommitLineData
252b5132 1/* nm.c -- Describe symbol table of a rel file.
8c2bc687 2 Copyright 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000,
ddb1377c 3 2001, 2002, 2003, 2004, 2005, 2007, 2008, 2009, 2010, 2011, 2012
252b5132
RH
4 Free Software Foundation, Inc.
5
6 This file is part of GNU Binutils.
7
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
32866df7 10 the Free Software Foundation; either version 3 of the License, or
252b5132
RH
11 (at your option) any later version.
12
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
b43b5d5f
NC
20 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
21 02110-1301, USA. */
252b5132 22
3db64b00 23#include "sysdep.h"
252b5132
RH
24#include "bfd.h"
25#include "progress.h"
252b5132
RH
26#include "getopt.h"
27#include "aout/stab_gnu.h"
28#include "aout/ranlib.h"
29#include "demangle.h"
30#include "libiberty.h"
6ab6b380 31#include "elf-bfd.h"
33f5f537 32#include "elf/common.h"
3db64b00 33#include "bucomm.h"
ce3c775b 34#include "plugin.h"
252b5132
RH
35
36/* When sorting by size, we use this structure to hold the size and a
37 pointer to the minisymbol. */
38
39struct size_sym
40{
2da42df6 41 const void *minisym;
252b5132
RH
42 bfd_vma size;
43};
44
45/* When fetching relocs, we use this structure to pass information to
46 get_relocs. */
47
48struct get_relocs_info
49{
50 asection **secs;
51 arelent ***relocs;
52 long *relcount;
53 asymbol **syms;
54};
55
9710509e 56struct extended_symbol_info
977f7911
NC
57{
58 symbol_info *sinfo;
59 bfd_vma ssize;
33f5f537 60 elf_symbol_type *elfinfo;
977f7911
NC
61 /* FIXME: We should add more fields for Type, Line, Section. */
62};
63#define SYM_NAME(sym) (sym->sinfo->name)
64#define SYM_VALUE(sym) (sym->sinfo->value)
65#define SYM_TYPE(sym) (sym->sinfo->type)
66#define SYM_STAB_NAME(sym) (sym->sinfo->stab_name)
67#define SYM_STAB_DESC(sym) (sym->sinfo->stab_desc)
68#define SYM_STAB_OTHER(sym) (sym->sinfo->stab_other)
33f5f537
L
69#define SYM_SIZE(sym) \
70 (sym->elfinfo ? sym->elfinfo->internal_elf_sym.st_size: sym->ssize)
977f7911 71
252b5132 72/* The output formatting functions. */
2da42df6
AJ
73static void print_object_filename_bsd (char *);
74static void print_object_filename_sysv (char *);
75static void print_object_filename_posix (char *);
76static void print_archive_filename_bsd (char *);
77static void print_archive_filename_sysv (char *);
78static void print_archive_filename_posix (char *);
79static void print_archive_member_bsd (char *, const char *);
80static void print_archive_member_sysv (char *, const char *);
81static void print_archive_member_posix (char *, const char *);
82static void print_symbol_filename_bsd (bfd *, bfd *);
83static void print_symbol_filename_sysv (bfd *, bfd *);
84static void print_symbol_filename_posix (bfd *, bfd *);
85static void print_value (bfd *, bfd_vma);
86static void print_symbol_info_bsd (struct extended_symbol_info *, bfd *);
87static void print_symbol_info_sysv (struct extended_symbol_info *, bfd *);
88static void print_symbol_info_posix (struct extended_symbol_info *, bfd *);
252b5132
RH
89
90/* Support for different output formats. */
91struct output_fns
92 {
93 /* Print the name of an object file given on the command line. */
2da42df6 94 void (*print_object_filename) (char *);
252b5132
RH
95
96 /* Print the name of an archive file given on the command line. */
2da42df6 97 void (*print_archive_filename) (char *);
252b5132
RH
98
99 /* Print the name of an archive member file. */
2da42df6 100 void (*print_archive_member) (char *, const char *);
252b5132
RH
101
102 /* Print the name of the file (and archive, if there is one)
103 containing a symbol. */
2da42df6 104 void (*print_symbol_filename) (bfd *, bfd *);
252b5132
RH
105
106 /* Print a line of information about a symbol. */
2da42df6 107 void (*print_symbol_info) (struct extended_symbol_info *, bfd *);
252b5132 108 };
977f7911 109
252b5132
RH
110static struct output_fns formats[] =
111{
112 {print_object_filename_bsd,
113 print_archive_filename_bsd,
114 print_archive_member_bsd,
115 print_symbol_filename_bsd,
116 print_symbol_info_bsd},
117 {print_object_filename_sysv,
118 print_archive_filename_sysv,
119 print_archive_member_sysv,
120 print_symbol_filename_sysv,
121 print_symbol_info_sysv},
122 {print_object_filename_posix,
123 print_archive_filename_posix,
124 print_archive_member_posix,
125 print_symbol_filename_posix,
126 print_symbol_info_posix}
127};
128
129/* Indices in `formats'. */
130#define FORMAT_BSD 0
131#define FORMAT_SYSV 1
132#define FORMAT_POSIX 2
133#define FORMAT_DEFAULT FORMAT_BSD
134
135/* The output format to use. */
136static struct output_fns *format = &formats[FORMAT_DEFAULT];
137
252b5132
RH
138/* Command options. */
139
140static int do_demangle = 0; /* Pretty print C++ symbol names. */
977f7911
NC
141static int external_only = 0; /* Print external symbols only. */
142static int defined_only = 0; /* Print defined symbols only. */
143static int no_sort = 0; /* Don't sort; print syms in order found. */
144static int print_debug_syms = 0;/* Print debugger-only symbols too. */
145static int print_armap = 0; /* Describe __.SYMDEF data in archive files. */
72797995 146static int print_size = 0; /* Print size of defined symbols. */
977f7911
NC
147static int reverse_sort = 0; /* Sort in downward(alpha or numeric) order. */
148static int sort_numerically = 0;/* Sort in numeric rather than alpha order. */
149static int sort_by_size = 0; /* Sort by size of symbol. */
150static int undefined_only = 0; /* Print undefined symbols only. */
151static int dynamic = 0; /* Print dynamic symbols. */
152static int show_version = 0; /* Show the version number. */
153static int show_stats = 0; /* Show statistics. */
0873df2a 154static int show_synthetic = 0; /* Display synthesized symbols too. */
977f7911 155static int line_numbers = 0; /* Print line numbers for symbols. */
3c9458e9 156static int allow_special_symbols = 0; /* Allow special symbols. */
252b5132
RH
157
158/* When to print the names of files. Not mutually exclusive in SYSV format. */
159static int filename_per_file = 0; /* Once per file, on its own line. */
160static int filename_per_symbol = 0; /* Once per symbol, at start of line. */
161
162/* Print formats for printing a symbol value. */
970ccc77 163static char value_format_32bit[] = "%08lx";
39dbeff8 164#if BFD_HOST_64BIT_LONG
970ccc77 165static char value_format_64bit[] = "%016lx";
39dbeff8 166#elif BFD_HOST_64BIT_LONG_LONG
a46d1146 167#ifndef __MSVCRT__
39dbeff8 168static char value_format_64bit[] = "%016llx";
a46d1146
JM
169#else
170static char value_format_64bit[] = "%016I64x";
171#endif
39dbeff8 172#endif
970ccc77 173static int print_width = 0;
252b5132
RH
174static int print_radix = 16;
175/* Print formats for printing stab info. */
176static char other_format[] = "%02x";
177static char desc_format[] = "%04x";
178
179static char *target = NULL;
a4b8af35 180static char *plugin_target = NULL;
252b5132
RH
181
182/* Used to cache the line numbers for a BFD. */
183static bfd *lineno_cache_bfd;
184static bfd *lineno_cache_rel_bfd;
185
c20f4f8c 186#define OPTION_TARGET 200
ddb1377c
AM
187#define OPTION_PLUGIN (OPTION_TARGET + 1)
188#define OPTION_SIZE_SORT (OPTION_PLUGIN + 1)
c20f4f8c 189
252b5132
RH
190static struct option long_options[] =
191{
192 {"debug-syms", no_argument, &print_debug_syms, 1},
28c309a2 193 {"demangle", optional_argument, 0, 'C'},
252b5132
RH
194 {"dynamic", no_argument, &dynamic, 1},
195 {"extern-only", no_argument, &external_only, 1},
196 {"format", required_argument, 0, 'f'},
197 {"help", no_argument, 0, 'h'},
198 {"line-numbers", no_argument, 0, 'l'},
199 {"no-cplus", no_argument, &do_demangle, 0}, /* Linux compatibility. */
200 {"no-demangle", no_argument, &do_demangle, 0},
ddb1377c
AM
201 {"no-sort", no_argument, 0, 'p'},
202 {"numeric-sort", no_argument, 0, 'n'},
ce3c775b 203 {"plugin", required_argument, 0, OPTION_PLUGIN},
252b5132
RH
204 {"portability", no_argument, 0, 'P'},
205 {"print-armap", no_argument, &print_armap, 1},
206 {"print-file-name", no_argument, 0, 'o'},
72797995 207 {"print-size", no_argument, 0, 'S'},
252b5132
RH
208 {"radix", required_argument, 0, 't'},
209 {"reverse-sort", no_argument, &reverse_sort, 1},
ddb1377c 210 {"size-sort", no_argument, 0, OPTION_SIZE_SORT},
3c9458e9 211 {"special-syms", no_argument, &allow_special_symbols, 1},
252b5132 212 {"stats", no_argument, &show_stats, 1},
0873df2a 213 {"synthetic", no_argument, &show_synthetic, 1},
c20f4f8c 214 {"target", required_argument, 0, OPTION_TARGET},
252b5132
RH
215 {"defined-only", no_argument, &defined_only, 1},
216 {"undefined-only", no_argument, &undefined_only, 1},
217 {"version", no_argument, &show_version, 1},
218 {0, no_argument, 0, 0}
219};
220\f
977f7911 221/* Some error-reporting functions. */
252b5132
RH
222
223static void
2da42df6 224usage (FILE *stream, int status)
252b5132 225{
8b53311e
NC
226 fprintf (stream, _("Usage: %s [option(s)] [file(s)]\n"), program_name);
227 fprintf (stream, _(" List symbols in [file(s)] (a.out by default).\n"));
228 fprintf (stream, _(" The options are:\n\
b56f55ce
NC
229 -a, --debug-syms Display debugger-only symbols\n\
230 -A, --print-file-name Print name of the input file before every symbol\n\
231 -B Same as --format=bsd\n\
28c309a2
NC
232 -C, --demangle[=STYLE] Decode low-level symbol names into user-level names\n\
233 The STYLE, if specified, can be `auto' (the default),\n\
f0c8c24a
NC
234 `gnu', `lucid', `arm', `hp', `edg', `gnu-v3', `java'\n\
235 or `gnat'\n\
b56f55ce
NC
236 --no-demangle Do not demangle low-level symbol names\n\
237 -D, --dynamic Display dynamic symbols instead of normal symbols\n\
238 --defined-only Display only defined symbols\n\
239 -e (ignored)\n\
240 -f, --format=FORMAT Use the output format FORMAT. FORMAT can be `bsd',\n\
241 `sysv' or `posix'. The default is `bsd'\n\
242 -g, --extern-only Display only external symbols\n\
b56f55ce
NC
243 -l, --line-numbers Use debugging information to find a filename and\n\
244 line number for each symbol\n\
245 -n, --numeric-sort Sort symbols numerically by address\n\
246 -o Same as -A\n\
247 -p, --no-sort Do not sort the symbols\n\
248 -P, --portability Same as --format=posix\n\
d46fc8e8 249 -r, --reverse-sort Reverse the sense of the sort\n"));
ce3c775b 250#if BFD_SUPPORTS_PLUGINS
d46fc8e8
NC
251 fprintf (stream, _("\
252 --plugin NAME Load the specified plugin\n"));
ce3c775b 253#endif
d46fc8e8 254 fprintf (stream, _("\
d2ca6b5b 255 -S, --print-size Print size of defined symbols\n\
b56f55ce
NC
256 -s, --print-armap Include index for symbols from archive members\n\
257 --size-sort Sort symbols by size\n\
61bbd35b 258 --special-syms Include special symbols in the output\n\
0873df2a 259 --synthetic Display synthetic symbols as well\n\
b56f55ce
NC
260 -t, --radix=RADIX Use RADIX for printing symbol values\n\
261 --target=BFDNAME Specify the target object format as BFDNAME\n\
262 -u, --undefined-only Display only undefined symbols\n\
6e800839 263 -X 32_64 (ignored)\n\
07012eee 264 @FILE Read options from FILE\n\
8b53311e
NC
265 -h, --help Display this information\n\
266 -V, --version Display this program's version number\n\
b56f55ce 267\n"));
252b5132 268 list_supported_targets (program_name, stream);
92f01d61 269 if (REPORT_BUGS_TO[0] && status == 0)
b56f55ce 270 fprintf (stream, _("Report bugs to %s.\n"), REPORT_BUGS_TO);
252b5132
RH
271 exit (status);
272}
273
274/* Set the radix for the symbol value and size according to RADIX. */
275
276static void
2da42df6 277set_print_radix (char *radix)
252b5132
RH
278{
279 switch (*radix)
280 {
281 case 'x':
282 break;
283 case 'd':
284 case 'o':
285 if (*radix == 'd')
286 print_radix = 10;
287 else
288 print_radix = 8;
970ccc77 289 value_format_32bit[4] = *radix;
39dbeff8 290#if BFD_HOST_64BIT_LONG
970ccc77 291 value_format_64bit[5] = *radix;
39dbeff8 292#elif BFD_HOST_64BIT_LONG_LONG
a46d1146 293#ifndef __MSVCRT__
39dbeff8 294 value_format_64bit[6] = *radix;
a46d1146
JM
295#else
296 value_format_64bit[7] = *radix;
297#endif
39dbeff8 298#endif
252b5132
RH
299 other_format[3] = desc_format[3] = *radix;
300 break;
301 default:
37cc8ec1 302 fatal (_("%s: invalid radix"), radix);
252b5132
RH
303 }
304}
305
306static void
2da42df6 307set_output_format (char *f)
252b5132
RH
308{
309 int i;
310
311 switch (*f)
312 {
313 case 'b':
314 case 'B':
315 i = FORMAT_BSD;
316 break;
317 case 'p':
318 case 'P':
319 i = FORMAT_POSIX;
320 break;
321 case 's':
322 case 'S':
323 i = FORMAT_SYSV;
324 break;
325 default:
37cc8ec1 326 fatal (_("%s: invalid output format"), f);
252b5132
RH
327 }
328 format = &formats[i];
329}
330\f
33f5f537 331static const char *
2da42df6 332get_symbol_type (unsigned int type)
33f5f537
L
333{
334 static char buff [32];
335
336 switch (type)
337 {
338 case STT_NOTYPE: return "NOTYPE";
339 case STT_OBJECT: return "OBJECT";
340 case STT_FUNC: return "FUNC";
341 case STT_SECTION: return "SECTION";
342 case STT_FILE: return "FILE";
343 case STT_COMMON: return "COMMON";
344 case STT_TLS: return "TLS";
345 default:
346 if (type >= STT_LOPROC && type <= STT_HIPROC)
347 sprintf (buff, _("<processor specific>: %d"), type);
348 else if (type >= STT_LOOS && type <= STT_HIOS)
349 sprintf (buff, _("<OS specific>: %d"), type);
350 else
351 sprintf (buff, _("<unknown>: %d"), type);
352 return buff;
353 }
354}
382c1116 355\f
91d6fa6a 356/* Print symbol name NAME, read from ABFD, with printf format FORM,
382c1116 357 demangling it if requested. */
33f5f537 358
252b5132 359static void
91d6fa6a 360print_symname (const char *form, const char *name, bfd *abfd)
252b5132 361{
382c1116 362 if (do_demangle && *name)
252b5132 363 {
ed180cc5
AM
364 char *res = bfd_demangle (abfd, name, DMGL_ANSI | DMGL_PARAMS);
365
366 if (res != NULL)
367 {
91d6fa6a 368 printf (form, res);
ed180cc5
AM
369 free (res);
370 return;
371 }
382c1116 372 }
252b5132 373
91d6fa6a 374 printf (form, name);
382c1116 375}
252b5132 376
382c1116
NC
377static void
378print_symdef_entry (bfd *abfd)
379{
380 symindex idx = BFD_NO_MORE_SYMBOLS;
381 carsym *thesym;
382 bfd_boolean everprinted = FALSE;
33f5f537 383
382c1116
NC
384 for (idx = bfd_get_next_mapent (abfd, idx, &thesym);
385 idx != BFD_NO_MORE_SYMBOLS;
386 idx = bfd_get_next_mapent (abfd, idx, &thesym))
387 {
388 bfd *elt;
389 if (!everprinted)
252b5132 390 {
382c1116
NC
391 printf (_("\nArchive index:\n"));
392 everprinted = TRUE;
252b5132 393 }
382c1116
NC
394 elt = bfd_get_elt_at_index (abfd, idx);
395 if (elt == NULL)
396 bfd_fatal ("bfd_get_elt_at_index");
397 if (thesym->name != (char *) NULL)
252b5132 398 {
382c1116
NC
399 print_symname ("%s", thesym->name, abfd);
400 printf (" in %s\n", bfd_get_filename (elt));
252b5132 401 }
252b5132
RH
402 }
403}
382c1116
NC
404\f
405/* Choose which symbol entries to print;
406 compact them downward to get rid of the rest.
407 Return the number of symbols to be printed. */
252b5132 408
382c1116 409static long
91d6fa6a 410filter_symbols (bfd *abfd, bfd_boolean is_dynamic, void *minisyms,
382c1116 411 long symcount, unsigned int size)
252b5132 412{
382c1116
NC
413 bfd_byte *from, *fromend, *to;
414 asymbol *store;
252b5132 415
382c1116
NC
416 store = bfd_make_empty_symbol (abfd);
417 if (store == NULL)
418 bfd_fatal (bfd_get_filename (abfd));
f24ddbdd 419
382c1116
NC
420 from = (bfd_byte *) minisyms;
421 fromend = from + symcount * size;
422 to = (bfd_byte *) minisyms;
252b5132 423
382c1116 424 for (; from < fromend; from += size)
252b5132 425 {
382c1116
NC
426 int keep = 0;
427 asymbol *sym;
33f5f537 428
382c1116
NC
429 PROGRESS (1);
430
91d6fa6a 431 sym = bfd_minisymbol_to_symbol (abfd, is_dynamic, (const void *) from, store);
382c1116
NC
432 if (sym == NULL)
433 bfd_fatal (bfd_get_filename (abfd));
434
435 if (undefined_only)
436 keep = bfd_is_und_section (sym->section);
437 else if (external_only)
6a1b08f5
L
438 /* PR binutls/12753: Unique symbols are global too. */
439 keep = ((sym->flags & (BSF_GLOBAL
440 | BSF_WEAK
441 | BSF_GNU_UNIQUE)) != 0
382c1116
NC
442 || bfd_is_und_section (sym->section)
443 || bfd_is_com_section (sym->section));
444 else
445 keep = 1;
446
447 if (keep
448 && ! print_debug_syms
449 && (sym->flags & BSF_DEBUGGING) != 0)
450 keep = 0;
451
452 if (keep
453 && sort_by_size
454 && (bfd_is_abs_section (sym->section)
455 || bfd_is_und_section (sym->section)))
456 keep = 0;
457
458 if (keep
459 && defined_only)
252b5132 460 {
382c1116
NC
461 if (bfd_is_und_section (sym->section))
462 keep = 0;
252b5132 463 }
252b5132 464
3c9458e9
NC
465 if (keep
466 && bfd_is_target_special_symbol (abfd, sym)
467 && ! allow_special_symbols)
468 keep = 0;
469
382c1116
NC
470 if (keep)
471 {
ede76260
HPN
472 if (to != from)
473 memcpy (to, from, size);
382c1116
NC
474 to += size;
475 }
476 }
252b5132 477
382c1116 478 return (to - (bfd_byte *) minisyms) / size;
252b5132
RH
479}
480\f
481/* These globals are used to pass information into the sorting
482 routines. */
483static bfd *sort_bfd;
b34976b6 484static bfd_boolean sort_dynamic;
252b5132
RH
485static asymbol *sort_x;
486static asymbol *sort_y;
487
488/* Symbol-sorting predicates */
489#define valueof(x) ((x)->section->vma + (x)->value)
490
491/* Numeric sorts. Undefined symbols are always considered "less than"
492 defined symbols with zero values. Common symbols are not treated
493 specially -- i.e., their sizes are used as their "values". */
494
252b5132 495static int
2da42df6 496non_numeric_forward (const void *P_x, const void *P_y)
252b5132
RH
497{
498 asymbol *x, *y;
499 const char *xn, *yn;
500
501 x = bfd_minisymbol_to_symbol (sort_bfd, sort_dynamic, P_x, sort_x);
502 y = bfd_minisymbol_to_symbol (sort_bfd, sort_dynamic, P_y, sort_y);
503 if (x == NULL || y == NULL)
504 bfd_fatal (bfd_get_filename (sort_bfd));
505
506 xn = bfd_asymbol_name (x);
507 yn = bfd_asymbol_name (y);
508
9710509e
AM
509 if (yn == NULL)
510 return xn != NULL;
511 if (xn == NULL)
512 return -1;
513
514#ifdef HAVE_STRCOLL
515 /* Solaris 2.5 has a bug in strcoll.
516 strcoll returns invalid values when confronted with empty strings. */
517 if (*yn == '\0')
518 return *xn != '\0';
519 if (*xn == '\0')
520 return -1;
521
522 return strcoll (xn, yn);
523#else
524 return strcmp (xn, yn);
525#endif
252b5132
RH
526}
527
528static int
2da42df6 529non_numeric_reverse (const void *x, const void *y)
252b5132
RH
530{
531 return - non_numeric_forward (x, y);
532}
533
382c1116
NC
534static int
535numeric_forward (const void *P_x, const void *P_y)
536{
537 asymbol *x, *y;
538 asection *xs, *ys;
539
540 x = bfd_minisymbol_to_symbol (sort_bfd, sort_dynamic, P_x, sort_x);
541 y = bfd_minisymbol_to_symbol (sort_bfd, sort_dynamic, P_y, sort_y);
542 if (x == NULL || y == NULL)
543 bfd_fatal (bfd_get_filename (sort_bfd));
544
545 xs = bfd_get_section (x);
546 ys = bfd_get_section (y);
547
548 if (bfd_is_und_section (xs))
549 {
550 if (! bfd_is_und_section (ys))
551 return -1;
552 }
553 else if (bfd_is_und_section (ys))
554 return 1;
555 else if (valueof (x) != valueof (y))
556 return valueof (x) < valueof (y) ? -1 : 1;
557
558 return non_numeric_forward (P_x, P_y);
559}
560
561static int
562numeric_reverse (const void *x, const void *y)
563{
564 return - numeric_forward (x, y);
565}
566
2da42df6 567static int (*(sorters[2][2])) (const void *, const void *) =
252b5132
RH
568{
569 { non_numeric_forward, non_numeric_reverse },
570 { numeric_forward, numeric_reverse }
571};
572
573/* This sort routine is used by sort_symbols_by_size. It is similar
574 to numeric_forward, but when symbols have the same value it sorts
575 by section VMA. This simplifies the sort_symbols_by_size code
576 which handles symbols at the end of sections. Also, this routine
577 tries to sort file names before other symbols with the same value.
578 That will make the file name have a zero size, which will make
579 sort_symbols_by_size choose the non file name symbol, leading to
580 more meaningful output. For similar reasons, this code sorts
581 gnu_compiled_* and gcc2_compiled before other symbols with the same
582 value. */
583
584static int
2da42df6 585size_forward1 (const void *P_x, const void *P_y)
252b5132
RH
586{
587 asymbol *x, *y;
588 asection *xs, *ys;
589 const char *xn, *yn;
590 size_t xnl, ynl;
591 int xf, yf;
592
593 x = bfd_minisymbol_to_symbol (sort_bfd, sort_dynamic, P_x, sort_x);
594 y = bfd_minisymbol_to_symbol (sort_bfd, sort_dynamic, P_y, sort_y);
595 if (x == NULL || y == NULL)
596 bfd_fatal (bfd_get_filename (sort_bfd));
597
598 xs = bfd_get_section (x);
599 ys = bfd_get_section (y);
600
601 if (bfd_is_und_section (xs))
602 abort ();
603 if (bfd_is_und_section (ys))
604 abort ();
605
606 if (valueof (x) != valueof (y))
607 return valueof (x) < valueof (y) ? -1 : 1;
608
609 if (xs->vma != ys->vma)
610 return xs->vma < ys->vma ? -1 : 1;
611
612 xn = bfd_asymbol_name (x);
613 yn = bfd_asymbol_name (y);
614 xnl = strlen (xn);
615 ynl = strlen (yn);
616
617 /* The symbols gnu_compiled and gcc2_compiled convey even less
618 information than the file name, so sort them out first. */
619
620 xf = (strstr (xn, "gnu_compiled") != NULL
621 || strstr (xn, "gcc2_compiled") != NULL);
622 yf = (strstr (yn, "gnu_compiled") != NULL
623 || strstr (yn, "gcc2_compiled") != NULL);
624
625 if (xf && ! yf)
626 return -1;
627 if (! xf && yf)
628 return 1;
629
630 /* We use a heuristic for the file name. It may not work on non
631 Unix systems, but it doesn't really matter; the only difference
632 is precisely which symbol names get printed. */
633
634#define file_symbol(s, sn, snl) \
635 (((s)->flags & BSF_FILE) != 0 \
636 || ((sn)[(snl) - 2] == '.' \
637 && ((sn)[(snl) - 1] == 'o' \
638 || (sn)[(snl) - 1] == 'a')))
639
640 xf = file_symbol (x, xn, xnl);
641 yf = file_symbol (y, yn, ynl);
642
643 if (xf && ! yf)
644 return -1;
645 if (! xf && yf)
646 return 1;
647
648 return non_numeric_forward (P_x, P_y);
649}
650
651/* This sort routine is used by sort_symbols_by_size. It is sorting
652 an array of size_sym structures into size order. */
653
654static int
2da42df6 655size_forward2 (const void *P_x, const void *P_y)
252b5132
RH
656{
657 const struct size_sym *x = (const struct size_sym *) P_x;
658 const struct size_sym *y = (const struct size_sym *) P_y;
659
660 if (x->size < y->size)
661 return reverse_sort ? 1 : -1;
662 else if (x->size > y->size)
663 return reverse_sort ? -1 : 1;
664 else
665 return sorters[0][reverse_sort] (x->minisym, y->minisym);
666}
667
6ab6b380
NC
668/* Sort the symbols by size. ELF provides a size but for other formats
669 we have to make a guess by assuming that the difference between the
670 address of a symbol and the address of the next higher symbol is the
671 size. */
252b5132
RH
672
673static long
91d6fa6a 674sort_symbols_by_size (bfd *abfd, bfd_boolean is_dynamic, void *minisyms,
2da42df6
AJ
675 long symcount, unsigned int size,
676 struct size_sym **symsizesp)
252b5132
RH
677{
678 struct size_sym *symsizes;
679 bfd_byte *from, *fromend;
680 asymbol *sym = NULL;
681 asymbol *store_sym, *store_next;
682
683 qsort (minisyms, symcount, size, size_forward1);
684
685 /* We are going to return a special set of symbols and sizes to
686 print. */
3f5e193b 687 symsizes = (struct size_sym *) xmalloc (symcount * sizeof (struct size_sym));
252b5132
RH
688 *symsizesp = symsizes;
689
690 /* Note that filter_symbols has already removed all absolute and
691 undefined symbols. Here we remove all symbols whose size winds
692 up as zero. */
252b5132
RH
693 from = (bfd_byte *) minisyms;
694 fromend = from + symcount * size;
695
696 store_sym = sort_x;
697 store_next = sort_y;
698
699 if (from < fromend)
700 {
91d6fa6a 701 sym = bfd_minisymbol_to_symbol (abfd, is_dynamic, (const void *) from,
252b5132
RH
702 store_sym);
703 if (sym == NULL)
704 bfd_fatal (bfd_get_filename (abfd));
705 }
706
707 for (; from < fromend; from += size)
708 {
709 asymbol *next;
710 asection *sec;
711 bfd_vma sz;
712 asymbol *temp;
713
714 if (from + size < fromend)
715 {
716 next = bfd_minisymbol_to_symbol (abfd,
91d6fa6a 717 is_dynamic,
2da42df6 718 (const void *) (from + size),
252b5132
RH
719 store_next);
720 if (next == NULL)
721 bfd_fatal (bfd_get_filename (abfd));
722 }
723 else
724 next = NULL;
725
726 sec = bfd_get_section (sym);
727
9710509e 728 if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
6ab6b380
NC
729 sz = ((elf_symbol_type *) sym)->internal_elf_sym.st_size;
730 else if (bfd_is_com_section (sec))
252b5132
RH
731 sz = sym->value;
732 else
733 {
734 if (from + size < fromend
735 && sec == bfd_get_section (next))
736 sz = valueof (next) - valueof (sym);
737 else
738 sz = (bfd_get_section_vma (abfd, sec)
739 + bfd_section_size (abfd, sec)
740 - valueof (sym));
741 }
742
743 if (sz != 0)
744 {
2da42df6 745 symsizes->minisym = (const void *) from;
252b5132
RH
746 symsizes->size = sz;
747 ++symsizes;
748 }
749
750 sym = next;
751
752 temp = store_sym;
753 store_sym = store_next;
754 store_next = temp;
755 }
756
757 symcount = symsizes - *symsizesp;
758
759 /* We must now sort again by size. */
2da42df6 760 qsort ((void *) *symsizesp, symcount, sizeof (struct size_sym), size_forward2);
252b5132
RH
761
762 return symcount;
763}
382c1116
NC
764
765/* This function is used to get the relocs for a particular section.
766 It is called via bfd_map_over_sections. */
252b5132
RH
767
768static void
382c1116 769get_relocs (bfd *abfd, asection *sec, void *dataarg)
252b5132 770{
382c1116 771 struct get_relocs_info *data = (struct get_relocs_info *) dataarg;
252b5132 772
382c1116
NC
773 *data->secs = sec;
774
775 if ((sec->flags & SEC_RELOC) == 0)
252b5132 776 {
382c1116
NC
777 *data->relocs = NULL;
778 *data->relcount = 0;
252b5132 779 }
382c1116
NC
780 else
781 {
782 long relsize;
252b5132 783
382c1116
NC
784 relsize = bfd_get_reloc_upper_bound (abfd, sec);
785 if (relsize < 0)
786 bfd_fatal (bfd_get_filename (abfd));
252b5132 787
3f5e193b 788 *data->relocs = (arelent **) xmalloc (relsize);
382c1116
NC
789 *data->relcount = bfd_canonicalize_reloc (abfd, sec, *data->relocs,
790 data->syms);
791 if (*data->relcount < 0)
792 bfd_fatal (bfd_get_filename (abfd));
68a4c073 793 }
252b5132 794
382c1116
NC
795 ++data->secs;
796 ++data->relocs;
797 ++data->relcount;
798}
799
800/* Print a single symbol. */
801
802static void
803print_symbol (bfd *abfd, asymbol *sym, bfd_vma ssize, bfd *archive_bfd)
804{
805 symbol_info syminfo;
806 struct extended_symbol_info info;
807
808 PROGRESS (1);
809
810 format->print_symbol_filename (archive_bfd, abfd);
811
812 bfd_get_symbol_info (abfd, sym, &syminfo);
813 info.sinfo = &syminfo;
814 info.ssize = ssize;
815 if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
816 info.elfinfo = (elf_symbol_type *) sym;
817 else
818 info.elfinfo = NULL;
819 format->print_symbol_info (&info, abfd);
820
821 if (line_numbers)
0873df2a 822 {
382c1116
NC
823 static asymbol **syms;
824 static long symcount;
825 const char *filename, *functionname;
826 unsigned int lineno;
0873df2a 827
382c1116
NC
828 /* We need to get the canonical symbols in order to call
829 bfd_find_nearest_line. This is inefficient, but, then, you
830 don't have to use --line-numbers. */
831 if (abfd != lineno_cache_bfd && syms != NULL)
0873df2a 832 {
382c1116
NC
833 free (syms);
834 syms = NULL;
0873df2a 835 }
382c1116 836 if (syms == NULL)
0873df2a 837 {
382c1116
NC
838 long symsize;
839
840 symsize = bfd_get_symtab_upper_bound (abfd);
841 if (symsize < 0)
842 bfd_fatal (bfd_get_filename (abfd));
3f5e193b 843 syms = (asymbol **) xmalloc (symsize);
382c1116
NC
844 symcount = bfd_canonicalize_symtab (abfd, syms);
845 if (symcount < 0)
846 bfd_fatal (bfd_get_filename (abfd));
847 lineno_cache_bfd = abfd;
0873df2a 848 }
0873df2a 849
382c1116
NC
850 if (bfd_is_und_section (bfd_get_section (sym)))
851 {
852 static asection **secs;
853 static arelent ***relocs;
854 static long *relcount;
855 static unsigned int seccount;
856 unsigned int i;
857 const char *symname;
0873df2a 858
382c1116
NC
859 /* For an undefined symbol, we try to find a reloc for the
860 symbol, and print the line number of the reloc. */
861 if (abfd != lineno_cache_rel_bfd && relocs != NULL)
862 {
863 for (i = 0; i < seccount; i++)
864 if (relocs[i] != NULL)
865 free (relocs[i]);
866 free (secs);
867 free (relocs);
868 free (relcount);
869 secs = NULL;
870 relocs = NULL;
871 relcount = NULL;
872 }
252b5132 873
382c1116
NC
874 if (relocs == NULL)
875 {
91d6fa6a 876 struct get_relocs_info rinfo;
252b5132 877
382c1116 878 seccount = bfd_count_sections (abfd);
252b5132 879
3f5e193b
NC
880 secs = (asection **) xmalloc (seccount * sizeof *secs);
881 relocs = (arelent ***) xmalloc (seccount * sizeof *relocs);
882 relcount = (long *) xmalloc (seccount * sizeof *relcount);
252b5132 883
91d6fa6a
NC
884 rinfo.secs = secs;
885 rinfo.relocs = relocs;
886 rinfo.relcount = relcount;
887 rinfo.syms = syms;
888 bfd_map_over_sections (abfd, get_relocs, (void *) &rinfo);
382c1116
NC
889 lineno_cache_rel_bfd = abfd;
890 }
252b5132 891
382c1116
NC
892 symname = bfd_asymbol_name (sym);
893 for (i = 0; i < seccount; i++)
894 {
895 long j;
896
897 for (j = 0; j < relcount[i]; j++)
898 {
899 arelent *r;
900
901 r = relocs[i][j];
902 if (r->sym_ptr_ptr != NULL
903 && (*r->sym_ptr_ptr)->section == sym->section
904 && (*r->sym_ptr_ptr)->value == sym->value
905 && strcmp (symname,
906 bfd_asymbol_name (*r->sym_ptr_ptr)) == 0
907 && bfd_find_nearest_line (abfd, secs[i], syms,
908 r->address, &filename,
909 &functionname, &lineno)
910 && filename != NULL)
911 {
912 /* We only print the first one we find. */
913 printf ("\t%s:%u", filename, lineno);
914 i = seccount;
915 break;
916 }
917 }
918 }
919 }
920 else if (bfd_get_section (sym)->owner == abfd)
921 {
5420f73d
L
922 if ((bfd_find_line (abfd, syms, sym, &filename, &lineno)
923 || bfd_find_nearest_line (abfd, bfd_get_section (sym),
924 syms, sym->value, &filename,
925 &functionname, &lineno))
382c1116
NC
926 && filename != NULL
927 && lineno != 0)
928 printf ("\t%s:%u", filename, lineno);
929 }
930 }
931
932 putchar ('\n');
252b5132
RH
933}
934\f
382c1116 935/* Print the symbols when sorting by size. */
252b5132 936
382c1116 937static void
91d6fa6a 938print_size_symbols (bfd *abfd, bfd_boolean is_dynamic,
382c1116
NC
939 struct size_sym *symsizes, long symcount,
940 bfd *archive_bfd)
252b5132 941{
252b5132 942 asymbol *store;
382c1116 943 struct size_sym *from, *fromend;
252b5132
RH
944
945 store = bfd_make_empty_symbol (abfd);
946 if (store == NULL)
947 bfd_fatal (bfd_get_filename (abfd));
948
382c1116
NC
949 from = symsizes;
950 fromend = from + symcount;
951 for (; from < fromend; from++)
252b5132 952 {
252b5132 953 asymbol *sym;
382c1116 954 bfd_vma ssize;
252b5132 955
91d6fa6a 956 sym = bfd_minisymbol_to_symbol (abfd, is_dynamic, from->minisym, store);
252b5132
RH
957 if (sym == NULL)
958 bfd_fatal (bfd_get_filename (abfd));
959
382c1116
NC
960 /* For elf we have already computed the correct symbol size. */
961 if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
962 ssize = from->size;
252b5132 963 else
382c1116 964 ssize = from->size - bfd_section_vma (abfd, bfd_get_section (sym));
eb3f2f5c 965
382c1116 966 print_symbol (abfd, sym, ssize, archive_bfd);
252b5132 967 }
252b5132
RH
968}
969
382c1116 970\f
252b5132
RH
971/* Print the symbols. If ARCHIVE_BFD is non-NULL, it is the archive
972 containing ABFD. */
973
974static void
91d6fa6a 975print_symbols (bfd *abfd, bfd_boolean is_dynamic, void *minisyms, long symcount,
2da42df6 976 unsigned int size, bfd *archive_bfd)
252b5132
RH
977{
978 asymbol *store;
979 bfd_byte *from, *fromend;
980
981 store = bfd_make_empty_symbol (abfd);
982 if (store == NULL)
983 bfd_fatal (bfd_get_filename (abfd));
984
985 from = (bfd_byte *) minisyms;
986 fromend = from + symcount * size;
987 for (; from < fromend; from += size)
988 {
989 asymbol *sym;
990
91d6fa6a 991 sym = bfd_minisymbol_to_symbol (abfd, is_dynamic, from, store);
252b5132
RH
992 if (sym == NULL)
993 bfd_fatal (bfd_get_filename (abfd));
994
33f5f537 995 print_symbol (abfd, sym, (bfd_vma) 0, archive_bfd);
252b5132
RH
996 }
997}
998
382c1116 999/* If ARCHIVE_BFD is non-NULL, it is the archive containing ABFD. */
252b5132 1000
0af11b59 1001static void
382c1116 1002display_rel_file (bfd *abfd, bfd *archive_bfd)
252b5132 1003{
382c1116
NC
1004 long symcount;
1005 void *minisyms;
1006 unsigned int size;
1007 struct size_sym *symsizes;
252b5132 1008
382c1116
NC
1009 if (! dynamic)
1010 {
1011 if (!(bfd_get_file_flags (abfd) & HAS_SYMS))
1012 {
1013 non_fatal (_("%s: no symbols"), bfd_get_filename (abfd));
1014 return;
1015 }
1016 }
1017
1018 symcount = bfd_read_minisymbols (abfd, dynamic, &minisyms, &size);
1019 if (symcount < 0)
252b5132
RH
1020 bfd_fatal (bfd_get_filename (abfd));
1021
382c1116 1022 if (symcount == 0)
252b5132 1023 {
382c1116
NC
1024 non_fatal (_("%s: no symbols"), bfd_get_filename (abfd));
1025 return;
1026 }
252b5132 1027
382c1116
NC
1028 if (show_synthetic && size == sizeof (asymbol *))
1029 {
1030 asymbol *synthsyms;
1031 long synth_count;
1032 asymbol **static_syms = NULL;
1033 asymbol **dyn_syms = NULL;
1034 long static_count = 0;
1035 long dyn_count = 0;
252b5132 1036
382c1116
NC
1037 if (dynamic)
1038 {
1039 dyn_count = symcount;
3f5e193b 1040 dyn_syms = (asymbol **) minisyms;
382c1116 1041 }
977f7911 1042 else
382c1116 1043 {
8615f3f2
AM
1044 long storage = bfd_get_dynamic_symtab_upper_bound (abfd);
1045
382c1116 1046 static_count = symcount;
3f5e193b 1047 static_syms = (asymbol **) minisyms;
8615f3f2
AM
1048
1049 if (storage > 0)
1050 {
3f5e193b 1051 dyn_syms = (asymbol **) xmalloc (storage);
8615f3f2
AM
1052 dyn_count = bfd_canonicalize_dynamic_symtab (abfd, dyn_syms);
1053 if (dyn_count < 0)
1054 bfd_fatal (bfd_get_filename (abfd));
1055 }
382c1116
NC
1056 }
1057 synth_count = bfd_get_synthetic_symtab (abfd, static_count, static_syms,
1058 dyn_count, dyn_syms, &synthsyms);
1059 if (synth_count > 0)
1060 {
1061 asymbol **symp;
1062 void *new_mini;
1063 long i;
977f7911 1064
382c1116 1065 new_mini = xmalloc ((symcount + synth_count + 1) * sizeof (*symp));
3f5e193b 1066 symp = (asymbol **) new_mini;
382c1116
NC
1067 memcpy (symp, minisyms, symcount * sizeof (*symp));
1068 symp += symcount;
1069 for (i = 0; i < synth_count; i++)
1070 *symp++ = synthsyms + i;
1071 *symp = 0;
1072 minisyms = new_mini;
1073 symcount += synth_count;
1074 }
252b5132 1075 }
252b5132 1076
382c1116
NC
1077 /* Discard the symbols we don't want to print.
1078 It's OK to do this in place; we'll free the storage anyway
1079 (after printing). */
252b5132 1080
382c1116 1081 symcount = filter_symbols (abfd, dynamic, minisyms, symcount, size);
2da42df6 1082
382c1116
NC
1083 symsizes = NULL;
1084 if (! no_sort)
1085 {
1086 sort_bfd = abfd;
1087 sort_dynamic = dynamic;
1088 sort_x = bfd_make_empty_symbol (abfd);
1089 sort_y = bfd_make_empty_symbol (abfd);
1090 if (sort_x == NULL || sort_y == NULL)
1091 bfd_fatal (bfd_get_filename (abfd));
252b5132 1092
382c1116
NC
1093 if (! sort_by_size)
1094 qsort (minisyms, symcount, size,
1095 sorters[sort_numerically][reverse_sort]);
1096 else
1097 symcount = sort_symbols_by_size (abfd, dynamic, minisyms, symcount,
1098 size, &symsizes);
1099 }
252b5132 1100
382c1116
NC
1101 if (! sort_by_size)
1102 print_symbols (abfd, dynamic, minisyms, symcount, size, archive_bfd);
252b5132 1103 else
382c1116 1104 print_size_symbols (abfd, dynamic, symsizes, symcount, archive_bfd);
252b5132 1105
382c1116 1106 free (minisyms);
497b9b32 1107 free (symsizes);
382c1116
NC
1108}
1109
970ccc77
NC
1110static void
1111set_print_width (bfd *file)
1112{
1113 print_width = bfd_get_arch_size (file);
1114
1115 if (print_width == -1)
1116 {
1117 /* PR binutils/4292
1118 Guess the target's bitsize based on its name.
1119 We assume here than any 64-bit format will include
1120 "64" somewhere in its name. The only known exception
1121 is the MMO object file format. */
1122 if (strstr (bfd_get_target (file), "64") != NULL
1123 || strcmp (bfd_get_target (file), "mmo") == 0)
1124 print_width = 64;
1125 else
1126 print_width = 32;
1127 }
1128}
1129
382c1116
NC
1130static void
1131display_archive (bfd *file)
1132{
1133 bfd *arfile = NULL;
1134 bfd *last_arfile = NULL;
1135 char **matching;
1136
1137 format->print_archive_filename (bfd_get_filename (file));
1138
1139 if (print_armap)
1140 print_symdef_entry (file);
1141
1142 for (;;)
252b5132 1143 {
382c1116 1144 PROGRESS (1);
252b5132 1145
382c1116
NC
1146 arfile = bfd_openr_next_archived_file (file, arfile);
1147
1148 if (arfile == NULL)
252b5132 1149 {
382c1116
NC
1150 if (bfd_get_error () != bfd_error_no_more_archived_files)
1151 bfd_fatal (bfd_get_filename (file));
1152 break;
252b5132 1153 }
382c1116
NC
1154
1155 if (bfd_check_format_matches (arfile, bfd_object, &matching))
252b5132 1156 {
970ccc77 1157 set_print_width (arfile);
382c1116
NC
1158 format->print_archive_member (bfd_get_filename (file),
1159 bfd_get_filename (arfile));
1160 display_rel_file (arfile, file);
252b5132 1161 }
382c1116 1162 else
252b5132 1163 {
382c1116
NC
1164 bfd_nonfatal (bfd_get_filename (arfile));
1165 if (bfd_get_error () == bfd_error_file_ambiguously_recognized)
252b5132 1166 {
382c1116
NC
1167 list_matching_formats (matching);
1168 free (matching);
252b5132 1169 }
382c1116 1170 }
252b5132 1171
382c1116
NC
1172 if (last_arfile != NULL)
1173 {
1174 bfd_close (last_arfile);
1175 lineno_cache_bfd = NULL;
1176 lineno_cache_rel_bfd = NULL;
1177 }
1178 last_arfile = arfile;
1179 }
252b5132 1180
382c1116
NC
1181 if (last_arfile != NULL)
1182 {
1183 bfd_close (last_arfile);
1184 lineno_cache_bfd = NULL;
1185 lineno_cache_rel_bfd = NULL;
1186 }
1187}
252b5132 1188
382c1116
NC
1189static bfd_boolean
1190display_file (char *filename)
1191{
1192 bfd_boolean retval = TRUE;
1193 bfd *file;
1194 char **matching;
252b5132 1195
382c1116
NC
1196 if (get_file_size (filename) < 1)
1197 return FALSE;
252b5132 1198
a4b8af35 1199 file = bfd_openr (filename, target ? target : plugin_target);
382c1116
NC
1200 if (file == NULL)
1201 {
1202 bfd_nonfatal (filename);
1203 return FALSE;
1204 }
252b5132 1205
b76e66d3
CC
1206 /* If printing line numbers, decompress the debug sections. */
1207 if (line_numbers)
1208 file->flags |= BFD_DECOMPRESS;
1209
382c1116
NC
1210 if (bfd_check_format (file, bfd_archive))
1211 {
1212 display_archive (file);
1213 }
1214 else if (bfd_check_format_matches (file, bfd_object, &matching))
1215 {
970ccc77 1216 set_print_width (file);
382c1116
NC
1217 format->print_object_filename (filename);
1218 display_rel_file (file, NULL);
1219 }
1220 else
1221 {
1222 bfd_nonfatal (filename);
1223 if (bfd_get_error () == bfd_error_file_ambiguously_recognized)
252b5132 1224 {
382c1116
NC
1225 list_matching_formats (matching);
1226 free (matching);
252b5132 1227 }
382c1116 1228 retval = FALSE;
252b5132
RH
1229 }
1230
382c1116
NC
1231 if (!bfd_close (file))
1232 bfd_fatal (filename);
1233
1234 lineno_cache_bfd = NULL;
1235 lineno_cache_rel_bfd = NULL;
1236
1237 return retval;
252b5132
RH
1238}
1239\f
1240/* The following 3 groups of functions are called unconditionally,
1241 once at the start of processing each file of the appropriate type.
1242 They should check `filename_per_file' and `filename_per_symbol',
1243 as appropriate for their output format, to determine whether to
1244 print anything. */
1245\f
1246/* Print the name of an object file given on the command line. */
1247
1248static void
2da42df6 1249print_object_filename_bsd (char *filename)
252b5132
RH
1250{
1251 if (filename_per_file && !filename_per_symbol)
1252 printf ("\n%s:\n", filename);
1253}
1254
1255static void
2da42df6 1256print_object_filename_sysv (char *filename)
252b5132
RH
1257{
1258 if (undefined_only)
1259 printf (_("\n\nUndefined symbols from %s:\n\n"), filename);
1260 else
1261 printf (_("\n\nSymbols from %s:\n\n"), filename);
970ccc77 1262 if (print_width == 32)
33f5f537
L
1263 printf (_("\
1264Name Value Class Type Size Line Section\n\n"));
1265 else
1266 printf (_("\
1267Name Value Class Type Size Line Section\n\n"));
252b5132
RH
1268}
1269
1270static void
2da42df6 1271print_object_filename_posix (char *filename)
252b5132
RH
1272{
1273 if (filename_per_file && !filename_per_symbol)
1274 printf ("%s:\n", filename);
1275}
1276\f
1277/* Print the name of an archive file given on the command line. */
1278
1279static void
2da42df6 1280print_archive_filename_bsd (char *filename)
252b5132
RH
1281{
1282 if (filename_per_file)
1283 printf ("\n%s:\n", filename);
1284}
1285
1286static void
2da42df6 1287print_archive_filename_sysv (char *filename ATTRIBUTE_UNUSED)
252b5132
RH
1288{
1289}
1290
1291static void
2da42df6 1292print_archive_filename_posix (char *filename ATTRIBUTE_UNUSED)
252b5132
RH
1293{
1294}
1295\f
1296/* Print the name of an archive member file. */
1297
1298static void
2da42df6
AJ
1299print_archive_member_bsd (char *archive ATTRIBUTE_UNUSED,
1300 const char *filename)
252b5132
RH
1301{
1302 if (!filename_per_symbol)
1303 printf ("\n%s:\n", filename);
1304}
1305
1306static void
2da42df6 1307print_archive_member_sysv (char *archive, const char *filename)
252b5132
RH
1308{
1309 if (undefined_only)
1310 printf (_("\n\nUndefined symbols from %s[%s]:\n\n"), archive, filename);
1311 else
1312 printf (_("\n\nSymbols from %s[%s]:\n\n"), archive, filename);
970ccc77 1313 if (print_width == 32)
33f5f537
L
1314 printf (_("\
1315Name Value Class Type Size Line Section\n\n"));
1316 else
1317 printf (_("\
1318Name Value Class Type Size Line Section\n\n"));
252b5132
RH
1319}
1320
1321static void
2da42df6 1322print_archive_member_posix (char *archive, const char *filename)
252b5132
RH
1323{
1324 if (!filename_per_symbol)
1325 printf ("%s[%s]:\n", archive, filename);
1326}
1327\f
1328/* Print the name of the file (and archive, if there is one)
1329 containing a symbol. */
1330
1331static void
2da42df6 1332print_symbol_filename_bsd (bfd *archive_bfd, bfd *abfd)
252b5132
RH
1333{
1334 if (filename_per_symbol)
1335 {
1336 if (archive_bfd)
1337 printf ("%s:", bfd_get_filename (archive_bfd));
1338 printf ("%s:", bfd_get_filename (abfd));
1339 }
1340}
1341
1342static void
2da42df6 1343print_symbol_filename_sysv (bfd *archive_bfd, bfd *abfd)
252b5132
RH
1344{
1345 if (filename_per_symbol)
1346 {
1347 if (archive_bfd)
1348 printf ("%s:", bfd_get_filename (archive_bfd));
1349 printf ("%s:", bfd_get_filename (abfd));
1350 }
1351}
1352
1353static void
2da42df6 1354print_symbol_filename_posix (bfd *archive_bfd, bfd *abfd)
252b5132
RH
1355{
1356 if (filename_per_symbol)
1357 {
1358 if (archive_bfd)
1359 printf ("%s[%s]: ", bfd_get_filename (archive_bfd),
1360 bfd_get_filename (abfd));
1361 else
1362 printf ("%s: ", bfd_get_filename (abfd));
1363 }
1364}
1365\f
1366/* Print a symbol value. */
1367
1368static void
2da42df6 1369print_value (bfd *abfd ATTRIBUTE_UNUSED, bfd_vma val)
252b5132 1370{
970ccc77 1371 switch (print_width)
252b5132 1372 {
970ccc77 1373 case 32:
be26064b 1374 printf (value_format_32bit, (unsigned long) val);
970ccc77 1375 break;
252b5132 1376
970ccc77 1377 case 64:
39dbeff8 1378#if BFD_HOST_64BIT_LONG || BFD_HOST_64BIT_LONG_LONG
970ccc77
NC
1379 printf (value_format_64bit, val);
1380#else
1381 /* We have a 64 bit value to print, but the host is only 32 bit. */
1382 if (print_radix == 16)
1383 bfd_fprintf_vma (abfd, stdout, val);
1384 else
252b5132 1385 {
970ccc77
NC
1386 char buf[30];
1387 char *s;
1388
1389 s = buf + sizeof buf;
1390 *--s = '\0';
1391 while (val > 0)
1392 {
1393 *--s = (val % print_radix) + '0';
1394 val /= print_radix;
1395 }
1396 while ((buf + sizeof buf - 1) - s < 16)
1397 *--s = '0';
1398 printf ("%s", s);
252b5132 1399 }
252b5132 1400#endif
970ccc77
NC
1401 break;
1402
1403 default:
1404 fatal (_("Print width has not been initialized (%d)"), print_width);
1405 break;
1406 }
252b5132
RH
1407}
1408
1409/* Print a line of information about a symbol. */
1410
1411static void
2da42df6 1412print_symbol_info_bsd (struct extended_symbol_info *info, bfd *abfd)
252b5132 1413{
977f7911 1414 if (bfd_is_undefined_symclass (SYM_TYPE (info)))
252b5132 1415 {
970ccc77 1416 if (print_width == 64)
62a5a82d 1417 printf (" ");
21211521 1418 printf (" ");
252b5132
RH
1419 }
1420 else
977f7911 1421 {
06a30c77 1422 /* Normally we print the value of the symbol. If we are printing the
50c2245b 1423 size or sorting by size then we print its size, except for the
06a30c77
NC
1424 (weird) special case where both flags are defined, in which case we
1425 print both values. This conforms to documented behaviour. */
1426 if (sort_by_size && !print_size)
1427 print_value (abfd, SYM_SIZE (info));
1428 else
1429 print_value (abfd, SYM_VALUE (info));
977f7911 1430
72797995 1431 if (print_size && SYM_SIZE (info))
977f7911 1432 {
06a30c77 1433 printf (" ");
977f7911
NC
1434 print_value (abfd, SYM_SIZE (info));
1435 }
1436 }
1437
1438 printf (" %c", SYM_TYPE (info));
1439
1440 if (SYM_TYPE (info) == '-')
252b5132
RH
1441 {
1442 /* A stab. */
1443 printf (" ");
977f7911 1444 printf (other_format, SYM_STAB_OTHER (info));
252b5132 1445 printf (" ");
977f7911
NC
1446 printf (desc_format, SYM_STAB_DESC (info));
1447 printf (" %5s", SYM_STAB_NAME (info));
252b5132 1448 }
977f7911 1449 print_symname (" %s", SYM_NAME (info), abfd);
252b5132
RH
1450}
1451
1452static void
2da42df6 1453print_symbol_info_sysv (struct extended_symbol_info *info, bfd *abfd)
252b5132 1454{
977f7911
NC
1455 print_symname ("%-20s|", SYM_NAME (info), abfd);
1456
1457 if (bfd_is_undefined_symclass (SYM_TYPE (info)))
33f5f537 1458 {
970ccc77 1459 if (print_width == 32)
33f5f537
L
1460 printf (" ");
1461 else
1462 printf (" ");
1463 }
252b5132 1464 else
977f7911
NC
1465 print_value (abfd, SYM_VALUE (info));
1466
1467 printf ("| %c |", SYM_TYPE (info));
1468
1469 if (SYM_TYPE (info) == '-')
252b5132
RH
1470 {
1471 /* A stab. */
e3b83c8f
NC
1472 printf ("%18s| ", SYM_STAB_NAME (info)); /* (C) Type. */
1473 printf (desc_format, SYM_STAB_DESC (info)); /* Size. */
1474 printf ("| |"); /* Line, Section. */
252b5132
RH
1475 }
1476 else
9710509e 1477 {
977f7911 1478 /* Type, Size, Line, Section */
33f5f537
L
1479 if (info->elfinfo)
1480 printf ("%18s|",
1481 get_symbol_type (ELF_ST_TYPE (info->elfinfo->internal_elf_sym.st_info)));
1482 else
1483 printf (" |");
977f7911
NC
1484
1485 if (SYM_SIZE (info))
1486 print_value (abfd, SYM_SIZE (info));
1487 else
33f5f537 1488 {
970ccc77 1489 if (print_width == 32)
33f5f537
L
1490 printf (" ");
1491 else
1492 printf (" ");
1493 }
977f7911 1494
33f5f537
L
1495 if (info->elfinfo)
1496 printf("| |%s", info->elfinfo->symbol.section->name);
1497 else
1498 printf("| |");
977f7911 1499 }
252b5132
RH
1500}
1501
1502static void
2da42df6 1503print_symbol_info_posix (struct extended_symbol_info *info, bfd *abfd)
252b5132 1504{
977f7911
NC
1505 print_symname ("%s ", SYM_NAME (info), abfd);
1506 printf ("%c ", SYM_TYPE (info));
1507
1508 if (bfd_is_undefined_symclass (SYM_TYPE (info)))
252b5132
RH
1509 printf (" ");
1510 else
977f7911
NC
1511 {
1512 print_value (abfd, SYM_VALUE (info));
1513 printf (" ");
1514 if (SYM_SIZE (info))
1515 print_value (abfd, SYM_SIZE (info));
1516 }
252b5132
RH
1517}
1518\f
382c1116
NC
1519int
1520main (int argc, char **argv)
252b5132 1521{
382c1116
NC
1522 int c;
1523 int retval;
252b5132 1524
382c1116
NC
1525#if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
1526 setlocale (LC_MESSAGES, "");
1527#endif
1528#if defined (HAVE_SETLOCALE)
1529 setlocale (LC_CTYPE, "");
1530 setlocale (LC_COLLATE, "");
1531#endif
1532 bindtextdomain (PACKAGE, LOCALEDIR);
1533 textdomain (PACKAGE);
1534
1535 program_name = *argv;
1536 xmalloc_set_program_name (program_name);
fc579192
NC
1537#if BFD_SUPPORTS_PLUGINS
1538 bfd_plugin_set_program_name (program_name);
1539#endif
382c1116
NC
1540
1541 START_PROGRESS (program_name, 0);
1542
869b9d07
MM
1543 expandargv (&argc, &argv);
1544
382c1116
NC
1545 bfd_init ();
1546 set_default_bfd_target ();
1547
1548 while ((c = getopt_long (argc, argv, "aABCDef:gHhlnopPrSst:uvVvX:",
1549 long_options, (int *) 0)) != EOF)
252b5132 1550 {
382c1116 1551 switch (c)
252b5132 1552 {
382c1116
NC
1553 case 'a':
1554 print_debug_syms = 1;
1555 break;
1556 case 'A':
1557 case 'o':
1558 filename_per_symbol = 1;
1559 break;
1560 case 'B': /* For MIPS compatibility. */
1561 set_output_format ("bsd");
1562 break;
1563 case 'C':
1564 do_demangle = 1;
1565 if (optarg != NULL)
1566 {
1567 enum demangling_styles style;
1568
1569 style = cplus_demangle_name_to_style (optarg);
1570 if (style == unknown_demangling)
1571 fatal (_("unknown demangling style `%s'"),
1572 optarg);
1573
1574 cplus_demangle_set_style (style);
1575 }
1576 break;
1577 case 'D':
1578 dynamic = 1;
1579 break;
1580 case 'e':
1581 /* Ignored for HP/UX compatibility. */
1582 break;
1583 case 'f':
1584 set_output_format (optarg);
1585 break;
1586 case 'g':
1587 external_only = 1;
1588 break;
1589 case 'H':
1590 case 'h':
1591 usage (stdout, 0);
1592 case 'l':
1593 line_numbers = 1;
1594 break;
1595 case 'n':
1596 case 'v':
ddb1377c 1597 no_sort = 0;
382c1116 1598 sort_numerically = 1;
ddb1377c 1599 sort_by_size = 0;
382c1116
NC
1600 break;
1601 case 'p':
1602 no_sort = 1;
ddb1377c
AM
1603 sort_numerically = 0;
1604 sort_by_size = 0;
1605 break;
1606 case OPTION_SIZE_SORT:
1607 no_sort = 0;
1608 sort_numerically = 0;
1609 sort_by_size = 1;
382c1116
NC
1610 break;
1611 case 'P':
1612 set_output_format ("posix");
1613 break;
1614 case 'r':
1615 reverse_sort = 1;
1616 break;
1617 case 's':
1618 print_armap = 1;
1619 break;
1620 case 'S':
1621 print_size = 1;
1622 break;
1623 case 't':
1624 set_print_radix (optarg);
1625 break;
1626 case 'u':
1627 undefined_only = 1;
1628 break;
1629 case 'V':
1630 show_version = 1;
1631 break;
1632 case 'X':
1633 /* Ignored for (partial) AIX compatibility. On AIX, the
1634 argument has values 32, 64, or 32_64, and specifies that
1635 only 32-bit, only 64-bit, or both kinds of objects should
1636 be examined. The default is 32. So plain AIX nm on a
1637 library archive with both kinds of objects will ignore
1638 the 64-bit ones. For GNU nm, the default is and always
1639 has been -X 32_64, and other options are not supported. */
1640 if (strcmp (optarg, "32_64") != 0)
1641 fatal (_("Only -X 32_64 is supported"));
1642 break;
1643
1644 case OPTION_TARGET: /* --target */
1645 target = optarg;
1646 break;
1647
ce3c775b
NC
1648 case OPTION_PLUGIN: /* --plugin */
1649#if BFD_SUPPORTS_PLUGINS
a4b8af35 1650 plugin_target = "plugin";
ce3c775b
NC
1651 bfd_plugin_set_plugin (optarg);
1652#else
1653 fatal (_("sorry - this program has been built without plugin support\n"));
1654#endif
1655 break;
1656
382c1116
NC
1657 case 0: /* A long option that just sets a flag. */
1658 break;
1659
1660 default:
1661 usage (stderr, 1);
252b5132
RH
1662 }
1663 }
252b5132 1664
382c1116
NC
1665 if (show_version)
1666 print_version ("nm");
252b5132 1667
382c1116 1668 if (sort_by_size && undefined_only)
252b5132 1669 {
382c1116
NC
1670 non_fatal (_("Using the --size-sort and --undefined-only options together"));
1671 non_fatal (_("will produce no output, since undefined symbols have no size."));
1672 return 0;
252b5132 1673 }
382c1116
NC
1674
1675 /* OK, all options now parsed. If no filename specified, do a.out. */
1676 if (optind == argc)
1677 return !display_file ("a.out");
1678
1679 retval = 0;
1680
1681 if (argc - optind > 1)
1682 filename_per_file = 1;
1683
1684 /* We were given several filenames to do. */
1685 while (optind < argc)
252b5132 1686 {
382c1116
NC
1687 PROGRESS (1);
1688 if (!display_file (argv[optind++]))
1689 retval++;
1690 }
252b5132 1691
382c1116 1692 END_PROGRESS (program_name);
252b5132 1693
382c1116
NC
1694#ifdef HAVE_SBRK
1695 if (show_stats)
1696 {
1697 char *lim = (char *) sbrk (0);
1698
1699 non_fatal (_("data size %ld"), (long) (lim - (char *) &environ));
252b5132 1700 }
382c1116 1701#endif
252b5132 1702
382c1116
NC
1703 exit (retval);
1704 return retval;
252b5132 1705}
This page took 0.690921 seconds and 4 git commands to generate.