PR26388, objdump debug dump memory leaks
authorAlan Modra <amodra@gmail.com>
Fri, 14 Aug 2020 10:49:39 +0000 (20:19 +0930)
committerAlan Modra <amodra@gmail.com>
Fri, 14 Aug 2020 12:01:22 +0000 (21:31 +0930)
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.

binutils/ChangeLog
binutils/dwarf.c
binutils/rddbg.c

index 223ffb099561257c8f764d867de64b0d9ef03274..7a6479b008e1f7039077c25de8bb6a5a0d74249d 100644 (file)
@@ -1,3 +1,11 @@
+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.
index d739230a28efbf4145d4b717941fa0de79ed019d..5275994871849f5ab00de7ae6f8ea52dba5e1bba 100644 (file)
@@ -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;
index 930dbf71349bedcc2ecb58ffef3081476bc1973f..f8ea2f99afaa5a6f04c094bd59c3125962766279 100644 (file)
@@ -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;
     }