* readelf.c (debug_str, debug_str_size): New.

(display_debug_abbrev): If no abbrevs were read, skip the CU.
	Call free_abbrevs.
	(read_and_display_addr): Handle DW_FORM_strp.
	(display_debug_info): Read .debug_str section if present,
	so that DW_FORM_strp can be handled.
	Fix test for non-existant .debug_abbrev section.
This commit is contained in:
Jakub Jelinek 2001-11-07 16:14:09 +00:00
parent a4a7d16f8b
commit ef5cdfc7dd
2 changed files with 57 additions and 1 deletions

View file

@ -1,3 +1,13 @@
2001-11-07 Jakub Jelinek <jakub@redhat.com>
* readelf.c (debug_str, debug_str_size): New.
(display_debug_abbrev): If no abbrevs were read, skip the CU.
Call free_abbrevs.
(read_and_display_addr): Handle DW_FORM_strp.
(display_debug_info): Read .debug_str section if present,
so that DW_FORM_strp can be handled.
Fix test for non-existant .debug_abbrev section.
2001-11-05 Jakub Jelinek <jakub@redhat.com>
* arlex.l: Accept `\' in filenames. Patch by <earl_chew@agilent.com>.

View file

@ -6278,6 +6278,9 @@ get_FORM_name (form)
}
}
static const char *debug_str;
static bfd_vma debug_str_size;
/* FIXME: There are better and more effiecint ways to handle
these structures. For now though, I just want something that
is simple to implement. */
@ -6528,6 +6531,9 @@ display_debug_abbrev (section, start, file)
{
start = process_abbrev_section (start, end);
if (first_abbrev == NULL)
continue;
printf (_(" Number TAG\n"));
for (entry = first_abbrev; entry; entry = entry->next)
@ -6546,6 +6552,8 @@ display_debug_abbrev (section, start, file)
get_FORM_name (attr->form));
}
}
free_abbrevs ();
}
while (start);
@ -6921,6 +6929,11 @@ read_and_display_attr (attribute, form, data, cu_offset, pointer_size)
data += pointer_size;
break;
case DW_FORM_strp:
uvalue = byte_get (data, /* offset_size */ 4);
data += /* offset_size */ 4;
break;
case DW_FORM_ref1:
case DW_FORM_flag:
case DW_FORM_data1:
@ -7014,6 +7027,15 @@ read_and_display_attr (attribute, form, data, cu_offset, pointer_size)
break;
case DW_FORM_strp:
if (debug_str == NULL)
warn (_("DW_FORM_strp used but no .debug_str section"));
else if (uvalue >= debug_str_size)
warn (_("DW_FORM_strp %lx points outside of .debug_str section"),
uvalue);
else
printf (" %s", debug_str + uvalue);
break;
case DW_FORM_indirect:
warn (_("Unable to handle FORM: %d"), form);
break;
@ -7189,6 +7211,24 @@ display_debug_info (section, start, file)
printf (_("The section %s contains:\n\n"), SECTION_NAME (section));
{
Elf32_Internal_Shdr * sec;
int i;
/* Locate the .debug_str section and read it. */
for (i = 0, sec = section_headers;
i < elf_header.e_shnum;
i ++, sec ++)
if (strcmp (SECTION_NAME (sec), ".debug_str") == 0 && sec->sh_size != 0)
{
debug_str = (const char *)
get_data (NULL, file, sec->sh_offset, sec->sh_size,
_("debug_str section data"));
debug_str_size = sec->sh_size;
break;
}
}
while (start < end)
{
DWARF2_External_CompUnit * external;
@ -7306,7 +7346,7 @@ display_debug_info (section, start, file)
if (strcmp (SECTION_NAME (sec), ".debug_abbrev") == 0)
break;
if (i == -1 || sec->sh_size == 0)
if (i == elf_header.e_shnum || sec->sh_size == 0)
{
warn (_("Unable to locate .debug_abbrev section!\n"));
return 0;
@ -7373,6 +7413,12 @@ display_debug_info (section, start, file)
}
}
if (debug_str != NULL)
{
free ((char *) debug_str);
debug_str = NULL;
}
printf ("\n");
return 1;