* som.c (hppa_som_reloc, som_mkobject, som_is_space)
[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 = NULL; /* Initialize to avoid compiler warning. */
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 = &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 (process_section_p ((* current)->section)
2349 && (dump_special_syms
2350 || !bfd_is_target_special_symbol (cur_bfd, *current)))
2351 {
2352 const char *name = (*current)->name;
2353
2354 if (do_demangle && name != NULL && *name != '\0')
2355 {
2356 char *alloc;
2357
2358 /* If we want to demangle the name, we demangle it
2359 here, and temporarily clobber it while calling
2360 bfd_print_symbol. FIXME: This is a gross hack. */
2361 alloc = demangle (cur_bfd, name);
2362 (*current)->name = alloc;
2363 bfd_print_symbol (cur_bfd, stdout, *current,
2364 bfd_print_symbol_all);
2365 (*current)->name = name;
2366 free (alloc);
2367 }
2368 else
2369 bfd_print_symbol (cur_bfd, stdout, *current,
2370 bfd_print_symbol_all);
2371 printf ("\n");
2372 }
2373
2374 current++;
2375 }
2376 printf ("\n\n");
2377 }
2378 \f
2379 static void
2380 dump_reloc_set (bfd *abfd, asection *sec, arelent **relpp, long relcount)
2381 {
2382 arelent **p;
2383 char *last_filename, *last_functionname;
2384 unsigned int last_line;
2385
2386 /* Get column headers lined up reasonably. */
2387 {
2388 static int width;
2389
2390 if (width == 0)
2391 {
2392 char buf[30];
2393
2394 bfd_sprintf_vma (abfd, buf, (bfd_vma) -1);
2395 width = strlen (buf) - 7;
2396 }
2397 printf ("OFFSET %*s TYPE %*s VALUE \n", width, "", 12, "");
2398 }
2399
2400 last_filename = NULL;
2401 last_functionname = NULL;
2402 last_line = 0;
2403
2404 for (p = relpp; relcount && *p != NULL; p++, relcount--)
2405 {
2406 arelent *q = *p;
2407 const char *filename, *functionname;
2408 unsigned int line;
2409 const char *sym_name;
2410 const char *section_name;
2411
2412 if (start_address != (bfd_vma) -1
2413 && q->address < start_address)
2414 continue;
2415 if (stop_address != (bfd_vma) -1
2416 && q->address > stop_address)
2417 continue;
2418
2419 if (with_line_numbers
2420 && sec != NULL
2421 && bfd_find_nearest_line (abfd, sec, syms, q->address,
2422 &filename, &functionname, &line))
2423 {
2424 if (functionname != NULL
2425 && (last_functionname == NULL
2426 || strcmp (functionname, last_functionname) != 0))
2427 {
2428 printf ("%s():\n", functionname);
2429 if (last_functionname != NULL)
2430 free (last_functionname);
2431 last_functionname = xstrdup (functionname);
2432 }
2433
2434 if (line > 0
2435 && (line != last_line
2436 || (filename != NULL
2437 && last_filename != NULL
2438 && strcmp (filename, last_filename) != 0)))
2439 {
2440 printf ("%s:%u\n", filename == NULL ? "???" : filename, line);
2441 last_line = line;
2442 if (last_filename != NULL)
2443 free (last_filename);
2444 if (filename == NULL)
2445 last_filename = NULL;
2446 else
2447 last_filename = xstrdup (filename);
2448 }
2449 }
2450
2451 if (q->sym_ptr_ptr && *q->sym_ptr_ptr)
2452 {
2453 sym_name = (*(q->sym_ptr_ptr))->name;
2454 section_name = (*(q->sym_ptr_ptr))->section->name;
2455 }
2456 else
2457 {
2458 sym_name = NULL;
2459 section_name = NULL;
2460 }
2461
2462 if (sym_name)
2463 {
2464 bfd_printf_vma (abfd, q->address);
2465 if (q->howto->name)
2466 printf (" %-16s ", q->howto->name);
2467 else
2468 printf (" %-16d ", q->howto->type);
2469 objdump_print_symname (abfd, NULL, *q->sym_ptr_ptr);
2470 }
2471 else
2472 {
2473 if (section_name == NULL)
2474 section_name = "*unknown*";
2475 bfd_printf_vma (abfd, q->address);
2476 printf (" %-16s [%s]",
2477 q->howto->name,
2478 section_name);
2479 }
2480
2481 if (q->addend)
2482 {
2483 printf ("+0x");
2484 bfd_printf_vma (abfd, q->addend);
2485 }
2486
2487 printf ("\n");
2488 }
2489 }
2490
2491 static void
2492 dump_relocs_in_section (bfd *abfd,
2493 asection *section,
2494 void *dummy ATTRIBUTE_UNUSED)
2495 {
2496 arelent **relpp;
2497 long relcount;
2498 long relsize;
2499
2500 if ( bfd_is_abs_section (section)
2501 || bfd_is_und_section (section)
2502 || bfd_is_com_section (section)
2503 || (! process_section_p (section))
2504 || ((section->flags & SEC_RELOC) == 0))
2505 return;
2506
2507 relsize = bfd_get_reloc_upper_bound (abfd, section);
2508 if (relsize < 0)
2509 bfd_fatal (bfd_get_filename (abfd));
2510
2511 printf ("RELOCATION RECORDS FOR [%s]:", section->name);
2512
2513 if (relsize == 0)
2514 {
2515 printf (" (none)\n\n");
2516 return;
2517 }
2518
2519 relpp = xmalloc (relsize);
2520 relcount = bfd_canonicalize_reloc (abfd, section, relpp, syms);
2521
2522 if (relcount < 0)
2523 bfd_fatal (bfd_get_filename (abfd));
2524 else if (relcount == 0)
2525 printf (" (none)\n\n");
2526 else
2527 {
2528 printf ("\n");
2529 dump_reloc_set (abfd, section, relpp, relcount);
2530 printf ("\n\n");
2531 }
2532 free (relpp);
2533 }
2534
2535 static void
2536 dump_relocs (bfd *abfd)
2537 {
2538 bfd_map_over_sections (abfd, dump_relocs_in_section, NULL);
2539 }
2540
2541 static void
2542 dump_dynamic_relocs (bfd *abfd)
2543 {
2544 long relsize;
2545 arelent **relpp;
2546 long relcount;
2547
2548 relsize = bfd_get_dynamic_reloc_upper_bound (abfd);
2549 if (relsize < 0)
2550 bfd_fatal (bfd_get_filename (abfd));
2551
2552 printf ("DYNAMIC RELOCATION RECORDS");
2553
2554 if (relsize == 0)
2555 printf (" (none)\n\n");
2556 else
2557 {
2558 relpp = xmalloc (relsize);
2559 relcount = bfd_canonicalize_dynamic_reloc (abfd, relpp, dynsyms);
2560
2561 if (relcount < 0)
2562 bfd_fatal (bfd_get_filename (abfd));
2563 else if (relcount == 0)
2564 printf (" (none)\n\n");
2565 else
2566 {
2567 printf ("\n");
2568 dump_reloc_set (abfd, NULL, relpp, relcount);
2569 printf ("\n\n");
2570 }
2571 free (relpp);
2572 }
2573 }
2574
2575 /* Creates a table of paths, to search for source files. */
2576
2577 static void
2578 add_include_path (const char *path)
2579 {
2580 if (path[0] == 0)
2581 return;
2582 include_path_count++;
2583 include_paths = xrealloc (include_paths,
2584 include_path_count * sizeof (*include_paths));
2585 #ifdef HAVE_DOS_BASED_FILE_SYSTEM
2586 if (path[1] == ':' && path[2] == 0)
2587 path = concat (path, ".", (const char *) 0);
2588 #endif
2589 include_paths[include_path_count - 1] = path;
2590 }
2591
2592 static void
2593 adjust_addresses (bfd *abfd ATTRIBUTE_UNUSED,
2594 asection *section,
2595 void *dummy ATTRIBUTE_UNUSED)
2596 {
2597 section->vma += adjust_section_vma;
2598 section->lma += adjust_section_vma;
2599 }
2600
2601 /* Dump selected contents of ABFD. */
2602
2603 static void
2604 dump_bfd (bfd *abfd)
2605 {
2606 /* If we are adjusting section VMA's, change them all now. Changing
2607 the BFD information is a hack. However, we must do it, or
2608 bfd_find_nearest_line will not do the right thing. */
2609 if (adjust_section_vma != 0)
2610 bfd_map_over_sections (abfd, adjust_addresses, NULL);
2611
2612 if (! dump_debugging_tags)
2613 printf (_("\n%s: file format %s\n"), bfd_get_filename (abfd),
2614 abfd->xvec->name);
2615 if (dump_ar_hdrs)
2616 print_arelt_descr (stdout, abfd, TRUE);
2617 if (dump_file_header)
2618 dump_bfd_header (abfd);
2619 if (dump_private_headers)
2620 dump_bfd_private_header (abfd);
2621 if (! dump_debugging_tags)
2622 putchar ('\n');
2623 if (dump_section_headers)
2624 dump_headers (abfd);
2625
2626 if (dump_symtab || dump_reloc_info || disassemble || dump_debugging)
2627 syms = slurp_symtab (abfd);
2628 if (dump_dynamic_symtab || dump_dynamic_reloc_info
2629 || (disassemble && bfd_get_dynamic_symtab_upper_bound (abfd) > 0))
2630 dynsyms = slurp_dynamic_symtab (abfd);
2631 if (disassemble)
2632 {
2633 synthcount = bfd_get_synthetic_symtab (abfd, symcount, syms,
2634 dynsymcount, dynsyms, &synthsyms);
2635 if (synthcount < 0)
2636 synthcount = 0;
2637 }
2638
2639 if (dump_symtab)
2640 dump_symbols (abfd, FALSE);
2641 if (dump_dynamic_symtab)
2642 dump_symbols (abfd, TRUE);
2643 if (dump_stab_section_info)
2644 dump_stabs (abfd);
2645 if (dump_reloc_info && ! disassemble)
2646 dump_relocs (abfd);
2647 if (dump_dynamic_reloc_info && ! disassemble)
2648 dump_dynamic_relocs (abfd);
2649 if (dump_section_contents)
2650 dump_data (abfd);
2651 if (disassemble)
2652 disassemble_data (abfd);
2653
2654 if (dump_debugging)
2655 {
2656 void *dhandle;
2657
2658 dhandle = read_debugging_info (abfd, syms, symcount);
2659 if (dhandle != NULL)
2660 {
2661 if (! print_debugging_info (stdout, dhandle, abfd, syms, demangle,
2662 dump_debugging_tags ? TRUE : FALSE))
2663 {
2664 non_fatal (_("%s: printing debugging information failed"),
2665 bfd_get_filename (abfd));
2666 exit_status = 1;
2667 }
2668 }
2669 }
2670
2671 if (syms)
2672 {
2673 free (syms);
2674 syms = NULL;
2675 }
2676
2677 if (dynsyms)
2678 {
2679 free (dynsyms);
2680 dynsyms = NULL;
2681 }
2682
2683 if (synthsyms)
2684 {
2685 free (synthsyms);
2686 synthsyms = NULL;
2687 }
2688
2689 symcount = 0;
2690 dynsymcount = 0;
2691 synthcount = 0;
2692 }
2693
2694 static void
2695 display_bfd (bfd *abfd)
2696 {
2697 char **matching;
2698
2699 if (bfd_check_format_matches (abfd, bfd_object, &matching))
2700 {
2701 dump_bfd (abfd);
2702 return;
2703 }
2704
2705 if (bfd_get_error () == bfd_error_file_ambiguously_recognized)
2706 {
2707 nonfatal (bfd_get_filename (abfd));
2708 list_matching_formats (matching);
2709 free (matching);
2710 return;
2711 }
2712
2713 if (bfd_get_error () != bfd_error_file_not_recognized)
2714 {
2715 nonfatal (bfd_get_filename (abfd));
2716 return;
2717 }
2718
2719 if (bfd_check_format_matches (abfd, bfd_core, &matching))
2720 {
2721 dump_bfd (abfd);
2722 return;
2723 }
2724
2725 nonfatal (bfd_get_filename (abfd));
2726
2727 if (bfd_get_error () == bfd_error_file_ambiguously_recognized)
2728 {
2729 list_matching_formats (matching);
2730 free (matching);
2731 }
2732 }
2733
2734 static void
2735 display_file (char *filename, char *target)
2736 {
2737 bfd *file;
2738 bfd *arfile = NULL;
2739
2740 if (get_file_size (filename) < 1)
2741 return;
2742
2743 file = bfd_openr (filename, target);
2744 if (file == NULL)
2745 {
2746 nonfatal (filename);
2747 return;
2748 }
2749
2750 /* If the file is an archive, process all of its elements. */
2751 if (bfd_check_format (file, bfd_archive))
2752 {
2753 bfd *last_arfile = NULL;
2754
2755 printf (_("In archive %s:\n"), bfd_get_filename (file));
2756 for (;;)
2757 {
2758 bfd_set_error (bfd_error_no_error);
2759
2760 arfile = bfd_openr_next_archived_file (file, arfile);
2761 if (arfile == NULL)
2762 {
2763 if (bfd_get_error () != bfd_error_no_more_archived_files)
2764 nonfatal (bfd_get_filename (file));
2765 break;
2766 }
2767
2768 display_bfd (arfile);
2769
2770 if (last_arfile != NULL)
2771 bfd_close (last_arfile);
2772 last_arfile = arfile;
2773 }
2774
2775 if (last_arfile != NULL)
2776 bfd_close (last_arfile);
2777 }
2778 else
2779 display_bfd (file);
2780
2781 bfd_close (file);
2782 }
2783 \f
2784 int
2785 main (int argc, char **argv)
2786 {
2787 int c;
2788 char *target = default_target;
2789 bfd_boolean seenflag = FALSE;
2790
2791 #if defined (HAVE_SETLOCALE)
2792 #if defined (HAVE_LC_MESSAGES)
2793 setlocale (LC_MESSAGES, "");
2794 #endif
2795 setlocale (LC_CTYPE, "");
2796 #endif
2797
2798 bindtextdomain (PACKAGE, LOCALEDIR);
2799 textdomain (PACKAGE);
2800
2801 program_name = *argv;
2802 xmalloc_set_program_name (program_name);
2803
2804 START_PROGRESS (program_name, 0);
2805
2806 bfd_init ();
2807 set_default_bfd_target ();
2808
2809 while ((c = getopt_long (argc, argv, "pib:m:M:VvCdDlfaHhrRtTxsSI:j:wE:zgeG",
2810 long_options, (int *) 0))
2811 != EOF)
2812 {
2813 switch (c)
2814 {
2815 case 0:
2816 break; /* We've been given a long option. */
2817 case 'm':
2818 machine = optarg;
2819 break;
2820 case 'M':
2821 if (disassembler_options)
2822 /* Ignore potential memory leak for now. */
2823 disassembler_options = concat (disassembler_options, ",",
2824 optarg, NULL);
2825 else
2826 disassembler_options = optarg;
2827 break;
2828 case 'j':
2829 if (only_used == only_size)
2830 {
2831 only_size += 8;
2832 only = xrealloc (only, only_size * sizeof (char *));
2833 }
2834 only [only_used++] = optarg;
2835 break;
2836 case 'l':
2837 with_line_numbers = TRUE;
2838 break;
2839 case 'b':
2840 target = optarg;
2841 break;
2842 case 'C':
2843 do_demangle = TRUE;
2844 if (optarg != NULL)
2845 {
2846 enum demangling_styles style;
2847
2848 style = cplus_demangle_name_to_style (optarg);
2849 if (style == unknown_demangling)
2850 fatal (_("unknown demangling style `%s'"),
2851 optarg);
2852
2853 cplus_demangle_set_style (style);
2854 }
2855 break;
2856 case 'w':
2857 wide_output = TRUE;
2858 break;
2859 case OPTION_ADJUST_VMA:
2860 adjust_section_vma = parse_vma (optarg, "--adjust-vma");
2861 break;
2862 case OPTION_START_ADDRESS:
2863 start_address = parse_vma (optarg, "--start-address");
2864 break;
2865 case OPTION_STOP_ADDRESS:
2866 stop_address = parse_vma (optarg, "--stop-address");
2867 break;
2868 case 'E':
2869 if (strcmp (optarg, "B") == 0)
2870 endian = BFD_ENDIAN_BIG;
2871 else if (strcmp (optarg, "L") == 0)
2872 endian = BFD_ENDIAN_LITTLE;
2873 else
2874 {
2875 non_fatal (_("unrecognized -E option"));
2876 usage (stderr, 1);
2877 }
2878 break;
2879 case OPTION_ENDIAN:
2880 if (strncmp (optarg, "big", strlen (optarg)) == 0)
2881 endian = BFD_ENDIAN_BIG;
2882 else if (strncmp (optarg, "little", strlen (optarg)) == 0)
2883 endian = BFD_ENDIAN_LITTLE;
2884 else
2885 {
2886 non_fatal (_("unrecognized --endian type `%s'"), optarg);
2887 usage (stderr, 1);
2888 }
2889 break;
2890
2891 case 'f':
2892 dump_file_header = TRUE;
2893 seenflag = TRUE;
2894 break;
2895 case 'i':
2896 formats_info = TRUE;
2897 seenflag = TRUE;
2898 break;
2899 case 'I':
2900 add_include_path (optarg);
2901 break;
2902 case 'p':
2903 dump_private_headers = TRUE;
2904 seenflag = TRUE;
2905 break;
2906 case 'x':
2907 dump_private_headers = TRUE;
2908 dump_symtab = TRUE;
2909 dump_reloc_info = TRUE;
2910 dump_file_header = TRUE;
2911 dump_ar_hdrs = TRUE;
2912 dump_section_headers = TRUE;
2913 seenflag = TRUE;
2914 break;
2915 case 't':
2916 dump_symtab = TRUE;
2917 seenflag = TRUE;
2918 break;
2919 case 'T':
2920 dump_dynamic_symtab = TRUE;
2921 seenflag = TRUE;
2922 break;
2923 case 'd':
2924 disassemble = TRUE;
2925 seenflag = TRUE;
2926 break;
2927 case 'z':
2928 disassemble_zeroes = TRUE;
2929 break;
2930 case 'D':
2931 disassemble = TRUE;
2932 disassemble_all = TRUE;
2933 seenflag = TRUE;
2934 break;
2935 case 'S':
2936 disassemble = TRUE;
2937 with_source_code = TRUE;
2938 seenflag = TRUE;
2939 break;
2940 case 'g':
2941 dump_debugging = 1;
2942 seenflag = TRUE;
2943 break;
2944 case 'e':
2945 dump_debugging = 1;
2946 dump_debugging_tags = 1;
2947 do_demangle = TRUE;
2948 seenflag = TRUE;
2949 break;
2950 case 'G':
2951 dump_stab_section_info = TRUE;
2952 seenflag = TRUE;
2953 break;
2954 case 's':
2955 dump_section_contents = TRUE;
2956 seenflag = TRUE;
2957 break;
2958 case 'r':
2959 dump_reloc_info = TRUE;
2960 seenflag = TRUE;
2961 break;
2962 case 'R':
2963 dump_dynamic_reloc_info = TRUE;
2964 seenflag = TRUE;
2965 break;
2966 case 'a':
2967 dump_ar_hdrs = TRUE;
2968 seenflag = TRUE;
2969 break;
2970 case 'h':
2971 dump_section_headers = TRUE;
2972 seenflag = TRUE;
2973 break;
2974 case 'H':
2975 usage (stdout, 0);
2976 seenflag = TRUE;
2977 case 'v':
2978 case 'V':
2979 show_version = TRUE;
2980 seenflag = TRUE;
2981 break;
2982
2983 default:
2984 usage (stderr, 1);
2985 }
2986 }
2987
2988 if (show_version)
2989 print_version ("objdump");
2990
2991 if (!seenflag)
2992 usage (stderr, 2);
2993
2994 if (formats_info)
2995 exit_status = display_info ();
2996 else
2997 {
2998 if (optind == argc)
2999 display_file ("a.out", target);
3000 else
3001 for (; optind < argc;)
3002 display_file (argv[optind++], target);
3003 }
3004
3005 END_PROGRESS (program_name);
3006
3007 return exit_status;
3008 }
This page took 0.095375 seconds and 5 git commands to generate.