Large memory allocation reading fuzzed 64-bit archive
Alan Modra
amodra@gmail.com
Thu Mar 5 00:47:00 GMT 2020
More information about the Binutils mailing list
Thu Mar 5 00:47:00 GMT 2020
- Previous message (by thread): Creating overlays with symbol duplication within one ELF file
- Next message (by thread): PR25629, objcopy : SIGSEGV in filter_symbols
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
This patch adds a sanity check for the size of an armap.
* archive64.c (_bfd_archive_64_bit_slurp_armap): Check parsed_size
against file size before allocating memory. Use bfd_alloc rather
than bfd_zalloc for carsym/strings memory.
diff --git a/bfd/archive64.c b/bfd/archive64.c
index d4b0c3cf0c..5e1443932c 100644
--- a/bfd/archive64.c
+++ b/bfd/archive64.c
@@ -47,6 +47,7 @@ _bfd_archive_64_bit_slurp_armap (bfd *abfd)
bfd_byte *raw_armap = NULL;
carsym *carsyms;
bfd_size_type amt;
+ ufile_ptr filesize;
ardata->symdefs = NULL;
@@ -76,6 +77,13 @@ _bfd_archive_64_bit_slurp_armap (bfd *abfd)
parsed_size = mapdata->parsed_size;
free (mapdata);
+ filesize = bfd_get_file_size (abfd);
+ if (filesize != 0 && parsed_size > filesize)
+ {
+ bfd_set_error (bfd_error_malformed_archive);
+ return FALSE;
+ }
+
if (bfd_bread (int_buf, 8, abfd) != 8)
{
if (bfd_get_error () != bfd_error_system_call)
@@ -102,7 +110,7 @@ _bfd_archive_64_bit_slurp_armap (bfd *abfd)
bfd_set_error (bfd_error_malformed_archive);
return FALSE;
}
- ardata->symdefs = (struct carsym *) bfd_zalloc (abfd, amt);
+ ardata->symdefs = (struct carsym *) bfd_alloc (abfd, amt);
if (ardata->symdefs == NULL)
return FALSE;
carsyms = ardata->symdefs;
--
Alan Modra
Australia Development Lab, IBM
- Previous message (by thread): Creating overlays with symbol duplication within one ELF file
- Next message (by thread): PR25629, objcopy : SIGSEGV in filter_symbols
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
More information about the Binutils mailing list