From: Alan Modra Date: Thu, 14 Dec 2006 02:59:25 +0000 (+0000) Subject: PR 3704 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=1fb41da414b7826e82d65cb644d00508d5b92458;p=binutils-gdb.git PR 3704 * bfdio.c (bfd_bread): Don't read past end of archive elements. --- diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 4a5528633b3..f15fdd35677 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2006-12-14 Alan Modra + + PR 3704 + * bfdio.c (bfd_bread): Don't read past end of archive elements. + 2006-12-12 Daniel Jacobowitz * doc/Makefile.am (bfd_TEXINFOS): Set. diff --git a/bfd/bfdio.c b/bfd/bfdio.c index 0aa82a9d2e2..0c720f61b07 100644 --- a/bfd/bfdio.c +++ b/bfd/bfdio.c @@ -1,7 +1,7 @@ /* Low-level I/O routines for BFDs. Copyright 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997, 1998, - 1999, 2000, 2001, 2002, 2003, 2004, 2005 + 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006 Free Software Foundation, Inc. Written by Cygnus Support. @@ -116,6 +116,15 @@ bfd_bread (void *ptr, bfd_size_type size, bfd *abfd) { size_t nread; + /* If this is an archive element, don't read past the end of + this element. */ + if (abfd->arelt_data != NULL) + { + size_t maxbytes = ((struct areltdata *) abfd->arelt_data)->parsed_size; + if (size > maxbytes) + size = maxbytes; + } + if ((abfd->flags & BFD_IN_MEMORY) != 0) { struct bfd_in_memory *bim;