summaryrefslogtreecommitdiff
path: root/bfd
diff options
context:
space:
mode:
authorAlan Modra <amodra@bigpond.net.au>2012-05-16 13:00:28 +0000
committerAlan Modra <amodra@bigpond.net.au>2012-05-16 13:00:28 +0000
commitc8e608e6205a1b27eac48270d941ba5c59a992ba (patch)
treec091af74b9a05a5692a372299bf9e0cf31ffd17f /bfd
parente95e822ba2156fb84fec5ad2650511406a0c0f26 (diff)
downloadbinutils-redhat-c8e608e6205a1b27eac48270d941ba5c59a992ba.tar.gz
* archive.c (_bfd_generic_read_ar_hdr_mag): Ensure sscanf
stops at end of ar_size field.
Diffstat (limited to 'bfd')
-rw-r--r--bfd/ChangeLog5
-rw-r--r--bfd/archive.c1
2 files changed, 6 insertions, 0 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog
index 34bee4f160..9db6ed35ae 100644
--- a/bfd/ChangeLog
+++ b/bfd/ChangeLog
@@ -1,5 +1,10 @@
2012-05-16 Alan Modra <amodra@gmail.com>
+ * archive.c (_bfd_generic_read_ar_hdr_mag): Ensure sscanf
+ stops at end of ar_size field.
+
+2012-05-16 Alan Modra <amodra@gmail.com>
+
PR ld/13962
PR ld/7023
* elf.c (bfd_section_from_shdr): Fail when .dynsym sh_info is
diff --git a/bfd/archive.c b/bfd/archive.c
index fd44f5405f..eb5f5ec0cf 100644
--- a/bfd/archive.c
+++ b/bfd/archive.c
@@ -471,6 +471,7 @@ _bfd_generic_read_ar_hdr_mag (bfd *abfd, const char *mag)
}
errno = 0;
+ hdr.ar_fmag[0] = 0;
if (sscanf (hdr.ar_size, "%" BFD_VMA_FMT "u", &parsed_size) != 1)
{
bfd_set_error (bfd_error_malformed_archive);