]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
PR31692, objdump fails .debug_info size check
authorAlan Modra <amodra@gmail.com>
Thu, 2 May 2024 09:32:48 +0000 (19:02 +0930)
committerAlan Modra <amodra@gmail.com>
Thu, 2 May 2024 09:37:50 +0000 (19:07 +0930)
PR 31692
* objdump.c (load_specific_debug_section): Replace bfd_get_size
check with bfd_section_size_insane.  Call free_debug_section
after printing error messages.  Set section->start NULL when
freeing.

binutils/objdump.c

index 5acaa54929dbd4bbe37d7a2195ca698bfca603d0..3d70df470f290f7e4dc46cf80bc075f3015e6c14 100644 (file)
@@ -4286,6 +4286,7 @@ load_specific_debug_section (enum dwarf_section_display_enum debug,
       if (streq (section->filename, bfd_get_filename (abfd)))
        return true;
       free (section->start);
+      section->start = NULL;
     }
 
   section->filename = bfd_get_filename (abfd);
@@ -4297,13 +4298,12 @@ load_specific_debug_section (enum dwarf_section_display_enum debug,
   alloced = amt = section->size + 1;
   if (alloced != amt
       || alloced == 0
-      || (bfd_get_size (abfd) != 0 && alloced >= bfd_get_size (abfd)))
+      || bfd_section_size_insane (abfd, sec))
     {
-      section->start = NULL;
-      free_debug_section (debug);
       printf (_("\nSection '%s' has an invalid size: %#" PRIx64 ".\n"),
              sanitize_string (section->name),
              section->size);
+      free_debug_section (debug);
       return false;
     }
 
@@ -4345,9 +4345,9 @@ load_specific_debug_section (enum dwarf_section_display_enum debug,
 
   if (!ret)
     {
-      free_debug_section (debug);
       printf (_("\nCan't get contents for section '%s'.\n"),
              sanitize_string (section->name));
+      free_debug_section (debug);
       return false;
     }