binutils/
* dwarf.c (do_debug_addr, do_debug_cu_index): New global flags. (load_debug_info): Fix typo. (cu_tu_indexes_read, shndx_pool, shndx_pool_size, shndx_pool_used): New global variables. (prealloc_cu_tu_list, add_shndx_to_cu_tu_entry, end_cu_tu_entry) (process_cu_tu_index, load_cu_tu_indexes, find_cu_tu_set) (display_cu_index): New functions. (dwarf_select_sections_by_names): Add "debug_addr", "cu_index". Sort entries alphabetically. (dwarf_select_sections_all): Set do_debug_addr, do_debug_cu_index. (debug_displays): Add .debug_cu_index, .debug_tu_index. Clean up formatting. * dwarf.h (dwarf_section_display_enum): Add dwp_cu_index, dwp_tu_index. (do_debug_addr, do_debug_cu_index): New global flags. (find_cu_tu_set): New function declaration. * objdump.c (usage): Add --dwarf=addr, --dwarf=cu_index. * readelf.c (find_section_in_set): New function. (usage): Add --debug-dump=addr, --debug_dump=cu_index. (process_section_headers): Check do_debug_addr and do_debug_cu_index. (section_subset): New global variable. (load_debug_section): Restrict search to section subset. (display_debug_section): Add section index as paramter. Select subset of sections when dumping a .dwp file. Update caller.
This commit is contained in:
parent
c886f0b40c
commit
657d0d47ba
5 changed files with 326 additions and 50 deletions
|
@ -1,3 +1,30 @@
|
||||||
|
2012-10-23 Cary Coutant <ccoutant@google.com>
|
||||||
|
|
||||||
|
* dwarf.c (do_debug_addr, do_debug_cu_index): New global flags.
|
||||||
|
(load_debug_info): Fix typo.
|
||||||
|
(cu_tu_indexes_read, shndx_pool, shndx_pool_size, shndx_pool_used):
|
||||||
|
New global variables.
|
||||||
|
(prealloc_cu_tu_list, add_shndx_to_cu_tu_entry, end_cu_tu_entry)
|
||||||
|
(process_cu_tu_index, load_cu_tu_indexes, find_cu_tu_set)
|
||||||
|
(display_cu_index): New functions.
|
||||||
|
(dwarf_select_sections_by_names): Add "debug_addr", "cu_index".
|
||||||
|
Sort entries alphabetically.
|
||||||
|
(dwarf_select_sections_all): Set do_debug_addr, do_debug_cu_index.
|
||||||
|
(debug_displays): Add .debug_cu_index, .debug_tu_index.
|
||||||
|
Clean up formatting.
|
||||||
|
* dwarf.h (dwarf_section_display_enum): Add dwp_cu_index,
|
||||||
|
dwp_tu_index.
|
||||||
|
(do_debug_addr, do_debug_cu_index): New global flags.
|
||||||
|
(find_cu_tu_set): New function declaration.
|
||||||
|
* objdump.c (usage): Add --dwarf=addr, --dwarf=cu_index.
|
||||||
|
* readelf.c (find_section_in_set): New function.
|
||||||
|
(usage): Add --debug-dump=addr, --debug_dump=cu_index.
|
||||||
|
(process_section_headers): Check do_debug_addr and do_debug_cu_index.
|
||||||
|
(section_subset): New global variable.
|
||||||
|
(load_debug_section): Restrict search to section subset.
|
||||||
|
(display_debug_section): Add section index as paramter. Select subset
|
||||||
|
of sections when dumping a .dwp file. Update caller.
|
||||||
|
|
||||||
2012-10-23 Tom Tromey <tromey@redhat.com>
|
2012-10-23 Tom Tromey <tromey@redhat.com>
|
||||||
|
|
||||||
* readelf.c (get_note_type): Handle NT_SIGINFO, NT_FILE.
|
* readelf.c (get_note_type): Handle NT_SIGINFO, NT_FILE.
|
||||||
|
|
289
binutils/dwarf.c
289
binutils/dwarf.c
|
@ -62,6 +62,8 @@ int do_gdb_index;
|
||||||
int do_trace_info;
|
int do_trace_info;
|
||||||
int do_trace_abbrevs;
|
int do_trace_abbrevs;
|
||||||
int do_trace_aranges;
|
int do_trace_aranges;
|
||||||
|
int do_debug_addr;
|
||||||
|
int do_debug_cu_index;
|
||||||
int do_wide;
|
int do_wide;
|
||||||
|
|
||||||
int dwarf_cutoff_level = -1;
|
int dwarf_cutoff_level = -1;
|
||||||
|
@ -2313,7 +2315,7 @@ load_debug_info (void * file)
|
||||||
warned_about_missing_comp_units = FALSE;
|
warned_about_missing_comp_units = FALSE;
|
||||||
|
|
||||||
/* If we have already tried and failed to load the .debug_info
|
/* If we have already tried and failed to load the .debug_info
|
||||||
section then do not bother to repear the task. */
|
section then do not bother to repeat the task. */
|
||||||
if (num_debug_info_entries == DEBUG_INFO_UNAVAILABLE)
|
if (num_debug_info_entries == DEBUG_INFO_UNAVAILABLE)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
@ -5850,6 +5852,200 @@ display_gdb_index (struct dwarf_section *section,
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Collection of CU/TU section sets from .debug_cu_index and .debug_tu_index
|
||||||
|
sections. Each set is stored in SHNDX_POOL as a zero-terminated list of
|
||||||
|
section indexes comprising one set of debug sections from a .dwo file. */
|
||||||
|
|
||||||
|
int cu_tu_indexes_read = 0;
|
||||||
|
unsigned int *shndx_pool = NULL;
|
||||||
|
unsigned int shndx_pool_size = 0;
|
||||||
|
unsigned int shndx_pool_used = 0;
|
||||||
|
|
||||||
|
/* Pre-allocate enough space for the CU/TU sets needed. */
|
||||||
|
|
||||||
|
static void
|
||||||
|
prealloc_cu_tu_list (unsigned int nshndx)
|
||||||
|
{
|
||||||
|
if (shndx_pool == NULL)
|
||||||
|
{
|
||||||
|
shndx_pool_size = nshndx;
|
||||||
|
shndx_pool_used = 0;
|
||||||
|
shndx_pool = (unsigned int *) xcmalloc (shndx_pool_size,
|
||||||
|
sizeof (unsigned int));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
shndx_pool_size = shndx_pool_used + nshndx;
|
||||||
|
shndx_pool = (unsigned int *) xcrealloc (shndx_pool, shndx_pool_size,
|
||||||
|
sizeof (unsigned int));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
add_shndx_to_cu_tu_entry (unsigned int shndx)
|
||||||
|
{
|
||||||
|
if (shndx_pool_used >= shndx_pool_size)
|
||||||
|
{
|
||||||
|
error (_("Internal error: out of space in the shndx pool.\n"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
shndx_pool [shndx_pool_used++] = shndx;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
end_cu_tu_entry (void)
|
||||||
|
{
|
||||||
|
if (shndx_pool_used >= shndx_pool_size)
|
||||||
|
{
|
||||||
|
error (_("Internal error: out of space in the shndx pool.\n"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
shndx_pool [shndx_pool_used++] = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Process a CU or TU index. If DO_DISPLAY is true, print the contents. */
|
||||||
|
|
||||||
|
static int
|
||||||
|
process_cu_tu_index (struct dwarf_section *section, int do_display)
|
||||||
|
{
|
||||||
|
unsigned char *phdr = section->start;
|
||||||
|
unsigned char *limit = phdr + section->size;
|
||||||
|
unsigned char *phash;
|
||||||
|
unsigned char *pindex;
|
||||||
|
unsigned char *ppool;
|
||||||
|
unsigned int version;
|
||||||
|
unsigned int nused;
|
||||||
|
unsigned int nslots;
|
||||||
|
unsigned int i;
|
||||||
|
|
||||||
|
version = byte_get (phdr, 4);
|
||||||
|
nused = byte_get (phdr + 8, 4);
|
||||||
|
nslots = byte_get (phdr + 12, 4);
|
||||||
|
phash = phdr + 16;
|
||||||
|
pindex = phash + nslots * 8;
|
||||||
|
ppool = pindex + nslots * 4;
|
||||||
|
|
||||||
|
if (!do_display)
|
||||||
|
prealloc_cu_tu_list((limit - ppool) / 4);
|
||||||
|
|
||||||
|
if (do_display)
|
||||||
|
{
|
||||||
|
printf (_("Contents of the %s section:\n\n"), section->name);
|
||||||
|
printf (_(" Version: %d\n"), version);
|
||||||
|
printf (_(" Number of used entries: %d\n"), nused);
|
||||||
|
printf (_(" Number of slots: %d\n\n"), nslots);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ppool > limit)
|
||||||
|
{
|
||||||
|
warn (_("Section %s too small for %d hash table entries\n"),
|
||||||
|
section->name, nslots);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < nslots; i++)
|
||||||
|
{
|
||||||
|
dwarf_vma signature_high;
|
||||||
|
dwarf_vma signature_low;
|
||||||
|
unsigned int j;
|
||||||
|
unsigned char *shndx_list;
|
||||||
|
unsigned int shndx;
|
||||||
|
char buf[64];
|
||||||
|
|
||||||
|
byte_get_64 (phash, &signature_high, &signature_low);
|
||||||
|
if (signature_high != 0 || signature_low != 0)
|
||||||
|
{
|
||||||
|
j = byte_get (pindex, 4);
|
||||||
|
shndx_list = ppool + j * 4;
|
||||||
|
if (do_display)
|
||||||
|
printf (_(" [%3d] Signature: 0x%s Sections: "),
|
||||||
|
i, dwarf_vmatoa64 (signature_high, signature_low,
|
||||||
|
buf, sizeof (buf)));
|
||||||
|
for (;;)
|
||||||
|
{
|
||||||
|
if (shndx_list >= limit)
|
||||||
|
{
|
||||||
|
warn (_("Section %s too small for shndx pool\n"),
|
||||||
|
section->name);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
shndx = byte_get (shndx_list, 4);
|
||||||
|
if (shndx == 0)
|
||||||
|
break;
|
||||||
|
if (do_display)
|
||||||
|
printf (" %d", shndx);
|
||||||
|
else
|
||||||
|
add_shndx_to_cu_tu_entry (shndx);
|
||||||
|
shndx_list += 4;
|
||||||
|
}
|
||||||
|
if (do_display)
|
||||||
|
printf ("\n");
|
||||||
|
else
|
||||||
|
end_cu_tu_entry ();
|
||||||
|
}
|
||||||
|
phash += 8;
|
||||||
|
pindex += 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (do_display)
|
||||||
|
printf ("\n");
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Load the CU and TU indexes if present. This will build a list of
|
||||||
|
section sets that we can use to associate a .debug_info.dwo section
|
||||||
|
with its associated .debug_abbrev.dwo section in a .dwp file. */
|
||||||
|
|
||||||
|
static void
|
||||||
|
load_cu_tu_indexes (void *file)
|
||||||
|
{
|
||||||
|
/* If we have already loaded (or tried to load) the CU and TU indexes
|
||||||
|
then do not bother to repeat the task. */
|
||||||
|
if (cu_tu_indexes_read)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (load_debug_section (dwp_cu_index, file))
|
||||||
|
process_cu_tu_index (&debug_displays [dwp_cu_index].section, 0);
|
||||||
|
|
||||||
|
if (load_debug_section (dwp_tu_index, file))
|
||||||
|
process_cu_tu_index (&debug_displays [dwp_tu_index].section, 0);
|
||||||
|
|
||||||
|
cu_tu_indexes_read = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Find the set of sections that includes section SHNDX. */
|
||||||
|
|
||||||
|
unsigned int *
|
||||||
|
find_cu_tu_set (void *file, unsigned int shndx)
|
||||||
|
{
|
||||||
|
unsigned int i;
|
||||||
|
|
||||||
|
load_cu_tu_indexes (file);
|
||||||
|
|
||||||
|
/* Find SHNDX in the shndx pool. */
|
||||||
|
for (i = 0; i < shndx_pool_used; i++)
|
||||||
|
if (shndx_pool [i] == shndx)
|
||||||
|
break;
|
||||||
|
|
||||||
|
if (i >= shndx_pool_used)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
/* Now backup to find the first entry in the set. */
|
||||||
|
while (i > 0 && shndx_pool [i - 1] != 0)
|
||||||
|
i--;
|
||||||
|
|
||||||
|
return shndx_pool + i;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Display a .debug_cu_index or .debug_tu_index section. */
|
||||||
|
|
||||||
|
static int
|
||||||
|
display_cu_index (struct dwarf_section *section, void *file ATTRIBUTE_UNUSED)
|
||||||
|
{
|
||||||
|
return process_cu_tu_index (section, 1);
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
display_debug_not_supported (struct dwarf_section *section,
|
display_debug_not_supported (struct dwarf_section *section,
|
||||||
void *file ATTRIBUTE_UNUSED)
|
void *file ATTRIBUTE_UNUSED)
|
||||||
|
@ -5938,13 +6134,16 @@ dwarf_select_sections_by_names (const char *names)
|
||||||
/* Please keep this table alpha- sorted. */
|
/* Please keep this table alpha- sorted. */
|
||||||
{ "Ranges", & do_debug_ranges, 1 },
|
{ "Ranges", & do_debug_ranges, 1 },
|
||||||
{ "abbrev", & do_debug_abbrevs, 1 },
|
{ "abbrev", & do_debug_abbrevs, 1 },
|
||||||
|
{ "addr", & do_debug_addr, 1 },
|
||||||
{ "aranges", & do_debug_aranges, 1 },
|
{ "aranges", & do_debug_aranges, 1 },
|
||||||
|
{ "cu_index", & do_debug_cu_index, 1 },
|
||||||
|
{ "decodedline", & do_debug_lines, FLAG_DEBUG_LINES_DECODED },
|
||||||
{ "frames", & do_debug_frames, 1 },
|
{ "frames", & do_debug_frames, 1 },
|
||||||
{ "frames-interp", & do_debug_frames_interp, 1 },
|
{ "frames-interp", & do_debug_frames_interp, 1 },
|
||||||
|
/* The special .gdb_index section. */
|
||||||
|
{ "gdb_index", & do_gdb_index, 1 },
|
||||||
{ "info", & do_debug_info, 1 },
|
{ "info", & do_debug_info, 1 },
|
||||||
{ "line", & do_debug_lines, FLAG_DEBUG_LINES_RAW }, /* For backwards compatibility. */
|
{ "line", & do_debug_lines, FLAG_DEBUG_LINES_RAW }, /* For backwards compatibility. */
|
||||||
{ "rawline", & do_debug_lines, FLAG_DEBUG_LINES_RAW },
|
|
||||||
{ "decodedline", & do_debug_lines, FLAG_DEBUG_LINES_DECODED },
|
|
||||||
{ "loc", & do_debug_loc, 1 },
|
{ "loc", & do_debug_loc, 1 },
|
||||||
{ "macro", & do_debug_macinfo, 1 },
|
{ "macro", & do_debug_macinfo, 1 },
|
||||||
{ "pubnames", & do_debug_pubnames, 1 },
|
{ "pubnames", & do_debug_pubnames, 1 },
|
||||||
|
@ -5952,9 +6151,8 @@ dwarf_select_sections_by_names (const char *names)
|
||||||
/* This entry is for compatability
|
/* This entry is for compatability
|
||||||
with earlier versions of readelf. */
|
with earlier versions of readelf. */
|
||||||
{ "ranges", & do_debug_aranges, 1 },
|
{ "ranges", & do_debug_aranges, 1 },
|
||||||
|
{ "rawline", & do_debug_lines, FLAG_DEBUG_LINES_RAW },
|
||||||
{ "str", & do_debug_str, 1 },
|
{ "str", & do_debug_str, 1 },
|
||||||
/* The special .gdb_index section. */
|
|
||||||
{ "gdb_index", & do_gdb_index, 1 },
|
|
||||||
/* These trace_* sections are used by Itanium VMS. */
|
/* These trace_* sections are used by Itanium VMS. */
|
||||||
{ "trace_abbrev", & do_trace_abbrevs, 1 },
|
{ "trace_abbrev", & do_trace_abbrevs, 1 },
|
||||||
{ "trace_aranges", & do_trace_aranges, 1 },
|
{ "trace_aranges", & do_trace_aranges, 1 },
|
||||||
|
@ -6083,73 +6281,78 @@ dwarf_select_sections_all (void)
|
||||||
do_trace_info = 1;
|
do_trace_info = 1;
|
||||||
do_trace_abbrevs = 1;
|
do_trace_abbrevs = 1;
|
||||||
do_trace_aranges = 1;
|
do_trace_aranges = 1;
|
||||||
|
do_debug_addr = 1;
|
||||||
|
do_debug_cu_index = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dwarf_section_display debug_displays[] =
|
struct dwarf_section_display debug_displays[] =
|
||||||
{
|
{
|
||||||
{ { ".debug_abbrev", ".zdebug_abbrev", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_abbrev", ".zdebug_abbrev", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_abbrev, &do_debug_abbrevs, 0 },
|
display_debug_abbrev, &do_debug_abbrevs, 0 },
|
||||||
{ { ".debug_aranges", ".zdebug_aranges", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_aranges", ".zdebug_aranges", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_aranges, &do_debug_aranges, 1 },
|
display_debug_aranges, &do_debug_aranges, 1 },
|
||||||
{ { ".debug_frame", ".zdebug_frame", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_frame", ".zdebug_frame", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_frames, &do_debug_frames, 1 },
|
display_debug_frames, &do_debug_frames, 1 },
|
||||||
{ { ".debug_info", ".zdebug_info", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_info", ".zdebug_info", NULL, NULL, 0, 0, abbrev },
|
||||||
display_debug_info, &do_debug_info, 1 },
|
display_debug_info, &do_debug_info, 1 },
|
||||||
{ { ".debug_line", ".zdebug_line", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_line", ".zdebug_line", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_lines, &do_debug_lines, 1 },
|
display_debug_lines, &do_debug_lines, 1 },
|
||||||
{ { ".debug_pubnames", ".zdebug_pubnames", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_pubnames", ".zdebug_pubnames", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_pubnames, &do_debug_pubnames, 0 },
|
display_debug_pubnames, &do_debug_pubnames, 0 },
|
||||||
{ { ".eh_frame", "", NULL, NULL, 0, 0, abbrev },
|
{ { ".eh_frame", "", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_frames, &do_debug_frames, 1 },
|
display_debug_frames, &do_debug_frames, 1 },
|
||||||
{ { ".debug_macinfo", ".zdebug_macinfo", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_macinfo", ".zdebug_macinfo", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_macinfo, &do_debug_macinfo, 0 },
|
display_debug_macinfo, &do_debug_macinfo, 0 },
|
||||||
{ { ".debug_macro", ".zdebug_macro", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_macro", ".zdebug_macro", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_macro, &do_debug_macinfo, 1 },
|
display_debug_macro, &do_debug_macinfo, 1 },
|
||||||
{ { ".debug_str", ".zdebug_str", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_str", ".zdebug_str", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_str, &do_debug_str, 0 },
|
display_debug_str, &do_debug_str, 0 },
|
||||||
{ { ".debug_loc", ".zdebug_loc", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_loc", ".zdebug_loc", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_loc, &do_debug_loc, 1 },
|
display_debug_loc, &do_debug_loc, 1 },
|
||||||
{ { ".debug_pubtypes", ".zdebug_pubtypes", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_pubtypes", ".zdebug_pubtypes", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_pubnames, &do_debug_pubtypes, 0 },
|
display_debug_pubnames, &do_debug_pubtypes, 0 },
|
||||||
{ { ".debug_ranges", ".zdebug_ranges", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_ranges", ".zdebug_ranges", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_ranges, &do_debug_ranges, 1 },
|
display_debug_ranges, &do_debug_ranges, 1 },
|
||||||
{ { ".debug_static_func", ".zdebug_static_func", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_static_func", ".zdebug_static_func", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_not_supported, NULL, 0 },
|
display_debug_not_supported, NULL, 0 },
|
||||||
{ { ".debug_static_vars", ".zdebug_static_vars", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_static_vars", ".zdebug_static_vars", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_not_supported, NULL, 0 },
|
display_debug_not_supported, NULL, 0 },
|
||||||
{ { ".debug_types", ".zdebug_types", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_types", ".zdebug_types", NULL, NULL, 0, 0, abbrev },
|
||||||
display_debug_types, &do_debug_info, 1 },
|
display_debug_types, &do_debug_info, 1 },
|
||||||
{ { ".debug_weaknames", ".zdebug_weaknames", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_weaknames", ".zdebug_weaknames", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_not_supported, NULL, 0 },
|
display_debug_not_supported, NULL, 0 },
|
||||||
{ { ".gdb_index", "", NULL, NULL, 0, 0, abbrev },
|
{ { ".gdb_index", "", NULL, NULL, 0, 0, 0 },
|
||||||
display_gdb_index, &do_gdb_index, 0 },
|
display_gdb_index, &do_gdb_index, 0 },
|
||||||
{ { ".trace_info", "", NULL, NULL, 0, 0, trace_abbrev },
|
{ { ".trace_info", "", NULL, NULL, 0, 0, trace_abbrev },
|
||||||
display_trace_info, &do_trace_info, 1 },
|
display_trace_info, &do_trace_info, 1 },
|
||||||
{ { ".trace_abbrev", "", NULL, NULL, 0, 0, abbrev },
|
{ { ".trace_abbrev", "", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_abbrev, &do_trace_abbrevs, 0 },
|
display_debug_abbrev, &do_trace_abbrevs, 0 },
|
||||||
{ { ".trace_aranges", "", NULL, NULL, 0, 0, abbrev },
|
{ { ".trace_aranges", "", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_aranges, &do_trace_aranges, 0 },
|
display_debug_aranges, &do_trace_aranges, 0 },
|
||||||
{ { ".debug_info.dwo", ".zdebug_info.dwo", NULL, NULL, 0, 0, abbrev_dwo },
|
{ { ".debug_info.dwo", ".zdebug_info.dwo", NULL, NULL, 0, 0, abbrev_dwo },
|
||||||
display_debug_info, &do_debug_info, 1 },
|
display_debug_info, &do_debug_info, 1 },
|
||||||
{ { ".debug_abbrev.dwo", ".zdebug_abbrev.dwo", NULL, NULL, 0, 0, abbrev_dwo },
|
{ { ".debug_abbrev.dwo", ".zdebug_abbrev.dwo", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_abbrev, &do_debug_abbrevs, 0 },
|
display_debug_abbrev, &do_debug_abbrevs, 0 },
|
||||||
{ { ".debug_types.dwo", ".zdebug_types.dwo", NULL, NULL, 0, 0, abbrev_dwo },
|
{ { ".debug_types.dwo", ".zdebug_types.dwo", NULL, NULL, 0, 0, abbrev_dwo },
|
||||||
display_debug_types, &do_debug_info, 1 },
|
display_debug_types, &do_debug_info, 1 },
|
||||||
{ { ".debug_line.dwo", ".zdebug_line.dwo", NULL, NULL, 0, 0, abbrev_dwo },
|
{ { ".debug_line.dwo", ".zdebug_line.dwo", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_lines, &do_debug_lines, 1 },
|
display_debug_lines, &do_debug_lines, 1 },
|
||||||
{ { ".debug_loc.dwo", ".zdebug_loc.dwo", NULL, NULL, 0, 0, abbrev_dwo },
|
{ { ".debug_loc.dwo", ".zdebug_loc.dwo", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_loc, &do_debug_loc, 1 },
|
display_debug_loc, &do_debug_loc, 1 },
|
||||||
{ { ".debug_macro.dwo", ".zdebug_macro.dwo",NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_macro.dwo", ".zdebug_macro.dwo", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_macro, &do_debug_macinfo, 1 },
|
display_debug_macro, &do_debug_macinfo, 1 },
|
||||||
{ { ".debug_macinfo.dwo", ".zdebug_macinfo.dwo",NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_macinfo.dwo", ".zdebug_macinfo.dwo", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_macinfo, &do_debug_macinfo, 0 },
|
display_debug_macinfo, &do_debug_macinfo, 0 },
|
||||||
{ { ".debug_str.dwo", ".zdebug_str.dwo", NULL, NULL, 0, 0, str_dwo },
|
{ { ".debug_str.dwo", ".zdebug_str.dwo", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_str, &do_debug_str, 1 },
|
display_debug_str, &do_debug_str, 1 },
|
||||||
{ { ".debug_str_offsets",".zdebug_str_offsets", NULL, NULL, 0, 0, abbrev },
|
{ { ".debug_str_offsets", ".zdebug_str_offsets", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_str_offsets, NULL, 0 },
|
display_debug_str_offsets, NULL, 0 },
|
||||||
{ { ".debug_str_offsets.dwo",".zdebug_str_offsets.dwo", NULL, NULL, 0, 0,
|
{ { ".debug_str_offsets.dwo", ".zdebug_str_offsets.dwo", NULL, NULL, 0, 0, 0 },
|
||||||
abbrev },
|
|
||||||
display_debug_str_offsets, NULL, 0 },
|
display_debug_str_offsets, NULL, 0 },
|
||||||
{ { ".debug_addr",".zdebug_addr", NULL, NULL, 0, 0, debug_addr },
|
{ { ".debug_addr", ".zdebug_addr", NULL, NULL, 0, 0, 0 },
|
||||||
display_debug_addr, NULL, 1 },
|
display_debug_addr, &do_debug_addr, 1 },
|
||||||
|
{ { ".debug_cu_index", "", NULL, NULL, 0, 0, 0 },
|
||||||
|
display_cu_index, &do_debug_cu_index, 0 },
|
||||||
|
{ { ".debug_tu_index", "", NULL, NULL, 0, 0, 0 },
|
||||||
|
display_cu_index, &do_debug_cu_index, 0 },
|
||||||
};
|
};
|
||||||
|
|
|
@ -143,6 +143,8 @@ enum dwarf_section_display_enum
|
||||||
str_index,
|
str_index,
|
||||||
str_index_dwo,
|
str_index_dwo,
|
||||||
debug_addr,
|
debug_addr,
|
||||||
|
dwp_cu_index,
|
||||||
|
dwp_tu_index,
|
||||||
max
|
max
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -218,6 +220,8 @@ extern int do_gdb_index;
|
||||||
extern int do_trace_info;
|
extern int do_trace_info;
|
||||||
extern int do_trace_abbrevs;
|
extern int do_trace_abbrevs;
|
||||||
extern int do_trace_aranges;
|
extern int do_trace_aranges;
|
||||||
|
extern int do_debug_addr;
|
||||||
|
extern int do_debug_cu_index;
|
||||||
extern int do_wide;
|
extern int do_wide;
|
||||||
|
|
||||||
extern int dwarf_cutoff_level;
|
extern int dwarf_cutoff_level;
|
||||||
|
@ -238,6 +242,8 @@ extern void dwarf_select_sections_by_names (const char *);
|
||||||
extern void dwarf_select_sections_by_letters (const char *);
|
extern void dwarf_select_sections_by_letters (const char *);
|
||||||
extern void dwarf_select_sections_all (void);
|
extern void dwarf_select_sections_all (void);
|
||||||
|
|
||||||
|
unsigned int * find_cu_tu_set (void *, unsigned int);
|
||||||
|
|
||||||
void * cmalloc (size_t, size_t);
|
void * cmalloc (size_t, size_t);
|
||||||
void * xcmalloc (size_t, size_t);
|
void * xcmalloc (size_t, size_t);
|
||||||
void * xcrealloc (void *, size_t, size_t);
|
void * xcrealloc (void *, size_t, size_t);
|
||||||
|
|
|
@ -216,7 +216,8 @@ usage (FILE *stream, int status)
|
||||||
-W[lLiaprmfFsoRt] or\n\
|
-W[lLiaprmfFsoRt] or\n\
|
||||||
--dwarf[=rawline,=decodedline,=info,=abbrev,=pubnames,=aranges,=macro,=frames,\n\
|
--dwarf[=rawline,=decodedline,=info,=abbrev,=pubnames,=aranges,=macro,=frames,\n\
|
||||||
=frames-interp,=str,=loc,=Ranges,=pubtypes,\n\
|
=frames-interp,=str,=loc,=Ranges,=pubtypes,\n\
|
||||||
=gdb_index,=trace_info,=trace_abbrev,=trace_aranges]\n\
|
=gdb_index,=trace_info,=trace_abbrev,=trace_aranges,\n\
|
||||||
|
=addr,=cu_index]\n\
|
||||||
Display DWARF info in the file\n\
|
Display DWARF info in the file\n\
|
||||||
-t, --syms Display the contents of the symbol table(s)\n\
|
-t, --syms Display the contents of the symbol table(s)\n\
|
||||||
-T, --dynamic-syms Display the contents of the dynamic symbol table\n\
|
-T, --dynamic-syms Display the contents of the dynamic symbol table\n\
|
||||||
|
|
|
@ -505,6 +505,24 @@ find_section_by_address (bfd_vma addr)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Return a pointer to section NAME, or NULL if no such section exists,
|
||||||
|
restricted to the list of sections given in SET. */
|
||||||
|
|
||||||
|
static Elf_Internal_Shdr *
|
||||||
|
find_section_in_set (const char * name, unsigned int * set)
|
||||||
|
{
|
||||||
|
unsigned int i;
|
||||||
|
|
||||||
|
if (set != NULL)
|
||||||
|
{
|
||||||
|
while ((i = *set++) > 0)
|
||||||
|
if (streq (SECTION_NAME (section_headers + i), name))
|
||||||
|
return section_headers + i;
|
||||||
|
}
|
||||||
|
|
||||||
|
return find_section (name);
|
||||||
|
}
|
||||||
|
|
||||||
/* Read an unsigned LEB128 encoded value from p. Set *PLEN to the number of
|
/* Read an unsigned LEB128 encoded value from p. Set *PLEN to the number of
|
||||||
bytes read. */
|
bytes read. */
|
||||||
|
|
||||||
|
@ -3244,7 +3262,8 @@ usage (FILE * stream)
|
||||||
-w[lLiaprmfFsoRt] or\n\
|
-w[lLiaprmfFsoRt] or\n\
|
||||||
--debug-dump[=rawline,=decodedline,=info,=abbrev,=pubnames,=aranges,=macro,=frames,\n\
|
--debug-dump[=rawline,=decodedline,=info,=abbrev,=pubnames,=aranges,=macro,=frames,\n\
|
||||||
=frames-interp,=str,=loc,=Ranges,=pubtypes,\n\
|
=frames-interp,=str,=loc,=Ranges,=pubtypes,\n\
|
||||||
=gdb_index,=trace_info,=trace_abbrev,=trace_aranges]\n\
|
=gdb_index,=trace_info,=trace_abbrev,=trace_aranges,\n\
|
||||||
|
=addr,=cu_index]\n\
|
||||||
Display the contents of DWARF2 debug sections\n"));
|
Display the contents of DWARF2 debug sections\n"));
|
||||||
fprintf (stream, _("\
|
fprintf (stream, _("\
|
||||||
--dwarf-depth=N Do not display DIEs at depth N or greater\n\
|
--dwarf-depth=N Do not display DIEs at depth N or greater\n\
|
||||||
|
@ -4671,7 +4690,8 @@ process_section_headers (FILE * file)
|
||||||
else if ((do_debugging || do_debug_info || do_debug_abbrevs
|
else if ((do_debugging || do_debug_info || do_debug_abbrevs
|
||||||
|| do_debug_lines || do_debug_pubnames || do_debug_pubtypes
|
|| do_debug_lines || do_debug_pubnames || do_debug_pubtypes
|
||||||
|| do_debug_aranges || do_debug_frames || do_debug_macinfo
|
|| do_debug_aranges || do_debug_frames || do_debug_macinfo
|
||||||
|| do_debug_str || do_debug_loc || do_debug_ranges)
|
|| do_debug_str || do_debug_loc || do_debug_ranges
|
||||||
|
|| do_debug_addr || do_debug_cu_index)
|
||||||
&& (const_strneq (name, ".debug_")
|
&& (const_strneq (name, ".debug_")
|
||||||
|| const_strneq (name, ".zdebug_")))
|
|| const_strneq (name, ".zdebug_")))
|
||||||
{
|
{
|
||||||
|
@ -4694,6 +4714,9 @@ process_section_headers (FILE * file)
|
||||||
|| (do_debug_macinfo && const_strneq (name, "macro"))
|
|| (do_debug_macinfo && const_strneq (name, "macro"))
|
||||||
|| (do_debug_str && const_strneq (name, "str"))
|
|| (do_debug_str && const_strneq (name, "str"))
|
||||||
|| (do_debug_loc && const_strneq (name, "loc"))
|
|| (do_debug_loc && const_strneq (name, "loc"))
|
||||||
|
|| (do_debug_addr && const_strneq (name, "addr"))
|
||||||
|
|| (do_debug_cu_index && const_strneq (name, "cu_index"))
|
||||||
|
|| (do_debug_cu_index && const_strneq (name, "tu_index"))
|
||||||
)
|
)
|
||||||
request_dump_bynumber (i, DEBUG_DUMP);
|
request_dump_bynumber (i, DEBUG_DUMP);
|
||||||
}
|
}
|
||||||
|
@ -10673,6 +10696,10 @@ load_specific_debug_section (enum dwarf_section_display_enum debug,
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* If this is not NULL, load_debug_section will only look for sections
|
||||||
|
within the list of sections given here. */
|
||||||
|
unsigned int *section_subset = NULL;
|
||||||
|
|
||||||
int
|
int
|
||||||
load_debug_section (enum dwarf_section_display_enum debug, void * file)
|
load_debug_section (enum dwarf_section_display_enum debug, void * file)
|
||||||
{
|
{
|
||||||
|
@ -10680,18 +10707,24 @@ load_debug_section (enum dwarf_section_display_enum debug, void * file)
|
||||||
Elf_Internal_Shdr * sec;
|
Elf_Internal_Shdr * sec;
|
||||||
|
|
||||||
/* Locate the debug section. */
|
/* Locate the debug section. */
|
||||||
sec = find_section (section->uncompressed_name);
|
sec = find_section_in_set (section->uncompressed_name, section_subset);
|
||||||
if (sec != NULL)
|
if (sec != NULL)
|
||||||
section->name = section->uncompressed_name;
|
section->name = section->uncompressed_name;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
sec = find_section (section->compressed_name);
|
sec = find_section_in_set (section->compressed_name, section_subset);
|
||||||
if (sec != NULL)
|
if (sec != NULL)
|
||||||
section->name = section->compressed_name;
|
section->name = section->compressed_name;
|
||||||
}
|
}
|
||||||
if (sec == NULL)
|
if (sec == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
/* If we're loading from a subset of sections, and we've loaded
|
||||||
|
a section matching this name before, it's likely that it's a
|
||||||
|
different one. */
|
||||||
|
if (section_subset != NULL)
|
||||||
|
free_debug_section (debug);
|
||||||
|
|
||||||
return load_specific_debug_section (debug, sec, (FILE *) file);
|
return load_specific_debug_section (debug, sec, (FILE *) file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10710,7 +10743,7 @@ free_debug_section (enum dwarf_section_display_enum debug)
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
display_debug_section (Elf_Internal_Shdr * section, FILE * file)
|
display_debug_section (int shndx, Elf_Internal_Shdr * section, FILE * file)
|
||||||
{
|
{
|
||||||
char * name = SECTION_NAME (section);
|
char * name = SECTION_NAME (section);
|
||||||
bfd_size_type length;
|
bfd_size_type length;
|
||||||
|
@ -10754,8 +10787,14 @@ display_debug_section (Elf_Internal_Shdr * section, FILE * file)
|
||||||
if (load_specific_debug_section ((enum dwarf_section_display_enum) i,
|
if (load_specific_debug_section ((enum dwarf_section_display_enum) i,
|
||||||
section, file))
|
section, file))
|
||||||
{
|
{
|
||||||
|
/* If this debug section is part of a CU/TU set in a .dwp file,
|
||||||
|
restrict load_debug_section to the sections in that set. */
|
||||||
|
section_subset = find_cu_tu_set (file, shndx);
|
||||||
|
|
||||||
result &= debug_displays[i].display (sec, file);
|
result &= debug_displays[i].display (sec, file);
|
||||||
|
|
||||||
|
section_subset = NULL;
|
||||||
|
|
||||||
if (secondary || (i != info && i != abbrev))
|
if (secondary || (i != info && i != abbrev))
|
||||||
free_debug_section ((enum dwarf_section_display_enum) i);
|
free_debug_section ((enum dwarf_section_display_enum) i);
|
||||||
}
|
}
|
||||||
|
@ -10827,7 +10866,7 @@ process_section_contents (FILE * file)
|
||||||
dump_section_as_strings (section, file);
|
dump_section_as_strings (section, file);
|
||||||
|
|
||||||
if (dump_sects[i] & DEBUG_DUMP)
|
if (dump_sects[i] & DEBUG_DUMP)
|
||||||
display_debug_section (section, file);
|
display_debug_section (i, section, file);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check to see if the user requested a
|
/* Check to see if the user requested a
|
||||||
|
|
Loading…
Reference in a new issue