]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
nm.c free_lineno_cache
authorAlan Modra <amodra@gmail.com>
Sun, 8 Dec 2024 10:57:27 +0000 (21:27 +1030)
committerAlan Modra <amodra@gmail.com>
Thu, 12 Dec 2024 05:34:51 +0000 (16:04 +1030)
free_lineno_cache frees symbol and relocation data used when displaying
line number info for symbols (nm -l).  Currently that is done when
closing the bfd, but that's not ideal for archives since that results
in two bfds worth of memory in use.

* nm.c (display_rel_file): Call free_lineno_cache here..
(display_archive, display_file): ..not here.

binutils/nm.c

index 2546dc5105f1c83d569dc5cc9ab2dbc248fc6f7d..87e8305b3f8cfad7b27afc44cec78137a4018fc5 100644 (file)
@@ -1498,8 +1498,8 @@ display_rel_file (bfd *abfd, bfd *archive_bfd)
   else
     print_size_symbols (abfd, dynamic, symsizes, symcount, archive_bfd);
 
-  if (synthsyms)
-    free (synthsyms);
+  free_lineno_cache (abfd);
+  free (synthsyms);
   free (minisyms);
   free (symsizes);
 }
@@ -1602,7 +1602,6 @@ display_archive (bfd *file)
 
       if (last_arfile != NULL)
        {
-         free_lineno_cache (last_arfile);
          bfd_close (last_arfile);
          if (arfile == last_arfile)
            return;
@@ -1611,10 +1610,7 @@ display_archive (bfd *file)
     }
 
   if (last_arfile != NULL)
-    {
-      free_lineno_cache (last_arfile);
-      bfd_close (last_arfile);
-    }
+    bfd_close (last_arfile);
 }
 
 static bool
@@ -1656,7 +1652,6 @@ display_file (char *filename)
       retval = false;
     }
 
-  free_lineno_cache (file);
   if (!bfd_close (file))
     retval = false;