objdump.c: Fix coding for DISASSEMBLER_NEEDS_RELOC:
[deliverable/binutils-gdb.git] / binutils / objdump.c
1 /* objdump.c -- dump information about an object file.
2 Copyright 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
3 2000, 2001, 2002, 2003, 2004, 2005
4 Free Software Foundation, Inc.
5
6 This file is part of GNU Binutils.
7
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 2, or (at your option)
11 any later version.
12
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with this program; if not, write to the Free Software
20 Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */
21
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:
30
31 1. Command line arguments are checked for control switches and the
32 information to be displayed is selected.
33
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.
37
38 3. The file's target architecture and binary file format are determined
39 by bfd_check_format(). If they are recognised, then dump_bfd() is
40 called.
41
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
44 a disassembly has been requested.
45
46 When disassembling the code loops through blocks of instructions bounded
47 by symbols, calling disassemble_bytes() on each block. The actual
48 disassembling is done by the libopcodes library, via a function pointer
49 supplied by the disassembler() function. */
50
51 #include "bfd.h"
52 #include "bfdver.h"
53 #include "progress.h"
54 #include "bucomm.h"
55 #include "budemang.h"
56 #include "getopt.h"
57 #include "safe-ctype.h"
58 #include "dis-asm.h"
59 #include "libiberty.h"
60 #include "demangle.h"
61 #include "debug.h"
62 #include "budbg.h"
63
64 /* Internal headers for the ELF .stab-dump code - sorry. */
65 #define BYTES_IN_WORD 32
66 #include "aout/aout64.h"
67
68 #ifdef NEED_DECLARATION_FPRINTF
69 /* This is needed by init_disassemble_info(). */
70 extern int fprintf (FILE *, const char *, ...);
71 #endif
72
73 /* Exit status. */
74 static int exit_status = 0;
75
76 static char *default_target = NULL; /* Default at runtime. */
77
78 /* The following variables are set based on arguments passed on the
79 command line. */
80 static int show_version = 0; /* Show the version number. */
81 static int dump_section_contents; /* -s */
82 static int dump_section_headers; /* -h */
83 static bfd_boolean dump_file_header; /* -f */
84 static int dump_symtab; /* -t */
85 static int dump_dynamic_symtab; /* -T */
86 static int dump_reloc_info; /* -r */
87 static int dump_dynamic_reloc_info; /* -R */
88 static int dump_ar_hdrs; /* -a */
89 static int dump_private_headers; /* -p */
90 static int prefix_addresses; /* --prefix-addresses */
91 static int with_line_numbers; /* -l */
92 static bfd_boolean with_source_code; /* -S */
93 static int show_raw_insn; /* --show-raw-insn */
94 static int dump_stab_section_info; /* --stabs */
95 static int do_demangle; /* -C, --demangle */
96 static bfd_boolean disassemble; /* -d */
97 static bfd_boolean disassemble_all; /* -D */
98 static int disassemble_zeroes; /* --disassemble-zeroes */
99 static bfd_boolean formats_info; /* -i */
100 static int wide_output; /* -w */
101 static bfd_vma start_address = (bfd_vma) -1; /* --start-address */
102 static bfd_vma stop_address = (bfd_vma) -1; /* --stop-address */
103 static int dump_debugging; /* --debugging */
104 static int dump_debugging_tags; /* --debugging-tags */
105 static int dump_special_syms = 0; /* --special-syms */
106 static bfd_vma adjust_section_vma = 0; /* --adjust-vma */
107 static int file_start_context = 0; /* --file-start-context */
108
109 /* Pointer to an array of section names provided by
110 one or more "-j secname" command line options. */
111 static char **only;
112 /* The total number of slots in the only[] array. */
113 static size_t only_size = 0;
114 /* The number of occupied slots in the only[] array. */
115 static size_t only_used = 0;
116
117 /* Variables for handling include file path table. */
118 static const char **include_paths;
119 static int include_path_count;
120
121 /* Extra info to pass to the section disassembler and address printing
122 function. */
123 struct objdump_disasm_info
124 {
125 bfd * abfd;
126 asection * sec;
127 bfd_boolean require_sec;
128 arelent ** dynrelbuf;
129 long dynrelcount;
130 disassembler_ftype disassemble_fn;
131 #ifdef DISASSEMBLER_NEEDS_RELOCS
132 arelent * reloc;
133 #endif
134 };
135
136 /* Architecture to disassemble for, or default if NULL. */
137 static char *machine = NULL;
138
139 /* Target specific options to the disassembler. */
140 static char *disassembler_options = NULL;
141
142 /* Endianness to disassemble for, or default if BFD_ENDIAN_UNKNOWN. */
143 static enum bfd_endian endian = BFD_ENDIAN_UNKNOWN;
144
145 /* The symbol table. */
146 static asymbol **syms;
147
148 /* Number of symbols in `syms'. */
149 static long symcount = 0;
150
151 /* The sorted symbol table. */
152 static asymbol **sorted_syms;
153
154 /* Number of symbols in `sorted_syms'. */
155 static long sorted_symcount = 0;
156
157 /* The dynamic symbol table. */
158 static asymbol **dynsyms;
159
160 /* The synthetic symbol table. */
161 static asymbol *synthsyms;
162 static long synthcount = 0;
163
164 /* Number of symbols in `dynsyms'. */
165 static long dynsymcount = 0;
166
167 static bfd_byte *stabs;
168 static bfd_size_type stab_size;
169
170 static char *strtab;
171 static bfd_size_type stabstr_size;
172 \f
173 static void
174 usage (FILE *stream, int status)
175 {
176 fprintf (stream, _("Usage: %s <option(s)> <file(s)>\n"), program_name);
177 fprintf (stream, _(" Display information from object <file(s)>.\n"));
178 fprintf (stream, _(" At least one of the following switches must be given:\n"));
179 fprintf (stream, _("\
180 -a, --archive-headers Display archive header information\n\
181 -f, --file-headers Display the contents of the overall file header\n\
182 -p, --private-headers Display object format specific file header contents\n\
183 -h, --[section-]headers Display the contents of the section headers\n\
184 -x, --all-headers Display the contents of all headers\n\
185 -d, --disassemble Display assembler contents of executable sections\n\
186 -D, --disassemble-all Display assembler contents of all sections\n\
187 -S, --source Intermix source code with disassembly\n\
188 -s, --full-contents Display the full contents of all sections requested\n\
189 -g, --debugging Display debug information in object file\n\
190 -e, --debugging-tags Display debug information using ctags style\n\
191 -G, --stabs Display (in raw form) any STABS info in the file\n\
192 -t, --syms Display the contents of the symbol table(s)\n\
193 -T, --dynamic-syms Display the contents of the dynamic symbol table\n\
194 -r, --reloc Display the relocation entries in the file\n\
195 -R, --dynamic-reloc Display the dynamic relocation entries in the file\n\
196 -v, --version Display this program's version number\n\
197 -i, --info List object formats and architectures supported\n\
198 -H, --help Display this information\n\
199 "));
200 if (status != 2)
201 {
202 fprintf (stream, _("\n The following switches are optional:\n"));
203 fprintf (stream, _("\
204 -b, --target=BFDNAME Specify the target object format as BFDNAME\n\
205 -m, --architecture=MACHINE Specify the target architecture as MACHINE\n\
206 -j, --section=NAME Only display information for section NAME\n\
207 -M, --disassembler-options=OPT Pass text OPT on to the disassembler\n\
208 -EB --endian=big Assume big endian format when disassembling\n\
209 -EL --endian=little Assume little endian format when disassembling\n\
210 --file-start-context Include context from start of file (with -S)\n\
211 -I, --include=DIR Add DIR to search list for source files\n\
212 -l, --line-numbers Include line numbers and filenames in output\n\
213 -C, --demangle[=STYLE] Decode mangled/processed symbol names\n\
214 The STYLE, if specified, can be `auto', `gnu',\n\
215 `lucid', `arm', `hp', `edg', `gnu-v3', `java'\n\
216 or `gnat'\n\
217 -w, --wide Format output for more than 80 columns\n\
218 -z, --disassemble-zeroes Do not skip blocks of zeroes when disassembling\n\
219 --start-address=ADDR Only process data whose address is >= ADDR\n\
220 --stop-address=ADDR Only process data whose address is <= ADDR\n\
221 --prefix-addresses Print complete address alongside disassembly\n\
222 --[no-]show-raw-insn Display hex alongside symbolic disassembly\n\
223 --adjust-vma=OFFSET Add OFFSET to all displayed section addresses\n\
224 --special-syms Include special symbols in symbol dumps\n\
225 \n"));
226 list_supported_targets (program_name, stream);
227 list_supported_architectures (program_name, stream);
228
229 disassembler_usage (stream);
230 }
231 if (status == 0)
232 fprintf (stream, _("Report bugs to %s.\n"), REPORT_BUGS_TO);
233 exit (status);
234 }
235
236 /* 150 isn't special; it's just an arbitrary non-ASCII char value. */
237 enum option_values
238 {
239 OPTION_ENDIAN=150,
240 OPTION_START_ADDRESS,
241 OPTION_STOP_ADDRESS,
242 OPTION_ADJUST_VMA
243 };
244
245 static struct option long_options[]=
246 {
247 {"adjust-vma", required_argument, NULL, OPTION_ADJUST_VMA},
248 {"all-headers", no_argument, NULL, 'x'},
249 {"private-headers", no_argument, NULL, 'p'},
250 {"architecture", required_argument, NULL, 'm'},
251 {"archive-headers", no_argument, NULL, 'a'},
252 {"debugging", no_argument, NULL, 'g'},
253 {"debugging-tags", no_argument, NULL, 'e'},
254 {"demangle", optional_argument, NULL, 'C'},
255 {"disassemble", no_argument, NULL, 'd'},
256 {"disassemble-all", no_argument, NULL, 'D'},
257 {"disassembler-options", required_argument, NULL, 'M'},
258 {"disassemble-zeroes", no_argument, NULL, 'z'},
259 {"dynamic-reloc", no_argument, NULL, 'R'},
260 {"dynamic-syms", no_argument, NULL, 'T'},
261 {"endian", required_argument, NULL, OPTION_ENDIAN},
262 {"file-headers", no_argument, NULL, 'f'},
263 {"file-start-context", no_argument, &file_start_context, 1},
264 {"full-contents", no_argument, NULL, 's'},
265 {"headers", no_argument, NULL, 'h'},
266 {"help", no_argument, NULL, 'H'},
267 {"info", no_argument, NULL, 'i'},
268 {"line-numbers", no_argument, NULL, 'l'},
269 {"no-show-raw-insn", no_argument, &show_raw_insn, -1},
270 {"prefix-addresses", no_argument, &prefix_addresses, 1},
271 {"reloc", no_argument, NULL, 'r'},
272 {"section", required_argument, NULL, 'j'},
273 {"section-headers", no_argument, NULL, 'h'},
274 {"show-raw-insn", no_argument, &show_raw_insn, 1},
275 {"source", no_argument, NULL, 'S'},
276 {"special-syms", no_argument, &dump_special_syms, 1},
277 {"include", required_argument, NULL, 'I'},
278 {"stabs", no_argument, NULL, 'G'},
279 {"start-address", required_argument, NULL, OPTION_START_ADDRESS},
280 {"stop-address", required_argument, NULL, OPTION_STOP_ADDRESS},
281 {"syms", no_argument, NULL, 't'},
282 {"target", required_argument, NULL, 'b'},
283 {"version", no_argument, NULL, 'V'},
284 {"wide", no_argument, NULL, 'w'},
285 {0, no_argument, 0, 0}
286 };
287 \f
288 static void
289 nonfatal (const char *msg)
290 {
291 bfd_nonfatal (msg);
292 exit_status = 1;
293 }
294 \f
295 static void
296 dump_section_header (bfd *abfd, asection *section,
297 void *ignored ATTRIBUTE_UNUSED)
298 {
299 char *comma = "";
300 unsigned int opb = bfd_octets_per_byte (abfd);
301
302 printf ("%3d %-13s %08lx ", section->index,
303 bfd_get_section_name (abfd, section),
304 (unsigned long) bfd_section_size (abfd, section) / opb);
305 bfd_printf_vma (abfd, bfd_get_section_vma (abfd, section));
306 printf (" ");
307 bfd_printf_vma (abfd, section->lma);
308 printf (" %08lx 2**%u", (unsigned long) section->filepos,
309 bfd_get_section_alignment (abfd, section));
310 if (! wide_output)
311 printf ("\n ");
312 printf (" ");
313
314 #define PF(x, y) \
315 if (section->flags & x) { printf ("%s%s", comma, y); comma = ", "; }
316
317 PF (SEC_HAS_CONTENTS, "CONTENTS");
318 PF (SEC_ALLOC, "ALLOC");
319 PF (SEC_CONSTRUCTOR, "CONSTRUCTOR");
320 PF (SEC_LOAD, "LOAD");
321 PF (SEC_RELOC, "RELOC");
322 PF (SEC_READONLY, "READONLY");
323 PF (SEC_CODE, "CODE");
324 PF (SEC_DATA, "DATA");
325 PF (SEC_ROM, "ROM");
326 PF (SEC_DEBUGGING, "DEBUGGING");
327 PF (SEC_NEVER_LOAD, "NEVER_LOAD");
328 PF (SEC_EXCLUDE, "EXCLUDE");
329 PF (SEC_SORT_ENTRIES, "SORT_ENTRIES");
330 if (bfd_get_arch (abfd) == bfd_arch_tic54x)
331 {
332 PF (SEC_TIC54X_BLOCK, "BLOCK");
333 PF (SEC_TIC54X_CLINK, "CLINK");
334 }
335 PF (SEC_SMALL_DATA, "SMALL_DATA");
336 if (bfd_get_flavour (abfd) == bfd_target_coff_flavour)
337 PF (SEC_COFF_SHARED, "SHARED");
338 PF (SEC_THREAD_LOCAL, "THREAD_LOCAL");
339
340 if ((section->flags & SEC_LINK_ONCE) != 0)
341 {
342 const char *ls;
343 struct coff_comdat_info *comdat;
344
345 switch (section->flags & SEC_LINK_DUPLICATES)
346 {
347 default:
348 abort ();
349 case SEC_LINK_DUPLICATES_DISCARD:
350 ls = "LINK_ONCE_DISCARD";
351 break;
352 case SEC_LINK_DUPLICATES_ONE_ONLY:
353 ls = "LINK_ONCE_ONE_ONLY";
354 break;
355 case SEC_LINK_DUPLICATES_SAME_SIZE:
356 ls = "LINK_ONCE_SAME_SIZE";
357 break;
358 case SEC_LINK_DUPLICATES_SAME_CONTENTS:
359 ls = "LINK_ONCE_SAME_CONTENTS";
360 break;
361 }
362 printf ("%s%s", comma, ls);
363
364 comdat = bfd_coff_get_comdat_section (abfd, section);
365 if (comdat != NULL)
366 printf (" (COMDAT %s %ld)", comdat->name, comdat->symbol);
367
368 comma = ", ";
369 }
370
371 printf ("\n");
372 #undef PF
373 }
374
375 static void
376 dump_headers (bfd *abfd)
377 {
378 printf (_("Sections:\n"));
379
380 #ifndef BFD64
381 printf (_("Idx Name Size VMA LMA File off Algn"));
382 #else
383 /* With BFD64, non-ELF returns -1 and wants always 64 bit addresses. */
384 if (bfd_get_arch_size (abfd) == 32)
385 printf (_("Idx Name Size VMA LMA File off Algn"));
386 else
387 printf (_("Idx Name Size VMA LMA File off Algn"));
388 #endif
389
390 if (wide_output)
391 printf (_(" Flags"));
392 if (abfd->flags & HAS_LOAD_PAGE)
393 printf (_(" Pg"));
394 printf ("\n");
395
396 bfd_map_over_sections (abfd, dump_section_header, NULL);
397 }
398 \f
399 static asymbol **
400 slurp_symtab (bfd *abfd)
401 {
402 asymbol **sy = NULL;
403 long storage;
404
405 if (!(bfd_get_file_flags (abfd) & HAS_SYMS))
406 {
407 symcount = 0;
408 return NULL;
409 }
410
411 storage = bfd_get_symtab_upper_bound (abfd);
412 if (storage < 0)
413 bfd_fatal (bfd_get_filename (abfd));
414 if (storage)
415 sy = xmalloc (storage);
416
417 symcount = bfd_canonicalize_symtab (abfd, sy);
418 if (symcount < 0)
419 bfd_fatal (bfd_get_filename (abfd));
420 return sy;
421 }
422
423 /* Read in the dynamic symbols. */
424
425 static asymbol **
426 slurp_dynamic_symtab (bfd *abfd)
427 {
428 asymbol **sy = NULL;
429 long storage;
430
431 storage = bfd_get_dynamic_symtab_upper_bound (abfd);
432 if (storage < 0)
433 {
434 if (!(bfd_get_file_flags (abfd) & DYNAMIC))
435 {
436 non_fatal (_("%s: not a dynamic object"), bfd_get_filename (abfd));
437 dynsymcount = 0;
438 return NULL;
439 }
440
441 bfd_fatal (bfd_get_filename (abfd));
442 }
443 if (storage)
444 sy = xmalloc (storage);
445
446 dynsymcount = bfd_canonicalize_dynamic_symtab (abfd, sy);
447 if (dynsymcount < 0)
448 bfd_fatal (bfd_get_filename (abfd));
449 return sy;
450 }
451
452 /* Filter out (in place) symbols that are useless for disassembly.
453 COUNT is the number of elements in SYMBOLS.
454 Return the number of useful symbols. */
455
456 static long
457 remove_useless_symbols (asymbol **symbols, long count)
458 {
459 asymbol **in_ptr = symbols, **out_ptr = symbols;
460
461 while (--count >= 0)
462 {
463 asymbol *sym = *in_ptr++;
464
465 if (sym->name == NULL || sym->name[0] == '\0')
466 continue;
467 if (sym->flags & (BSF_DEBUGGING | BSF_SECTION_SYM))
468 continue;
469 if (bfd_is_und_section (sym->section)
470 || bfd_is_com_section (sym->section))
471 continue;
472
473 *out_ptr++ = sym;
474 }
475 return out_ptr - symbols;
476 }
477
478 /* Sort symbols into value order. */
479
480 static int
481 compare_symbols (const void *ap, const void *bp)
482 {
483 const asymbol *a = * (const asymbol **) ap;
484 const asymbol *b = * (const asymbol **) bp;
485 const char *an;
486 const char *bn;
487 size_t anl;
488 size_t bnl;
489 bfd_boolean af;
490 bfd_boolean bf;
491 flagword aflags;
492 flagword bflags;
493
494 if (bfd_asymbol_value (a) > bfd_asymbol_value (b))
495 return 1;
496 else if (bfd_asymbol_value (a) < bfd_asymbol_value (b))
497 return -1;
498
499 if (a->section > b->section)
500 return 1;
501 else if (a->section < b->section)
502 return -1;
503
504 an = bfd_asymbol_name (a);
505 bn = bfd_asymbol_name (b);
506 anl = strlen (an);
507 bnl = strlen (bn);
508
509 /* The symbols gnu_compiled and gcc2_compiled convey no real
510 information, so put them after other symbols with the same value. */
511 af = (strstr (an, "gnu_compiled") != NULL
512 || strstr (an, "gcc2_compiled") != NULL);
513 bf = (strstr (bn, "gnu_compiled") != NULL
514 || strstr (bn, "gcc2_compiled") != NULL);
515
516 if (af && ! bf)
517 return 1;
518 if (! af && bf)
519 return -1;
520
521 /* We use a heuristic for the file name, to try to sort it after
522 more useful symbols. It may not work on non Unix systems, but it
523 doesn't really matter; the only difference is precisely which
524 symbol names get printed. */
525
526 #define file_symbol(s, sn, snl) \
527 (((s)->flags & BSF_FILE) != 0 \
528 || ((sn)[(snl) - 2] == '.' \
529 && ((sn)[(snl) - 1] == 'o' \
530 || (sn)[(snl) - 1] == 'a')))
531
532 af = file_symbol (a, an, anl);
533 bf = file_symbol (b, bn, bnl);
534
535 if (af && ! bf)
536 return 1;
537 if (! af && bf)
538 return -1;
539
540 /* Try to sort global symbols before local symbols before function
541 symbols before debugging symbols. */
542
543 aflags = a->flags;
544 bflags = b->flags;
545
546 if ((aflags & BSF_DEBUGGING) != (bflags & BSF_DEBUGGING))
547 {
548 if ((aflags & BSF_DEBUGGING) != 0)
549 return 1;
550 else
551 return -1;
552 }
553 if ((aflags & BSF_FUNCTION) != (bflags & BSF_FUNCTION))
554 {
555 if ((aflags & BSF_FUNCTION) != 0)
556 return -1;
557 else
558 return 1;
559 }
560 if ((aflags & BSF_LOCAL) != (bflags & BSF_LOCAL))
561 {
562 if ((aflags & BSF_LOCAL) != 0)
563 return 1;
564 else
565 return -1;
566 }
567 if ((aflags & BSF_GLOBAL) != (bflags & BSF_GLOBAL))
568 {
569 if ((aflags & BSF_GLOBAL) != 0)
570 return -1;
571 else
572 return 1;
573 }
574
575 /* Symbols that start with '.' might be section names, so sort them
576 after symbols that don't start with '.'. */
577 if (an[0] == '.' && bn[0] != '.')
578 return 1;
579 if (an[0] != '.' && bn[0] == '.')
580 return -1;
581
582 /* Finally, if we can't distinguish them in any other way, try to
583 get consistent results by sorting the symbols by name. */
584 return strcmp (an, bn);
585 }
586
587 /* Sort relocs into address order. */
588
589 static int
590 compare_relocs (const void *ap, const void *bp)
591 {
592 const arelent *a = * (const arelent **) ap;
593 const arelent *b = * (const arelent **) bp;
594
595 if (a->address > b->address)
596 return 1;
597 else if (a->address < b->address)
598 return -1;
599
600 /* So that associated relocations tied to the same address show up
601 in the correct order, we don't do any further sorting. */
602 if (a > b)
603 return 1;
604 else if (a < b)
605 return -1;
606 else
607 return 0;
608 }
609
610 /* Print an address (VMA) to the output stream in INFO.
611 If SKIP_ZEROES is TRUE, omit leading zeroes. */
612
613 static void
614 objdump_print_value (bfd_vma vma, struct disassemble_info *info,
615 bfd_boolean skip_zeroes)
616 {
617 char buf[30];
618 char *p;
619 struct objdump_disasm_info *aux;
620
621 aux = (struct objdump_disasm_info *) info->application_data;
622 bfd_sprintf_vma (aux->abfd, buf, vma);
623 if (! skip_zeroes)
624 p = buf;
625 else
626 {
627 for (p = buf; *p == '0'; ++p)
628 ;
629 if (*p == '\0')
630 --p;
631 }
632 (*info->fprintf_func) (info->stream, "%s", p);
633 }
634
635 /* Print the name of a symbol. */
636
637 static void
638 objdump_print_symname (bfd *abfd, struct disassemble_info *info,
639 asymbol *sym)
640 {
641 char *alloc;
642 const char *name;
643
644 alloc = NULL;
645 name = bfd_asymbol_name (sym);
646 if (do_demangle && name[0] != '\0')
647 {
648 /* Demangle the name. */
649 alloc = demangle (abfd, name);
650 name = alloc;
651 }
652
653 if (info != NULL)
654 (*info->fprintf_func) (info->stream, "%s", name);
655 else
656 printf ("%s", name);
657
658 if (alloc != NULL)
659 free (alloc);
660 }
661
662 /* Locate a symbol given a bfd and a section (from INFO->application_data),
663 and a VMA. If INFO->application_data->require_sec is TRUE, then always
664 require the symbol to be in the section. Returns NULL if there is no
665 suitable symbol. If PLACE is not NULL, then *PLACE is set to the index
666 of the symbol in sorted_syms. */
667
668 static asymbol *
669 find_symbol_for_address (bfd_vma vma,
670 struct disassemble_info *info,
671 long *place)
672 {
673 /* @@ Would it speed things up to cache the last two symbols returned,
674 and maybe their address ranges? For many processors, only one memory
675 operand can be present at a time, so the 2-entry cache wouldn't be
676 constantly churned by code doing heavy memory accesses. */
677
678 /* Indices in `sorted_syms'. */
679 long min = 0;
680 long max = sorted_symcount;
681 long thisplace;
682 struct objdump_disasm_info *aux;
683 bfd *abfd;
684 asection *sec;
685 unsigned int opb;
686
687 if (sorted_symcount < 1)
688 return NULL;
689
690 aux = (struct objdump_disasm_info *) info->application_data;
691 abfd = aux->abfd;
692 sec = aux->sec;
693 opb = bfd_octets_per_byte (abfd);
694
695 /* Perform a binary search looking for the closest symbol to the
696 required value. We are searching the range (min, max]. */
697 while (min + 1 < max)
698 {
699 asymbol *sym;
700
701 thisplace = (max + min) / 2;
702 sym = sorted_syms[thisplace];
703
704 if (bfd_asymbol_value (sym) > vma)
705 max = thisplace;
706 else if (bfd_asymbol_value (sym) < vma)
707 min = thisplace;
708 else
709 {
710 min = thisplace;
711 break;
712 }
713 }
714
715 /* The symbol we want is now in min, the low end of the range we
716 were searching. If there are several symbols with the same
717 value, we want the first one. */
718 thisplace = min;
719 while (thisplace > 0
720 && (bfd_asymbol_value (sorted_syms[thisplace])
721 == bfd_asymbol_value (sorted_syms[thisplace - 1])))
722 --thisplace;
723
724 /* If the file is relocatable, and the symbol could be from this
725 section, prefer a symbol from this section over symbols from
726 others, even if the other symbol's value might be closer.
727
728 Note that this may be wrong for some symbol references if the
729 sections have overlapping memory ranges, but in that case there's
730 no way to tell what's desired without looking at the relocation
731 table. */
732 if (sorted_syms[thisplace]->section != sec
733 && (aux->require_sec
734 || ((abfd->flags & HAS_RELOC) != 0
735 && vma >= bfd_get_section_vma (abfd, sec)
736 && vma < (bfd_get_section_vma (abfd, sec)
737 + bfd_section_size (abfd, sec) / opb))))
738 {
739 long i;
740
741 for (i = thisplace + 1; i < sorted_symcount; i++)
742 {
743 if (bfd_asymbol_value (sorted_syms[i])
744 != bfd_asymbol_value (sorted_syms[thisplace]))
745 break;
746 }
747
748 --i;
749
750 for (; i >= 0; i--)
751 {
752 if (sorted_syms[i]->section == sec
753 && (i == 0
754 || sorted_syms[i - 1]->section != sec
755 || (bfd_asymbol_value (sorted_syms[i])
756 != bfd_asymbol_value (sorted_syms[i - 1]))))
757 {
758 thisplace = i;
759 break;
760 }
761 }
762
763 if (sorted_syms[thisplace]->section != sec)
764 {
765 /* We didn't find a good symbol with a smaller value.
766 Look for one with a larger value. */
767 for (i = thisplace + 1; i < sorted_symcount; i++)
768 {
769 if (sorted_syms[i]->section == sec)
770 {
771 thisplace = i;
772 break;
773 }
774 }
775 }
776
777 if (sorted_syms[thisplace]->section != sec
778 && (aux->require_sec
779 || ((abfd->flags & HAS_RELOC) != 0
780 && vma >= bfd_get_section_vma (abfd, sec)
781 && vma < (bfd_get_section_vma (abfd, sec)
782 + bfd_section_size (abfd, sec)))))
783 /* There is no suitable symbol. */
784 return NULL;
785 }
786
787 /* Give the target a chance to reject the symbol. */
788 while (! info->symbol_is_valid (sorted_syms [thisplace], info))
789 {
790 ++ thisplace;
791 if (thisplace >= sorted_symcount
792 || bfd_asymbol_value (sorted_syms [thisplace]) > vma)
793 return NULL;
794 }
795
796 if (place != NULL)
797 *place = thisplace;
798
799 return sorted_syms[thisplace];
800 }
801
802 /* Print an address and the offset to the nearest symbol. */
803
804 static void
805 objdump_print_addr_with_sym (bfd *abfd, asection *sec, asymbol *sym,
806 bfd_vma vma, struct disassemble_info *info,
807 bfd_boolean skip_zeroes)
808 {
809 objdump_print_value (vma, info, skip_zeroes);
810
811 if (sym == NULL)
812 {
813 bfd_vma secaddr;
814
815 (*info->fprintf_func) (info->stream, " <%s",
816 bfd_get_section_name (abfd, sec));
817 secaddr = bfd_get_section_vma (abfd, sec);
818 if (vma < secaddr)
819 {
820 (*info->fprintf_func) (info->stream, "-0x");
821 objdump_print_value (secaddr - vma, info, TRUE);
822 }
823 else if (vma > secaddr)
824 {
825 (*info->fprintf_func) (info->stream, "+0x");
826 objdump_print_value (vma - secaddr, info, TRUE);
827 }
828 (*info->fprintf_func) (info->stream, ">");
829 }
830 else
831 {
832 (*info->fprintf_func) (info->stream, " <");
833 objdump_print_symname (abfd, info, sym);
834 if (bfd_asymbol_value (sym) > vma)
835 {
836 (*info->fprintf_func) (info->stream, "-0x");
837 objdump_print_value (bfd_asymbol_value (sym) - vma, info, TRUE);
838 }
839 else if (vma > bfd_asymbol_value (sym))
840 {
841 (*info->fprintf_func) (info->stream, "+0x");
842 objdump_print_value (vma - bfd_asymbol_value (sym), info, TRUE);
843 }
844 (*info->fprintf_func) (info->stream, ">");
845 }
846 }
847
848 /* Print an address (VMA), symbolically if possible.
849 If SKIP_ZEROES is TRUE, don't output leading zeroes. */
850
851 static void
852 objdump_print_addr (bfd_vma vma,
853 struct disassemble_info *info,
854 bfd_boolean skip_zeroes)
855 {
856 struct objdump_disasm_info *aux;
857 asymbol *sym;
858 #ifdef DISASSEMBLER_NEEDS_RELOCS
859 bfd_boolean skip_find = FALSE;
860 #endif
861
862 if (sorted_symcount < 1)
863 {
864 (*info->fprintf_func) (info->stream, "0x");
865 objdump_print_value (vma, info, skip_zeroes);
866 return;
867 }
868
869 aux = (struct objdump_disasm_info *) info->application_data;
870
871 #ifdef DISASSEMBLER_NEEDS_RELOCS
872 if (aux->reloc != NULL
873 && aux->reloc->sym_ptr_ptr != NULL
874 && * aux->reloc->sym_ptr_ptr != NULL)
875 {
876 sym = * aux->reloc->sym_ptr_ptr;
877
878 /* Adjust the vma to the reloc. */
879 vma += bfd_asymbol_value (sym);
880
881 if (bfd_is_und_section (bfd_get_section (sym)))
882 skip_find = TRUE;
883 }
884
885 if (!skip_find)
886 #endif
887 sym = find_symbol_for_address (vma, info, NULL);
888
889 objdump_print_addr_with_sym (aux->abfd, aux->sec, sym, vma, info,
890 skip_zeroes);
891 }
892
893 /* Print VMA to INFO. This function is passed to the disassembler
894 routine. */
895
896 static void
897 objdump_print_address (bfd_vma vma, struct disassemble_info *info)
898 {
899 objdump_print_addr (vma, info, ! prefix_addresses);
900 }
901
902 /* Determine of the given address has a symbol associated with it. */
903
904 static int
905 objdump_symbol_at_address (bfd_vma vma, struct disassemble_info * info)
906 {
907 asymbol * sym;
908
909 sym = find_symbol_for_address (vma, info, NULL);
910
911 return (sym != NULL && (bfd_asymbol_value (sym) == vma));
912 }
913
914 /* Hold the last function name and the last line number we displayed
915 in a disassembly. */
916
917 static char *prev_functionname;
918 static unsigned int prev_line;
919
920 /* We keep a list of all files that we have seen when doing a
921 disassembly with source, so that we know how much of the file to
922 display. This can be important for inlined functions. */
923
924 struct print_file_list
925 {
926 struct print_file_list *next;
927 const char *filename;
928 const char *modname;
929 unsigned int line;
930 FILE *f;
931 };
932
933 static struct print_file_list *print_files;
934
935 /* The number of preceding context lines to show when we start
936 displaying a file for the first time. */
937
938 #define SHOW_PRECEDING_CONTEXT_LINES (5)
939
940 /* Tries to open MODNAME, and if successful adds a node to print_files
941 linked list and returns that node. Returns NULL on failure. */
942
943 static struct print_file_list *
944 try_print_file_open (const char *origname, const char *modname)
945 {
946 struct print_file_list *p;
947 FILE *f;
948
949 f = fopen (modname, "r");
950 if (f == NULL)
951 return NULL;
952
953 if (print_files != NULL && print_files->f != NULL)
954 {
955 fclose (print_files->f);
956 print_files->f = NULL;
957 }
958
959 p = xmalloc (sizeof (struct print_file_list));
960 p->filename = origname;
961 p->modname = modname;
962 p->line = 0;
963 p->f = f;
964 p->next = print_files;
965 print_files = p;
966 return p;
967 }
968
969 /* If the the source file, as described in the symtab, is not found
970 try to locate it in one of the paths specified with -I
971 If found, add location to print_files linked list. */
972
973 static struct print_file_list *
974 update_source_path (const char *filename)
975 {
976 struct print_file_list *p;
977 const char *fname;
978 int i;
979
980 if (filename == NULL)
981 return NULL;
982
983 p = try_print_file_open (filename, filename);
984 if (p != NULL)
985 return p;
986
987 if (include_path_count == 0)
988 return NULL;
989
990 /* Get the name of the file. */
991 fname = strrchr (filename, '/');
992 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
993 {
994 /* We could have a mixed forward/back slash case. */
995 char *backslash = strrchr (filename, '\\');
996 if (fname == NULL || (backslash != NULL && backslash > fname))
997 fname = backslash;
998 if (fname == NULL && filename[0] != '\0' && filename[1] == ':')
999 fname = filename + 1;
1000 }
1001 #endif
1002 if (fname == NULL)
1003 fname = filename;
1004 else
1005 ++fname;
1006
1007 /* If file exists under a new path, we need to add it to the list
1008 so that show_line knows about it. */
1009 for (i = 0; i < include_path_count; i++)
1010 {
1011 char *modname = concat (include_paths[i], "/", fname, (const char *) 0);
1012
1013 p = try_print_file_open (filename, modname);
1014 if (p)
1015 return p;
1016
1017 free (modname);
1018 }
1019
1020 return NULL;
1021 }
1022
1023 /* Skip ahead to a given line in a file, optionally printing each
1024 line. */
1025
1026 static void
1027 skip_to_line (struct print_file_list *p, unsigned int line,
1028 bfd_boolean show)
1029 {
1030 while (p->line < line)
1031 {
1032 char buf[100];
1033
1034 if (fgets (buf, sizeof buf, p->f) == NULL)
1035 {
1036 fclose (p->f);
1037 p->f = NULL;
1038 break;
1039 }
1040
1041 if (show)
1042 printf ("%s", buf);
1043
1044 if (strchr (buf, '\n') != NULL)
1045 ++p->line;
1046 }
1047 }
1048
1049 /* Show the line number, or the source line, in a disassembly
1050 listing. */
1051
1052 static void
1053 show_line (bfd *abfd, asection *section, bfd_vma addr_offset)
1054 {
1055 const char *filename;
1056 const char *functionname;
1057 unsigned int line;
1058
1059 if (! with_line_numbers && ! with_source_code)
1060 return;
1061
1062 if (! bfd_find_nearest_line (abfd, section, syms, addr_offset, &filename,
1063 &functionname, &line))
1064 return;
1065
1066 if (filename != NULL && *filename == '\0')
1067 filename = NULL;
1068 if (functionname != NULL && *functionname == '\0')
1069 functionname = NULL;
1070
1071 if (with_line_numbers)
1072 {
1073 if (functionname != NULL
1074 && (prev_functionname == NULL
1075 || strcmp (functionname, prev_functionname) != 0))
1076 printf ("%s():\n", functionname);
1077 if (line > 0 && line != prev_line)
1078 printf ("%s:%u\n", filename == NULL ? "???" : filename, line);
1079 }
1080
1081 if (with_source_code
1082 && filename != NULL
1083 && line > 0)
1084 {
1085 struct print_file_list **pp, *p;
1086
1087 for (pp = &print_files; *pp != NULL; pp = &(*pp)->next)
1088 if (strcmp ((*pp)->filename, filename) == 0)
1089 break;
1090 p = *pp;
1091
1092 if (p != NULL)
1093 {
1094 if (p != print_files)
1095 {
1096 int l;
1097
1098 /* We have reencountered a file name which we saw
1099 earlier. This implies that either we are dumping out
1100 code from an included file, or the same file was
1101 linked in more than once. There are two common cases
1102 of an included file: inline functions in a header
1103 file, and a bison or flex skeleton file. In the
1104 former case we want to just start printing (but we
1105 back up a few lines to give context); in the latter
1106 case we want to continue from where we left off. I
1107 can't think of a good way to distinguish the cases,
1108 so I used a heuristic based on the file name. */
1109 if (strcmp (p->filename + strlen (p->filename) - 2, ".h") != 0)
1110 l = p->line;
1111 else
1112 {
1113 l = line - SHOW_PRECEDING_CONTEXT_LINES;
1114 if (l < 0)
1115 l = 0;
1116 }
1117
1118 if (p->f == NULL)
1119 {
1120 p->f = fopen (p->modname, "r");
1121 p->line = 0;
1122 }
1123 if (p->f != NULL)
1124 skip_to_line (p, l, FALSE);
1125
1126 if (print_files->f != NULL)
1127 {
1128 fclose (print_files->f);
1129 print_files->f = NULL;
1130 }
1131 }
1132
1133 if (p->f != NULL)
1134 {
1135 skip_to_line (p, line, TRUE);
1136 *pp = p->next;
1137 p->next = print_files;
1138 print_files = p;
1139 }
1140 }
1141 else
1142 {
1143 p = update_source_path (filename);
1144
1145 if (p != NULL)
1146 {
1147 int l;
1148
1149 if (file_start_context)
1150 l = 0;
1151 else
1152 l = line - SHOW_PRECEDING_CONTEXT_LINES;
1153 if (l < 0)
1154 l = 0;
1155 skip_to_line (p, l, FALSE);
1156 if (p->f != NULL)
1157 skip_to_line (p, line, TRUE);
1158 }
1159 }
1160 }
1161
1162 if (functionname != NULL
1163 && (prev_functionname == NULL
1164 || strcmp (functionname, prev_functionname) != 0))
1165 {
1166 if (prev_functionname != NULL)
1167 free (prev_functionname);
1168 prev_functionname = xmalloc (strlen (functionname) + 1);
1169 strcpy (prev_functionname, functionname);
1170 }
1171
1172 if (line > 0 && line != prev_line)
1173 prev_line = line;
1174 }
1175
1176 /* Pseudo FILE object for strings. */
1177 typedef struct
1178 {
1179 char *buffer;
1180 size_t pos;
1181 size_t alloc;
1182 } SFILE;
1183
1184 /* sprintf to a "stream". */
1185
1186 static int
1187 objdump_sprintf (SFILE *f, const char *format, ...)
1188 {
1189 size_t n;
1190 va_list args;
1191
1192 while (1)
1193 {
1194 size_t space = f->alloc - f->pos;
1195
1196 va_start (args, format);
1197 n = vsnprintf (f->buffer + f->pos, space, format, args);
1198 va_end (args);
1199
1200 if (space > n)
1201 break;
1202
1203 f->alloc = (f->alloc + n) * 2;
1204 f->buffer = xrealloc (f->buffer, f->alloc);
1205 }
1206 f->pos += n;
1207
1208 return n;
1209 }
1210
1211 /* Returns TRUE if the specified section should be dumped. */
1212
1213 static bfd_boolean
1214 process_section_p (asection * section)
1215 {
1216 size_t i;
1217
1218 if (only == NULL)
1219 return TRUE;
1220
1221 for (i = 0; i < only_used; i++)
1222 if (strcmp (only [i], section->name) == 0)
1223 return TRUE;
1224
1225 return FALSE;
1226 }
1227
1228
1229 /* The number of zeroes we want to see before we start skipping them.
1230 The number is arbitrarily chosen. */
1231
1232 #define DEFAULT_SKIP_ZEROES 8
1233
1234 /* The number of zeroes to skip at the end of a section. If the
1235 number of zeroes at the end is between SKIP_ZEROES_AT_END and
1236 SKIP_ZEROES, they will be disassembled. If there are fewer than
1237 SKIP_ZEROES_AT_END, they will be skipped. This is a heuristic
1238 attempt to avoid disassembling zeroes inserted by section
1239 alignment. */
1240
1241 #define DEFAULT_SKIP_ZEROES_AT_END 3
1242
1243 /* Disassemble some data in memory between given values. */
1244
1245 static void
1246 disassemble_bytes (struct disassemble_info * info,
1247 disassembler_ftype disassemble_fn,
1248 bfd_boolean insns,
1249 bfd_byte * data,
1250 bfd_vma start_offset,
1251 bfd_vma stop_offset,
1252 bfd_vma rel_offset,
1253 arelent *** relppp,
1254 arelent ** relppend)
1255 {
1256 struct objdump_disasm_info *aux;
1257 asection *section;
1258 int octets_per_line;
1259 bfd_boolean done_dot;
1260 int skip_addr_chars;
1261 bfd_vma addr_offset;
1262 unsigned int opb = info->octets_per_byte;
1263 unsigned int skip_zeroes = info->skip_zeroes;
1264 unsigned int skip_zeroes_at_end = info->skip_zeroes_at_end;
1265 int octets = opb;
1266 SFILE sfile;
1267
1268 aux = (struct objdump_disasm_info *) info->application_data;
1269 section = aux->sec;
1270
1271 sfile.alloc = 120;
1272 sfile.buffer = xmalloc (sfile.alloc);
1273 sfile.pos = 0;
1274
1275 if (insns)
1276 octets_per_line = 4;
1277 else
1278 octets_per_line = 16;
1279
1280 /* Figure out how many characters to skip at the start of an
1281 address, to make the disassembly look nicer. We discard leading
1282 zeroes in chunks of 4, ensuring that there is always a leading
1283 zero remaining. */
1284 skip_addr_chars = 0;
1285 if (! prefix_addresses)
1286 {
1287 char buf[30];
1288 char *s;
1289
1290 bfd_sprintf_vma
1291 (aux->abfd, buf,
1292 (section->vma
1293 + bfd_section_size (section->owner, section) / opb));
1294 s = buf;
1295 while (s[0] == '0' && s[1] == '0' && s[2] == '0' && s[3] == '0'
1296 && s[4] == '0')
1297 {
1298 skip_addr_chars += 4;
1299 s += 4;
1300 }
1301 }
1302
1303 info->insn_info_valid = 0;
1304
1305 done_dot = FALSE;
1306 addr_offset = start_offset;
1307 while (addr_offset < stop_offset)
1308 {
1309 bfd_vma z;
1310 bfd_boolean need_nl = FALSE;
1311 #ifdef DISASSEMBLER_NEEDS_RELOCS
1312 int previous_octets;
1313
1314 /* Remember the length of the previous instruction. */
1315 previous_octets = octets;
1316 #endif
1317 octets = 0;
1318
1319 /* If we see more than SKIP_ZEROES octets of zeroes, we just
1320 print `...'. */
1321 for (z = addr_offset * opb; z < stop_offset * opb; z++)
1322 if (data[z] != 0)
1323 break;
1324 if (! disassemble_zeroes
1325 && (info->insn_info_valid == 0
1326 || info->branch_delay_insns == 0)
1327 && (z - addr_offset * opb >= skip_zeroes
1328 || (z == stop_offset * opb &&
1329 z - addr_offset * opb < skip_zeroes_at_end)))
1330 {
1331 printf ("\t...\n");
1332
1333 /* If there are more nonzero octets to follow, we only skip
1334 zeroes in multiples of 4, to try to avoid running over
1335 the start of an instruction which happens to start with
1336 zero. */
1337 if (z != stop_offset * opb)
1338 z = addr_offset * opb + ((z - addr_offset * opb) &~ 3);
1339
1340 octets = z - addr_offset * opb;
1341 }
1342 else
1343 {
1344 char buf[50];
1345 int bpc = 0;
1346 int pb = 0;
1347
1348 done_dot = FALSE;
1349
1350 if (with_line_numbers || with_source_code)
1351 /* The line number tables will refer to unadjusted
1352 section VMAs, so we must undo any VMA modifications
1353 when calling show_line. */
1354 show_line (aux->abfd, section, addr_offset - adjust_section_vma);
1355
1356 if (! prefix_addresses)
1357 {
1358 char *s;
1359
1360 bfd_sprintf_vma (aux->abfd, buf, section->vma + addr_offset);
1361 for (s = buf + skip_addr_chars; *s == '0'; s++)
1362 *s = ' ';
1363 if (*s == '\0')
1364 *--s = '0';
1365 printf ("%s:\t", buf + skip_addr_chars);
1366 }
1367 else
1368 {
1369 aux->require_sec = TRUE;
1370 objdump_print_address (section->vma + addr_offset, info);
1371 aux->require_sec = FALSE;
1372 putchar (' ');
1373 }
1374
1375 if (insns)
1376 {
1377 sfile.pos = 0;
1378 info->fprintf_func = (fprintf_ftype) objdump_sprintf;
1379 info->stream = (FILE *) &sfile;
1380 info->bytes_per_line = 0;
1381 info->bytes_per_chunk = 0;
1382 info->flags = 0;
1383
1384 #ifdef DISASSEMBLER_NEEDS_RELOCS
1385 if (*relppp < relppend)
1386 {
1387 bfd_signed_vma distance_to_rel;
1388
1389 distance_to_rel = (**relppp)->address
1390 - (rel_offset + addr_offset);
1391
1392 /* Check to see if the current reloc is associated with
1393 the instruction that we are about to disassemble. */
1394 if (distance_to_rel == 0
1395 /* FIXME: This is wrong. We are trying to catch
1396 relocs that are addressed part way through the
1397 current instruction, as might happen with a packed
1398 VLIW instruction. Unfortunately we do not know the
1399 length of the current instruction since we have not
1400 disassembled it yet. Instead we take a guess based
1401 upon the length of the previous instruction. The
1402 proper solution is to have a new target-specific
1403 disassembler function which just returns the length
1404 of an instruction at a given address without trying
1405 to display its disassembly. */
1406 || (distance_to_rel > 0
1407 && distance_to_rel < (bfd_signed_vma) (previous_octets/ opb)))
1408 {
1409 info->flags = INSN_HAS_RELOC;
1410 aux->reloc = **relppp;
1411 }
1412 else
1413 aux->reloc = NULL;
1414 }
1415 #endif
1416 octets = (*disassemble_fn) (section->vma + addr_offset, info);
1417 info->fprintf_func = (fprintf_ftype) fprintf;
1418 info->stream = stdout;
1419 if (info->bytes_per_line != 0)
1420 octets_per_line = info->bytes_per_line;
1421 if (octets < 0)
1422 {
1423 if (sfile.pos)
1424 printf ("%s\n", sfile.buffer);
1425 break;
1426 }
1427 }
1428 else
1429 {
1430 bfd_vma j;
1431
1432 octets = octets_per_line;
1433 if (addr_offset + octets / opb > stop_offset)
1434 octets = (stop_offset - addr_offset) * opb;
1435
1436 for (j = addr_offset * opb; j < addr_offset * opb + octets; ++j)
1437 {
1438 if (ISPRINT (data[j]))
1439 buf[j - addr_offset * opb] = data[j];
1440 else
1441 buf[j - addr_offset * opb] = '.';
1442 }
1443 buf[j - addr_offset * opb] = '\0';
1444 }
1445
1446 if (prefix_addresses
1447 ? show_raw_insn > 0
1448 : show_raw_insn >= 0)
1449 {
1450 bfd_vma j;
1451
1452 /* If ! prefix_addresses and ! wide_output, we print
1453 octets_per_line octets per line. */
1454 pb = octets;
1455 if (pb > octets_per_line && ! prefix_addresses && ! wide_output)
1456 pb = octets_per_line;
1457
1458 if (info->bytes_per_chunk)
1459 bpc = info->bytes_per_chunk;
1460 else
1461 bpc = 1;
1462
1463 for (j = addr_offset * opb; j < addr_offset * opb + pb; j += bpc)
1464 {
1465 int k;
1466
1467 if (bpc > 1 && info->display_endian == BFD_ENDIAN_LITTLE)
1468 {
1469 for (k = bpc - 1; k >= 0; k--)
1470 printf ("%02x", (unsigned) data[j + k]);
1471 putchar (' ');
1472 }
1473 else
1474 {
1475 for (k = 0; k < bpc; k++)
1476 printf ("%02x", (unsigned) data[j + k]);
1477 putchar (' ');
1478 }
1479 }
1480
1481 for (; pb < octets_per_line; pb += bpc)
1482 {
1483 int k;
1484
1485 for (k = 0; k < bpc; k++)
1486 printf (" ");
1487 putchar (' ');
1488 }
1489
1490 /* Separate raw data from instruction by extra space. */
1491 if (insns)
1492 putchar ('\t');
1493 else
1494 printf (" ");
1495 }
1496
1497 if (! insns)
1498 printf ("%s", buf);
1499 else if (sfile.pos)
1500 printf ("%s", sfile.buffer);
1501
1502 if (prefix_addresses
1503 ? show_raw_insn > 0
1504 : show_raw_insn >= 0)
1505 {
1506 while (pb < octets)
1507 {
1508 bfd_vma j;
1509 char *s;
1510
1511 putchar ('\n');
1512 j = addr_offset * opb + pb;
1513
1514 bfd_sprintf_vma (aux->abfd, buf, section->vma + j / opb);
1515 for (s = buf + skip_addr_chars; *s == '0'; s++)
1516 *s = ' ';
1517 if (*s == '\0')
1518 *--s = '0';
1519 printf ("%s:\t", buf + skip_addr_chars);
1520
1521 pb += octets_per_line;
1522 if (pb > octets)
1523 pb = octets;
1524 for (; j < addr_offset * opb + pb; j += bpc)
1525 {
1526 int k;
1527
1528 if (bpc > 1 && info->display_endian == BFD_ENDIAN_LITTLE)
1529 {
1530 for (k = bpc - 1; k >= 0; k--)
1531 printf ("%02x", (unsigned) data[j + k]);
1532 putchar (' ');
1533 }
1534 else
1535 {
1536 for (k = 0; k < bpc; k++)
1537 printf ("%02x", (unsigned) data[j + k]);
1538 putchar (' ');
1539 }
1540 }
1541 }
1542 }
1543
1544 if (!wide_output)
1545 putchar ('\n');
1546 else
1547 need_nl = TRUE;
1548 }
1549
1550 while ((*relppp) < relppend
1551 && (**relppp)->address < rel_offset + addr_offset + octets / opb)
1552 {
1553 if (dump_reloc_info || dump_dynamic_reloc_info)
1554 {
1555 arelent *q;
1556
1557 q = **relppp;
1558
1559 if (wide_output)
1560 putchar ('\t');
1561 else
1562 printf ("\t\t\t");
1563
1564 objdump_print_value (section->vma - rel_offset + q->address,
1565 info, TRUE);
1566
1567 printf (": %s\t", q->howto->name);
1568
1569 if (q->sym_ptr_ptr == NULL || *q->sym_ptr_ptr == NULL)
1570 printf ("*unknown*");
1571 else
1572 {
1573 const char *sym_name;
1574
1575 sym_name = bfd_asymbol_name (*q->sym_ptr_ptr);
1576 if (sym_name != NULL && *sym_name != '\0')
1577 objdump_print_symname (aux->abfd, info, *q->sym_ptr_ptr);
1578 else
1579 {
1580 asection *sym_sec;
1581
1582 sym_sec = bfd_get_section (*q->sym_ptr_ptr);
1583 sym_name = bfd_get_section_name (aux->abfd, sym_sec);
1584 if (sym_name == NULL || *sym_name == '\0')
1585 sym_name = "*unknown*";
1586 printf ("%s", sym_name);
1587 }
1588 }
1589
1590 if (q->addend)
1591 {
1592 printf ("+0x");
1593 objdump_print_value (q->addend, info, TRUE);
1594 }
1595
1596 printf ("\n");
1597 need_nl = FALSE;
1598 }
1599 ++(*relppp);
1600 }
1601
1602 if (need_nl)
1603 printf ("\n");
1604
1605 addr_offset += octets / opb;
1606 }
1607
1608 free (sfile.buffer);
1609 }
1610
1611 static void
1612 disassemble_section (bfd *abfd, asection *section, void *info)
1613 {
1614 struct disassemble_info * pinfo = (struct disassemble_info *) info;
1615 struct objdump_disasm_info * paux;
1616 unsigned int opb = pinfo->octets_per_byte;
1617 bfd_byte * data = NULL;
1618 bfd_size_type datasize = 0;
1619 arelent ** rel_pp = NULL;
1620 arelent ** rel_ppstart = NULL;
1621 arelent ** rel_ppend;
1622 unsigned long stop_offset;
1623 asymbol * sym = NULL;
1624 long place = 0;
1625 long rel_count;
1626 bfd_vma rel_offset;
1627 unsigned long addr_offset;
1628
1629 /* Sections that do not contain machine
1630 code are not normally disassembled. */
1631 if (! disassemble_all
1632 && only == NULL
1633 && ((section->flags & (SEC_CODE | SEC_HAS_CONTENTS))
1634 != (SEC_CODE | SEC_HAS_CONTENTS)))
1635 return;
1636
1637 if (! process_section_p (section))
1638 return;
1639
1640 datasize = bfd_get_section_size (section);
1641 if (datasize == 0)
1642 return;
1643
1644 /* Decide which set of relocs to use. Load them if necessary. */
1645 paux = (struct objdump_disasm_info *) pinfo->application_data;
1646 if (paux->dynrelbuf)
1647 {
1648 rel_pp = paux->dynrelbuf;
1649 rel_count = paux->dynrelcount;
1650 /* Dynamic reloc addresses are absolute, non-dynamic are section
1651 relative. REL_OFFSET specifies the reloc address corresponding
1652 to the start of this section. */
1653 rel_offset = section->vma;
1654 }
1655 else
1656 {
1657 rel_count = 0;
1658 rel_pp = NULL;
1659 rel_offset = 0;
1660
1661 if ((section->flags & SEC_RELOC) != 0
1662 #ifndef DISASSEMBLER_NEEDS_RELOCS
1663 && dump_reloc_info
1664 #endif
1665 )
1666 {
1667 long relsize;
1668
1669 relsize = bfd_get_reloc_upper_bound (abfd, section);
1670 if (relsize < 0)
1671 bfd_fatal (bfd_get_filename (abfd));
1672
1673 if (relsize > 0)
1674 {
1675 rel_ppstart = rel_pp = xmalloc (relsize);
1676 rel_count = bfd_canonicalize_reloc (abfd, section, rel_pp, syms);
1677 if (rel_count < 0)
1678 bfd_fatal (bfd_get_filename (abfd));
1679
1680 /* Sort the relocs by address. */
1681 qsort (rel_pp, rel_count, sizeof (arelent *), compare_relocs);
1682 }
1683 }
1684
1685 }
1686 rel_ppend = rel_pp + rel_count;
1687
1688 data = xmalloc (datasize);
1689
1690 bfd_get_section_contents (abfd, section, data, 0, datasize);
1691
1692 paux->sec = section;
1693 pinfo->buffer = data;
1694 pinfo->buffer_vma = section->vma;
1695 pinfo->buffer_length = datasize;
1696 pinfo->section = section;
1697
1698 if (start_address == (bfd_vma) -1
1699 || start_address < pinfo->buffer_vma)
1700 addr_offset = 0;
1701 else
1702 addr_offset = start_address - pinfo->buffer_vma;
1703
1704 if (stop_address == (bfd_vma) -1)
1705 stop_offset = datasize / opb;
1706 else
1707 {
1708 if (stop_address < pinfo->buffer_vma)
1709 stop_offset = 0;
1710 else
1711 stop_offset = stop_address - pinfo->buffer_vma;
1712 if (stop_offset > pinfo->buffer_length / opb)
1713 stop_offset = pinfo->buffer_length / opb;
1714 }
1715
1716 /* Skip over the relocs belonging to addresses below the
1717 start address. */
1718 while (rel_pp < rel_ppend
1719 && (*rel_pp)->address < rel_offset + addr_offset)
1720 ++rel_pp;
1721
1722 printf (_("Disassembly of section %s:\n"), section->name);
1723
1724 /* Find the nearest symbol forwards from our current position. */
1725 paux->require_sec = TRUE;
1726 sym = find_symbol_for_address (section->vma + addr_offset, info, &place);
1727 paux->require_sec = FALSE;
1728
1729 /* Disassemble a block of instructions up to the address associated with
1730 the symbol we have just found. Then print the symbol and find the
1731 next symbol on. Repeat until we have disassembled the entire section
1732 or we have reached the end of the address range we are interested in. */
1733 while (addr_offset < stop_offset)
1734 {
1735 bfd_vma addr;
1736 asymbol *nextsym;
1737 unsigned long nextstop_offset;
1738 bfd_boolean insns;
1739
1740 addr = section->vma + addr_offset;
1741
1742 if (sym != NULL && bfd_asymbol_value (sym) <= addr)
1743 {
1744 int x;
1745
1746 for (x = place;
1747 (x < sorted_symcount
1748 && (bfd_asymbol_value (sorted_syms[x]) <= addr));
1749 ++x)
1750 continue;
1751
1752 pinfo->symbols = sorted_syms + place;
1753 pinfo->num_symbols = x - place;
1754 }
1755 else
1756 {
1757 pinfo->symbols = NULL;
1758 pinfo->num_symbols = 0;
1759 }
1760
1761 if (! prefix_addresses)
1762 {
1763 pinfo->fprintf_func (pinfo->stream, "\n");
1764 objdump_print_addr_with_sym (abfd, section, sym, addr,
1765 pinfo, FALSE);
1766 pinfo->fprintf_func (pinfo->stream, ":\n");
1767 }
1768
1769 if (sym != NULL && bfd_asymbol_value (sym) > addr)
1770 nextsym = sym;
1771 else if (sym == NULL)
1772 nextsym = NULL;
1773 else
1774 {
1775 #define is_valid_next_sym(SYM) \
1776 ((SYM)->section == section \
1777 && (bfd_asymbol_value (SYM) > bfd_asymbol_value (sym)) \
1778 && pinfo->symbol_is_valid (SYM, pinfo))
1779
1780 /* Search forward for the next appropriate symbol in
1781 SECTION. Note that all the symbols are sorted
1782 together into one big array, and that some sections
1783 may have overlapping addresses. */
1784 while (place < sorted_symcount
1785 && ! is_valid_next_sym (sorted_syms [place]))
1786 ++place;
1787
1788 if (place >= sorted_symcount)
1789 nextsym = NULL;
1790 else
1791 nextsym = sorted_syms[place];
1792 }
1793
1794 if (sym != NULL && bfd_asymbol_value (sym) > addr)
1795 nextstop_offset = bfd_asymbol_value (sym) - section->vma;
1796 else if (nextsym == NULL)
1797 nextstop_offset = stop_offset;
1798 else
1799 nextstop_offset = bfd_asymbol_value (nextsym) - section->vma;
1800
1801 if (nextstop_offset > stop_offset)
1802 nextstop_offset = stop_offset;
1803
1804 /* If a symbol is explicitly marked as being an object
1805 rather than a function, just dump the bytes without
1806 disassembling them. */
1807 if (disassemble_all
1808 || sym == NULL
1809 || bfd_asymbol_value (sym) > addr
1810 || ((sym->flags & BSF_OBJECT) == 0
1811 && (strstr (bfd_asymbol_name (sym), "gnu_compiled")
1812 == NULL)
1813 && (strstr (bfd_asymbol_name (sym), "gcc2_compiled")
1814 == NULL))
1815 || (sym->flags & BSF_FUNCTION) != 0)
1816 insns = TRUE;
1817 else
1818 insns = FALSE;
1819
1820 disassemble_bytes (pinfo, paux->disassemble_fn, insns, data,
1821 addr_offset, nextstop_offset,
1822 rel_offset, &rel_pp, rel_ppend);
1823
1824 addr_offset = nextstop_offset;
1825 sym = nextsym;
1826 }
1827
1828 free (data);
1829
1830 if (rel_ppstart != NULL)
1831 free (rel_ppstart);
1832 }
1833
1834 /* Disassemble the contents of an object file. */
1835
1836 static void
1837 disassemble_data (bfd *abfd)
1838 {
1839 struct disassemble_info disasm_info;
1840 struct objdump_disasm_info aux;
1841 long i;
1842
1843 print_files = NULL;
1844 prev_functionname = NULL;
1845 prev_line = -1;
1846
1847 /* We make a copy of syms to sort. We don't want to sort syms
1848 because that will screw up the relocs. */
1849 sorted_symcount = symcount ? symcount : dynsymcount;
1850 sorted_syms = xmalloc ((sorted_symcount + synthcount) * sizeof (asymbol *));
1851 memcpy (sorted_syms, symcount ? syms : dynsyms,
1852 sorted_symcount * sizeof (asymbol *));
1853
1854 sorted_symcount = remove_useless_symbols (sorted_syms, sorted_symcount);
1855
1856 for (i = 0; i < synthcount; ++i)
1857 {
1858 sorted_syms[sorted_symcount] = synthsyms + i;
1859 ++sorted_symcount;
1860 }
1861
1862 /* Sort the symbols into section and symbol order. */
1863 qsort (sorted_syms, sorted_symcount, sizeof (asymbol *), compare_symbols);
1864
1865 init_disassemble_info (&disasm_info, stdout, (fprintf_ftype) fprintf);
1866
1867 disasm_info.application_data = (void *) &aux;
1868 aux.abfd = abfd;
1869 aux.require_sec = FALSE;
1870 aux.dynrelbuf = NULL;
1871 aux.dynrelcount = 0;
1872 #ifdef DISASSEMBLER_NEEDS_RELOCS
1873 aux.reloc = NULL;
1874 #endif
1875
1876 disasm_info.print_address_func = objdump_print_address;
1877 disasm_info.symbol_at_address_func = objdump_symbol_at_address;
1878
1879 if (machine != NULL)
1880 {
1881 const bfd_arch_info_type *info = bfd_scan_arch (machine);
1882
1883 if (info == NULL)
1884 fatal (_("Can't use supplied machine %s"), machine);
1885
1886 abfd->arch_info = info;
1887 }
1888
1889 if (endian != BFD_ENDIAN_UNKNOWN)
1890 {
1891 struct bfd_target *xvec;
1892
1893 xvec = xmalloc (sizeof (struct bfd_target));
1894 memcpy (xvec, abfd->xvec, sizeof (struct bfd_target));
1895 xvec->byteorder = endian;
1896 abfd->xvec = xvec;
1897 }
1898
1899 /* Use libopcodes to locate a suitable disassembler. */
1900 aux.disassemble_fn = disassembler (abfd);
1901 if (!aux.disassemble_fn)
1902 {
1903 non_fatal (_("Can't disassemble for architecture %s\n"),
1904 bfd_printable_arch_mach (bfd_get_arch (abfd), 0));
1905 exit_status = 1;
1906 return;
1907 }
1908
1909 disasm_info.flavour = bfd_get_flavour (abfd);
1910 disasm_info.arch = bfd_get_arch (abfd);
1911 disasm_info.mach = bfd_get_mach (abfd);
1912 disasm_info.disassembler_options = disassembler_options;
1913 disasm_info.octets_per_byte = bfd_octets_per_byte (abfd);
1914 disasm_info.skip_zeroes = DEFAULT_SKIP_ZEROES;
1915 disasm_info.skip_zeroes_at_end = DEFAULT_SKIP_ZEROES_AT_END;
1916
1917 if (bfd_big_endian (abfd))
1918 disasm_info.display_endian = disasm_info.endian = BFD_ENDIAN_BIG;
1919 else if (bfd_little_endian (abfd))
1920 disasm_info.display_endian = disasm_info.endian = BFD_ENDIAN_LITTLE;
1921 else
1922 /* ??? Aborting here seems too drastic. We could default to big or little
1923 instead. */
1924 disasm_info.endian = BFD_ENDIAN_UNKNOWN;
1925
1926 /* Allow the target to customize the info structure. */
1927 disassemble_init_for_target (& disasm_info);
1928
1929 /* Pre-load the dynamic relocs if we are going
1930 to be dumping them along with the disassembly. */
1931 if (dump_dynamic_reloc_info)
1932 {
1933 long relsize = bfd_get_dynamic_reloc_upper_bound (abfd);
1934
1935 if (relsize < 0)
1936 bfd_fatal (bfd_get_filename (abfd));
1937
1938 if (relsize > 0)
1939 {
1940 aux.dynrelbuf = xmalloc (relsize);
1941 aux.dynrelcount = bfd_canonicalize_dynamic_reloc (abfd,
1942 aux.dynrelbuf,
1943 dynsyms);
1944 if (aux.dynrelcount < 0)
1945 bfd_fatal (bfd_get_filename (abfd));
1946
1947 /* Sort the relocs by address. */
1948 qsort (aux.dynrelbuf, aux.dynrelcount, sizeof (arelent *),
1949 compare_relocs);
1950 }
1951 }
1952
1953 bfd_map_over_sections (abfd, disassemble_section, & disasm_info);
1954
1955 if (aux.dynrelbuf != NULL)
1956 free (aux.dynrelbuf);
1957 free (sorted_syms);
1958 }
1959 \f
1960 /* Read ABFD's stabs section STABSECT_NAME, and return a pointer to
1961 it. Return NULL on failure. */
1962
1963 static char *
1964 read_section_stabs (bfd *abfd, const char *sect_name, bfd_size_type *size_ptr)
1965 {
1966 asection *stabsect;
1967 bfd_size_type size;
1968 char *contents;
1969
1970 stabsect = bfd_get_section_by_name (abfd, sect_name);
1971 if (stabsect == NULL)
1972 {
1973 printf (_("No %s section present\n\n"), sect_name);
1974 return FALSE;
1975 }
1976
1977 size = bfd_section_size (abfd, stabsect);
1978 contents = xmalloc (size);
1979
1980 if (! bfd_get_section_contents (abfd, stabsect, contents, 0, size))
1981 {
1982 non_fatal (_("Reading %s section of %s failed: %s"),
1983 sect_name, bfd_get_filename (abfd),
1984 bfd_errmsg (bfd_get_error ()));
1985 free (contents);
1986 exit_status = 1;
1987 return NULL;
1988 }
1989
1990 *size_ptr = size;
1991
1992 return contents;
1993 }
1994
1995 /* Stabs entries use a 12 byte format:
1996 4 byte string table index
1997 1 byte stab type
1998 1 byte stab other field
1999 2 byte stab desc field
2000 4 byte stab value
2001 FIXME: This will have to change for a 64 bit object format. */
2002
2003 #define STRDXOFF (0)
2004 #define TYPEOFF (4)
2005 #define OTHEROFF (5)
2006 #define DESCOFF (6)
2007 #define VALOFF (8)
2008 #define STABSIZE (12)
2009
2010 /* Print ABFD's stabs section STABSECT_NAME (in `stabs'),
2011 using string table section STRSECT_NAME (in `strtab'). */
2012
2013 static void
2014 print_section_stabs (bfd *abfd,
2015 const char *stabsect_name,
2016 unsigned *string_offset_ptr)
2017 {
2018 int i;
2019 unsigned file_string_table_offset = 0;
2020 unsigned next_file_string_table_offset = *string_offset_ptr;
2021 bfd_byte *stabp, *stabs_end;
2022
2023 stabp = stabs;
2024 stabs_end = stabp + stab_size;
2025
2026 printf (_("Contents of %s section:\n\n"), stabsect_name);
2027 printf ("Symnum n_type n_othr n_desc n_value n_strx String\n");
2028
2029 /* Loop through all symbols and print them.
2030
2031 We start the index at -1 because there is a dummy symbol on
2032 the front of stabs-in-{coff,elf} sections that supplies sizes. */
2033 for (i = -1; stabp < stabs_end; stabp += STABSIZE, i++)
2034 {
2035 const char *name;
2036 unsigned long strx;
2037 unsigned char type, other;
2038 unsigned short desc;
2039 bfd_vma value;
2040
2041 strx = bfd_h_get_32 (abfd, stabp + STRDXOFF);
2042 type = bfd_h_get_8 (abfd, stabp + TYPEOFF);
2043 other = bfd_h_get_8 (abfd, stabp + OTHEROFF);
2044 desc = bfd_h_get_16 (abfd, stabp + DESCOFF);
2045 value = bfd_h_get_32 (abfd, stabp + VALOFF);
2046
2047 printf ("\n%-6d ", i);
2048 /* Either print the stab name, or, if unnamed, print its number
2049 again (makes consistent formatting for tools like awk). */
2050 name = bfd_get_stab_name (type);
2051 if (name != NULL)
2052 printf ("%-6s", name);
2053 else if (type == N_UNDF)
2054 printf ("HdrSym");
2055 else
2056 printf ("%-6d", type);
2057 printf (" %-6d %-6d ", other, desc);
2058 bfd_printf_vma (abfd, value);
2059 printf (" %-6lu", strx);
2060
2061 /* Symbols with type == 0 (N_UNDF) specify the length of the
2062 string table associated with this file. We use that info
2063 to know how to relocate the *next* file's string table indices. */
2064 if (type == N_UNDF)
2065 {
2066 file_string_table_offset = next_file_string_table_offset;
2067 next_file_string_table_offset += value;
2068 }
2069 else
2070 {
2071 /* Using the (possibly updated) string table offset, print the
2072 string (if any) associated with this symbol. */
2073 if ((strx + file_string_table_offset) < stabstr_size)
2074 printf (" %s", &strtab[strx + file_string_table_offset]);
2075 else
2076 printf (" *");
2077 }
2078 }
2079 printf ("\n\n");
2080 *string_offset_ptr = next_file_string_table_offset;
2081 }
2082
2083 typedef struct
2084 {
2085 const char * section_name;
2086 const char * string_section_name;
2087 unsigned string_offset;
2088 }
2089 stab_section_names;
2090
2091 static void
2092 find_stabs_section (bfd *abfd, asection *section, void *names)
2093 {
2094 int len;
2095 stab_section_names * sought = (stab_section_names *) names;
2096
2097 /* Check for section names for which stabsect_name is a prefix, to
2098 handle .stab.N, etc. */
2099 len = strlen (sought->section_name);
2100
2101 /* If the prefix matches, and the files section name ends with a
2102 nul or a digit, then we match. I.e., we want either an exact
2103 match or a section followed by a number. */
2104 if (strncmp (sought->section_name, section->name, len) == 0
2105 && (section->name[len] == 0
2106 || (section->name[len] == '.' && ISDIGIT (section->name[len + 1]))))
2107 {
2108 if (strtab == NULL)
2109 strtab = read_section_stabs (abfd, sought->string_section_name,
2110 &stabstr_size);
2111
2112 if (strtab)
2113 {
2114 stabs = (bfd_byte *) read_section_stabs (abfd, section->name,
2115 &stab_size);
2116 if (stabs)
2117 print_section_stabs (abfd, section->name, &sought->string_offset);
2118 }
2119 }
2120 }
2121
2122 static void
2123 dump_stabs_section (bfd *abfd, char *stabsect_name, char *strsect_name)
2124 {
2125 stab_section_names s;
2126
2127 s.section_name = stabsect_name;
2128 s.string_section_name = strsect_name;
2129 s.string_offset = 0;
2130
2131 bfd_map_over_sections (abfd, find_stabs_section, & s);
2132
2133 free (strtab);
2134 strtab = NULL;
2135 }
2136
2137 /* Dump the any sections containing stabs debugging information. */
2138
2139 static void
2140 dump_stabs (bfd *abfd)
2141 {
2142 dump_stabs_section (abfd, ".stab", ".stabstr");
2143 dump_stabs_section (abfd, ".stab.excl", ".stab.exclstr");
2144 dump_stabs_section (abfd, ".stab.index", ".stab.indexstr");
2145 dump_stabs_section (abfd, "$GDB_SYMBOLS$", "$GDB_STRINGS$");
2146 }
2147 \f
2148 static void
2149 dump_bfd_header (bfd *abfd)
2150 {
2151 char *comma = "";
2152
2153 printf (_("architecture: %s, "),
2154 bfd_printable_arch_mach (bfd_get_arch (abfd),
2155 bfd_get_mach (abfd)));
2156 printf (_("flags 0x%08x:\n"), abfd->flags);
2157
2158 #define PF(x, y) if (abfd->flags & x) {printf("%s%s", comma, y); comma=", ";}
2159 PF (HAS_RELOC, "HAS_RELOC");
2160 PF (EXEC_P, "EXEC_P");
2161 PF (HAS_LINENO, "HAS_LINENO");
2162 PF (HAS_DEBUG, "HAS_DEBUG");
2163 PF (HAS_SYMS, "HAS_SYMS");
2164 PF (HAS_LOCALS, "HAS_LOCALS");
2165 PF (DYNAMIC, "DYNAMIC");
2166 PF (WP_TEXT, "WP_TEXT");
2167 PF (D_PAGED, "D_PAGED");
2168 PF (BFD_IS_RELAXABLE, "BFD_IS_RELAXABLE");
2169 PF (HAS_LOAD_PAGE, "HAS_LOAD_PAGE");
2170 printf (_("\nstart address 0x"));
2171 bfd_printf_vma (abfd, abfd->start_address);
2172 printf ("\n");
2173 }
2174
2175 \f
2176 static void
2177 dump_bfd_private_header (bfd *abfd)
2178 {
2179 bfd_print_private_bfd_data (abfd, stdout);
2180 }
2181
2182 \f
2183 /* Display a section in hexadecimal format with associated characters.
2184 Each line prefixed by the zero padded address. */
2185
2186 static void
2187 dump_section (bfd *abfd, asection *section, void *dummy ATTRIBUTE_UNUSED)
2188 {
2189 bfd_byte *data = 0;
2190 bfd_size_type datasize;
2191 bfd_size_type addr_offset;
2192 bfd_size_type start_offset;
2193 bfd_size_type stop_offset;
2194 unsigned int opb = bfd_octets_per_byte (abfd);
2195 /* Bytes per line. */
2196 const int onaline = 16;
2197 char buf[64];
2198 int count;
2199 int width;
2200
2201 if ((section->flags & SEC_HAS_CONTENTS) == 0)
2202 return;
2203
2204 if (! process_section_p (section))
2205 return;
2206
2207 if ((datasize = bfd_section_size (abfd, section)) == 0)
2208 return;
2209
2210 printf (_("Contents of section %s:\n"), section->name);
2211
2212 data = xmalloc (datasize);
2213
2214 bfd_get_section_contents (abfd, section, data, 0, datasize);
2215
2216 /* Compute the address range to display. */
2217 if (start_address == (bfd_vma) -1
2218 || start_address < section->vma)
2219 start_offset = 0;
2220 else
2221 start_offset = start_address - section->vma;
2222
2223 if (stop_address == (bfd_vma) -1)
2224 stop_offset = datasize / opb;
2225 else
2226 {
2227 if (stop_address < section->vma)
2228 stop_offset = 0;
2229 else
2230 stop_offset = stop_address - section->vma;
2231
2232 if (stop_offset > datasize / opb)
2233 stop_offset = datasize / opb;
2234 }
2235
2236 width = 4;
2237
2238 bfd_sprintf_vma (abfd, buf, start_offset + section->vma);
2239 if (strlen (buf) >= sizeof (buf))
2240 abort ();
2241
2242 count = 0;
2243 while (buf[count] == '0' && buf[count+1] != '\0')
2244 count++;
2245 count = strlen (buf) - count;
2246 if (count > width)
2247 width = count;
2248
2249 bfd_sprintf_vma (abfd, buf, stop_offset + section->vma - 1);
2250 if (strlen (buf) >= sizeof (buf))
2251 abort ();
2252
2253 count = 0;
2254 while (buf[count] == '0' && buf[count+1] != '\0')
2255 count++;
2256 count = strlen (buf) - count;
2257 if (count > width)
2258 width = count;
2259
2260 for (addr_offset = start_offset;
2261 addr_offset < stop_offset; addr_offset += onaline / opb)
2262 {
2263 bfd_size_type j;
2264
2265 bfd_sprintf_vma (abfd, buf, (addr_offset + section->vma));
2266 count = strlen (buf);
2267 if ((size_t) count >= sizeof (buf))
2268 abort ();
2269
2270 putchar (' ');
2271 while (count < width)
2272 {
2273 putchar ('0');
2274 count++;
2275 }
2276 fputs (buf + count - width, stdout);
2277 putchar (' ');
2278
2279 for (j = addr_offset * opb;
2280 j < addr_offset * opb + onaline; j++)
2281 {
2282 if (j < stop_offset * opb)
2283 printf ("%02x", (unsigned) (data[j]));
2284 else
2285 printf (" ");
2286 if ((j & 3) == 3)
2287 printf (" ");
2288 }
2289
2290 printf (" ");
2291 for (j = addr_offset * opb;
2292 j < addr_offset * opb + onaline; j++)
2293 {
2294 if (j >= stop_offset * opb)
2295 printf (" ");
2296 else
2297 printf ("%c", ISPRINT (data[j]) ? data[j] : '.');
2298 }
2299 putchar ('\n');
2300 }
2301 free (data);
2302 }
2303
2304 /* Actually display the various requested regions. */
2305
2306 static void
2307 dump_data (bfd *abfd)
2308 {
2309 bfd_map_over_sections (abfd, dump_section, NULL);
2310 }
2311
2312 /* Should perhaps share code and display with nm? */
2313
2314 static void
2315 dump_symbols (bfd *abfd ATTRIBUTE_UNUSED, bfd_boolean dynamic)
2316 {
2317 asymbol **current;
2318 long max;
2319 long count;
2320
2321 if (dynamic)
2322 {
2323 current = dynsyms;
2324 max = dynsymcount;
2325 printf ("DYNAMIC SYMBOL TABLE:\n");
2326 }
2327 else
2328 {
2329 current = syms;
2330 max = symcount;
2331 printf ("SYMBOL TABLE:\n");
2332 }
2333
2334 if (max == 0)
2335 printf (_("no symbols\n"));
2336
2337 for (count = 0; count < max; count++)
2338 {
2339 bfd *cur_bfd;
2340
2341 if (*current == NULL)
2342 printf (_("no information for symbol number %ld\n"), count);
2343
2344 else if ((cur_bfd = bfd_asymbol_bfd (*current)) == NULL)
2345 printf (_("could not determine the type of symbol number %ld\n"),
2346 count);
2347
2348 else if (dump_special_syms
2349 || !bfd_is_target_special_symbol (cur_bfd, *current))
2350 {
2351 const char *name = (*current)->name;
2352
2353 if (do_demangle && name != NULL && *name != '\0')
2354 {
2355 char *alloc;
2356
2357 /* If we want to demangle the name, we demangle it
2358 here, and temporarily clobber it while calling
2359 bfd_print_symbol. FIXME: This is a gross hack. */
2360 alloc = demangle (cur_bfd, name);
2361 (*current)->name = alloc;
2362 bfd_print_symbol (cur_bfd, stdout, *current,
2363 bfd_print_symbol_all);
2364 (*current)->name = name;
2365 free (alloc);
2366 }
2367 else
2368 bfd_print_symbol (cur_bfd, stdout, *current,
2369 bfd_print_symbol_all);
2370 printf ("\n");
2371 }
2372 current++;
2373 }
2374 printf ("\n\n");
2375 }
2376 \f
2377 static void
2378 dump_reloc_set (bfd *abfd, asection *sec, arelent **relpp, long relcount)
2379 {
2380 arelent **p;
2381 char *last_filename, *last_functionname;
2382 unsigned int last_line;
2383
2384 /* Get column headers lined up reasonably. */
2385 {
2386 static int width;
2387
2388 if (width == 0)
2389 {
2390 char buf[30];
2391
2392 bfd_sprintf_vma (abfd, buf, (bfd_vma) -1);
2393 width = strlen (buf) - 7;
2394 }
2395 printf ("OFFSET %*s TYPE %*s VALUE \n", width, "", 12, "");
2396 }
2397
2398 last_filename = NULL;
2399 last_functionname = NULL;
2400 last_line = 0;
2401
2402 for (p = relpp; relcount && *p != NULL; p++, relcount--)
2403 {
2404 arelent *q = *p;
2405 const char *filename, *functionname;
2406 unsigned int line;
2407 const char *sym_name;
2408 const char *section_name;
2409
2410 if (start_address != (bfd_vma) -1
2411 && q->address < start_address)
2412 continue;
2413 if (stop_address != (bfd_vma) -1
2414 && q->address > stop_address)
2415 continue;
2416
2417 if (with_line_numbers
2418 && sec != NULL
2419 && bfd_find_nearest_line (abfd, sec, syms, q->address,
2420 &filename, &functionname, &line))
2421 {
2422 if (functionname != NULL
2423 && (last_functionname == NULL
2424 || strcmp (functionname, last_functionname) != 0))
2425 {
2426 printf ("%s():\n", functionname);
2427 if (last_functionname != NULL)
2428 free (last_functionname);
2429 last_functionname = xstrdup (functionname);
2430 }
2431
2432 if (line > 0
2433 && (line != last_line
2434 || (filename != NULL
2435 && last_filename != NULL
2436 && strcmp (filename, last_filename) != 0)))
2437 {
2438 printf ("%s:%u\n", filename == NULL ? "???" : filename, line);
2439 last_line = line;
2440 if (last_filename != NULL)
2441 free (last_filename);
2442 if (filename == NULL)
2443 last_filename = NULL;
2444 else
2445 last_filename = xstrdup (filename);
2446 }
2447 }
2448
2449 if (q->sym_ptr_ptr && *q->sym_ptr_ptr)
2450 {
2451 sym_name = (*(q->sym_ptr_ptr))->name;
2452 section_name = (*(q->sym_ptr_ptr))->section->name;
2453 }
2454 else
2455 {
2456 sym_name = NULL;
2457 section_name = NULL;
2458 }
2459
2460 if (sym_name)
2461 {
2462 bfd_printf_vma (abfd, q->address);
2463 if (q->howto->name)
2464 printf (" %-16s ", q->howto->name);
2465 else
2466 printf (" %-16d ", q->howto->type);
2467 objdump_print_symname (abfd, NULL, *q->sym_ptr_ptr);
2468 }
2469 else
2470 {
2471 if (section_name == NULL)
2472 section_name = "*unknown*";
2473 bfd_printf_vma (abfd, q->address);
2474 printf (" %-16s [%s]",
2475 q->howto->name,
2476 section_name);
2477 }
2478
2479 if (q->addend)
2480 {
2481 printf ("+0x");
2482 bfd_printf_vma (abfd, q->addend);
2483 }
2484
2485 printf ("\n");
2486 }
2487 }
2488
2489 static void
2490 dump_relocs_in_section (bfd *abfd,
2491 asection *section,
2492 void *dummy ATTRIBUTE_UNUSED)
2493 {
2494 arelent **relpp;
2495 long relcount;
2496 long relsize;
2497
2498 if ( bfd_is_abs_section (section)
2499 || bfd_is_und_section (section)
2500 || bfd_is_com_section (section)
2501 || (! process_section_p (section))
2502 || ((section->flags & SEC_RELOC) == 0))
2503 return;
2504
2505 relsize = bfd_get_reloc_upper_bound (abfd, section);
2506 if (relsize < 0)
2507 bfd_fatal (bfd_get_filename (abfd));
2508
2509 printf ("RELOCATION RECORDS FOR [%s]:", section->name);
2510
2511 if (relsize == 0)
2512 {
2513 printf (" (none)\n\n");
2514 return;
2515 }
2516
2517 relpp = xmalloc (relsize);
2518 relcount = bfd_canonicalize_reloc (abfd, section, relpp, syms);
2519
2520 if (relcount < 0)
2521 bfd_fatal (bfd_get_filename (abfd));
2522 else if (relcount == 0)
2523 printf (" (none)\n\n");
2524 else
2525 {
2526 printf ("\n");
2527 dump_reloc_set (abfd, section, relpp, relcount);
2528 printf ("\n\n");
2529 }
2530 free (relpp);
2531 }
2532
2533 static void
2534 dump_relocs (bfd *abfd)
2535 {
2536 bfd_map_over_sections (abfd, dump_relocs_in_section, NULL);
2537 }
2538
2539 static void
2540 dump_dynamic_relocs (bfd *abfd)
2541 {
2542 long relsize;
2543 arelent **relpp;
2544 long relcount;
2545
2546 relsize = bfd_get_dynamic_reloc_upper_bound (abfd);
2547 if (relsize < 0)
2548 bfd_fatal (bfd_get_filename (abfd));
2549
2550 printf ("DYNAMIC RELOCATION RECORDS");
2551
2552 if (relsize == 0)
2553 printf (" (none)\n\n");
2554 else
2555 {
2556 relpp = xmalloc (relsize);
2557 relcount = bfd_canonicalize_dynamic_reloc (abfd, relpp, dynsyms);
2558
2559 if (relcount < 0)
2560 bfd_fatal (bfd_get_filename (abfd));
2561 else if (relcount == 0)
2562 printf (" (none)\n\n");
2563 else
2564 {
2565 printf ("\n");
2566 dump_reloc_set (abfd, NULL, relpp, relcount);
2567 printf ("\n\n");
2568 }
2569 free (relpp);
2570 }
2571 }
2572
2573 /* Creates a table of paths, to search for source files. */
2574
2575 static void
2576 add_include_path (const char *path)
2577 {
2578 if (path[0] == 0)
2579 return;
2580 include_path_count++;
2581 include_paths = xrealloc (include_paths,
2582 include_path_count * sizeof (*include_paths));
2583 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
2584 if (path[1] == ':' && path[2] == 0)
2585 path = concat (path, ".", (const char *) 0);
2586 #endif
2587 include_paths[include_path_count - 1] = path;
2588 }
2589
2590 static void
2591 adjust_addresses (bfd *abfd ATTRIBUTE_UNUSED,
2592 asection *section,
2593 void *dummy ATTRIBUTE_UNUSED)
2594 {
2595 section->vma += adjust_section_vma;
2596 section->lma += adjust_section_vma;
2597 }
2598
2599 /* Dump selected contents of ABFD. */
2600
2601 static void
2602 dump_bfd (bfd *abfd)
2603 {
2604 /* If we are adjusting section VMA's, change them all now. Changing
2605 the BFD information is a hack. However, we must do it, or
2606 bfd_find_nearest_line will not do the right thing. */
2607 if (adjust_section_vma != 0)
2608 bfd_map_over_sections (abfd, adjust_addresses, NULL);
2609
2610 if (! dump_debugging_tags)
2611 printf (_("\n%s: file format %s\n"), bfd_get_filename (abfd),
2612 abfd->xvec->name);
2613 if (dump_ar_hdrs)
2614 print_arelt_descr (stdout, abfd, TRUE);
2615 if (dump_file_header)
2616 dump_bfd_header (abfd);
2617 if (dump_private_headers)
2618 dump_bfd_private_header (abfd);
2619 if (! dump_debugging_tags)
2620 putchar ('\n');
2621 if (dump_section_headers)
2622 dump_headers (abfd);
2623
2624 if (dump_symtab || dump_reloc_info || disassemble || dump_debugging)
2625 syms = slurp_symtab (abfd);
2626 if (dump_dynamic_symtab || dump_dynamic_reloc_info
2627 || (disassemble && bfd_get_dynamic_symtab_upper_bound (abfd) > 0))
2628 dynsyms = slurp_dynamic_symtab (abfd);
2629 if (disassemble)
2630 {
2631 synthcount = bfd_get_synthetic_symtab (abfd, symcount, syms,
2632 dynsymcount, dynsyms, &synthsyms);
2633 if (synthcount < 0)
2634 synthcount = 0;
2635 }
2636
2637 if (dump_symtab)
2638 dump_symbols (abfd, FALSE);
2639 if (dump_dynamic_symtab)
2640 dump_symbols (abfd, TRUE);
2641 if (dump_stab_section_info)
2642 dump_stabs (abfd);
2643 if (dump_reloc_info && ! disassemble)
2644 dump_relocs (abfd);
2645 if (dump_dynamic_reloc_info && ! disassemble)
2646 dump_dynamic_relocs (abfd);
2647 if (dump_section_contents)
2648 dump_data (abfd);
2649 if (disassemble)
2650 disassemble_data (abfd);
2651
2652 if (dump_debugging)
2653 {
2654 void *dhandle;
2655
2656 dhandle = read_debugging_info (abfd, syms, symcount);
2657 if (dhandle != NULL)
2658 {
2659 if (! print_debugging_info (stdout, dhandle, abfd, syms, demangle,
2660 dump_debugging_tags ? TRUE : FALSE))
2661 {
2662 non_fatal (_("%s: printing debugging information failed"),
2663 bfd_get_filename (abfd));
2664 exit_status = 1;
2665 }
2666 }
2667 }
2668
2669 if (syms)
2670 {
2671 free (syms);
2672 syms = NULL;
2673 }
2674
2675 if (dynsyms)
2676 {
2677 free (dynsyms);
2678 dynsyms = NULL;
2679 }
2680
2681 if (synthsyms)
2682 {
2683 free (synthsyms);
2684 synthsyms = NULL;
2685 }
2686
2687 symcount = 0;
2688 dynsymcount = 0;
2689 synthcount = 0;
2690 }
2691
2692 static void
2693 display_bfd (bfd *abfd)
2694 {
2695 char **matching;
2696
2697 if (bfd_check_format_matches (abfd, bfd_object, &matching))
2698 {
2699 dump_bfd (abfd);
2700 return;
2701 }
2702
2703 if (bfd_get_error () == bfd_error_file_ambiguously_recognized)
2704 {
2705 nonfatal (bfd_get_filename (abfd));
2706 list_matching_formats (matching);
2707 free (matching);
2708 return;
2709 }
2710
2711 if (bfd_get_error () != bfd_error_file_not_recognized)
2712 {
2713 nonfatal (bfd_get_filename (abfd));
2714 return;
2715 }
2716
2717 if (bfd_check_format_matches (abfd, bfd_core, &matching))
2718 {
2719 dump_bfd (abfd);
2720 return;
2721 }
2722
2723 nonfatal (bfd_get_filename (abfd));
2724
2725 if (bfd_get_error () == bfd_error_file_ambiguously_recognized)
2726 {
2727 list_matching_formats (matching);
2728 free (matching);
2729 }
2730 }
2731
2732 static void
2733 display_file (char *filename, char *target)
2734 {
2735 bfd *file;
2736 bfd *arfile = NULL;
2737
2738 if (get_file_size (filename) < 1)
2739 return;
2740
2741 file = bfd_openr (filename, target);
2742 if (file == NULL)
2743 {
2744 nonfatal (filename);
2745 return;
2746 }
2747
2748 /* If the file is an archive, process all of its elements. */
2749 if (bfd_check_format (file, bfd_archive))
2750 {
2751 bfd *last_arfile = NULL;
2752
2753 printf (_("In archive %s:\n"), bfd_get_filename (file));
2754 for (;;)
2755 {
2756 bfd_set_error (bfd_error_no_error);
2757
2758 arfile = bfd_openr_next_archived_file (file, arfile);
2759 if (arfile == NULL)
2760 {
2761 if (bfd_get_error () != bfd_error_no_more_archived_files)
2762 nonfatal (bfd_get_filename (file));
2763 break;
2764 }
2765
2766 display_bfd (arfile);
2767
2768 if (last_arfile != NULL)
2769 bfd_close (last_arfile);
2770 last_arfile = arfile;
2771 }
2772
2773 if (last_arfile != NULL)
2774 bfd_close (last_arfile);
2775 }
2776 else
2777 display_bfd (file);
2778
2779 bfd_close (file);
2780 }
2781 \f
2782 int
2783 main (int argc, char **argv)
2784 {
2785 int c;
2786 char *target = default_target;
2787 bfd_boolean seenflag = FALSE;
2788
2789 #if defined (HAVE_SETLOCALE)
2790 #if defined (HAVE_LC_MESSAGES)
2791 setlocale (LC_MESSAGES, "");
2792 #endif
2793 setlocale (LC_CTYPE, "");
2794 #endif
2795
2796 bindtextdomain (PACKAGE, LOCALEDIR);
2797 textdomain (PACKAGE);
2798
2799 program_name = *argv;
2800 xmalloc_set_program_name (program_name);
2801
2802 START_PROGRESS (program_name, 0);
2803
2804 bfd_init ();
2805 set_default_bfd_target ();
2806
2807 while ((c = getopt_long (argc, argv, "pib:m:M:VvCdDlfaHhrRtTxsSI:j:wE:zgeG",
2808 long_options, (int *) 0))
2809 != EOF)
2810 {
2811 switch (c)
2812 {
2813 case 0:
2814 break; /* We've been given a long option. */
2815 case 'm':
2816 machine = optarg;
2817 break;
2818 case 'M':
2819 if (disassembler_options)
2820 /* Ignore potential memory leak for now. */
2821 disassembler_options = concat (disassembler_options, ",",
2822 optarg, NULL);
2823 else
2824 disassembler_options = optarg;
2825 break;
2826 case 'j':
2827 if (only_used == only_size)
2828 {
2829 only_size += 8;
2830 only = xrealloc (only, only_size * sizeof (char *));
2831 }
2832 only [only_used++] = optarg;
2833 break;
2834 case 'l':
2835 with_line_numbers = TRUE;
2836 break;
2837 case 'b':
2838 target = optarg;
2839 break;
2840 case 'C':
2841 do_demangle = TRUE;
2842 if (optarg != NULL)
2843 {
2844 enum demangling_styles style;
2845
2846 style = cplus_demangle_name_to_style (optarg);
2847 if (style == unknown_demangling)
2848 fatal (_("unknown demangling style `%s'"),
2849 optarg);
2850
2851 cplus_demangle_set_style (style);
2852 }
2853 break;
2854 case 'w':
2855 wide_output = TRUE;
2856 break;
2857 case OPTION_ADJUST_VMA:
2858 adjust_section_vma = parse_vma (optarg, "--adjust-vma");
2859 break;
2860 case OPTION_START_ADDRESS:
2861 start_address = parse_vma (optarg, "--start-address");
2862 break;
2863 case OPTION_STOP_ADDRESS:
2864 stop_address = parse_vma (optarg, "--stop-address");
2865 break;
2866 case 'E':
2867 if (strcmp (optarg, "B") == 0)
2868 endian = BFD_ENDIAN_BIG;
2869 else if (strcmp (optarg, "L") == 0)
2870 endian = BFD_ENDIAN_LITTLE;
2871 else
2872 {
2873 non_fatal (_("unrecognized -E option"));
2874 usage (stderr, 1);
2875 }
2876 break;
2877 case OPTION_ENDIAN:
2878 if (strncmp (optarg, "big", strlen (optarg)) == 0)
2879 endian = BFD_ENDIAN_BIG;
2880 else if (strncmp (optarg, "little", strlen (optarg)) == 0)
2881 endian = BFD_ENDIAN_LITTLE;
2882 else
2883 {
2884 non_fatal (_("unrecognized --endian type `%s'"), optarg);
2885 usage (stderr, 1);
2886 }
2887 break;
2888
2889 case 'f':
2890 dump_file_header = TRUE;
2891 seenflag = TRUE;
2892 break;
2893 case 'i':
2894 formats_info = TRUE;
2895 seenflag = TRUE;
2896 break;
2897 case 'I':
2898 add_include_path (optarg);
2899 break;
2900 case 'p':
2901 dump_private_headers = TRUE;
2902 seenflag = TRUE;
2903 break;
2904 case 'x':
2905 dump_private_headers = TRUE;
2906 dump_symtab = TRUE;
2907 dump_reloc_info = TRUE;
2908 dump_file_header = TRUE;
2909 dump_ar_hdrs = TRUE;
2910 dump_section_headers = TRUE;
2911 seenflag = TRUE;
2912 break;
2913 case 't':
2914 dump_symtab = TRUE;
2915 seenflag = TRUE;
2916 break;
2917 case 'T':
2918 dump_dynamic_symtab = TRUE;
2919 seenflag = TRUE;
2920 break;
2921 case 'd':
2922 disassemble = TRUE;
2923 seenflag = TRUE;
2924 break;
2925 case 'z':
2926 disassemble_zeroes = TRUE;
2927 break;
2928 case 'D':
2929 disassemble = TRUE;
2930 disassemble_all = TRUE;
2931 seenflag = TRUE;
2932 break;
2933 case 'S':
2934 disassemble = TRUE;
2935 with_source_code = TRUE;
2936 seenflag = TRUE;
2937 break;
2938 case 'g':
2939 dump_debugging = 1;
2940 seenflag = TRUE;
2941 break;
2942 case 'e':
2943 dump_debugging = 1;
2944 dump_debugging_tags = 1;
2945 do_demangle = TRUE;
2946 seenflag = TRUE;
2947 break;
2948 case 'G':
2949 dump_stab_section_info = TRUE;
2950 seenflag = TRUE;
2951 break;
2952 case 's':
2953 dump_section_contents = TRUE;
2954 seenflag = TRUE;
2955 break;
2956 case 'r':
2957 dump_reloc_info = TRUE;
2958 seenflag = TRUE;
2959 break;
2960 case 'R':
2961 dump_dynamic_reloc_info = TRUE;
2962 seenflag = TRUE;
2963 break;
2964 case 'a':
2965 dump_ar_hdrs = TRUE;
2966 seenflag = TRUE;
2967 break;
2968 case 'h':
2969 dump_section_headers = TRUE;
2970 seenflag = TRUE;
2971 break;
2972 case 'H':
2973 usage (stdout, 0);
2974 seenflag = TRUE;
2975 case 'v':
2976 case 'V':
2977 show_version = TRUE;
2978 seenflag = TRUE;
2979 break;
2980
2981 default:
2982 usage (stderr, 1);
2983 }
2984 }
2985
2986 if (show_version)
2987 print_version ("objdump");
2988
2989 if (!seenflag)
2990 usage (stderr, 2);
2991
2992 if (formats_info)
2993 exit_status = display_info ();
2994 else
2995 {
2996 if (optind == argc)
2997 display_file ("a.out", target);
2998 else
2999 for (; optind < argc;)
3000 display_file (argv[optind++], target);
3001 }
3002
3003 END_PROGRESS (program_name);
3004
3005 return exit_status;
3006 }
This page took 0.12091 seconds and 5 git commands to generate.