mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-06 12:09:26 +08:00
readelf looping in process_archive
With a crafted "negative" ar_hdr.ar_size it is possible to make readelf loop. This patch catches the overflow in a file offset calculation. * readelf.c (process_archive): Prevent endless loop.
This commit is contained in:
parent
aac88046e6
commit
4c83662712
@ -1,3 +1,7 @@
|
||||
2020-03-25 Alan Modra <amodra@gmail.com>
|
||||
|
||||
* readelf.c (process_archive): Prevent endless loop.
|
||||
|
||||
2020-03-24 H.J. Lu <hongjiu.lu@intel.com>
|
||||
|
||||
PR binutils/25708
|
||||
|
@ -20505,11 +20505,13 @@ process_archive (Filedata * filedata, bfd_boolean is_thin_archive)
|
||||
{
|
||||
free (name);
|
||||
archive_file_offset = arch.next_arhdr_offset;
|
||||
arch.next_arhdr_offset += archive_file_size;
|
||||
|
||||
filedata->file_name = qualified_name;
|
||||
if (! process_object (filedata))
|
||||
ret = FALSE;
|
||||
arch.next_arhdr_offset += archive_file_size;
|
||||
/* Stop looping with "negative" archive_file_size. */
|
||||
if (arch.next_arhdr_offset < archive_file_size)
|
||||
break;
|
||||
}
|
||||
|
||||
free (qualified_name);
|
||||
|
Loading…
Reference in New Issue
Block a user