From 440ae135a822be30029115ff739e1d0e16a07858 Mon Sep 17 00:00:00 2001 From: Doug Evans Date: Sun, 16 Aug 2009 17:32:35 +0000 Subject: * opncls.c (bfd_close): Until BFD_IN_MEMORY has an iovec, at least don't leak memory. --- bfd/opncls.c | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) (limited to 'bfd/opncls.c') diff --git a/bfd/opncls.c b/bfd/opncls.c index 6a4f319d31..799203065c 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); -- cgit v1.2.1