1 /* readelf.c -- display contents of an ELF format file
2 Copyright 1998, 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
4 Originally developed by Eric Youngdale <eric@andante.jic.com>
5 Modifications by Nick Clifton <nickc@redhat.com>
7 This file is part of GNU Binutils.
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program; if not, write to the Free Software
21 Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
26 #include <sys/types.h>
32 /* Define BFD64 here, even if our default architecture is 32 bit ELF
33 as this will allow us to read in and parse 64bit and 32bit ELF files.
34 Only do this if we believe that the compiler can support a 64 bit
35 data type. For now we only rely on GCC being able to do this. */
41 #include "elf/common.h"
42 #include "elf/external.h"
43 #include "elf/internal.h"
44 #include "elf/dwarf2.h"
46 /* The following headers use the elf/reloc-macros.h file to
47 automatically generate relocation recognition functions
48 such as elf_mips_reloc_type() */
50 #define RELOC_MACROS_GEN_FUNC
52 #include "elf/alpha.h"
72 #include "elf/m68hc11.h"
73 #include "elf/mcore.h"
76 #include "elf/mn10200.h"
77 #include "elf/mn10300.h"
78 #include "elf/msp430.h"
82 #include "elf/ppc64.h"
85 #include "elf/sparc.h"
88 #include "elf/x86-64.h"
89 #include "elf/xstormy16.h"
90 #include "elf/iq2000.h"
91 #include "elf/xtensa.h"
95 #include "libiberty.h"
97 char *program_name
= "readelf";
98 unsigned long dynamic_addr
;
99 bfd_size_type dynamic_size
;
100 char *dynamic_strings
;
102 unsigned long string_table_length
;
103 unsigned long num_dynamic_syms
;
104 Elf_Internal_Sym
*dynamic_symbols
;
105 Elf_Internal_Syminfo
*dynamic_syminfo
;
106 unsigned long dynamic_syminfo_offset
;
107 unsigned int dynamic_syminfo_nent
;
108 char program_interpreter
[64];
109 bfd_vma dynamic_info
[DT_JMPREL
+ 1];
110 bfd_vma version_info
[16];
111 Elf_Internal_Ehdr elf_header
;
112 Elf_Internal_Shdr
*section_headers
;
113 Elf_Internal_Phdr
*program_headers
;
114 Elf_Internal_Dyn
*dynamic_segment
;
115 Elf_Internal_Shdr
*symtab_shndx_hdr
;
123 int do_using_dynamic
;
131 int do_debug_abbrevs
;
133 int do_debug_pubnames
;
134 int do_debug_aranges
;
136 int do_debug_frames_interp
;
137 int do_debug_macinfo
;
144 /* A dynamic array of flags indicating which sections require dumping. */
145 char *dump_sects
= NULL
;
146 unsigned int num_dump_sects
= 0;
148 #define HEX_DUMP (1 << 0)
149 #define DISASS_DUMP (1 << 1)
150 #define DEBUG_DUMP (1 << 2)
152 /* How to rpint a vma value. */
153 typedef enum print_mode
165 /* Forward declarations for dumb compilers. */
166 static void print_vma
167 PARAMS ((bfd_vma
, print_mode
));
168 static void print_symbol
169 PARAMS ((int, const char *));
170 static bfd_vma (*byte_get
)
171 PARAMS ((unsigned char *, int));
172 static bfd_vma byte_get_little_endian
173 PARAMS ((unsigned char *, int));
174 static bfd_vma byte_get_big_endian
175 PARAMS ((unsigned char *, int));
176 static bfd_vma byte_get_signed
177 PARAMS ((unsigned char *, int));
178 static void (*byte_put
)
179 PARAMS ((unsigned char *, bfd_vma
, int));
180 static void byte_put_little_endian
181 PARAMS ((unsigned char *, bfd_vma
, int));
182 static void byte_put_big_endian
183 PARAMS ((unsigned char *, bfd_vma
, int));
184 static const char *get_mips_dynamic_type
185 PARAMS ((unsigned long));
186 static const char *get_sparc64_dynamic_type
187 PARAMS ((unsigned long));
188 static const char *get_ppc64_dynamic_type
189 PARAMS ((unsigned long));
190 static const char *get_parisc_dynamic_type
191 PARAMS ((unsigned long));
192 static const char *get_ia64_dynamic_type
193 PARAMS ((unsigned long));
194 static const char *get_dynamic_type
195 PARAMS ((unsigned long));
196 static int slurp_rela_relocs
197 PARAMS ((FILE *, unsigned long, unsigned long, Elf_Internal_Rela
**,
199 static int slurp_rel_relocs
200 PARAMS ((FILE *, unsigned long, unsigned long, Elf_Internal_Rela
**,
202 static int dump_relocations
203 PARAMS ((FILE *, unsigned long, unsigned long, Elf_Internal_Sym
*,
204 unsigned long, char *, int));
205 static char *get_file_type
207 static char *get_machine_name
209 static void decode_ARM_machine_flags
210 PARAMS ((unsigned, char[]));
211 static char *get_machine_flags
212 PARAMS ((unsigned, unsigned));
213 static const char *get_mips_segment_type
214 PARAMS ((unsigned long));
215 static const char *get_parisc_segment_type
216 PARAMS ((unsigned long));
217 static const char *get_ia64_segment_type
218 PARAMS ((unsigned long));
219 static const char *get_segment_type
220 PARAMS ((unsigned long));
221 static const char *get_mips_section_type_name
222 PARAMS ((unsigned int));
223 static const char *get_parisc_section_type_name
224 PARAMS ((unsigned int));
225 static const char *get_ia64_section_type_name
226 PARAMS ((unsigned int));
227 static const char *get_section_type_name
228 PARAMS ((unsigned int));
229 static const char *get_symbol_binding
230 PARAMS ((unsigned int));
231 static const char *get_symbol_type
232 PARAMS ((unsigned int));
233 static const char *get_symbol_visibility
234 PARAMS ((unsigned int));
235 static const char *get_symbol_index_type
236 PARAMS ((unsigned int));
237 static const char *get_dynamic_flags
241 static void parse_args
242 PARAMS ((int, char **));
243 static int process_file_header
245 static int process_program_headers
247 static int process_section_headers
249 static int process_unwind
251 static void dynamic_segment_mips_val
252 PARAMS ((Elf_Internal_Dyn
*));
253 static void dynamic_segment_parisc_val
254 PARAMS ((Elf_Internal_Dyn
*));
255 static void dynamic_segment_ia64_val
256 PARAMS ((Elf_Internal_Dyn
*));
257 static int process_dynamic_segment
259 static int process_symbol_table
261 static int process_syminfo
263 static int process_section_contents
265 static void process_mips_fpe_exception
267 static int process_mips_specific
269 static int process_file
271 static int process_relocs
273 static int process_version_sections
275 static char *get_ver_flags
276 PARAMS ((unsigned int));
277 static int get_32bit_section_headers
278 PARAMS ((FILE *, unsigned int));
279 static int get_64bit_section_headers
280 PARAMS ((FILE *, unsigned int));
281 static int get_32bit_program_headers
282 PARAMS ((FILE *, Elf_Internal_Phdr
*));
283 static int get_64bit_program_headers
284 PARAMS ((FILE *, Elf_Internal_Phdr
*));
285 static int get_program_headers
287 static int get_file_header
289 static Elf_Internal_Sym
*get_32bit_elf_symbols
290 PARAMS ((FILE *, Elf_Internal_Shdr
*));
291 static Elf_Internal_Sym
*get_64bit_elf_symbols
292 PARAMS ((FILE *, Elf_Internal_Shdr
*));
293 static const char *get_elf_section_flags
295 static int *get_dynamic_data
296 PARAMS ((FILE *, unsigned int));
297 static int get_32bit_dynamic_segment
299 static int get_64bit_dynamic_segment
301 static long offset_from_vma
302 PARAMS ((FILE *, bfd_vma vma
, bfd_size_type size
));
303 #ifdef SUPPORT_DISASSEMBLY
304 static int disassemble_section
305 PARAMS ((Elf_Internal_Shdr
*, FILE *));
307 static int dump_section
308 PARAMS ((Elf_Internal_Shdr
*, FILE *));
309 static int display_debug_section
310 PARAMS ((Elf_Internal_Shdr
*, FILE *));
311 static int display_debug_info
312 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
313 static int display_debug_not_supported
314 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
315 static int prescan_debug_info
316 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
317 static int display_debug_lines
318 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
319 static int display_debug_pubnames
320 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
321 static int display_debug_abbrev
322 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
323 static int display_debug_aranges
324 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
325 static int display_debug_frames
326 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
327 static int display_debug_macinfo
328 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
329 static int display_debug_str
330 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
331 static int display_debug_loc
332 PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
333 static unsigned char *process_abbrev_section
334 PARAMS ((unsigned char *, unsigned char *));
335 static void load_debug_str
337 static void free_debug_str
339 static const char *fetch_indirect_string
340 PARAMS ((unsigned long));
341 static void load_debug_loc
343 static void free_debug_loc
345 static unsigned long read_leb128
346 PARAMS ((unsigned char *, int *, int));
347 static int process_extended_line_op
348 PARAMS ((unsigned char *, int, int));
349 static void reset_state_machine
351 static char *get_TAG_name
352 PARAMS ((unsigned long));
353 static char *get_AT_name
354 PARAMS ((unsigned long));
355 static char *get_FORM_name
356 PARAMS ((unsigned long));
357 static void free_abbrevs
359 static void add_abbrev
360 PARAMS ((unsigned long, unsigned long, int));
361 static void add_abbrev_attr
362 PARAMS ((unsigned long, unsigned long));
363 static unsigned char *read_and_display_attr
364 PARAMS ((unsigned long, unsigned long, unsigned char *, unsigned long,
365 unsigned long, unsigned long, int));
366 static unsigned char *read_and_display_attr_value
367 PARAMS ((unsigned long, unsigned long, unsigned char *, unsigned long,
368 unsigned long, unsigned long, int));
369 static unsigned char *display_block
370 PARAMS ((unsigned char *, unsigned long));
371 static void decode_location_expression
372 PARAMS ((unsigned char *, unsigned int, unsigned long));
373 static void request_dump
374 PARAMS ((unsigned int, int));
375 static const char *get_elf_class
376 PARAMS ((unsigned int));
377 static const char *get_data_encoding
378 PARAMS ((unsigned int));
379 static const char *get_osabi_name
380 PARAMS ((unsigned int));
381 static int guess_is_rela
382 PARAMS ((unsigned long));
383 static const char *get_note_type
384 PARAMS ((unsigned int));
385 static const char *get_netbsd_elfcore_note_type
386 PARAMS ((unsigned int));
387 static int process_note
388 PARAMS ((Elf_Internal_Note
*));
389 static int process_corefile_note_segment
390 PARAMS ((FILE *, bfd_vma
, bfd_vma
));
391 static int process_corefile_note_segments
393 static int process_corefile_contents
395 static int process_arch_specific
397 static int process_gnu_liblist
400 typedef int Elf32_Word
;
404 #define SECTION_NAME(X) ((X) == NULL ? "<none>" : \
405 ((X)->sh_name >= string_table_length \
406 ? "<corrupt>" : string_table + (X)->sh_name))
408 /* Given st_shndx I, map to section_headers index. */
409 #define SECTION_HEADER_INDEX(I) \
410 ((I) < SHN_LORESERVE \
412 : ((I) <= SHN_HIRESERVE \
414 : (I) - (SHN_HIRESERVE + 1 - SHN_LORESERVE)))
416 /* Reverse of the above. */
417 #define SECTION_HEADER_NUM(N) \
418 ((N) < SHN_LORESERVE \
420 : (N) + (SHN_HIRESERVE + 1 - SHN_LORESERVE))
422 #define SECTION_HEADER(I) (section_headers + SECTION_HEADER_INDEX (I))
424 #define DT_VERSIONTAGIDX(tag) (DT_VERNEEDNUM - (tag)) /* Reverse order! */
426 #define BYTE_GET(field) byte_get (field, sizeof (field))
428 /* If we can support a 64 bit data type then BFD64 should be defined
429 and sizeof (bfd_vma) == 8. In this case when translating from an
430 external 8 byte field to an internal field, we can assume that the
431 internal field is also 8 bytes wide and so we can extract all the data.
432 If, however, BFD64 is not defined, then we must assume that the
433 internal data structure only has 4 byte wide fields that are the
434 equivalent of the 8 byte wide external counterparts, and so we must
435 truncate the data. */
437 #define BYTE_GET8(field) byte_get (field, -8)
439 #define BYTE_GET8(field) byte_get (field, 8)
442 #define NUM_ELEM(array) (sizeof (array) / sizeof ((array)[0]))
444 #define GET_ELF_SYMBOLS(file, section) \
445 (is_32bit_elf ? get_32bit_elf_symbols (file, section) \
446 : get_64bit_elf_symbols (file, section))
450 error
VPARAMS ((const char *message
, ...))
452 VA_OPEN (args
, message
);
453 VA_FIXEDARG (args
, const char *, message
);
455 fprintf (stderr
, _("%s: Error: "), program_name
);
456 vfprintf (stderr
, message
, args
);
461 warn
VPARAMS ((const char *message
, ...))
463 VA_OPEN (args
, message
);
464 VA_FIXEDARG (args
, const char *, message
);
466 fprintf (stderr
, _("%s: Warning: "), program_name
);
467 vfprintf (stderr
, message
, args
);
471 static PTR get_data
PARAMS ((PTR
, FILE *, long, size_t, const char *));
474 get_data (var
, file
, offset
, size
, reason
)
486 if (fseek (file
, offset
, SEEK_SET
))
488 error (_("Unable to seek to %x for %s\n"), offset
, reason
);
495 mvar
= (PTR
) malloc (size
);
499 error (_("Out of memory allocating %d bytes for %s\n"),
505 if (fread (mvar
, size
, 1, file
) != 1)
507 error (_("Unable to read in %d bytes of %s\n"), size
, reason
);
517 byte_get_little_endian (field
, size
)
518 unsigned char *field
;
527 return ((unsigned int) (field
[0]))
528 | (((unsigned int) (field
[1])) << 8);
532 /* We want to extract data from an 8 byte wide field and
533 place it into a 4 byte wide field. Since this is a little
534 endian source we can just use the 4 byte extraction code. */
538 return ((unsigned long) (field
[0]))
539 | (((unsigned long) (field
[1])) << 8)
540 | (((unsigned long) (field
[2])) << 16)
541 | (((unsigned long) (field
[3])) << 24);
546 /* This is a special case, generated by the BYTE_GET8 macro.
547 It means that we are loading an 8 byte value from a field
548 in an external structure into an 8 byte value in a field
549 in an internal strcuture. */
550 return ((bfd_vma
) (field
[0]))
551 | (((bfd_vma
) (field
[1])) << 8)
552 | (((bfd_vma
) (field
[2])) << 16)
553 | (((bfd_vma
) (field
[3])) << 24)
554 | (((bfd_vma
) (field
[4])) << 32)
555 | (((bfd_vma
) (field
[5])) << 40)
556 | (((bfd_vma
) (field
[6])) << 48)
557 | (((bfd_vma
) (field
[7])) << 56);
560 error (_("Unhandled data length: %d\n"), size
);
566 byte_get_signed (field
, size
)
567 unsigned char *field
;
570 bfd_vma x
= byte_get (field
, size
);
575 return (x
^ 0x80) - 0x80;
577 return (x
^ 0x8000) - 0x8000;
579 return (x
^ 0x80000000) - 0x80000000;
589 byte_put_little_endian (field
, value
, size
)
590 unsigned char * field
;
597 field
[7] = (((value
>> 24) >> 24) >> 8) & 0xff;
598 field
[6] = ((value
>> 24) >> 24) & 0xff;
599 field
[5] = ((value
>> 24) >> 16) & 0xff;
600 field
[4] = ((value
>> 24) >> 8) & 0xff;
603 field
[3] = (value
>> 24) & 0xff;
604 field
[2] = (value
>> 16) & 0xff;
607 field
[1] = (value
>> 8) & 0xff;
610 field
[0] = value
& 0xff;
614 error (_("Unhandled data length: %d\n"), size
);
619 /* Print a VMA value. */
621 print_vma (vma
, mode
)
635 printf ("%8.8lx", (unsigned long) vma
);
641 printf ("%5ld", (long) vma
);
649 printf ("%lx", (unsigned long) vma
);
653 printf ("%ld", (unsigned long) vma
);
657 printf ("%lu", (unsigned long) vma
);
679 #if BFD_HOST_64BIT_LONG
682 if (_bfd_int64_high (vma
))
683 printf ("%lx%8.8lx", _bfd_int64_high (vma
), _bfd_int64_low (vma
));
685 printf ("%lx", _bfd_int64_low (vma
));
690 #if BFD_HOST_64BIT_LONG
693 if (_bfd_int64_high (vma
))
695 printf ("++%ld", _bfd_int64_low (vma
));
697 printf ("%ld", _bfd_int64_low (vma
));
702 #if BFD_HOST_64BIT_LONG
704 printf ("%5ld", vma
);
706 printf ("%#lx", vma
);
708 if (_bfd_int64_high (vma
))
710 printf ("++%ld", _bfd_int64_low (vma
));
711 else if (vma
<= 99999)
712 printf ("%5ld", _bfd_int64_low (vma
));
714 printf ("%#lx", _bfd_int64_low (vma
));
719 #if BFD_HOST_64BIT_LONG
722 if (_bfd_int64_high (vma
))
724 printf ("++%lu", _bfd_int64_low (vma
));
726 printf ("%lu", _bfd_int64_low (vma
));
734 /* Display a symbol on stdout. If do_wide is not true then
735 format the symbol to be at most WIDTH characters,
736 truncating as necessary. If WIDTH is negative then
737 format the string to be exactly - WIDTH characters,
738 truncating or padding as necessary. */
741 print_symbol (width
, symbol
)
746 printf ("%s", symbol
);
748 printf ("%-*.*s", width
, width
, symbol
);
750 printf ("%-.*s", width
, symbol
);
754 byte_get_big_endian (field
, size
)
755 unsigned char *field
;
764 return ((unsigned int) (field
[1])) | (((int) (field
[0])) << 8);
767 return ((unsigned long) (field
[3]))
768 | (((unsigned long) (field
[2])) << 8)
769 | (((unsigned long) (field
[1])) << 16)
770 | (((unsigned long) (field
[0])) << 24);
774 /* Although we are extracing data from an 8 byte wide field, we
775 are returning only 4 bytes of data. */
776 return ((unsigned long) (field
[7]))
777 | (((unsigned long) (field
[6])) << 8)
778 | (((unsigned long) (field
[5])) << 16)
779 | (((unsigned long) (field
[4])) << 24);
783 /* This is a special case, generated by the BYTE_GET8 macro.
784 It means that we are loading an 8 byte value from a field
785 in an external structure into an 8 byte value in a field
786 in an internal strcuture. */
787 return ((bfd_vma
) (field
[7]))
788 | (((bfd_vma
) (field
[6])) << 8)
789 | (((bfd_vma
) (field
[5])) << 16)
790 | (((bfd_vma
) (field
[4])) << 24)
791 | (((bfd_vma
) (field
[3])) << 32)
792 | (((bfd_vma
) (field
[2])) << 40)
793 | (((bfd_vma
) (field
[1])) << 48)
794 | (((bfd_vma
) (field
[0])) << 56);
798 error (_("Unhandled data length: %d\n"), size
);
804 byte_put_big_endian (field
, value
, size
)
805 unsigned char * field
;
812 field
[7] = value
& 0xff;
813 field
[6] = (value
>> 8) & 0xff;
814 field
[5] = (value
>> 16) & 0xff;
815 field
[4] = (value
>> 24) & 0xff;
820 field
[3] = value
& 0xff;
821 field
[2] = (value
>> 8) & 0xff;
825 field
[1] = value
& 0xff;
829 field
[0] = value
& 0xff;
833 error (_("Unhandled data length: %d\n"), size
);
838 /* Guess the relocation size commonly used by the specific machines. */
841 guess_is_rela (e_machine
)
842 unsigned long e_machine
;
846 /* Targets that use REL relocations. */
862 /* Targets that use RELA relocations. */
877 case EM_CYGNUS_MN10200
:
879 case EM_CYGNUS_MN10300
:
924 warn (_("Don't know about relocations on this machine architecture\n"));
930 slurp_rela_relocs (file
, rel_offset
, rel_size
, relasp
, nrelasp
)
932 unsigned long rel_offset
;
933 unsigned long rel_size
;
934 Elf_Internal_Rela
**relasp
;
935 unsigned long *nrelasp
;
937 Elf_Internal_Rela
*relas
;
938 unsigned long nrelas
;
943 Elf32_External_Rela
*erelas
;
945 erelas
= (Elf32_External_Rela
*) get_data (NULL
, file
, rel_offset
,
946 rel_size
, _("relocs"));
950 nrelas
= rel_size
/ sizeof (Elf32_External_Rela
);
952 relas
= (Elf_Internal_Rela
*)
953 malloc (nrelas
* sizeof (Elf_Internal_Rela
));
957 error(_("out of memory parsing relocs"));
961 for (i
= 0; i
< nrelas
; i
++)
963 relas
[i
].r_offset
= BYTE_GET (erelas
[i
].r_offset
);
964 relas
[i
].r_info
= BYTE_GET (erelas
[i
].r_info
);
965 relas
[i
].r_addend
= BYTE_GET (erelas
[i
].r_addend
);
972 Elf64_External_Rela
*erelas
;
974 erelas
= (Elf64_External_Rela
*) get_data (NULL
, file
, rel_offset
,
975 rel_size
, _("relocs"));
979 nrelas
= rel_size
/ sizeof (Elf64_External_Rela
);
981 relas
= (Elf_Internal_Rela
*)
982 malloc (nrelas
* sizeof (Elf_Internal_Rela
));
986 error(_("out of memory parsing relocs"));
990 for (i
= 0; i
< nrelas
; i
++)
992 relas
[i
].r_offset
= BYTE_GET8 (erelas
[i
].r_offset
);
993 relas
[i
].r_info
= BYTE_GET8 (erelas
[i
].r_info
);
994 relas
[i
].r_addend
= BYTE_GET8 (erelas
[i
].r_addend
);
1005 slurp_rel_relocs (file
, rel_offset
, rel_size
, relsp
, nrelsp
)
1007 unsigned long rel_offset
;
1008 unsigned long rel_size
;
1009 Elf_Internal_Rela
**relsp
;
1010 unsigned long *nrelsp
;
1012 Elf_Internal_Rela
*rels
;
1013 unsigned long nrels
;
1018 Elf32_External_Rel
*erels
;
1020 erels
= (Elf32_External_Rel
*) get_data (NULL
, file
, rel_offset
,
1021 rel_size
, _("relocs"));
1025 nrels
= rel_size
/ sizeof (Elf32_External_Rel
);
1027 rels
= (Elf_Internal_Rela
*) malloc (nrels
* sizeof (Elf_Internal_Rela
));
1031 error(_("out of memory parsing relocs"));
1035 for (i
= 0; i
< nrels
; i
++)
1037 rels
[i
].r_offset
= BYTE_GET (erels
[i
].r_offset
);
1038 rels
[i
].r_info
= BYTE_GET (erels
[i
].r_info
);
1039 rels
[i
].r_addend
= 0;
1046 Elf64_External_Rel
*erels
;
1048 erels
= (Elf64_External_Rel
*) get_data (NULL
, file
, rel_offset
,
1049 rel_size
, _("relocs"));
1053 nrels
= rel_size
/ sizeof (Elf64_External_Rel
);
1055 rels
= (Elf_Internal_Rela
*) malloc (nrels
* sizeof (Elf_Internal_Rela
));
1059 error(_("out of memory parsing relocs"));
1063 for (i
= 0; i
< nrels
; i
++)
1065 rels
[i
].r_offset
= BYTE_GET8 (erels
[i
].r_offset
);
1066 rels
[i
].r_info
= BYTE_GET8 (erels
[i
].r_info
);
1067 rels
[i
].r_addend
= 0;
1077 /* Display the contents of the relocation data found at the specified offset. */
1080 dump_relocations (file
, rel_offset
, rel_size
, symtab
, nsyms
, strtab
, is_rela
)
1082 unsigned long rel_offset
;
1083 unsigned long rel_size
;
1084 Elf_Internal_Sym
*symtab
;
1085 unsigned long nsyms
;
1090 Elf_Internal_Rela
*rels
;
1093 if (is_rela
== UNKNOWN
)
1094 is_rela
= guess_is_rela (elf_header
.e_machine
);
1098 if (!slurp_rela_relocs (file
, rel_offset
, rel_size
, &rels
, &rel_size
))
1103 if (!slurp_rel_relocs (file
, rel_offset
, rel_size
, &rels
, &rel_size
))
1112 printf (_(" Offset Info Type Sym. Value Symbol's Name + Addend\n"));
1114 printf (_(" Offset Info Type Sym.Value Sym. Name + Addend\n"));
1119 printf (_(" Offset Info Type Sym. Value Symbol's Name\n"));
1121 printf (_(" Offset Info Type Sym.Value Sym. Name\n"));
1129 printf (_(" Offset Info Type Symbol's Value Symbol's Name + Addend\n"));
1131 printf (_(" Offset Info Type Sym. Value Sym. Name + Addend\n"));
1136 printf (_(" Offset Info Type Symbol's Value Symbol's Name\n"));
1138 printf (_(" Offset Info Type Sym. Value Sym. Name\n"));
1142 for (i
= 0; i
< rel_size
; i
++)
1145 const char *rtype2
= NULL
;
1146 const char *rtype3
= NULL
;
1149 bfd_vma symtab_index
;
1151 bfd_vma type2
= (bfd_vma
) NULL
;
1152 bfd_vma type3
= (bfd_vma
) NULL
;
1154 offset
= rels
[i
].r_offset
;
1155 info
= rels
[i
].r_info
;
1159 type
= ELF32_R_TYPE (info
);
1160 symtab_index
= ELF32_R_SYM (info
);
1164 /* The #ifdef BFD64 below is to prevent a compile time warning.
1165 We know that if we do not have a 64 bit data type that we
1166 will never execute this code anyway. */
1168 if (elf_header
.e_machine
== EM_MIPS
)
1170 /* In little-endian objects, r_info isn't really a 64-bit
1171 little-endian value: it has a 32-bit little-endian
1172 symbol index followed by four individual byte fields.
1173 Reorder INFO accordingly. */
1174 if (elf_header
.e_ident
[EI_DATA
] != ELFDATA2MSB
)
1175 info
= (((info
& 0xffffffff) << 32)
1176 | ((info
>> 56) & 0xff)
1177 | ((info
>> 40) & 0xff00)
1178 | ((info
>> 24) & 0xff0000)
1179 | ((info
>> 8) & 0xff000000));
1180 type
= ELF64_MIPS_R_TYPE (info
);
1181 type2
= ELF64_MIPS_R_TYPE2 (info
);
1182 type3
= ELF64_MIPS_R_TYPE3 (info
);
1184 else if (elf_header
.e_machine
== EM_SPARCV9
)
1185 type
= ELF64_R_TYPE_ID (info
);
1187 type
= ELF64_R_TYPE (info
);
1189 symtab_index
= ELF64_R_SYM (info
);
1195 #ifdef _bfd_int64_low
1196 printf ("%8.8lx %8.8lx ", _bfd_int64_low (offset
), _bfd_int64_low (info
));
1198 printf ("%8.8lx %8.8lx ", offset
, info
);
1203 #ifdef _bfd_int64_low
1205 ? "%8.8lx%8.8lx %8.8lx%8.8lx "
1206 : "%4.4lx%8.8lx %4.4lx%8.8lx ",
1207 _bfd_int64_high (offset
),
1208 _bfd_int64_low (offset
),
1209 _bfd_int64_high (info
),
1210 _bfd_int64_low (info
));
1213 ? "%16.16lx %16.16lx "
1214 : "%12.12lx %12.12lx ",
1219 switch (elf_header
.e_machine
)
1226 case EM_CYGNUS_M32R
:
1227 rtype
= elf_m32r_reloc_type (type
);
1232 rtype
= elf_i386_reloc_type (type
);
1237 rtype
= elf_m68hc11_reloc_type (type
);
1241 rtype
= elf_m68k_reloc_type (type
);
1245 rtype
= elf_i960_reloc_type (type
);
1250 rtype
= elf_avr_reloc_type (type
);
1253 case EM_OLD_SPARCV9
:
1254 case EM_SPARC32PLUS
:
1257 rtype
= elf_sparc_reloc_type (type
);
1261 case EM_CYGNUS_V850
:
1262 rtype
= v850_reloc_type (type
);
1266 case EM_CYGNUS_D10V
:
1267 rtype
= elf_d10v_reloc_type (type
);
1271 case EM_CYGNUS_D30V
:
1272 rtype
= elf_d30v_reloc_type (type
);
1276 rtype
= elf_dlx_reloc_type (type
);
1280 rtype
= elf_sh_reloc_type (type
);
1284 case EM_CYGNUS_MN10300
:
1285 rtype
= elf_mn10300_reloc_type (type
);
1289 case EM_CYGNUS_MN10200
:
1290 rtype
= elf_mn10200_reloc_type (type
);
1294 case EM_CYGNUS_FR30
:
1295 rtype
= elf_fr30_reloc_type (type
);
1299 rtype
= elf_frv_reloc_type (type
);
1303 rtype
= elf_mcore_reloc_type (type
);
1307 rtype
= elf_mmix_reloc_type (type
);
1312 rtype
= elf_msp430_reloc_type (type
);
1316 rtype
= elf_ppc_reloc_type (type
);
1320 rtype
= elf_ppc64_reloc_type (type
);
1324 case EM_MIPS_RS3_LE
:
1325 rtype
= elf_mips_reloc_type (type
);
1328 rtype2
= elf_mips_reloc_type (type2
);
1329 rtype3
= elf_mips_reloc_type (type3
);
1334 rtype
= elf_alpha_reloc_type (type
);
1338 rtype
= elf_arm_reloc_type (type
);
1342 rtype
= elf_arc_reloc_type (type
);
1346 rtype
= elf_hppa_reloc_type (type
);
1352 rtype
= elf_h8_reloc_type (type
);
1357 rtype
= elf_or32_reloc_type (type
);
1362 rtype
= elf_pj_reloc_type (type
);
1365 rtype
= elf_ia64_reloc_type (type
);
1369 rtype
= elf_cris_reloc_type (type
);
1373 rtype
= elf_i860_reloc_type (type
);
1377 rtype
= elf_x86_64_reloc_type (type
);
1381 rtype
= i370_reloc_type (type
);
1386 rtype
= elf_s390_reloc_type (type
);
1390 rtype
= elf_xstormy16_reloc_type (type
);
1394 rtype
= elf_vax_reloc_type (type
);
1399 rtype
= elf_ip2k_reloc_type (type
);
1403 rtype
= elf_iq2000_reloc_type (type
);
1408 rtype
= elf_xtensa_reloc_type (type
);
1413 #ifdef _bfd_int64_low
1414 printf (_("unrecognized: %-7lx"), _bfd_int64_low (type
));
1416 printf (_("unrecognized: %-7lx"), type
);
1419 printf (do_wide
? "%-22.22s" : "%-17.17s", rtype
);
1423 if (symtab
== NULL
|| symtab_index
>= nsyms
)
1424 printf (" bad symbol index: %08lx", (unsigned long) symtab_index
);
1427 Elf_Internal_Sym
*psym
;
1429 psym
= symtab
+ symtab_index
;
1432 print_vma (psym
->st_value
, LONG_HEX
);
1433 printf (is_32bit_elf
? " " : " ");
1435 if (psym
->st_name
== 0)
1437 const char *sec_name
= "<null>";
1440 if (ELF_ST_TYPE (psym
->st_info
) == STT_SECTION
)
1442 bfd_vma sec_index
= (bfd_vma
) -1;
1444 if (psym
->st_shndx
< SHN_LORESERVE
)
1445 sec_index
= psym
->st_shndx
;
1446 else if (psym
->st_shndx
> SHN_LORESERVE
)
1447 sec_index
= psym
->st_shndx
- (SHN_HIRESERVE
+ 1
1450 if (sec_index
!= (bfd_vma
) -1)
1451 sec_name
= SECTION_NAME (section_headers
+ sec_index
);
1452 else if (psym
->st_shndx
== SHN_ABS
)
1454 else if (psym
->st_shndx
== SHN_COMMON
)
1455 sec_name
= "COMMON";
1458 sprintf (name_buf
, "<section 0x%x>",
1459 (unsigned int) psym
->st_shndx
);
1460 sec_name
= name_buf
;
1463 print_symbol (22, sec_name
);
1465 else if (strtab
== NULL
)
1466 printf (_("<string table index %3ld>"), psym
->st_name
);
1468 print_symbol (22, strtab
+ psym
->st_name
);
1471 printf (" + %lx", (unsigned long) rels
[i
].r_addend
);
1476 printf ("%*c", is_32bit_elf
? (do_wide
? 34 : 28) : (do_wide
? 26 : 20), ' ');
1477 print_vma (rels
[i
].r_addend
, LONG_HEX
);
1480 if (elf_header
.e_machine
== EM_SPARCV9
1481 && !strcmp (rtype
, "R_SPARC_OLO10"))
1482 printf (" + %lx", (unsigned long) ELF64_R_TYPE_DATA (info
));
1486 if (! is_32bit_elf
&& elf_header
.e_machine
== EM_MIPS
)
1488 printf (" Type2: ");
1491 #ifdef _bfd_int64_low
1492 printf (_("unrecognized: %-7lx"), _bfd_int64_low (type2
));
1494 printf (_("unrecognized: %-7lx"), type2
);
1497 printf ("%-17.17s", rtype2
);
1499 printf("\n Type3: ");
1502 #ifdef _bfd_int64_low
1503 printf (_("unrecognized: %-7lx"), _bfd_int64_low (type3
));
1505 printf (_("unrecognized: %-7lx"), type3
);
1508 printf ("%-17.17s", rtype3
);
1520 get_mips_dynamic_type (type
)
1525 case DT_MIPS_RLD_VERSION
: return "MIPS_RLD_VERSION";
1526 case DT_MIPS_TIME_STAMP
: return "MIPS_TIME_STAMP";
1527 case DT_MIPS_ICHECKSUM
: return "MIPS_ICHECKSUM";
1528 case DT_MIPS_IVERSION
: return "MIPS_IVERSION";
1529 case DT_MIPS_FLAGS
: return "MIPS_FLAGS";
1530 case DT_MIPS_BASE_ADDRESS
: return "MIPS_BASE_ADDRESS";
1531 case DT_MIPS_MSYM
: return "MIPS_MSYM";
1532 case DT_MIPS_CONFLICT
: return "MIPS_CONFLICT";
1533 case DT_MIPS_LIBLIST
: return "MIPS_LIBLIST";
1534 case DT_MIPS_LOCAL_GOTNO
: return "MIPS_LOCAL_GOTNO";
1535 case DT_MIPS_CONFLICTNO
: return "MIPS_CONFLICTNO";
1536 case DT_MIPS_LIBLISTNO
: return "MIPS_LIBLISTNO";
1537 case DT_MIPS_SYMTABNO
: return "MIPS_SYMTABNO";
1538 case DT_MIPS_UNREFEXTNO
: return "MIPS_UNREFEXTNO";
1539 case DT_MIPS_GOTSYM
: return "MIPS_GOTSYM";
1540 case DT_MIPS_HIPAGENO
: return "MIPS_HIPAGENO";
1541 case DT_MIPS_RLD_MAP
: return "MIPS_RLD_MAP";
1542 case DT_MIPS_DELTA_CLASS
: return "MIPS_DELTA_CLASS";
1543 case DT_MIPS_DELTA_CLASS_NO
: return "MIPS_DELTA_CLASS_NO";
1544 case DT_MIPS_DELTA_INSTANCE
: return "MIPS_DELTA_INSTANCE";
1545 case DT_MIPS_DELTA_INSTANCE_NO
: return "MIPS_DELTA_INSTANCE_NO";
1546 case DT_MIPS_DELTA_RELOC
: return "MIPS_DELTA_RELOC";
1547 case DT_MIPS_DELTA_RELOC_NO
: return "MIPS_DELTA_RELOC_NO";
1548 case DT_MIPS_DELTA_SYM
: return "MIPS_DELTA_SYM";
1549 case DT_MIPS_DELTA_SYM_NO
: return "MIPS_DELTA_SYM_NO";
1550 case DT_MIPS_DELTA_CLASSSYM
: return "MIPS_DELTA_CLASSSYM";
1551 case DT_MIPS_DELTA_CLASSSYM_NO
: return "MIPS_DELTA_CLASSSYM_NO";
1552 case DT_MIPS_CXX_FLAGS
: return "MIPS_CXX_FLAGS";
1553 case DT_MIPS_PIXIE_INIT
: return "MIPS_PIXIE_INIT";
1554 case DT_MIPS_SYMBOL_LIB
: return "MIPS_SYMBOL_LIB";
1555 case DT_MIPS_LOCALPAGE_GOTIDX
: return "MIPS_LOCALPAGE_GOTIDX";
1556 case DT_MIPS_LOCAL_GOTIDX
: return "MIPS_LOCAL_GOTIDX";
1557 case DT_MIPS_HIDDEN_GOTIDX
: return "MIPS_HIDDEN_GOTIDX";
1558 case DT_MIPS_PROTECTED_GOTIDX
: return "MIPS_PROTECTED_GOTIDX";
1559 case DT_MIPS_OPTIONS
: return "MIPS_OPTIONS";
1560 case DT_MIPS_INTERFACE
: return "MIPS_INTERFACE";
1561 case DT_MIPS_DYNSTR_ALIGN
: return "MIPS_DYNSTR_ALIGN";
1562 case DT_MIPS_INTERFACE_SIZE
: return "MIPS_INTERFACE_SIZE";
1563 case DT_MIPS_RLD_TEXT_RESOLVE_ADDR
: return "MIPS_RLD_TEXT_RESOLVE_ADDR";
1564 case DT_MIPS_PERF_SUFFIX
: return "MIPS_PERF_SUFFIX";
1565 case DT_MIPS_COMPACT_SIZE
: return "MIPS_COMPACT_SIZE";
1566 case DT_MIPS_GP_VALUE
: return "MIPS_GP_VALUE";
1567 case DT_MIPS_AUX_DYNAMIC
: return "MIPS_AUX_DYNAMIC";
1574 get_sparc64_dynamic_type (type
)
1579 case DT_SPARC_REGISTER
: return "SPARC_REGISTER";
1586 get_ppc64_dynamic_type (type
)
1591 case DT_PPC64_GLINK
: return "PPC64_GLINK";
1592 case DT_PPC64_OPD
: return "PPC64_OPD";
1593 case DT_PPC64_OPDSZ
: return "PPC64_OPDSZ";
1600 get_parisc_dynamic_type (type
)
1605 case DT_HP_LOAD_MAP
: return "HP_LOAD_MAP";
1606 case DT_HP_DLD_FLAGS
: return "HP_DLD_FLAGS";
1607 case DT_HP_DLD_HOOK
: return "HP_DLD_HOOK";
1608 case DT_HP_UX10_INIT
: return "HP_UX10_INIT";
1609 case DT_HP_UX10_INITSZ
: return "HP_UX10_INITSZ";
1610 case DT_HP_PREINIT
: return "HP_PREINIT";
1611 case DT_HP_PREINITSZ
: return "HP_PREINITSZ";
1612 case DT_HP_NEEDED
: return "HP_NEEDED";
1613 case DT_HP_TIME_STAMP
: return "HP_TIME_STAMP";
1614 case DT_HP_CHECKSUM
: return "HP_CHECKSUM";
1615 case DT_HP_GST_SIZE
: return "HP_GST_SIZE";
1616 case DT_HP_GST_VERSION
: return "HP_GST_VERSION";
1617 case DT_HP_GST_HASHVAL
: return "HP_GST_HASHVAL";
1624 get_ia64_dynamic_type (type
)
1629 case DT_IA_64_PLT_RESERVE
: return "IA_64_PLT_RESERVE";
1636 get_dynamic_type (type
)
1639 static char buff
[32];
1643 case DT_NULL
: return "NULL";
1644 case DT_NEEDED
: return "NEEDED";
1645 case DT_PLTRELSZ
: return "PLTRELSZ";
1646 case DT_PLTGOT
: return "PLTGOT";
1647 case DT_HASH
: return "HASH";
1648 case DT_STRTAB
: return "STRTAB";
1649 case DT_SYMTAB
: return "SYMTAB";
1650 case DT_RELA
: return "RELA";
1651 case DT_RELASZ
: return "RELASZ";
1652 case DT_RELAENT
: return "RELAENT";
1653 case DT_STRSZ
: return "STRSZ";
1654 case DT_SYMENT
: return "SYMENT";
1655 case DT_INIT
: return "INIT";
1656 case DT_FINI
: return "FINI";
1657 case DT_SONAME
: return "SONAME";
1658 case DT_RPATH
: return "RPATH";
1659 case DT_SYMBOLIC
: return "SYMBOLIC";
1660 case DT_REL
: return "REL";
1661 case DT_RELSZ
: return "RELSZ";
1662 case DT_RELENT
: return "RELENT";
1663 case DT_PLTREL
: return "PLTREL";
1664 case DT_DEBUG
: return "DEBUG";
1665 case DT_TEXTREL
: return "TEXTREL";
1666 case DT_JMPREL
: return "JMPREL";
1667 case DT_BIND_NOW
: return "BIND_NOW";
1668 case DT_INIT_ARRAY
: return "INIT_ARRAY";
1669 case DT_FINI_ARRAY
: return "FINI_ARRAY";
1670 case DT_INIT_ARRAYSZ
: return "INIT_ARRAYSZ";
1671 case DT_FINI_ARRAYSZ
: return "FINI_ARRAYSZ";
1672 case DT_RUNPATH
: return "RUNPATH";
1673 case DT_FLAGS
: return "FLAGS";
1675 case DT_PREINIT_ARRAY
: return "PREINIT_ARRAY";
1676 case DT_PREINIT_ARRAYSZ
: return "PREINIT_ARRAYSZ";
1678 case DT_CHECKSUM
: return "CHECKSUM";
1679 case DT_PLTPADSZ
: return "PLTPADSZ";
1680 case DT_MOVEENT
: return "MOVEENT";
1681 case DT_MOVESZ
: return "MOVESZ";
1682 case DT_FEATURE
: return "FEATURE";
1683 case DT_POSFLAG_1
: return "POSFLAG_1";
1684 case DT_SYMINSZ
: return "SYMINSZ";
1685 case DT_SYMINENT
: return "SYMINENT"; /* aka VALRNGHI */
1687 case DT_ADDRRNGLO
: return "ADDRRNGLO";
1688 case DT_CONFIG
: return "CONFIG";
1689 case DT_DEPAUDIT
: return "DEPAUDIT";
1690 case DT_AUDIT
: return "AUDIT";
1691 case DT_PLTPAD
: return "PLTPAD";
1692 case DT_MOVETAB
: return "MOVETAB";
1693 case DT_SYMINFO
: return "SYMINFO"; /* aka ADDRRNGHI */
1695 case DT_VERSYM
: return "VERSYM";
1697 case DT_RELACOUNT
: return "RELACOUNT";
1698 case DT_RELCOUNT
: return "RELCOUNT";
1699 case DT_FLAGS_1
: return "FLAGS_1";
1700 case DT_VERDEF
: return "VERDEF";
1701 case DT_VERDEFNUM
: return "VERDEFNUM";
1702 case DT_VERNEED
: return "VERNEED";
1703 case DT_VERNEEDNUM
: return "VERNEEDNUM";
1705 case DT_AUXILIARY
: return "AUXILIARY";
1706 case DT_USED
: return "USED";
1707 case DT_FILTER
: return "FILTER";
1709 case DT_GNU_PRELINKED
: return "GNU_PRELINKED";
1710 case DT_GNU_CONFLICT
: return "GNU_CONFLICT";
1711 case DT_GNU_CONFLICTSZ
: return "GNU_CONFLICTSZ";
1712 case DT_GNU_LIBLIST
: return "GNU_LIBLIST";
1713 case DT_GNU_LIBLISTSZ
: return "GNU_LIBLISTSZ";
1716 if ((type
>= DT_LOPROC
) && (type
<= DT_HIPROC
))
1720 switch (elf_header
.e_machine
)
1723 case EM_MIPS_RS3_LE
:
1724 result
= get_mips_dynamic_type (type
);
1727 result
= get_sparc64_dynamic_type (type
);
1730 result
= get_ppc64_dynamic_type (type
);
1733 result
= get_ia64_dynamic_type (type
);
1743 sprintf (buff
, _("Processor Specific: %lx"), type
);
1745 else if ((type
>= DT_LOOS
) && (type
<= DT_HIOS
))
1749 switch (elf_header
.e_machine
)
1752 result
= get_parisc_dynamic_type (type
);
1762 sprintf (buff
, _("Operating System specific: %lx"), type
);
1765 sprintf (buff
, _("<unknown>: %lx"), type
);
1772 get_file_type (e_type
)
1775 static char buff
[32];
1779 case ET_NONE
: return _("NONE (None)");
1780 case ET_REL
: return _("REL (Relocatable file)");
1781 case ET_EXEC
: return _("EXEC (Executable file)");
1782 case ET_DYN
: return _("DYN (Shared object file)");
1783 case ET_CORE
: return _("CORE (Core file)");
1786 if ((e_type
>= ET_LOPROC
) && (e_type
<= ET_HIPROC
))
1787 sprintf (buff
, _("Processor Specific: (%x)"), e_type
);
1788 else if ((e_type
>= ET_LOOS
) && (e_type
<= ET_HIOS
))
1789 sprintf (buff
, _("OS Specific: (%x)"), e_type
);
1791 sprintf (buff
, _("<unknown>: %x"), e_type
);
1797 get_machine_name (e_machine
)
1800 static char buff
[64]; /* XXX */
1804 case EM_NONE
: return _("None");
1805 case EM_M32
: return "WE32100";
1806 case EM_SPARC
: return "Sparc";
1807 case EM_386
: return "Intel 80386";
1808 case EM_68K
: return "MC68000";
1809 case EM_88K
: return "MC88000";
1810 case EM_486
: return "Intel 80486";
1811 case EM_860
: return "Intel 80860";
1812 case EM_MIPS
: return "MIPS R3000";
1813 case EM_S370
: return "IBM System/370";
1814 case EM_MIPS_RS3_LE
: return "MIPS R4000 big-endian";
1815 case EM_OLD_SPARCV9
: return "Sparc v9 (old)";
1816 case EM_PARISC
: return "HPPA";
1817 case EM_PPC_OLD
: return "Power PC (old)";
1818 case EM_SPARC32PLUS
: return "Sparc v8+" ;
1819 case EM_960
: return "Intel 90860";
1820 case EM_PPC
: return "PowerPC";
1821 case EM_PPC64
: return "PowerPC64";
1822 case EM_V800
: return "NEC V800";
1823 case EM_FR20
: return "Fujitsu FR20";
1824 case EM_RH32
: return "TRW RH32";
1825 case EM_MCORE
: return "MCORE";
1826 case EM_ARM
: return "ARM";
1827 case EM_OLD_ALPHA
: return "Digital Alpha (old)";
1828 case EM_SH
: return "Renesas / SuperH SH";
1829 case EM_SPARCV9
: return "Sparc v9";
1830 case EM_TRICORE
: return "Siemens Tricore";
1831 case EM_ARC
: return "ARC";
1832 case EM_H8_300
: return "Renesas H8/300";
1833 case EM_H8_300H
: return "Renesas H8/300H";
1834 case EM_H8S
: return "Renesas H8S";
1835 case EM_H8_500
: return "Renesas H8/500";
1836 case EM_IA_64
: return "Intel IA-64";
1837 case EM_MIPS_X
: return "Stanford MIPS-X";
1838 case EM_COLDFIRE
: return "Motorola Coldfire";
1839 case EM_68HC12
: return "Motorola M68HC12";
1840 case EM_ALPHA
: return "Alpha";
1841 case EM_CYGNUS_D10V
:
1842 case EM_D10V
: return "d10v";
1843 case EM_CYGNUS_D30V
:
1844 case EM_D30V
: return "d30v";
1845 case EM_CYGNUS_M32R
:
1846 case EM_M32R
: return "Renesas M32R (formerly Mitsubishi M32r)";
1847 case EM_CYGNUS_V850
:
1848 case EM_V850
: return "NEC v850";
1849 case EM_CYGNUS_MN10300
:
1850 case EM_MN10300
: return "mn10300";
1851 case EM_CYGNUS_MN10200
:
1852 case EM_MN10200
: return "mn10200";
1853 case EM_CYGNUS_FR30
:
1854 case EM_FR30
: return "Fujitsu FR30";
1855 case EM_CYGNUS_FRV
: return "Fujitsu FR-V";
1857 case EM_PJ
: return "picoJava";
1858 case EM_MMA
: return "Fujitsu Multimedia Accelerator";
1859 case EM_PCP
: return "Siemens PCP";
1860 case EM_NCPU
: return "Sony nCPU embedded RISC processor";
1861 case EM_NDR1
: return "Denso NDR1 microprocesspr";
1862 case EM_STARCORE
: return "Motorola Star*Core processor";
1863 case EM_ME16
: return "Toyota ME16 processor";
1864 case EM_ST100
: return "STMicroelectronics ST100 processor";
1865 case EM_TINYJ
: return "Advanced Logic Corp. TinyJ embedded processor";
1866 case EM_FX66
: return "Siemens FX66 microcontroller";
1867 case EM_ST9PLUS
: return "STMicroelectronics ST9+ 8/16 bit microcontroller";
1868 case EM_ST7
: return "STMicroelectronics ST7 8-bit microcontroller";
1869 case EM_68HC16
: return "Motorola MC68HC16 Microcontroller";
1870 case EM_68HC11
: return "Motorola MC68HC11 Microcontroller";
1871 case EM_68HC08
: return "Motorola MC68HC08 Microcontroller";
1872 case EM_68HC05
: return "Motorola MC68HC05 Microcontroller";
1873 case EM_SVX
: return "Silicon Graphics SVx";
1874 case EM_ST19
: return "STMicroelectronics ST19 8-bit microcontroller";
1875 case EM_VAX
: return "Digital VAX";
1877 case EM_AVR
: return "Atmel AVR 8-bit microcontroller";
1878 case EM_CRIS
: return "Axis Communications 32-bit embedded processor";
1879 case EM_JAVELIN
: return "Infineon Technologies 32-bit embedded cpu";
1880 case EM_FIREPATH
: return "Element 14 64-bit DSP processor";
1881 case EM_ZSP
: return "LSI Logic's 16-bit DSP processor";
1882 case EM_MMIX
: return "Donald Knuth's educational 64-bit processor";
1883 case EM_HUANY
: return "Harvard Universitys's machine-independent object format";
1884 case EM_PRISM
: return "Vitesse Prism";
1885 case EM_X86_64
: return "Advanced Micro Devices X86-64";
1887 case EM_S390
: return "IBM S/390";
1888 case EM_XSTORMY16
: return "Sanyo Xstormy16 CPU core";
1890 case EM_OR32
: return "OpenRISC";
1891 case EM_DLX
: return "OpenDLX";
1893 case EM_IP2K
: return "Ubicom IP2xxx 8-bit microcontrollers";
1894 case EM_IQ2000
: return "Vitesse IQ2000";
1896 case EM_XTENSA
: return "Tensilica Xtensa Processor";
1898 sprintf (buff
, _("<unknown>: %x"), e_machine
);
1904 decode_ARM_machine_flags (e_flags
, buf
)
1911 eabi
= EF_ARM_EABI_VERSION (e_flags
);
1912 e_flags
&= ~ EF_ARM_EABIMASK
;
1914 /* Handle "generic" ARM flags. */
1915 if (e_flags
& EF_ARM_RELEXEC
)
1917 strcat (buf
, ", relocatable executable");
1918 e_flags
&= ~ EF_ARM_RELEXEC
;
1921 if (e_flags
& EF_ARM_HASENTRY
)
1923 strcat (buf
, ", has entry point");
1924 e_flags
&= ~ EF_ARM_HASENTRY
;
1927 /* Now handle EABI specific flags. */
1931 strcat (buf
, ", <unrecognized EABI>");
1936 case EF_ARM_EABI_VER1
:
1937 strcat (buf
, ", Version1 EABI");
1942 /* Process flags one bit at a time. */
1943 flag
= e_flags
& - e_flags
;
1948 case EF_ARM_SYMSARESORTED
: /* Conflicts with EF_ARM_INTERWORK. */
1949 strcat (buf
, ", sorted symbol tables");
1959 case EF_ARM_EABI_VER2
:
1960 strcat (buf
, ", Version2 EABI");
1965 /* Process flags one bit at a time. */
1966 flag
= e_flags
& - e_flags
;
1971 case EF_ARM_SYMSARESORTED
: /* Conflicts with EF_ARM_INTERWORK. */
1972 strcat (buf
, ", sorted symbol tables");
1975 case EF_ARM_DYNSYMSUSESEGIDX
:
1976 strcat (buf
, ", dynamic symbols use segment index");
1979 case EF_ARM_MAPSYMSFIRST
:
1980 strcat (buf
, ", mapping symbols precede others");
1990 case EF_ARM_EABI_UNKNOWN
:
1991 strcat (buf
, ", GNU EABI");
1996 /* Process flags one bit at a time. */
1997 flag
= e_flags
& - e_flags
;
2002 case EF_ARM_INTERWORK
:
2003 strcat (buf
, ", interworking enabled");
2006 case EF_ARM_APCS_26
:
2007 strcat (buf
, ", uses APCS/26");
2010 case EF_ARM_APCS_FLOAT
:
2011 strcat (buf
, ", uses APCS/float");
2015 strcat (buf
, ", position independent");
2019 strcat (buf
, ", 8 bit structure alignment");
2022 case EF_ARM_NEW_ABI
:
2023 strcat (buf
, ", uses new ABI");
2026 case EF_ARM_OLD_ABI
:
2027 strcat (buf
, ", uses old ABI");
2030 case EF_ARM_SOFT_FLOAT
:
2031 strcat (buf
, ", software FP");
2034 case EF_ARM_MAVERICK_FLOAT
:
2035 strcat (buf
, ", Maverick FP");
2046 strcat (buf
,", <unknown>");
2050 get_machine_flags (e_flags
, e_machine
)
2054 static char buf
[1024];
2066 decode_ARM_machine_flags (e_flags
, buf
);
2070 if (e_flags
& EF_CPU32
)
2071 strcat (buf
, ", cpu32");
2072 if (e_flags
& EF_M68000
)
2073 strcat (buf
, ", m68000");
2077 if (e_flags
& EF_PPC_EMB
)
2078 strcat (buf
, ", emb");
2080 if (e_flags
& EF_PPC_RELOCATABLE
)
2081 strcat (buf
, ", relocatable");
2083 if (e_flags
& EF_PPC_RELOCATABLE_LIB
)
2084 strcat (buf
, ", relocatable-lib");
2088 case EM_CYGNUS_V850
:
2089 switch (e_flags
& EF_V850_ARCH
)
2092 strcat (buf
, ", v850e");
2095 strcat (buf
, ", v850");
2098 strcat (buf
, ", unknown v850 architecture variant");
2104 case EM_CYGNUS_M32R
:
2105 if ((e_flags
& EF_M32R_ARCH
) == E_M32R_ARCH
)
2106 strcat (buf
, ", m32r");
2111 case EM_MIPS_RS3_LE
:
2112 if (e_flags
& EF_MIPS_NOREORDER
)
2113 strcat (buf
, ", noreorder");
2115 if (e_flags
& EF_MIPS_PIC
)
2116 strcat (buf
, ", pic");
2118 if (e_flags
& EF_MIPS_CPIC
)
2119 strcat (buf
, ", cpic");
2121 if (e_flags
& EF_MIPS_UCODE
)
2122 strcat (buf
, ", ugen_reserved");
2124 if (e_flags
& EF_MIPS_ABI2
)
2125 strcat (buf
, ", abi2");
2127 if (e_flags
& EF_MIPS_OPTIONS_FIRST
)
2128 strcat (buf
, ", odk first");
2130 if (e_flags
& EF_MIPS_32BITMODE
)
2131 strcat (buf
, ", 32bitmode");
2133 switch ((e_flags
& EF_MIPS_MACH
))
2135 case E_MIPS_MACH_3900
: strcat (buf
, ", 3900"); break;
2136 case E_MIPS_MACH_4010
: strcat (buf
, ", 4010"); break;
2137 case E_MIPS_MACH_4100
: strcat (buf
, ", 4100"); break;
2138 case E_MIPS_MACH_4111
: strcat (buf
, ", 4111"); break;
2139 case E_MIPS_MACH_4120
: strcat (buf
, ", 4120"); break;
2140 case E_MIPS_MACH_4650
: strcat (buf
, ", 4650"); break;
2141 case E_MIPS_MACH_5400
: strcat (buf
, ", 5400"); break;
2142 case E_MIPS_MACH_5500
: strcat (buf
, ", 5500"); break;
2143 case E_MIPS_MACH_SB1
: strcat (buf
, ", sb1"); break;
2145 /* We simply ignore the field in this case to avoid confusion:
2146 MIPS ELF does not specify EF_MIPS_MACH, it is a GNU
2149 default: strcat (buf
, ", unknown CPU"); break;
2152 switch ((e_flags
& EF_MIPS_ABI
))
2154 case E_MIPS_ABI_O32
: strcat (buf
, ", o32"); break;
2155 case E_MIPS_ABI_O64
: strcat (buf
, ", o64"); break;
2156 case E_MIPS_ABI_EABI32
: strcat (buf
, ", eabi32"); break;
2157 case E_MIPS_ABI_EABI64
: strcat (buf
, ", eabi64"); break;
2159 /* We simply ignore the field in this case to avoid confusion:
2160 MIPS ELF does not specify EF_MIPS_ABI, it is a GNU extension.
2161 This means it is likely to be an o32 file, but not for
2164 default: strcat (buf
, ", unknown ABI"); break;
2167 if (e_flags
& EF_MIPS_ARCH_ASE_MDMX
)
2168 strcat (buf
, ", mdmx");
2170 if (e_flags
& EF_MIPS_ARCH_ASE_M16
)
2171 strcat (buf
, ", mips16");
2173 switch ((e_flags
& EF_MIPS_ARCH
))
2175 case E_MIPS_ARCH_1
: strcat (buf
, ", mips1"); break;
2176 case E_MIPS_ARCH_2
: strcat (buf
, ", mips2"); break;
2177 case E_MIPS_ARCH_3
: strcat (buf
, ", mips3"); break;
2178 case E_MIPS_ARCH_4
: strcat (buf
, ", mips4"); break;
2179 case E_MIPS_ARCH_5
: strcat (buf
, ", mips5"); break;
2180 case E_MIPS_ARCH_32
: strcat (buf
, ", mips32"); break;
2181 case E_MIPS_ARCH_32R2
: strcat (buf
, ", mips32r2"); break;
2182 case E_MIPS_ARCH_64
: strcat (buf
, ", mips64"); break;
2183 default: strcat (buf
, ", unknown ISA"); break;
2189 if (e_flags
& EF_SPARC_32PLUS
)
2190 strcat (buf
, ", v8+");
2192 if (e_flags
& EF_SPARC_SUN_US1
)
2193 strcat (buf
, ", ultrasparcI");
2195 if (e_flags
& EF_SPARC_SUN_US3
)
2196 strcat (buf
, ", ultrasparcIII");
2198 if (e_flags
& EF_SPARC_HAL_R1
)
2199 strcat (buf
, ", halr1");
2201 if (e_flags
& EF_SPARC_LEDATA
)
2202 strcat (buf
, ", ledata");
2204 if ((e_flags
& EF_SPARCV9_MM
) == EF_SPARCV9_TSO
)
2205 strcat (buf
, ", tso");
2207 if ((e_flags
& EF_SPARCV9_MM
) == EF_SPARCV9_PSO
)
2208 strcat (buf
, ", pso");
2210 if ((e_flags
& EF_SPARCV9_MM
) == EF_SPARCV9_RMO
)
2211 strcat (buf
, ", rmo");
2215 switch (e_flags
& EF_PARISC_ARCH
)
2217 case EFA_PARISC_1_0
:
2218 strcpy (buf
, ", PA-RISC 1.0");
2220 case EFA_PARISC_1_1
:
2221 strcpy (buf
, ", PA-RISC 1.1");
2223 case EFA_PARISC_2_0
:
2224 strcpy (buf
, ", PA-RISC 2.0");
2229 if (e_flags
& EF_PARISC_TRAPNIL
)
2230 strcat (buf
, ", trapnil");
2231 if (e_flags
& EF_PARISC_EXT
)
2232 strcat (buf
, ", ext");
2233 if (e_flags
& EF_PARISC_LSB
)
2234 strcat (buf
, ", lsb");
2235 if (e_flags
& EF_PARISC_WIDE
)
2236 strcat (buf
, ", wide");
2237 if (e_flags
& EF_PARISC_NO_KABP
)
2238 strcat (buf
, ", no kabp");
2239 if (e_flags
& EF_PARISC_LAZYSWAP
)
2240 strcat (buf
, ", lazyswap");
2245 if ((e_flags
& EF_PICOJAVA_NEWCALLS
) == EF_PICOJAVA_NEWCALLS
)
2246 strcat (buf
, ", new calling convention");
2248 if ((e_flags
& EF_PICOJAVA_GNUCALLS
) == EF_PICOJAVA_GNUCALLS
)
2249 strcat (buf
, ", gnu calling convention");
2253 if ((e_flags
& EF_IA_64_ABI64
))
2254 strcat (buf
, ", 64-bit");
2256 strcat (buf
, ", 32-bit");
2257 if ((e_flags
& EF_IA_64_REDUCEDFP
))
2258 strcat (buf
, ", reduced fp model");
2259 if ((e_flags
& EF_IA_64_NOFUNCDESC_CONS_GP
))
2260 strcat (buf
, ", no function descriptors, constant gp");
2261 else if ((e_flags
& EF_IA_64_CONS_GP
))
2262 strcat (buf
, ", constant gp");
2263 if ((e_flags
& EF_IA_64_ABSOLUTE
))
2264 strcat (buf
, ", absolute");
2268 if ((e_flags
& EF_VAX_NONPIC
))
2269 strcat (buf
, ", non-PIC");
2270 if ((e_flags
& EF_VAX_DFLOAT
))
2271 strcat (buf
, ", D-Float");
2272 if ((e_flags
& EF_VAX_GFLOAT
))
2273 strcat (buf
, ", G-Float");
2282 get_mips_segment_type (type
)
2287 case PT_MIPS_REGINFO
:
2289 case PT_MIPS_RTPROC
:
2291 case PT_MIPS_OPTIONS
:
2301 get_parisc_segment_type (type
)
2306 case PT_HP_TLS
: return "HP_TLS";
2307 case PT_HP_CORE_NONE
: return "HP_CORE_NONE";
2308 case PT_HP_CORE_VERSION
: return "HP_CORE_VERSION";
2309 case PT_HP_CORE_KERNEL
: return "HP_CORE_KERNEL";
2310 case PT_HP_CORE_COMM
: return "HP_CORE_COMM";
2311 case PT_HP_CORE_PROC
: return "HP_CORE_PROC";
2312 case PT_HP_CORE_LOADABLE
: return "HP_CORE_LOADABLE";
2313 case PT_HP_CORE_STACK
: return "HP_CORE_STACK";
2314 case PT_HP_CORE_SHM
: return "HP_CORE_SHM";
2315 case PT_HP_CORE_MMF
: return "HP_CORE_MMF";
2316 case PT_HP_PARALLEL
: return "HP_PARALLEL";
2317 case PT_HP_FASTBIND
: return "HP_FASTBIND";
2318 case PT_PARISC_ARCHEXT
: return "PARISC_ARCHEXT";
2319 case PT_PARISC_UNWIND
: return "PARISC_UNWIND";
2328 get_ia64_segment_type (type
)
2333 case PT_IA_64_ARCHEXT
: return "IA_64_ARCHEXT";
2334 case PT_IA_64_UNWIND
: return "IA_64_UNWIND";
2335 case PT_HP_TLS
: return "HP_TLS";
2336 case PT_IA_64_HP_OPT_ANOT
: return "HP_OPT_ANNOT";
2337 case PT_IA_64_HP_HSL_ANOT
: return "HP_HSL_ANNOT";
2338 case PT_IA_64_HP_STACK
: return "HP_STACK";
2347 get_segment_type (p_type
)
2348 unsigned long p_type
;
2350 static char buff
[32];
2354 case PT_NULL
: return "NULL";
2355 case PT_LOAD
: return "LOAD";
2356 case PT_DYNAMIC
: return "DYNAMIC";
2357 case PT_INTERP
: return "INTERP";
2358 case PT_NOTE
: return "NOTE";
2359 case PT_SHLIB
: return "SHLIB";
2360 case PT_PHDR
: return "PHDR";
2361 case PT_TLS
: return "TLS";
2363 case PT_GNU_EH_FRAME
:
2364 return "GNU_EH_FRAME";
2365 case PT_GNU_STACK
: return "STACK";
2368 if ((p_type
>= PT_LOPROC
) && (p_type
<= PT_HIPROC
))
2372 switch (elf_header
.e_machine
)
2375 case EM_MIPS_RS3_LE
:
2376 result
= get_mips_segment_type (p_type
);
2379 result
= get_parisc_segment_type (p_type
);
2382 result
= get_ia64_segment_type (p_type
);
2392 sprintf (buff
, "LOPROC+%lx", p_type
- PT_LOPROC
);
2394 else if ((p_type
>= PT_LOOS
) && (p_type
<= PT_HIOS
))
2398 switch (elf_header
.e_machine
)
2401 result
= get_parisc_segment_type (p_type
);
2404 result
= get_ia64_segment_type (p_type
);
2414 sprintf (buff
, "LOOS+%lx", p_type
- PT_LOOS
);
2417 sprintf (buff
, _("<unknown>: %lx"), p_type
);
2424 get_mips_section_type_name (sh_type
)
2425 unsigned int sh_type
;
2429 case SHT_MIPS_LIBLIST
: return "MIPS_LIBLIST";
2430 case SHT_MIPS_MSYM
: return "MIPS_MSYM";
2431 case SHT_MIPS_CONFLICT
: return "MIPS_CONFLICT";
2432 case SHT_MIPS_GPTAB
: return "MIPS_GPTAB";
2433 case SHT_MIPS_UCODE
: return "MIPS_UCODE";
2434 case SHT_MIPS_DEBUG
: return "MIPS_DEBUG";
2435 case SHT_MIPS_REGINFO
: return "MIPS_REGINFO";
2436 case SHT_MIPS_PACKAGE
: return "MIPS_PACKAGE";
2437 case SHT_MIPS_PACKSYM
: return "MIPS_PACKSYM";
2438 case SHT_MIPS_RELD
: return "MIPS_RELD";
2439 case SHT_MIPS_IFACE
: return "MIPS_IFACE";
2440 case SHT_MIPS_CONTENT
: return "MIPS_CONTENT";
2441 case SHT_MIPS_OPTIONS
: return "MIPS_OPTIONS";
2442 case SHT_MIPS_SHDR
: return "MIPS_SHDR";
2443 case SHT_MIPS_FDESC
: return "MIPS_FDESC";
2444 case SHT_MIPS_EXTSYM
: return "MIPS_EXTSYM";
2445 case SHT_MIPS_DENSE
: return "MIPS_DENSE";
2446 case SHT_MIPS_PDESC
: return "MIPS_PDESC";
2447 case SHT_MIPS_LOCSYM
: return "MIPS_LOCSYM";
2448 case SHT_MIPS_AUXSYM
: return "MIPS_AUXSYM";
2449 case SHT_MIPS_OPTSYM
: return "MIPS_OPTSYM";
2450 case SHT_MIPS_LOCSTR
: return "MIPS_LOCSTR";
2451 case SHT_MIPS_LINE
: return "MIPS_LINE";
2452 case SHT_MIPS_RFDESC
: return "MIPS_RFDESC";
2453 case SHT_MIPS_DELTASYM
: return "MIPS_DELTASYM";
2454 case SHT_MIPS_DELTAINST
: return "MIPS_DELTAINST";
2455 case SHT_MIPS_DELTACLASS
: return "MIPS_DELTACLASS";
2456 case SHT_MIPS_DWARF
: return "MIPS_DWARF";
2457 case SHT_MIPS_DELTADECL
: return "MIPS_DELTADECL";
2458 case SHT_MIPS_SYMBOL_LIB
: return "MIPS_SYMBOL_LIB";
2459 case SHT_MIPS_EVENTS
: return "MIPS_EVENTS";
2460 case SHT_MIPS_TRANSLATE
: return "MIPS_TRANSLATE";
2461 case SHT_MIPS_PIXIE
: return "MIPS_PIXIE";
2462 case SHT_MIPS_XLATE
: return "MIPS_XLATE";
2463 case SHT_MIPS_XLATE_DEBUG
: return "MIPS_XLATE_DEBUG";
2464 case SHT_MIPS_WHIRL
: return "MIPS_WHIRL";
2465 case SHT_MIPS_EH_REGION
: return "MIPS_EH_REGION";
2466 case SHT_MIPS_XLATE_OLD
: return "MIPS_XLATE_OLD";
2467 case SHT_MIPS_PDR_EXCEPTION
: return "MIPS_PDR_EXCEPTION";
2475 get_parisc_section_type_name (sh_type
)
2476 unsigned int sh_type
;
2480 case SHT_PARISC_EXT
: return "PARISC_EXT";
2481 case SHT_PARISC_UNWIND
: return "PARISC_UNWIND";
2482 case SHT_PARISC_DOC
: return "PARISC_DOC";
2490 get_ia64_section_type_name (sh_type
)
2491 unsigned int sh_type
;
2493 /* If the top 8 bits are 0x78 the next 8 are the os/abi ID. */
2494 if ((sh_type
& 0xFF000000) == SHT_IA_64_LOPSREG
)
2495 return get_osabi_name ((sh_type
& 0x00FF0000) >> 16);
2499 case SHT_IA_64_EXT
: return "IA_64_EXT";
2500 case SHT_IA_64_UNWIND
: return "IA_64_UNWIND";
2501 case SHT_IA_64_PRIORITY_INIT
: return "IA_64_PRIORITY_INIT";
2509 get_section_type_name (sh_type
)
2510 unsigned int sh_type
;
2512 static char buff
[32];
2516 case SHT_NULL
: return "NULL";
2517 case SHT_PROGBITS
: return "PROGBITS";
2518 case SHT_SYMTAB
: return "SYMTAB";
2519 case SHT_STRTAB
: return "STRTAB";
2520 case SHT_RELA
: return "RELA";
2521 case SHT_HASH
: return "HASH";
2522 case SHT_DYNAMIC
: return "DYNAMIC";
2523 case SHT_NOTE
: return "NOTE";
2524 case SHT_NOBITS
: return "NOBITS";
2525 case SHT_REL
: return "REL";
2526 case SHT_SHLIB
: return "SHLIB";
2527 case SHT_DYNSYM
: return "DYNSYM";
2528 case SHT_INIT_ARRAY
: return "INIT_ARRAY";
2529 case SHT_FINI_ARRAY
: return "FINI_ARRAY";
2530 case SHT_PREINIT_ARRAY
: return "PREINIT_ARRAY";
2531 case SHT_GROUP
: return "GROUP";
2532 case SHT_SYMTAB_SHNDX
: return "SYMTAB SECTION INDICIES";
2533 case SHT_GNU_verdef
: return "VERDEF";
2534 case SHT_GNU_verneed
: return "VERNEED";
2535 case SHT_GNU_versym
: return "VERSYM";
2536 case 0x6ffffff0: return "VERSYM";
2537 case 0x6ffffffc: return "VERDEF";
2538 case 0x7ffffffd: return "AUXILIARY";
2539 case 0x7fffffff: return "FILTER";
2540 case SHT_GNU_LIBLIST
: return "GNU_LIBLIST";
2543 if ((sh_type
>= SHT_LOPROC
) && (sh_type
<= SHT_HIPROC
))
2547 switch (elf_header
.e_machine
)
2550 case EM_MIPS_RS3_LE
:
2551 result
= get_mips_section_type_name (sh_type
);
2554 result
= get_parisc_section_type_name (sh_type
);
2557 result
= get_ia64_section_type_name (sh_type
);
2567 sprintf (buff
, "LOPROC+%x", sh_type
- SHT_LOPROC
);
2569 else if ((sh_type
>= SHT_LOOS
) && (sh_type
<= SHT_HIOS
))
2570 sprintf (buff
, "LOOS+%x", sh_type
- SHT_LOOS
);
2571 else if ((sh_type
>= SHT_LOUSER
) && (sh_type
<= SHT_HIUSER
))
2572 sprintf (buff
, "LOUSER+%x", sh_type
- SHT_LOUSER
);
2574 sprintf (buff
, _("<unknown>: %x"), sh_type
);
2580 #define OPTION_DEBUG_DUMP 512
2582 struct option options
[] =
2584 {"all", no_argument
, 0, 'a'},
2585 {"file-header", no_argument
, 0, 'h'},
2586 {"program-headers", no_argument
, 0, 'l'},
2587 {"headers", no_argument
, 0, 'e'},
2588 {"histogram", no_argument
, 0, 'I'},
2589 {"segments", no_argument
, 0, 'l'},
2590 {"sections", no_argument
, 0, 'S'},
2591 {"section-headers", no_argument
, 0, 'S'},
2592 {"symbols", no_argument
, 0, 's'},
2593 {"syms", no_argument
, 0, 's'},
2594 {"relocs", no_argument
, 0, 'r'},
2595 {"notes", no_argument
, 0, 'n'},
2596 {"dynamic", no_argument
, 0, 'd'},
2597 {"arch-specific", no_argument
, 0, 'A'},
2598 {"version-info", no_argument
, 0, 'V'},
2599 {"use-dynamic", no_argument
, 0, 'D'},
2600 {"hex-dump", required_argument
, 0, 'x'},
2601 {"debug-dump", optional_argument
, 0, OPTION_DEBUG_DUMP
},
2602 {"unwind", no_argument
, 0, 'u'},
2603 #ifdef SUPPORT_DISASSEMBLY
2604 {"instruction-dump", required_argument
, 0, 'i'},
2607 {"version", no_argument
, 0, 'v'},
2608 {"wide", no_argument
, 0, 'W'},
2609 {"help", no_argument
, 0, 'H'},
2610 {0, no_argument
, 0, 0}
2616 fprintf (stdout
, _("Usage: readelf <option(s)> elf-file(s)\n"));
2617 fprintf (stdout
, _(" Display information about the contents of ELF format files\n"));
2618 fprintf (stdout
, _(" Options are:\n\
2619 -a --all Equivalent to: -h -l -S -s -r -d -V -A -I\n\
2620 -h --file-header Display the ELF file header\n\
2621 -l --program-headers Display the program headers\n\
2622 --segments An alias for --program-headers\n\
2623 -S --section-headers Display the sections' header\n\
2624 --sections An alias for --section-headers\n\
2625 -e --headers Equivalent to: -h -l -S\n\
2626 -s --syms Display the symbol table\n\
2627 --symbols An alias for --syms\n\
2628 -n --notes Display the core notes (if present)\n\
2629 -r --relocs Display the relocations (if present)\n\
2630 -u --unwind Display the unwind info (if present)\n\
2631 -d --dynamic Display the dynamic segment (if present)\n\
2632 -V --version-info Display the version sections (if present)\n\
2633 -A --arch-specific Display architecture specific information (if any).\n\
2634 -D --use-dynamic Use the dynamic section info when displaying symbols\n\
2635 -x --hex-dump=<number> Dump the contents of section <number>\n\
2636 -w[liaprmfFso] or\n\
2637 --debug-dump[=line,=info,=abbrev,=pubnames,=ranges,=macro,=frames,=str,=loc]\n\
2638 Display the contents of DWARF2 debug sections\n"));
2639 #ifdef SUPPORT_DISASSEMBLY
2640 fprintf (stdout
, _("\
2641 -i --instruction-dump=<number>\n\
2642 Disassemble the contents of section <number>\n"));
2644 fprintf (stdout
, _("\
2645 -I --histogram Display histogram of bucket list lengths\n\
2646 -W --wide Allow output width to exceed 80 characters\n\
2647 -H --help Display this information\n\
2648 -v --version Display the version number of readelf\n"));
2649 fprintf (stdout
, _("Report bugs to %s\n"), REPORT_BUGS_TO
);
2655 request_dump (section
, type
)
2656 unsigned int section
;
2659 if (section
>= num_dump_sects
)
2661 char *new_dump_sects
;
2663 new_dump_sects
= (char *) calloc (section
+ 1, 1);
2665 if (new_dump_sects
== NULL
)
2666 error (_("Out of memory allocating dump request table."));
2669 /* Copy current flag settings. */
2670 memcpy (new_dump_sects
, dump_sects
, num_dump_sects
);
2674 dump_sects
= new_dump_sects
;
2675 num_dump_sects
= section
+ 1;
2680 dump_sects
[section
] |= type
;
2686 parse_args (argc
, argv
)
2695 while ((c
= getopt_long
2696 (argc
, argv
, "ersuahnldSDAIw::x:i:vVWH", options
, NULL
)) != EOF
)
2763 section
= strtoul (optarg
, & cp
, 0);
2764 if (! *cp
&& section
>= 0)
2766 request_dump (section
, HEX_DUMP
);
2776 unsigned int index
= 0;
2780 while (optarg
[index
])
2781 switch (optarg
[index
++])
2790 do_debug_abbrevs
= 1;
2800 do_debug_pubnames
= 1;
2805 do_debug_aranges
= 1;
2809 do_debug_frames_interp
= 1;
2811 do_debug_frames
= 1;
2816 do_debug_macinfo
= 1;
2830 warn (_("Unrecognized debug option '%s'\n"), optarg
);
2835 case OPTION_DEBUG_DUMP
:
2841 static const char *debug_dump_opt
[]
2842 = { "line", "info", "abbrev", "pubnames", "ranges",
2843 "macro", "frames", "frames-interp", "str", "loc", NULL
};
2852 for (index
= 0; debug_dump_opt
[index
]; index
++)
2854 size_t len
= strlen (debug_dump_opt
[index
]);
2856 if (strncmp (p
, debug_dump_opt
[index
], len
) == 0
2857 && (p
[len
] == ',' || p
[len
] == '\0'))
2866 do_debug_abbrevs
= 1;
2877 do_debug_pubnames
= 1;
2881 do_debug_aranges
= 1;
2886 do_debug_frames_interp
= 1;
2887 do_debug_frames
= 1;
2891 do_debug_macinfo
= 1;
2904 if (debug_dump_opt
[index
] == NULL
)
2906 warn (_("Unrecognized debug option '%s'\n"), p
);
2907 p
= strchr (p
, ',');
2917 #ifdef SUPPORT_DISASSEMBLY
2920 section
= strtoul (optarg
, & cp
, 0);
2921 if (! *cp
&& section
>= 0)
2923 request_dump (section
, DISASS_DUMP
);
2929 print_version (program_name
);
2939 /* xgettext:c-format */
2940 error (_("Invalid option '-%c'\n"), c
);
2947 if (!do_dynamic
&& !do_syms
&& !do_reloc
&& !do_unwind
&& !do_sections
2948 && !do_segments
&& !do_header
&& !do_dump
&& !do_version
2949 && !do_histogram
&& !do_debugging
&& !do_arch
&& !do_notes
)
2953 warn (_("Nothing to do.\n"));
2959 get_elf_class (elf_class
)
2960 unsigned int elf_class
;
2962 static char buff
[32];
2966 case ELFCLASSNONE
: return _("none");
2967 case ELFCLASS32
: return "ELF32";
2968 case ELFCLASS64
: return "ELF64";
2970 sprintf (buff
, _("<unknown: %x>"), elf_class
);
2976 get_data_encoding (encoding
)
2977 unsigned int encoding
;
2979 static char buff
[32];
2983 case ELFDATANONE
: return _("none");
2984 case ELFDATA2LSB
: return _("2's complement, little endian");
2985 case ELFDATA2MSB
: return _("2's complement, big endian");
2987 sprintf (buff
, _("<unknown: %x>"), encoding
);
2993 get_osabi_name (osabi
)
2996 static char buff
[32];
3000 case ELFOSABI_NONE
: return "UNIX - System V";
3001 case ELFOSABI_HPUX
: return "UNIX - HP-UX";
3002 case ELFOSABI_NETBSD
: return "UNIX - NetBSD";
3003 case ELFOSABI_LINUX
: return "UNIX - Linux";
3004 case ELFOSABI_HURD
: return "GNU/Hurd";
3005 case ELFOSABI_SOLARIS
: return "UNIX - Solaris";
3006 case ELFOSABI_AIX
: return "UNIX - AIX";
3007 case ELFOSABI_IRIX
: return "UNIX - IRIX";
3008 case ELFOSABI_FREEBSD
: return "UNIX - FreeBSD";
3009 case ELFOSABI_TRU64
: return "UNIX - TRU64";
3010 case ELFOSABI_MODESTO
: return "Novell - Modesto";
3011 case ELFOSABI_OPENBSD
: return "UNIX - OpenBSD";
3012 case ELFOSABI_OPENVMS
: return "VMS - OpenVMS";
3013 case ELFOSABI_NSK
: return "HP - Non-Stop Kernel";
3014 case ELFOSABI_AROS
: return "Amiga Research OS";
3015 case ELFOSABI_STANDALONE
: return _("Standalone App");
3016 case ELFOSABI_ARM
: return "ARM";
3018 sprintf (buff
, _("<unknown: %x>"), osabi
);
3023 /* Decode the data held in 'elf_header'. */
3026 process_file_header ()
3028 if ( elf_header
.e_ident
[EI_MAG0
] != ELFMAG0
3029 || elf_header
.e_ident
[EI_MAG1
] != ELFMAG1
3030 || elf_header
.e_ident
[EI_MAG2
] != ELFMAG2
3031 || elf_header
.e_ident
[EI_MAG3
] != ELFMAG3
)
3034 (_("Not an ELF file - it has the wrong magic bytes at the start\n"));
3042 printf (_("ELF Header:\n"));
3043 printf (_(" Magic: "));
3044 for (i
= 0; i
< EI_NIDENT
; i
++)
3045 printf ("%2.2x ", elf_header
.e_ident
[i
]);
3047 printf (_(" Class: %s\n"),
3048 get_elf_class (elf_header
.e_ident
[EI_CLASS
]));
3049 printf (_(" Data: %s\n"),
3050 get_data_encoding (elf_header
.e_ident
[EI_DATA
]));
3051 printf (_(" Version: %d %s\n"),
3052 elf_header
.e_ident
[EI_VERSION
],
3053 (elf_header
.e_ident
[EI_VERSION
] == EV_CURRENT
3055 : (elf_header
.e_ident
[EI_VERSION
] != EV_NONE
3058 printf (_(" OS/ABI: %s\n"),
3059 get_osabi_name (elf_header
.e_ident
[EI_OSABI
]));
3060 printf (_(" ABI Version: %d\n"),
3061 elf_header
.e_ident
[EI_ABIVERSION
]);
3062 printf (_(" Type: %s\n"),
3063 get_file_type (elf_header
.e_type
));
3064 printf (_(" Machine: %s\n"),
3065 get_machine_name (elf_header
.e_machine
));
3066 printf (_(" Version: 0x%lx\n"),
3067 (unsigned long) elf_header
.e_version
);
3069 printf (_(" Entry point address: "));
3070 print_vma ((bfd_vma
) elf_header
.e_entry
, PREFIX_HEX
);
3071 printf (_("\n Start of program headers: "));
3072 print_vma ((bfd_vma
) elf_header
.e_phoff
, DEC
);
3073 printf (_(" (bytes into file)\n Start of section headers: "));
3074 print_vma ((bfd_vma
) elf_header
.e_shoff
, DEC
);
3075 printf (_(" (bytes into file)\n"));
3077 printf (_(" Flags: 0x%lx%s\n"),
3078 (unsigned long) elf_header
.e_flags
,
3079 get_machine_flags (elf_header
.e_flags
, elf_header
.e_machine
));
3080 printf (_(" Size of this header: %ld (bytes)\n"),
3081 (long) elf_header
.e_ehsize
);
3082 printf (_(" Size of program headers: %ld (bytes)\n"),
3083 (long) elf_header
.e_phentsize
);
3084 printf (_(" Number of program headers: %ld\n"),
3085 (long) elf_header
.e_phnum
);
3086 printf (_(" Size of section headers: %ld (bytes)\n"),
3087 (long) elf_header
.e_shentsize
);
3088 printf (_(" Number of section headers: %ld"),
3089 (long) elf_header
.e_shnum
);
3090 if (section_headers
!= NULL
&& elf_header
.e_shnum
== 0)
3091 printf (" (%ld)", (long) section_headers
[0].sh_size
);
3092 putc ('\n', stdout
);
3093 printf (_(" Section header string table index: %ld"),
3094 (long) elf_header
.e_shstrndx
);
3095 if (section_headers
!= NULL
&& elf_header
.e_shstrndx
== SHN_XINDEX
)
3096 printf (" (%ld)", (long) section_headers
[0].sh_link
);
3097 putc ('\n', stdout
);
3100 if (section_headers
!= NULL
)
3102 if (elf_header
.e_shnum
== 0)
3103 elf_header
.e_shnum
= section_headers
[0].sh_size
;
3104 if (elf_header
.e_shstrndx
== SHN_XINDEX
)
3105 elf_header
.e_shstrndx
= section_headers
[0].sh_link
;
3106 free (section_headers
);
3107 section_headers
= NULL
;
3115 get_32bit_program_headers (file
, program_headers
)
3117 Elf_Internal_Phdr
*program_headers
;
3119 Elf32_External_Phdr
*phdrs
;
3120 Elf32_External_Phdr
*external
;
3121 Elf_Internal_Phdr
*internal
;
3124 phdrs
= ((Elf32_External_Phdr
*)
3125 get_data (NULL
, file
, elf_header
.e_phoff
,
3126 elf_header
.e_phentsize
* elf_header
.e_phnum
,
3127 _("program headers")));
3131 for (i
= 0, internal
= program_headers
, external
= phdrs
;
3132 i
< elf_header
.e_phnum
;
3133 i
++, internal
++, external
++)
3135 internal
->p_type
= BYTE_GET (external
->p_type
);
3136 internal
->p_offset
= BYTE_GET (external
->p_offset
);
3137 internal
->p_vaddr
= BYTE_GET (external
->p_vaddr
);
3138 internal
->p_paddr
= BYTE_GET (external
->p_paddr
);
3139 internal
->p_filesz
= BYTE_GET (external
->p_filesz
);
3140 internal
->p_memsz
= BYTE_GET (external
->p_memsz
);
3141 internal
->p_flags
= BYTE_GET (external
->p_flags
);
3142 internal
->p_align
= BYTE_GET (external
->p_align
);
3151 get_64bit_program_headers (file
, program_headers
)
3153 Elf_Internal_Phdr
*program_headers
;
3155 Elf64_External_Phdr
*phdrs
;
3156 Elf64_External_Phdr
*external
;
3157 Elf_Internal_Phdr
*internal
;
3160 phdrs
= ((Elf64_External_Phdr
*)
3161 get_data (NULL
, file
, elf_header
.e_phoff
,
3162 elf_header
.e_phentsize
* elf_header
.e_phnum
,
3163 _("program headers")));
3167 for (i
= 0, internal
= program_headers
, external
= phdrs
;
3168 i
< elf_header
.e_phnum
;
3169 i
++, internal
++, external
++)
3171 internal
->p_type
= BYTE_GET (external
->p_type
);
3172 internal
->p_flags
= BYTE_GET (external
->p_flags
);
3173 internal
->p_offset
= BYTE_GET8 (external
->p_offset
);
3174 internal
->p_vaddr
= BYTE_GET8 (external
->p_vaddr
);
3175 internal
->p_paddr
= BYTE_GET8 (external
->p_paddr
);
3176 internal
->p_filesz
= BYTE_GET8 (external
->p_filesz
);
3177 internal
->p_memsz
= BYTE_GET8 (external
->p_memsz
);
3178 internal
->p_align
= BYTE_GET8 (external
->p_align
);
3186 /* Returns 1 if the program headers were read into `program_headers'. */
3189 get_program_headers (file
)
3192 Elf_Internal_Phdr
*phdrs
;
3194 /* Check cache of prior read. */
3195 if (program_headers
!= NULL
)
3198 phdrs
= (Elf_Internal_Phdr
*) malloc
3199 (elf_header
.e_phnum
* sizeof (Elf_Internal_Phdr
));
3203 error (_("Out of memory\n"));
3208 ? get_32bit_program_headers (file
, phdrs
)
3209 : get_64bit_program_headers (file
, phdrs
))
3211 program_headers
= phdrs
;
3219 /* Returns 1 if the program headers were loaded. */
3222 process_program_headers (file
)
3225 Elf_Internal_Phdr
*segment
;
3228 if (elf_header
.e_phnum
== 0)
3231 printf (_("\nThere are no program headers in this file.\n"));
3235 if (do_segments
&& !do_header
)
3237 printf (_("\nElf file type is %s\n"), get_file_type (elf_header
.e_type
));
3238 printf (_("Entry point "));
3239 print_vma ((bfd_vma
) elf_header
.e_entry
, PREFIX_HEX
);
3240 printf (_("\nThere are %d program headers, starting at offset "),
3241 elf_header
.e_phnum
);
3242 print_vma ((bfd_vma
) elf_header
.e_phoff
, DEC
);
3246 if (! get_program_headers (file
))
3251 if (elf_header
.e_phnum
> 1)
3252 printf (_("\nProgram Headers:\n"));
3254 printf (_("\nProgram Headers:\n"));
3258 (_(" Type Offset VirtAddr PhysAddr FileSiz MemSiz Flg Align\n"));
3261 (_(" Type Offset VirtAddr PhysAddr FileSiz MemSiz Flg Align\n"));
3265 (_(" Type Offset VirtAddr PhysAddr\n"));
3267 (_(" FileSiz MemSiz Flags Align\n"));
3274 for (i
= 0, segment
= program_headers
;
3275 i
< elf_header
.e_phnum
;
3280 printf (" %-14.14s ", get_segment_type (segment
->p_type
));
3284 printf ("0x%6.6lx ", (unsigned long) segment
->p_offset
);
3285 printf ("0x%8.8lx ", (unsigned long) segment
->p_vaddr
);
3286 printf ("0x%8.8lx ", (unsigned long) segment
->p_paddr
);
3287 printf ("0x%5.5lx ", (unsigned long) segment
->p_filesz
);
3288 printf ("0x%5.5lx ", (unsigned long) segment
->p_memsz
);
3290 (segment
->p_flags
& PF_R
? 'R' : ' '),
3291 (segment
->p_flags
& PF_W
? 'W' : ' '),
3292 (segment
->p_flags
& PF_X
? 'E' : ' '));
3293 printf ("%#lx", (unsigned long) segment
->p_align
);
3297 if ((unsigned long) segment
->p_offset
== segment
->p_offset
)
3298 printf ("0x%6.6lx ", (unsigned long) segment
->p_offset
);
3301 print_vma (segment
->p_offset
, FULL_HEX
);
3305 print_vma (segment
->p_vaddr
, FULL_HEX
);
3307 print_vma (segment
->p_paddr
, FULL_HEX
);
3310 if ((unsigned long) segment
->p_filesz
== segment
->p_filesz
)
3311 printf ("0x%6.6lx ", (unsigned long) segment
->p_filesz
);
3314 print_vma (segment
->p_filesz
, FULL_HEX
);
3318 if ((unsigned long) segment
->p_memsz
== segment
->p_memsz
)
3319 printf ("0x%6.6lx", (unsigned long) segment
->p_memsz
);
3322 print_vma (segment
->p_offset
, FULL_HEX
);
3326 (segment
->p_flags
& PF_R
? 'R' : ' '),
3327 (segment
->p_flags
& PF_W
? 'W' : ' '),
3328 (segment
->p_flags
& PF_X
? 'E' : ' '));
3330 if ((unsigned long) segment
->p_align
== segment
->p_align
)
3331 printf ("%#lx", (unsigned long) segment
->p_align
);
3334 print_vma (segment
->p_align
, PREFIX_HEX
);
3339 print_vma (segment
->p_offset
, FULL_HEX
);
3341 print_vma (segment
->p_vaddr
, FULL_HEX
);
3343 print_vma (segment
->p_paddr
, FULL_HEX
);
3345 print_vma (segment
->p_filesz
, FULL_HEX
);
3347 print_vma (segment
->p_memsz
, FULL_HEX
);
3349 (segment
->p_flags
& PF_R
? 'R' : ' '),
3350 (segment
->p_flags
& PF_W
? 'W' : ' '),
3351 (segment
->p_flags
& PF_X
? 'E' : ' '));
3352 print_vma (segment
->p_align
, HEX
);
3356 switch (segment
->p_type
)
3360 error (_("more than one dynamic segment\n"));
3362 dynamic_addr
= segment
->p_offset
;
3363 dynamic_size
= segment
->p_filesz
;
3367 if (fseek (file
, (long) segment
->p_offset
, SEEK_SET
))
3368 error (_("Unable to find program interpreter name\n"));
3371 program_interpreter
[0] = 0;
3372 fscanf (file
, "%63s", program_interpreter
);
3375 printf (_("\n [Requesting program interpreter: %s]"),
3376 program_interpreter
);
3382 putc ('\n', stdout
);
3385 if (do_segments
&& section_headers
!= NULL
)
3387 printf (_("\n Section to Segment mapping:\n"));
3388 printf (_(" Segment Sections...\n"));
3390 assert (string_table
!= NULL
);
3392 for (i
= 0; i
< elf_header
.e_phnum
; i
++)
3395 Elf_Internal_Shdr
*section
;
3397 segment
= program_headers
+ i
;
3398 section
= section_headers
;
3400 printf (" %2.2d ", i
);
3402 for (j
= 1; j
< elf_header
.e_shnum
; j
++, section
++)
3404 if (section
->sh_size
> 0
3405 /* Compare allocated sections by VMA, unallocated
3406 sections by file offset. */
3407 && (section
->sh_flags
& SHF_ALLOC
3408 ? (section
->sh_addr
>= segment
->p_vaddr
3409 && section
->sh_addr
+ section
->sh_size
3410 <= segment
->p_vaddr
+ segment
->p_memsz
)
3411 : ((bfd_vma
) section
->sh_offset
>= segment
->p_offset
3412 && (section
->sh_offset
+ section
->sh_size
3413 <= segment
->p_offset
+ segment
->p_filesz
))))
3414 printf ("%s ", SECTION_NAME (section
));
3425 /* Find the file offset corresponding to VMA by using the program headers. */
3428 offset_from_vma (file
, vma
, size
)
3433 Elf_Internal_Phdr
*seg
;
3435 if (! get_program_headers (file
))
3437 warn (_("Cannot interpret virtual addresses without program headers.\n"));
3441 for (seg
= program_headers
;
3442 seg
< program_headers
+ elf_header
.e_phnum
;
3445 if (seg
->p_type
!= PT_LOAD
)
3448 if (vma
>= (seg
->p_vaddr
& -seg
->p_align
)
3449 && vma
+ size
<= seg
->p_vaddr
+ seg
->p_filesz
)
3450 return vma
- seg
->p_vaddr
+ seg
->p_offset
;
3453 warn (_("Virtual address 0x%lx not located in any PT_LOAD segment.\n"),
3460 get_32bit_section_headers (file
, num
)
3464 Elf32_External_Shdr
*shdrs
;
3465 Elf_Internal_Shdr
*internal
;
3468 shdrs
= ((Elf32_External_Shdr
*)
3469 get_data (NULL
, file
, elf_header
.e_shoff
,
3470 elf_header
.e_shentsize
* num
,
3471 _("section headers")));
3475 section_headers
= ((Elf_Internal_Shdr
*)
3476 malloc (num
* sizeof (Elf_Internal_Shdr
)));
3478 if (section_headers
== NULL
)
3480 error (_("Out of memory\n"));
3484 for (i
= 0, internal
= section_headers
;
3488 internal
->sh_name
= BYTE_GET (shdrs
[i
].sh_name
);
3489 internal
->sh_type
= BYTE_GET (shdrs
[i
].sh_type
);
3490 internal
->sh_flags
= BYTE_GET (shdrs
[i
].sh_flags
);
3491 internal
->sh_addr
= BYTE_GET (shdrs
[i
].sh_addr
);
3492 internal
->sh_offset
= BYTE_GET (shdrs
[i
].sh_offset
);
3493 internal
->sh_size
= BYTE_GET (shdrs
[i
].sh_size
);
3494 internal
->sh_link
= BYTE_GET (shdrs
[i
].sh_link
);
3495 internal
->sh_info
= BYTE_GET (shdrs
[i
].sh_info
);
3496 internal
->sh_addralign
= BYTE_GET (shdrs
[i
].sh_addralign
);
3497 internal
->sh_entsize
= BYTE_GET (shdrs
[i
].sh_entsize
);
3506 get_64bit_section_headers (file
, num
)
3510 Elf64_External_Shdr
*shdrs
;
3511 Elf_Internal_Shdr
*internal
;
3514 shdrs
= ((Elf64_External_Shdr
*)
3515 get_data (NULL
, file
, elf_header
.e_shoff
,
3516 elf_header
.e_shentsize
* num
,
3517 _("section headers")));
3521 section_headers
= ((Elf_Internal_Shdr
*)
3522 malloc (num
* sizeof (Elf_Internal_Shdr
)));
3524 if (section_headers
== NULL
)
3526 error (_("Out of memory\n"));
3530 for (i
= 0, internal
= section_headers
;
3534 internal
->sh_name
= BYTE_GET (shdrs
[i
].sh_name
);
3535 internal
->sh_type
= BYTE_GET (shdrs
[i
].sh_type
);
3536 internal
->sh_flags
= BYTE_GET8 (shdrs
[i
].sh_flags
);
3537 internal
->sh_addr
= BYTE_GET8 (shdrs
[i
].sh_addr
);
3538 internal
->sh_size
= BYTE_GET8 (shdrs
[i
].sh_size
);
3539 internal
->sh_entsize
= BYTE_GET8 (shdrs
[i
].sh_entsize
);
3540 internal
->sh_link
= BYTE_GET (shdrs
[i
].sh_link
);
3541 internal
->sh_info
= BYTE_GET (shdrs
[i
].sh_info
);
3542 internal
->sh_offset
= BYTE_GET (shdrs
[i
].sh_offset
);
3543 internal
->sh_addralign
= BYTE_GET (shdrs
[i
].sh_addralign
);
3551 static Elf_Internal_Sym
*
3552 get_32bit_elf_symbols (file
, section
)
3554 Elf_Internal_Shdr
*section
;
3556 unsigned long number
;
3557 Elf32_External_Sym
*esyms
;
3558 Elf_External_Sym_Shndx
*shndx
;
3559 Elf_Internal_Sym
*isyms
;
3560 Elf_Internal_Sym
*psym
;
3563 esyms
= ((Elf32_External_Sym
*)
3564 get_data (NULL
, file
, section
->sh_offset
,
3565 section
->sh_size
, _("symbols")));
3570 if (symtab_shndx_hdr
!= NULL
3571 && (symtab_shndx_hdr
->sh_link
3572 == (unsigned long) SECTION_HEADER_NUM (section
- section_headers
)))
3574 shndx
= ((Elf_External_Sym_Shndx
*)
3575 get_data (NULL
, file
, symtab_shndx_hdr
->sh_offset
,
3576 symtab_shndx_hdr
->sh_size
, _("symtab shndx")));
3584 number
= section
->sh_size
/ section
->sh_entsize
;
3585 isyms
= (Elf_Internal_Sym
*) malloc (number
* sizeof (Elf_Internal_Sym
));
3589 error (_("Out of memory\n"));
3596 for (j
= 0, psym
= isyms
;
3600 psym
->st_name
= BYTE_GET (esyms
[j
].st_name
);
3601 psym
->st_value
= BYTE_GET (esyms
[j
].st_value
);
3602 psym
->st_size
= BYTE_GET (esyms
[j
].st_size
);
3603 psym
->st_shndx
= BYTE_GET (esyms
[j
].st_shndx
);
3604 if (psym
->st_shndx
== SHN_XINDEX
&& shndx
!= NULL
)
3606 = byte_get ((unsigned char *) &shndx
[j
], sizeof (shndx
[j
]));
3607 psym
->st_info
= BYTE_GET (esyms
[j
].st_info
);
3608 psym
->st_other
= BYTE_GET (esyms
[j
].st_other
);
3618 static Elf_Internal_Sym
*
3619 get_64bit_elf_symbols (file
, section
)
3621 Elf_Internal_Shdr
*section
;
3623 unsigned long number
;
3624 Elf64_External_Sym
*esyms
;
3625 Elf_External_Sym_Shndx
*shndx
;
3626 Elf_Internal_Sym
*isyms
;
3627 Elf_Internal_Sym
*psym
;
3630 esyms
= ((Elf64_External_Sym
*)
3631 get_data (NULL
, file
, section
->sh_offset
,
3632 section
->sh_size
, _("symbols")));
3637 if (symtab_shndx_hdr
!= NULL
3638 && (symtab_shndx_hdr
->sh_link
3639 == (unsigned long) SECTION_HEADER_NUM (section
- section_headers
)))
3641 shndx
= ((Elf_External_Sym_Shndx
*)
3642 get_data (NULL
, file
, symtab_shndx_hdr
->sh_offset
,
3643 symtab_shndx_hdr
->sh_size
, _("symtab shndx")));
3651 number
= section
->sh_size
/ section
->sh_entsize
;
3652 isyms
= (Elf_Internal_Sym
*) malloc (number
* sizeof (Elf_Internal_Sym
));
3656 error (_("Out of memory\n"));
3663 for (j
= 0, psym
= isyms
;
3667 psym
->st_name
= BYTE_GET (esyms
[j
].st_name
);
3668 psym
->st_info
= BYTE_GET (esyms
[j
].st_info
);
3669 psym
->st_other
= BYTE_GET (esyms
[j
].st_other
);
3670 psym
->st_shndx
= BYTE_GET (esyms
[j
].st_shndx
);
3671 if (psym
->st_shndx
== SHN_XINDEX
&& shndx
!= NULL
)
3673 = byte_get ((unsigned char *) &shndx
[j
], sizeof (shndx
[j
]));
3674 psym
->st_value
= BYTE_GET8 (esyms
[j
].st_value
);
3675 psym
->st_size
= BYTE_GET8 (esyms
[j
].st_size
);
3686 get_elf_section_flags (sh_flags
)
3689 static char buff
[32];
3697 flag
= sh_flags
& - sh_flags
;
3702 case SHF_WRITE
: strcat (buff
, "W"); break;
3703 case SHF_ALLOC
: strcat (buff
, "A"); break;
3704 case SHF_EXECINSTR
: strcat (buff
, "X"); break;
3705 case SHF_MERGE
: strcat (buff
, "M"); break;
3706 case SHF_STRINGS
: strcat (buff
, "S"); break;
3707 case SHF_INFO_LINK
: strcat (buff
, "I"); break;
3708 case SHF_LINK_ORDER
: strcat (buff
, "L"); break;
3709 case SHF_OS_NONCONFORMING
: strcat (buff
, "O"); break;
3710 case SHF_GROUP
: strcat (buff
, "G"); break;
3711 case SHF_TLS
: strcat (buff
, "T"); break;
3714 if (flag
& SHF_MASKOS
)
3717 sh_flags
&= ~ SHF_MASKOS
;
3719 else if (flag
& SHF_MASKPROC
)
3722 sh_flags
&= ~ SHF_MASKPROC
;
3734 process_section_headers (file
)
3737 Elf_Internal_Shdr
*section
;
3740 section_headers
= NULL
;
3742 if (elf_header
.e_shnum
== 0)
3745 printf (_("\nThere are no sections in this file.\n"));
3750 if (do_sections
&& !do_header
)
3751 printf (_("There are %d section headers, starting at offset 0x%lx:\n"),
3752 elf_header
.e_shnum
, (unsigned long) elf_header
.e_shoff
);
3756 if (! get_32bit_section_headers (file
, elf_header
.e_shnum
))
3759 else if (! get_64bit_section_headers (file
, elf_header
.e_shnum
))
3762 /* Read in the string table, so that we have names to display. */
3763 section
= SECTION_HEADER (elf_header
.e_shstrndx
);
3765 if (section
->sh_size
!= 0)
3767 string_table
= (char *) get_data (NULL
, file
, section
->sh_offset
,
3768 section
->sh_size
, _("string table"));
3770 string_table_length
= section
->sh_size
;
3773 /* Scan the sections for the dynamic symbol table
3774 and dynamic string table and debug sections. */
3775 dynamic_symbols
= NULL
;
3776 dynamic_strings
= NULL
;
3777 dynamic_syminfo
= NULL
;
3778 symtab_shndx_hdr
= NULL
;
3780 for (i
= 0, section
= section_headers
;
3781 i
< elf_header
.e_shnum
;
3784 char *name
= SECTION_NAME (section
);
3786 if (section
->sh_type
== SHT_DYNSYM
)
3788 if (dynamic_symbols
!= NULL
)
3790 error (_("File contains multiple dynamic symbol tables\n"));
3794 num_dynamic_syms
= section
->sh_size
/ section
->sh_entsize
;
3795 dynamic_symbols
= GET_ELF_SYMBOLS (file
, section
);
3797 else if (section
->sh_type
== SHT_STRTAB
3798 && strcmp (name
, ".dynstr") == 0)
3800 if (dynamic_strings
!= NULL
)
3802 error (_("File contains multiple dynamic string tables\n"));
3806 dynamic_strings
= (char *) get_data (NULL
, file
, section
->sh_offset
,
3808 _("dynamic strings"));
3810 else if (section
->sh_type
== SHT_SYMTAB_SHNDX
)
3812 if (symtab_shndx_hdr
!= NULL
)
3814 error (_("File contains multiple symtab shndx tables\n"));
3817 symtab_shndx_hdr
= section
;
3819 else if ((do_debugging
|| do_debug_info
|| do_debug_abbrevs
3820 || do_debug_lines
|| do_debug_pubnames
|| do_debug_aranges
3821 || do_debug_frames
|| do_debug_macinfo
|| do_debug_str
3823 && strncmp (name
, ".debug_", 7) == 0)
3828 || (do_debug_info
&& (strcmp (name
, "info") == 0))
3829 || (do_debug_abbrevs
&& (strcmp (name
, "abbrev") == 0))
3830 || (do_debug_lines
&& (strcmp (name
, "line") == 0))
3831 || (do_debug_pubnames
&& (strcmp (name
, "pubnames") == 0))
3832 || (do_debug_aranges
&& (strcmp (name
, "aranges") == 0))
3833 || (do_debug_frames
&& (strcmp (name
, "frame") == 0))
3834 || (do_debug_macinfo
&& (strcmp (name
, "macinfo") == 0))
3835 || (do_debug_str
&& (strcmp (name
, "str") == 0))
3836 || (do_debug_loc
&& (strcmp (name
, "loc") == 0))
3838 request_dump (i
, DEBUG_DUMP
);
3840 /* linkonce section to be combined with .debug_info at link time. */
3841 else if ((do_debugging
|| do_debug_info
)
3842 && strncmp (name
, ".gnu.linkonce.wi.", 17) == 0)
3843 request_dump (i
, DEBUG_DUMP
);
3844 else if (do_debug_frames
&& strcmp (name
, ".eh_frame") == 0)
3845 request_dump (i
, DEBUG_DUMP
);
3851 if (elf_header
.e_shnum
> 1)
3852 printf (_("\nSection Headers:\n"));
3854 printf (_("\nSection Header:\n"));
3858 (_(" [Nr] Name Type Addr Off Size ES Flg Lk Inf Al\n"));
3861 (_(" [Nr] Name Type Address Off Size ES Flg Lk Inf Al\n"));
3864 printf (_(" [Nr] Name Type Address Offset\n"));
3865 printf (_(" Size EntSize Flags Link Info Align\n"));
3868 for (i
= 0, section
= section_headers
;
3869 i
< elf_header
.e_shnum
;
3872 printf (" [%2u] %-17.17s %-15.15s ",
3873 SECTION_HEADER_NUM (i
),
3874 SECTION_NAME (section
),
3875 get_section_type_name (section
->sh_type
));
3879 print_vma (section
->sh_addr
, LONG_HEX
);
3881 printf ( " %6.6lx %6.6lx %2.2lx",
3882 (unsigned long) section
->sh_offset
,
3883 (unsigned long) section
->sh_size
,
3884 (unsigned long) section
->sh_entsize
);
3886 printf (" %3s ", get_elf_section_flags (section
->sh_flags
));
3888 printf ("%2ld %3lx %2ld\n",
3889 (unsigned long) section
->sh_link
,
3890 (unsigned long) section
->sh_info
,
3891 (unsigned long) section
->sh_addralign
);
3895 print_vma (section
->sh_addr
, LONG_HEX
);
3897 if ((long) section
->sh_offset
== section
->sh_offset
)
3898 printf (" %6.6lx", (unsigned long) section
->sh_offset
);
3902 print_vma (section
->sh_offset
, LONG_HEX
);
3905 if ((unsigned long) section
->sh_size
== section
->sh_size
)
3906 printf (" %6.6lx", (unsigned long) section
->sh_size
);
3910 print_vma (section
->sh_size
, LONG_HEX
);
3913 if ((unsigned long) section
->sh_entsize
== section
->sh_entsize
)
3914 printf (" %2.2lx", (unsigned long) section
->sh_entsize
);
3918 print_vma (section
->sh_entsize
, LONG_HEX
);
3921 printf (" %3s ", get_elf_section_flags (section
->sh_flags
));
3923 printf ("%2ld %3lx ",
3924 (unsigned long) section
->sh_link
,
3925 (unsigned long) section
->sh_info
);
3927 if ((unsigned long) section
->sh_addralign
== section
->sh_addralign
)
3928 printf ("%2ld\n", (unsigned long) section
->sh_addralign
);
3931 print_vma (section
->sh_addralign
, DEC
);
3938 print_vma (section
->sh_addr
, LONG_HEX
);
3939 if ((long) section
->sh_offset
== section
->sh_offset
)
3940 printf (" %8.8lx", (unsigned long) section
->sh_offset
);
3944 print_vma (section
->sh_offset
, LONG_HEX
);
3947 print_vma (section
->sh_size
, LONG_HEX
);
3949 print_vma (section
->sh_entsize
, LONG_HEX
);
3951 printf (" %3s ", get_elf_section_flags (section
->sh_flags
));
3953 printf (" %2ld %3lx %ld\n",
3954 (unsigned long) section
->sh_link
,
3955 (unsigned long) section
->sh_info
,
3956 (unsigned long) section
->sh_addralign
);
3960 printf (_("Key to Flags:\n\
3961 W (write), A (alloc), X (execute), M (merge), S (strings)\n\
3962 I (info), L (link order), G (group), x (unknown)\n\
3963 O (extra OS processing required) o (OS specific), p (processor specific)\n"));
3974 } dynamic_relocations
[] =
3976 { "REL", DT_REL
, DT_RELSZ
, FALSE
},
3977 { "RELA", DT_RELA
, DT_RELASZ
, TRUE
},
3978 { "PLT", DT_JMPREL
, DT_PLTRELSZ
, UNKNOWN
}
3981 /* Process the reloc section. */
3983 process_relocs (file
)
3986 unsigned long rel_size
;
3987 unsigned long rel_offset
;
3993 if (do_using_dynamic
)
3997 int has_dynamic_reloc
;
4000 has_dynamic_reloc
= 0;
4002 for (i
= 0; i
< ARRAY_SIZE (dynamic_relocations
); i
++)
4004 is_rela
= dynamic_relocations
[i
].rela
;
4005 name
= dynamic_relocations
[i
].name
;
4006 rel_size
= dynamic_info
[dynamic_relocations
[i
].size
];
4007 rel_offset
= dynamic_info
[dynamic_relocations
[i
].reloc
];
4009 has_dynamic_reloc
|= rel_size
;
4011 if (is_rela
== UNKNOWN
)
4013 if (dynamic_relocations
[i
].reloc
== DT_JMPREL
)
4014 switch (dynamic_info
[DT_PLTREL
])
4028 (_("\n'%s' relocation section at offset 0x%lx contains %ld bytes:\n"),
4029 name
, rel_offset
, rel_size
);
4031 dump_relocations (file
,
4032 offset_from_vma (file
, rel_offset
, rel_size
),
4034 dynamic_symbols
, num_dynamic_syms
,
4035 dynamic_strings
, is_rela
);
4039 if (! has_dynamic_reloc
)
4040 printf (_("\nThere are no dynamic relocations in this file.\n"));
4044 Elf_Internal_Shdr
*section
;
4048 for (i
= 0, section
= section_headers
;
4049 i
< elf_header
.e_shnum
;
4052 if ( section
->sh_type
!= SHT_RELA
4053 && section
->sh_type
!= SHT_REL
)
4056 rel_offset
= section
->sh_offset
;
4057 rel_size
= section
->sh_size
;
4061 Elf_Internal_Shdr
*strsec
;
4062 Elf_Internal_Sym
*symtab
;
4065 unsigned long nsyms
;
4067 printf (_("\nRelocation section "));
4069 if (string_table
== NULL
)
4070 printf ("%d", section
->sh_name
);
4072 printf (_("'%s'"), SECTION_NAME (section
));
4074 printf (_(" at offset 0x%lx contains %lu entries:\n"),
4075 rel_offset
, (unsigned long) (rel_size
/ section
->sh_entsize
));
4080 if (section
->sh_link
)
4082 Elf_Internal_Shdr
*symsec
;
4084 symsec
= SECTION_HEADER (section
->sh_link
);
4085 nsyms
= symsec
->sh_size
/ symsec
->sh_entsize
;
4086 symtab
= GET_ELF_SYMBOLS (file
, symsec
);
4091 strsec
= SECTION_HEADER (symsec
->sh_link
);
4093 strtab
= (char *) get_data (NULL
, file
, strsec
->sh_offset
,
4097 is_rela
= section
->sh_type
== SHT_RELA
;
4099 dump_relocations (file
, rel_offset
, rel_size
,
4100 symtab
, nsyms
, strtab
, is_rela
);
4112 printf (_("\nThere are no relocations in this file.\n"));
4118 #include "unwind-ia64.h"
4120 /* An absolute address consists of a section and an offset. If the
4121 section is NULL, the offset itself is the address, otherwise, the
4122 address equals to LOAD_ADDRESS(section) + offset. */
4126 unsigned short section
;
4132 struct unw_table_entry
4134 struct absaddr start
;
4136 struct absaddr info
;
4138 *table
; /* Unwind table. */
4139 unsigned long table_len
; /* Length of unwind table. */
4140 unsigned char *info
; /* Unwind info. */
4141 unsigned long info_size
; /* Size of unwind info. */
4142 bfd_vma info_addr
; /* starting address of unwind info. */
4143 bfd_vma seg_base
; /* Starting address of segment. */
4144 Elf_Internal_Sym
*symtab
; /* The symbol table. */
4145 unsigned long nsyms
; /* Number of symbols. */
4146 char *strtab
; /* The string table. */
4147 unsigned long strtab_size
; /* Size of string table. */
4150 static void find_symbol_for_address
4151 PARAMS ((struct unw_aux_info
*, struct absaddr
, const char **, bfd_vma
*));
4152 static void dump_ia64_unwind
4153 PARAMS ((struct unw_aux_info
*));
4154 static int slurp_ia64_unwind_table
4155 PARAMS ((FILE *, struct unw_aux_info
*, Elf_Internal_Shdr
*));
4158 find_symbol_for_address (aux
, addr
, symname
, offset
)
4159 struct unw_aux_info
*aux
;
4160 struct absaddr addr
;
4161 const char **symname
;
4164 bfd_vma dist
= (bfd_vma
) 0x100000;
4165 Elf_Internal_Sym
*sym
, *best
= NULL
;
4168 for (i
= 0, sym
= aux
->symtab
; i
< aux
->nsyms
; ++i
, ++sym
)
4170 if (ELF_ST_TYPE (sym
->st_info
) == STT_FUNC
4171 && sym
->st_name
!= 0
4172 && (addr
.section
== SHN_UNDEF
|| addr
.section
== sym
->st_shndx
)
4173 && addr
.offset
>= sym
->st_value
4174 && addr
.offset
- sym
->st_value
< dist
)
4177 dist
= addr
.offset
- sym
->st_value
;
4184 *symname
= (best
->st_name
>= aux
->strtab_size
4185 ? "<corrupt>" : aux
->strtab
+ best
->st_name
);
4190 *offset
= addr
.offset
;
4194 dump_ia64_unwind (aux
)
4195 struct unw_aux_info
*aux
;
4198 struct unw_table_entry
*tp
;
4201 addr_size
= is_32bit_elf
? 4 : 8;
4203 for (tp
= aux
->table
; tp
< aux
->table
+ aux
->table_len
; ++tp
)
4207 const unsigned char *dp
;
4208 const unsigned char *head
;
4209 const char *procname
;
4211 find_symbol_for_address (aux
, tp
->start
, &procname
, &offset
);
4213 fputs ("\n<", stdout
);
4217 fputs (procname
, stdout
);
4220 printf ("+%lx", (unsigned long) offset
);
4223 fputs (">: [", stdout
);
4224 print_vma (tp
->start
.offset
, PREFIX_HEX
);
4225 fputc ('-', stdout
);
4226 print_vma (tp
->end
.offset
, PREFIX_HEX
);
4227 printf ("], info at +0x%lx\n",
4228 (unsigned long) (tp
->info
.offset
- aux
->seg_base
));
4230 head
= aux
->info
+ (tp
->info
.offset
- aux
->info_addr
);
4231 stamp
= BYTE_GET8 ((unsigned char *) head
);
4233 printf (" v%u, flags=0x%lx (%s%s), len=%lu bytes\n",
4234 (unsigned) UNW_VER (stamp
),
4235 (unsigned long) ((stamp
& UNW_FLAG_MASK
) >> 32),
4236 UNW_FLAG_EHANDLER (stamp
) ? " ehandler" : "",
4237 UNW_FLAG_UHANDLER (stamp
) ? " uhandler" : "",
4238 (unsigned long) (addr_size
* UNW_LENGTH (stamp
)));
4240 if (UNW_VER (stamp
) != 1)
4242 printf ("\tUnknown version.\n");
4247 for (dp
= head
+ 8; dp
< head
+ 8 + addr_size
* UNW_LENGTH (stamp
);)
4248 dp
= unw_decode (dp
, in_body
, & in_body
);
4253 slurp_ia64_unwind_table (file
, aux
, sec
)
4255 struct unw_aux_info
*aux
;
4256 Elf_Internal_Shdr
*sec
;
4258 unsigned long size
, addr_size
, nrelas
, i
;
4259 Elf_Internal_Phdr
*seg
;
4260 struct unw_table_entry
*tep
;
4261 Elf_Internal_Shdr
*relsec
;
4262 Elf_Internal_Rela
*rela
, *rp
;
4263 unsigned char *table
, *tp
;
4264 Elf_Internal_Sym
*sym
;
4265 const char *relname
;
4267 addr_size
= is_32bit_elf
? 4 : 8;
4269 /* First, find the starting address of the segment that includes
4272 if (elf_header
.e_phnum
)
4274 if (! get_program_headers (file
))
4277 for (seg
= program_headers
;
4278 seg
< program_headers
+ elf_header
.e_phnum
;
4281 if (seg
->p_type
!= PT_LOAD
)
4284 if (sec
->sh_addr
>= seg
->p_vaddr
4285 && (sec
->sh_addr
+ sec
->sh_size
<= seg
->p_vaddr
+ seg
->p_memsz
))
4287 aux
->seg_base
= seg
->p_vaddr
;
4293 /* Second, build the unwind table from the contents of the unwind section: */
4294 size
= sec
->sh_size
;
4295 table
= (char *) get_data (NULL
, file
, sec
->sh_offset
,
4296 size
, _("unwind table"));
4300 tep
= aux
->table
= xmalloc (size
/ (3 * addr_size
) * sizeof (aux
->table
[0]));
4301 for (tp
= table
; tp
< table
+ size
; tp
+= 3 * addr_size
, ++tep
)
4303 tep
->start
.section
= SHN_UNDEF
;
4304 tep
->end
.section
= SHN_UNDEF
;
4305 tep
->info
.section
= SHN_UNDEF
;
4308 tep
->start
.offset
= byte_get ((unsigned char *) tp
+ 0, 4);
4309 tep
->end
.offset
= byte_get ((unsigned char *) tp
+ 4, 4);
4310 tep
->info
.offset
= byte_get ((unsigned char *) tp
+ 8, 4);
4314 tep
->start
.offset
= BYTE_GET8 ((unsigned char *) tp
+ 0);
4315 tep
->end
.offset
= BYTE_GET8 ((unsigned char *) tp
+ 8);
4316 tep
->info
.offset
= BYTE_GET8 ((unsigned char *) tp
+ 16);
4318 tep
->start
.offset
+= aux
->seg_base
;
4319 tep
->end
.offset
+= aux
->seg_base
;
4320 tep
->info
.offset
+= aux
->seg_base
;
4324 /* Third, apply any relocations to the unwind table: */
4326 for (relsec
= section_headers
;
4327 relsec
< section_headers
+ elf_header
.e_shnum
;
4330 if (relsec
->sh_type
!= SHT_RELA
4331 || SECTION_HEADER (relsec
->sh_info
) != sec
)
4334 if (!slurp_rela_relocs (file
, relsec
->sh_offset
, relsec
->sh_size
,
4338 for (rp
= rela
; rp
< rela
+ nrelas
; ++rp
)
4342 relname
= elf_ia64_reloc_type (ELF32_R_TYPE (rp
->r_info
));
4343 sym
= aux
->symtab
+ ELF32_R_SYM (rp
->r_info
);
4345 if (ELF32_ST_TYPE (sym
->st_info
) != STT_SECTION
)
4347 warn (_("Skipping unexpected symbol type %u\n"),
4348 ELF32_ST_TYPE (sym
->st_info
));
4354 relname
= elf_ia64_reloc_type (ELF64_R_TYPE (rp
->r_info
));
4355 sym
= aux
->symtab
+ ELF64_R_SYM (rp
->r_info
);
4357 if (ELF64_ST_TYPE (sym
->st_info
) != STT_SECTION
)
4359 warn (_("Skipping unexpected symbol type %u\n"),
4360 ELF64_ST_TYPE (sym
->st_info
));
4365 if (strncmp (relname
, "R_IA64_SEGREL", 13) != 0)
4367 warn (_("Skipping unexpected relocation type %s\n"), relname
);
4371 i
= rp
->r_offset
/ (3 * addr_size
);
4373 switch (rp
->r_offset
/addr_size
% 3)
4376 aux
->table
[i
].start
.section
= sym
->st_shndx
;
4377 aux
->table
[i
].start
.offset
+= rp
->r_addend
;
4380 aux
->table
[i
].end
.section
= sym
->st_shndx
;
4381 aux
->table
[i
].end
.offset
+= rp
->r_addend
;
4384 aux
->table
[i
].info
.section
= sym
->st_shndx
;
4385 aux
->table
[i
].info
.offset
+= rp
->r_addend
;
4395 aux
->table_len
= size
/ (3 * addr_size
);
4400 process_unwind (file
)
4403 Elf_Internal_Shdr
*sec
, *unwsec
= NULL
, *strsec
;
4404 unsigned long i
, addr_size
, unwcount
= 0, unwstart
= 0;
4405 struct unw_aux_info aux
;
4410 if (elf_header
.e_machine
!= EM_IA_64
)
4412 printf (_("\nThere are no unwind sections in this file.\n"));
4416 memset (& aux
, 0, sizeof (aux
));
4418 addr_size
= is_32bit_elf
? 4 : 8;
4420 for (i
= 0, sec
= section_headers
; i
< elf_header
.e_shnum
; ++i
, ++sec
)
4422 if (sec
->sh_type
== SHT_SYMTAB
)
4424 aux
.nsyms
= sec
->sh_size
/ sec
->sh_entsize
;
4425 aux
.symtab
= GET_ELF_SYMBOLS (file
, sec
);
4427 strsec
= SECTION_HEADER (sec
->sh_link
);
4428 aux
.strtab_size
= strsec
->sh_size
;
4429 aux
.strtab
= (char *) get_data (NULL
, file
, strsec
->sh_offset
,
4430 aux
.strtab_size
, _("string table"));
4432 else if (sec
->sh_type
== SHT_IA_64_UNWIND
)
4437 printf (_("\nThere are no unwind sections in this file.\n"));
4439 while (unwcount
-- > 0)
4444 for (i
= unwstart
, sec
= section_headers
+ unwstart
;
4445 i
< elf_header
.e_shnum
; ++i
, ++sec
)
4446 if (sec
->sh_type
== SHT_IA_64_UNWIND
)
4453 len
= sizeof (ELF_STRING_ia64_unwind_once
) - 1;
4455 if (strncmp (SECTION_NAME (unwsec
), ELF_STRING_ia64_unwind_once
,
4458 /* .gnu.linkonce.ia64unw.FOO -> .gnu.linkonce.ia64unwi.FOO */
4459 len2
= sizeof (ELF_STRING_ia64_unwind_info_once
) - 1;
4460 suffix
= SECTION_NAME (unwsec
) + len
;
4461 for (i
= 0, sec
= section_headers
; i
< elf_header
.e_shnum
;
4463 if (strncmp (SECTION_NAME (sec
),
4464 ELF_STRING_ia64_unwind_info_once
, len2
) == 0
4465 && strcmp (SECTION_NAME (sec
) + len2
, suffix
) == 0)
4470 /* .IA_64.unwindFOO -> .IA_64.unwind_infoFOO
4471 .IA_64.unwind or BAR -> .IA_64.unwind_info */
4472 len
= sizeof (ELF_STRING_ia64_unwind
) - 1;
4473 len2
= sizeof (ELF_STRING_ia64_unwind_info
) - 1;
4475 if (strncmp (SECTION_NAME (unwsec
), ELF_STRING_ia64_unwind
,
4477 suffix
= SECTION_NAME (unwsec
) + len
;
4478 for (i
= 0, sec
= section_headers
; i
< elf_header
.e_shnum
;
4480 if (strncmp (SECTION_NAME (sec
),
4481 ELF_STRING_ia64_unwind_info
, len2
) == 0
4482 && strcmp (SECTION_NAME (sec
) + len2
, suffix
) == 0)
4486 if (i
== elf_header
.e_shnum
)
4488 printf (_("\nCould not find unwind info section for "));
4490 if (string_table
== NULL
)
4491 printf ("%d", unwsec
->sh_name
);
4493 printf (_("'%s'"), SECTION_NAME (unwsec
));
4497 aux
.info_size
= sec
->sh_size
;
4498 aux
.info_addr
= sec
->sh_addr
;
4499 aux
.info
= (char *) get_data (NULL
, file
, sec
->sh_offset
,
4500 aux
.info_size
, _("unwind info"));
4502 printf (_("\nUnwind section "));
4504 if (string_table
== NULL
)
4505 printf ("%d", unwsec
->sh_name
);
4507 printf (_("'%s'"), SECTION_NAME (unwsec
));
4509 printf (_(" at offset 0x%lx contains %lu entries:\n"),
4510 (unsigned long) unwsec
->sh_offset
,
4511 (unsigned long) (unwsec
->sh_size
/ (3 * addr_size
)));
4513 (void) slurp_ia64_unwind_table (file
, & aux
, unwsec
);
4515 if (aux
.table_len
> 0)
4516 dump_ia64_unwind (& aux
);
4519 free ((char *) aux
.table
);
4521 free ((char *) aux
.info
);
4530 free ((char *) aux
.strtab
);
4536 dynamic_segment_mips_val (entry
)
4537 Elf_Internal_Dyn
*entry
;
4539 switch (entry
->d_tag
)
4542 if (entry
->d_un
.d_val
== 0)
4546 static const char * opts
[] =
4548 "QUICKSTART", "NOTPOT", "NO_LIBRARY_REPLACEMENT",
4549 "NO_MOVE", "SGI_ONLY", "GUARANTEE_INIT", "DELTA_C_PLUS_PLUS",
4550 "GUARANTEE_START_INIT", "PIXIE", "DEFAULT_DELAY_LOAD",
4551 "REQUICKSTART", "REQUICKSTARTED", "CORD", "NO_UNRES_UNDEF",
4556 for (cnt
= 0; cnt
< NUM_ELEM (opts
); ++cnt
)
4557 if (entry
->d_un
.d_val
& (1 << cnt
))
4559 printf ("%s%s", first
? "" : " ", opts
[cnt
]);
4566 case DT_MIPS_IVERSION
:
4567 if (dynamic_strings
!= NULL
)
4568 printf ("Interface Version: %s\n",
4569 dynamic_strings
+ entry
->d_un
.d_val
);
4571 printf ("%ld\n", (long) entry
->d_un
.d_ptr
);
4574 case DT_MIPS_TIME_STAMP
:
4579 time_t time
= entry
->d_un
.d_val
;
4580 tmp
= gmtime (&time
);
4581 sprintf (timebuf
, "%04u-%02u-%02uT%02u:%02u:%02u",
4582 tmp
->tm_year
+ 1900, tmp
->tm_mon
+ 1, tmp
->tm_mday
,
4583 tmp
->tm_hour
, tmp
->tm_min
, tmp
->tm_sec
);
4584 printf ("Time Stamp: %s\n", timebuf
);
4588 case DT_MIPS_RLD_VERSION
:
4589 case DT_MIPS_LOCAL_GOTNO
:
4590 case DT_MIPS_CONFLICTNO
:
4591 case DT_MIPS_LIBLISTNO
:
4592 case DT_MIPS_SYMTABNO
:
4593 case DT_MIPS_UNREFEXTNO
:
4594 case DT_MIPS_HIPAGENO
:
4595 case DT_MIPS_DELTA_CLASS_NO
:
4596 case DT_MIPS_DELTA_INSTANCE_NO
:
4597 case DT_MIPS_DELTA_RELOC_NO
:
4598 case DT_MIPS_DELTA_SYM_NO
:
4599 case DT_MIPS_DELTA_CLASSSYM_NO
:
4600 case DT_MIPS_COMPACT_SIZE
:
4601 printf ("%ld\n", (long) entry
->d_un
.d_ptr
);
4605 printf ("%#lx\n", (long) entry
->d_un
.d_ptr
);
4611 dynamic_segment_parisc_val (entry
)
4612 Elf_Internal_Dyn
*entry
;
4614 switch (entry
->d_tag
)
4616 case DT_HP_DLD_FLAGS
:
4625 { DT_HP_DEBUG_PRIVATE
, "HP_DEBUG_PRIVATE" },
4626 { DT_HP_DEBUG_CALLBACK
, "HP_DEBUG_CALLBACK" },
4627 { DT_HP_DEBUG_CALLBACK_BOR
, "HP_DEBUG_CALLBACK_BOR" },
4628 { DT_HP_NO_ENVVAR
, "HP_NO_ENVVAR" },
4629 { DT_HP_BIND_NOW
, "HP_BIND_NOW" },
4630 { DT_HP_BIND_NONFATAL
, "HP_BIND_NONFATAL" },
4631 { DT_HP_BIND_VERBOSE
, "HP_BIND_VERBOSE" },
4632 { DT_HP_BIND_RESTRICTED
, "HP_BIND_RESTRICTED" },
4633 { DT_HP_BIND_SYMBOLIC
, "HP_BIND_SYMBOLIC" },
4634 { DT_HP_RPATH_FIRST
, "HP_RPATH_FIRST" },
4635 { DT_HP_BIND_DEPTH_FIRST
, "HP_BIND_DEPTH_FIRST" }
4639 bfd_vma val
= entry
->d_un
.d_val
;
4641 for (cnt
= 0; cnt
< sizeof (flags
) / sizeof (flags
[0]); ++cnt
)
4642 if (val
& flags
[cnt
].bit
)
4646 fputs (flags
[cnt
].str
, stdout
);
4648 val
^= flags
[cnt
].bit
;
4651 if (val
!= 0 || first
)
4655 print_vma (val
, HEX
);
4661 print_vma (entry
->d_un
.d_ptr
, PREFIX_HEX
);
4668 dynamic_segment_ia64_val (entry
)
4669 Elf_Internal_Dyn
*entry
;
4671 switch (entry
->d_tag
)
4673 case DT_IA_64_PLT_RESERVE
:
4674 /* First 3 slots reserved. */
4675 print_vma (entry
->d_un
.d_ptr
, PREFIX_HEX
);
4677 print_vma (entry
->d_un
.d_ptr
+ (3 * 8), PREFIX_HEX
);
4681 print_vma (entry
->d_un
.d_ptr
, PREFIX_HEX
);
4688 get_32bit_dynamic_segment (file
)
4691 Elf32_External_Dyn
*edyn
;
4692 Elf_Internal_Dyn
*entry
;
4695 edyn
= (Elf32_External_Dyn
*) get_data (NULL
, file
, dynamic_addr
,
4696 dynamic_size
, _("dynamic segment"));
4700 /* SGI's ELF has more than one section in the DYNAMIC segment. Determine
4701 how large this .dynamic is now. We can do this even before the byte
4702 swapping since the DT_NULL tag is recognizable. */
4704 while (*(Elf32_Word
*) edyn
[dynamic_size
++].d_tag
!= DT_NULL
)
4707 dynamic_segment
= (Elf_Internal_Dyn
*)
4708 malloc (dynamic_size
* sizeof (Elf_Internal_Dyn
));
4710 if (dynamic_segment
== NULL
)
4712 error (_("Out of memory\n"));
4717 for (i
= 0, entry
= dynamic_segment
;
4721 entry
->d_tag
= BYTE_GET (edyn
[i
].d_tag
);
4722 entry
->d_un
.d_val
= BYTE_GET (edyn
[i
].d_un
.d_val
);
4731 get_64bit_dynamic_segment (file
)
4734 Elf64_External_Dyn
*edyn
;
4735 Elf_Internal_Dyn
*entry
;
4738 edyn
= (Elf64_External_Dyn
*) get_data (NULL
, file
, dynamic_addr
,
4739 dynamic_size
, _("dynamic segment"));
4743 /* SGI's ELF has more than one section in the DYNAMIC segment. Determine
4744 how large this .dynamic is now. We can do this even before the byte
4745 swapping since the DT_NULL tag is recognizable. */
4747 while (*(bfd_vma
*) edyn
[dynamic_size
++].d_tag
!= DT_NULL
)
4750 dynamic_segment
= (Elf_Internal_Dyn
*)
4751 malloc (dynamic_size
* sizeof (Elf_Internal_Dyn
));
4753 if (dynamic_segment
== NULL
)
4755 error (_("Out of memory\n"));
4760 for (i
= 0, entry
= dynamic_segment
;
4764 entry
->d_tag
= BYTE_GET8 (edyn
[i
].d_tag
);
4765 entry
->d_un
.d_val
= BYTE_GET8 (edyn
[i
].d_un
.d_val
);
4774 get_dynamic_flags (flags
)
4777 static char buff
[128];
4785 flag
= flags
& - flags
;
4793 case DF_ORIGIN
: strcpy (p
, "ORIGIN"); break;
4794 case DF_SYMBOLIC
: strcpy (p
, "SYMBOLIC"); break;
4795 case DF_TEXTREL
: strcpy (p
, "TEXTREL"); break;
4796 case DF_BIND_NOW
: strcpy (p
, "BIND_NOW"); break;
4797 case DF_STATIC_TLS
: strcpy (p
, "STATIC_TLS"); break;
4798 default: strcpy (p
, "unknown"); break;
4801 p
= strchr (p
, '\0');
4806 /* Parse and display the contents of the dynamic segment. */
4808 process_dynamic_segment (file
)
4811 Elf_Internal_Dyn
*entry
;
4814 if (dynamic_size
== 0)
4817 printf (_("\nThere is no dynamic segment in this file.\n"));
4824 if (! get_32bit_dynamic_segment (file
))
4827 else if (! get_64bit_dynamic_segment (file
))
4830 /* Find the appropriate symbol table. */
4831 if (dynamic_symbols
== NULL
)
4833 for (i
= 0, entry
= dynamic_segment
;
4837 Elf_Internal_Shdr section
;
4839 if (entry
->d_tag
!= DT_SYMTAB
)
4842 dynamic_info
[DT_SYMTAB
] = entry
->d_un
.d_val
;
4844 /* Since we do not know how big the symbol table is,
4845 we default to reading in the entire file (!) and
4846 processing that. This is overkill, I know, but it
4848 section
.sh_offset
= offset_from_vma (file
, entry
->d_un
.d_val
, 0);
4850 if (fseek (file
, 0, SEEK_END
))
4851 error (_("Unable to seek to end of file!"));
4853 section
.sh_size
= ftell (file
) - section
.sh_offset
;
4855 section
.sh_entsize
= sizeof (Elf32_External_Sym
);
4857 section
.sh_entsize
= sizeof (Elf64_External_Sym
);
4859 num_dynamic_syms
= section
.sh_size
/ section
.sh_entsize
;
4860 if (num_dynamic_syms
< 1)
4862 error (_("Unable to determine the number of symbols to load\n"));
4866 dynamic_symbols
= GET_ELF_SYMBOLS (file
, §ion
);
4870 /* Similarly find a string table. */
4871 if (dynamic_strings
== NULL
)
4873 for (i
= 0, entry
= dynamic_segment
;
4877 unsigned long offset
;
4880 if (entry
->d_tag
!= DT_STRTAB
)
4883 dynamic_info
[DT_STRTAB
] = entry
->d_un
.d_val
;
4885 /* Since we do not know how big the string table is,
4886 we default to reading in the entire file (!) and
4887 processing that. This is overkill, I know, but it
4890 offset
= offset_from_vma (file
, entry
->d_un
.d_val
, 0);
4891 if (fseek (file
, 0, SEEK_END
))
4892 error (_("Unable to seek to end of file\n"));
4893 str_tab_len
= ftell (file
) - offset
;
4895 if (str_tab_len
< 1)
4898 (_("Unable to determine the length of the dynamic string table\n"));
4902 dynamic_strings
= (char *) get_data (NULL
, file
, offset
, str_tab_len
,
4903 _("dynamic string table"));
4908 /* And find the syminfo section if available. */
4909 if (dynamic_syminfo
== NULL
)
4911 unsigned long syminsz
= 0;
4913 for (i
= 0, entry
= dynamic_segment
;
4917 if (entry
->d_tag
== DT_SYMINENT
)
4919 /* Note: these braces are necessary to avoid a syntax
4920 error from the SunOS4 C compiler. */
4921 assert (sizeof (Elf_External_Syminfo
) == entry
->d_un
.d_val
);
4923 else if (entry
->d_tag
== DT_SYMINSZ
)
4924 syminsz
= entry
->d_un
.d_val
;
4925 else if (entry
->d_tag
== DT_SYMINFO
)
4926 dynamic_syminfo_offset
= offset_from_vma (file
, entry
->d_un
.d_val
,
4930 if (dynamic_syminfo_offset
!= 0 && syminsz
!= 0)
4932 Elf_External_Syminfo
*extsyminfo
;
4933 Elf_Internal_Syminfo
*syminfo
;
4935 /* There is a syminfo section. Read the data. */
4936 extsyminfo
= ((Elf_External_Syminfo
*)
4937 get_data (NULL
, file
, dynamic_syminfo_offset
,
4938 syminsz
, _("symbol information")));
4942 dynamic_syminfo
= (Elf_Internal_Syminfo
*) malloc (syminsz
);
4943 if (dynamic_syminfo
== NULL
)
4945 error (_("Out of memory\n"));
4949 dynamic_syminfo_nent
= syminsz
/ sizeof (Elf_External_Syminfo
);
4950 for (i
= 0, syminfo
= dynamic_syminfo
; i
< dynamic_syminfo_nent
;
4953 syminfo
->si_boundto
= BYTE_GET (extsyminfo
[i
].si_boundto
);
4954 syminfo
->si_flags
= BYTE_GET (extsyminfo
[i
].si_flags
);
4961 if (do_dynamic
&& dynamic_addr
)
4962 printf (_("\nDynamic segment at offset 0x%lx contains %ld entries:\n"),
4963 dynamic_addr
, (long) dynamic_size
);
4965 printf (_(" Tag Type Name/Value\n"));
4967 for (i
= 0, entry
= dynamic_segment
;
4976 print_vma (entry
->d_tag
, FULL_HEX
);
4977 dtype
= get_dynamic_type (entry
->d_tag
);
4978 printf (" (%s)%*s", dtype
,
4979 ((is_32bit_elf
? 27 : 19)
4980 - (int) strlen (dtype
)),
4984 switch (entry
->d_tag
)
4988 puts (get_dynamic_flags (entry
->d_un
.d_val
));
4998 switch (entry
->d_tag
)
5001 printf (_("Auxiliary library"));
5005 printf (_("Filter library"));
5009 printf (_("Configuration file"));
5013 printf (_("Dependency audit library"));
5017 printf (_("Audit library"));
5021 if (dynamic_strings
)
5022 printf (": [%s]\n", dynamic_strings
+ entry
->d_un
.d_val
);
5026 print_vma (entry
->d_un
.d_val
, PREFIX_HEX
);
5035 printf (_("Flags:"));
5037 if (entry
->d_un
.d_val
== 0)
5038 printf (_(" None\n"));
5041 unsigned long int val
= entry
->d_un
.d_val
;
5043 if (val
& DTF_1_PARINIT
)
5045 printf (" PARINIT");
5046 val
^= DTF_1_PARINIT
;
5048 if (val
& DTF_1_CONFEXP
)
5050 printf (" CONFEXP");
5051 val
^= DTF_1_CONFEXP
;
5054 printf (" %lx", val
);
5063 printf (_("Flags:"));
5065 if (entry
->d_un
.d_val
== 0)
5066 printf (_(" None\n"));
5069 unsigned long int val
= entry
->d_un
.d_val
;
5071 if (val
& DF_P1_LAZYLOAD
)
5073 printf (" LAZYLOAD");
5074 val
^= DF_P1_LAZYLOAD
;
5076 if (val
& DF_P1_GROUPPERM
)
5078 printf (" GROUPPERM");
5079 val
^= DF_P1_GROUPPERM
;
5082 printf (" %lx", val
);
5091 printf (_("Flags:"));
5092 if (entry
->d_un
.d_val
== 0)
5093 printf (_(" None\n"));
5096 unsigned long int val
= entry
->d_un
.d_val
;
5103 if (val
& DF_1_GLOBAL
)
5108 if (val
& DF_1_GROUP
)
5113 if (val
& DF_1_NODELETE
)
5115 printf (" NODELETE");
5116 val
^= DF_1_NODELETE
;
5118 if (val
& DF_1_LOADFLTR
)
5120 printf (" LOADFLTR");
5121 val
^= DF_1_LOADFLTR
;
5123 if (val
& DF_1_INITFIRST
)
5125 printf (" INITFIRST");
5126 val
^= DF_1_INITFIRST
;
5128 if (val
& DF_1_NOOPEN
)
5133 if (val
& DF_1_ORIGIN
)
5138 if (val
& DF_1_DIRECT
)
5143 if (val
& DF_1_TRANS
)
5148 if (val
& DF_1_INTERPOSE
)
5150 printf (" INTERPOSE");
5151 val
^= DF_1_INTERPOSE
;
5153 if (val
& DF_1_NODEFLIB
)
5155 printf (" NODEFLIB");
5156 val
^= DF_1_NODEFLIB
;
5158 if (val
& DF_1_NODUMP
)
5163 if (val
& DF_1_CONLFAT
)
5165 printf (" CONLFAT");
5166 val
^= DF_1_CONLFAT
;
5169 printf (" %lx", val
);
5176 dynamic_info
[entry
->d_tag
] = entry
->d_un
.d_val
;
5178 puts (get_dynamic_type (entry
->d_un
.d_val
));
5198 dynamic_info
[entry
->d_tag
] = entry
->d_un
.d_val
;
5204 if (dynamic_strings
== NULL
)
5207 name
= dynamic_strings
+ entry
->d_un
.d_val
;
5211 switch (entry
->d_tag
)
5214 printf (_("Shared library: [%s]"), name
);
5216 if (strcmp (name
, program_interpreter
) == 0)
5217 printf (_(" program interpreter"));
5221 printf (_("Library soname: [%s]"), name
);
5225 printf (_("Library rpath: [%s]"), name
);
5229 printf (_("Library runpath: [%s]"), name
);
5233 print_vma (entry
->d_un
.d_val
, PREFIX_HEX
);
5238 print_vma (entry
->d_un
.d_val
, PREFIX_HEX
);
5251 dynamic_info
[entry
->d_tag
] = entry
->d_un
.d_val
;
5255 case DT_INIT_ARRAYSZ
:
5256 case DT_FINI_ARRAYSZ
:
5257 case DT_GNU_CONFLICTSZ
:
5258 case DT_GNU_LIBLISTSZ
:
5261 print_vma (entry
->d_un
.d_val
, UNSIGNED
);
5262 printf (" (bytes)\n");
5272 print_vma (entry
->d_un
.d_val
, UNSIGNED
);
5285 if (dynamic_strings
!= NULL
&& entry
->d_tag
== DT_USED
)
5289 name
= dynamic_strings
+ entry
->d_un
.d_val
;
5293 printf (_("Not needed object: [%s]\n"), name
);
5298 print_vma (entry
->d_un
.d_val
, PREFIX_HEX
);
5304 /* The value of this entry is ignored. */
5309 case DT_GNU_PRELINKED
:
5313 time_t time
= entry
->d_un
.d_val
;
5315 tmp
= gmtime (&time
);
5316 printf ("%04u-%02u-%02uT%02u:%02u:%02u\n",
5317 tmp
->tm_year
+ 1900, tmp
->tm_mon
+ 1, tmp
->tm_mday
,
5318 tmp
->tm_hour
, tmp
->tm_min
, tmp
->tm_sec
);
5324 if ((entry
->d_tag
>= DT_VERSYM
) && (entry
->d_tag
<= DT_VERNEEDNUM
))
5325 version_info
[DT_VERSIONTAGIDX (entry
->d_tag
)] =
5330 switch (elf_header
.e_machine
)
5333 case EM_MIPS_RS3_LE
:
5334 dynamic_segment_mips_val (entry
);
5337 dynamic_segment_parisc_val (entry
);
5340 dynamic_segment_ia64_val (entry
);
5343 print_vma (entry
->d_un
.d_val
, PREFIX_HEX
);
5355 get_ver_flags (flags
)
5358 static char buff
[32];
5365 if (flags
& VER_FLG_BASE
)
5366 strcat (buff
, "BASE ");
5368 if (flags
& VER_FLG_WEAK
)
5370 if (flags
& VER_FLG_BASE
)
5371 strcat (buff
, "| ");
5373 strcat (buff
, "WEAK ");
5376 if (flags
& ~(VER_FLG_BASE
| VER_FLG_WEAK
))
5377 strcat (buff
, "| <unknown>");
5382 /* Display the contents of the version sections. */
5384 process_version_sections (file
)
5387 Elf_Internal_Shdr
*section
;
5394 for (i
= 0, section
= section_headers
;
5395 i
< elf_header
.e_shnum
;
5398 switch (section
->sh_type
)
5400 case SHT_GNU_verdef
:
5402 Elf_External_Verdef
*edefs
;
5409 (_("\nVersion definition section '%s' contains %ld entries:\n"),
5410 SECTION_NAME (section
), section
->sh_info
);
5412 printf (_(" Addr: 0x"));
5413 printf_vma (section
->sh_addr
);
5414 printf (_(" Offset: %#08lx Link: %lx (%s)\n"),
5415 (unsigned long) section
->sh_offset
, section
->sh_link
,
5416 SECTION_NAME (SECTION_HEADER (section
->sh_link
)));
5418 edefs
= ((Elf_External_Verdef
*)
5419 get_data (NULL
, file
, section
->sh_offset
,
5421 _("version definition section")));
5425 for (idx
= cnt
= 0; cnt
< section
->sh_info
; ++cnt
)
5428 Elf_External_Verdef
*edef
;
5429 Elf_Internal_Verdef ent
;
5430 Elf_External_Verdaux
*eaux
;
5431 Elf_Internal_Verdaux aux
;
5435 vstart
= ((char *) edefs
) + idx
;
5437 edef
= (Elf_External_Verdef
*) vstart
;
5439 ent
.vd_version
= BYTE_GET (edef
->vd_version
);
5440 ent
.vd_flags
= BYTE_GET (edef
->vd_flags
);
5441 ent
.vd_ndx
= BYTE_GET (edef
->vd_ndx
);
5442 ent
.vd_cnt
= BYTE_GET (edef
->vd_cnt
);
5443 ent
.vd_hash
= BYTE_GET (edef
->vd_hash
);
5444 ent
.vd_aux
= BYTE_GET (edef
->vd_aux
);
5445 ent
.vd_next
= BYTE_GET (edef
->vd_next
);
5447 printf (_(" %#06x: Rev: %d Flags: %s"),
5448 idx
, ent
.vd_version
, get_ver_flags (ent
.vd_flags
));
5450 printf (_(" Index: %d Cnt: %d "),
5451 ent
.vd_ndx
, ent
.vd_cnt
);
5453 vstart
+= ent
.vd_aux
;
5455 eaux
= (Elf_External_Verdaux
*) vstart
;
5457 aux
.vda_name
= BYTE_GET (eaux
->vda_name
);
5458 aux
.vda_next
= BYTE_GET (eaux
->vda_next
);
5460 if (dynamic_strings
)
5461 printf (_("Name: %s\n"), dynamic_strings
+ aux
.vda_name
);
5463 printf (_("Name index: %ld\n"), aux
.vda_name
);
5465 isum
= idx
+ ent
.vd_aux
;
5467 for (j
= 1; j
< ent
.vd_cnt
; j
++)
5469 isum
+= aux
.vda_next
;
5470 vstart
+= aux
.vda_next
;
5472 eaux
= (Elf_External_Verdaux
*) vstart
;
5474 aux
.vda_name
= BYTE_GET (eaux
->vda_name
);
5475 aux
.vda_next
= BYTE_GET (eaux
->vda_next
);
5477 if (dynamic_strings
)
5478 printf (_(" %#06x: Parent %d: %s\n"),
5479 isum
, j
, dynamic_strings
+ aux
.vda_name
);
5481 printf (_(" %#06x: Parent %d, name index: %ld\n"),
5482 isum
, j
, aux
.vda_name
);
5492 case SHT_GNU_verneed
:
5494 Elf_External_Verneed
*eneed
;
5500 printf (_("\nVersion needs section '%s' contains %ld entries:\n"),
5501 SECTION_NAME (section
), section
->sh_info
);
5503 printf (_(" Addr: 0x"));
5504 printf_vma (section
->sh_addr
);
5505 printf (_(" Offset: %#08lx Link to section: %ld (%s)\n"),
5506 (unsigned long) section
->sh_offset
, section
->sh_link
,
5507 SECTION_NAME (SECTION_HEADER (section
->sh_link
)));
5509 eneed
= ((Elf_External_Verneed
*)
5510 get_data (NULL
, file
, section
->sh_offset
,
5511 section
->sh_size
, _("version need section")));
5515 for (idx
= cnt
= 0; cnt
< section
->sh_info
; ++cnt
)
5517 Elf_External_Verneed
*entry
;
5518 Elf_Internal_Verneed ent
;
5523 vstart
= ((char *) eneed
) + idx
;
5525 entry
= (Elf_External_Verneed
*) vstart
;
5527 ent
.vn_version
= BYTE_GET (entry
->vn_version
);
5528 ent
.vn_cnt
= BYTE_GET (entry
->vn_cnt
);
5529 ent
.vn_file
= BYTE_GET (entry
->vn_file
);
5530 ent
.vn_aux
= BYTE_GET (entry
->vn_aux
);
5531 ent
.vn_next
= BYTE_GET (entry
->vn_next
);
5533 printf (_(" %#06x: Version: %d"), idx
, ent
.vn_version
);
5535 if (dynamic_strings
)
5536 printf (_(" File: %s"), dynamic_strings
+ ent
.vn_file
);
5538 printf (_(" File: %lx"), ent
.vn_file
);
5540 printf (_(" Cnt: %d\n"), ent
.vn_cnt
);
5542 vstart
+= ent
.vn_aux
;
5544 for (j
= 0, isum
= idx
+ ent
.vn_aux
; j
< ent
.vn_cnt
; ++j
)
5546 Elf_External_Vernaux
*eaux
;
5547 Elf_Internal_Vernaux aux
;
5549 eaux
= (Elf_External_Vernaux
*) vstart
;
5551 aux
.vna_hash
= BYTE_GET (eaux
->vna_hash
);
5552 aux
.vna_flags
= BYTE_GET (eaux
->vna_flags
);
5553 aux
.vna_other
= BYTE_GET (eaux
->vna_other
);
5554 aux
.vna_name
= BYTE_GET (eaux
->vna_name
);
5555 aux
.vna_next
= BYTE_GET (eaux
->vna_next
);
5557 if (dynamic_strings
)
5558 printf (_(" %#06x: Name: %s"),
5559 isum
, dynamic_strings
+ aux
.vna_name
);
5561 printf (_(" %#06x: Name index: %lx"),
5562 isum
, aux
.vna_name
);
5564 printf (_(" Flags: %s Version: %d\n"),
5565 get_ver_flags (aux
.vna_flags
), aux
.vna_other
);
5567 isum
+= aux
.vna_next
;
5568 vstart
+= aux
.vna_next
;
5578 case SHT_GNU_versym
:
5580 Elf_Internal_Shdr
*link_section
;
5583 unsigned char *edata
;
5584 unsigned short *data
;
5586 Elf_Internal_Sym
*symbols
;
5587 Elf_Internal_Shdr
*string_sec
;
5589 link_section
= SECTION_HEADER (section
->sh_link
);
5590 total
= section
->sh_size
/ section
->sh_entsize
;
5594 symbols
= GET_ELF_SYMBOLS (file
, link_section
);
5596 string_sec
= SECTION_HEADER (link_section
->sh_link
);
5598 strtab
= (char *) get_data (NULL
, file
, string_sec
->sh_offset
,
5599 string_sec
->sh_size
,
5600 _("version string table"));
5604 printf (_("\nVersion symbols section '%s' contains %d entries:\n"),
5605 SECTION_NAME (section
), total
);
5607 printf (_(" Addr: "));
5608 printf_vma (section
->sh_addr
);
5609 printf (_(" Offset: %#08lx Link: %lx (%s)\n"),
5610 (unsigned long) section
->sh_offset
, section
->sh_link
,
5611 SECTION_NAME (link_section
));
5615 get_data (NULL
, file
,
5617 (file
, version_info
[DT_VERSIONTAGIDX (DT_VERSYM
)],
5618 total
* sizeof (short)),
5619 total
* sizeof (short), _("version symbol data")));
5626 data
= (unsigned short *) malloc (total
* sizeof (short));
5628 for (cnt
= total
; cnt
--;)
5629 data
[cnt
] = byte_get (edata
+ cnt
* sizeof (short),
5634 for (cnt
= 0; cnt
< total
; cnt
+= 4)
5637 int check_def
, check_need
;
5640 printf (" %03x:", cnt
);
5642 for (j
= 0; (j
< 4) && (cnt
+ j
) < total
; ++j
)
5643 switch (data
[cnt
+ j
])
5646 fputs (_(" 0 (*local*) "), stdout
);
5650 fputs (_(" 1 (*global*) "), stdout
);
5654 nn
= printf ("%4x%c", data
[cnt
+ j
] & 0x7fff,
5655 data
[cnt
+ j
] & 0x8000 ? 'h' : ' ');
5659 if (SECTION_HEADER (symbols
[cnt
+ j
].st_shndx
)->sh_type
5662 if (symbols
[cnt
+ j
].st_shndx
== SHN_UNDEF
)
5669 && version_info
[DT_VERSIONTAGIDX (DT_VERNEED
)])
5671 Elf_Internal_Verneed ivn
;
5672 unsigned long offset
;
5674 offset
= offset_from_vma
5675 (file
, version_info
[DT_VERSIONTAGIDX (DT_VERNEED
)],
5676 sizeof (Elf_External_Verneed
));
5680 Elf_Internal_Vernaux ivna
;
5681 Elf_External_Verneed evn
;
5682 Elf_External_Vernaux evna
;
5683 unsigned long a_off
;
5685 get_data (&evn
, file
, offset
, sizeof (evn
),
5688 ivn
.vn_aux
= BYTE_GET (evn
.vn_aux
);
5689 ivn
.vn_next
= BYTE_GET (evn
.vn_next
);
5691 a_off
= offset
+ ivn
.vn_aux
;
5695 get_data (&evna
, file
, a_off
, sizeof (evna
),
5696 _("version need aux (2)"));
5698 ivna
.vna_next
= BYTE_GET (evna
.vna_next
);
5699 ivna
.vna_other
= BYTE_GET (evna
.vna_other
);
5701 a_off
+= ivna
.vna_next
;
5703 while (ivna
.vna_other
!= data
[cnt
+ j
]
5704 && ivna
.vna_next
!= 0);
5706 if (ivna
.vna_other
== data
[cnt
+ j
])
5708 ivna
.vna_name
= BYTE_GET (evna
.vna_name
);
5710 name
= strtab
+ ivna
.vna_name
;
5711 nn
+= printf ("(%s%-*s",
5713 12 - (int) strlen (name
),
5719 offset
+= ivn
.vn_next
;
5721 while (ivn
.vn_next
);
5724 if (check_def
&& data
[cnt
+ j
] != 0x8001
5725 && version_info
[DT_VERSIONTAGIDX (DT_VERDEF
)])
5727 Elf_Internal_Verdef ivd
;
5728 Elf_External_Verdef evd
;
5729 unsigned long offset
;
5731 offset
= offset_from_vma
5732 (file
, version_info
[DT_VERSIONTAGIDX (DT_VERDEF
)],
5737 get_data (&evd
, file
, offset
, sizeof (evd
),
5740 ivd
.vd_next
= BYTE_GET (evd
.vd_next
);
5741 ivd
.vd_ndx
= BYTE_GET (evd
.vd_ndx
);
5743 offset
+= ivd
.vd_next
;
5745 while (ivd
.vd_ndx
!= (data
[cnt
+ j
] & 0x7fff)
5746 && ivd
.vd_next
!= 0);
5748 if (ivd
.vd_ndx
== (data
[cnt
+ j
] & 0x7fff))
5750 Elf_External_Verdaux evda
;
5751 Elf_Internal_Verdaux ivda
;
5753 ivd
.vd_aux
= BYTE_GET (evd
.vd_aux
);
5755 get_data (&evda
, file
,
5756 offset
- ivd
.vd_next
+ ivd
.vd_aux
,
5757 sizeof (evda
), _("version def aux"));
5759 ivda
.vda_name
= BYTE_GET (evda
.vda_name
);
5761 name
= strtab
+ ivda
.vda_name
;
5762 nn
+= printf ("(%s%-*s",
5764 12 - (int) strlen (name
),
5770 printf ("%*c", 18 - nn
, ' ');
5788 printf (_("\nNo version information found in this file.\n"));
5794 get_symbol_binding (binding
)
5795 unsigned int binding
;
5797 static char buff
[32];
5801 case STB_LOCAL
: return "LOCAL";
5802 case STB_GLOBAL
: return "GLOBAL";
5803 case STB_WEAK
: return "WEAK";
5805 if (binding
>= STB_LOPROC
&& binding
<= STB_HIPROC
)
5806 sprintf (buff
, _("<processor specific>: %d"), binding
);
5807 else if (binding
>= STB_LOOS
&& binding
<= STB_HIOS
)
5808 sprintf (buff
, _("<OS specific>: %d"), binding
);
5810 sprintf (buff
, _("<unknown>: %d"), binding
);
5816 get_symbol_type (type
)
5819 static char buff
[32];
5823 case STT_NOTYPE
: return "NOTYPE";
5824 case STT_OBJECT
: return "OBJECT";
5825 case STT_FUNC
: return "FUNC";
5826 case STT_SECTION
: return "SECTION";
5827 case STT_FILE
: return "FILE";
5828 case STT_COMMON
: return "COMMON";
5829 case STT_TLS
: return "TLS";
5831 if (type
>= STT_LOPROC
&& type
<= STT_HIPROC
)
5833 if (elf_header
.e_machine
== EM_ARM
&& type
== STT_ARM_TFUNC
)
5834 return "THUMB_FUNC";
5836 if (elf_header
.e_machine
== EM_SPARCV9
&& type
== STT_REGISTER
)
5839 if (elf_header
.e_machine
== EM_PARISC
&& type
== STT_PARISC_MILLI
)
5840 return "PARISC_MILLI";
5842 sprintf (buff
, _("<processor specific>: %d"), type
);
5844 else if (type
>= STT_LOOS
&& type
<= STT_HIOS
)
5846 if (elf_header
.e_machine
== EM_PARISC
)
5848 if (type
== STT_HP_OPAQUE
)
5850 if (type
== STT_HP_STUB
)
5854 sprintf (buff
, _("<OS specific>: %d"), type
);
5857 sprintf (buff
, _("<unknown>: %d"), type
);
5863 get_symbol_visibility (visibility
)
5864 unsigned int visibility
;
5868 case STV_DEFAULT
: return "DEFAULT";
5869 case STV_INTERNAL
: return "INTERNAL";
5870 case STV_HIDDEN
: return "HIDDEN";
5871 case STV_PROTECTED
: return "PROTECTED";
5877 get_symbol_index_type (type
)
5880 static char buff
[32];
5884 case SHN_UNDEF
: return "UND";
5885 case SHN_ABS
: return "ABS";
5886 case SHN_COMMON
: return "COM";
5888 if (type
>= SHN_LOPROC
&& type
<= SHN_HIPROC
)
5889 sprintf (buff
, "PRC[0x%04x]", type
);
5890 else if (type
>= SHN_LOOS
&& type
<= SHN_HIOS
)
5891 sprintf (buff
, "OS [0x%04x]", type
);
5892 else if (type
>= SHN_LORESERVE
&& type
<= SHN_HIRESERVE
)
5893 sprintf (buff
, "RSV[0x%04x]", type
);
5895 sprintf (buff
, "%3d", type
);
5903 get_dynamic_data (file
, number
)
5905 unsigned int number
;
5907 unsigned char *e_data
;
5910 e_data
= (unsigned char *) malloc (number
* 4);
5914 error (_("Out of memory\n"));
5918 if (fread (e_data
, 4, number
, file
) != number
)
5920 error (_("Unable to read in dynamic data\n"));
5924 i_data
= (int *) malloc (number
* sizeof (*i_data
));
5928 error (_("Out of memory\n"));
5934 i_data
[number
] = byte_get (e_data
+ number
* 4, 4);
5941 /* Dump the symbol table. */
5943 process_symbol_table (file
)
5946 Elf_Internal_Shdr
*section
;
5947 unsigned char nb
[4];
5948 unsigned char nc
[4];
5951 int *buckets
= NULL
;
5954 if (! do_syms
&& !do_histogram
)
5957 if (dynamic_info
[DT_HASH
] && ((do_using_dynamic
&& dynamic_strings
!= NULL
)
5960 if (fseek (file
, offset_from_vma (file
, dynamic_info
[DT_HASH
],
5961 sizeof nb
+ sizeof nc
),
5964 error (_("Unable to seek to start of dynamic information"));
5968 if (fread (nb
, sizeof (nb
), 1, file
) != 1)
5970 error (_("Failed to read in number of buckets\n"));
5974 if (fread (nc
, sizeof (nc
), 1, file
) != 1)
5976 error (_("Failed to read in number of chains\n"));
5980 nbuckets
= byte_get (nb
, 4);
5981 nchains
= byte_get (nc
, 4);
5983 buckets
= get_dynamic_data (file
, nbuckets
);
5984 chains
= get_dynamic_data (file
, nchains
);
5986 if (buckets
== NULL
|| chains
== NULL
)
5991 && dynamic_info
[DT_HASH
] && do_using_dynamic
&& dynamic_strings
!= NULL
)
5996 printf (_("\nSymbol table for image:\n"));
5998 printf (_(" Num Buc: Value Size Type Bind Vis Ndx Name\n"));
6000 printf (_(" Num Buc: Value Size Type Bind Vis Ndx Name\n"));
6002 for (hn
= 0; hn
< nbuckets
; hn
++)
6007 for (si
= buckets
[hn
]; si
< nchains
&& si
> 0; si
= chains
[si
])
6009 Elf_Internal_Sym
*psym
;
6011 psym
= dynamic_symbols
+ si
;
6013 printf (" %3d %3d: ", si
, hn
);
6014 print_vma (psym
->st_value
, LONG_HEX
);
6016 print_vma (psym
->st_size
, DEC_5
);
6018 printf (" %6s", get_symbol_type (ELF_ST_TYPE (psym
->st_info
)));
6019 printf (" %6s", get_symbol_binding (ELF_ST_BIND (psym
->st_info
)));
6020 printf (" %3s", get_symbol_visibility (ELF_ST_VISIBILITY (psym
->st_other
)));
6021 printf (" %3.3s ", get_symbol_index_type (psym
->st_shndx
));
6022 print_symbol (25, dynamic_strings
+ psym
->st_name
);
6027 else if (do_syms
&& !do_using_dynamic
)
6031 for (i
= 0, section
= section_headers
;
6032 i
< elf_header
.e_shnum
;
6037 Elf_Internal_Sym
*symtab
;
6038 Elf_Internal_Sym
*psym
;
6041 if ( section
->sh_type
!= SHT_SYMTAB
6042 && section
->sh_type
!= SHT_DYNSYM
)
6045 printf (_("\nSymbol table '%s' contains %lu entries:\n"),
6046 SECTION_NAME (section
),
6047 (unsigned long) (section
->sh_size
/ section
->sh_entsize
));
6049 printf (_(" Num: Value Size Type Bind Vis Ndx Name\n"));
6051 printf (_(" Num: Value Size Type Bind Vis Ndx Name\n"));
6053 symtab
= GET_ELF_SYMBOLS (file
, section
);
6057 if (section
->sh_link
== elf_header
.e_shstrndx
)
6058 strtab
= string_table
;
6061 Elf_Internal_Shdr
*string_sec
;
6063 string_sec
= SECTION_HEADER (section
->sh_link
);
6065 strtab
= (char *) get_data (NULL
, file
, string_sec
->sh_offset
,
6066 string_sec
->sh_size
,
6070 for (si
= 0, psym
= symtab
;
6071 si
< section
->sh_size
/ section
->sh_entsize
;
6074 printf ("%6d: ", si
);
6075 print_vma (psym
->st_value
, LONG_HEX
);
6077 print_vma (psym
->st_size
, DEC_5
);
6078 printf (" %-7s", get_symbol_type (ELF_ST_TYPE (psym
->st_info
)));
6079 printf (" %-6s", get_symbol_binding (ELF_ST_BIND (psym
->st_info
)));
6080 printf (" %-3s", get_symbol_visibility (ELF_ST_VISIBILITY (psym
->st_other
)));
6081 printf (" %4s ", get_symbol_index_type (psym
->st_shndx
));
6082 print_symbol (25, strtab
+ psym
->st_name
);
6084 if (section
->sh_type
== SHT_DYNSYM
&&
6085 version_info
[DT_VERSIONTAGIDX (DT_VERSYM
)] != 0)
6087 unsigned char data
[2];
6088 unsigned short vers_data
;
6089 unsigned long offset
;
6093 offset
= offset_from_vma
6094 (file
, version_info
[DT_VERSIONTAGIDX (DT_VERSYM
)],
6095 sizeof data
+ si
* sizeof (vers_data
));
6097 get_data (&data
, file
, offset
+ si
* sizeof (vers_data
),
6098 sizeof (data
), _("version data"));
6100 vers_data
= byte_get (data
, 2);
6102 is_nobits
= (SECTION_HEADER (psym
->st_shndx
)->sh_type
6105 check_def
= (psym
->st_shndx
!= SHN_UNDEF
);
6107 if ((vers_data
& 0x8000) || vers_data
> 1)
6109 if (version_info
[DT_VERSIONTAGIDX (DT_VERNEED
)]
6110 && (is_nobits
|| ! check_def
))
6112 Elf_External_Verneed evn
;
6113 Elf_Internal_Verneed ivn
;
6114 Elf_Internal_Vernaux ivna
;
6116 /* We must test both. */
6117 offset
= offset_from_vma
6118 (file
, version_info
[DT_VERSIONTAGIDX (DT_VERNEED
)],
6123 unsigned long vna_off
;
6125 get_data (&evn
, file
, offset
, sizeof (evn
),
6128 ivn
.vn_aux
= BYTE_GET (evn
.vn_aux
);
6129 ivn
.vn_next
= BYTE_GET (evn
.vn_next
);
6131 vna_off
= offset
+ ivn
.vn_aux
;
6135 Elf_External_Vernaux evna
;
6137 get_data (&evna
, file
, vna_off
,
6139 _("version need aux (3)"));
6141 ivna
.vna_other
= BYTE_GET (evna
.vna_other
);
6142 ivna
.vna_next
= BYTE_GET (evna
.vna_next
);
6143 ivna
.vna_name
= BYTE_GET (evna
.vna_name
);
6145 vna_off
+= ivna
.vna_next
;
6147 while (ivna
.vna_other
!= vers_data
6148 && ivna
.vna_next
!= 0);
6150 if (ivna
.vna_other
== vers_data
)
6153 offset
+= ivn
.vn_next
;
6155 while (ivn
.vn_next
!= 0);
6157 if (ivna
.vna_other
== vers_data
)
6160 strtab
+ ivna
.vna_name
, ivna
.vna_other
);
6163 else if (! is_nobits
)
6164 error (_("bad dynamic symbol"));
6171 if (vers_data
!= 0x8001
6172 && version_info
[DT_VERSIONTAGIDX (DT_VERDEF
)])
6174 Elf_Internal_Verdef ivd
;
6175 Elf_Internal_Verdaux ivda
;
6176 Elf_External_Verdaux evda
;
6177 unsigned long offset
;
6179 offset
= offset_from_vma
6181 version_info
[DT_VERSIONTAGIDX (DT_VERDEF
)],
6182 sizeof (Elf_External_Verdef
));
6186 Elf_External_Verdef evd
;
6188 get_data (&evd
, file
, offset
, sizeof (evd
),
6191 ivd
.vd_ndx
= BYTE_GET (evd
.vd_ndx
);
6192 ivd
.vd_aux
= BYTE_GET (evd
.vd_aux
);
6193 ivd
.vd_next
= BYTE_GET (evd
.vd_next
);
6195 offset
+= ivd
.vd_next
;
6197 while (ivd
.vd_ndx
!= (vers_data
& 0x7fff)
6198 && ivd
.vd_next
!= 0);
6200 offset
-= ivd
.vd_next
;
6201 offset
+= ivd
.vd_aux
;
6203 get_data (&evda
, file
, offset
, sizeof (evda
),
6204 _("version def aux"));
6206 ivda
.vda_name
= BYTE_GET (evda
.vda_name
);
6208 if (psym
->st_name
!= ivda
.vda_name
)
6209 printf ((vers_data
& 0x8000)
6211 strtab
+ ivda
.vda_name
);
6221 if (strtab
!= string_table
)
6227 (_("\nDynamic symbol information is not available for displaying symbols.\n"));
6229 if (do_histogram
&& buckets
!= NULL
)
6236 int nzero_counts
= 0;
6239 printf (_("\nHistogram for bucket list length (total of %d buckets):\n"),
6241 printf (_(" Length Number %% of total Coverage\n"));
6243 lengths
= (int *) calloc (nbuckets
, sizeof (int));
6244 if (lengths
== NULL
)
6246 error (_("Out of memory"));
6249 for (hn
= 0; hn
< nbuckets
; ++hn
)
6254 for (si
= buckets
[hn
]; si
> 0 && si
< nchains
; si
= chains
[si
])
6257 if (maxlength
< ++lengths
[hn
])
6262 counts
= (int *) calloc (maxlength
+ 1, sizeof (int));
6265 error (_("Out of memory"));
6269 for (hn
= 0; hn
< nbuckets
; ++hn
)
6270 ++counts
[lengths
[hn
]];
6274 printf (" 0 %-10d (%5.1f%%)\n",
6275 counts
[0], (counts
[0] * 100.0) / nbuckets
);
6276 for (si
= 1; si
<= maxlength
; ++si
)
6278 nzero_counts
+= counts
[si
] * si
;
6279 printf ("%7d %-10d (%5.1f%%) %5.1f%%\n",
6280 si
, counts
[si
], (counts
[si
] * 100.0) / nbuckets
,
6281 (nzero_counts
* 100.0) / nsyms
);
6289 if (buckets
!= NULL
)
6299 process_syminfo (file
)
6300 FILE *file ATTRIBUTE_UNUSED
;
6304 if (dynamic_syminfo
== NULL
6306 /* No syminfo, this is ok. */
6309 /* There better should be a dynamic symbol section. */
6310 if (dynamic_symbols
== NULL
|| dynamic_strings
== NULL
)
6314 printf (_("\nDynamic info segment at offset 0x%lx contains %d entries:\n"),
6315 dynamic_syminfo_offset
, dynamic_syminfo_nent
);
6317 printf (_(" Num: Name BoundTo Flags\n"));
6318 for (i
= 0; i
< dynamic_syminfo_nent
; ++i
)
6320 unsigned short int flags
= dynamic_syminfo
[i
].si_flags
;
6322 printf ("%4d: ", i
);
6323 print_symbol (30, dynamic_strings
+ dynamic_symbols
[i
].st_name
);
6326 switch (dynamic_syminfo
[i
].si_boundto
)
6328 case SYMINFO_BT_SELF
:
6329 fputs ("SELF ", stdout
);
6331 case SYMINFO_BT_PARENT
:
6332 fputs ("PARENT ", stdout
);
6335 if (dynamic_syminfo
[i
].si_boundto
> 0
6336 && dynamic_syminfo
[i
].si_boundto
< dynamic_size
)
6341 [dynamic_syminfo
[i
].si_boundto
].d_un
.d_val
));
6345 printf ("%-10d ", dynamic_syminfo
[i
].si_boundto
);
6349 if (flags
& SYMINFO_FLG_DIRECT
)
6351 if (flags
& SYMINFO_FLG_PASSTHRU
)
6352 printf (" PASSTHRU");
6353 if (flags
& SYMINFO_FLG_COPY
)
6355 if (flags
& SYMINFO_FLG_LAZYLOAD
)
6356 printf (" LAZYLOAD");
6364 #ifdef SUPPORT_DISASSEMBLY
6366 disassemble_section (section
, file
)
6367 Elf_Internal_Shdr
*section
;
6370 printf (_("\nAssembly dump of section %s\n"),
6371 SECTION_NAME (section
));
6373 /* XXX -- to be done --- XXX */
6380 dump_section (section
, file
)
6381 Elf_Internal_Shdr
*section
;
6384 bfd_size_type bytes
;
6386 unsigned char *data
;
6387 unsigned char *start
;
6389 bytes
= section
->sh_size
;
6393 printf (_("\nSection '%s' has no data to dump.\n"),
6394 SECTION_NAME (section
));
6398 printf (_("\nHex dump of section '%s':\n"), SECTION_NAME (section
));
6400 addr
= section
->sh_addr
;
6402 start
= (unsigned char *) get_data (NULL
, file
, section
->sh_offset
, bytes
,
6415 lbytes
= (bytes
> 16 ? 16 : bytes
);
6417 printf (" 0x%8.8lx ", (unsigned long) addr
);
6419 switch (elf_header
.e_ident
[EI_DATA
])
6423 for (j
= 15; j
>= 0; j
--)
6426 printf ("%2.2x", data
[j
]);
6436 for (j
= 0; j
< 16; j
++)
6439 printf ("%2.2x", data
[j
]);
6449 for (j
= 0; j
< lbytes
; j
++)
6452 if (k
>= ' ' && k
< 0x80)
6471 static unsigned long int
6472 read_leb128 (data
, length_return
, sign
)
6473 unsigned char *data
;
6477 unsigned long int result
= 0;
6478 unsigned int num_read
= 0;
6487 result
|= (byte
& 0x7f) << shift
;
6492 while (byte
& 0x80);
6494 if (length_return
!= NULL
)
6495 *length_return
= num_read
;
6497 if (sign
&& (shift
< 32) && (byte
& 0x40))
6498 result
|= -1 << shift
;
6503 typedef struct State_Machine_Registers
6505 unsigned long address
;
6508 unsigned int column
;
6512 /* This variable hold the number of the last entry seen
6513 in the File Table. */
6514 unsigned int last_file_entry
;
6517 static SMR state_machine_regs
;
6520 reset_state_machine (is_stmt
)
6523 state_machine_regs
.address
= 0;
6524 state_machine_regs
.file
= 1;
6525 state_machine_regs
.line
= 1;
6526 state_machine_regs
.column
= 0;
6527 state_machine_regs
.is_stmt
= is_stmt
;
6528 state_machine_regs
.basic_block
= 0;
6529 state_machine_regs
.end_sequence
= 0;
6530 state_machine_regs
.last_file_entry
= 0;
6533 /* Handled an extend line op. Returns true if this is the end
6536 process_extended_line_op (data
, is_stmt
, pointer_size
)
6537 unsigned char *data
;
6541 unsigned char op_code
;
6544 unsigned char *name
;
6547 len
= read_leb128 (data
, & bytes_read
, 0);
6552 warn (_("badly formed extended line op encountered!\n"));
6559 printf (_(" Extended opcode %d: "), op_code
);
6563 case DW_LNE_end_sequence
:
6564 printf (_("End of Sequence\n\n"));
6565 reset_state_machine (is_stmt
);
6568 case DW_LNE_set_address
:
6569 adr
= byte_get (data
, pointer_size
);
6570 printf (_("set Address to 0x%lx\n"), adr
);
6571 state_machine_regs
.address
= adr
;
6574 case DW_LNE_define_file
:
6575 printf (_(" define new File Table entry\n"));
6576 printf (_(" Entry\tDir\tTime\tSize\tName\n"));
6578 printf (_(" %d\t"), ++state_machine_regs
.last_file_entry
);
6580 data
+= strlen ((char *) data
) + 1;
6581 printf (_("%lu\t"), read_leb128 (data
, & bytes_read
, 0));
6583 printf (_("%lu\t"), read_leb128 (data
, & bytes_read
, 0));
6585 printf (_("%lu\t"), read_leb128 (data
, & bytes_read
, 0));
6586 printf (_("%s\n\n"), name
);
6590 printf (_("UNKNOWN: length %d\n"), len
- bytes_read
);
6597 /* Size of pointers in the .debug_line section. This information is not
6598 really present in that section. It's obtained before dumping the debug
6599 sections by doing some pre-scan of the .debug_info section. */
6600 static int debug_line_pointer_size
= 4;
6603 display_debug_lines (section
, start
, file
)
6604 Elf_Internal_Shdr
*section
;
6605 unsigned char * start
;
6606 FILE *file ATTRIBUTE_UNUSED
;
6608 unsigned char *hdrptr
;
6609 DWARF2_Internal_LineInfo info
;
6610 unsigned char *standard_opcodes
;
6611 unsigned char *data
= start
;
6612 unsigned char *end
= start
+ section
->sh_size
;
6613 unsigned char *end_of_sequence
;
6616 int initial_length_size
;
6618 printf (_("\nDump of debug contents of section %s:\n\n"),
6619 SECTION_NAME (section
));
6625 /* Check the length of the block. */
6626 info
.li_length
= byte_get (hdrptr
, 4);
6629 if (info
.li_length
== 0xffffffff)
6631 /* This section is 64-bit DWARF 3. */
6632 info
.li_length
= byte_get (hdrptr
, 8);
6635 initial_length_size
= 12;
6640 initial_length_size
= 4;
6643 if (info
.li_length
+ initial_length_size
> section
->sh_size
)
6646 (_("The line info appears to be corrupt - the section is too small\n"));
6650 /* Check its version number. */
6651 info
.li_version
= byte_get (hdrptr
, 2);
6653 if (info
.li_version
!= 2 && info
.li_version
!= 3)
6655 warn (_("Only DWARF version 2 and 3 line info is currently supported.\n"));
6659 info
.li_prologue_length
= byte_get (hdrptr
, offset_size
);
6660 hdrptr
+= offset_size
;
6661 info
.li_min_insn_length
= byte_get (hdrptr
, 1);
6663 info
.li_default_is_stmt
= byte_get (hdrptr
, 1);
6665 info
.li_line_base
= byte_get (hdrptr
, 1);
6667 info
.li_line_range
= byte_get (hdrptr
, 1);
6669 info
.li_opcode_base
= byte_get (hdrptr
, 1);
6672 /* Sign extend the line base field. */
6673 info
.li_line_base
<<= 24;
6674 info
.li_line_base
>>= 24;
6676 printf (_(" Length: %ld\n"), info
.li_length
);
6677 printf (_(" DWARF Version: %d\n"), info
.li_version
);
6678 printf (_(" Prologue Length: %d\n"), info
.li_prologue_length
);
6679 printf (_(" Minimum Instruction Length: %d\n"), info
.li_min_insn_length
);
6680 printf (_(" Initial value of 'is_stmt': %d\n"), info
.li_default_is_stmt
);
6681 printf (_(" Line Base: %d\n"), info
.li_line_base
);
6682 printf (_(" Line Range: %d\n"), info
.li_line_range
);
6683 printf (_(" Opcode Base: %d\n"), info
.li_opcode_base
);
6685 end_of_sequence
= data
+ info
.li_length
+ initial_length_size
;
6687 reset_state_machine (info
.li_default_is_stmt
);
6689 /* Display the contents of the Opcodes table. */
6690 standard_opcodes
= hdrptr
;
6692 printf (_("\n Opcodes:\n"));
6694 for (i
= 1; i
< info
.li_opcode_base
; i
++)
6695 printf (_(" Opcode %d has %d args\n"), i
, standard_opcodes
[i
- 1]);
6697 /* Display the contents of the Directory table. */
6698 data
= standard_opcodes
+ info
.li_opcode_base
- 1;
6701 printf (_("\n The Directory Table is empty.\n"));
6704 printf (_("\n The Directory Table:\n"));
6708 printf (_(" %s\n"), data
);
6710 data
+= strlen ((char *) data
) + 1;
6714 /* Skip the NUL at the end of the table. */
6717 /* Display the contents of the File Name table. */
6719 printf (_("\n The File Name Table is empty.\n"));
6722 printf (_("\n The File Name Table:\n"));
6723 printf (_(" Entry\tDir\tTime\tSize\tName\n"));
6727 unsigned char *name
;
6730 printf (_(" %d\t"), ++state_machine_regs
.last_file_entry
);
6733 data
+= strlen ((char *) data
) + 1;
6735 printf (_("%lu\t"), read_leb128 (data
, & bytes_read
, 0));
6737 printf (_("%lu\t"), read_leb128 (data
, & bytes_read
, 0));
6739 printf (_("%lu\t"), read_leb128 (data
, & bytes_read
, 0));
6741 printf (_("%s\n"), name
);
6745 /* Skip the NUL at the end of the table. */
6748 /* Now display the statements. */
6749 printf (_("\n Line Number Statements:\n"));
6752 while (data
< end_of_sequence
)
6754 unsigned char op_code
;
6760 if (op_code
>= info
.li_opcode_base
)
6762 op_code
-= info
.li_opcode_base
;
6763 adv
= (op_code
/ info
.li_line_range
) * info
.li_min_insn_length
;
6764 state_machine_regs
.address
+= adv
;
6765 printf (_(" Special opcode %d: advance Address by %d to 0x%lx"),
6766 op_code
, adv
, state_machine_regs
.address
);
6767 adv
= (op_code
% info
.li_line_range
) + info
.li_line_base
;
6768 state_machine_regs
.line
+= adv
;
6769 printf (_(" and Line by %d to %d\n"),
6770 adv
, state_machine_regs
.line
);
6772 else switch (op_code
)
6774 case DW_LNS_extended_op
:
6775 data
+= process_extended_line_op (data
, info
.li_default_is_stmt
,
6776 debug_line_pointer_size
);
6780 printf (_(" Copy\n"));
6783 case DW_LNS_advance_pc
:
6784 adv
= info
.li_min_insn_length
* read_leb128 (data
, & bytes_read
, 0);
6786 state_machine_regs
.address
+= adv
;
6787 printf (_(" Advance PC by %d to %lx\n"), adv
,
6788 state_machine_regs
.address
);
6791 case DW_LNS_advance_line
:
6792 adv
= read_leb128 (data
, & bytes_read
, 1);
6794 state_machine_regs
.line
+= adv
;
6795 printf (_(" Advance Line by %d to %d\n"), adv
,
6796 state_machine_regs
.line
);
6799 case DW_LNS_set_file
:
6800 adv
= read_leb128 (data
, & bytes_read
, 0);
6802 printf (_(" Set File Name to entry %d in the File Name Table\n"),
6804 state_machine_regs
.file
= adv
;
6807 case DW_LNS_set_column
:
6808 adv
= read_leb128 (data
, & bytes_read
, 0);
6810 printf (_(" Set column to %d\n"), adv
);
6811 state_machine_regs
.column
= adv
;
6814 case DW_LNS_negate_stmt
:
6815 adv
= state_machine_regs
.is_stmt
;
6817 printf (_(" Set is_stmt to %d\n"), adv
);
6818 state_machine_regs
.is_stmt
= adv
;
6821 case DW_LNS_set_basic_block
:
6822 printf (_(" Set basic block\n"));
6823 state_machine_regs
.basic_block
= 1;
6826 case DW_LNS_const_add_pc
:
6827 adv
= (((255 - info
.li_opcode_base
) / info
.li_line_range
)
6828 * info
.li_min_insn_length
);
6829 state_machine_regs
.address
+= adv
;
6830 printf (_(" Advance PC by constant %d to 0x%lx\n"), adv
,
6831 state_machine_regs
.address
);
6834 case DW_LNS_fixed_advance_pc
:
6835 adv
= byte_get (data
, 2);
6837 state_machine_regs
.address
+= adv
;
6838 printf (_(" Advance PC by fixed size amount %d to 0x%lx\n"),
6839 adv
, state_machine_regs
.address
);
6842 case DW_LNS_set_prologue_end
:
6843 printf (_(" Set prologue_end to true\n"));
6846 case DW_LNS_set_epilogue_begin
:
6847 printf (_(" Set epilogue_begin to true\n"));
6850 case DW_LNS_set_isa
:
6851 adv
= read_leb128 (data
, & bytes_read
, 0);
6853 printf (_(" Set ISA to %d\n"), adv
);
6857 printf (_(" Unknown opcode %d with operands: "), op_code
);
6860 for (i
= standard_opcodes
[op_code
- 1]; i
> 0 ; --i
)
6862 printf ("0x%lx%s", read_leb128 (data
, &bytes_read
, 0),
6863 i
== 1 ? "" : ", ");
6878 display_debug_pubnames (section
, start
, file
)
6879 Elf_Internal_Shdr
*section
;
6880 unsigned char *start
;
6881 FILE *file ATTRIBUTE_UNUSED
;
6883 DWARF2_Internal_PubNames pubnames
;
6886 end
= start
+ section
->sh_size
;
6888 printf (_("Contents of the %s section:\n\n"), SECTION_NAME (section
));
6892 unsigned char *data
;
6893 unsigned long offset
;
6894 int offset_size
, initial_length_size
;
6898 pubnames
.pn_length
= byte_get (data
, 4);
6900 if (pubnames
.pn_length
== 0xffffffff)
6902 pubnames
.pn_length
= byte_get (data
, 8);
6905 initial_length_size
= 12;
6910 initial_length_size
= 4;
6913 pubnames
.pn_version
= byte_get (data
, 2);
6915 pubnames
.pn_offset
= byte_get (data
, offset_size
);
6916 data
+= offset_size
;
6917 pubnames
.pn_size
= byte_get (data
, offset_size
);
6918 data
+= offset_size
;
6920 start
+= pubnames
.pn_length
+ initial_length_size
;
6922 if (pubnames
.pn_version
!= 2 && pubnames
.pn_version
!= 3)
6924 static int warned
= 0;
6928 warn (_("Only DWARF 2 and 3 pubnames are currently supported\n"));
6935 printf (_(" Length: %ld\n"),
6936 pubnames
.pn_length
);
6937 printf (_(" Version: %d\n"),
6938 pubnames
.pn_version
);
6939 printf (_(" Offset into .debug_info section: %ld\n"),
6940 pubnames
.pn_offset
);
6941 printf (_(" Size of area in .debug_info section: %ld\n"),
6944 printf (_("\n Offset\tName\n"));
6948 offset
= byte_get (data
, offset_size
);
6952 data
+= offset_size
;
6953 printf (" %ld\t\t%s\n", offset
, data
);
6954 data
+= strlen ((char *) data
) + 1;
6957 while (offset
!= 0);
6970 case DW_TAG_padding
: return "DW_TAG_padding";
6971 case DW_TAG_array_type
: return "DW_TAG_array_type";
6972 case DW_TAG_class_type
: return "DW_TAG_class_type";
6973 case DW_TAG_entry_point
: return "DW_TAG_entry_point";
6974 case DW_TAG_enumeration_type
: return "DW_TAG_enumeration_type";
6975 case DW_TAG_formal_parameter
: return "DW_TAG_formal_parameter";
6976 case DW_TAG_imported_declaration
: return "DW_TAG_imported_declaration";
6977 case DW_TAG_label
: return "DW_TAG_label";
6978 case DW_TAG_lexical_block
: return "DW_TAG_lexical_block";
6979 case DW_TAG_member
: return "DW_TAG_member";
6980 case DW_TAG_pointer_type
: return "DW_TAG_pointer_type";
6981 case DW_TAG_reference_type
: return "DW_TAG_reference_type";
6982 case DW_TAG_compile_unit
: return "DW_TAG_compile_unit";
6983 case DW_TAG_string_type
: return "DW_TAG_string_type";
6984 case DW_TAG_structure_type
: return "DW_TAG_structure_type";
6985 case DW_TAG_subroutine_type
: return "DW_TAG_subroutine_type";
6986 case DW_TAG_typedef
: return "DW_TAG_typedef";
6987 case DW_TAG_union_type
: return "DW_TAG_union_type";
6988 case DW_TAG_unspecified_parameters
: return "DW_TAG_unspecified_parameters";
6989 case DW_TAG_variant
: return "DW_TAG_variant";
6990 case DW_TAG_common_block
: return "DW_TAG_common_block";
6991 case DW_TAG_common_inclusion
: return "DW_TAG_common_inclusion";
6992 case DW_TAG_inheritance
: return "DW_TAG_inheritance";
6993 case DW_TAG_inlined_subroutine
: return "DW_TAG_inlined_subroutine";
6994 case DW_TAG_module
: return "DW_TAG_module";
6995 case DW_TAG_ptr_to_member_type
: return "DW_TAG_ptr_to_member_type";
6996 case DW_TAG_set_type
: return "DW_TAG_set_type";
6997 case DW_TAG_subrange_type
: return "DW_TAG_subrange_type";
6998 case DW_TAG_with_stmt
: return "DW_TAG_with_stmt";
6999 case DW_TAG_access_declaration
: return "DW_TAG_access_declaration";
7000 case DW_TAG_base_type
: return "DW_TAG_base_type";
7001 case DW_TAG_catch_block
: return "DW_TAG_catch_block";
7002 case DW_TAG_const_type
: return "DW_TAG_const_type";
7003 case DW_TAG_constant
: return "DW_TAG_constant";
7004 case DW_TAG_enumerator
: return "DW_TAG_enumerator";
7005 case DW_TAG_file_type
: return "DW_TAG_file_type";
7006 case DW_TAG_friend
: return "DW_TAG_friend";
7007 case DW_TAG_namelist
: return "DW_TAG_namelist";
7008 case DW_TAG_namelist_item
: return "DW_TAG_namelist_item";
7009 case DW_TAG_packed_type
: return "DW_TAG_packed_type";
7010 case DW_TAG_subprogram
: return "DW_TAG_subprogram";
7011 case DW_TAG_template_type_param
: return "DW_TAG_template_type_param";
7012 case DW_TAG_template_value_param
: return "DW_TAG_template_value_param";
7013 case DW_TAG_thrown_type
: return "DW_TAG_thrown_type";
7014 case DW_TAG_try_block
: return "DW_TAG_try_block";
7015 case DW_TAG_variant_part
: return "DW_TAG_variant_part";
7016 case DW_TAG_variable
: return "DW_TAG_variable";
7017 case DW_TAG_volatile_type
: return "DW_TAG_volatile_type";
7018 case DW_TAG_MIPS_loop
: return "DW_TAG_MIPS_loop";
7019 case DW_TAG_format_label
: return "DW_TAG_format_label";
7020 case DW_TAG_function_template
: return "DW_TAG_function_template";
7021 case DW_TAG_class_template
: return "DW_TAG_class_template";
7022 /* DWARF 2.1 values. */
7023 case DW_TAG_dwarf_procedure
: return "DW_TAG_dwarf_procedure";
7024 case DW_TAG_restrict_type
: return "DW_TAG_restrict_type";
7025 case DW_TAG_interface_type
: return "DW_TAG_interface_type";
7026 case DW_TAG_namespace
: return "DW_TAG_namespace";
7027 case DW_TAG_imported_module
: return "DW_TAG_imported_module";
7028 case DW_TAG_unspecified_type
: return "DW_TAG_unspecified_type";
7029 case DW_TAG_partial_unit
: return "DW_TAG_partial_unit";
7030 case DW_TAG_imported_unit
: return "DW_TAG_imported_unit";
7032 case DW_TAG_upc_shared_type
: return "DW_TAG_upc_shared_type";
7033 case DW_TAG_upc_strict_type
: return "DW_TAG_upc_strict_type";
7034 case DW_TAG_upc_relaxed_type
: return "DW_TAG_upc_relaxed_type";
7037 static char buffer
[100];
7039 sprintf (buffer
, _("Unknown TAG value: %lx"), tag
);
7046 get_AT_name (attribute
)
7047 unsigned long attribute
;
7051 case DW_AT_sibling
: return "DW_AT_sibling";
7052 case DW_AT_location
: return "DW_AT_location";
7053 case DW_AT_name
: return "DW_AT_name";
7054 case DW_AT_ordering
: return "DW_AT_ordering";
7055 case DW_AT_subscr_data
: return "DW_AT_subscr_data";
7056 case DW_AT_byte_size
: return "DW_AT_byte_size";
7057 case DW_AT_bit_offset
: return "DW_AT_bit_offset";
7058 case DW_AT_bit_size
: return "DW_AT_bit_size";
7059 case DW_AT_element_list
: return "DW_AT_element_list";
7060 case DW_AT_stmt_list
: return "DW_AT_stmt_list";
7061 case DW_AT_low_pc
: return "DW_AT_low_pc";
7062 case DW_AT_high_pc
: return "DW_AT_high_pc";
7063 case DW_AT_language
: return "DW_AT_language";
7064 case DW_AT_member
: return "DW_AT_member";
7065 case DW_AT_discr
: return "DW_AT_discr";
7066 case DW_AT_discr_value
: return "DW_AT_discr_value";
7067 case DW_AT_visibility
: return "DW_AT_visibility";
7068 case DW_AT_import
: return "DW_AT_import";
7069 case DW_AT_string_length
: return "DW_AT_string_length";
7070 case DW_AT_common_reference
: return "DW_AT_common_reference";
7071 case DW_AT_comp_dir
: return "DW_AT_comp_dir";
7072 case DW_AT_const_value
: return "DW_AT_const_value";
7073 case DW_AT_containing_type
: return "DW_AT_containing_type";
7074 case DW_AT_default_value
: return "DW_AT_default_value";
7075 case DW_AT_inline
: return "DW_AT_inline";
7076 case DW_AT_is_optional
: return "DW_AT_is_optional";
7077 case DW_AT_lower_bound
: return "DW_AT_lower_bound";
7078 case DW_AT_producer
: return "DW_AT_producer";
7079 case DW_AT_prototyped
: return "DW_AT_prototyped";
7080 case DW_AT_return_addr
: return "DW_AT_return_addr";
7081 case DW_AT_start_scope
: return "DW_AT_start_scope";
7082 case DW_AT_stride_size
: return "DW_AT_stride_size";
7083 case DW_AT_upper_bound
: return "DW_AT_upper_bound";
7084 case DW_AT_abstract_origin
: return "DW_AT_abstract_origin";
7085 case DW_AT_accessibility
: return "DW_AT_accessibility";
7086 case DW_AT_address_class
: return "DW_AT_address_class";
7087 case DW_AT_artificial
: return "DW_AT_artificial";
7088 case DW_AT_base_types
: return "DW_AT_base_types";
7089 case DW_AT_calling_convention
: return "DW_AT_calling_convention";
7090 case DW_AT_count
: return "DW_AT_count";
7091 case DW_AT_data_member_location
: return "DW_AT_data_member_location";
7092 case DW_AT_decl_column
: return "DW_AT_decl_column";
7093 case DW_AT_decl_file
: return "DW_AT_decl_file";
7094 case DW_AT_decl_line
: return "DW_AT_decl_line";
7095 case DW_AT_declaration
: return "DW_AT_declaration";
7096 case DW_AT_discr_list
: return "DW_AT_discr_list";
7097 case DW_AT_encoding
: return "DW_AT_encoding";
7098 case DW_AT_external
: return "DW_AT_external";
7099 case DW_AT_frame_base
: return "DW_AT_frame_base";
7100 case DW_AT_friend
: return "DW_AT_friend";
7101 case DW_AT_identifier_case
: return "DW_AT_identifier_case";
7102 case DW_AT_macro_info
: return "DW_AT_macro_info";
7103 case DW_AT_namelist_items
: return "DW_AT_namelist_items";
7104 case DW_AT_priority
: return "DW_AT_priority";
7105 case DW_AT_segment
: return "DW_AT_segment";
7106 case DW_AT_specification
: return "DW_AT_specification";
7107 case DW_AT_static_link
: return "DW_AT_static_link";
7108 case DW_AT_type
: return "DW_AT_type";
7109 case DW_AT_use_location
: return "DW_AT_use_location";
7110 case DW_AT_variable_parameter
: return "DW_AT_variable_parameter";
7111 case DW_AT_virtuality
: return "DW_AT_virtuality";
7112 case DW_AT_vtable_elem_location
: return "DW_AT_vtable_elem_location";
7113 /* DWARF 2.1 values. */
7114 case DW_AT_allocated
: return "DW_AT_allocated";
7115 case DW_AT_associated
: return "DW_AT_associated";
7116 case DW_AT_data_location
: return "DW_AT_data_location";
7117 case DW_AT_stride
: return "DW_AT_stride";
7118 case DW_AT_entry_pc
: return "DW_AT_entry_pc";
7119 case DW_AT_use_UTF8
: return "DW_AT_use_UTF8";
7120 case DW_AT_extension
: return "DW_AT_extension";
7121 case DW_AT_ranges
: return "DW_AT_ranges";
7122 case DW_AT_trampoline
: return "DW_AT_trampoline";
7123 case DW_AT_call_column
: return "DW_AT_call_column";
7124 case DW_AT_call_file
: return "DW_AT_call_file";
7125 case DW_AT_call_line
: return "DW_AT_call_line";
7126 /* SGI/MIPS extensions. */
7127 case DW_AT_MIPS_fde
: return "DW_AT_MIPS_fde";
7128 case DW_AT_MIPS_loop_begin
: return "DW_AT_MIPS_loop_begin";
7129 case DW_AT_MIPS_tail_loop_begin
: return "DW_AT_MIPS_tail_loop_begin";
7130 case DW_AT_MIPS_epilog_begin
: return "DW_AT_MIPS_epilog_begin";
7131 case DW_AT_MIPS_loop_unroll_factor
: return "DW_AT_MIPS_loop_unroll_factor";
7132 case DW_AT_MIPS_software_pipeline_depth
:
7133 return "DW_AT_MIPS_software_pipeline_depth";
7134 case DW_AT_MIPS_linkage_name
: return "DW_AT_MIPS_linkage_name";
7135 case DW_AT_MIPS_stride
: return "DW_AT_MIPS_stride";
7136 case DW_AT_MIPS_abstract_name
: return "DW_AT_MIPS_abstract_name";
7137 case DW_AT_MIPS_clone_origin
: return "DW_AT_MIPS_clone_origin";
7138 case DW_AT_MIPS_has_inlines
: return "DW_AT_MIPS_has_inlines";
7139 /* GNU extensions. */
7140 case DW_AT_sf_names
: return "DW_AT_sf_names";
7141 case DW_AT_src_info
: return "DW_AT_src_info";
7142 case DW_AT_mac_info
: return "DW_AT_mac_info";
7143 case DW_AT_src_coords
: return "DW_AT_src_coords";
7144 case DW_AT_body_begin
: return "DW_AT_body_begin";
7145 case DW_AT_body_end
: return "DW_AT_body_end";
7146 case DW_AT_GNU_vector
: return "DW_AT_GNU_vector";
7147 /* UPC extension. */
7148 case DW_AT_upc_threads_scaled
: return "DW_AT_upc_threads_scaled";
7151 static char buffer
[100];
7153 sprintf (buffer
, _("Unknown AT value: %lx"), attribute
);
7160 get_FORM_name (form
)
7165 case DW_FORM_addr
: return "DW_FORM_addr";
7166 case DW_FORM_block2
: return "DW_FORM_block2";
7167 case DW_FORM_block4
: return "DW_FORM_block4";
7168 case DW_FORM_data2
: return "DW_FORM_data2";
7169 case DW_FORM_data4
: return "DW_FORM_data4";
7170 case DW_FORM_data8
: return "DW_FORM_data8";
7171 case DW_FORM_string
: return "DW_FORM_string";
7172 case DW_FORM_block
: return "DW_FORM_block";
7173 case DW_FORM_block1
: return "DW_FORM_block1";
7174 case DW_FORM_data1
: return "DW_FORM_data1";
7175 case DW_FORM_flag
: return "DW_FORM_flag";
7176 case DW_FORM_sdata
: return "DW_FORM_sdata";
7177 case DW_FORM_strp
: return "DW_FORM_strp";
7178 case DW_FORM_udata
: return "DW_FORM_udata";
7179 case DW_FORM_ref_addr
: return "DW_FORM_ref_addr";
7180 case DW_FORM_ref1
: return "DW_FORM_ref1";
7181 case DW_FORM_ref2
: return "DW_FORM_ref2";
7182 case DW_FORM_ref4
: return "DW_FORM_ref4";
7183 case DW_FORM_ref8
: return "DW_FORM_ref8";
7184 case DW_FORM_ref_udata
: return "DW_FORM_ref_udata";
7185 case DW_FORM_indirect
: return "DW_FORM_indirect";
7188 static char buffer
[100];
7190 sprintf (buffer
, _("Unknown FORM value: %lx"), form
);
7196 /* FIXME: There are better and more effiecint ways to handle
7197 these structures. For now though, I just want something that
7198 is simple to implement. */
7199 typedef struct abbrev_attr
7201 unsigned long attribute
;
7203 struct abbrev_attr
*next
;
7207 typedef struct abbrev_entry
7209 unsigned long entry
;
7212 struct abbrev_attr
*first_attr
;
7213 struct abbrev_attr
*last_attr
;
7214 struct abbrev_entry
*next
;
7218 static abbrev_entry
*first_abbrev
= NULL
;
7219 static abbrev_entry
*last_abbrev
= NULL
;
7224 abbrev_entry
*abbrev
;
7226 for (abbrev
= first_abbrev
; abbrev
;)
7228 abbrev_entry
*next
= abbrev
->next
;
7231 for (attr
= abbrev
->first_attr
; attr
;)
7233 abbrev_attr
*next
= attr
->next
;
7243 last_abbrev
= first_abbrev
= NULL
;
7247 add_abbrev (number
, tag
, children
)
7248 unsigned long number
;
7252 abbrev_entry
*entry
;
7254 entry
= (abbrev_entry
*) malloc (sizeof (*entry
));
7260 entry
->entry
= number
;
7262 entry
->children
= children
;
7263 entry
->first_attr
= NULL
;
7264 entry
->last_attr
= NULL
;
7267 if (first_abbrev
== NULL
)
7268 first_abbrev
= entry
;
7270 last_abbrev
->next
= entry
;
7272 last_abbrev
= entry
;
7276 add_abbrev_attr (attribute
, form
)
7277 unsigned long attribute
;
7282 attr
= (abbrev_attr
*) malloc (sizeof (*attr
));
7288 attr
->attribute
= attribute
;
7292 if (last_abbrev
->first_attr
== NULL
)
7293 last_abbrev
->first_attr
= attr
;
7295 last_abbrev
->last_attr
->next
= attr
;
7297 last_abbrev
->last_attr
= attr
;
7300 /* Processes the (partial) contents of a .debug_abbrev section.
7301 Returns NULL if the end of the section was encountered.
7302 Returns the address after the last byte read if the end of
7303 an abbreviation set was found. */
7305 static unsigned char *
7306 process_abbrev_section (start
, end
)
7307 unsigned char *start
;
7310 if (first_abbrev
!= NULL
)
7316 unsigned long entry
;
7318 unsigned long attribute
;
7321 entry
= read_leb128 (start
, & bytes_read
, 0);
7322 start
+= bytes_read
;
7324 /* A single zero is supposed to end the section according
7325 to the standard. If there's more, then signal that to
7328 return start
== end
? NULL
: start
;
7330 tag
= read_leb128 (start
, & bytes_read
, 0);
7331 start
+= bytes_read
;
7333 children
= *start
++;
7335 add_abbrev (entry
, tag
, children
);
7341 attribute
= read_leb128 (start
, & bytes_read
, 0);
7342 start
+= bytes_read
;
7344 form
= read_leb128 (start
, & bytes_read
, 0);
7345 start
+= bytes_read
;
7348 add_abbrev_attr (attribute
, form
);
7350 while (attribute
!= 0);
7358 display_debug_macinfo (section
, start
, file
)
7359 Elf_Internal_Shdr
*section
;
7360 unsigned char *start
;
7361 FILE *file ATTRIBUTE_UNUSED
;
7363 unsigned char *end
= start
+ section
->sh_size
;
7364 unsigned char *curr
= start
;
7365 unsigned int bytes_read
;
7366 enum dwarf_macinfo_record_type op
;
7368 printf (_("Contents of the %s section:\n\n"), SECTION_NAME (section
));
7372 unsigned int lineno
;
7380 case DW_MACINFO_start_file
:
7382 unsigned int filenum
;
7384 lineno
= read_leb128 (curr
, & bytes_read
, 0);
7386 filenum
= read_leb128 (curr
, & bytes_read
, 0);
7389 printf (_(" DW_MACINFO_start_file - lineno: %d filenum: %d\n"), lineno
, filenum
);
7393 case DW_MACINFO_end_file
:
7394 printf (_(" DW_MACINFO_end_file\n"));
7397 case DW_MACINFO_define
:
7398 lineno
= read_leb128 (curr
, & bytes_read
, 0);
7401 curr
+= strlen (string
) + 1;
7402 printf (_(" DW_MACINFO_define - lineno : %d macro : %s\n"), lineno
, string
);
7405 case DW_MACINFO_undef
:
7406 lineno
= read_leb128 (curr
, & bytes_read
, 0);
7409 curr
+= strlen (string
) + 1;
7410 printf (_(" DW_MACINFO_undef - lineno : %d macro : %s\n"), lineno
, string
);
7413 case DW_MACINFO_vendor_ext
:
7415 unsigned int constant
;
7417 constant
= read_leb128 (curr
, & bytes_read
, 0);
7420 curr
+= strlen (string
) + 1;
7421 printf (_(" DW_MACINFO_vendor_ext - constant : %d string : %s\n"), constant
, string
);
7432 display_debug_abbrev (section
, start
, file
)
7433 Elf_Internal_Shdr
*section
;
7434 unsigned char *start
;
7435 FILE *file ATTRIBUTE_UNUSED
;
7437 abbrev_entry
*entry
;
7438 unsigned char *end
= start
+ section
->sh_size
;
7440 printf (_("Contents of the %s section:\n\n"), SECTION_NAME (section
));
7444 start
= process_abbrev_section (start
, end
);
7446 if (first_abbrev
== NULL
)
7449 printf (_(" Number TAG\n"));
7451 for (entry
= first_abbrev
; entry
; entry
= entry
->next
)
7455 printf (_(" %ld %s [%s]\n"),
7457 get_TAG_name (entry
->tag
),
7458 entry
->children
? _("has children") : _("no children"));
7460 for (attr
= entry
->first_attr
; attr
; attr
= attr
->next
)
7462 printf (_(" %-18s %s\n"),
7463 get_AT_name (attr
->attribute
),
7464 get_FORM_name (attr
->form
));
7478 static unsigned char *
7479 display_block (data
, length
)
7480 unsigned char *data
;
7481 unsigned long length
;
7483 printf (_(" %lu byte block: "), length
);
7486 printf ("%lx ", (unsigned long) byte_get (data
++, 1));
7492 decode_location_expression (data
, pointer_size
, length
)
7493 unsigned char * data
;
7494 unsigned int pointer_size
;
7495 unsigned long length
;
7499 unsigned long uvalue
;
7500 unsigned char *end
= data
+ length
;
7509 printf ("DW_OP_addr: %lx",
7510 (unsigned long) byte_get (data
, pointer_size
));
7511 data
+= pointer_size
;
7514 printf ("DW_OP_deref");
7517 printf ("DW_OP_const1u: %lu", (unsigned long) byte_get (data
++, 1));
7520 printf ("DW_OP_const1s: %ld", (long) byte_get (data
++, 1));
7523 printf ("DW_OP_const2u: %lu", (unsigned long) byte_get (data
, 2));
7527 printf ("DW_OP_const2s: %ld", (long) byte_get (data
, 2));
7531 printf ("DW_OP_const4u: %lu", (unsigned long) byte_get (data
, 4));
7535 printf ("DW_OP_const4s: %ld", (long) byte_get (data
, 4));
7539 printf ("DW_OP_const8u: %lu %lu", (unsigned long) byte_get (data
, 4),
7540 (unsigned long) byte_get (data
+ 4, 4));
7544 printf ("DW_OP_const8s: %ld %ld", (long) byte_get (data
, 4),
7545 (long) byte_get (data
+ 4, 4));
7549 printf ("DW_OP_constu: %lu", read_leb128 (data
, &bytes_read
, 0));
7553 printf ("DW_OP_consts: %ld", read_leb128 (data
, &bytes_read
, 1));
7557 printf ("DW_OP_dup");
7560 printf ("DW_OP_drop");
7563 printf ("DW_OP_over");
7566 printf ("DW_OP_pick: %ld", (unsigned long) byte_get (data
++, 1));
7569 printf ("DW_OP_swap");
7572 printf ("DW_OP_rot");
7575 printf ("DW_OP_xderef");
7578 printf ("DW_OP_abs");
7581 printf ("DW_OP_and");
7584 printf ("DW_OP_div");
7587 printf ("DW_OP_minus");
7590 printf ("DW_OP_mod");
7593 printf ("DW_OP_mul");
7596 printf ("DW_OP_neg");
7599 printf ("DW_OP_not");
7602 printf ("DW_OP_or");
7605 printf ("DW_OP_plus");
7607 case DW_OP_plus_uconst
:
7608 printf ("DW_OP_plus_uconst: %lu",
7609 read_leb128 (data
, &bytes_read
, 0));
7613 printf ("DW_OP_shl");
7616 printf ("DW_OP_shr");
7619 printf ("DW_OP_shra");
7622 printf ("DW_OP_xor");
7625 printf ("DW_OP_bra: %ld", (long) byte_get (data
, 2));
7629 printf ("DW_OP_eq");
7632 printf ("DW_OP_ge");
7635 printf ("DW_OP_gt");
7638 printf ("DW_OP_le");
7641 printf ("DW_OP_lt");
7644 printf ("DW_OP_ne");
7647 printf ("DW_OP_skip: %ld", (long) byte_get (data
, 2));
7683 printf ("DW_OP_lit%d", op
- DW_OP_lit0
);
7718 printf ("DW_OP_reg%d", op
- DW_OP_reg0
);
7753 printf ("DW_OP_breg%d: %ld", op
- DW_OP_breg0
,
7754 read_leb128 (data
, &bytes_read
, 1));
7759 printf ("DW_OP_regx: %lu", read_leb128 (data
, &bytes_read
, 0));
7763 printf ("DW_OP_fbreg: %ld", read_leb128 (data
, &bytes_read
, 1));
7767 uvalue
= read_leb128 (data
, &bytes_read
, 0);
7769 printf ("DW_OP_bregx: %lu %ld", uvalue
,
7770 read_leb128 (data
, &bytes_read
, 1));
7774 printf ("DW_OP_piece: %lu", read_leb128 (data
, &bytes_read
, 0));
7777 case DW_OP_deref_size
:
7778 printf ("DW_OP_deref_size: %ld", (long) byte_get (data
++, 1));
7780 case DW_OP_xderef_size
:
7781 printf ("DW_OP_xderef_size: %ld", (long) byte_get (data
++, 1));
7784 printf ("DW_OP_nop");
7787 /* DWARF 3 extensions. */
7788 case DW_OP_push_object_address
:
7789 printf ("DW_OP_push_object_address");
7792 printf ("DW_OP_call2: <%lx>", (long) byte_get (data
, 2));
7796 printf ("DW_OP_call4: <%lx>", (long) byte_get (data
, 4));
7799 case DW_OP_call_ref
:
7800 printf ("DW_OP_call_ref");
7803 /* GNU extensions. */
7804 case DW_OP_GNU_push_tls_address
:
7805 printf ("DW_OP_GNU_push_tls_address");
7809 if (op
>= DW_OP_lo_user
7810 && op
<= DW_OP_hi_user
)
7811 printf (_("(User defined location op)"));
7813 printf (_("(Unknown location op)"));
7814 /* No way to tell where the next op is, so just bail. */
7818 /* Separate the ops. */
7824 static const char *debug_loc_contents
;
7825 static bfd_vma debug_loc_size
;
7828 load_debug_loc (file
)
7831 Elf_Internal_Shdr
*sec
;
7834 /* If it is already loaded, do nothing. */
7835 if (debug_loc_contents
!= NULL
)
7838 /* Locate the .debug_loc section. */
7839 for (i
= 0, sec
= section_headers
;
7840 i
< elf_header
.e_shnum
;
7842 if (strcmp (SECTION_NAME (sec
), ".debug_loc") == 0)
7845 if (i
== elf_header
.e_shnum
|| sec
->sh_size
== 0)
7848 debug_loc_size
= sec
->sh_size
;
7850 debug_loc_contents
= ((char *)
7851 get_data (NULL
, file
, sec
->sh_offset
, sec
->sh_size
,
7852 _("debug_loc section data")));
7858 if (debug_loc_contents
== NULL
)
7861 free ((char *) debug_loc_contents
);
7862 debug_loc_contents
= NULL
;
7868 display_debug_loc (section
, start
, file
)
7869 Elf_Internal_Shdr
*section
;
7870 unsigned char *start
;
7871 FILE *file ATTRIBUTE_UNUSED
;
7873 unsigned char *section_end
;
7874 unsigned long bytes
;
7875 unsigned char *section_begin
= start
;
7878 addr
= section
->sh_addr
;
7879 bytes
= section
->sh_size
;
7880 section_end
= start
+ bytes
;
7884 printf (_("\nThe .debug_loc section is empty.\n"));
7888 printf (_("Contents of the .debug_loc section:\n\n"));
7889 printf (_("\n Offset Begin End Expression\n"));
7891 while (start
< section_end
)
7893 unsigned long begin
;
7895 unsigned short length
;
7896 unsigned long offset
;
7898 offset
= start
- section_begin
;
7902 /* Normally, the lists in the debug_loc section are related to a
7903 given compilation unit, and thus, we would use the pointer size
7904 of that compilation unit. However, since we are displaying it
7905 seperately here, we either have to store pointer sizes of all
7906 compilation units, or assume they don't change. We assume,
7907 like the debug_line display, that it doesn't change. */
7908 begin
= byte_get (start
, debug_line_pointer_size
);
7909 start
+= debug_line_pointer_size
;
7910 end
= byte_get (start
, debug_line_pointer_size
);
7911 start
+= debug_line_pointer_size
;
7913 if (begin
== 0 && end
== 0)
7916 /* For now, skip any base address specifiers. */
7917 if (begin
== 0xffffffff)
7923 length
= byte_get (start
, 2);
7926 printf (" %8.8lx %8.8lx %8.8lx (", offset
, begin
, end
);
7927 decode_location_expression (start
, debug_line_pointer_size
, length
);
7937 static const char *debug_str_contents
;
7938 static bfd_vma debug_str_size
;
7941 load_debug_str (file
)
7944 Elf_Internal_Shdr
*sec
;
7947 /* If it is already loaded, do nothing. */
7948 if (debug_str_contents
!= NULL
)
7951 /* Locate the .debug_str section. */
7952 for (i
= 0, sec
= section_headers
;
7953 i
< elf_header
.e_shnum
;
7955 if (strcmp (SECTION_NAME (sec
), ".debug_str") == 0)
7958 if (i
== elf_header
.e_shnum
|| sec
->sh_size
== 0)
7961 debug_str_size
= sec
->sh_size
;
7963 debug_str_contents
= ((char *)
7964 get_data (NULL
, file
, sec
->sh_offset
, sec
->sh_size
,
7965 _("debug_str section data")));
7971 if (debug_str_contents
== NULL
)
7974 free ((char *) debug_str_contents
);
7975 debug_str_contents
= NULL
;
7980 fetch_indirect_string (offset
)
7981 unsigned long offset
;
7983 if (debug_str_contents
== NULL
)
7984 return _("<no .debug_str section>");
7986 if (offset
> debug_str_size
)
7987 return _("<offset is too big>");
7989 return debug_str_contents
+ offset
;
7993 display_debug_str (section
, start
, file
)
7994 Elf_Internal_Shdr
*section
;
7995 unsigned char *start
;
7996 FILE *file ATTRIBUTE_UNUSED
;
7998 unsigned long bytes
;
8001 addr
= section
->sh_addr
;
8002 bytes
= section
->sh_size
;
8006 printf (_("\nThe .debug_str section is empty.\n"));
8010 printf (_("Contents of the .debug_str section:\n\n"));
8018 lbytes
= (bytes
> 16 ? 16 : bytes
);
8020 printf (" 0x%8.8lx ", (unsigned long) addr
);
8022 for (j
= 0; j
< 16; j
++)
8025 printf ("%2.2x", start
[j
]);
8033 for (j
= 0; j
< lbytes
; j
++)
8036 if (k
>= ' ' && k
< 0x80)
8052 static unsigned char *
8053 read_and_display_attr_value (attribute
, form
, data
, cu_offset
, pointer_size
,
8054 offset_size
, dwarf_version
)
8055 unsigned long attribute
;
8057 unsigned char *data
;
8058 unsigned long cu_offset
;
8059 unsigned long pointer_size
;
8060 unsigned long offset_size
;
8063 unsigned long uvalue
= 0;
8064 unsigned char *block_start
= NULL
;
8072 case DW_FORM_ref_addr
:
8073 if (dwarf_version
== 2)
8075 uvalue
= byte_get (data
, pointer_size
);
8076 data
+= pointer_size
;
8078 else if (dwarf_version
== 3)
8080 uvalue
= byte_get (data
, offset_size
);
8081 data
+= offset_size
;
8085 error (_("Internal error: DWARF version is not 2 or 3.\n"));
8090 uvalue
= byte_get (data
, pointer_size
);
8091 data
+= pointer_size
;
8095 uvalue
= byte_get (data
, offset_size
);
8096 data
+= offset_size
;
8102 uvalue
= byte_get (data
++, 1);
8107 uvalue
= byte_get (data
, 2);
8113 uvalue
= byte_get (data
, 4);
8118 uvalue
= read_leb128 (data
, & bytes_read
, 1);
8122 case DW_FORM_ref_udata
:
8124 uvalue
= read_leb128 (data
, & bytes_read
, 0);
8128 case DW_FORM_indirect
:
8129 form
= read_leb128 (data
, & bytes_read
, 0);
8131 printf (" %s", get_FORM_name (form
));
8132 return read_and_display_attr_value (attribute
, form
, data
, cu_offset
,
8133 pointer_size
, offset_size
,
8139 case DW_FORM_ref_addr
:
8140 printf (" <#%lx>", uvalue
);
8146 case DW_FORM_ref_udata
:
8147 printf (" <%lx>", uvalue
+ cu_offset
);
8151 printf (" %#lx", uvalue
);
8159 printf (" %ld", uvalue
);
8164 uvalue
= byte_get (data
, 4);
8165 printf (" %lx", uvalue
);
8166 printf (" %lx", (unsigned long) byte_get (data
+ 4, 4));
8170 case DW_FORM_string
:
8171 printf (" %s", data
);
8172 data
+= strlen ((char *) data
) + 1;
8176 uvalue
= read_leb128 (data
, & bytes_read
, 0);
8177 block_start
= data
+ bytes_read
;
8178 data
= display_block (block_start
, uvalue
);
8181 case DW_FORM_block1
:
8182 uvalue
= byte_get (data
, 1);
8183 block_start
= data
+ 1;
8184 data
= display_block (block_start
, uvalue
);
8187 case DW_FORM_block2
:
8188 uvalue
= byte_get (data
, 2);
8189 block_start
= data
+ 2;
8190 data
= display_block (block_start
, uvalue
);
8193 case DW_FORM_block4
:
8194 uvalue
= byte_get (data
, 4);
8195 block_start
= data
+ 4;
8196 data
= display_block (block_start
, uvalue
);
8200 printf (_(" (indirect string, offset: 0x%lx): %s"),
8201 uvalue
, fetch_indirect_string (uvalue
));
8204 case DW_FORM_indirect
:
8205 /* Handled above. */
8209 warn (_("Unrecognized form: %d\n"), form
);
8213 /* For some attributes we can display futher information. */
8222 case DW_INL_not_inlined
:
8223 printf (_("(not inlined)"));
8225 case DW_INL_inlined
:
8226 printf (_("(inlined)"));
8228 case DW_INL_declared_not_inlined
:
8229 printf (_("(declared as inline but ignored)"));
8231 case DW_INL_declared_inlined
:
8232 printf (_("(declared as inline and inlined)"));
8235 printf (_(" (Unknown inline attribute value: %lx)"), uvalue
);
8240 case DW_AT_language
:
8243 case DW_LANG_C
: printf ("(non-ANSI C)"); break;
8244 case DW_LANG_C89
: printf ("(ANSI C)"); break;
8245 case DW_LANG_C_plus_plus
: printf ("(C++)"); break;
8246 case DW_LANG_Fortran77
: printf ("(FORTRAN 77)"); break;
8247 case DW_LANG_Fortran90
: printf ("(Fortran 90)"); break;
8248 case DW_LANG_Modula2
: printf ("(Modula 2)"); break;
8249 case DW_LANG_Pascal83
: printf ("(ANSI Pascal)"); break;
8250 case DW_LANG_Ada83
: printf ("(Ada)"); break;
8251 case DW_LANG_Cobol74
: printf ("(Cobol 74)"); break;
8252 case DW_LANG_Cobol85
: printf ("(Cobol 85)"); break;
8253 /* DWARF 2.1 values. */
8254 case DW_LANG_C99
: printf ("(ANSI C99)"); break;
8255 case DW_LANG_Ada95
: printf ("(ADA 95)"); break;
8256 case DW_LANG_Fortran95
: printf ("(Fortran 95)"); break;
8257 /* MIPS extension. */
8258 case DW_LANG_Mips_Assembler
: printf ("(MIPS assembler)"); break;
8259 /* UPC extension. */
8260 case DW_LANG_Upc
: printf ("(Unified Parallel C)"); break;
8262 printf ("(Unknown: %lx)", uvalue
);
8267 case DW_AT_encoding
:
8270 case DW_ATE_void
: printf ("(void)"); break;
8271 case DW_ATE_address
: printf ("(machine address)"); break;
8272 case DW_ATE_boolean
: printf ("(boolean)"); break;
8273 case DW_ATE_complex_float
: printf ("(complex float)"); break;
8274 case DW_ATE_float
: printf ("(float)"); break;
8275 case DW_ATE_signed
: printf ("(signed)"); break;
8276 case DW_ATE_signed_char
: printf ("(signed char)"); break;
8277 case DW_ATE_unsigned
: printf ("(unsigned)"); break;
8278 case DW_ATE_unsigned_char
: printf ("(unsigned char)"); break;
8279 /* DWARF 2.1 value. */
8280 case DW_ATE_imaginary_float
: printf ("(imaginary float)"); break;
8282 if (uvalue
>= DW_ATE_lo_user
8283 && uvalue
<= DW_ATE_hi_user
)
8284 printf ("(user defined type)");
8286 printf ("(unknown type)");
8291 case DW_AT_accessibility
:
8294 case DW_ACCESS_public
: printf ("(public)"); break;
8295 case DW_ACCESS_protected
: printf ("(protected)"); break;
8296 case DW_ACCESS_private
: printf ("(private)"); break;
8298 printf ("(unknown accessibility)");
8303 case DW_AT_visibility
:
8306 case DW_VIS_local
: printf ("(local)"); break;
8307 case DW_VIS_exported
: printf ("(exported)"); break;
8308 case DW_VIS_qualified
: printf ("(qualified)"); break;
8309 default: printf ("(unknown visibility)"); break;
8313 case DW_AT_virtuality
:
8316 case DW_VIRTUALITY_none
: printf ("(none)"); break;
8317 case DW_VIRTUALITY_virtual
: printf ("(virtual)"); break;
8318 case DW_VIRTUALITY_pure_virtual
:printf ("(pure_virtual)"); break;
8319 default: printf ("(unknown virtuality)"); break;
8323 case DW_AT_identifier_case
:
8326 case DW_ID_case_sensitive
: printf ("(case_sensitive)"); break;
8327 case DW_ID_up_case
: printf ("(up_case)"); break;
8328 case DW_ID_down_case
: printf ("(down_case)"); break;
8329 case DW_ID_case_insensitive
: printf ("(case_insensitive)"); break;
8330 default: printf ("(unknown case)"); break;
8334 case DW_AT_calling_convention
:
8337 case DW_CC_normal
: printf ("(normal)"); break;
8338 case DW_CC_program
: printf ("(program)"); break;
8339 case DW_CC_nocall
: printf ("(nocall)"); break;
8341 if (uvalue
>= DW_CC_lo_user
8342 && uvalue
<= DW_CC_hi_user
)
8343 printf ("(user defined)");
8345 printf ("(unknown convention)");
8349 case DW_AT_ordering
:
8352 case -1: printf ("(undefined)"); break;
8353 case 0: printf ("(row major)"); break;
8354 case 1: printf ("(column major)"); break;
8358 case DW_AT_frame_base
:
8359 case DW_AT_location
:
8360 case DW_AT_data_member_location
:
8361 case DW_AT_vtable_elem_location
:
8362 case DW_AT_allocated
:
8363 case DW_AT_associated
:
8364 case DW_AT_data_location
:
8366 case DW_AT_upper_bound
:
8367 case DW_AT_lower_bound
:
8371 decode_location_expression (block_start
, pointer_size
, uvalue
);
8374 else if (form
== DW_FORM_data4
|| form
== DW_FORM_data8
)
8377 printf ("location list");
8389 static unsigned char *
8390 read_and_display_attr (attribute
, form
, data
, cu_offset
, pointer_size
,
8391 offset_size
, dwarf_version
)
8392 unsigned long attribute
;
8394 unsigned char *data
;
8395 unsigned long cu_offset
;
8396 unsigned long pointer_size
;
8397 unsigned long offset_size
;
8400 printf (" %-18s:", get_AT_name (attribute
));
8401 data
= read_and_display_attr_value (attribute
, form
, data
, cu_offset
,
8402 pointer_size
, offset_size
, dwarf_version
);
8408 display_debug_info (section
, start
, file
)
8409 Elf_Internal_Shdr
*section
;
8410 unsigned char *start
;
8413 unsigned char *end
= start
+ section
->sh_size
;
8414 unsigned char *section_begin
= start
;
8416 printf (_("The section %s contains:\n\n"), SECTION_NAME (section
));
8418 load_debug_str (file
);
8419 load_debug_loc (file
);
8423 DWARF2_Internal_CompUnit compunit
;
8424 Elf_Internal_Shdr
*relsec
;
8425 unsigned char *hdrptr
;
8426 unsigned char *cu_abbrev_offset_ptr
;
8427 unsigned char *tags
;
8430 unsigned long cu_offset
;
8432 int initial_length_size
;
8436 compunit
.cu_length
= byte_get (hdrptr
, 4);
8439 if (compunit
.cu_length
== 0xffffffff)
8441 compunit
.cu_length
= byte_get (hdrptr
, 8);
8444 initial_length_size
= 12;
8449 initial_length_size
= 4;
8452 compunit
.cu_version
= byte_get (hdrptr
, 2);
8455 /* Apply addends of RELA relocations. */
8456 for (relsec
= section_headers
;
8457 relsec
< section_headers
+ elf_header
.e_shnum
;
8460 unsigned long nrelas
;
8461 Elf_Internal_Rela
*rela
, *rp
;
8462 Elf_Internal_Shdr
*symsec
;
8463 Elf_Internal_Sym
*symtab
;
8464 Elf_Internal_Sym
*sym
;
8466 if (relsec
->sh_type
!= SHT_RELA
8467 || SECTION_HEADER (relsec
->sh_info
) != section
8468 || relsec
->sh_size
== 0)
8471 if (!slurp_rela_relocs (file
, relsec
->sh_offset
, relsec
->sh_size
,
8475 symsec
= SECTION_HEADER (relsec
->sh_link
);
8476 symtab
= GET_ELF_SYMBOLS (file
, symsec
);
8478 for (rp
= rela
; rp
< rela
+ nrelas
; ++rp
)
8482 if (rp
->r_offset
>= (bfd_vma
) (hdrptr
- section_begin
)
8483 && section
->sh_size
> (bfd_vma
) offset_size
8484 && rp
->r_offset
<= section
->sh_size
- offset_size
)
8485 loc
= section_begin
+ rp
->r_offset
;
8491 sym
= symtab
+ ELF32_R_SYM (rp
->r_info
);
8493 if (ELF32_R_SYM (rp
->r_info
) != 0
8494 && ELF32_ST_TYPE (sym
->st_info
) != STT_SECTION
)
8496 warn (_("Skipping unexpected symbol type %u\n"),
8497 ELF32_ST_TYPE (sym
->st_info
));
8503 sym
= symtab
+ ELF64_R_SYM (rp
->r_info
);
8505 if (ELF64_R_SYM (rp
->r_info
) != 0
8506 && ELF64_ST_TYPE (sym
->st_info
) != STT_SECTION
)
8508 warn (_("Skipping unexpected symbol type %u\n"),
8509 ELF64_ST_TYPE (sym
->st_info
));
8514 byte_put (loc
, rp
->r_addend
, offset_size
);
8521 cu_abbrev_offset_ptr
= hdrptr
;
8522 compunit
.cu_abbrev_offset
= byte_get (hdrptr
, offset_size
);
8523 hdrptr
+= offset_size
;
8525 compunit
.cu_pointer_size
= byte_get (hdrptr
, 1);
8529 cu_offset
= start
- section_begin
;
8530 start
+= compunit
.cu_length
+ initial_length_size
;
8532 printf (_(" Compilation Unit @ %lx:\n"), cu_offset
);
8533 printf (_(" Length: %ld\n"), compunit
.cu_length
);
8534 printf (_(" Version: %d\n"), compunit
.cu_version
);
8535 printf (_(" Abbrev Offset: %ld\n"), compunit
.cu_abbrev_offset
);
8536 printf (_(" Pointer Size: %d\n"), compunit
.cu_pointer_size
);
8538 if (compunit
.cu_version
!= 2 && compunit
.cu_version
!= 3)
8540 warn (_("Only version 2 and 3 DWARF debug information is currently supported.\n"));
8546 /* Read in the abbrevs used by this compilation unit. */
8548 Elf_Internal_Shdr
*sec
;
8549 unsigned char *begin
;
8551 /* Locate the .debug_abbrev section and process it. */
8552 for (i
= 0, sec
= section_headers
;
8553 i
< elf_header
.e_shnum
;
8555 if (strcmp (SECTION_NAME (sec
), ".debug_abbrev") == 0)
8558 if (i
== elf_header
.e_shnum
|| sec
->sh_size
== 0)
8560 warn (_("Unable to locate .debug_abbrev section!\n"));
8564 begin
= ((unsigned char *)
8565 get_data (NULL
, file
, sec
->sh_offset
, sec
->sh_size
,
8566 _("debug_abbrev section data")));
8570 process_abbrev_section (begin
+ compunit
.cu_abbrev_offset
,
8571 begin
+ sec
->sh_size
);
8577 while (tags
< start
)
8580 unsigned long abbrev_number
;
8581 abbrev_entry
*entry
;
8584 abbrev_number
= read_leb128 (tags
, & bytes_read
, 0);
8587 /* A null DIE marks the end of a list of children. */
8588 if (abbrev_number
== 0)
8594 /* Scan through the abbreviation list until we reach the
8596 for (entry
= first_abbrev
;
8597 entry
&& entry
->entry
!= abbrev_number
;
8598 entry
= entry
->next
)
8603 warn (_("Unable to locate entry %lu in the abbreviation table\n"),
8608 printf (_(" <%d><%lx>: Abbrev Number: %lu (%s)\n"),
8610 (unsigned long) (tags
- section_begin
- bytes_read
),
8612 get_TAG_name (entry
->tag
));
8614 for (attr
= entry
->first_attr
; attr
; attr
= attr
->next
)
8615 tags
= read_and_display_attr (attr
->attribute
,
8618 compunit
.cu_pointer_size
,
8620 compunit
.cu_version
);
8622 if (entry
->children
)
8636 display_debug_aranges (section
, start
, file
)
8637 Elf_Internal_Shdr
*section
;
8638 unsigned char *start
;
8639 FILE *file ATTRIBUTE_UNUSED
;
8641 unsigned char *end
= start
+ section
->sh_size
;
8643 printf (_("The section %s contains:\n\n"), SECTION_NAME (section
));
8647 unsigned char *hdrptr
;
8648 DWARF2_Internal_ARange arange
;
8649 unsigned char *ranges
;
8650 unsigned long length
;
8651 unsigned long address
;
8654 int initial_length_size
;
8658 arange
.ar_length
= byte_get (hdrptr
, 4);
8661 if (arange
.ar_length
== 0xffffffff)
8663 arange
.ar_length
= byte_get (hdrptr
, 8);
8666 initial_length_size
= 12;
8671 initial_length_size
= 4;
8674 arange
.ar_version
= byte_get (hdrptr
, 2);
8677 arange
.ar_info_offset
= byte_get (hdrptr
, offset_size
);
8678 hdrptr
+= offset_size
;
8680 arange
.ar_pointer_size
= byte_get (hdrptr
, 1);
8683 arange
.ar_segment_size
= byte_get (hdrptr
, 1);
8686 if (arange
.ar_version
!= 2 && arange
.ar_version
!= 3)
8688 warn (_("Only DWARF 2 and 3 aranges are currently supported.\n"));
8692 printf (_(" Length: %ld\n"), arange
.ar_length
);
8693 printf (_(" Version: %d\n"), arange
.ar_version
);
8694 printf (_(" Offset into .debug_info: %lx\n"), arange
.ar_info_offset
);
8695 printf (_(" Pointer Size: %d\n"), arange
.ar_pointer_size
);
8696 printf (_(" Segment Size: %d\n"), arange
.ar_segment_size
);
8698 printf (_("\n Address Length\n"));
8702 /* Must pad to an alignment boundary that is twice the pointer size. */
8703 excess
= (hdrptr
- start
) % (2 * arange
.ar_pointer_size
);
8705 ranges
+= (2 * arange
.ar_pointer_size
) - excess
;
8709 address
= byte_get (ranges
, arange
.ar_pointer_size
);
8711 ranges
+= arange
.ar_pointer_size
;
8713 length
= byte_get (ranges
, arange
.ar_pointer_size
);
8715 ranges
+= arange
.ar_pointer_size
;
8717 /* A pair of zeros marks the end of the list. */
8718 if (address
== 0 && length
== 0)
8721 printf (" %8.8lx %lu\n", address
, length
);
8724 start
+= arange
.ar_length
+ initial_length_size
;
8732 typedef struct Frame_Chunk
8734 struct Frame_Chunk
*next
;
8735 unsigned char *chunk_start
;
8737 /* DW_CFA_{undefined,same_value,offset,register,unreferenced} */
8738 short int *col_type
;
8741 unsigned int code_factor
;
8743 unsigned long pc_begin
;
8744 unsigned long pc_range
;
8748 unsigned char fde_encoding
;
8749 unsigned char cfa_exp
;
8753 /* A marker for a col_type that means this column was never referenced
8754 in the frame info. */
8755 #define DW_CFA_unreferenced (-1)
8757 static void frame_need_space
PARAMS ((Frame_Chunk
*, int));
8758 static void frame_display_row
PARAMS ((Frame_Chunk
*, int *, int *));
8759 static int size_of_encoded_value
PARAMS ((int));
8760 static bfd_vma get_encoded_value
PARAMS ((unsigned char *, int));
8763 frame_need_space (fc
, reg
)
8767 int prev
= fc
->ncols
;
8769 if (reg
< fc
->ncols
)
8772 fc
->ncols
= reg
+ 1;
8773 fc
->col_type
= (short int *) xrealloc (fc
->col_type
,
8774 fc
->ncols
* sizeof (short int));
8775 fc
->col_offset
= (int *) xrealloc (fc
->col_offset
,
8776 fc
->ncols
* sizeof (int));
8778 while (prev
< fc
->ncols
)
8780 fc
->col_type
[prev
] = DW_CFA_unreferenced
;
8781 fc
->col_offset
[prev
] = 0;
8787 frame_display_row (fc
, need_col_headers
, max_regs
)
8789 int *need_col_headers
;
8795 if (*max_regs
< fc
->ncols
)
8796 *max_regs
= fc
->ncols
;
8798 if (*need_col_headers
)
8800 *need_col_headers
= 0;
8802 printf (" LOC CFA ");
8804 for (r
= 0; r
< *max_regs
; r
++)
8805 if (fc
->col_type
[r
] != DW_CFA_unreferenced
)
8810 printf ("r%-4d", r
);
8816 printf ("%08lx ", fc
->pc_begin
);
8818 strcpy (tmp
, "exp");
8820 sprintf (tmp
, "r%d%+d", fc
->cfa_reg
, fc
->cfa_offset
);
8821 printf ("%-8s ", tmp
);
8823 for (r
= 0; r
< fc
->ncols
; r
++)
8825 if (fc
->col_type
[r
] != DW_CFA_unreferenced
)
8827 switch (fc
->col_type
[r
])
8829 case DW_CFA_undefined
:
8832 case DW_CFA_same_value
:
8836 sprintf (tmp
, "c%+d", fc
->col_offset
[r
]);
8838 case DW_CFA_register
:
8839 sprintf (tmp
, "r%d", fc
->col_offset
[r
]);
8841 case DW_CFA_expression
:
8842 strcpy (tmp
, "exp");
8845 strcpy (tmp
, "n/a");
8848 printf ("%-5s", tmp
);
8855 size_of_encoded_value (encoding
)
8858 switch (encoding
& 0x7)
8861 case 0: return is_32bit_elf
? 4 : 8;
8869 get_encoded_value (data
, encoding
)
8870 unsigned char *data
;
8873 int size
= size_of_encoded_value (encoding
);
8874 if (encoding
& DW_EH_PE_signed
)
8875 return byte_get_signed (data
, size
);
8877 return byte_get (data
, size
);
8880 #define GET(N) byte_get (start, N); start += N
8881 #define LEB() read_leb128 (start, & length_return, 0); start += length_return
8882 #define SLEB() read_leb128 (start, & length_return, 1); start += length_return
8885 display_debug_frames (section
, start
, file
)
8886 Elf_Internal_Shdr
*section
;
8887 unsigned char *start
;
8888 FILE *file ATTRIBUTE_UNUSED
;
8890 unsigned char *end
= start
+ section
->sh_size
;
8891 unsigned char *section_start
= start
;
8892 Frame_Chunk
*chunks
= 0;
8893 Frame_Chunk
*remembered_state
= 0;
8895 int is_eh
= (strcmp (SECTION_NAME (section
), ".eh_frame") == 0);
8898 int addr_size
= is_32bit_elf
? 4 : 8;
8900 printf (_("The section %s contains:\n"), SECTION_NAME (section
));
8904 unsigned char *saved_start
;
8905 unsigned char *block_end
;
8906 unsigned long length
;
8907 unsigned long cie_id
;
8910 int need_col_headers
= 1;
8911 unsigned char *augmentation_data
= NULL
;
8912 unsigned long augmentation_data_len
= 0;
8913 int encoded_ptr_size
= addr_size
;
8915 int initial_length_size
;
8917 saved_start
= start
;
8918 length
= byte_get (start
, 4); start
+= 4;
8922 printf ("\n%08lx ZERO terminator\n\n",
8923 (unsigned long)(saved_start
- section_start
));
8927 if (length
== 0xffffffff)
8929 length
= byte_get (start
, 8);
8932 initial_length_size
= 12;
8937 initial_length_size
= 4;
8940 block_end
= saved_start
+ length
+ initial_length_size
;
8941 cie_id
= byte_get (start
, offset_size
); start
+= offset_size
;
8943 if (is_eh
? (cie_id
== 0) : (cie_id
== DW_CIE_ID
))
8947 fc
= (Frame_Chunk
*) xmalloc (sizeof (Frame_Chunk
));
8948 memset (fc
, 0, sizeof (Frame_Chunk
));
8952 fc
->chunk_start
= saved_start
;
8954 fc
->col_type
= (short int *) xmalloc (sizeof (short int));
8955 fc
->col_offset
= (int *) xmalloc (sizeof (int));
8956 frame_need_space (fc
, max_regs
-1);
8960 fc
->augmentation
= start
;
8961 start
= strchr (start
, '\0') + 1;
8963 if (fc
->augmentation
[0] == 'z')
8965 fc
->code_factor
= LEB ();
8966 fc
->data_factor
= SLEB ();
8967 fc
->ra
= byte_get (start
, 1); start
+= 1;
8968 augmentation_data_len
= LEB ();
8969 augmentation_data
= start
;
8970 start
+= augmentation_data_len
;
8972 else if (strcmp (fc
->augmentation
, "eh") == 0)
8975 fc
->code_factor
= LEB ();
8976 fc
->data_factor
= SLEB ();
8977 fc
->ra
= byte_get (start
, 1); start
+= 1;
8981 fc
->code_factor
= LEB ();
8982 fc
->data_factor
= SLEB ();
8983 fc
->ra
= byte_get (start
, 1); start
+= 1;
8987 if (do_debug_frames_interp
)
8988 printf ("\n%08lx %08lx %08lx CIE \"%s\" cf=%d df=%d ra=%d\n",
8989 (unsigned long)(saved_start
- section_start
), length
, cie_id
,
8990 fc
->augmentation
, fc
->code_factor
, fc
->data_factor
,
8994 printf ("\n%08lx %08lx %08lx CIE\n",
8995 (unsigned long)(saved_start
- section_start
), length
, cie_id
);
8996 printf (" Version: %d\n", version
);
8997 printf (" Augmentation: \"%s\"\n", fc
->augmentation
);
8998 printf (" Code alignment factor: %u\n", fc
->code_factor
);
8999 printf (" Data alignment factor: %d\n", fc
->data_factor
);
9000 printf (" Return address column: %d\n", fc
->ra
);
9002 if (augmentation_data_len
)
9005 printf (" Augmentation data: ");
9006 for (i
= 0; i
< augmentation_data_len
; ++i
)
9007 printf (" %02x", augmentation_data
[i
]);
9013 if (augmentation_data_len
)
9015 unsigned char *p
, *q
;
9016 p
= fc
->augmentation
+ 1;
9017 q
= augmentation_data
;
9024 q
+= 1 + size_of_encoded_value (*q
);
9026 fc
->fde_encoding
= *q
++;
9032 if (fc
->fde_encoding
)
9033 encoded_ptr_size
= size_of_encoded_value (fc
->fde_encoding
);
9036 frame_need_space (fc
, fc
->ra
);
9040 unsigned char *look_for
;
9041 static Frame_Chunk fde_fc
;
9044 memset (fc
, 0, sizeof (Frame_Chunk
));
9046 look_for
= is_eh
? start
- 4 - cie_id
: section_start
+ cie_id
;
9048 for (cie
= chunks
; cie
; cie
= cie
->next
)
9049 if (cie
->chunk_start
== look_for
)
9054 warn ("Invalid CIE pointer %08lx in FDE at %08lx\n",
9055 cie_id
, saved_start
);
9058 fc
->col_type
= (short int *) xmalloc (sizeof (short int));
9059 fc
->col_offset
= (int *) xmalloc (sizeof (int));
9060 frame_need_space (fc
, max_regs
- 1);
9062 fc
->augmentation
= "";
9063 fc
->fde_encoding
= 0;
9067 fc
->ncols
= cie
->ncols
;
9068 fc
->col_type
= (short int *) xmalloc (fc
->ncols
* sizeof (short int));
9069 fc
->col_offset
= (int *) xmalloc (fc
->ncols
* sizeof (int));
9070 memcpy (fc
->col_type
, cie
->col_type
, fc
->ncols
* sizeof (short int));
9071 memcpy (fc
->col_offset
, cie
->col_offset
, fc
->ncols
* sizeof (int));
9072 fc
->augmentation
= cie
->augmentation
;
9073 fc
->code_factor
= cie
->code_factor
;
9074 fc
->data_factor
= cie
->data_factor
;
9075 fc
->cfa_reg
= cie
->cfa_reg
;
9076 fc
->cfa_offset
= cie
->cfa_offset
;
9078 frame_need_space (fc
, max_regs
-1);
9079 fc
->fde_encoding
= cie
->fde_encoding
;
9082 if (fc
->fde_encoding
)
9083 encoded_ptr_size
= size_of_encoded_value (fc
->fde_encoding
);
9085 fc
->pc_begin
= get_encoded_value (start
, fc
->fde_encoding
);
9086 if ((fc
->fde_encoding
& 0x70) == DW_EH_PE_pcrel
)
9087 fc
->pc_begin
+= section
->sh_addr
+ (start
- section_start
);
9088 start
+= encoded_ptr_size
;
9089 fc
->pc_range
= byte_get (start
, encoded_ptr_size
);
9090 start
+= encoded_ptr_size
;
9092 if (cie
->augmentation
[0] == 'z')
9094 augmentation_data_len
= LEB ();
9095 augmentation_data
= start
;
9096 start
+= augmentation_data_len
;
9099 printf ("\n%08lx %08lx %08lx FDE cie=%08lx pc=%08lx..%08lx\n",
9100 (unsigned long)(saved_start
- section_start
), length
, cie_id
,
9101 (unsigned long)(cie
->chunk_start
- section_start
),
9102 fc
->pc_begin
, fc
->pc_begin
+ fc
->pc_range
);
9103 if (! do_debug_frames_interp
&& augmentation_data_len
)
9106 printf (" Augmentation data: ");
9107 for (i
= 0; i
< augmentation_data_len
; ++i
)
9108 printf (" %02x", augmentation_data
[i
]);
9114 /* At this point, fc is the current chunk, cie (if any) is set, and we're
9115 about to interpret instructions for the chunk. */
9116 /* ??? At present we need to do this always, since this sizes the
9117 fc->col_type and fc->col_offset arrays, which we write into always.
9118 We should probably split the interpreted and non-interpreted bits
9119 into two different routines, since there's so much that doesn't
9120 really overlap between them. */
9121 if (1 || do_debug_frames_interp
)
9123 /* Start by making a pass over the chunk, allocating storage
9124 and taking note of what registers are used. */
9125 unsigned char *tmp
= start
;
9127 while (start
< block_end
)
9130 unsigned long reg
, tmp
;
9137 /* Warning: if you add any more cases to this switch, be
9138 sure to add them to the corresponding switch below. */
9141 case DW_CFA_advance_loc
:
9145 frame_need_space (fc
, opa
);
9146 fc
->col_type
[opa
] = DW_CFA_undefined
;
9148 case DW_CFA_restore
:
9149 frame_need_space (fc
, opa
);
9150 fc
->col_type
[opa
] = DW_CFA_undefined
;
9152 case DW_CFA_set_loc
:
9153 start
+= encoded_ptr_size
;
9155 case DW_CFA_advance_loc1
:
9158 case DW_CFA_advance_loc2
:
9161 case DW_CFA_advance_loc4
:
9164 case DW_CFA_offset_extended
:
9165 reg
= LEB (); LEB ();
9166 frame_need_space (fc
, reg
);
9167 fc
->col_type
[reg
] = DW_CFA_undefined
;
9169 case DW_CFA_restore_extended
:
9171 frame_need_space (fc
, reg
);
9172 fc
->col_type
[reg
] = DW_CFA_undefined
;
9174 case DW_CFA_undefined
:
9176 frame_need_space (fc
, reg
);
9177 fc
->col_type
[reg
] = DW_CFA_undefined
;
9179 case DW_CFA_same_value
:
9181 frame_need_space (fc
, reg
);
9182 fc
->col_type
[reg
] = DW_CFA_undefined
;
9184 case DW_CFA_register
:
9185 reg
= LEB (); LEB ();
9186 frame_need_space (fc
, reg
);
9187 fc
->col_type
[reg
] = DW_CFA_undefined
;
9189 case DW_CFA_def_cfa
:
9192 case DW_CFA_def_cfa_register
:
9195 case DW_CFA_def_cfa_offset
:
9198 case DW_CFA_def_cfa_expression
:
9202 case DW_CFA_expression
:
9206 frame_need_space (fc
, reg
);
9207 fc
->col_type
[reg
] = DW_CFA_undefined
;
9209 case DW_CFA_offset_extended_sf
:
9210 reg
= LEB (); SLEB ();
9211 frame_need_space (fc
, reg
);
9212 fc
->col_type
[reg
] = DW_CFA_undefined
;
9214 case DW_CFA_def_cfa_sf
:
9217 case DW_CFA_def_cfa_offset_sf
:
9220 case DW_CFA_MIPS_advance_loc8
:
9223 case DW_CFA_GNU_args_size
:
9226 case DW_CFA_GNU_negative_offset_extended
:
9227 reg
= LEB (); LEB ();
9228 frame_need_space (fc
, reg
);
9229 fc
->col_type
[reg
] = DW_CFA_undefined
;
9238 /* Now we know what registers are used, make a second pass over
9239 the chunk, this time actually printing out the info. */
9241 while (start
< block_end
)
9244 unsigned long ul
, reg
, roffs
;
9253 /* Warning: if you add any more cases to this switch, be
9254 sure to add them to the corresponding switch above. */
9257 case DW_CFA_advance_loc
:
9258 if (do_debug_frames_interp
)
9259 frame_display_row (fc
, &need_col_headers
, &max_regs
);
9261 printf (" DW_CFA_advance_loc: %d to %08lx\n",
9262 opa
* fc
->code_factor
,
9263 fc
->pc_begin
+ opa
* fc
->code_factor
);
9264 fc
->pc_begin
+= opa
* fc
->code_factor
;
9269 if (! do_debug_frames_interp
)
9270 printf (" DW_CFA_offset: r%d at cfa%+ld\n",
9271 opa
, roffs
* fc
->data_factor
);
9272 fc
->col_type
[opa
] = DW_CFA_offset
;
9273 fc
->col_offset
[opa
] = roffs
* fc
->data_factor
;
9276 case DW_CFA_restore
:
9277 if (! do_debug_frames_interp
)
9278 printf (" DW_CFA_restore: r%d\n", opa
);
9279 fc
->col_type
[opa
] = cie
->col_type
[opa
];
9280 fc
->col_offset
[opa
] = cie
->col_offset
[opa
];
9283 case DW_CFA_set_loc
:
9284 vma
= get_encoded_value (start
, fc
->fde_encoding
);
9285 if ((fc
->fde_encoding
& 0x70) == DW_EH_PE_pcrel
)
9286 vma
+= section
->sh_addr
+ (start
- section_start
);
9287 start
+= encoded_ptr_size
;
9288 if (do_debug_frames_interp
)
9289 frame_display_row (fc
, &need_col_headers
, &max_regs
);
9291 printf (" DW_CFA_set_loc: %08lx\n", (unsigned long)vma
);
9295 case DW_CFA_advance_loc1
:
9296 ofs
= byte_get (start
, 1); start
+= 1;
9297 if (do_debug_frames_interp
)
9298 frame_display_row (fc
, &need_col_headers
, &max_regs
);
9300 printf (" DW_CFA_advance_loc1: %ld to %08lx\n",
9301 ofs
* fc
->code_factor
,
9302 fc
->pc_begin
+ ofs
* fc
->code_factor
);
9303 fc
->pc_begin
+= ofs
* fc
->code_factor
;
9306 case DW_CFA_advance_loc2
:
9307 ofs
= byte_get (start
, 2); start
+= 2;
9308 if (do_debug_frames_interp
)
9309 frame_display_row (fc
, &need_col_headers
, &max_regs
);
9311 printf (" DW_CFA_advance_loc2: %ld to %08lx\n",
9312 ofs
* fc
->code_factor
,
9313 fc
->pc_begin
+ ofs
* fc
->code_factor
);
9314 fc
->pc_begin
+= ofs
* fc
->code_factor
;
9317 case DW_CFA_advance_loc4
:
9318 ofs
= byte_get (start
, 4); start
+= 4;
9319 if (do_debug_frames_interp
)
9320 frame_display_row (fc
, &need_col_headers
, &max_regs
);
9322 printf (" DW_CFA_advance_loc4: %ld to %08lx\n",
9323 ofs
* fc
->code_factor
,
9324 fc
->pc_begin
+ ofs
* fc
->code_factor
);
9325 fc
->pc_begin
+= ofs
* fc
->code_factor
;
9328 case DW_CFA_offset_extended
:
9331 if (! do_debug_frames_interp
)
9332 printf (" DW_CFA_offset_extended: r%ld at cfa%+ld\n",
9333 reg
, roffs
* fc
->data_factor
);
9334 fc
->col_type
[reg
] = DW_CFA_offset
;
9335 fc
->col_offset
[reg
] = roffs
* fc
->data_factor
;
9338 case DW_CFA_restore_extended
:
9340 if (! do_debug_frames_interp
)
9341 printf (" DW_CFA_restore_extended: r%ld\n", reg
);
9342 fc
->col_type
[reg
] = cie
->col_type
[reg
];
9343 fc
->col_offset
[reg
] = cie
->col_offset
[reg
];
9346 case DW_CFA_undefined
:
9348 if (! do_debug_frames_interp
)
9349 printf (" DW_CFA_undefined: r%ld\n", reg
);
9350 fc
->col_type
[reg
] = DW_CFA_undefined
;
9351 fc
->col_offset
[reg
] = 0;
9354 case DW_CFA_same_value
:
9356 if (! do_debug_frames_interp
)
9357 printf (" DW_CFA_same_value: r%ld\n", reg
);
9358 fc
->col_type
[reg
] = DW_CFA_same_value
;
9359 fc
->col_offset
[reg
] = 0;
9362 case DW_CFA_register
:
9365 if (! do_debug_frames_interp
)
9366 printf (" DW_CFA_register: r%ld in r%ld\n", reg
, roffs
);
9367 fc
->col_type
[reg
] = DW_CFA_register
;
9368 fc
->col_offset
[reg
] = roffs
;
9371 case DW_CFA_remember_state
:
9372 if (! do_debug_frames_interp
)
9373 printf (" DW_CFA_remember_state\n");
9374 rs
= (Frame_Chunk
*) xmalloc (sizeof (Frame_Chunk
));
9375 rs
->ncols
= fc
->ncols
;
9376 rs
->col_type
= (short int *) xmalloc (rs
->ncols
* sizeof (short int));
9377 rs
->col_offset
= (int *) xmalloc (rs
->ncols
* sizeof (int));
9378 memcpy (rs
->col_type
, fc
->col_type
, rs
->ncols
);
9379 memcpy (rs
->col_offset
, fc
->col_offset
, rs
->ncols
* sizeof (int));
9380 rs
->next
= remembered_state
;
9381 remembered_state
= rs
;
9384 case DW_CFA_restore_state
:
9385 if (! do_debug_frames_interp
)
9386 printf (" DW_CFA_restore_state\n");
9387 rs
= remembered_state
;
9388 remembered_state
= rs
->next
;
9389 frame_need_space (fc
, rs
->ncols
-1);
9390 memcpy (fc
->col_type
, rs
->col_type
, rs
->ncols
);
9391 memcpy (fc
->col_offset
, rs
->col_offset
, rs
->ncols
* sizeof (int));
9392 free (rs
->col_type
);
9393 free (rs
->col_offset
);
9397 case DW_CFA_def_cfa
:
9398 fc
->cfa_reg
= LEB ();
9399 fc
->cfa_offset
= LEB ();
9401 if (! do_debug_frames_interp
)
9402 printf (" DW_CFA_def_cfa: r%d ofs %d\n",
9403 fc
->cfa_reg
, fc
->cfa_offset
);
9406 case DW_CFA_def_cfa_register
:
9407 fc
->cfa_reg
= LEB ();
9409 if (! do_debug_frames_interp
)
9410 printf (" DW_CFA_def_cfa_reg: r%d\n", fc
->cfa_reg
);
9413 case DW_CFA_def_cfa_offset
:
9414 fc
->cfa_offset
= LEB ();
9415 if (! do_debug_frames_interp
)
9416 printf (" DW_CFA_def_cfa_offset: %d\n", fc
->cfa_offset
);
9420 if (! do_debug_frames_interp
)
9421 printf (" DW_CFA_nop\n");
9424 case DW_CFA_def_cfa_expression
:
9426 if (! do_debug_frames_interp
)
9428 printf (" DW_CFA_def_cfa_expression (");
9429 decode_location_expression (start
, addr_size
, ul
);
9436 case DW_CFA_expression
:
9439 if (! do_debug_frames_interp
)
9441 printf (" DW_CFA_expression: r%ld (", reg
);
9442 decode_location_expression (start
, addr_size
, ul
);
9445 fc
->col_type
[reg
] = DW_CFA_expression
;
9449 case DW_CFA_offset_extended_sf
:
9452 frame_need_space (fc
, reg
);
9453 if (! do_debug_frames_interp
)
9454 printf (" DW_CFA_offset_extended_sf: r%ld at cfa%+ld\n",
9455 reg
, l
* fc
->data_factor
);
9456 fc
->col_type
[reg
] = DW_CFA_offset
;
9457 fc
->col_offset
[reg
] = l
* fc
->data_factor
;
9460 case DW_CFA_def_cfa_sf
:
9461 fc
->cfa_reg
= LEB ();
9462 fc
->cfa_offset
= SLEB ();
9464 if (! do_debug_frames_interp
)
9465 printf (" DW_CFA_def_cfa_sf: r%d ofs %d\n",
9466 fc
->cfa_reg
, fc
->cfa_offset
);
9469 case DW_CFA_def_cfa_offset_sf
:
9470 fc
->cfa_offset
= SLEB ();
9471 if (! do_debug_frames_interp
)
9472 printf (" DW_CFA_def_cfa_offset_sf: %d\n", fc
->cfa_offset
);
9475 case DW_CFA_MIPS_advance_loc8
:
9476 ofs
= byte_get (start
, 8); start
+= 8;
9477 if (do_debug_frames_interp
)
9478 frame_display_row (fc
, &need_col_headers
, &max_regs
);
9480 printf (" DW_CFA_MIPS_advance_loc8: %ld to %08lx\n",
9481 ofs
* fc
->code_factor
,
9482 fc
->pc_begin
+ ofs
* fc
->code_factor
);
9483 fc
->pc_begin
+= ofs
* fc
->code_factor
;
9486 case DW_CFA_GNU_window_save
:
9487 if (! do_debug_frames_interp
)
9488 printf (" DW_CFA_GNU_window_save\n");
9491 case DW_CFA_GNU_args_size
:
9493 if (! do_debug_frames_interp
)
9494 printf (" DW_CFA_GNU_args_size: %ld\n", ul
);
9497 case DW_CFA_GNU_negative_offset_extended
:
9500 frame_need_space (fc
, reg
);
9501 if (! do_debug_frames_interp
)
9502 printf (" DW_CFA_GNU_negative_offset_extended: r%ld at cfa%+ld\n",
9503 reg
, l
* fc
->data_factor
);
9504 fc
->col_type
[reg
] = DW_CFA_offset
;
9505 fc
->col_offset
[reg
] = l
* fc
->data_factor
;
9509 fprintf (stderr
, "unsupported or unknown DW_CFA_%d\n", op
);
9514 if (do_debug_frames_interp
)
9515 frame_display_row (fc
, &need_col_headers
, &max_regs
);
9530 display_debug_not_supported (section
, start
, file
)
9531 Elf_Internal_Shdr
*section
;
9532 unsigned char *start ATTRIBUTE_UNUSED
;
9533 FILE *file ATTRIBUTE_UNUSED
;
9535 printf (_("Displaying the debug contents of section %s is not yet supported.\n"),
9536 SECTION_NAME (section
));
9541 /* Pre-scan the .debug_info section to record the size of address.
9542 When dumping the .debug_line, we use that size information, assuming
9543 that all compilation units have the same address size. */
9545 prescan_debug_info (section
, start
, file
)
9546 Elf_Internal_Shdr
*section ATTRIBUTE_UNUSED
;
9547 unsigned char *start
;
9548 FILE *file ATTRIBUTE_UNUSED
;
9550 unsigned long length
;
9552 /* Read the first 4 bytes. For a 32-bit DWARF section, this will
9553 be the length. For a 64-bit DWARF section, it'll be the escape
9554 code 0xffffffff followed by an 8 byte length. For the purposes
9555 of this prescan, we don't care about the actual length, but the
9556 presence of the escape bytes does affect the location of the byte
9557 which describes the address size. */
9558 length
= byte_get (start
, 4);
9560 if (length
== 0xffffffff)
9562 /* For 64-bit DWARF, the 1-byte address_size field is 22 bytes
9563 from the start of the section. This is computed as follows:
9565 unit_length: 12 bytes
9567 debug_abbrev_offset: 8 bytes
9568 -----------------------------
9571 debug_line_pointer_size
= byte_get (start
+ 22, 1);
9575 /* For 32-bit DWARF, the 1-byte address_size field is 10 bytes from
9576 the start of the section:
9577 unit_length: 4 bytes
9579 debug_abbrev_offset: 4 bytes
9580 -----------------------------
9583 debug_line_pointer_size
= byte_get (start
+ 10, 1);
9588 /* A structure containing the name of a debug section and a pointer
9589 to a function that can decode it. The third field is a prescan
9590 function to be run over the section before displaying any of the
9594 const char *const name
;
9595 int (*display
) PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
9596 int (*prescan
) PARAMS ((Elf_Internal_Shdr
*, unsigned char *, FILE *));
9600 { ".debug_abbrev", display_debug_abbrev
, NULL
},
9601 { ".debug_aranges", display_debug_aranges
, NULL
},
9602 { ".debug_frame", display_debug_frames
, NULL
},
9603 { ".debug_info", display_debug_info
, prescan_debug_info
},
9604 { ".debug_line", display_debug_lines
, NULL
},
9605 { ".debug_pubnames", display_debug_pubnames
, NULL
},
9606 { ".eh_frame", display_debug_frames
, NULL
},
9607 { ".debug_macinfo", display_debug_macinfo
, NULL
},
9608 { ".debug_str", display_debug_str
, NULL
},
9609 { ".debug_loc", display_debug_loc
, NULL
},
9610 { ".debug_pubtypes", display_debug_not_supported
, NULL
},
9611 { ".debug_ranges", display_debug_not_supported
, NULL
},
9612 { ".debug_static_func", display_debug_not_supported
, NULL
},
9613 { ".debug_static_vars", display_debug_not_supported
, NULL
},
9614 { ".debug_types", display_debug_not_supported
, NULL
},
9615 { ".debug_weaknames", display_debug_not_supported
, NULL
}
9619 display_debug_section (section
, file
)
9620 Elf_Internal_Shdr
*section
;
9623 char *name
= SECTION_NAME (section
);
9624 bfd_size_type length
;
9625 unsigned char *start
;
9628 length
= section
->sh_size
;
9631 printf (_("\nSection '%s' has no debugging data.\n"), name
);
9635 start
= (unsigned char *) get_data (NULL
, file
, section
->sh_offset
, length
,
9636 _("debug section data"));
9640 /* See if we know how to display the contents of this section. */
9641 if (strncmp (name
, ".gnu.linkonce.wi.", 17) == 0)
9642 name
= ".debug_info";
9644 for (i
= NUM_ELEM (debug_displays
); i
--;)
9645 if (strcmp (debug_displays
[i
].name
, name
) == 0)
9647 debug_displays
[i
].display (section
, start
, file
);
9652 printf (_("Unrecognized debug section: %s\n"), name
);
9656 /* If we loaded in the abbrev section at some point,
9657 we must release it here. */
9664 process_section_contents (file
)
9667 Elf_Internal_Shdr
*section
;
9673 /* Pre-scan the debug sections to find some debug information not
9674 present in some of them. For the .debug_line, we must find out the
9675 size of address (specified in .debug_info and .debug_aranges). */
9676 for (i
= 0, section
= section_headers
;
9677 i
< elf_header
.e_shnum
&& i
< num_dump_sects
;
9680 char *name
= SECTION_NAME (section
);
9683 if (section
->sh_size
== 0)
9686 /* See if there is some pre-scan operation for this section. */
9687 for (j
= NUM_ELEM (debug_displays
); j
--;)
9688 if (strcmp (debug_displays
[j
].name
, name
) == 0)
9690 if (debug_displays
[j
].prescan
!= NULL
)
9692 bfd_size_type length
;
9693 unsigned char *start
;
9695 length
= section
->sh_size
;
9696 start
= ((unsigned char *)
9697 get_data (NULL
, file
, section
->sh_offset
, length
,
9698 _("debug section data")));
9702 debug_displays
[j
].prescan (section
, start
, file
);
9710 for (i
= 0, section
= section_headers
;
9711 i
< elf_header
.e_shnum
&& i
< num_dump_sects
;
9714 #ifdef SUPPORT_DISASSEMBLY
9715 if (dump_sects
[i
] & DISASS_DUMP
)
9716 disassemble_section (section
, file
);
9718 if (dump_sects
[i
] & HEX_DUMP
)
9719 dump_section (section
, file
);
9721 if (dump_sects
[i
] & DEBUG_DUMP
)
9722 display_debug_section (section
, file
);
9725 if (i
< num_dump_sects
)
9726 warn (_("Some sections were not dumped because they do not exist!\n"));
9732 process_mips_fpe_exception (mask
)
9738 if (mask
& OEX_FPU_INEX
)
9739 fputs ("INEX", stdout
), first
= 0;
9740 if (mask
& OEX_FPU_UFLO
)
9741 printf ("%sUFLO", first
? "" : "|"), first
= 0;
9742 if (mask
& OEX_FPU_OFLO
)
9743 printf ("%sOFLO", first
? "" : "|"), first
= 0;
9744 if (mask
& OEX_FPU_DIV0
)
9745 printf ("%sDIV0", first
? "" : "|"), first
= 0;
9746 if (mask
& OEX_FPU_INVAL
)
9747 printf ("%sINVAL", first
? "" : "|");
9750 fputs ("0", stdout
);
9754 process_mips_specific (file
)
9757 Elf_Internal_Dyn
*entry
;
9758 size_t liblist_offset
= 0;
9759 size_t liblistno
= 0;
9760 size_t conflictsno
= 0;
9761 size_t options_offset
= 0;
9762 size_t conflicts_offset
= 0;
9764 /* We have a lot of special sections. Thanks SGI! */
9765 if (dynamic_segment
== NULL
)
9766 /* No information available. */
9769 for (entry
= dynamic_segment
; entry
->d_tag
!= DT_NULL
; ++entry
)
9770 switch (entry
->d_tag
)
9772 case DT_MIPS_LIBLIST
:
9774 = offset_from_vma (file
, entry
->d_un
.d_val
,
9775 liblistno
* sizeof (Elf32_External_Lib
));
9777 case DT_MIPS_LIBLISTNO
:
9778 liblistno
= entry
->d_un
.d_val
;
9780 case DT_MIPS_OPTIONS
:
9781 options_offset
= offset_from_vma (file
, entry
->d_un
.d_val
, 0);
9783 case DT_MIPS_CONFLICT
:
9785 = offset_from_vma (file
, entry
->d_un
.d_val
,
9786 conflictsno
* sizeof (Elf32_External_Conflict
));
9788 case DT_MIPS_CONFLICTNO
:
9789 conflictsno
= entry
->d_un
.d_val
;
9795 if (liblist_offset
!= 0 && liblistno
!= 0 && do_dynamic
)
9797 Elf32_External_Lib
*elib
;
9800 elib
= ((Elf32_External_Lib
*)
9801 get_data (NULL
, file
, liblist_offset
,
9802 liblistno
* sizeof (Elf32_External_Lib
),
9806 printf ("\nSection '.liblist' contains %lu entries:\n",
9807 (unsigned long) liblistno
);
9808 fputs (" Library Time Stamp Checksum Version Flags\n",
9811 for (cnt
= 0; cnt
< liblistno
; ++cnt
)
9818 liblist
.l_name
= BYTE_GET (elib
[cnt
].l_name
);
9819 time
= BYTE_GET (elib
[cnt
].l_time_stamp
);
9820 liblist
.l_checksum
= BYTE_GET (elib
[cnt
].l_checksum
);
9821 liblist
.l_version
= BYTE_GET (elib
[cnt
].l_version
);
9822 liblist
.l_flags
= BYTE_GET (elib
[cnt
].l_flags
);
9824 tmp
= gmtime (&time
);
9825 sprintf (timebuf
, "%04u-%02u-%02uT%02u:%02u:%02u",
9826 tmp
->tm_year
+ 1900, tmp
->tm_mon
+ 1, tmp
->tm_mday
,
9827 tmp
->tm_hour
, tmp
->tm_min
, tmp
->tm_sec
);
9829 printf ("%3lu: ", (unsigned long) cnt
);
9830 print_symbol (20, dynamic_strings
+ liblist
.l_name
);
9831 printf (" %s %#10lx %-7ld", timebuf
, liblist
.l_checksum
,
9834 if (liblist
.l_flags
== 0)
9845 { " EXACT_MATCH", LL_EXACT_MATCH
},
9846 { " IGNORE_INT_VER", LL_IGNORE_INT_VER
},
9847 { " REQUIRE_MINOR", LL_REQUIRE_MINOR
},
9848 { " EXPORTS", LL_EXPORTS
},
9849 { " DELAY_LOAD", LL_DELAY_LOAD
},
9850 { " DELTA", LL_DELTA
}
9852 int flags
= liblist
.l_flags
;
9856 fcnt
< sizeof (l_flags_vals
) / sizeof (l_flags_vals
[0]);
9858 if ((flags
& l_flags_vals
[fcnt
].bit
) != 0)
9860 fputs (l_flags_vals
[fcnt
].name
, stdout
);
9861 flags
^= l_flags_vals
[fcnt
].bit
;
9864 printf (" %#x", (unsigned int) flags
);
9874 if (options_offset
!= 0)
9876 Elf_External_Options
*eopt
;
9877 Elf_Internal_Shdr
*sect
= section_headers
;
9878 Elf_Internal_Options
*iopt
;
9879 Elf_Internal_Options
*option
;
9883 /* Find the section header so that we get the size. */
9884 while (sect
->sh_type
!= SHT_MIPS_OPTIONS
)
9887 eopt
= (Elf_External_Options
*) get_data (NULL
, file
, options_offset
,
9888 sect
->sh_size
, _("options"));
9891 iopt
= ((Elf_Internal_Options
*)
9892 malloc ((sect
->sh_size
/ sizeof (eopt
)) * sizeof (*iopt
)));
9895 error (_("Out of memory"));
9902 while (offset
< sect
->sh_size
)
9904 Elf_External_Options
*eoption
;
9906 eoption
= (Elf_External_Options
*) ((char *) eopt
+ offset
);
9908 option
->kind
= BYTE_GET (eoption
->kind
);
9909 option
->size
= BYTE_GET (eoption
->size
);
9910 option
->section
= BYTE_GET (eoption
->section
);
9911 option
->info
= BYTE_GET (eoption
->info
);
9913 offset
+= option
->size
;
9919 printf (_("\nSection '%s' contains %d entries:\n"),
9920 SECTION_NAME (sect
), cnt
);
9928 switch (option
->kind
)
9931 /* This shouldn't happen. */
9932 printf (" NULL %d %lx", option
->section
, option
->info
);
9935 printf (" REGINFO ");
9936 if (elf_header
.e_machine
== EM_MIPS
)
9939 Elf32_External_RegInfo
*ereg
;
9940 Elf32_RegInfo reginfo
;
9942 ereg
= (Elf32_External_RegInfo
*) (option
+ 1);
9943 reginfo
.ri_gprmask
= BYTE_GET (ereg
->ri_gprmask
);
9944 reginfo
.ri_cprmask
[0] = BYTE_GET (ereg
->ri_cprmask
[0]);
9945 reginfo
.ri_cprmask
[1] = BYTE_GET (ereg
->ri_cprmask
[1]);
9946 reginfo
.ri_cprmask
[2] = BYTE_GET (ereg
->ri_cprmask
[2]);
9947 reginfo
.ri_cprmask
[3] = BYTE_GET (ereg
->ri_cprmask
[3]);
9948 reginfo
.ri_gp_value
= BYTE_GET (ereg
->ri_gp_value
);
9950 printf ("GPR %08lx GP 0x%lx\n",
9952 (unsigned long) reginfo
.ri_gp_value
);
9953 printf (" CPR0 %08lx CPR1 %08lx CPR2 %08lx CPR3 %08lx\n",
9954 reginfo
.ri_cprmask
[0], reginfo
.ri_cprmask
[1],
9955 reginfo
.ri_cprmask
[2], reginfo
.ri_cprmask
[3]);
9960 Elf64_External_RegInfo
*ereg
;
9961 Elf64_Internal_RegInfo reginfo
;
9963 ereg
= (Elf64_External_RegInfo
*) (option
+ 1);
9964 reginfo
.ri_gprmask
= BYTE_GET (ereg
->ri_gprmask
);
9965 reginfo
.ri_cprmask
[0] = BYTE_GET (ereg
->ri_cprmask
[0]);
9966 reginfo
.ri_cprmask
[1] = BYTE_GET (ereg
->ri_cprmask
[1]);
9967 reginfo
.ri_cprmask
[2] = BYTE_GET (ereg
->ri_cprmask
[2]);
9968 reginfo
.ri_cprmask
[3] = BYTE_GET (ereg
->ri_cprmask
[3]);
9969 reginfo
.ri_gp_value
= BYTE_GET8 (ereg
->ri_gp_value
);
9971 printf ("GPR %08lx GP 0x",
9972 reginfo
.ri_gprmask
);
9973 printf_vma (reginfo
.ri_gp_value
);
9976 printf (" CPR0 %08lx CPR1 %08lx CPR2 %08lx CPR3 %08lx\n",
9977 reginfo
.ri_cprmask
[0], reginfo
.ri_cprmask
[1],
9978 reginfo
.ri_cprmask
[2], reginfo
.ri_cprmask
[3]);
9982 case ODK_EXCEPTIONS
:
9983 fputs (" EXCEPTIONS fpe_min(", stdout
);
9984 process_mips_fpe_exception (option
->info
& OEX_FPU_MIN
);
9985 fputs (") fpe_max(", stdout
);
9986 process_mips_fpe_exception ((option
->info
& OEX_FPU_MAX
) >> 8);
9987 fputs (")", stdout
);
9989 if (option
->info
& OEX_PAGE0
)
9990 fputs (" PAGE0", stdout
);
9991 if (option
->info
& OEX_SMM
)
9992 fputs (" SMM", stdout
);
9993 if (option
->info
& OEX_FPDBUG
)
9994 fputs (" FPDBUG", stdout
);
9995 if (option
->info
& OEX_DISMISS
)
9996 fputs (" DISMISS", stdout
);
9999 fputs (" PAD ", stdout
);
10000 if (option
->info
& OPAD_PREFIX
)
10001 fputs (" PREFIX", stdout
);
10002 if (option
->info
& OPAD_POSTFIX
)
10003 fputs (" POSTFIX", stdout
);
10004 if (option
->info
& OPAD_SYMBOL
)
10005 fputs (" SYMBOL", stdout
);
10008 fputs (" HWPATCH ", stdout
);
10009 if (option
->info
& OHW_R4KEOP
)
10010 fputs (" R4KEOP", stdout
);
10011 if (option
->info
& OHW_R8KPFETCH
)
10012 fputs (" R8KPFETCH", stdout
);
10013 if (option
->info
& OHW_R5KEOP
)
10014 fputs (" R5KEOP", stdout
);
10015 if (option
->info
& OHW_R5KCVTL
)
10016 fputs (" R5KCVTL", stdout
);
10019 fputs (" FILL ", stdout
);
10020 /* XXX Print content of info word? */
10023 fputs (" TAGS ", stdout
);
10024 /* XXX Print content of info word? */
10027 fputs (" HWAND ", stdout
);
10028 if (option
->info
& OHWA0_R4KEOP_CHECKED
)
10029 fputs (" R4KEOP_CHECKED", stdout
);
10030 if (option
->info
& OHWA0_R4KEOP_CLEAN
)
10031 fputs (" R4KEOP_CLEAN", stdout
);
10034 fputs (" HWOR ", stdout
);
10035 if (option
->info
& OHWA0_R4KEOP_CHECKED
)
10036 fputs (" R4KEOP_CHECKED", stdout
);
10037 if (option
->info
& OHWA0_R4KEOP_CLEAN
)
10038 fputs (" R4KEOP_CLEAN", stdout
);
10041 printf (" GP_GROUP %#06lx self-contained %#06lx",
10042 option
->info
& OGP_GROUP
,
10043 (option
->info
& OGP_SELF
) >> 16);
10046 printf (" IDENT %#06lx self-contained %#06lx",
10047 option
->info
& OGP_GROUP
,
10048 (option
->info
& OGP_SELF
) >> 16);
10051 /* This shouldn't happen. */
10052 printf (" %3d ??? %d %lx",
10053 option
->kind
, option
->section
, option
->info
);
10057 len
= sizeof (*eopt
);
10058 while (len
< option
->size
)
10059 if (((char *) option
)[len
] >= ' '
10060 && ((char *) option
)[len
] < 0x7f)
10061 printf ("%c", ((char *) option
)[len
++]);
10063 printf ("\\%03o", ((char *) option
)[len
++]);
10065 fputs ("\n", stdout
);
10073 if (conflicts_offset
!= 0 && conflictsno
!= 0)
10075 Elf32_Conflict
*iconf
;
10078 if (dynamic_symbols
== NULL
)
10080 error (_("conflict list found without a dynamic symbol table"));
10084 iconf
= (Elf32_Conflict
*) malloc (conflictsno
* sizeof (*iconf
));
10087 error (_("Out of memory"));
10093 Elf32_External_Conflict
*econf32
;
10095 econf32
= ((Elf32_External_Conflict
*)
10096 get_data (NULL
, file
, conflicts_offset
,
10097 conflictsno
* sizeof (*econf32
),
10102 for (cnt
= 0; cnt
< conflictsno
; ++cnt
)
10103 iconf
[cnt
] = BYTE_GET (econf32
[cnt
]);
10109 Elf64_External_Conflict
*econf64
;
10111 econf64
= ((Elf64_External_Conflict
*)
10112 get_data (NULL
, file
, conflicts_offset
,
10113 conflictsno
* sizeof (*econf64
),
10118 for (cnt
= 0; cnt
< conflictsno
; ++cnt
)
10119 iconf
[cnt
] = BYTE_GET (econf64
[cnt
]);
10124 printf (_("\nSection '.conflict' contains %ld entries:\n"),
10125 (long) conflictsno
);
10126 puts (_(" Num: Index Value Name"));
10128 for (cnt
= 0; cnt
< conflictsno
; ++cnt
)
10130 Elf_Internal_Sym
*psym
= & dynamic_symbols
[iconf
[cnt
]];
10132 printf ("%5lu: %8lu ", (unsigned long) cnt
, iconf
[cnt
]);
10133 print_vma (psym
->st_value
, FULL_HEX
);
10135 print_symbol (25, dynamic_strings
+ psym
->st_name
);
10146 process_gnu_liblist (file
)
10149 Elf_Internal_Shdr
*section
, *string_sec
;
10150 Elf32_External_Lib
*elib
;
10158 for (i
= 0, section
= section_headers
;
10159 i
< elf_header
.e_shnum
;
10162 switch (section
->sh_type
)
10164 case SHT_GNU_LIBLIST
:
10165 elib
= ((Elf32_External_Lib
*)
10166 get_data (NULL
, file
, section
->sh_offset
, section
->sh_size
,
10171 string_sec
= SECTION_HEADER (section
->sh_link
);
10173 strtab
= (char *) get_data (NULL
, file
, string_sec
->sh_offset
,
10174 string_sec
->sh_size
,
10175 _("liblist string table"));
10178 || section
->sh_entsize
!= sizeof (Elf32_External_Lib
))
10184 printf (_("\nLibrary list section '%s' contains %lu entries:\n"),
10185 SECTION_NAME (section
),
10186 (long) (section
->sh_size
/ sizeof (Elf32_External_Lib
)));
10188 puts (" Library Time Stamp Checksum Version Flags");
10190 for (cnt
= 0; cnt
< section
->sh_size
/ sizeof (Elf32_External_Lib
);
10198 liblist
.l_name
= BYTE_GET (elib
[cnt
].l_name
);
10199 time
= BYTE_GET (elib
[cnt
].l_time_stamp
);
10200 liblist
.l_checksum
= BYTE_GET (elib
[cnt
].l_checksum
);
10201 liblist
.l_version
= BYTE_GET (elib
[cnt
].l_version
);
10202 liblist
.l_flags
= BYTE_GET (elib
[cnt
].l_flags
);
10204 tmp
= gmtime (&time
);
10205 sprintf (timebuf
, "%04u-%02u-%02uT%02u:%02u:%02u",
10206 tmp
->tm_year
+ 1900, tmp
->tm_mon
+ 1, tmp
->tm_mday
,
10207 tmp
->tm_hour
, tmp
->tm_min
, tmp
->tm_sec
);
10209 printf ("%3lu: ", (unsigned long) cnt
);
10211 printf ("%-20s", strtab
+ liblist
.l_name
);
10213 printf ("%-20.20s", strtab
+ liblist
.l_name
);
10214 printf (" %s %#010lx %-7ld %-7ld\n", timebuf
, liblist
.l_checksum
,
10215 liblist
.l_version
, liblist
.l_flags
);
10225 static const char *
10226 get_note_type (e_type
)
10229 static char buff
[64];
10233 case NT_PRSTATUS
: return _("NT_PRSTATUS (prstatus structure)");
10234 case NT_FPREGSET
: return _("NT_FPREGSET (floating point registers)");
10235 case NT_PRPSINFO
: return _("NT_PRPSINFO (prpsinfo structure)");
10236 case NT_TASKSTRUCT
: return _("NT_TASKSTRUCT (task structure)");
10237 case NT_PRXFPREG
: return _("NT_PRXFPREG (user_xfpregs structure)");
10238 case NT_PSTATUS
: return _("NT_PSTATUS (pstatus structure)");
10239 case NT_FPREGS
: return _("NT_FPREGS (floating point registers)");
10240 case NT_PSINFO
: return _("NT_PSINFO (psinfo structure)");
10241 case NT_LWPSTATUS
: return _("NT_LWPSTATUS (lwpstatus_t structure)");
10242 case NT_LWPSINFO
: return _("NT_LWPSINFO (lwpsinfo_t structure)");
10243 case NT_WIN32PSTATUS
: return _("NT_WIN32PSTATUS (win32_pstatus structure)");
10245 sprintf (buff
, _("Unknown note type: (0x%08x)"), e_type
);
10250 static const char *
10251 get_netbsd_elfcore_note_type (e_type
)
10254 static char buff
[64];
10256 if (e_type
== NT_NETBSDCORE_PROCINFO
)
10258 /* NetBSD core "procinfo" structure. */
10259 return _("NetBSD procinfo structure");
10262 /* As of Jan 2002 there are no other machine-independent notes
10263 defined for NetBSD core files. If the note type is less
10264 than the start of the machine-dependent note types, we don't
10267 if (e_type
< NT_NETBSDCORE_FIRSTMACH
)
10269 sprintf (buff
, _("Unknown note type: (0x%08x)"), e_type
);
10273 switch (elf_header
.e_machine
)
10275 /* On the Alpha, SPARC (32-bit and 64-bit), PT_GETREGS == mach+0
10276 and PT_GETFPREGS == mach+2. */
10281 case EM_SPARC32PLUS
:
10285 case NT_NETBSDCORE_FIRSTMACH
+0:
10286 return _("PT_GETREGS (reg structure)");
10287 case NT_NETBSDCORE_FIRSTMACH
+2:
10288 return _("PT_GETFPREGS (fpreg structure)");
10294 /* On all other arch's, PT_GETREGS == mach+1 and
10295 PT_GETFPREGS == mach+3. */
10299 case NT_NETBSDCORE_FIRSTMACH
+1:
10300 return _("PT_GETREGS (reg structure)");
10301 case NT_NETBSDCORE_FIRSTMACH
+3:
10302 return _("PT_GETFPREGS (fpreg structure)");
10308 sprintf (buff
, _("PT_FIRSTMACH+%d"), e_type
- NT_NETBSDCORE_FIRSTMACH
);
10312 /* Note that by the ELF standard, the name field is already null byte
10313 terminated, and namesz includes the terminating null byte.
10314 I.E. the value of namesz for the name "FSF" is 4.
10316 If the value of namesz is zero, there is no name present. */
10318 process_note (pnote
)
10319 Elf_Internal_Note
*pnote
;
10323 if (pnote
->namesz
== 0)
10325 /* If there is no note name, then use the default set of
10326 note type strings. */
10327 nt
= get_note_type (pnote
->type
);
10329 else if (strncmp (pnote
->namedata
, "NetBSD-CORE", 11) == 0)
10331 /* NetBSD-specific core file notes. */
10332 nt
= get_netbsd_elfcore_note_type (pnote
->type
);
10336 /* Don't recognize this note name; just use the default set of
10337 note type strings. */
10338 nt
= get_note_type (pnote
->type
);
10341 printf (" %s\t\t0x%08lx\t%s\n",
10342 pnote
->namesz
? pnote
->namedata
: "(NONE)",
10343 pnote
->descsz
, nt
);
10349 process_corefile_note_segment (file
, offset
, length
)
10354 Elf_External_Note
*pnotes
;
10355 Elf_External_Note
*external
;
10361 pnotes
= (Elf_External_Note
*) get_data (NULL
, file
, offset
, length
,
10368 printf (_("\nNotes at offset 0x%08lx with length 0x%08lx:\n"),
10369 (unsigned long) offset
, (unsigned long) length
);
10370 printf (_(" Owner\t\tData size\tDescription\n"));
10372 while (external
< (Elf_External_Note
*)((char *) pnotes
+ length
))
10374 Elf_External_Note
*next
;
10375 Elf_Internal_Note inote
;
10378 inote
.type
= BYTE_GET (external
->type
);
10379 inote
.namesz
= BYTE_GET (external
->namesz
);
10380 inote
.namedata
= external
->name
;
10381 inote
.descsz
= BYTE_GET (external
->descsz
);
10382 inote
.descdata
= inote
.namedata
+ align_power (inote
.namesz
, 2);
10383 inote
.descpos
= offset
+ (inote
.descdata
- (char *) pnotes
);
10385 next
= (Elf_External_Note
*)(inote
.descdata
+ align_power (inote
.descsz
, 2));
10387 if (((char *) next
) > (((char *) pnotes
) + length
))
10389 warn (_("corrupt note found at offset %x into core notes\n"),
10390 ((char *) external
) - ((char *) pnotes
));
10391 warn (_(" type: %x, namesize: %08lx, descsize: %08lx\n"),
10392 inote
.type
, inote
.namesz
, inote
.descsz
);
10398 /* Verify that name is null terminated. It appears that at least
10399 one version of Linux (RedHat 6.0) generates corefiles that don't
10400 comply with the ELF spec by failing to include the null byte in
10402 if (inote
.namedata
[inote
.namesz
] != '\0')
10404 temp
= malloc (inote
.namesz
+ 1);
10408 error (_("Out of memory\n"));
10413 strncpy (temp
, inote
.namedata
, inote
.namesz
);
10414 temp
[inote
.namesz
] = 0;
10416 /* warn (_("'%s' NOTE name not properly null terminated\n"), temp); */
10417 inote
.namedata
= temp
;
10420 res
&= process_note (& inote
);
10435 process_corefile_note_segments (file
)
10438 Elf_Internal_Phdr
*segment
;
10442 if (! get_program_headers (file
))
10445 for (i
= 0, segment
= program_headers
;
10446 i
< elf_header
.e_phnum
;
10449 if (segment
->p_type
== PT_NOTE
)
10450 res
&= process_corefile_note_segment (file
,
10451 (bfd_vma
) segment
->p_offset
,
10452 (bfd_vma
) segment
->p_filesz
);
10459 process_corefile_contents (file
)
10462 /* If we have not been asked to display the notes then do nothing. */
10466 /* If file is not a core file then exit. */
10467 if (elf_header
.e_type
!= ET_CORE
)
10470 /* No program headers means no NOTE segment. */
10471 if (elf_header
.e_phnum
== 0)
10473 printf (_("No note segments present in the core file.\n"));
10477 return process_corefile_note_segments (file
);
10481 process_arch_specific (file
)
10487 switch (elf_header
.e_machine
)
10490 case EM_MIPS_RS3_LE
:
10491 return process_mips_specific (file
);
10500 get_file_header (file
)
10503 /* Read in the identity array. */
10504 if (fread (elf_header
.e_ident
, EI_NIDENT
, 1, file
) != 1)
10507 /* Determine how to read the rest of the header. */
10508 switch (elf_header
.e_ident
[EI_DATA
])
10510 default: /* fall through */
10511 case ELFDATANONE
: /* fall through */
10513 byte_get
= byte_get_little_endian
;
10514 byte_put
= byte_put_little_endian
;
10517 byte_get
= byte_get_big_endian
;
10518 byte_put
= byte_put_big_endian
;
10522 /* For now we only support 32 bit and 64 bit ELF files. */
10523 is_32bit_elf
= (elf_header
.e_ident
[EI_CLASS
] != ELFCLASS64
);
10525 /* Read in the rest of the header. */
10528 Elf32_External_Ehdr ehdr32
;
10530 if (fread (ehdr32
.e_type
, sizeof (ehdr32
) - EI_NIDENT
, 1, file
) != 1)
10533 elf_header
.e_type
= BYTE_GET (ehdr32
.e_type
);
10534 elf_header
.e_machine
= BYTE_GET (ehdr32
.e_machine
);
10535 elf_header
.e_version
= BYTE_GET (ehdr32
.e_version
);
10536 elf_header
.e_entry
= BYTE_GET (ehdr32
.e_entry
);
10537 elf_header
.e_phoff
= BYTE_GET (ehdr32
.e_phoff
);
10538 elf_header
.e_shoff
= BYTE_GET (ehdr32
.e_shoff
);
10539 elf_header
.e_flags
= BYTE_GET (ehdr32
.e_flags
);
10540 elf_header
.e_ehsize
= BYTE_GET (ehdr32
.e_ehsize
);
10541 elf_header
.e_phentsize
= BYTE_GET (ehdr32
.e_phentsize
);
10542 elf_header
.e_phnum
= BYTE_GET (ehdr32
.e_phnum
);
10543 elf_header
.e_shentsize
= BYTE_GET (ehdr32
.e_shentsize
);
10544 elf_header
.e_shnum
= BYTE_GET (ehdr32
.e_shnum
);
10545 elf_header
.e_shstrndx
= BYTE_GET (ehdr32
.e_shstrndx
);
10549 Elf64_External_Ehdr ehdr64
;
10551 /* If we have been compiled with sizeof (bfd_vma) == 4, then
10552 we will not be able to cope with the 64bit data found in
10553 64 ELF files. Detect this now and abort before we start
10554 overwritting things. */
10555 if (sizeof (bfd_vma
) < 8)
10557 error (_("This instance of readelf has been built without support for a\n\
10558 64 bit data type and so it cannot read 64 bit ELF files.\n"));
10562 if (fread (ehdr64
.e_type
, sizeof (ehdr64
) - EI_NIDENT
, 1, file
) != 1)
10565 elf_header
.e_type
= BYTE_GET (ehdr64
.e_type
);
10566 elf_header
.e_machine
= BYTE_GET (ehdr64
.e_machine
);
10567 elf_header
.e_version
= BYTE_GET (ehdr64
.e_version
);
10568 elf_header
.e_entry
= BYTE_GET8 (ehdr64
.e_entry
);
10569 elf_header
.e_phoff
= BYTE_GET8 (ehdr64
.e_phoff
);
10570 elf_header
.e_shoff
= BYTE_GET8 (ehdr64
.e_shoff
);
10571 elf_header
.e_flags
= BYTE_GET (ehdr64
.e_flags
);
10572 elf_header
.e_ehsize
= BYTE_GET (ehdr64
.e_ehsize
);
10573 elf_header
.e_phentsize
= BYTE_GET (ehdr64
.e_phentsize
);
10574 elf_header
.e_phnum
= BYTE_GET (ehdr64
.e_phnum
);
10575 elf_header
.e_shentsize
= BYTE_GET (ehdr64
.e_shentsize
);
10576 elf_header
.e_shnum
= BYTE_GET (ehdr64
.e_shnum
);
10577 elf_header
.e_shstrndx
= BYTE_GET (ehdr64
.e_shstrndx
);
10580 if (elf_header
.e_shoff
)
10582 /* There may be some extensions in the first section header. Don't
10583 bomb if we can't read it. */
10585 get_32bit_section_headers (file
, 1);
10587 get_64bit_section_headers (file
, 1);
10594 process_file (file_name
)
10598 struct stat statbuf
;
10601 if (stat (file_name
, & statbuf
) < 0)
10603 error (_("Cannot stat input file %s.\n"), file_name
);
10607 file
= fopen (file_name
, "rb");
10610 error (_("Input file %s not found.\n"), file_name
);
10614 if (! get_file_header (file
))
10616 error (_("%s: Failed to read file header\n"), file_name
);
10621 /* Initialise per file variables. */
10622 for (i
= NUM_ELEM (version_info
); i
--;)
10623 version_info
[i
] = 0;
10625 for (i
= NUM_ELEM (dynamic_info
); i
--;)
10626 dynamic_info
[i
] = 0;
10628 /* Process the file. */
10630 printf (_("\nFile: %s\n"), file_name
);
10632 if (! process_file_header ())
10638 if (! process_section_headers (file
))
10640 /* Without loaded section headers we
10641 cannot process lots of things. */
10642 do_unwind
= do_version
= do_dump
= do_arch
= 0;
10644 if (! do_using_dynamic
)
10645 do_syms
= do_reloc
= 0;
10648 if (process_program_headers (file
))
10649 process_dynamic_segment (file
);
10651 process_relocs (file
);
10653 process_unwind (file
);
10655 process_symbol_table (file
);
10657 process_syminfo (file
);
10659 process_version_sections (file
);
10661 process_section_contents (file
);
10663 process_corefile_contents (file
);
10665 process_gnu_liblist (file
);
10667 process_arch_specific (file
);
10671 if (program_headers
)
10673 free (program_headers
);
10674 program_headers
= NULL
;
10677 if (section_headers
)
10679 free (section_headers
);
10680 section_headers
= NULL
;
10685 free (string_table
);
10686 string_table
= NULL
;
10687 string_table_length
= 0;
10690 if (dynamic_strings
)
10692 free (dynamic_strings
);
10693 dynamic_strings
= NULL
;
10696 if (dynamic_symbols
)
10698 free (dynamic_symbols
);
10699 dynamic_symbols
= NULL
;
10700 num_dynamic_syms
= 0;
10703 if (dynamic_syminfo
)
10705 free (dynamic_syminfo
);
10706 dynamic_syminfo
= NULL
;
10712 #ifdef SUPPORT_DISASSEMBLY
10713 /* Needed by the i386 disassembler. For extra credit, someone could
10714 fix this so that we insert symbolic addresses here, esp for GOT/PLT
10718 print_address (unsigned int addr
, FILE *outfile
)
10720 fprintf (outfile
,"0x%8.8x", addr
);
10723 /* Needed by the i386 disassembler. */
10725 db_task_printsym (unsigned int addr
)
10727 print_address (addr
, stderr
);
10731 int main
PARAMS ((int, char **));
10739 char *cmdline_dump_sects
= NULL
;
10740 unsigned num_cmdline_dump_sects
= 0;
10742 #if defined (HAVE_SETLOCALE) && defined (HAVE_LC_MESSAGES)
10743 setlocale (LC_MESSAGES
, "");
10745 #if defined (HAVE_SETLOCALE)
10746 setlocale (LC_CTYPE
, "");
10748 bindtextdomain (PACKAGE
, LOCALEDIR
);
10749 textdomain (PACKAGE
);
10751 parse_args (argc
, argv
);
10753 if (optind
< (argc
- 1))
10756 /* When processing more than one file remember the dump requests
10757 issued on command line to reset them after each file. */
10758 if (optind
+ 1 < argc
&& dump_sects
!= NULL
)
10760 cmdline_dump_sects
= malloc (num_dump_sects
);
10761 if (cmdline_dump_sects
== NULL
)
10762 error (_("Out of memory allocating dump request table."));
10765 memcpy (cmdline_dump_sects
, dump_sects
, num_dump_sects
);
10766 num_cmdline_dump_sects
= num_dump_sects
;
10771 while (optind
< argc
)
10773 err
|= process_file (argv
[optind
++]);
10775 /* Reset dump requests. */
10776 if (optind
< argc
&& dump_sects
!= NULL
)
10778 num_dump_sects
= num_cmdline_dump_sects
;
10779 if (num_cmdline_dump_sects
> 0)
10780 memcpy (dump_sects
, cmdline_dump_sects
, num_cmdline_dump_sects
);
10784 if (dump_sects
!= NULL
)
10786 if (cmdline_dump_sects
!= NULL
)
10787 free (cmdline_dump_sects
);