aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2020-08-14 20:19:39 +0930
committerAlan Modra <amodra@gmail.com>2020-08-14 21:31:22 +0930
commit82fcdb39388c6690699d41b7022b054c2de2554c (patch)
tree6b1b98eb38205802317aa297108d6a6b25533cd4
parentfc0efc4bd704f09f59dd87e354c734f902017094 (diff)
downloadgdb-82fcdb39388c6690699d41b7022b054c2de2554c.zip
gdb-82fcdb39388c6690699d41b7022b054c2de2554c.tar.gz
gdb-82fcdb39388c6690699d41b7022b054c2de2554c.tar.bz2
PR26388, objdump debug dump memory leaks
num_debug_info_entries is used not just as a count but also as a flag (DEBUG_INFO_UNAVAILABLE) after some errors. That means num_debug_info_entries can't be used when cleaning up malloc'd info. PR 26388 * dwarf.c (free_debug_memory): Free alloc_num_debug_info_entries of debug_information. Correct test of max_loc_offsets and max_range_lists. * rddbg.c (read_debugging_info): Free dhandle on error.
-rw-r--r--binutils/ChangeLog8
-rw-r--r--binutils/dwarf.c15
-rw-r--r--binutils/rddbg.c11
3 files changed, 21 insertions, 13 deletions
diff --git a/binutils/ChangeLog b/binutils/ChangeLog
index 223ffb0..7a6479b 100644
--- a/binutils/ChangeLog
+++ b/binutils/ChangeLog
@@ -1,5 +1,13 @@
2020-08-14 Alan Modra <amodra@gmail.com>
+ PR 26388
+ * dwarf.c (free_debug_memory): Free alloc_num_debug_info_entries
+ of debug_information. Correct test of max_loc_offsets and
+ max_range_lists.
+ * rddbg.c (read_debugging_info): Free dhandle on error.
+
+2020-08-14 Alan Modra <amodra@gmail.com>
+
* testsuite/binutils-all/mangled.s: Use dc.a rather than dc.d.
2020-08-13 Alan Modra <amodra@gmail.com>
diff --git a/binutils/dwarf.c b/binutils/dwarf.c
index d739230..5275994 100644
--- a/binutils/dwarf.c
+++ b/binutils/dwarf.c
@@ -10777,18 +10777,15 @@ free_debug_memory (void)
if (debug_information != NULL)
{
- if (num_debug_info_entries != DEBUG_INFO_UNAVAILABLE)
+ for (i = 0; i < alloc_num_debug_info_entries; i++)
{
- for (i = 0; i < num_debug_info_entries; i++)
+ if (debug_information [i].max_loc_offsets)
{
- if (!debug_information [i].max_loc_offsets)
- {
- free (debug_information [i].loc_offsets);
- free (debug_information [i].have_frame_base);
- }
- if (!debug_information [i].max_range_lists)
- free (debug_information [i].range_lists);
+ free (debug_information [i].loc_offsets);
+ free (debug_information [i].have_frame_base);
}
+ if (debug_information [i].max_range_lists)
+ free (debug_information [i].range_lists);
}
free (debug_information);
debug_information = NULL;
diff --git a/binutils/rddbg.c b/binutils/rddbg.c
index 930dbf7..f8ea2f9 100644
--- a/binutils/rddbg.c
+++ b/binutils/rddbg.c
@@ -43,7 +43,8 @@ static void free_saved_stabs (void);
pointer. */
void *
-read_debugging_info (bfd *abfd, asymbol **syms, long symcount, bfd_boolean no_messages)
+read_debugging_info (bfd *abfd, asymbol **syms, long symcount,
+ bfd_boolean no_messages)
{
void *dhandle;
bfd_boolean found;
@@ -54,13 +55,13 @@ read_debugging_info (bfd *abfd, asymbol **syms, long symcount, bfd_boolean no_me
if (! read_section_stabs_debugging_info (abfd, syms, symcount, dhandle,
&found))
- return NULL;
+ goto err_exit;
if (bfd_get_flavour (abfd) == bfd_target_aout_flavour)
{
if (! read_symbol_stabs_debugging_info (abfd, syms, symcount, dhandle,
&found))
- return NULL;
+ goto err_exit;
}
/* Try reading the COFF symbols if we didn't find any stabs in COFF
@@ -70,7 +71,7 @@ read_debugging_info (bfd *abfd, asymbol **syms, long symcount, bfd_boolean no_me
&& symcount > 0)
{
if (! parse_coff (abfd, syms, symcount, dhandle))
- return NULL;
+ goto err_exit;
found = TRUE;
}
@@ -79,6 +80,8 @@ read_debugging_info (bfd *abfd, asymbol **syms, long symcount, bfd_boolean no_me
if (! no_messages)
non_fatal (_("%s: no recognized debugging information"),
bfd_get_filename (abfd));
+ err_exit:
+ free (dhandle);
return NULL;
}