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