diff options
author | Doug Evans <dje@google.com> | 2009-08-16 17:32:35 +0000 |
---|---|---|
committer | Doug Evans <dje@google.com> | 2009-08-16 17:32:35 +0000 |
commit | 440ae135a822be30029115ff739e1d0e16a07858 (patch) | |
tree | cdc0f6d439043702947296f1d7a114a688fbca9a /bfd | |
parent | Sync config/ from GCC: (diff) | |
download | binutils-gdb-440ae135a822be30029115ff739e1d0e16a07858.tar.gz binutils-gdb-440ae135a822be30029115ff739e1d0e16a07858.tar.bz2 binutils-gdb-440ae135a822be30029115ff739e1d0e16a07858.zip |
* opncls.c (bfd_close): Until BFD_IN_MEMORY has an iovec,
at least don't leak memory.
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 5 | ||||
-rw-r--r-- | bfd/opncls.c | 16 |
2 files changed, 16 insertions, 5 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index ecca9ca072d..f9c4c6de077 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,8 @@ +2009-08-16 Doug Evans <dje@google.com> + + * opncls.c (bfd_close): Until BFD_IN_MEMORY has an iovec, + at least don't leak memory. + 2009-08-13 DJ Delorie <dj@redhat.com> * elf32-m32c.c (m32c_elf_relax_delete_bytes): Adjust symbol sizes diff --git a/bfd/opncls.c b/bfd/opncls.c index 6a4f319d315..799203065ce 100644 --- a/bfd/opncls.c +++ b/bfd/opncls.c @@ -703,12 +703,18 @@ bfd_close (bfd *abfd) if (! BFD_SEND (abfd, _close_and_cleanup, (abfd))) return FALSE; - /* FIXME: cagney/2004-02-15: Need to implement a BFD_IN_MEMORY io - vector. */ - if (!(abfd->flags & BFD_IN_MEMORY)) - ret = abfd->iovec->bclose (abfd); + if ((abfd->flags & BFD_IN_MEMORY) != 0) + { + /* FIXME: cagney/2004-02-15: Need to implement a BFD_IN_MEMORY io + vector. + Until that's done, at least don't leak memory. */ + struct bfd_in_memory *bim = abfd->iostream; + free (bim->buffer); + free (bim); + ret = TRUE; + } else - ret = TRUE; + ret = abfd->iovec->bclose (abfd); if (ret) _maybe_make_executable (abfd); |