aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2020-08-05 17:38:26 +0930
committerAlan Modra <amodra@gmail.com>2020-08-05 17:40:02 +0930
commit787bbc56d895b452ebfe90bc2b1345ca825fa412 (patch)
tree7952b5be6fa8db4201d21ef6c2cd0742f06ebeac
parent0b97e818464a42305c8243a980a5c13967554fd9 (diff)
downloadbinutils-787bbc56d895b452ebfe90bc2b1345ca825fa412.zip
binutils-787bbc56d895b452ebfe90bc2b1345ca825fa412.tar.gz
binutils-787bbc56d895b452ebfe90bc2b1345ca825fa412.tar.bz2
Revert "PR26337, Malloc size error in objdump"
This reverts commit 0b97e818464a42305c8243a980a5c13967554fd9.
-rw-r--r--binutils/ChangeLog5
-rw-r--r--binutils/objdump.c7
2 files changed, 9 insertions, 3 deletions
diff --git a/binutils/ChangeLog b/binutils/ChangeLog
index a924ae2..0aab6a2 100644
--- a/binutils/ChangeLog
+++ b/binutils/ChangeLog
@@ -1,6 +1,11 @@
2020-08-05 Alan Modra <amodra@gmail.com>
PR 26337
+ * objdump.c (load_specific_debug_section): Revert last change.
+
+2020-08-05 Alan Modra <amodra@gmail.com>
+
+ PR 26337
* objdump.c (load_specific_debug_section): Don't malloc space for
section contents, use bfd_malloc_and_get_section.
diff --git a/binutils/objdump.c b/binutils/objdump.c
index 1b48cd3..79ef051 100644
--- a/binutils/objdump.c
+++ b/binutils/objdump.c
@@ -3545,7 +3545,6 @@ 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);
@@ -3558,20 +3557,22 @@ load_specific_debug_section (enum dwarf_section_display_enum debug,
alloced = amt = section->size + 1;
if (alloced != amt || alloced == 0)
{
+ section->start = NULL;
free_debug_section (debug);
printf (_("\nSection '%s' has an invalid size: %#llx.\n"),
sanitize_string (section->name),
(unsigned long long) section->size);
return FALSE;
}
- if (!bfd_malloc_and_get_section (abfd, sec, &contents))
+ section->start = contents = malloc (alloced);
+ if (section->start == NULL
+ || !bfd_get_full_section_contents (abfd, sec, &contents))
{
free_debug_section (debug);
printf (_("\nCan't get contents for section '%s'.\n"),
sanitize_string (section->name));
return FALSE;
}
- section->start = contents;
/* Ensure any string section has a terminating NUL. */
section->start[section->size] = 0;