Propagate gdb_disassembly_flags to btrace_print_lines
[deliverable/binutils-gdb.git] / binutils / objdump.c
CommitLineData
252b5132 1/* objdump.c -- dump information about an object file.
219d1afa 2 Copyright (C) 1990-2018 Free Software Foundation, Inc.
252b5132 3
b5e2a4f3 4 This file is part of GNU Binutils.
252b5132 5
b5e2a4f3
NC
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
32866df7 8 the Free Software Foundation; either version 3, or (at your option)
b5e2a4f3 9 any later version.
252b5132 10
b5e2a4f3
NC
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
252b5132 15
b5e2a4f3
NC
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
32866df7
NC
18 Foundation, 51 Franklin Street - Fifth Floor, Boston,
19 MA 02110-1301, USA. */
20
252b5132 21
155e0d23
NC
22/* Objdump overview.
23
24 Objdump displays information about one or more object files, either on
25 their own, or inside libraries. It is commonly used as a disassembler,
26 but it can also display information about file headers, symbol tables,
27 relocations, debugging directives and more.
28
29 The flow of execution is as follows:
3aade688 30
155e0d23
NC
31 1. Command line arguments are checked for control switches and the
32 information to be displayed is selected.
3aade688 33
155e0d23
NC
34 2. Any remaining arguments are assumed to be object files, and they are
35 processed in order by display_bfd(). If the file is an archive each
36 of its elements is processed in turn.
3aade688 37
50c2245b 38 3. The file's target architecture and binary file format are determined
155e0d23
NC
39 by bfd_check_format(). If they are recognised, then dump_bfd() is
40 called.
41
50c2245b
KH
42 4. dump_bfd() in turn calls separate functions to display the requested
43 item(s) of information(s). For example disassemble_data() is called if
aaad4cf3 44 a disassembly has been requested.
155e0d23
NC
45
46 When disassembling the code loops through blocks of instructions bounded
50c2245b 47 by symbols, calling disassemble_bytes() on each block. The actual
155e0d23
NC
48 disassembling is done by the libopcodes library, via a function pointer
49 supplied by the disassembler() function. */
50
3db64b00 51#include "sysdep.h"
252b5132 52#include "bfd.h"
2dc4cec1 53#include "elf-bfd.h"
f4943d82 54#include "coff-bfd.h"
252b5132
RH
55#include "progress.h"
56#include "bucomm.h"
3284fe0c 57#include "elfcomm.h"
365544c3 58#include "dwarf.h"
d7a283d4 59#include "getopt.h"
3882b010 60#include "safe-ctype.h"
252b5132
RH
61#include "dis-asm.h"
62#include "libiberty.h"
63#include "demangle.h"
0dafdf3f 64#include "filenames.h"
252b5132
RH
65#include "debug.h"
66#include "budbg.h"
6abcee90 67#include "objdump.h"
252b5132 68
e8f5eee4
NC
69#ifdef HAVE_MMAP
70#include <sys/mman.h>
71#endif
72
252b5132
RH
73/* Internal headers for the ELF .stab-dump code - sorry. */
74#define BYTES_IN_WORD 32
75#include "aout/aout64.h"
76
75cd796a
ILT
77/* Exit status. */
78static int exit_status = 0;
79
98a91d6a 80static char *default_target = NULL; /* Default at runtime. */
252b5132 81
3b9ad1cc
AM
82/* The following variables are set based on arguments passed on the
83 command line. */
98a91d6a 84static int show_version = 0; /* Show the version number. */
252b5132
RH
85static int dump_section_contents; /* -s */
86static int dump_section_headers; /* -h */
b34976b6 87static bfd_boolean dump_file_header; /* -f */
252b5132
RH
88static int dump_symtab; /* -t */
89static int dump_dynamic_symtab; /* -T */
90static int dump_reloc_info; /* -r */
91static int dump_dynamic_reloc_info; /* -R */
92static int dump_ar_hdrs; /* -a */
93static int dump_private_headers; /* -p */
6abcee90 94static char *dump_private_options; /* -P */
252b5132
RH
95static int prefix_addresses; /* --prefix-addresses */
96static int with_line_numbers; /* -l */
b34976b6 97static bfd_boolean with_source_code; /* -S */
252b5132 98static int show_raw_insn; /* --show-raw-insn */
365544c3 99static int dump_dwarf_section_info; /* --dwarf */
252b5132
RH
100static int dump_stab_section_info; /* --stabs */
101static int do_demangle; /* -C, --demangle */
b34976b6
AM
102static bfd_boolean disassemble; /* -d */
103static bfd_boolean disassemble_all; /* -D */
252b5132 104static int disassemble_zeroes; /* --disassemble-zeroes */
b34976b6 105static bfd_boolean formats_info; /* -i */
252b5132 106static int wide_output; /* -w */
3dcb3fcb 107static int insn_width; /* --insn-width */
252b5132
RH
108static bfd_vma start_address = (bfd_vma) -1; /* --start-address */
109static bfd_vma stop_address = (bfd_vma) -1; /* --stop-address */
110static int dump_debugging; /* --debugging */
51cdc6e0 111static int dump_debugging_tags; /* --debugging-tags */
fd2f0033 112static int suppress_bfd_header;
3c9458e9 113static int dump_special_syms = 0; /* --special-syms */
252b5132 114static bfd_vma adjust_section_vma = 0; /* --adjust-vma */
f1563258 115static int file_start_context = 0; /* --file-start-context */
98ec6e72 116static bfd_boolean display_file_offsets;/* -F */
0dafdf3f
L
117static const char *prefix; /* --prefix */
118static int prefix_strip; /* --prefix-strip */
119static size_t prefix_length;
4a14e306 120static bfd_boolean unwind_inlines; /* --inlines. */
252b5132 121
70ecb384
NC
122/* A structure to record the sections mentioned in -j switches. */
123struct only
124{
125 const char * name; /* The name of the section. */
126 bfd_boolean seen; /* A flag to indicate that the section has been found in one or more input files. */
127 struct only * next; /* Pointer to the next structure in the list. */
128};
129/* Pointer to an array of 'only' structures.
130 This pointer is NULL if the -j switch has not been used. */
131static struct only * only_list = NULL;
155e0d23 132
43ac9881
AM
133/* Variables for handling include file path table. */
134static const char **include_paths;
135static int include_path_count;
136
3b9ad1cc
AM
137/* Extra info to pass to the section disassembler and address printing
138 function. */
026df7c5
NC
139struct objdump_disasm_info
140{
155e0d23
NC
141 bfd * abfd;
142 asection * sec;
143 bfd_boolean require_sec;
144 arelent ** dynrelbuf;
145 long dynrelcount;
146 disassembler_ftype disassemble_fn;
ce04548a 147 arelent * reloc;
252b5132
RH
148};
149
150/* Architecture to disassemble for, or default if NULL. */
d3ba0551 151static char *machine = NULL;
252b5132 152
dd92f639 153/* Target specific options to the disassembler. */
d3ba0551 154static char *disassembler_options = NULL;
dd92f639 155
252b5132
RH
156/* Endianness to disassemble for, or default if BFD_ENDIAN_UNKNOWN. */
157static enum bfd_endian endian = BFD_ENDIAN_UNKNOWN;
158
159/* The symbol table. */
160static asymbol **syms;
161
162/* Number of symbols in `syms'. */
163static long symcount = 0;
164
165/* The sorted symbol table. */
166static asymbol **sorted_syms;
167
168/* Number of symbols in `sorted_syms'. */
169static long sorted_symcount = 0;
170
171/* The dynamic symbol table. */
172static asymbol **dynsyms;
173
4c45e5c9
JJ
174/* The synthetic symbol table. */
175static asymbol *synthsyms;
176static long synthcount = 0;
177
252b5132
RH
178/* Number of symbols in `dynsyms'. */
179static long dynsymcount = 0;
180
98a91d6a
NC
181static bfd_byte *stabs;
182static bfd_size_type stab_size;
183
bae7501e 184static bfd_byte *strtab;
98a91d6a 185static bfd_size_type stabstr_size;
41e92641
NC
186
187static bfd_boolean is_relocatable = FALSE;
6abcee90
TG
188
189/* Handlers for -P/--private. */
190static const struct objdump_private_desc * const objdump_private_vectors[] =
191 {
192 OBJDUMP_PRIVATE_VECTORS
193 NULL
194 };
252b5132 195\f
aebcf7b7 196static void usage (FILE *, int) ATTRIBUTE_NORETURN;
252b5132 197static void
46dca2e0 198usage (FILE *stream, int status)
252b5132 199{
8b53311e
NC
200 fprintf (stream, _("Usage: %s <option(s)> <file(s)>\n"), program_name);
201 fprintf (stream, _(" Display information from object <file(s)>.\n"));
202 fprintf (stream, _(" At least one of the following switches must be given:\n"));
252b5132 203 fprintf (stream, _("\
86d65c94
MK
204 -a, --archive-headers Display archive header information\n\
205 -f, --file-headers Display the contents of the overall file header\n\
206 -p, --private-headers Display object format specific file header contents\n\
6abcee90 207 -P, --private=OPT,OPT... Display object format specific contents\n\
86d65c94
MK
208 -h, --[section-]headers Display the contents of the section headers\n\
209 -x, --all-headers Display the contents of all headers\n\
210 -d, --disassemble Display assembler contents of executable sections\n\
211 -D, --disassemble-all Display assembler contents of all sections\n\
212 -S, --source Intermix source code with disassembly\n\
213 -s, --full-contents Display the full contents of all sections requested\n\
214 -g, --debugging Display debug information in object file\n\
51cdc6e0 215 -e, --debugging-tags Display debug information using ctags style\n\
86d65c94 216 -G, --stabs Display (in raw form) any STABS info in the file\n\
dda8d76d 217 -W[lLiaprmfFsoRtUuTgAckK] or\n\
1ed06042 218 --dwarf[=rawline,=decodedline,=info,=abbrev,=pubnames,=aranges,=macro,=frames,\n\
6f875884 219 =frames-interp,=str,=loc,=Ranges,=pubtypes,\n\
657d0d47 220 =gdb_index,=trace_info,=trace_abbrev,=trace_aranges,\n\
dda8d76d 221 =addr,=cu_index,=links,=follow-links]\n\
4cb93e3b 222 Display DWARF info in the file\n\
86d65c94
MK
223 -t, --syms Display the contents of the symbol table(s)\n\
224 -T, --dynamic-syms Display the contents of the dynamic symbol table\n\
225 -r, --reloc Display the relocation entries in the file\n\
226 -R, --dynamic-reloc Display the dynamic relocation entries in the file\n\
07012eee 227 @<file> Read options from <file>\n\
8b53311e 228 -v, --version Display this program's version number\n\
86d65c94
MK
229 -i, --info List object formats and architectures supported\n\
230 -H, --help Display this information\n\
1dada9c5
NC
231"));
232 if (status != 2)
233 {
6abcee90
TG
234 const struct objdump_private_desc * const *desc;
235
1dada9c5
NC
236 fprintf (stream, _("\n The following switches are optional:\n"));
237 fprintf (stream, _("\
86d65c94
MK
238 -b, --target=BFDNAME Specify the target object format as BFDNAME\n\
239 -m, --architecture=MACHINE Specify the target architecture as MACHINE\n\
240 -j, --section=NAME Only display information for section NAME\n\
241 -M, --disassembler-options=OPT Pass text OPT on to the disassembler\n\
1dada9c5
NC
242 -EB --endian=big Assume big endian format when disassembling\n\
243 -EL --endian=little Assume little endian format when disassembling\n\
f1563258 244 --file-start-context Include context from start of file (with -S)\n\
43ac9881 245 -I, --include=DIR Add DIR to search list for source files\n\
86d65c94 246 -l, --line-numbers Include line numbers and filenames in output\n\
98ec6e72 247 -F, --file-offsets Include file offsets when displaying information\n\
28c309a2 248 -C, --demangle[=STYLE] Decode mangled/processed symbol names\n\
f0c8c24a
NC
249 The STYLE, if specified, can be `auto', `gnu',\n\
250 `lucid', `arm', `hp', `edg', `gnu-v3', `java'\n\
251 or `gnat'\n\
86d65c94
MK
252 -w, --wide Format output for more than 80 columns\n\
253 -z, --disassemble-zeroes Do not skip blocks of zeroes when disassembling\n\
f0c8c24a
NC
254 --start-address=ADDR Only process data whose address is >= ADDR\n\
255 --stop-address=ADDR Only process data whose address is <= ADDR\n\
1dada9c5
NC
256 --prefix-addresses Print complete address alongside disassembly\n\
257 --[no-]show-raw-insn Display hex alongside symbolic disassembly\n\
505f1412 258 --insn-width=WIDTH Display WIDTH bytes on a single line for -d\n\
86d65c94 259 --adjust-vma=OFFSET Add OFFSET to all displayed section addresses\n\
3c9458e9 260 --special-syms Include special symbols in symbol dumps\n\
4a14e306 261 --inlines Print all inlines for source line (with -l)\n\
0dafdf3f 262 --prefix=PREFIX Add PREFIX to absolute paths for -S\n\
fd2f0033
TT
263 --prefix-strip=LEVEL Strip initial directory names for -S\n"));
264 fprintf (stream, _("\
265 --dwarf-depth=N Do not display DIEs at depth N or greater\n\
266 --dwarf-start=N Display DIEs starting with N, at the same depth\n\
4723351a
CC
267 or deeper\n\
268 --dwarf-check Make additional dwarf internal consistency checks.\
269 \n\n"));
1dada9c5 270 list_supported_targets (program_name, stream);
2f83960e 271 list_supported_architectures (program_name, stream);
86d65c94 272
94470b23 273 disassembler_usage (stream);
6abcee90
TG
274
275 if (objdump_private_vectors[0] != NULL)
276 {
277 fprintf (stream,
278 _("\nOptions supported for -P/--private switch:\n"));
279 for (desc = objdump_private_vectors; *desc != NULL; desc++)
280 (*desc)->help (stream);
281 }
1dada9c5 282 }
92f01d61 283 if (REPORT_BUGS_TO[0] && status == 0)
86d65c94 284 fprintf (stream, _("Report bugs to %s.\n"), REPORT_BUGS_TO);
252b5132
RH
285 exit (status);
286}
287
288/* 150 isn't special; it's just an arbitrary non-ASCII char value. */
46dca2e0
NC
289enum option_values
290 {
291 OPTION_ENDIAN=150,
292 OPTION_START_ADDRESS,
293 OPTION_STOP_ADDRESS,
4cb93e3b 294 OPTION_DWARF,
0dafdf3f
L
295 OPTION_PREFIX,
296 OPTION_PREFIX_STRIP,
3dcb3fcb 297 OPTION_INSN_WIDTH,
fd2f0033
TT
298 OPTION_ADJUST_VMA,
299 OPTION_DWARF_DEPTH,
4723351a 300 OPTION_DWARF_CHECK,
4a14e306
AK
301 OPTION_DWARF_START,
302 OPTION_INLINES
46dca2e0 303 };
252b5132
RH
304
305static struct option long_options[]=
306{
307 {"adjust-vma", required_argument, NULL, OPTION_ADJUST_VMA},
308 {"all-headers", no_argument, NULL, 'x'},
309 {"private-headers", no_argument, NULL, 'p'},
6abcee90 310 {"private", required_argument, NULL, 'P'},
252b5132
RH
311 {"architecture", required_argument, NULL, 'm'},
312 {"archive-headers", no_argument, NULL, 'a'},
1dada9c5 313 {"debugging", no_argument, NULL, 'g'},
51cdc6e0 314 {"debugging-tags", no_argument, NULL, 'e'},
28c309a2 315 {"demangle", optional_argument, NULL, 'C'},
252b5132
RH
316 {"disassemble", no_argument, NULL, 'd'},
317 {"disassemble-all", no_argument, NULL, 'D'},
dd92f639 318 {"disassembler-options", required_argument, NULL, 'M'},
1dada9c5 319 {"disassemble-zeroes", no_argument, NULL, 'z'},
252b5132
RH
320 {"dynamic-reloc", no_argument, NULL, 'R'},
321 {"dynamic-syms", no_argument, NULL, 'T'},
322 {"endian", required_argument, NULL, OPTION_ENDIAN},
323 {"file-headers", no_argument, NULL, 'f'},
98ec6e72 324 {"file-offsets", no_argument, NULL, 'F'},
f1563258 325 {"file-start-context", no_argument, &file_start_context, 1},
252b5132
RH
326 {"full-contents", no_argument, NULL, 's'},
327 {"headers", no_argument, NULL, 'h'},
328 {"help", no_argument, NULL, 'H'},
329 {"info", no_argument, NULL, 'i'},
330 {"line-numbers", no_argument, NULL, 'l'},
331 {"no-show-raw-insn", no_argument, &show_raw_insn, -1},
332 {"prefix-addresses", no_argument, &prefix_addresses, 1},
333 {"reloc", no_argument, NULL, 'r'},
334 {"section", required_argument, NULL, 'j'},
335 {"section-headers", no_argument, NULL, 'h'},
336 {"show-raw-insn", no_argument, &show_raw_insn, 1},
337 {"source", no_argument, NULL, 'S'},
3c9458e9 338 {"special-syms", no_argument, &dump_special_syms, 1},
43ac9881 339 {"include", required_argument, NULL, 'I'},
4cb93e3b 340 {"dwarf", optional_argument, NULL, OPTION_DWARF},
1dada9c5 341 {"stabs", no_argument, NULL, 'G'},
252b5132
RH
342 {"start-address", required_argument, NULL, OPTION_START_ADDRESS},
343 {"stop-address", required_argument, NULL, OPTION_STOP_ADDRESS},
344 {"syms", no_argument, NULL, 't'},
345 {"target", required_argument, NULL, 'b'},
1dada9c5
NC
346 {"version", no_argument, NULL, 'V'},
347 {"wide", no_argument, NULL, 'w'},
0dafdf3f
L
348 {"prefix", required_argument, NULL, OPTION_PREFIX},
349 {"prefix-strip", required_argument, NULL, OPTION_PREFIX_STRIP},
3dcb3fcb 350 {"insn-width", required_argument, NULL, OPTION_INSN_WIDTH},
dda8d76d
NC
351 {"dwarf-depth", required_argument, 0, OPTION_DWARF_DEPTH},
352 {"dwarf-start", required_argument, 0, OPTION_DWARF_START},
353 {"dwarf-check", no_argument, 0, OPTION_DWARF_CHECK},
354 {"inlines", no_argument, 0, OPTION_INLINES},
252b5132
RH
355 {0, no_argument, 0, 0}
356};
357\f
358static void
46dca2e0 359nonfatal (const char *msg)
75cd796a
ILT
360{
361 bfd_nonfatal (msg);
362 exit_status = 1;
363}
364\f
d2fcac5c
NC
365/* Returns TRUE if the specified section should be dumped. */
366
367static bfd_boolean
368process_section_p (asection * section)
369{
70ecb384 370 struct only * only;
d2fcac5c 371
70ecb384 372 if (only_list == NULL)
d2fcac5c
NC
373 return TRUE;
374
70ecb384
NC
375 for (only = only_list; only; only = only->next)
376 if (strcmp (only->name, section->name) == 0)
377 {
378 only->seen = TRUE;
379 return TRUE;
380 }
d2fcac5c
NC
381
382 return FALSE;
383}
70ecb384
NC
384
385/* Add an entry to the 'only' list. */
386
387static void
388add_only (char * name)
389{
390 struct only * only;
391
392 /* First check to make sure that we do not
393 already have an entry for this name. */
394 for (only = only_list; only; only = only->next)
395 if (strcmp (only->name, name) == 0)
396 return;
397
398 only = xmalloc (sizeof * only);
399 only->name = name;
400 only->seen = FALSE;
401 only->next = only_list;
402 only_list = only;
403}
404
405/* Release the memory used by the 'only' list.
406 PR 11225: Issue a warning message for unseen sections.
407 Only do this if none of the sections were seen. This is mainly to support
408 tools like the GAS testsuite where an object file is dumped with a list of
409 generic section names known to be present in a range of different file
410 formats. */
411
412static void
413free_only_list (void)
414{
415 bfd_boolean at_least_one_seen = FALSE;
416 struct only * only;
417 struct only * next;
418
419 if (only_list == NULL)
420 return;
421
422 for (only = only_list; only; only = only->next)
423 if (only->seen)
424 {
425 at_least_one_seen = TRUE;
426 break;
427 }
428
429 for (only = only_list; only; only = next)
430 {
431 if (! at_least_one_seen)
432 {
a8c62f1c
AM
433 non_fatal (_("section '%s' mentioned in a -j option, "
434 "but not found in any input file"),
70ecb384
NC
435 only->name);
436 exit_status = 1;
437 }
438 next = only->next;
439 free (only);
440 }
441}
442
d2fcac5c 443\f
75cd796a 444static void
1737c640 445dump_section_header (bfd *abfd, asection *section, void *data)
252b5132
RH
446{
447 char *comma = "";
f6af82bd 448 unsigned int opb = bfd_octets_per_byte (abfd);
1737c640 449 int longest_section_name = *((int *) data);
252b5132 450
3bee8bcd
L
451 /* Ignore linker created section. See elfNN_ia64_object_p in
452 bfd/elfxx-ia64.c. */
453 if (section->flags & SEC_LINKER_CREATED)
454 return;
455
d2fcac5c
NC
456 /* PR 10413: Skip sections that we are ignoring. */
457 if (! process_section_p (section))
458 return;
459
1737c640 460 printf ("%3d %-*s %08lx ", section->index, longest_section_name,
252b5132 461 bfd_get_section_name (abfd, section),
940b2b78 462 (unsigned long) bfd_section_size (abfd, section) / opb);
d8180c76 463 bfd_printf_vma (abfd, bfd_get_section_vma (abfd, section));
252b5132 464 printf (" ");
d8180c76 465 bfd_printf_vma (abfd, section->lma);
e59b4dfb 466 printf (" %08lx 2**%u", (unsigned long) section->filepos,
252b5132
RH
467 bfd_get_section_alignment (abfd, section));
468 if (! wide_output)
469 printf ("\n ");
470 printf (" ");
471
472#define PF(x, y) \
473 if (section->flags & x) { printf ("%s%s", comma, y); comma = ", "; }
474
475 PF (SEC_HAS_CONTENTS, "CONTENTS");
476 PF (SEC_ALLOC, "ALLOC");
477 PF (SEC_CONSTRUCTOR, "CONSTRUCTOR");
252b5132
RH
478 PF (SEC_LOAD, "LOAD");
479 PF (SEC_RELOC, "RELOC");
252b5132
RH
480 PF (SEC_READONLY, "READONLY");
481 PF (SEC_CODE, "CODE");
482 PF (SEC_DATA, "DATA");
483 PF (SEC_ROM, "ROM");
484 PF (SEC_DEBUGGING, "DEBUGGING");
485 PF (SEC_NEVER_LOAD, "NEVER_LOAD");
486 PF (SEC_EXCLUDE, "EXCLUDE");
487 PF (SEC_SORT_ENTRIES, "SORT_ENTRIES");
ebe372c1
L
488 if (bfd_get_arch (abfd) == bfd_arch_tic54x)
489 {
490 PF (SEC_TIC54X_BLOCK, "BLOCK");
491 PF (SEC_TIC54X_CLINK, "CLINK");
492 }
24c411ed 493 PF (SEC_SMALL_DATA, "SMALL_DATA");
ebe372c1 494 if (bfd_get_flavour (abfd) == bfd_target_coff_flavour)
91f68a68
MG
495 {
496 PF (SEC_COFF_SHARED, "SHARED");
497 PF (SEC_COFF_NOREAD, "NOREAD");
498 }
499 else if (bfd_get_flavour (abfd) == bfd_target_elf_flavour)
f0728ee3 500 PF (SEC_ELF_PURECODE, "PURECODE");
13ae64f3 501 PF (SEC_THREAD_LOCAL, "THREAD_LOCAL");
64c1196b 502 PF (SEC_GROUP, "GROUP");
91f68a68
MG
503 if (bfd_get_arch (abfd) == bfd_arch_mep)
504 {
505 PF (SEC_MEP_VLIW, "VLIW");
506 }
252b5132
RH
507
508 if ((section->flags & SEC_LINK_ONCE) != 0)
509 {
510 const char *ls;
082b7297 511 struct coff_comdat_info *comdat;
252b5132
RH
512
513 switch (section->flags & SEC_LINK_DUPLICATES)
514 {
515 default:
516 abort ();
517 case SEC_LINK_DUPLICATES_DISCARD:
518 ls = "LINK_ONCE_DISCARD";
519 break;
520 case SEC_LINK_DUPLICATES_ONE_ONLY:
521 ls = "LINK_ONCE_ONE_ONLY";
522 break;
523 case SEC_LINK_DUPLICATES_SAME_SIZE:
524 ls = "LINK_ONCE_SAME_SIZE";
525 break;
526 case SEC_LINK_DUPLICATES_SAME_CONTENTS:
527 ls = "LINK_ONCE_SAME_CONTENTS";
528 break;
529 }
530 printf ("%s%s", comma, ls);
deecf979 531
082b7297
L
532 comdat = bfd_coff_get_comdat_section (abfd, section);
533 if (comdat != NULL)
534 printf (" (COMDAT %s %ld)", comdat->name, comdat->symbol);
deecf979 535
252b5132
RH
536 comma = ", ";
537 }
538
539 printf ("\n");
540#undef PF
541}
542
1737c640
AB
543/* Called on each SECTION in ABFD, update the int variable pointed to by
544 DATA which contains the string length of the longest section name. */
545
546static void
547find_longest_section_name (bfd *abfd, asection *section, void *data)
548{
549 int *longest_so_far = (int *) data;
550 const char *name;
551 int len;
552
553 /* Ignore linker created section. */
554 if (section->flags & SEC_LINKER_CREATED)
555 return;
556
557 /* Skip sections that we are ignoring. */
558 if (! process_section_p (section))
559 return;
560
561 name = bfd_get_section_name (abfd, section);
562 len = (int) strlen (name);
563 if (len > *longest_so_far)
564 *longest_so_far = len;
565}
566
252b5132 567static void
46dca2e0 568dump_headers (bfd *abfd)
252b5132 569{
1737c640
AB
570 /* The default width of 13 is just an arbitrary choice. */
571 int max_section_name_length = 13;
572 int bfd_vma_width;
8bea4d5c 573
252b5132 574#ifndef BFD64
1737c640 575 bfd_vma_width = 10;
252b5132 576#else
21611032
TS
577 /* With BFD64, non-ELF returns -1 and wants always 64 bit addresses. */
578 if (bfd_get_arch_size (abfd) == 32)
1737c640 579 bfd_vma_width = 10;
21611032 580 else
1737c640 581 bfd_vma_width = 18;
252b5132 582#endif
8bea4d5c 583
1737c640
AB
584 printf (_("Sections:\n"));
585
586 if (wide_output)
587 bfd_map_over_sections (abfd, find_longest_section_name,
588 &max_section_name_length);
589
590 printf (_("Idx %-*s Size %-*s%-*sFile off Algn"),
591 max_section_name_length, "Name",
592 bfd_vma_width, "VMA",
593 bfd_vma_width, "LMA");
594
8bea4d5c
ILT
595 if (wide_output)
596 printf (_(" Flags"));
597 printf ("\n");
598
1737c640
AB
599 bfd_map_over_sections (abfd, dump_section_header,
600 &max_section_name_length);
252b5132
RH
601}
602\f
603static asymbol **
46dca2e0 604slurp_symtab (bfd *abfd)
252b5132 605{
d3ba0551 606 asymbol **sy = NULL;
252b5132
RH
607 long storage;
608
609 if (!(bfd_get_file_flags (abfd) & HAS_SYMS))
610 {
252b5132
RH
611 symcount = 0;
612 return NULL;
613 }
614
615 storage = bfd_get_symtab_upper_bound (abfd);
616 if (storage < 0)
5a3f568b
NC
617 {
618 non_fatal (_("failed to read symbol table from: %s"), bfd_get_filename (abfd));
619 bfd_fatal (_("error message was"));
620 }
252b5132 621 if (storage)
3f5e193b 622 sy = (asymbol **) xmalloc (storage);
28b18af1 623
252b5132
RH
624 symcount = bfd_canonicalize_symtab (abfd, sy);
625 if (symcount < 0)
626 bfd_fatal (bfd_get_filename (abfd));
252b5132
RH
627 return sy;
628}
629
630/* Read in the dynamic symbols. */
631
632static asymbol **
46dca2e0 633slurp_dynamic_symtab (bfd *abfd)
252b5132 634{
d3ba0551 635 asymbol **sy = NULL;
252b5132
RH
636 long storage;
637
638 storage = bfd_get_dynamic_symtab_upper_bound (abfd);
639 if (storage < 0)
640 {
641 if (!(bfd_get_file_flags (abfd) & DYNAMIC))
642 {
37cc8ec1 643 non_fatal (_("%s: not a dynamic object"), bfd_get_filename (abfd));
a8c62f1c 644 exit_status = 1;
252b5132
RH
645 dynsymcount = 0;
646 return NULL;
647 }
648
649 bfd_fatal (bfd_get_filename (abfd));
650 }
252b5132 651 if (storage)
3f5e193b 652 sy = (asymbol **) xmalloc (storage);
28b18af1 653
252b5132
RH
654 dynsymcount = bfd_canonicalize_dynamic_symtab (abfd, sy);
655 if (dynsymcount < 0)
656 bfd_fatal (bfd_get_filename (abfd));
252b5132
RH
657 return sy;
658}
659
a24bb4f0
NC
660/* Some symbol names are significant and should be kept in the
661 table of sorted symbol names, even if they are marked as
662 debugging/section symbols. */
663
664static bfd_boolean
665is_significant_symbol_name (const char * name)
666{
667 return strcmp (name, ".plt") == 0
668 || strcmp (name, ".got") == 0
669 || strcmp (name, ".plt.got") == 0;
670}
671
252b5132
RH
672/* Filter out (in place) symbols that are useless for disassembly.
673 COUNT is the number of elements in SYMBOLS.
0af11b59 674 Return the number of useful symbols. */
252b5132
RH
675
676static long
46dca2e0 677remove_useless_symbols (asymbol **symbols, long count)
252b5132 678{
46dca2e0 679 asymbol **in_ptr = symbols, **out_ptr = symbols;
252b5132
RH
680
681 while (--count >= 0)
682 {
683 asymbol *sym = *in_ptr++;
684
685 if (sym->name == NULL || sym->name[0] == '\0')
686 continue;
a24bb4f0
NC
687 if ((sym->flags & (BSF_DEBUGGING | BSF_SECTION_SYM))
688 && ! is_significant_symbol_name (sym->name))
252b5132
RH
689 continue;
690 if (bfd_is_und_section (sym->section)
691 || bfd_is_com_section (sym->section))
692 continue;
693
694 *out_ptr++ = sym;
695 }
696 return out_ptr - symbols;
697}
698
699/* Sort symbols into value order. */
700
0af11b59 701static int
46dca2e0 702compare_symbols (const void *ap, const void *bp)
252b5132 703{
46dca2e0
NC
704 const asymbol *a = * (const asymbol **) ap;
705 const asymbol *b = * (const asymbol **) bp;
706 const char *an;
707 const char *bn;
708 size_t anl;
709 size_t bnl;
710 bfd_boolean af;
711 bfd_boolean bf;
712 flagword aflags;
713 flagword bflags;
252b5132
RH
714
715 if (bfd_asymbol_value (a) > bfd_asymbol_value (b))
716 return 1;
717 else if (bfd_asymbol_value (a) < bfd_asymbol_value (b))
718 return -1;
719
720 if (a->section > b->section)
721 return 1;
722 else if (a->section < b->section)
723 return -1;
724
725 an = bfd_asymbol_name (a);
726 bn = bfd_asymbol_name (b);
727 anl = strlen (an);
728 bnl = strlen (bn);
729
730 /* The symbols gnu_compiled and gcc2_compiled convey no real
731 information, so put them after other symbols with the same value. */
252b5132
RH
732 af = (strstr (an, "gnu_compiled") != NULL
733 || strstr (an, "gcc2_compiled") != NULL);
734 bf = (strstr (bn, "gnu_compiled") != NULL
735 || strstr (bn, "gcc2_compiled") != NULL);
736
737 if (af && ! bf)
738 return 1;
739 if (! af && bf)
740 return -1;
741
742 /* We use a heuristic for the file name, to try to sort it after
743 more useful symbols. It may not work on non Unix systems, but it
744 doesn't really matter; the only difference is precisely which
745 symbol names get printed. */
746
747#define file_symbol(s, sn, snl) \
748 (((s)->flags & BSF_FILE) != 0 \
749 || ((sn)[(snl) - 2] == '.' \
750 && ((sn)[(snl) - 1] == 'o' \
751 || (sn)[(snl) - 1] == 'a')))
752
753 af = file_symbol (a, an, anl);
754 bf = file_symbol (b, bn, bnl);
755
756 if (af && ! bf)
757 return 1;
758 if (! af && bf)
759 return -1;
760
761 /* Try to sort global symbols before local symbols before function
762 symbols before debugging symbols. */
763
764 aflags = a->flags;
765 bflags = b->flags;
766
767 if ((aflags & BSF_DEBUGGING) != (bflags & BSF_DEBUGGING))
768 {
769 if ((aflags & BSF_DEBUGGING) != 0)
770 return 1;
771 else
772 return -1;
773 }
774 if ((aflags & BSF_FUNCTION) != (bflags & BSF_FUNCTION))
775 {
776 if ((aflags & BSF_FUNCTION) != 0)
777 return -1;
778 else
779 return 1;
780 }
781 if ((aflags & BSF_LOCAL) != (bflags & BSF_LOCAL))
782 {
783 if ((aflags & BSF_LOCAL) != 0)
784 return 1;
785 else
786 return -1;
787 }
788 if ((aflags & BSF_GLOBAL) != (bflags & BSF_GLOBAL))
789 {
790 if ((aflags & BSF_GLOBAL) != 0)
791 return -1;
792 else
793 return 1;
794 }
795
32a0481f
AM
796 if (bfd_get_flavour (bfd_asymbol_bfd (a)) == bfd_target_elf_flavour
797 && bfd_get_flavour (bfd_asymbol_bfd (b)) == bfd_target_elf_flavour)
798 {
799 bfd_vma asz, bsz;
800
801 asz = 0;
160b1a61 802 if ((a->flags & (BSF_SECTION_SYM | BSF_SYNTHETIC)) == 0)
32a0481f
AM
803 asz = ((elf_symbol_type *) a)->internal_elf_sym.st_size;
804 bsz = 0;
160b1a61 805 if ((b->flags & (BSF_SECTION_SYM | BSF_SYNTHETIC)) == 0)
32a0481f
AM
806 bsz = ((elf_symbol_type *) b)->internal_elf_sym.st_size;
807 if (asz != bsz)
808 return asz > bsz ? -1 : 1;
809 }
810
252b5132
RH
811 /* Symbols that start with '.' might be section names, so sort them
812 after symbols that don't start with '.'. */
813 if (an[0] == '.' && bn[0] != '.')
814 return 1;
815 if (an[0] != '.' && bn[0] == '.')
816 return -1;
817
818 /* Finally, if we can't distinguish them in any other way, try to
819 get consistent results by sorting the symbols by name. */
820 return strcmp (an, bn);
821}
822
823/* Sort relocs into address order. */
824
825static int
46dca2e0 826compare_relocs (const void *ap, const void *bp)
252b5132 827{
46dca2e0
NC
828 const arelent *a = * (const arelent **) ap;
829 const arelent *b = * (const arelent **) bp;
252b5132
RH
830
831 if (a->address > b->address)
832 return 1;
833 else if (a->address < b->address)
834 return -1;
835
836 /* So that associated relocations tied to the same address show up
837 in the correct order, we don't do any further sorting. */
838 if (a > b)
839 return 1;
840 else if (a < b)
841 return -1;
842 else
843 return 0;
844}
845
155e0d23
NC
846/* Print an address (VMA) to the output stream in INFO.
847 If SKIP_ZEROES is TRUE, omit leading zeroes. */
252b5132
RH
848
849static void
91d6fa6a 850objdump_print_value (bfd_vma vma, struct disassemble_info *inf,
46dca2e0 851 bfd_boolean skip_zeroes)
252b5132
RH
852{
853 char buf[30];
854 char *p;
3b9ad1cc 855 struct objdump_disasm_info *aux;
252b5132 856
91d6fa6a 857 aux = (struct objdump_disasm_info *) inf->application_data;
d8180c76 858 bfd_sprintf_vma (aux->abfd, buf, vma);
252b5132
RH
859 if (! skip_zeroes)
860 p = buf;
861 else
862 {
863 for (p = buf; *p == '0'; ++p)
864 ;
865 if (*p == '\0')
866 --p;
867 }
91d6fa6a 868 (*inf->fprintf_func) (inf->stream, "%s", p);
252b5132
RH
869}
870
871/* Print the name of a symbol. */
872
873static void
91d6fa6a 874objdump_print_symname (bfd *abfd, struct disassemble_info *inf,
46dca2e0 875 asymbol *sym)
252b5132
RH
876{
877 char *alloc;
bb4d2ac2
L
878 const char *name, *version_string = NULL;
879 bfd_boolean hidden = FALSE;
252b5132
RH
880
881 alloc = NULL;
882 name = bfd_asymbol_name (sym);
a6637ec0 883 if (do_demangle && name[0] != '\0')
252b5132
RH
884 {
885 /* Demangle the name. */
ed180cc5
AM
886 alloc = bfd_demangle (abfd, name, DMGL_ANSI | DMGL_PARAMS);
887 if (alloc != NULL)
888 name = alloc;
252b5132
RH
889 }
890
160b1a61 891 if ((sym->flags & (BSF_SECTION_SYM | BSF_SYNTHETIC)) == 0)
f2b2af2c 892 version_string = bfd_get_symbol_version_string (abfd, sym, &hidden);
bb4d2ac2
L
893
894 if (bfd_is_und_section (bfd_get_section (sym)))
895 hidden = TRUE;
896
91d6fa6a 897 if (inf != NULL)
bb4d2ac2
L
898 {
899 (*inf->fprintf_func) (inf->stream, "%s", name);
900 if (version_string && *version_string != '\0')
901 (*inf->fprintf_func) (inf->stream, hidden ? "@%s" : "@@%s",
902 version_string);
903 }
252b5132 904 else
bb4d2ac2
L
905 {
906 printf ("%s", name);
907 if (version_string && *version_string != '\0')
908 printf (hidden ? "@%s" : "@@%s", version_string);
909 }
252b5132
RH
910
911 if (alloc != NULL)
912 free (alloc);
913}
914
22a398e1
NC
915/* Locate a symbol given a bfd and a section (from INFO->application_data),
916 and a VMA. If INFO->application_data->require_sec is TRUE, then always
917 require the symbol to be in the section. Returns NULL if there is no
918 suitable symbol. If PLACE is not NULL, then *PLACE is set to the index
919 of the symbol in sorted_syms. */
252b5132
RH
920
921static asymbol *
3b9ad1cc 922find_symbol_for_address (bfd_vma vma,
91d6fa6a 923 struct disassemble_info *inf,
3b9ad1cc 924 long *place)
252b5132
RH
925{
926 /* @@ Would it speed things up to cache the last two symbols returned,
927 and maybe their address ranges? For many processors, only one memory
928 operand can be present at a time, so the 2-entry cache wouldn't be
929 constantly churned by code doing heavy memory accesses. */
930
931 /* Indices in `sorted_syms'. */
932 long min = 0;
91d6fa6a 933 long max_count = sorted_symcount;
252b5132 934 long thisplace;
3b9ad1cc
AM
935 struct objdump_disasm_info *aux;
936 bfd *abfd;
937 asection *sec;
938 unsigned int opb;
e39ff52a 939 bfd_boolean want_section;
252b5132
RH
940
941 if (sorted_symcount < 1)
942 return NULL;
943
91d6fa6a 944 aux = (struct objdump_disasm_info *) inf->application_data;
3b9ad1cc
AM
945 abfd = aux->abfd;
946 sec = aux->sec;
91d6fa6a 947 opb = inf->octets_per_byte;
3b9ad1cc 948
252b5132 949 /* Perform a binary search looking for the closest symbol to the
91d6fa6a
NC
950 required value. We are searching the range (min, max_count]. */
951 while (min + 1 < max_count)
252b5132
RH
952 {
953 asymbol *sym;
954
91d6fa6a 955 thisplace = (max_count + min) / 2;
252b5132
RH
956 sym = sorted_syms[thisplace];
957
958 if (bfd_asymbol_value (sym) > vma)
91d6fa6a 959 max_count = thisplace;
252b5132
RH
960 else if (bfd_asymbol_value (sym) < vma)
961 min = thisplace;
962 else
963 {
964 min = thisplace;
965 break;
966 }
967 }
968
969 /* The symbol we want is now in min, the low end of the range we
970 were searching. If there are several symbols with the same
a24bb4f0 971 value, we want the first (non-section/non-debugging) one. */
252b5132
RH
972 thisplace = min;
973 while (thisplace > 0
974 && (bfd_asymbol_value (sorted_syms[thisplace])
a24bb4f0
NC
975 == bfd_asymbol_value (sorted_syms[thisplace - 1]))
976 && ((sorted_syms[thisplace - 1]->flags
977 & (BSF_SECTION_SYM | BSF_DEBUGGING)) == 0)
978 )
252b5132
RH
979 --thisplace;
980
2b4590fb
AM
981 /* Prefer a symbol in the current section if we have multple symbols
982 with the same value, as can occur with overlays or zero size
983 sections. */
984 min = thisplace;
91d6fa6a 985 while (min < max_count
2b4590fb
AM
986 && (bfd_asymbol_value (sorted_syms[min])
987 == bfd_asymbol_value (sorted_syms[thisplace])))
988 {
989 if (sorted_syms[min]->section == sec
91d6fa6a 990 && inf->symbol_is_valid (sorted_syms[min], inf))
2b4590fb
AM
991 {
992 thisplace = min;
993
994 if (place != NULL)
995 *place = thisplace;
996
997 return sorted_syms[thisplace];
998 }
999 ++min;
1000 }
1001
1049f94e 1002 /* If the file is relocatable, and the symbol could be from this
252b5132
RH
1003 section, prefer a symbol from this section over symbols from
1004 others, even if the other symbol's value might be closer.
0af11b59 1005
252b5132
RH
1006 Note that this may be wrong for some symbol references if the
1007 sections have overlapping memory ranges, but in that case there's
1008 no way to tell what's desired without looking at the relocation
e39ff52a 1009 table.
3aade688 1010
e39ff52a
PB
1011 Also give the target a chance to reject symbols. */
1012 want_section = (aux->require_sec
1013 || ((abfd->flags & HAS_RELOC) != 0
1014 && vma >= bfd_get_section_vma (abfd, sec)
1015 && vma < (bfd_get_section_vma (abfd, sec)
1016 + bfd_section_size (abfd, sec) / opb)));
1017 if ((sorted_syms[thisplace]->section != sec && want_section)
91d6fa6a 1018 || ! inf->symbol_is_valid (sorted_syms[thisplace], inf))
252b5132
RH
1019 {
1020 long i;
2b4590fb 1021 long newplace = sorted_symcount;
98a91d6a 1022
2b4590fb 1023 for (i = min - 1; i >= 0; i--)
252b5132 1024 {
e39ff52a 1025 if ((sorted_syms[i]->section == sec || !want_section)
91d6fa6a 1026 && inf->symbol_is_valid (sorted_syms[i], inf))
252b5132 1027 {
e39ff52a
PB
1028 if (newplace == sorted_symcount)
1029 newplace = i;
1030
1031 if (bfd_asymbol_value (sorted_syms[i])
1032 != bfd_asymbol_value (sorted_syms[newplace]))
1033 break;
1034
1035 /* Remember this symbol and keep searching until we reach
1036 an earlier address. */
1037 newplace = i;
252b5132
RH
1038 }
1039 }
1040
e39ff52a
PB
1041 if (newplace != sorted_symcount)
1042 thisplace = newplace;
1043 else
252b5132
RH
1044 {
1045 /* We didn't find a good symbol with a smaller value.
1046 Look for one with a larger value. */
1047 for (i = thisplace + 1; i < sorted_symcount; i++)
1048 {
e39ff52a 1049 if ((sorted_syms[i]->section == sec || !want_section)
91d6fa6a 1050 && inf->symbol_is_valid (sorted_syms[i], inf))
252b5132
RH
1051 {
1052 thisplace = i;
1053 break;
1054 }
1055 }
1056 }
1057
e39ff52a 1058 if ((sorted_syms[thisplace]->section != sec && want_section)
91d6fa6a 1059 || ! inf->symbol_is_valid (sorted_syms[thisplace], inf))
22a398e1
NC
1060 /* There is no suitable symbol. */
1061 return NULL;
1062 }
1063
a24bb4f0
NC
1064 /* If we have not found an exact match for the specified address
1065 and we have dynamic relocations available, then we can produce
1066 a better result by matching a relocation to the address and
1067 using the symbol associated with that relocation. */
1068 if (!want_section
1069 && aux->dynrelbuf != NULL
1070 && sorted_syms[thisplace]->value != vma
1071 /* If we have matched a synthetic symbol, then stick with that. */
1072 && (sorted_syms[thisplace]->flags & BSF_SYNTHETIC) == 0)
1073 {
1074 long rel_count;
1075 arelent ** rel_pp;
1076
1077 for (rel_count = aux->dynrelcount, rel_pp = aux->dynrelbuf;
1078 rel_count--;)
1079 {
1080 arelent * rel = rel_pp[rel_count];
1081
1082 if (rel->address == vma
1083 && rel->sym_ptr_ptr != NULL
1084 /* Absolute relocations do not provide a more helpful symbolic address. */
1085 && ! bfd_is_abs_section ((* rel->sym_ptr_ptr)->section))
1086 {
1087 if (place != NULL)
1088 * place = thisplace;
1089 return * rel->sym_ptr_ptr;
1090 }
1091
1092 /* We are scanning backwards, so if we go below the target address
1093 we have failed. */
1094 if (rel_pp[rel_count]->address < vma)
1095 break;
1096 }
1097 }
1098
252b5132
RH
1099 if (place != NULL)
1100 *place = thisplace;
1101
1102 return sorted_syms[thisplace];
1103}
1104
155e0d23 1105/* Print an address and the offset to the nearest symbol. */
252b5132
RH
1106
1107static void
46dca2e0 1108objdump_print_addr_with_sym (bfd *abfd, asection *sec, asymbol *sym,
91d6fa6a 1109 bfd_vma vma, struct disassemble_info *inf,
46dca2e0 1110 bfd_boolean skip_zeroes)
252b5132 1111{
91d6fa6a 1112 objdump_print_value (vma, inf, skip_zeroes);
252b5132
RH
1113
1114 if (sym == NULL)
1115 {
1116 bfd_vma secaddr;
1117
91d6fa6a
NC
1118 (*inf->fprintf_func) (inf->stream, " <%s",
1119 bfd_get_section_name (abfd, sec));
252b5132
RH
1120 secaddr = bfd_get_section_vma (abfd, sec);
1121 if (vma < secaddr)
1122 {
91d6fa6a
NC
1123 (*inf->fprintf_func) (inf->stream, "-0x");
1124 objdump_print_value (secaddr - vma, inf, TRUE);
252b5132
RH
1125 }
1126 else if (vma > secaddr)
1127 {
91d6fa6a
NC
1128 (*inf->fprintf_func) (inf->stream, "+0x");
1129 objdump_print_value (vma - secaddr, inf, TRUE);
252b5132 1130 }
91d6fa6a 1131 (*inf->fprintf_func) (inf->stream, ">");
252b5132
RH
1132 }
1133 else
1134 {
91d6fa6a 1135 (*inf->fprintf_func) (inf->stream, " <");
a24bb4f0 1136
91d6fa6a 1137 objdump_print_symname (abfd, inf, sym);
a24bb4f0
NC
1138
1139 if (bfd_asymbol_value (sym) == vma)
1140 ;
1141 /* Undefined symbols in an executables and dynamic objects do not have
1142 a value associated with them, so it does not make sense to display
1143 an offset relative to them. Normally we would not be provided with
1144 this kind of symbol, but the target backend might choose to do so,
1145 and the code in find_symbol_for_address might return an as yet
1146 unresolved symbol associated with a dynamic reloc. */
1147 else if ((bfd_get_file_flags (abfd) & (EXEC_P | DYNAMIC))
1148 && bfd_is_und_section (sym->section))
1149 ;
1150 else if (bfd_asymbol_value (sym) > vma)
252b5132 1151 {
91d6fa6a
NC
1152 (*inf->fprintf_func) (inf->stream, "-0x");
1153 objdump_print_value (bfd_asymbol_value (sym) - vma, inf, TRUE);
252b5132
RH
1154 }
1155 else if (vma > bfd_asymbol_value (sym))
1156 {
91d6fa6a
NC
1157 (*inf->fprintf_func) (inf->stream, "+0x");
1158 objdump_print_value (vma - bfd_asymbol_value (sym), inf, TRUE);
252b5132 1159 }
a24bb4f0 1160
91d6fa6a 1161 (*inf->fprintf_func) (inf->stream, ">");
252b5132 1162 }
98ec6e72
NC
1163
1164 if (display_file_offsets)
91d6fa6a 1165 inf->fprintf_func (inf->stream, _(" (File Offset: 0x%lx)"),
98ec6e72 1166 (long int)(sec->filepos + (vma - sec->vma)));
252b5132
RH
1167}
1168
155e0d23
NC
1169/* Print an address (VMA), symbolically if possible.
1170 If SKIP_ZEROES is TRUE, don't output leading zeroes. */
252b5132
RH
1171
1172static void
3b9ad1cc 1173objdump_print_addr (bfd_vma vma,
91d6fa6a 1174 struct disassemble_info *inf,
46dca2e0 1175 bfd_boolean skip_zeroes)
252b5132 1176{
3b9ad1cc 1177 struct objdump_disasm_info *aux;
d253b654 1178 asymbol *sym = NULL;
ce04548a 1179 bfd_boolean skip_find = FALSE;
252b5132 1180
91d6fa6a 1181 aux = (struct objdump_disasm_info *) inf->application_data;
32760852 1182
252b5132
RH
1183 if (sorted_symcount < 1)
1184 {
91d6fa6a
NC
1185 (*inf->fprintf_func) (inf->stream, "0x");
1186 objdump_print_value (vma, inf, skip_zeroes);
32760852
NC
1187
1188 if (display_file_offsets)
91d6fa6a
NC
1189 inf->fprintf_func (inf->stream, _(" (File Offset: 0x%lx)"),
1190 (long int)(aux->sec->filepos + (vma - aux->sec->vma)));
252b5132
RH
1191 return;
1192 }
1193
ce04548a
NC
1194 if (aux->reloc != NULL
1195 && aux->reloc->sym_ptr_ptr != NULL
1196 && * aux->reloc->sym_ptr_ptr != NULL)
1197 {
1198 sym = * aux->reloc->sym_ptr_ptr;
1199
1200 /* Adjust the vma to the reloc. */
1201 vma += bfd_asymbol_value (sym);
1202
1203 if (bfd_is_und_section (bfd_get_section (sym)))
1204 skip_find = TRUE;
1205 }
1206
1207 if (!skip_find)
91d6fa6a 1208 sym = find_symbol_for_address (vma, inf, NULL);
ce04548a 1209
91d6fa6a 1210 objdump_print_addr_with_sym (aux->abfd, aux->sec, sym, vma, inf,
252b5132
RH
1211 skip_zeroes);
1212}
1213
1214/* Print VMA to INFO. This function is passed to the disassembler
1215 routine. */
1216
1217static void
91d6fa6a 1218objdump_print_address (bfd_vma vma, struct disassemble_info *inf)
252b5132 1219{
91d6fa6a 1220 objdump_print_addr (vma, inf, ! prefix_addresses);
252b5132
RH
1221}
1222
2ae86dfc 1223/* Determine if the given address has a symbol associated with it. */
252b5132
RH
1224
1225static int
91d6fa6a 1226objdump_symbol_at_address (bfd_vma vma, struct disassemble_info * inf)
252b5132 1227{
252b5132
RH
1228 asymbol * sym;
1229
91d6fa6a 1230 sym = find_symbol_for_address (vma, inf, NULL);
252b5132
RH
1231
1232 return (sym != NULL && (bfd_asymbol_value (sym) == vma));
1233}
1234
1235/* Hold the last function name and the last line number we displayed
1236 in a disassembly. */
1237
1238static char *prev_functionname;
1239static unsigned int prev_line;
9b8d1a36 1240static unsigned int prev_discriminator;
252b5132
RH
1241
1242/* We keep a list of all files that we have seen when doing a
50c2245b 1243 disassembly with source, so that we know how much of the file to
252b5132
RH
1244 display. This can be important for inlined functions. */
1245
1246struct print_file_list
1247{
1248 struct print_file_list *next;
43ac9881
AM
1249 const char *filename;
1250 const char *modname;
3aade688 1251 const char *map;
e8f5eee4 1252 size_t mapsize;
3aade688 1253 const char **linemap;
e8f5eee4
NC
1254 unsigned maxline;
1255 unsigned last_line;
43339b1d 1256 unsigned max_printed;
e8f5eee4 1257 int first;
252b5132
RH
1258};
1259
1260static struct print_file_list *print_files;
1261
1262/* The number of preceding context lines to show when we start
1263 displaying a file for the first time. */
1264
1265#define SHOW_PRECEDING_CONTEXT_LINES (5)
1266
417ed8af 1267/* Read a complete file into memory. */
e8f5eee4
NC
1268
1269static const char *
5ef2d51b 1270slurp_file (const char *fn, size_t *size, struct stat *fst)
e8f5eee4
NC
1271{
1272#ifdef HAVE_MMAP
1273 int ps = getpagesize ();
1274 size_t msize;
1275#endif
1276 const char *map;
417ed8af 1277 int fd = open (fn, O_RDONLY | O_BINARY);
e8f5eee4
NC
1278
1279 if (fd < 0)
1280 return NULL;
5ef2d51b 1281 if (fstat (fd, fst) < 0)
6c713012
AM
1282 {
1283 close (fd);
1284 return NULL;
1285 }
5ef2d51b 1286 *size = fst->st_size;
e8f5eee4
NC
1287#ifdef HAVE_MMAP
1288 msize = (*size + ps - 1) & ~(ps - 1);
1289 map = mmap (NULL, msize, PROT_READ, MAP_SHARED, fd, 0);
6c713012 1290 if (map != (char *) -1L)
e8f5eee4 1291 {
6c713012
AM
1292 close (fd);
1293 return map;
e8f5eee4
NC
1294 }
1295#endif
3f5e193b 1296 map = (const char *) malloc (*size);
6c713012
AM
1297 if (!map || (size_t) read (fd, (char *) map, *size) != *size)
1298 {
1299 free ((void *) map);
e8f5eee4
NC
1300 map = NULL;
1301 }
1302 close (fd);
6c713012 1303 return map;
e8f5eee4
NC
1304}
1305
1306#define line_map_decrease 5
1307
1308/* Precompute array of lines for a mapped file. */
1309
3aade688
L
1310static const char **
1311index_file (const char *map, size_t size, unsigned int *maxline)
e8f5eee4
NC
1312{
1313 const char *p, *lstart, *end;
1314 int chars_per_line = 45; /* First iteration will use 40. */
1315 unsigned int lineno;
3aade688 1316 const char **linemap = NULL;
e8f5eee4 1317 unsigned long line_map_size = 0;
3aade688 1318
e8f5eee4
NC
1319 lineno = 0;
1320 lstart = map;
1321 end = map + size;
1322
3aade688
L
1323 for (p = map; p < end; p++)
1324 {
1325 if (*p == '\n')
1326 {
1327 if (p + 1 < end && p[1] == '\r')
1328 p++;
1329 }
1330 else if (*p == '\r')
1331 {
e8f5eee4
NC
1332 if (p + 1 < end && p[1] == '\n')
1333 p++;
1334 }
1335 else
1336 continue;
3aade688 1337
e8f5eee4
NC
1338 /* End of line found. */
1339
3aade688
L
1340 if (linemap == NULL || line_map_size < lineno + 1)
1341 {
e8f5eee4
NC
1342 unsigned long newsize;
1343
1344 chars_per_line -= line_map_decrease;
1345 if (chars_per_line <= 1)
1346 chars_per_line = 1;
1347 line_map_size = size / chars_per_line + 1;
1348 if (line_map_size < lineno + 1)
1349 line_map_size = lineno + 1;
1350 newsize = line_map_size * sizeof (char *);
3f5e193b 1351 linemap = (const char **) xrealloc (linemap, newsize);
e8f5eee4
NC
1352 }
1353
3aade688
L
1354 linemap[lineno++] = lstart;
1355 lstart = p + 1;
e8f5eee4 1356 }
3aade688
L
1357
1358 *maxline = lineno;
e8f5eee4
NC
1359 return linemap;
1360}
1361
43ac9881
AM
1362/* Tries to open MODNAME, and if successful adds a node to print_files
1363 linked list and returns that node. Returns NULL on failure. */
1364
1365static struct print_file_list *
5ef2d51b 1366try_print_file_open (const char *origname, const char *modname, struct stat *fst)
43ac9881
AM
1367{
1368 struct print_file_list *p;
43ac9881 1369
3f5e193b 1370 p = (struct print_file_list *) xmalloc (sizeof (struct print_file_list));
43ac9881 1371
5ef2d51b 1372 p->map = slurp_file (modname, &p->mapsize, fst);
e8f5eee4 1373 if (p->map == NULL)
43ac9881 1374 {
e8f5eee4
NC
1375 free (p);
1376 return NULL;
43ac9881 1377 }
3aade688 1378
e8f5eee4
NC
1379 p->linemap = index_file (p->map, p->mapsize, &p->maxline);
1380 p->last_line = 0;
43339b1d 1381 p->max_printed = 0;
43ac9881
AM
1382 p->filename = origname;
1383 p->modname = modname;
43ac9881 1384 p->next = print_files;
e8f5eee4 1385 p->first = 1;
43ac9881
AM
1386 print_files = p;
1387 return p;
1388}
1389
a8685210 1390/* If the source file, as described in the symtab, is not found
43ac9881
AM
1391 try to locate it in one of the paths specified with -I
1392 If found, add location to print_files linked list. */
1393
1394static struct print_file_list *
5ef2d51b 1395update_source_path (const char *filename, bfd *abfd)
43ac9881
AM
1396{
1397 struct print_file_list *p;
1398 const char *fname;
5ef2d51b 1399 struct stat fst;
43ac9881
AM
1400 int i;
1401
5ef2d51b
AM
1402 p = try_print_file_open (filename, filename, &fst);
1403 if (p == NULL)
1404 {
1405 if (include_path_count == 0)
1406 return NULL;
43ac9881 1407
5ef2d51b
AM
1408 /* Get the name of the file. */
1409 fname = lbasename (filename);
43ac9881 1410
5ef2d51b
AM
1411 /* If file exists under a new path, we need to add it to the list
1412 so that show_line knows about it. */
1413 for (i = 0; i < include_path_count; i++)
1414 {
1415 char *modname = concat (include_paths[i], "/", fname,
1416 (const char *) 0);
43ac9881 1417
5ef2d51b
AM
1418 p = try_print_file_open (filename, modname, &fst);
1419 if (p)
1420 break;
43ac9881 1421
5ef2d51b
AM
1422 free (modname);
1423 }
1424 }
1425
1426 if (p != NULL)
1427 {
1428 long mtime = bfd_get_mtime (abfd);
43ac9881 1429
5ef2d51b
AM
1430 if (fst.st_mtime > mtime)
1431 warn (_("source file %s is more recent than object file\n"),
1432 filename);
43ac9881
AM
1433 }
1434
5ef2d51b 1435 return p;
43ac9881
AM
1436}
1437
e8f5eee4 1438/* Print a source file line. */
252b5132 1439
3aade688 1440static void
91d6fa6a 1441print_line (struct print_file_list *p, unsigned int linenum)
252b5132 1442{
e8f5eee4 1443 const char *l;
615f3149 1444 size_t len;
3aade688
L
1445
1446 --linenum;
91d6fa6a 1447 if (linenum >= p->maxline)
e8f5eee4 1448 return;
91d6fa6a 1449 l = p->linemap [linenum];
615f3149
AM
1450 /* Test fwrite return value to quiet glibc warning. */
1451 len = strcspn (l, "\n\r");
1452 if (len == 0 || fwrite (l, len, 1, stdout) == 1)
1453 putchar ('\n');
1454}
252b5132 1455
e8f5eee4 1456/* Print a range of source code lines. */
252b5132 1457
e8f5eee4
NC
1458static void
1459dump_lines (struct print_file_list *p, unsigned int start, unsigned int end)
1460{
1461 if (p->map == NULL)
1462 return;
3aade688 1463 while (start <= end)
e8f5eee4
NC
1464 {
1465 print_line (p, start);
1466 start++;
252b5132 1467 }
0af11b59 1468}
252b5132 1469
50c2245b 1470/* Show the line number, or the source line, in a disassembly
252b5132
RH
1471 listing. */
1472
1473static void
46dca2e0 1474show_line (bfd *abfd, asection *section, bfd_vma addr_offset)
252b5132 1475{
b1f88ebe
AM
1476 const char *filename;
1477 const char *functionname;
91d6fa6a 1478 unsigned int linenumber;
9b8d1a36 1479 unsigned int discriminator;
0dafdf3f 1480 bfd_boolean reloc;
e1fa0163 1481 char *path = NULL;
252b5132
RH
1482
1483 if (! with_line_numbers && ! with_source_code)
1484 return;
1485
9b8d1a36 1486 if (! bfd_find_nearest_line_discriminator (abfd, section, syms, addr_offset,
8b5b2529
AM
1487 &filename, &functionname,
1488 &linenumber, &discriminator))
252b5132
RH
1489 return;
1490
1491 if (filename != NULL && *filename == '\0')
1492 filename = NULL;
1493 if (functionname != NULL && *functionname == '\0')
1494 functionname = NULL;
1495
0dafdf3f
L
1496 if (filename
1497 && IS_ABSOLUTE_PATH (filename)
1498 && prefix)
1499 {
1500 char *path_up;
1501 const char *fname = filename;
e1fa0163
NC
1502
1503 path = xmalloc (prefix_length + PATH_MAX + 1);
0dafdf3f
L
1504
1505 if (prefix_length)
1506 memcpy (path, prefix, prefix_length);
1507 path_up = path + prefix_length;
1508
1509 /* Build relocated filename, stripping off leading directories
e1fa0163 1510 from the initial filename if requested. */
0dafdf3f
L
1511 if (prefix_strip > 0)
1512 {
1513 int level = 0;
1514 const char *s;
1515
e1fa0163 1516 /* Skip selected directory levels. */
0dafdf3f
L
1517 for (s = fname + 1; *s != '\0' && level < prefix_strip; s++)
1518 if (IS_DIR_SEPARATOR(*s))
1519 {
1520 fname = s;
1521 level++;
1522 }
1523 }
1524
e1fa0163 1525 /* Update complete filename. */
0dafdf3f
L
1526 strncpy (path_up, fname, PATH_MAX);
1527 path_up[PATH_MAX] = '\0';
1528
1529 filename = path;
1530 reloc = TRUE;
1531 }
1532 else
1533 reloc = FALSE;
1534
252b5132
RH
1535 if (with_line_numbers)
1536 {
1537 if (functionname != NULL
1538 && (prev_functionname == NULL
1539 || strcmp (functionname, prev_functionname) != 0))
8b5b2529
AM
1540 {
1541 printf ("%s():\n", functionname);
1542 prev_line = -1;
1543 }
1544 if (linenumber > 0
1545 && (linenumber != prev_line
1546 || discriminator != prev_discriminator))
1547 {
1548 if (discriminator > 0)
1549 printf ("%s:%u (discriminator %u)\n",
1550 filename == NULL ? "???" : filename,
1551 linenumber, discriminator);
1552 else
1553 printf ("%s:%u\n", filename == NULL ? "???" : filename,
1554 linenumber);
1555 }
4a14e306
AK
1556 if (unwind_inlines)
1557 {
1558 const char *filename2;
1559 const char *functionname2;
1560 unsigned line2;
1561
1562 while (bfd_find_inliner_info (abfd, &filename2, &functionname2,
1563 &line2))
1564 printf ("inlined by %s:%u (%s)\n", filename2, line2,
1565 functionname2);
1566 }
252b5132
RH
1567 }
1568
1569 if (with_source_code
1570 && filename != NULL
91d6fa6a 1571 && linenumber > 0)
252b5132
RH
1572 {
1573 struct print_file_list **pp, *p;
e8f5eee4 1574 unsigned l;
252b5132
RH
1575
1576 for (pp = &print_files; *pp != NULL; pp = &(*pp)->next)
8b6efd89 1577 if (filename_cmp ((*pp)->filename, filename) == 0)
252b5132
RH
1578 break;
1579 p = *pp;
1580
e8f5eee4 1581 if (p == NULL)
0dafdf3f
L
1582 {
1583 if (reloc)
1584 filename = xstrdup (filename);
5ef2d51b 1585 p = update_source_path (filename, abfd);
0dafdf3f 1586 }
252b5132 1587
91d6fa6a 1588 if (p != NULL && linenumber != p->last_line)
e8f5eee4 1589 {
3aade688 1590 if (file_start_context && p->first)
e8f5eee4 1591 l = 1;
3aade688 1592 else
252b5132 1593 {
91d6fa6a 1594 l = linenumber - SHOW_PRECEDING_CONTEXT_LINES;
3aade688 1595 if (l >= linenumber)
e8f5eee4 1596 l = 1;
43339b1d
AM
1597 if (p->max_printed >= l)
1598 {
1599 if (p->max_printed < linenumber)
1600 l = p->max_printed + 1;
1601 else
1602 l = linenumber;
1603 }
252b5132 1604 }
91d6fa6a 1605 dump_lines (p, l, linenumber);
43339b1d
AM
1606 if (p->max_printed < linenumber)
1607 p->max_printed = linenumber;
91d6fa6a 1608 p->last_line = linenumber;
e8f5eee4 1609 p->first = 0;
252b5132
RH
1610 }
1611 }
1612
1613 if (functionname != NULL
1614 && (prev_functionname == NULL
1615 || strcmp (functionname, prev_functionname) != 0))
1616 {
1617 if (prev_functionname != NULL)
1618 free (prev_functionname);
3f5e193b 1619 prev_functionname = (char *) xmalloc (strlen (functionname) + 1);
252b5132
RH
1620 strcpy (prev_functionname, functionname);
1621 }
1622
91d6fa6a
NC
1623 if (linenumber > 0 && linenumber != prev_line)
1624 prev_line = linenumber;
9b8d1a36
CC
1625
1626 if (discriminator != prev_discriminator)
1627 prev_discriminator = discriminator;
e1fa0163
NC
1628
1629 if (path)
1630 free (path);
252b5132
RH
1631}
1632
1633/* Pseudo FILE object for strings. */
1634typedef struct
1635{
1636 char *buffer;
6f104306
NS
1637 size_t pos;
1638 size_t alloc;
252b5132
RH
1639} SFILE;
1640
46dca2e0 1641/* sprintf to a "stream". */
252b5132 1642
0fd3a477 1643static int ATTRIBUTE_PRINTF_2
46dca2e0 1644objdump_sprintf (SFILE *f, const char *format, ...)
252b5132 1645{
252b5132 1646 size_t n;
46dca2e0 1647 va_list args;
252b5132 1648
6f104306 1649 while (1)
252b5132 1650 {
6f104306 1651 size_t space = f->alloc - f->pos;
3aade688 1652
6f104306
NS
1653 va_start (args, format);
1654 n = vsnprintf (f->buffer + f->pos, space, format, args);
451dad9c 1655 va_end (args);
252b5132 1656
6f104306
NS
1657 if (space > n)
1658 break;
3aade688 1659
6f104306 1660 f->alloc = (f->alloc + n) * 2;
3f5e193b 1661 f->buffer = (char *) xrealloc (f->buffer, f->alloc);
252b5132 1662 }
6f104306 1663 f->pos += n;
3aade688 1664
252b5132
RH
1665 return n;
1666}
1667
1668/* The number of zeroes we want to see before we start skipping them.
1669 The number is arbitrarily chosen. */
1670
0bcb06d2 1671#define DEFAULT_SKIP_ZEROES 8
252b5132
RH
1672
1673/* The number of zeroes to skip at the end of a section. If the
1674 number of zeroes at the end is between SKIP_ZEROES_AT_END and
1675 SKIP_ZEROES, they will be disassembled. If there are fewer than
1676 SKIP_ZEROES_AT_END, they will be skipped. This is a heuristic
1677 attempt to avoid disassembling zeroes inserted by section
1678 alignment. */
1679
0bcb06d2 1680#define DEFAULT_SKIP_ZEROES_AT_END 3
252b5132
RH
1681
1682/* Disassemble some data in memory between given values. */
1683
1684static void
91d6fa6a 1685disassemble_bytes (struct disassemble_info * inf,
46dca2e0
NC
1686 disassembler_ftype disassemble_fn,
1687 bfd_boolean insns,
1688 bfd_byte * data,
1689 bfd_vma start_offset,
1690 bfd_vma stop_offset,
fd7bb956 1691 bfd_vma rel_offset,
46dca2e0
NC
1692 arelent *** relppp,
1693 arelent ** relppend)
252b5132
RH
1694{
1695 struct objdump_disasm_info *aux;
1696 asection *section;
940b2b78 1697 int octets_per_line;
252b5132 1698 int skip_addr_chars;
940b2b78 1699 bfd_vma addr_offset;
91d6fa6a
NC
1700 unsigned int opb = inf->octets_per_byte;
1701 unsigned int skip_zeroes = inf->skip_zeroes;
1702 unsigned int skip_zeroes_at_end = inf->skip_zeroes_at_end;
ce04548a 1703 int octets = opb;
6f104306 1704 SFILE sfile;
252b5132 1705
91d6fa6a 1706 aux = (struct objdump_disasm_info *) inf->application_data;
252b5132
RH
1707 section = aux->sec;
1708
6f104306 1709 sfile.alloc = 120;
3f5e193b 1710 sfile.buffer = (char *) xmalloc (sfile.alloc);
6f104306 1711 sfile.pos = 0;
3aade688 1712
3dcb3fcb
L
1713 if (insn_width)
1714 octets_per_line = insn_width;
1715 else if (insns)
940b2b78 1716 octets_per_line = 4;
252b5132 1717 else
940b2b78 1718 octets_per_line = 16;
252b5132
RH
1719
1720 /* Figure out how many characters to skip at the start of an
1721 address, to make the disassembly look nicer. We discard leading
1722 zeroes in chunks of 4, ensuring that there is always a leading
1723 zero remaining. */
1724 skip_addr_chars = 0;
1725 if (! prefix_addresses)
1726 {
1727 char buf[30];
17ceb936
AM
1728
1729 bfd_sprintf_vma (aux->abfd, buf, section->vma + section->size / opb);
1730
1731 while (buf[skip_addr_chars] == '0')
1732 ++skip_addr_chars;
1733
1734 /* Don't discard zeros on overflow. */
1735 if (buf[skip_addr_chars] == '\0' && section->vma != 0)
1736 skip_addr_chars = 0;
1737
1738 if (skip_addr_chars != 0)
1739 skip_addr_chars = (skip_addr_chars - 1) & -4;
252b5132
RH
1740 }
1741
91d6fa6a 1742 inf->insn_info_valid = 0;
252b5132 1743
940b2b78
TW
1744 addr_offset = start_offset;
1745 while (addr_offset < stop_offset)
252b5132
RH
1746 {
1747 bfd_vma z;
b34976b6 1748 bfd_boolean need_nl = FALSE;
ce04548a
NC
1749 int previous_octets;
1750
1751 /* Remember the length of the previous instruction. */
1752 previous_octets = octets;
ce04548a 1753 octets = 0;
252b5132 1754
bb7c70ed
NC
1755 /* Make sure we don't use relocs from previous instructions. */
1756 aux->reloc = NULL;
1757
940b2b78 1758 /* If we see more than SKIP_ZEROES octets of zeroes, we just
43ac9881 1759 print `...'. */
940b2b78 1760 for (z = addr_offset * opb; z < stop_offset * opb; z++)
252b5132
RH
1761 if (data[z] != 0)
1762 break;
1763 if (! disassemble_zeroes
91d6fa6a
NC
1764 && (inf->insn_info_valid == 0
1765 || inf->branch_delay_insns == 0)
0bcb06d2 1766 && (z - addr_offset * opb >= skip_zeroes
0af11b59 1767 || (z == stop_offset * opb &&
0bcb06d2 1768 z - addr_offset * opb < skip_zeroes_at_end)))
252b5132 1769 {
940b2b78 1770 /* If there are more nonzero octets to follow, we only skip
43ac9881
AM
1771 zeroes in multiples of 4, to try to avoid running over
1772 the start of an instruction which happens to start with
1773 zero. */
940b2b78
TW
1774 if (z != stop_offset * opb)
1775 z = addr_offset * opb + ((z - addr_offset * opb) &~ 3);
252b5132 1776
940b2b78 1777 octets = z - addr_offset * opb;
98ec6e72
NC
1778
1779 /* If we are going to display more data, and we are displaying
1780 file offsets, then tell the user how many zeroes we skip
1781 and the file offset from where we resume dumping. */
1782 if (display_file_offsets && ((addr_offset + (octets / opb)) < stop_offset))
1783 printf ("\t... (skipping %d zeroes, resuming at file offset: 0x%lx)\n",
1784 octets / opb,
0af1713e
AM
1785 (unsigned long) (section->filepos
1786 + (addr_offset + (octets / opb))));
98ec6e72
NC
1787 else
1788 printf ("\t...\n");
252b5132
RH
1789 }
1790 else
1791 {
1792 char buf[50];
252b5132
RH
1793 int bpc = 0;
1794 int pb = 0;
1795
252b5132 1796 if (with_line_numbers || with_source_code)
bc79cded 1797 show_line (aux->abfd, section, addr_offset);
252b5132
RH
1798
1799 if (! prefix_addresses)
1800 {
1801 char *s;
1802
d8180c76 1803 bfd_sprintf_vma (aux->abfd, buf, section->vma + addr_offset);
252b5132
RH
1804 for (s = buf + skip_addr_chars; *s == '0'; s++)
1805 *s = ' ';
1806 if (*s == '\0')
1807 *--s = '0';
1808 printf ("%s:\t", buf + skip_addr_chars);
1809 }
1810 else
1811 {
b34976b6 1812 aux->require_sec = TRUE;
91d6fa6a 1813 objdump_print_address (section->vma + addr_offset, inf);
b34976b6 1814 aux->require_sec = FALSE;
252b5132
RH
1815 putchar (' ');
1816 }
1817
1818 if (insns)
1819 {
6f104306 1820 sfile.pos = 0;
91d6fa6a
NC
1821 inf->fprintf_func = (fprintf_ftype) objdump_sprintf;
1822 inf->stream = &sfile;
1823 inf->bytes_per_line = 0;
1824 inf->bytes_per_chunk = 0;
1825 inf->flags = disassemble_all ? DISASSEMBLE_DATA : 0;
0313a2b8 1826 if (machine)
91d6fa6a 1827 inf->flags |= USER_SPECIFIED_MACHINE_TYPE;
252b5132 1828
91d6fa6a 1829 if (inf->disassembler_needs_relocs
7df428b1
RS
1830 && (bfd_get_file_flags (aux->abfd) & EXEC_P) == 0
1831 && (bfd_get_file_flags (aux->abfd) & DYNAMIC) == 0
d99b6465 1832 && *relppp < relppend)
ce04548a
NC
1833 {
1834 bfd_signed_vma distance_to_rel;
1835
1836 distance_to_rel = (**relppp)->address
1837 - (rel_offset + addr_offset);
1838
1839 /* Check to see if the current reloc is associated with
1840 the instruction that we are about to disassemble. */
1841 if (distance_to_rel == 0
1842 /* FIXME: This is wrong. We are trying to catch
1843 relocs that are addressed part way through the
1844 current instruction, as might happen with a packed
1845 VLIW instruction. Unfortunately we do not know the
1846 length of the current instruction since we have not
1847 disassembled it yet. Instead we take a guess based
1848 upon the length of the previous instruction. The
1849 proper solution is to have a new target-specific
1850 disassembler function which just returns the length
1851 of an instruction at a given address without trying
1852 to display its disassembly. */
1853 || (distance_to_rel > 0
1854 && distance_to_rel < (bfd_signed_vma) (previous_octets/ opb)))
1855 {
91d6fa6a 1856 inf->flags |= INSN_HAS_RELOC;
ce04548a
NC
1857 aux->reloc = **relppp;
1858 }
ce04548a 1859 }
d99b6465 1860
bdc4de1b
NC
1861 if (! disassemble_all
1862 && (section->flags & (SEC_CODE | SEC_HAS_CONTENTS))
1863 == (SEC_CODE | SEC_HAS_CONTENTS))
1864 /* Set a stop_vma so that the disassembler will not read
1865 beyond the next symbol. We assume that symbols appear on
1866 the boundaries between instructions. We only do this when
1867 disassembling code of course, and when -D is in effect. */
1868 inf->stop_vma = section->vma + stop_offset;
3aade688 1869
91d6fa6a 1870 octets = (*disassemble_fn) (section->vma + addr_offset, inf);
bdc4de1b
NC
1871
1872 inf->stop_vma = 0;
91d6fa6a
NC
1873 inf->fprintf_func = (fprintf_ftype) fprintf;
1874 inf->stream = stdout;
1875 if (insn_width == 0 && inf->bytes_per_line != 0)
1876 octets_per_line = inf->bytes_per_line;
a8c62f1c 1877 if (octets < (int) opb)
e07bf1ac 1878 {
6f104306 1879 if (sfile.pos)
e07bf1ac 1880 printf ("%s\n", sfile.buffer);
a8c62f1c
AM
1881 if (octets >= 0)
1882 {
1883 non_fatal (_("disassemble_fn returned length %d"),
1884 octets);
1885 exit_status = 1;
1886 }
e07bf1ac
ILT
1887 break;
1888 }
252b5132
RH
1889 }
1890 else
1891 {
b4c96d0d 1892 bfd_vma j;
252b5132 1893
940b2b78
TW
1894 octets = octets_per_line;
1895 if (addr_offset + octets / opb > stop_offset)
1896 octets = (stop_offset - addr_offset) * opb;
252b5132 1897
940b2b78 1898 for (j = addr_offset * opb; j < addr_offset * opb + octets; ++j)
252b5132 1899 {
3882b010 1900 if (ISPRINT (data[j]))
940b2b78 1901 buf[j - addr_offset * opb] = data[j];
252b5132 1902 else
940b2b78 1903 buf[j - addr_offset * opb] = '.';
252b5132 1904 }
940b2b78 1905 buf[j - addr_offset * opb] = '\0';
252b5132
RH
1906 }
1907
1908 if (prefix_addresses
1909 ? show_raw_insn > 0
1910 : show_raw_insn >= 0)
1911 {
b4c96d0d 1912 bfd_vma j;
252b5132
RH
1913
1914 /* If ! prefix_addresses and ! wide_output, we print
43ac9881 1915 octets_per_line octets per line. */
940b2b78
TW
1916 pb = octets;
1917 if (pb > octets_per_line && ! prefix_addresses && ! wide_output)
1918 pb = octets_per_line;
252b5132 1919
91d6fa6a
NC
1920 if (inf->bytes_per_chunk)
1921 bpc = inf->bytes_per_chunk;
252b5132
RH
1922 else
1923 bpc = 1;
1924
940b2b78 1925 for (j = addr_offset * opb; j < addr_offset * opb + pb; j += bpc)
252b5132 1926 {
ae87f7e7
NC
1927 /* PR 21580: Check for a buffer ending early. */
1928 if (j + bpc <= stop_offset * opb)
252b5132 1929 {
ae87f7e7
NC
1930 int k;
1931
1932 if (inf->display_endian == BFD_ENDIAN_LITTLE)
1933 {
1934 for (k = bpc - 1; k >= 0; k--)
1935 printf ("%02x", (unsigned) data[j + k]);
1936 }
1937 else
1938 {
1939 for (k = 0; k < bpc; k++)
1940 printf ("%02x", (unsigned) data[j + k]);
1941 }
252b5132 1942 }
ae87f7e7 1943 putchar (' ');
252b5132
RH
1944 }
1945
940b2b78 1946 for (; pb < octets_per_line; pb += bpc)
252b5132
RH
1947 {
1948 int k;
1949
1950 for (k = 0; k < bpc; k++)
1951 printf (" ");
1952 putchar (' ');
1953 }
1954
1955 /* Separate raw data from instruction by extra space. */
1956 if (insns)
1957 putchar ('\t');
1958 else
1959 printf (" ");
1960 }
1961
1962 if (! insns)
1963 printf ("%s", buf);
6f104306
NS
1964 else if (sfile.pos)
1965 printf ("%s", sfile.buffer);
252b5132
RH
1966
1967 if (prefix_addresses
1968 ? show_raw_insn > 0
1969 : show_raw_insn >= 0)
1970 {
940b2b78 1971 while (pb < octets)
252b5132 1972 {
b4c96d0d 1973 bfd_vma j;
252b5132
RH
1974 char *s;
1975
1976 putchar ('\n');
940b2b78 1977 j = addr_offset * opb + pb;
252b5132 1978
d8180c76 1979 bfd_sprintf_vma (aux->abfd, buf, section->vma + j / opb);
252b5132
RH
1980 for (s = buf + skip_addr_chars; *s == '0'; s++)
1981 *s = ' ';
1982 if (*s == '\0')
1983 *--s = '0';
1984 printf ("%s:\t", buf + skip_addr_chars);
1985
940b2b78
TW
1986 pb += octets_per_line;
1987 if (pb > octets)
1988 pb = octets;
1989 for (; j < addr_offset * opb + pb; j += bpc)
252b5132 1990 {
d16fdddb
NC
1991 /* PR 21619: Check for a buffer ending early. */
1992 if (j + bpc <= stop_offset * opb)
252b5132 1993 {
d16fdddb
NC
1994 int k;
1995
1996 if (inf->display_endian == BFD_ENDIAN_LITTLE)
1997 {
1998 for (k = bpc - 1; k >= 0; k--)
1999 printf ("%02x", (unsigned) data[j + k]);
2000 }
2001 else
2002 {
2003 for (k = 0; k < bpc; k++)
2004 printf ("%02x", (unsigned) data[j + k]);
2005 }
252b5132 2006 }
d16fdddb 2007 putchar (' ');
252b5132
RH
2008 }
2009 }
2010 }
2011
2012 if (!wide_output)
2013 putchar ('\n');
2014 else
b34976b6 2015 need_nl = TRUE;
252b5132
RH
2016 }
2017
fd7bb956
AM
2018 while ((*relppp) < relppend
2019 && (**relppp)->address < rel_offset + addr_offset + octets / opb)
252b5132 2020 {
fd7bb956 2021 if (dump_reloc_info || dump_dynamic_reloc_info)
252b5132
RH
2022 {
2023 arelent *q;
2024
2025 q = **relppp;
2026
2027 if (wide_output)
2028 putchar ('\t');
2029 else
2030 printf ("\t\t\t");
2031
68b3b8dc 2032 objdump_print_value (section->vma - rel_offset + q->address,
91d6fa6a 2033 inf, TRUE);
252b5132 2034
f9ecb0a4
JJ
2035 if (q->howto == NULL)
2036 printf (": *unknown*\t");
2037 else if (q->howto->name)
2038 printf (": %s\t", q->howto->name);
2039 else
2040 printf (": %d\t", q->howto->type);
252b5132
RH
2041
2042 if (q->sym_ptr_ptr == NULL || *q->sym_ptr_ptr == NULL)
2043 printf ("*unknown*");
2044 else
2045 {
2046 const char *sym_name;
2047
2048 sym_name = bfd_asymbol_name (*q->sym_ptr_ptr);
2049 if (sym_name != NULL && *sym_name != '\0')
91d6fa6a 2050 objdump_print_symname (aux->abfd, inf, *q->sym_ptr_ptr);
252b5132
RH
2051 else
2052 {
2053 asection *sym_sec;
2054
2055 sym_sec = bfd_get_section (*q->sym_ptr_ptr);
2056 sym_name = bfd_get_section_name (aux->abfd, sym_sec);
2057 if (sym_name == NULL || *sym_name == '\0')
2058 sym_name = "*unknown*";
2059 printf ("%s", sym_name);
2060 }
2061 }
2062
2063 if (q->addend)
2064 {
343dbc36
L
2065 bfd_signed_vma addend = q->addend;
2066 if (addend < 0)
2067 {
2068 printf ("-0x");
2069 addend = -addend;
2070 }
2071 else
2072 printf ("+0x");
2073 objdump_print_value (addend, inf, TRUE);
252b5132
RH
2074 }
2075
2076 printf ("\n");
b34976b6 2077 need_nl = FALSE;
252b5132 2078 }
fd7bb956 2079 ++(*relppp);
252b5132
RH
2080 }
2081
2082 if (need_nl)
2083 printf ("\n");
2084
940b2b78 2085 addr_offset += octets / opb;
252b5132 2086 }
6f104306
NS
2087
2088 free (sfile.buffer);
252b5132
RH
2089}
2090
155e0d23 2091static void
91d6fa6a 2092disassemble_section (bfd *abfd, asection *section, void *inf)
155e0d23 2093{
1b0adfe0
NC
2094 const struct elf_backend_data * bed;
2095 bfd_vma sign_adjust = 0;
91d6fa6a 2096 struct disassemble_info * pinfo = (struct disassemble_info *) inf;
3b9ad1cc 2097 struct objdump_disasm_info * paux;
155e0d23
NC
2098 unsigned int opb = pinfo->octets_per_byte;
2099 bfd_byte * data = NULL;
2100 bfd_size_type datasize = 0;
2101 arelent ** rel_pp = NULL;
2102 arelent ** rel_ppstart = NULL;
2103 arelent ** rel_ppend;
bdc4de1b 2104 bfd_vma stop_offset;
155e0d23
NC
2105 asymbol * sym = NULL;
2106 long place = 0;
2107 long rel_count;
2108 bfd_vma rel_offset;
2109 unsigned long addr_offset;
2110
2111 /* Sections that do not contain machine
2112 code are not normally disassembled. */
2113 if (! disassemble_all
70ecb384 2114 && only_list == NULL
46212538
AM
2115 && ((section->flags & (SEC_CODE | SEC_HAS_CONTENTS))
2116 != (SEC_CODE | SEC_HAS_CONTENTS)))
155e0d23
NC
2117 return;
2118
2119 if (! process_section_p (section))
2120 return;
2121
135dfb4a 2122 datasize = bfd_get_section_size (section);
60a02042 2123 if (datasize == 0)
155e0d23
NC
2124 return;
2125
643902a4
AS
2126 if (start_address == (bfd_vma) -1
2127 || start_address < section->vma)
2128 addr_offset = 0;
2129 else
2130 addr_offset = start_address - section->vma;
2131
2132 if (stop_address == (bfd_vma) -1)
2133 stop_offset = datasize / opb;
2134 else
2135 {
2136 if (stop_address < section->vma)
2137 stop_offset = 0;
2138 else
2139 stop_offset = stop_address - section->vma;
2140 if (stop_offset > datasize / opb)
2141 stop_offset = datasize / opb;
2142 }
2143
2144 if (addr_offset >= stop_offset)
2145 return;
2146
155e0d23 2147 /* Decide which set of relocs to use. Load them if necessary. */
3b9ad1cc 2148 paux = (struct objdump_disasm_info *) pinfo->application_data;
a24bb4f0 2149 if (paux->dynrelbuf && dump_dynamic_reloc_info)
155e0d23
NC
2150 {
2151 rel_pp = paux->dynrelbuf;
2152 rel_count = paux->dynrelcount;
2153 /* Dynamic reloc addresses are absolute, non-dynamic are section
50c2245b 2154 relative. REL_OFFSET specifies the reloc address corresponding
155e0d23 2155 to the start of this section. */
68b3b8dc 2156 rel_offset = section->vma;
155e0d23
NC
2157 }
2158 else
2159 {
2160 rel_count = 0;
2161 rel_pp = NULL;
2162 rel_offset = 0;
2163
2164 if ((section->flags & SEC_RELOC) != 0
d99b6465 2165 && (dump_reloc_info || pinfo->disassembler_needs_relocs))
155e0d23
NC
2166 {
2167 long relsize;
2168
2169 relsize = bfd_get_reloc_upper_bound (abfd, section);
2170 if (relsize < 0)
2171 bfd_fatal (bfd_get_filename (abfd));
2172
2173 if (relsize > 0)
2174 {
3f5e193b 2175 rel_ppstart = rel_pp = (arelent **) xmalloc (relsize);
155e0d23
NC
2176 rel_count = bfd_canonicalize_reloc (abfd, section, rel_pp, syms);
2177 if (rel_count < 0)
2178 bfd_fatal (bfd_get_filename (abfd));
2179
2180 /* Sort the relocs by address. */
2181 qsort (rel_pp, rel_count, sizeof (arelent *), compare_relocs);
2182 }
2183 }
155e0d23
NC
2184 }
2185 rel_ppend = rel_pp + rel_count;
2186
bae7501e 2187 if (!bfd_malloc_and_get_section (abfd, section, &data))
b02cd3e9
AM
2188 {
2189 non_fatal (_("Reading section %s failed because: %s"),
2190 section->name, bfd_errmsg (bfd_get_error ()));
2191 return;
2192 }
155e0d23
NC
2193
2194 paux->sec = section;
2195 pinfo->buffer = data;
2196 pinfo->buffer_vma = section->vma;
2197 pinfo->buffer_length = datasize;
2198 pinfo->section = section;
2199
155e0d23
NC
2200 /* Skip over the relocs belonging to addresses below the
2201 start address. */
2202 while (rel_pp < rel_ppend
2203 && (*rel_pp)->address < rel_offset + addr_offset)
2204 ++rel_pp;
2205
643902a4 2206 printf (_("\nDisassembly of section %s:\n"), section->name);
155e0d23
NC
2207
2208 /* Find the nearest symbol forwards from our current position. */
3b9ad1cc 2209 paux->require_sec = TRUE;
3f5e193b 2210 sym = (asymbol *) find_symbol_for_address (section->vma + addr_offset,
91d6fa6a 2211 (struct disassemble_info *) inf,
3f5e193b 2212 &place);
3b9ad1cc 2213 paux->require_sec = FALSE;
155e0d23 2214
46bc35a9
RS
2215 /* PR 9774: If the target used signed addresses then we must make
2216 sure that we sign extend the value that we calculate for 'addr'
2217 in the loop below. */
1b0adfe0
NC
2218 if (bfd_get_flavour (abfd) == bfd_target_elf_flavour
2219 && (bed = get_elf_backend_data (abfd)) != NULL
2220 && bed->sign_extend_vma)
46bc35a9 2221 sign_adjust = (bfd_vma) 1 << (bed->s->arch_size - 1);
1b0adfe0 2222
155e0d23
NC
2223 /* Disassemble a block of instructions up to the address associated with
2224 the symbol we have just found. Then print the symbol and find the
2225 next symbol on. Repeat until we have disassembled the entire section
2226 or we have reached the end of the address range we are interested in. */
2227 while (addr_offset < stop_offset)
2228 {
22a398e1 2229 bfd_vma addr;
155e0d23 2230 asymbol *nextsym;
bdc4de1b 2231 bfd_vma nextstop_offset;
155e0d23
NC
2232 bfd_boolean insns;
2233
22a398e1 2234 addr = section->vma + addr_offset;
095ad3b8 2235 addr = ((addr & ((sign_adjust << 1) - 1)) ^ sign_adjust) - sign_adjust;
22a398e1
NC
2236
2237 if (sym != NULL && bfd_asymbol_value (sym) <= addr)
155e0d23
NC
2238 {
2239 int x;
2240
2241 for (x = place;
2242 (x < sorted_symcount
22a398e1 2243 && (bfd_asymbol_value (sorted_syms[x]) <= addr));
155e0d23
NC
2244 ++x)
2245 continue;
2246
22a398e1 2247 pinfo->symbols = sorted_syms + place;
155e0d23 2248 pinfo->num_symbols = x - place;
2087ad84 2249 pinfo->symtab_pos = place;
155e0d23
NC
2250 }
2251 else
22a398e1
NC
2252 {
2253 pinfo->symbols = NULL;
2254 pinfo->num_symbols = 0;
2087ad84 2255 pinfo->symtab_pos = -1;
22a398e1 2256 }
155e0d23
NC
2257
2258 if (! prefix_addresses)
2259 {
2260 pinfo->fprintf_func (pinfo->stream, "\n");
22a398e1 2261 objdump_print_addr_with_sym (abfd, section, sym, addr,
155e0d23
NC
2262 pinfo, FALSE);
2263 pinfo->fprintf_func (pinfo->stream, ":\n");
2264 }
2265
22a398e1 2266 if (sym != NULL && bfd_asymbol_value (sym) > addr)
155e0d23
NC
2267 nextsym = sym;
2268 else if (sym == NULL)
2269 nextsym = NULL;
2270 else
2271 {
22a398e1
NC
2272#define is_valid_next_sym(SYM) \
2273 ((SYM)->section == section \
2274 && (bfd_asymbol_value (SYM) > bfd_asymbol_value (sym)) \
2275 && pinfo->symbol_is_valid (SYM, pinfo))
3aade688 2276
155e0d23
NC
2277 /* Search forward for the next appropriate symbol in
2278 SECTION. Note that all the symbols are sorted
2279 together into one big array, and that some sections
2280 may have overlapping addresses. */
2281 while (place < sorted_symcount
22a398e1 2282 && ! is_valid_next_sym (sorted_syms [place]))
155e0d23 2283 ++place;
22a398e1 2284
155e0d23
NC
2285 if (place >= sorted_symcount)
2286 nextsym = NULL;
2287 else
2288 nextsym = sorted_syms[place];
2289 }
2290
22a398e1
NC
2291 if (sym != NULL && bfd_asymbol_value (sym) > addr)
2292 nextstop_offset = bfd_asymbol_value (sym) - section->vma;
155e0d23
NC
2293 else if (nextsym == NULL)
2294 nextstop_offset = stop_offset;
2295 else
22a398e1
NC
2296 nextstop_offset = bfd_asymbol_value (nextsym) - section->vma;
2297
84d7b001
NC
2298 if (nextstop_offset > stop_offset
2299 || nextstop_offset <= addr_offset)
22a398e1 2300 nextstop_offset = stop_offset;
155e0d23
NC
2301
2302 /* If a symbol is explicitly marked as being an object
2303 rather than a function, just dump the bytes without
2304 disassembling them. */
2305 if (disassemble_all
2306 || sym == NULL
abf71725 2307 || sym->section != section
22a398e1 2308 || bfd_asymbol_value (sym) > addr
155e0d23
NC
2309 || ((sym->flags & BSF_OBJECT) == 0
2310 && (strstr (bfd_asymbol_name (sym), "gnu_compiled")
2311 == NULL)
2312 && (strstr (bfd_asymbol_name (sym), "gcc2_compiled")
2313 == NULL))
2314 || (sym->flags & BSF_FUNCTION) != 0)
2315 insns = TRUE;
2316 else
2317 insns = FALSE;
2318
2319 disassemble_bytes (pinfo, paux->disassemble_fn, insns, data,
2320 addr_offset, nextstop_offset,
2321 rel_offset, &rel_pp, rel_ppend);
3aade688 2322
155e0d23
NC
2323 addr_offset = nextstop_offset;
2324 sym = nextsym;
2325 }
2326
2327 free (data);
2328
2329 if (rel_ppstart != NULL)
2330 free (rel_ppstart);
2331}
2332
252b5132
RH
2333/* Disassemble the contents of an object file. */
2334
2335static void
46dca2e0 2336disassemble_data (bfd *abfd)
252b5132 2337{
252b5132
RH
2338 struct disassemble_info disasm_info;
2339 struct objdump_disasm_info aux;
4c45e5c9 2340 long i;
252b5132
RH
2341
2342 print_files = NULL;
2343 prev_functionname = NULL;
2344 prev_line = -1;
9b8d1a36 2345 prev_discriminator = 0;
252b5132
RH
2346
2347 /* We make a copy of syms to sort. We don't want to sort syms
2348 because that will screw up the relocs. */
4c45e5c9 2349 sorted_symcount = symcount ? symcount : dynsymcount;
3f5e193b
NC
2350 sorted_syms = (asymbol **) xmalloc ((sorted_symcount + synthcount)
2351 * sizeof (asymbol *));
4c45e5c9
JJ
2352 memcpy (sorted_syms, symcount ? syms : dynsyms,
2353 sorted_symcount * sizeof (asymbol *));
252b5132 2354
4c45e5c9
JJ
2355 sorted_symcount = remove_useless_symbols (sorted_syms, sorted_symcount);
2356
2357 for (i = 0; i < synthcount; ++i)
2358 {
2359 sorted_syms[sorted_symcount] = synthsyms + i;
2360 ++sorted_symcount;
2361 }
252b5132 2362
98a91d6a 2363 /* Sort the symbols into section and symbol order. */
252b5132
RH
2364 qsort (sorted_syms, sorted_symcount, sizeof (asymbol *), compare_symbols);
2365
22a398e1 2366 init_disassemble_info (&disasm_info, stdout, (fprintf_ftype) fprintf);
98a91d6a 2367
46dca2e0 2368 disasm_info.application_data = (void *) &aux;
252b5132 2369 aux.abfd = abfd;
b34976b6 2370 aux.require_sec = FALSE;
155e0d23
NC
2371 aux.dynrelbuf = NULL;
2372 aux.dynrelcount = 0;
ce04548a 2373 aux.reloc = NULL;
155e0d23 2374
252b5132
RH
2375 disasm_info.print_address_func = objdump_print_address;
2376 disasm_info.symbol_at_address_func = objdump_symbol_at_address;
2377
d3ba0551 2378 if (machine != NULL)
252b5132 2379 {
91d6fa6a 2380 const bfd_arch_info_type *inf = bfd_scan_arch (machine);
98a91d6a 2381
91d6fa6a 2382 if (inf == NULL)
a8c62f1c 2383 fatal (_("can't use supplied machine %s"), machine);
98a91d6a 2384
91d6fa6a 2385 abfd->arch_info = inf;
252b5132
RH
2386 }
2387
2388 if (endian != BFD_ENDIAN_UNKNOWN)
2389 {
2390 struct bfd_target *xvec;
2391
3f5e193b 2392 xvec = (struct bfd_target *) xmalloc (sizeof (struct bfd_target));
252b5132
RH
2393 memcpy (xvec, abfd->xvec, sizeof (struct bfd_target));
2394 xvec->byteorder = endian;
2395 abfd->xvec = xvec;
2396 }
2397
155e0d23 2398 /* Use libopcodes to locate a suitable disassembler. */
003ca0fd
YQ
2399 aux.disassemble_fn = disassembler (bfd_get_arch (abfd),
2400 bfd_big_endian (abfd),
2401 bfd_get_mach (abfd), abfd);
155e0d23 2402 if (!aux.disassemble_fn)
252b5132 2403 {
a8c62f1c 2404 non_fatal (_("can't disassemble for architecture %s\n"),
37cc8ec1 2405 bfd_printable_arch_mach (bfd_get_arch (abfd), 0));
75cd796a 2406 exit_status = 1;
252b5132
RH
2407 return;
2408 }
2409
2410 disasm_info.flavour = bfd_get_flavour (abfd);
2411 disasm_info.arch = bfd_get_arch (abfd);
2412 disasm_info.mach = bfd_get_mach (abfd);
dd92f639 2413 disasm_info.disassembler_options = disassembler_options;
155e0d23 2414 disasm_info.octets_per_byte = bfd_octets_per_byte (abfd);
0bcb06d2
AS
2415 disasm_info.skip_zeroes = DEFAULT_SKIP_ZEROES;
2416 disasm_info.skip_zeroes_at_end = DEFAULT_SKIP_ZEROES_AT_END;
d99b6465 2417 disasm_info.disassembler_needs_relocs = FALSE;
0af11b59 2418
252b5132 2419 if (bfd_big_endian (abfd))
a8a9050d 2420 disasm_info.display_endian = disasm_info.endian = BFD_ENDIAN_BIG;
252b5132 2421 else if (bfd_little_endian (abfd))
a8a9050d 2422 disasm_info.display_endian = disasm_info.endian = BFD_ENDIAN_LITTLE;
252b5132
RH
2423 else
2424 /* ??? Aborting here seems too drastic. We could default to big or little
2425 instead. */
2426 disasm_info.endian = BFD_ENDIAN_UNKNOWN;
2427
22a398e1
NC
2428 /* Allow the target to customize the info structure. */
2429 disassemble_init_for_target (& disasm_info);
2430
a24bb4f0 2431 /* Pre-load the dynamic relocs as we may need them during the disassembly. */
fd7bb956
AM
2432 {
2433 long relsize = bfd_get_dynamic_reloc_upper_bound (abfd);
3aade688 2434
a24bb4f0 2435 if (relsize < 0 && dump_dynamic_reloc_info)
fd7bb956
AM
2436 bfd_fatal (bfd_get_filename (abfd));
2437
2438 if (relsize > 0)
2439 {
3f5e193b 2440 aux.dynrelbuf = (arelent **) xmalloc (relsize);
3b9ad1cc
AM
2441 aux.dynrelcount = bfd_canonicalize_dynamic_reloc (abfd,
2442 aux.dynrelbuf,
2443 dynsyms);
155e0d23 2444 if (aux.dynrelcount < 0)
fd7bb956
AM
2445 bfd_fatal (bfd_get_filename (abfd));
2446
2447 /* Sort the relocs by address. */
3b9ad1cc
AM
2448 qsort (aux.dynrelbuf, aux.dynrelcount, sizeof (arelent *),
2449 compare_relocs);
fd7bb956
AM
2450 }
2451 }
2087ad84
PB
2452 disasm_info.symtab = sorted_syms;
2453 disasm_info.symtab_size = sorted_symcount;
fd7bb956 2454
155e0d23 2455 bfd_map_over_sections (abfd, disassemble_section, & disasm_info);
98a91d6a 2456
155e0d23
NC
2457 if (aux.dynrelbuf != NULL)
2458 free (aux.dynrelbuf);
252b5132
RH
2459 free (sorted_syms);
2460}
2461\f
dda8d76d 2462static bfd_boolean
7bcbeb0f
CC
2463load_specific_debug_section (enum dwarf_section_display_enum debug,
2464 asection *sec, void *file)
365544c3
L
2465{
2466 struct dwarf_section *section = &debug_displays [debug].section;
3f5e193b 2467 bfd *abfd = (bfd *) file;
bfec0f11 2468 bfd_byte *contents;
f2023ce7 2469 bfd_size_type amt;
365544c3 2470
365544c3 2471 if (section->start != NULL)
dda8d76d
NC
2472 {
2473 /* If it is already loaded, do nothing. */
2474 if (streq (section->filename, bfd_get_filename (abfd)))
2475 return TRUE;
2476 free (section->start);
2477 }
365544c3 2478
dda8d76d 2479 section->filename = bfd_get_filename (abfd);
d1c4b12b 2480 section->reloc_info = NULL;
3aade688 2481 section->num_relocs = 0;
595330b7 2482 section->address = bfd_get_section_vma (abfd, sec);
365544c3 2483 section->size = bfd_get_section_size (sec);
f2023ce7
AM
2484 amt = section->size + 1;
2485 section->start = contents = malloc (amt);
06614111 2486 section->user_data = sec;
f2023ce7
AM
2487 if (amt == 0
2488 || section->start == NULL
bfec0f11 2489 || !bfd_get_full_section_contents (abfd, sec, &contents))
365544c3
L
2490 {
2491 free_debug_section (debug);
2492 printf (_("\nCan't get contents for section '%s'.\n"),
2493 section->name);
dda8d76d 2494 return FALSE;
1b315056 2495 }
4f1881b9
AM
2496 /* Ensure any string section has a terminating NUL. */
2497 section->start[section->size] = 0;
1b315056 2498
0acf065b
CC
2499 if (is_relocatable && debug_displays [debug].relocate)
2500 {
dda8d76d
NC
2501 long reloc_size;
2502 bfd_boolean ret;
2503
8a72cc6e 2504 bfd_cache_section_contents (sec, section->start);
0acf065b
CC
2505
2506 ret = bfd_simple_get_relocated_section_contents (abfd,
2507 sec,
2508 section->start,
2509 syms) != NULL;
2510
2511 if (! ret)
2512 {
2513 free_debug_section (debug);
2514 printf (_("\nCan't get contents for section '%s'.\n"),
2515 section->name);
dda8d76d 2516 return FALSE;
0acf065b 2517 }
d1c4b12b 2518
d1c4b12b
NC
2519 reloc_size = bfd_get_reloc_upper_bound (abfd, sec);
2520 if (reloc_size > 0)
2521 {
2522 unsigned long reloc_count;
2523 arelent **relocs;
2524
2525 relocs = (arelent **) xmalloc (reloc_size);
2526
2527 reloc_count = bfd_canonicalize_reloc (abfd, sec, relocs, NULL);
2528 if (reloc_count == 0)
2529 free (relocs);
2530 else
2531 {
2532 section->reloc_info = relocs;
2533 section->num_relocs = reloc_count;
2534 }
2535 }
bdc4de1b 2536 }
0acf065b 2537
dda8d76d 2538 return TRUE;
7bcbeb0f
CC
2539}
2540
d1c4b12b
NC
2541bfd_boolean
2542reloc_at (struct dwarf_section * dsec, dwarf_vma offset)
2543{
2544 arelent ** relocs;
2545 arelent * rp;
2546
2547 if (dsec == NULL || dsec->reloc_info == NULL)
2548 return FALSE;
2549
2550 relocs = (arelent **) dsec->reloc_info;
2551
2552 for (; (rp = * relocs) != NULL; ++ relocs)
2553 if (rp->address == offset)
2554 return TRUE;
2555
2556 return FALSE;
2557}
2558
dda8d76d 2559bfd_boolean
7bcbeb0f
CC
2560load_debug_section (enum dwarf_section_display_enum debug, void *file)
2561{
2562 struct dwarf_section *section = &debug_displays [debug].section;
3f5e193b 2563 bfd *abfd = (bfd *) file;
7bcbeb0f
CC
2564 asection *sec;
2565
2566 /* If it is already loaded, do nothing. */
2567 if (section->start != NULL)
dda8d76d
NC
2568 {
2569 if (streq (section->filename, bfd_get_filename (abfd)))
2570 return TRUE;
2571 }
7bcbeb0f
CC
2572
2573 /* Locate the debug section. */
2574 sec = bfd_get_section_by_name (abfd, section->uncompressed_name);
2575 if (sec != NULL)
2576 section->name = section->uncompressed_name;
2577 else
2578 {
2579 sec = bfd_get_section_by_name (abfd, section->compressed_name);
2580 if (sec != NULL)
2581 section->name = section->compressed_name;
2582 }
2583 if (sec == NULL)
dda8d76d 2584 return FALSE;
7bcbeb0f
CC
2585
2586 return load_specific_debug_section (debug, sec, file);
365544c3
L
2587}
2588
2589void
2590free_debug_section (enum dwarf_section_display_enum debug)
2591{
2592 struct dwarf_section *section = &debug_displays [debug].section;
2593
2594 if (section->start == NULL)
2595 return;
2596
06614111
NC
2597 /* PR 17512: file: 0f67f69d. */
2598 if (section->user_data != NULL)
2599 {
2600 asection * sec = (asection *) section->user_data;
2601
2602 /* If we are freeing contents that are also pointed to by the BFD
2603 library's section structure then make sure to update those pointers
2604 too. Otherwise, the next time we try to load data for this section
2605 we can end up using a stale pointer. */
2606 if (section->start == sec->contents)
2607 {
2608 sec->contents = NULL;
2609 sec->flags &= ~ SEC_IN_MEMORY;
db6b071a 2610 sec->compress_status = COMPRESS_SECTION_NONE;
06614111
NC
2611 }
2612 }
2613
365544c3
L
2614 free ((char *) section->start);
2615 section->start = NULL;
2616 section->address = 0;
2617 section->size = 0;
2618}
2619
dda8d76d
NC
2620void
2621close_debug_file (void * file)
2622{
2623 bfd * abfd = (bfd *) file;
2624
2625 bfd_close (abfd);
2626}
2627
2628void *
2629open_debug_file (const char * pathname)
2630{
2631 bfd * data;
2632
2633 data = bfd_openr (pathname, NULL);
2634 if (data == NULL)
2635 return NULL;
2636
2637 if (! bfd_check_format (data, bfd_object))
2638 return NULL;
2639
2640 return data;
2641}
2642
365544c3
L
2643static void
2644dump_dwarf_section (bfd *abfd, asection *section,
2645 void *arg ATTRIBUTE_UNUSED)
2646{
2647 const char *name = bfd_get_section_name (abfd, section);
2648 const char *match;
3f5e193b 2649 int i;
365544c3 2650
0112cd26 2651 if (CONST_STRNEQ (name, ".gnu.linkonce.wi."))
365544c3
L
2652 match = ".debug_info";
2653 else
2654 match = name;
2655
2656 for (i = 0; i < max; i++)
4cb93e3b
TG
2657 if ((strcmp (debug_displays [i].section.uncompressed_name, match) == 0
2658 || strcmp (debug_displays [i].section.compressed_name, match) == 0)
2659 && debug_displays [i].enabled != NULL
2660 && *debug_displays [i].enabled)
365544c3 2661 {
c8450da8 2662 struct dwarf_section *sec = &debug_displays [i].section;
365544c3 2663
c8450da8
TG
2664 if (strcmp (sec->uncompressed_name, match) == 0)
2665 sec->name = sec->uncompressed_name;
2666 else
2667 sec->name = sec->compressed_name;
3f5e193b
NC
2668 if (load_specific_debug_section ((enum dwarf_section_display_enum) i,
2669 section, abfd))
c8450da8
TG
2670 {
2671 debug_displays [i].display (sec, abfd);
3aade688 2672
c8450da8 2673 if (i != info && i != abbrev)
3f5e193b 2674 free_debug_section ((enum dwarf_section_display_enum) i);
365544c3
L
2675 }
2676 break;
2677 }
2678}
2679
2680/* Dump the dwarf debugging information. */
2681
2682static void
2683dump_dwarf (bfd *abfd)
2684{
dda8d76d
NC
2685 bfd * separates;
2686
5184c2ae 2687 is_relocatable = (abfd->flags & (EXEC_P | DYNAMIC)) == 0;
365544c3 2688
09fc85f6 2689 eh_addr_size = bfd_arch_bits_per_address (abfd) / 8;
365544c3
L
2690
2691 if (bfd_big_endian (abfd))
2692 byte_get = byte_get_big_endian;
2693 else if (bfd_little_endian (abfd))
2694 byte_get = byte_get_little_endian;
2695 else
f41e4712
NC
2696 /* PR 17512: file: objdump-s-endless-loop.tekhex. */
2697 {
2698 warn (_("File %s does not contain any dwarf debug information\n"),
2699 bfd_get_filename (abfd));
2700 return;
2701 }
365544c3 2702
b129eb0e 2703 switch (bfd_get_arch (abfd))
2dc4cec1 2704 {
b129eb0e
RH
2705 case bfd_arch_i386:
2706 switch (bfd_get_mach (abfd))
2707 {
2708 case bfd_mach_x86_64:
2709 case bfd_mach_x86_64_intel_syntax:
64b384e1 2710 case bfd_mach_x86_64_nacl:
f24e5a8a
L
2711 case bfd_mach_x64_32:
2712 case bfd_mach_x64_32_intel_syntax:
64b384e1 2713 case bfd_mach_x64_32_nacl:
b129eb0e
RH
2714 init_dwarf_regnames_x86_64 ();
2715 break;
2716
2717 default:
2718 init_dwarf_regnames_i386 ();
2719 break;
2720 }
2721 break;
2722
3d875af5
L
2723 case bfd_arch_iamcu:
2724 init_dwarf_regnames_iamcu ();
2725 break;
2726
4ee22035
RH
2727 case bfd_arch_aarch64:
2728 init_dwarf_regnames_aarch64();
2729 break;
2730
d6bb17b0
AA
2731 case bfd_arch_s390:
2732 init_dwarf_regnames_s390 ();
2733 break;
2734
5bb0830d
AB
2735 case bfd_arch_riscv:
2736 init_dwarf_regnames_riscv ();
2737 break;
2738
b129eb0e
RH
2739 default:
2740 break;
2dc4cec1
L
2741 }
2742
dda8d76d
NC
2743 separates = load_separate_debug_file (abfd, bfd_get_filename (abfd));
2744
365544c3
L
2745 bfd_map_over_sections (abfd, dump_dwarf_section, NULL);
2746
dda8d76d
NC
2747 if (separates)
2748 bfd_map_over_sections (separates, dump_dwarf_section, NULL);
2749
365544c3
L
2750 free_debug_memory ();
2751}
2752\f
29ca8dc5
NS
2753/* Read ABFD's stabs section STABSECT_NAME, and return a pointer to
2754 it. Return NULL on failure. */
252b5132 2755
bae7501e 2756static bfd_byte *
29ca8dc5 2757read_section_stabs (bfd *abfd, const char *sect_name, bfd_size_type *size_ptr)
252b5132 2758{
29ca8dc5 2759 asection *stabsect;
bae7501e 2760 bfd_byte *contents;
252b5132 2761
29ca8dc5 2762 stabsect = bfd_get_section_by_name (abfd, sect_name);
155e0d23 2763 if (stabsect == NULL)
252b5132 2764 {
29ca8dc5 2765 printf (_("No %s section present\n\n"), sect_name);
b34976b6 2766 return FALSE;
252b5132
RH
2767 }
2768
bae7501e 2769 if (!bfd_malloc_and_get_section (abfd, stabsect, &contents))
252b5132 2770 {
a8c62f1c 2771 non_fatal (_("reading %s section of %s failed: %s"),
29ca8dc5 2772 sect_name, bfd_get_filename (abfd),
37cc8ec1 2773 bfd_errmsg (bfd_get_error ()));
75cd796a 2774 exit_status = 1;
a8c62f1c 2775 free (contents);
29ca8dc5 2776 return NULL;
252b5132
RH
2777 }
2778
bae7501e 2779 *size_ptr = bfd_section_size (abfd, stabsect);
252b5132 2780
29ca8dc5 2781 return contents;
252b5132
RH
2782}
2783
2784/* Stabs entries use a 12 byte format:
2785 4 byte string table index
2786 1 byte stab type
2787 1 byte stab other field
2788 2 byte stab desc field
2789 4 byte stab value
2790 FIXME: This will have to change for a 64 bit object format. */
2791
46dca2e0
NC
2792#define STRDXOFF (0)
2793#define TYPEOFF (4)
2794#define OTHEROFF (5)
2795#define DESCOFF (6)
2796#define VALOFF (8)
252b5132
RH
2797#define STABSIZE (12)
2798
2799/* Print ABFD's stabs section STABSECT_NAME (in `stabs'),
2800 using string table section STRSECT_NAME (in `strtab'). */
2801
2802static void
3b9ad1cc
AM
2803print_section_stabs (bfd *abfd,
2804 const char *stabsect_name,
2805 unsigned *string_offset_ptr)
252b5132
RH
2806{
2807 int i;
46dca2e0 2808 unsigned file_string_table_offset = 0;
29ca8dc5 2809 unsigned next_file_string_table_offset = *string_offset_ptr;
252b5132
RH
2810 bfd_byte *stabp, *stabs_end;
2811
2812 stabp = stabs;
2813 stabs_end = stabp + stab_size;
2814
2815 printf (_("Contents of %s section:\n\n"), stabsect_name);
2816 printf ("Symnum n_type n_othr n_desc n_value n_strx String\n");
2817
2818 /* Loop through all symbols and print them.
2819
2820 We start the index at -1 because there is a dummy symbol on
2821 the front of stabs-in-{coff,elf} sections that supplies sizes. */
f41e4712 2822 for (i = -1; stabp <= stabs_end - STABSIZE; stabp += STABSIZE, i++)
252b5132
RH
2823 {
2824 const char *name;
2825 unsigned long strx;
2826 unsigned char type, other;
2827 unsigned short desc;
2828 bfd_vma value;
2829
2830 strx = bfd_h_get_32 (abfd, stabp + STRDXOFF);
2831 type = bfd_h_get_8 (abfd, stabp + TYPEOFF);
2832 other = bfd_h_get_8 (abfd, stabp + OTHEROFF);
2833 desc = bfd_h_get_16 (abfd, stabp + DESCOFF);
2834 value = bfd_h_get_32 (abfd, stabp + VALOFF);
2835
2836 printf ("\n%-6d ", i);
2837 /* Either print the stab name, or, if unnamed, print its number
0af11b59 2838 again (makes consistent formatting for tools like awk). */
252b5132
RH
2839 name = bfd_get_stab_name (type);
2840 if (name != NULL)
2841 printf ("%-6s", name);
2842 else if (type == N_UNDF)
2843 printf ("HdrSym");
2844 else
2845 printf ("%-6d", type);
2846 printf (" %-6d %-6d ", other, desc);
d8180c76 2847 bfd_printf_vma (abfd, value);
252b5132
RH
2848 printf (" %-6lu", strx);
2849
2850 /* Symbols with type == 0 (N_UNDF) specify the length of the
2851 string table associated with this file. We use that info
2852 to know how to relocate the *next* file's string table indices. */
252b5132
RH
2853 if (type == N_UNDF)
2854 {
2855 file_string_table_offset = next_file_string_table_offset;
2856 next_file_string_table_offset += value;
2857 }
2858 else
2859 {
f41e4712
NC
2860 bfd_size_type amt = strx + file_string_table_offset;
2861
252b5132
RH
2862 /* Using the (possibly updated) string table offset, print the
2863 string (if any) associated with this symbol. */
f41e4712
NC
2864 if (amt < stabstr_size)
2865 /* PR 17512: file: 079-79389-0.001:0.1. */
2866 printf (" %.*s", (int)(stabstr_size - amt), strtab + amt);
252b5132
RH
2867 else
2868 printf (" *");
2869 }
2870 }
2871 printf ("\n\n");
29ca8dc5 2872 *string_offset_ptr = next_file_string_table_offset;
252b5132
RH
2873}
2874
155e0d23
NC
2875typedef struct
2876{
2877 const char * section_name;
2878 const char * string_section_name;
29ca8dc5 2879 unsigned string_offset;
155e0d23
NC
2880}
2881stab_section_names;
2882
252b5132 2883static void
155e0d23 2884find_stabs_section (bfd *abfd, asection *section, void *names)
252b5132 2885{
155e0d23
NC
2886 int len;
2887 stab_section_names * sought = (stab_section_names *) names;
252b5132
RH
2888
2889 /* Check for section names for which stabsect_name is a prefix, to
29ca8dc5 2890 handle .stab.N, etc. */
155e0d23
NC
2891 len = strlen (sought->section_name);
2892
2893 /* If the prefix matches, and the files section name ends with a
2894 nul or a digit, then we match. I.e., we want either an exact
2895 match or a section followed by a number. */
2896 if (strncmp (sought->section_name, section->name, len) == 0
2897 && (section->name[len] == 0
29ca8dc5 2898 || (section->name[len] == '.' && ISDIGIT (section->name[len + 1]))))
252b5132 2899 {
29ca8dc5
NS
2900 if (strtab == NULL)
2901 strtab = read_section_stabs (abfd, sought->string_section_name,
2902 &stabstr_size);
3aade688 2903
29ca8dc5 2904 if (strtab)
252b5132 2905 {
bae7501e 2906 stabs = read_section_stabs (abfd, section->name, &stab_size);
29ca8dc5
NS
2907 if (stabs)
2908 print_section_stabs (abfd, section->name, &sought->string_offset);
252b5132
RH
2909 }
2910 }
2911}
98a91d6a 2912
155e0d23
NC
2913static void
2914dump_stabs_section (bfd *abfd, char *stabsect_name, char *strsect_name)
2915{
2916 stab_section_names s;
2917
2918 s.section_name = stabsect_name;
2919 s.string_section_name = strsect_name;
29ca8dc5
NS
2920 s.string_offset = 0;
2921
155e0d23 2922 bfd_map_over_sections (abfd, find_stabs_section, & s);
29ca8dc5
NS
2923
2924 free (strtab);
2925 strtab = NULL;
155e0d23
NC
2926}
2927
2928/* Dump the any sections containing stabs debugging information. */
2929
2930static void
2931dump_stabs (bfd *abfd)
2932{
2933 dump_stabs_section (abfd, ".stab", ".stabstr");
2934 dump_stabs_section (abfd, ".stab.excl", ".stab.exclstr");
2935 dump_stabs_section (abfd, ".stab.index", ".stab.indexstr");
62bb81b8
TG
2936
2937 /* For Darwin. */
2938 dump_stabs_section (abfd, "LC_SYMTAB.stabs", "LC_SYMTAB.stabstr");
2939
155e0d23
NC
2940 dump_stabs_section (abfd, "$GDB_SYMBOLS$", "$GDB_STRINGS$");
2941}
252b5132
RH
2942\f
2943static void
46dca2e0 2944dump_bfd_header (bfd *abfd)
252b5132
RH
2945{
2946 char *comma = "";
2947
2948 printf (_("architecture: %s, "),
2949 bfd_printable_arch_mach (bfd_get_arch (abfd),
2950 bfd_get_mach (abfd)));
6b6bc957 2951 printf (_("flags 0x%08x:\n"), abfd->flags & ~BFD_FLAGS_FOR_BFD_USE_MASK);
252b5132
RH
2952
2953#define PF(x, y) if (abfd->flags & x) {printf("%s%s", comma, y); comma=", ";}
2954 PF (HAS_RELOC, "HAS_RELOC");
2955 PF (EXEC_P, "EXEC_P");
2956 PF (HAS_LINENO, "HAS_LINENO");
2957 PF (HAS_DEBUG, "HAS_DEBUG");
2958 PF (HAS_SYMS, "HAS_SYMS");
2959 PF (HAS_LOCALS, "HAS_LOCALS");
2960 PF (DYNAMIC, "DYNAMIC");
2961 PF (WP_TEXT, "WP_TEXT");
2962 PF (D_PAGED, "D_PAGED");
2963 PF (BFD_IS_RELAXABLE, "BFD_IS_RELAXABLE");
2964 printf (_("\nstart address 0x"));
d8180c76 2965 bfd_printf_vma (abfd, abfd->start_address);
252b5132
RH
2966 printf ("\n");
2967}
98a91d6a 2968
252b5132
RH
2969\f
2970static void
46dca2e0 2971dump_bfd_private_header (bfd *abfd)
252b5132
RH
2972{
2973 bfd_print_private_bfd_data (abfd, stdout);
2974}
2975
6abcee90
TG
2976static void
2977dump_target_specific (bfd *abfd)
2978{
2979 const struct objdump_private_desc * const *desc;
2980 struct objdump_private_option *opt;
2981 char *e, *b;
2982
2983 /* Find the desc. */
2984 for (desc = objdump_private_vectors; *desc != NULL; desc++)
2985 if ((*desc)->filter (abfd))
2986 break;
2987
c32d6f7b 2988 if (*desc == NULL)
6abcee90
TG
2989 {
2990 non_fatal (_("option -P/--private not supported by this file"));
2991 return;
2992 }
2993
2994 /* Clear all options. */
2995 for (opt = (*desc)->options; opt->name; opt++)
2996 opt->selected = FALSE;
2997
2998 /* Decode options. */
2999 b = dump_private_options;
3000 do
3001 {
3002 e = strchr (b, ',');
3003
3004 if (e)
3005 *e = 0;
3006
3007 for (opt = (*desc)->options; opt->name; opt++)
3008 if (strcmp (opt->name, b) == 0)
3009 {
3010 opt->selected = TRUE;
3011 break;
3012 }
3013 if (opt->name == NULL)
3014 non_fatal (_("target specific dump '%s' not supported"), b);
3015
3016 if (e)
3017 {
3018 *e = ',';
3019 b = e + 1;
3020 }
3021 }
3022 while (e != NULL);
3023
3024 /* Dump. */
3025 (*desc)->dump (abfd);
3026}
155e0d23
NC
3027\f
3028/* Display a section in hexadecimal format with associated characters.
3029 Each line prefixed by the zero padded address. */
d24de309 3030
252b5132 3031static void
155e0d23 3032dump_section (bfd *abfd, asection *section, void *dummy ATTRIBUTE_UNUSED)
252b5132 3033{
cfd14a50 3034 bfd_byte *data = NULL;
155e0d23 3035 bfd_size_type datasize;
bdc4de1b
NC
3036 bfd_vma addr_offset;
3037 bfd_vma start_offset;
3038 bfd_vma stop_offset;
155e0d23
NC
3039 unsigned int opb = bfd_octets_per_byte (abfd);
3040 /* Bytes per line. */
3041 const int onaline = 16;
3042 char buf[64];
3043 int count;
3044 int width;
3045
3046 if ((section->flags & SEC_HAS_CONTENTS) == 0)
3047 return;
3048
3049 if (! process_section_p (section))
3050 return;
3aade688 3051
155e0d23
NC
3052 if ((datasize = bfd_section_size (abfd, section)) == 0)
3053 return;
3054
155e0d23
NC
3055 /* Compute the address range to display. */
3056 if (start_address == (bfd_vma) -1
3057 || start_address < section->vma)
3058 start_offset = 0;
3059 else
3060 start_offset = start_address - section->vma;
3061
3062 if (stop_address == (bfd_vma) -1)
3063 stop_offset = datasize / opb;
3064 else
252b5132 3065 {
155e0d23
NC
3066 if (stop_address < section->vma)
3067 stop_offset = 0;
3068 else
3069 stop_offset = stop_address - section->vma;
252b5132 3070
155e0d23
NC
3071 if (stop_offset > datasize / opb)
3072 stop_offset = datasize / opb;
252b5132
RH
3073 }
3074
32760852
NC
3075 if (start_offset >= stop_offset)
3076 return;
3aade688 3077
32760852
NC
3078 printf (_("Contents of section %s:"), section->name);
3079 if (display_file_offsets)
0af1713e
AM
3080 printf (_(" (Starting at file offset: 0x%lx)"),
3081 (unsigned long) (section->filepos + start_offset));
32760852
NC
3082 printf ("\n");
3083
4a114e3e
L
3084 if (!bfd_get_full_section_contents (abfd, section, &data))
3085 {
0821d5b1
NC
3086 non_fatal (_("Reading section %s failed because: %s"),
3087 section->name, bfd_errmsg (bfd_get_error ()));
4a114e3e
L
3088 return;
3089 }
32760852 3090
155e0d23 3091 width = 4;
026df7c5 3092
155e0d23
NC
3093 bfd_sprintf_vma (abfd, buf, start_offset + section->vma);
3094 if (strlen (buf) >= sizeof (buf))
3095 abort ();
026df7c5 3096
155e0d23
NC
3097 count = 0;
3098 while (buf[count] == '0' && buf[count+1] != '\0')
3099 count++;
3100 count = strlen (buf) - count;
3101 if (count > width)
3102 width = count;
252b5132 3103
155e0d23
NC
3104 bfd_sprintf_vma (abfd, buf, stop_offset + section->vma - 1);
3105 if (strlen (buf) >= sizeof (buf))
3106 abort ();
026df7c5 3107
155e0d23
NC
3108 count = 0;
3109 while (buf[count] == '0' && buf[count+1] != '\0')
3110 count++;
3111 count = strlen (buf) - count;
3112 if (count > width)
3113 width = count;
026df7c5 3114
155e0d23
NC
3115 for (addr_offset = start_offset;
3116 addr_offset < stop_offset; addr_offset += onaline / opb)
d24de309 3117 {
155e0d23 3118 bfd_size_type j;
d24de309 3119
155e0d23
NC
3120 bfd_sprintf_vma (abfd, buf, (addr_offset + section->vma));
3121 count = strlen (buf);
3122 if ((size_t) count >= sizeof (buf))
3123 abort ();
d24de309 3124
155e0d23
NC
3125 putchar (' ');
3126 while (count < width)
252b5132 3127 {
155e0d23
NC
3128 putchar ('0');
3129 count++;
3130 }
3131 fputs (buf + count - width, stdout);
3132 putchar (' ');
252b5132 3133
155e0d23
NC
3134 for (j = addr_offset * opb;
3135 j < addr_offset * opb + onaline; j++)
3136 {
3137 if (j < stop_offset * opb)
3138 printf ("%02x", (unsigned) (data[j]));
3139 else
3140 printf (" ");
3141 if ((j & 3) == 3)
3142 printf (" ");
252b5132
RH
3143 }
3144
155e0d23
NC
3145 printf (" ");
3146 for (j = addr_offset * opb;
3147 j < addr_offset * opb + onaline; j++)
3148 {
3149 if (j >= stop_offset * opb)
3150 printf (" ");
3151 else
3152 printf ("%c", ISPRINT (data[j]) ? data[j] : '.');
3153 }
3154 putchar ('\n');
252b5132 3155 }
155e0d23 3156 free (data);
252b5132 3157}
155e0d23 3158
98a91d6a 3159/* Actually display the various requested regions. */
252b5132
RH
3160
3161static void
46dca2e0 3162dump_data (bfd *abfd)
252b5132 3163{
155e0d23 3164 bfd_map_over_sections (abfd, dump_section, NULL);
252b5132
RH
3165}
3166
98a91d6a
NC
3167/* Should perhaps share code and display with nm? */
3168
252b5132 3169static void
46dca2e0 3170dump_symbols (bfd *abfd ATTRIBUTE_UNUSED, bfd_boolean dynamic)
252b5132
RH
3171{
3172 asymbol **current;
91d6fa6a 3173 long max_count;
252b5132
RH
3174 long count;
3175
3176 if (dynamic)
3177 {
3178 current = dynsyms;
91d6fa6a 3179 max_count = dynsymcount;
252b5132
RH
3180 printf ("DYNAMIC SYMBOL TABLE:\n");
3181 }
3182 else
3183 {
3184 current = syms;
91d6fa6a 3185 max_count = symcount;
252b5132
RH
3186 printf ("SYMBOL TABLE:\n");
3187 }
3188
91d6fa6a 3189 if (max_count == 0)
a1df01d1
AM
3190 printf (_("no symbols\n"));
3191
91d6fa6a 3192 for (count = 0; count < max_count; count++)
252b5132 3193 {
155e0d23
NC
3194 bfd *cur_bfd;
3195
3196 if (*current == NULL)
83ef0798 3197 printf (_("no information for symbol number %ld\n"), count);
155e0d23
NC
3198
3199 else if ((cur_bfd = bfd_asymbol_bfd (*current)) == NULL)
83ef0798 3200 printf (_("could not determine the type of symbol number %ld\n"),
155e0d23
NC
3201 count);
3202
661f7c35
NC
3203 else if (process_section_p ((* current)->section)
3204 && (dump_special_syms
3205 || !bfd_is_target_special_symbol (cur_bfd, *current)))
252b5132 3206 {
155e0d23 3207 const char *name = (*current)->name;
252b5132 3208
155e0d23 3209 if (do_demangle && name != NULL && *name != '\0')
252b5132 3210 {
252b5132
RH
3211 char *alloc;
3212
155e0d23
NC
3213 /* If we want to demangle the name, we demangle it
3214 here, and temporarily clobber it while calling
3215 bfd_print_symbol. FIXME: This is a gross hack. */
ed180cc5
AM
3216 alloc = bfd_demangle (cur_bfd, name, DMGL_ANSI | DMGL_PARAMS);
3217 if (alloc != NULL)
3218 (*current)->name = alloc;
252b5132
RH
3219 bfd_print_symbol (cur_bfd, stdout, *current,
3220 bfd_print_symbol_all);
ed180cc5
AM
3221 if (alloc != NULL)
3222 {
3223 (*current)->name = name;
3224 free (alloc);
3225 }
252b5132 3226 }
252b5132 3227 else
155e0d23
NC
3228 bfd_print_symbol (cur_bfd, stdout, *current,
3229 bfd_print_symbol_all);
83ef0798 3230 printf ("\n");
252b5132 3231 }
661f7c35 3232
155e0d23 3233 current++;
252b5132 3234 }
155e0d23 3235 printf ("\n\n");
252b5132 3236}
155e0d23 3237\f
252b5132 3238static void
46dca2e0 3239dump_reloc_set (bfd *abfd, asection *sec, arelent **relpp, long relcount)
252b5132
RH
3240{
3241 arelent **p;
3242 char *last_filename, *last_functionname;
3243 unsigned int last_line;
9b8d1a36 3244 unsigned int last_discriminator;
252b5132
RH
3245
3246 /* Get column headers lined up reasonably. */
3247 {
3248 static int width;
98a91d6a 3249
252b5132
RH
3250 if (width == 0)
3251 {
3252 char buf[30];
155e0d23 3253
d8180c76 3254 bfd_sprintf_vma (abfd, buf, (bfd_vma) -1);
252b5132
RH
3255 width = strlen (buf) - 7;
3256 }
3257 printf ("OFFSET %*s TYPE %*s VALUE \n", width, "", 12, "");
3258 }
3259
3260 last_filename = NULL;
3261 last_functionname = NULL;
3262 last_line = 0;
9b8d1a36 3263 last_discriminator = 0;
252b5132 3264
d3ba0551 3265 for (p = relpp; relcount && *p != NULL; p++, relcount--)
252b5132
RH
3266 {
3267 arelent *q = *p;
3268 const char *filename, *functionname;
91d6fa6a 3269 unsigned int linenumber;
9b8d1a36 3270 unsigned int discriminator;
252b5132
RH
3271 const char *sym_name;
3272 const char *section_name;
bf03e632 3273 bfd_vma addend2 = 0;
252b5132
RH
3274
3275 if (start_address != (bfd_vma) -1
3276 && q->address < start_address)
3277 continue;
3278 if (stop_address != (bfd_vma) -1
3279 && q->address > stop_address)
3280 continue;
3281
3282 if (with_line_numbers
3283 && sec != NULL
9b8d1a36
CC
3284 && bfd_find_nearest_line_discriminator (abfd, sec, syms, q->address,
3285 &filename, &functionname,
3286 &linenumber, &discriminator))
252b5132
RH
3287 {
3288 if (functionname != NULL
3289 && (last_functionname == NULL
3290 || strcmp (functionname, last_functionname) != 0))
3291 {
3292 printf ("%s():\n", functionname);
3293 if (last_functionname != NULL)
3294 free (last_functionname);
3295 last_functionname = xstrdup (functionname);
3296 }
98a91d6a 3297
91d6fa6a
NC
3298 if (linenumber > 0
3299 && (linenumber != last_line
252b5132
RH
3300 || (filename != NULL
3301 && last_filename != NULL
9b8d1a36
CC
3302 && filename_cmp (filename, last_filename) != 0)
3303 || (discriminator != last_discriminator)))
252b5132 3304 {
9b8d1a36
CC
3305 if (discriminator > 0)
3306 printf ("%s:%u\n", filename == NULL ? "???" : filename, linenumber);
3307 else
3308 printf ("%s:%u (discriminator %u)\n", filename == NULL ? "???" : filename,
3309 linenumber, discriminator);
91d6fa6a 3310 last_line = linenumber;
9b8d1a36 3311 last_discriminator = discriminator;
252b5132
RH
3312 if (last_filename != NULL)
3313 free (last_filename);
3314 if (filename == NULL)
3315 last_filename = NULL;
3316 else
3317 last_filename = xstrdup (filename);
3318 }
3319 }
3320
3321 if (q->sym_ptr_ptr && *q->sym_ptr_ptr)
3322 {
3323 sym_name = (*(q->sym_ptr_ptr))->name;
3324 section_name = (*(q->sym_ptr_ptr))->section->name;
3325 }
3326 else
3327 {
3328 sym_name = NULL;
3329 section_name = NULL;
3330 }
98a91d6a 3331
f9ecb0a4
JJ
3332 bfd_printf_vma (abfd, q->address);
3333 if (q->howto == NULL)
3334 printf (" *unknown* ");
3335 else if (q->howto->name)
bf03e632
DM
3336 {
3337 const char *name = q->howto->name;
3338
3339 /* R_SPARC_OLO10 relocations contain two addends.
3340 But because 'arelent' lacks enough storage to
3341 store them both, the 64-bit ELF Sparc backend
3342 records this as two relocations. One R_SPARC_LO10
3343 and one R_SPARC_13, both pointing to the same
3344 address. This is merely so that we have some
3345 place to store both addend fields.
3346
3347 Undo this transformation, otherwise the output
3348 will be confusing. */
3349 if (abfd->xvec->flavour == bfd_target_elf_flavour
3350 && elf_tdata(abfd)->elf_header->e_machine == EM_SPARCV9
3351 && relcount > 1
3352 && !strcmp (q->howto->name, "R_SPARC_LO10"))
3353 {
3354 arelent *q2 = *(p + 1);
3355 if (q2 != NULL
3356 && q2->howto
3357 && q->address == q2->address
3358 && !strcmp (q2->howto->name, "R_SPARC_13"))
3359 {
3360 name = "R_SPARC_OLO10";
3361 addend2 = q2->addend;
3362 p++;
3363 }
3364 }
3365 printf (" %-16s ", name);
3366 }
f9ecb0a4
JJ
3367 else
3368 printf (" %-16d ", q->howto->type);
171191ba 3369
252b5132 3370 if (sym_name)
171191ba
NC
3371 {
3372 objdump_print_symname (abfd, NULL, *q->sym_ptr_ptr);
171191ba 3373 }
252b5132
RH
3374 else
3375 {
d3ba0551 3376 if (section_name == NULL)
252b5132 3377 section_name = "*unknown*";
f9ecb0a4 3378 printf ("[%s]", section_name);
252b5132 3379 }
98a91d6a 3380
252b5132
RH
3381 if (q->addend)
3382 {
343dbc36
L
3383 bfd_signed_vma addend = q->addend;
3384 if (addend < 0)
3385 {
3386 printf ("-0x");
3387 addend = -addend;
3388 }
3389 else
3390 printf ("+0x");
3391 bfd_printf_vma (abfd, addend);
252b5132 3392 }
bf03e632
DM
3393 if (addend2)
3394 {
3395 printf ("+0x");
3396 bfd_printf_vma (abfd, addend2);
3397 }
98a91d6a 3398
252b5132
RH
3399 printf ("\n");
3400 }
4b41844b
NC
3401
3402 if (last_filename != NULL)
3403 free (last_filename);
3404 if (last_functionname != NULL)
3405 free (last_functionname);
252b5132 3406}
43ac9881 3407
155e0d23 3408static void
3b9ad1cc
AM
3409dump_relocs_in_section (bfd *abfd,
3410 asection *section,
3411 void *dummy ATTRIBUTE_UNUSED)
155e0d23
NC
3412{
3413 arelent **relpp;
3414 long relcount;
3415 long relsize;
3416
3417 if ( bfd_is_abs_section (section)
3418 || bfd_is_und_section (section)
3419 || bfd_is_com_section (section)
3420 || (! process_section_p (section))
3421 || ((section->flags & SEC_RELOC) == 0))
3422 return;
3423
3424 relsize = bfd_get_reloc_upper_bound (abfd, section);
3425 if (relsize < 0)
3426 bfd_fatal (bfd_get_filename (abfd));
3427
3428 printf ("RELOCATION RECORDS FOR [%s]:", section->name);
3429
3430 if (relsize == 0)
3431 {
3432 printf (" (none)\n\n");
3433 return;
3434 }
3435
39ff1b79 3436 if ((bfd_get_file_flags (abfd) & (BFD_IN_MEMORY | BFD_LINKER_CREATED)) == 0
d785b7d4
NC
3437 && (((ufile_ptr) relsize > bfd_get_file_size (abfd))
3438 /* Also check the section's reloc count since if this is negative
3439 (or very large) the computation in bfd_get_reloc_upper_bound
3440 may have resulted in returning a small, positive integer.
3441 See PR 22508 for a reproducer.
3442
3443 Note - we check against file size rather than section size as
3444 it is possible for there to be more relocs that apply to a
3445 section than there are bytes in that section. */
3446 || (section->reloc_count > bfd_get_file_size (abfd))))
39ff1b79
NC
3447 {
3448 printf (" (too many: 0x%x)\n", section->reloc_count);
3449 bfd_set_error (bfd_error_file_truncated);
3450 bfd_fatal (bfd_get_filename (abfd));
3451 }
3452
3f5e193b 3453 relpp = (arelent **) xmalloc (relsize);
155e0d23
NC
3454 relcount = bfd_canonicalize_reloc (abfd, section, relpp, syms);
3455
3456 if (relcount < 0)
5a3f568b
NC
3457 {
3458 printf ("\n");
3459 non_fatal (_("failed to read relocs in: %s"), bfd_get_filename (abfd));
3460 bfd_fatal (_("error message was"));
3461 }
155e0d23
NC
3462 else if (relcount == 0)
3463 printf (" (none)\n\n");
3464 else
3465 {
3466 printf ("\n");
3467 dump_reloc_set (abfd, section, relpp, relcount);
3468 printf ("\n\n");
3469 }
3470 free (relpp);
3471}
3472
3473static void
3474dump_relocs (bfd *abfd)
3475{
3476 bfd_map_over_sections (abfd, dump_relocs_in_section, NULL);
3477}
3478
3479static void
3480dump_dynamic_relocs (bfd *abfd)
3481{
3482 long relsize;
3483 arelent **relpp;
3484 long relcount;
3485
3486 relsize = bfd_get_dynamic_reloc_upper_bound (abfd);
3487 if (relsize < 0)
3488 bfd_fatal (bfd_get_filename (abfd));
3489
3490 printf ("DYNAMIC RELOCATION RECORDS");
3491
3492 if (relsize == 0)
3493 printf (" (none)\n\n");
3494 else
3495 {
3f5e193b 3496 relpp = (arelent **) xmalloc (relsize);
155e0d23
NC
3497 relcount = bfd_canonicalize_dynamic_reloc (abfd, relpp, dynsyms);
3498
3499 if (relcount < 0)
3500 bfd_fatal (bfd_get_filename (abfd));
3501 else if (relcount == 0)
3502 printf (" (none)\n\n");
3503 else
3504 {
3505 printf ("\n");
3506 dump_reloc_set (abfd, NULL, relpp, relcount);
3507 printf ("\n\n");
3508 }
3509 free (relpp);
3510 }
3511}
3512
43ac9881
AM
3513/* Creates a table of paths, to search for source files. */
3514
3515static void
3516add_include_path (const char *path)
3517{
3518 if (path[0] == 0)
3519 return;
3520 include_path_count++;
3f5e193b
NC
3521 include_paths = (const char **)
3522 xrealloc (include_paths, include_path_count * sizeof (*include_paths));
43ac9881
AM
3523#ifdef HAVE_DOS_BASED_FILE_SYSTEM
3524 if (path[1] == ':' && path[2] == 0)
3525 path = concat (path, ".", (const char *) 0);
3526#endif
3527 include_paths[include_path_count - 1] = path;
3528}
155e0d23
NC
3529
3530static void
3b9ad1cc
AM
3531adjust_addresses (bfd *abfd ATTRIBUTE_UNUSED,
3532 asection *section,
bc79cded 3533 void *arg)
155e0d23 3534{
bc79cded
L
3535 if ((section->flags & SEC_DEBUGGING) == 0)
3536 {
3537 bfd_boolean *has_reloc_p = (bfd_boolean *) arg;
3538 section->vma += adjust_section_vma;
3539 if (*has_reloc_p)
3540 section->lma += adjust_section_vma;
3541 }
155e0d23
NC
3542}
3543
3544/* Dump selected contents of ABFD. */
3545
3546static void
3547dump_bfd (bfd *abfd)
3548{
3549 /* If we are adjusting section VMA's, change them all now. Changing
3550 the BFD information is a hack. However, we must do it, or
3551 bfd_find_nearest_line will not do the right thing. */
3552 if (adjust_section_vma != 0)
bc79cded
L
3553 {
3554 bfd_boolean has_reloc = (abfd->flags & HAS_RELOC);
3555 bfd_map_over_sections (abfd, adjust_addresses, &has_reloc);
3556 }
155e0d23 3557
fd2f0033 3558 if (! dump_debugging_tags && ! suppress_bfd_header)
155e0d23
NC
3559 printf (_("\n%s: file format %s\n"), bfd_get_filename (abfd),
3560 abfd->xvec->name);
3561 if (dump_ar_hdrs)
3562 print_arelt_descr (stdout, abfd, TRUE);
3563 if (dump_file_header)
3564 dump_bfd_header (abfd);
3565 if (dump_private_headers)
3566 dump_bfd_private_header (abfd);
6abcee90
TG
3567 if (dump_private_options != NULL)
3568 dump_target_specific (abfd);
fd2f0033 3569 if (! dump_debugging_tags && ! suppress_bfd_header)
155e0d23 3570 putchar ('\n');
155e0d23 3571
365544c3
L
3572 if (dump_symtab
3573 || dump_reloc_info
3574 || disassemble
3575 || dump_debugging
3576 || dump_dwarf_section_info)
155e0d23 3577 syms = slurp_symtab (abfd);
a29a8af8
KT
3578
3579 if (dump_section_headers)
3580 dump_headers (abfd);
3581
4c45e5c9
JJ
3582 if (dump_dynamic_symtab || dump_dynamic_reloc_info
3583 || (disassemble && bfd_get_dynamic_symtab_upper_bound (abfd) > 0))
155e0d23 3584 dynsyms = slurp_dynamic_symtab (abfd);
90e3cdf2 3585 if (disassemble)
4c45e5c9 3586 {
c9727e01
AM
3587 synthcount = bfd_get_synthetic_symtab (abfd, symcount, syms,
3588 dynsymcount, dynsyms, &synthsyms);
3589 if (synthcount < 0)
3590 synthcount = 0;
4c45e5c9 3591 }
155e0d23
NC
3592
3593 if (dump_symtab)
3594 dump_symbols (abfd, FALSE);
3595 if (dump_dynamic_symtab)
3596 dump_symbols (abfd, TRUE);
365544c3
L
3597 if (dump_dwarf_section_info)
3598 dump_dwarf (abfd);
155e0d23
NC
3599 if (dump_stab_section_info)
3600 dump_stabs (abfd);
3601 if (dump_reloc_info && ! disassemble)
3602 dump_relocs (abfd);
3603 if (dump_dynamic_reloc_info && ! disassemble)
3604 dump_dynamic_relocs (abfd);
3605 if (dump_section_contents)
3606 dump_data (abfd);
3607 if (disassemble)
3608 disassemble_data (abfd);
3609
3610 if (dump_debugging)
3611 {
3612 void *dhandle;
3613
b922d590 3614 dhandle = read_debugging_info (abfd, syms, symcount, TRUE);
155e0d23
NC
3615 if (dhandle != NULL)
3616 {
ed180cc5
AM
3617 if (!print_debugging_info (stdout, dhandle, abfd, syms,
3618 bfd_demangle,
3619 dump_debugging_tags ? TRUE : FALSE))
155e0d23
NC
3620 {
3621 non_fatal (_("%s: printing debugging information failed"),
3622 bfd_get_filename (abfd));
3623 exit_status = 1;
3624 }
3625 }
b922d590
NC
3626 /* PR 6483: If there was no STABS or IEEE debug
3627 info in the file, try DWARF instead. */
3628 else if (! dump_dwarf_section_info)
3629 {
3aade688 3630 dwarf_select_sections_all ();
b922d590
NC
3631 dump_dwarf (abfd);
3632 }
155e0d23
NC
3633 }
3634
3635 if (syms)
3636 {
3637 free (syms);
3638 syms = NULL;
3639 }
3640
3641 if (dynsyms)
3642 {
3643 free (dynsyms);
3644 dynsyms = NULL;
3645 }
4c45e5c9
JJ
3646
3647 if (synthsyms)
3648 {
3649 free (synthsyms);
3650 synthsyms = NULL;
3651 }
3652
3653 symcount = 0;
3654 dynsymcount = 0;
3655 synthcount = 0;
155e0d23
NC
3656}
3657
3658static void
1598539f 3659display_object_bfd (bfd *abfd)
155e0d23
NC
3660{
3661 char **matching;
3662
3663 if (bfd_check_format_matches (abfd, bfd_object, &matching))
3664 {
3665 dump_bfd (abfd);
3666 return;
3667 }
3668
3669 if (bfd_get_error () == bfd_error_file_ambiguously_recognized)
3670 {
3671 nonfatal (bfd_get_filename (abfd));
3672 list_matching_formats (matching);
3673 free (matching);
3674 return;
3675 }
3676
3677 if (bfd_get_error () != bfd_error_file_not_recognized)
3678 {
3679 nonfatal (bfd_get_filename (abfd));
3680 return;
3681 }
3682
3683 if (bfd_check_format_matches (abfd, bfd_core, &matching))
3684 {
3685 dump_bfd (abfd);
3686 return;
3687 }
3688
3689 nonfatal (bfd_get_filename (abfd));
3690
3691 if (bfd_get_error () == bfd_error_file_ambiguously_recognized)
3692 {
3693 list_matching_formats (matching);
3694 free (matching);
3695 }
3696}
3697
3698static void
1598539f 3699display_any_bfd (bfd *file, int level)
155e0d23 3700{
4a114e3e
L
3701 /* Decompress sections unless dumping the section contents. */
3702 if (!dump_section_contents)
3703 file->flags |= BFD_DECOMPRESS;
3704
155e0d23
NC
3705 /* If the file is an archive, process all of its elements. */
3706 if (bfd_check_format (file, bfd_archive))
3707 {
1598539f 3708 bfd *arfile = NULL;
155e0d23 3709 bfd *last_arfile = NULL;
bdc4de1b 3710
1598539f
TG
3711 if (level == 0)
3712 printf (_("In archive %s:\n"), bfd_get_filename (file));
c88f5b8e
NC
3713 else if (level > 100)
3714 {
3715 /* Prevent corrupted files from spinning us into an
3716 infinite loop. 100 is an arbitrary heuristic. */
64d29018 3717 fatal (_("Archive nesting is too deep"));
c88f5b8e
NC
3718 return;
3719 }
1598539f
TG
3720 else
3721 printf (_("In nested archive %s:\n"), bfd_get_filename (file));
3722
155e0d23
NC
3723 for (;;)
3724 {
3725 bfd_set_error (bfd_error_no_error);
3726
3727 arfile = bfd_openr_next_archived_file (file, arfile);
3728 if (arfile == NULL)
3729 {
3730 if (bfd_get_error () != bfd_error_no_more_archived_files)
3731 nonfatal (bfd_get_filename (file));
3732 break;
3733 }
3734
1598539f 3735 display_any_bfd (arfile, level + 1);
155e0d23
NC
3736
3737 if (last_arfile != NULL)
f64e188b
NC
3738 {
3739 bfd_close (last_arfile);
3740 /* PR 17512: file: ac585d01. */
3741 if (arfile == last_arfile)
3742 {
3743 last_arfile = NULL;
3744 break;
3745 }
3746 }
155e0d23
NC
3747 last_arfile = arfile;
3748 }
3749
3750 if (last_arfile != NULL)
3751 bfd_close (last_arfile);
3752 }
3753 else
1598539f
TG
3754 display_object_bfd (file);
3755}
3756
3757static void
cd6581da 3758display_file (char *filename, char *target, bfd_boolean last_file)
1598539f
TG
3759{
3760 bfd *file;
3761
3762 if (get_file_size (filename) < 1)
3763 {
3764 exit_status = 1;
3765 return;
3766 }
3767
3768 file = bfd_openr (filename, target);
3769 if (file == NULL)
3770 {
3771 nonfatal (filename);
3772 return;
3773 }
3774
3775 display_any_bfd (file, 0);
155e0d23 3776
cd6581da
NC
3777 /* This is an optimization to improve the speed of objdump, especially when
3778 dumping a file with lots of associated debug informatiom. Calling
3779 bfd_close on such a file can take a non-trivial amount of time as there
3780 are lots of lists to walk and buffers to free. This is only really
3781 necessary however if we are about to load another file and we need the
3782 memory back. Otherwise, if we are about to exit, then we can save (a lot
3783 of) time by only doing a quick close, and allowing the OS to reclaim the
3784 memory for us. */
3785 if (! last_file)
3786 bfd_close (file);
3787 else
3788 bfd_close_all_done (file);
155e0d23 3789}
252b5132 3790\f
252b5132 3791int
46dca2e0 3792main (int argc, char **argv)
252b5132
RH
3793{
3794 int c;
3795 char *target = default_target;
b34976b6 3796 bfd_boolean seenflag = FALSE;
252b5132 3797
155e0d23
NC
3798#if defined (HAVE_SETLOCALE)
3799#if defined (HAVE_LC_MESSAGES)
252b5132 3800 setlocale (LC_MESSAGES, "");
3882b010 3801#endif
3882b010 3802 setlocale (LC_CTYPE, "");
252b5132 3803#endif
155e0d23 3804
252b5132
RH
3805 bindtextdomain (PACKAGE, LOCALEDIR);
3806 textdomain (PACKAGE);
3807
3808 program_name = *argv;
3809 xmalloc_set_program_name (program_name);
86eafac0 3810 bfd_set_error_program_name (program_name);
252b5132
RH
3811
3812 START_PROGRESS (program_name, 0);
3813
869b9d07
MM
3814 expandargv (&argc, &argv);
3815
252b5132
RH
3816 bfd_init ();
3817 set_default_bfd_target ();
3818
4cb93e3b 3819 while ((c = getopt_long (argc, argv,
6abcee90 3820 "pP:ib:m:M:VvCdDlfFaHhrRtTxsSI:j:wE:zgeGW::",
252b5132
RH
3821 long_options, (int *) 0))
3822 != EOF)
3823 {
252b5132
RH
3824 switch (c)
3825 {
3826 case 0:
8b53311e 3827 break; /* We've been given a long option. */
252b5132
RH
3828 case 'm':
3829 machine = optarg;
3830 break;
dd92f639 3831 case 'M':
65b48a81
PB
3832 {
3833 char *options;
3834 if (disassembler_options)
3835 /* Ignore potential memory leak for now. */
3836 options = concat (disassembler_options, ",",
3837 optarg, (const char *) NULL);
3838 else
3839 options = optarg;
3840 disassembler_options = remove_whitespace_and_extra_commas (options);
3841 }
dd92f639 3842 break;
252b5132 3843 case 'j':
70ecb384 3844 add_only (optarg);
252b5132 3845 break;
98ec6e72
NC
3846 case 'F':
3847 display_file_offsets = TRUE;
3848 break;
252b5132 3849 case 'l':
b34976b6 3850 with_line_numbers = TRUE;
252b5132
RH
3851 break;
3852 case 'b':
3853 target = optarg;
3854 break;
1dada9c5 3855 case 'C':
b34976b6 3856 do_demangle = TRUE;
28c309a2
NC
3857 if (optarg != NULL)
3858 {
3859 enum demangling_styles style;
8b53311e 3860
28c309a2 3861 style = cplus_demangle_name_to_style (optarg);
0af11b59 3862 if (style == unknown_demangling)
28c309a2
NC
3863 fatal (_("unknown demangling style `%s'"),
3864 optarg);
8b53311e 3865
28c309a2 3866 cplus_demangle_set_style (style);
0af11b59 3867 }
1dada9c5
NC
3868 break;
3869 case 'w':
7b5d4822 3870 do_wide = wide_output = TRUE;
1dada9c5
NC
3871 break;
3872 case OPTION_ADJUST_VMA:
3873 adjust_section_vma = parse_vma (optarg, "--adjust-vma");
3874 break;
3875 case OPTION_START_ADDRESS:
3876 start_address = parse_vma (optarg, "--start-address");
98ec6e72
NC
3877 if ((stop_address != (bfd_vma) -1) && stop_address <= start_address)
3878 fatal (_("error: the start address should be before the end address"));
1dada9c5
NC
3879 break;
3880 case OPTION_STOP_ADDRESS:
3881 stop_address = parse_vma (optarg, "--stop-address");
98ec6e72
NC
3882 if ((start_address != (bfd_vma) -1) && stop_address <= start_address)
3883 fatal (_("error: the stop address should be after the start address"));
1dada9c5 3884 break;
0dafdf3f
L
3885 case OPTION_PREFIX:
3886 prefix = optarg;
3887 prefix_length = strlen (prefix);
3888 /* Remove an unnecessary trailing '/' */
3889 while (IS_DIR_SEPARATOR (prefix[prefix_length - 1]))
3890 prefix_length--;
3891 break;
3892 case OPTION_PREFIX_STRIP:
3893 prefix_strip = atoi (optarg);
3894 if (prefix_strip < 0)
3895 fatal (_("error: prefix strip must be non-negative"));
3896 break;
3dcb3fcb
L
3897 case OPTION_INSN_WIDTH:
3898 insn_width = strtoul (optarg, NULL, 0);
3899 if (insn_width <= 0)
3900 fatal (_("error: instruction width must be positive"));
3901 break;
4a14e306
AK
3902 case OPTION_INLINES:
3903 unwind_inlines = TRUE;
3904 break;
1dada9c5
NC
3905 case 'E':
3906 if (strcmp (optarg, "B") == 0)
3907 endian = BFD_ENDIAN_BIG;
3908 else if (strcmp (optarg, "L") == 0)
3909 endian = BFD_ENDIAN_LITTLE;
3910 else
3911 {
a8c62f1c 3912 nonfatal (_("unrecognized -E option"));
1dada9c5
NC
3913 usage (stderr, 1);
3914 }
3915 break;
3916 case OPTION_ENDIAN:
3917 if (strncmp (optarg, "big", strlen (optarg)) == 0)
3918 endian = BFD_ENDIAN_BIG;
3919 else if (strncmp (optarg, "little", strlen (optarg)) == 0)
3920 endian = BFD_ENDIAN_LITTLE;
3921 else
3922 {
37cc8ec1 3923 non_fatal (_("unrecognized --endian type `%s'"), optarg);
a8c62f1c 3924 exit_status = 1;
1dada9c5
NC
3925 usage (stderr, 1);
3926 }
3927 break;
8b53311e 3928
252b5132 3929 case 'f':
b34976b6
AM
3930 dump_file_header = TRUE;
3931 seenflag = TRUE;
252b5132
RH
3932 break;
3933 case 'i':
b34976b6
AM
3934 formats_info = TRUE;
3935 seenflag = TRUE;
252b5132 3936 break;
43ac9881
AM
3937 case 'I':
3938 add_include_path (optarg);
3939 break;
252b5132 3940 case 'p':
b34976b6
AM
3941 dump_private_headers = TRUE;
3942 seenflag = TRUE;
252b5132 3943 break;
6abcee90
TG
3944 case 'P':
3945 dump_private_options = optarg;
3946 seenflag = TRUE;
3947 break;
252b5132 3948 case 'x':
b34976b6
AM
3949 dump_private_headers = TRUE;
3950 dump_symtab = TRUE;
3951 dump_reloc_info = TRUE;
3952 dump_file_header = TRUE;
3953 dump_ar_hdrs = TRUE;
3954 dump_section_headers = TRUE;
3955 seenflag = TRUE;
252b5132
RH
3956 break;
3957 case 't':
b34976b6
AM
3958 dump_symtab = TRUE;
3959 seenflag = TRUE;
252b5132
RH
3960 break;
3961 case 'T':
b34976b6
AM
3962 dump_dynamic_symtab = TRUE;
3963 seenflag = TRUE;
252b5132
RH
3964 break;
3965 case 'd':
b34976b6
AM
3966 disassemble = TRUE;
3967 seenflag = TRUE;
1dada9c5
NC
3968 break;
3969 case 'z':
b34976b6 3970 disassemble_zeroes = TRUE;
252b5132
RH
3971 break;
3972 case 'D':
b34976b6
AM
3973 disassemble = TRUE;
3974 disassemble_all = TRUE;
3975 seenflag = TRUE;
252b5132
RH
3976 break;
3977 case 'S':
b34976b6
AM
3978 disassemble = TRUE;
3979 with_source_code = TRUE;
3980 seenflag = TRUE;
1dada9c5
NC
3981 break;
3982 case 'g':
3983 dump_debugging = 1;
b34976b6 3984 seenflag = TRUE;
1dada9c5 3985 break;
51cdc6e0
NC
3986 case 'e':
3987 dump_debugging = 1;
3988 dump_debugging_tags = 1;
3989 do_demangle = TRUE;
3990 seenflag = TRUE;
3991 break;
365544c3
L
3992 case 'W':
3993 dump_dwarf_section_info = TRUE;
3994 seenflag = TRUE;
4cb93e3b
TG
3995 if (optarg)
3996 dwarf_select_sections_by_letters (optarg);
3997 else
3998 dwarf_select_sections_all ();
3999 break;
4000 case OPTION_DWARF:
4001 dump_dwarf_section_info = TRUE;
4002 seenflag = TRUE;
4003 if (optarg)
4004 dwarf_select_sections_by_names (optarg);
4005 else
4006 dwarf_select_sections_all ();
365544c3 4007 break;
fd2f0033
TT
4008 case OPTION_DWARF_DEPTH:
4009 {
4010 char *cp;
4011 dwarf_cutoff_level = strtoul (optarg, & cp, 0);
4012 }
4013 break;
4014 case OPTION_DWARF_START:
4015 {
4016 char *cp;
4017 dwarf_start_die = strtoul (optarg, & cp, 0);
4018 suppress_bfd_header = 1;
4019 }
4020 break;
4723351a
CC
4021 case OPTION_DWARF_CHECK:
4022 dwarf_check = TRUE;
4023 break;
1dada9c5 4024 case 'G':
b34976b6
AM
4025 dump_stab_section_info = TRUE;
4026 seenflag = TRUE;
252b5132
RH
4027 break;
4028 case 's':
b34976b6
AM
4029 dump_section_contents = TRUE;
4030 seenflag = TRUE;
252b5132
RH
4031 break;
4032 case 'r':
b34976b6
AM
4033 dump_reloc_info = TRUE;
4034 seenflag = TRUE;
252b5132
RH
4035 break;
4036 case 'R':
b34976b6
AM
4037 dump_dynamic_reloc_info = TRUE;
4038 seenflag = TRUE;
252b5132
RH
4039 break;
4040 case 'a':
b34976b6
AM
4041 dump_ar_hdrs = TRUE;
4042 seenflag = TRUE;
252b5132
RH
4043 break;
4044 case 'h':
b34976b6
AM
4045 dump_section_headers = TRUE;
4046 seenflag = TRUE;
252b5132 4047 break;
8b53311e 4048 case 'v':
252b5132 4049 case 'V':
b34976b6
AM
4050 show_version = TRUE;
4051 seenflag = TRUE;
252b5132 4052 break;
0af11b59 4053
aebcf7b7
NC
4054 case 'H':
4055 usage (stdout, 0);
4056 /* No need to set seenflag or to break - usage() does not return. */
252b5132
RH
4057 default:
4058 usage (stderr, 1);
4059 }
4060 }
4061
4062 if (show_version)
4063 print_version ("objdump");
4064
b34976b6 4065 if (!seenflag)
1dada9c5 4066 usage (stderr, 2);
252b5132
RH
4067
4068 if (formats_info)
06d86cf7 4069 exit_status = display_info ();
252b5132
RH
4070 else
4071 {
4072 if (optind == argc)
cd6581da 4073 display_file ("a.out", target, TRUE);
252b5132
RH
4074 else
4075 for (; optind < argc;)
cd6581da
NC
4076 {
4077 display_file (argv[optind], target, optind == argc - 1);
4078 optind++;
4079 }
252b5132
RH
4080 }
4081
70ecb384
NC
4082 free_only_list ();
4083
252b5132
RH
4084 END_PROGRESS (program_name);
4085
75cd796a 4086 return exit_status;
252b5132 4087}
This page took 1.016696 seconds and 4 git commands to generate.