This is the mail archive of the libc-alpha@sourceware.org mailing list for the glibc project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Re: [PATCH] Fix memory leaks in libio on allocation failure


On Mon, Sep 09, 2013 at 09:26:23PM +1000, Allan McRae wrote:
> ---
> 
> 2013-09-09  Allan McRae  <allan@archlinux.org>
> 
> 	[BZ #15892]
> 	* libio/memstream.c (open_memstream): Fix memory leak.
> 	* libio/wmemstream.c (open_wmemstream): Likewise.
> 
ok for me.
>  libio/memstream.c  | 5 ++++-
>  libio/wmemstream.c | 6 ++++--
>  2 files changed, 8 insertions(+), 3 deletions(-)
> 
> diff --git a/libio/memstream.c b/libio/memstream.c
> index 34534e2..3cb1bd7 100644
> --- a/libio/memstream.c
> +++ b/libio/memstream.c
> @@ -84,7 +84,10 @@ open_memstream (bufloc, sizeloc)
>  
>    buf = calloc (1, _IO_BUFSIZ);
>    if (buf == NULL)
> -    return NULL;
> +    {
> +      free (new_f);
> +      return NULL;
> +    }
>    _IO_init (&new_f->fp._sf._sbf._f, 0);
>    _IO_JUMPS ((struct _IO_FILE_plus *) &new_f->fp._sf._sbf) = &_IO_mem_jumps;
>    _IO_str_init_static_internal (&new_f->fp._sf, buf, _IO_BUFSIZ, buf);
> diff --git a/libio/wmemstream.c b/libio/wmemstream.c
> index 65738d4..fd7fe44 100644
> --- a/libio/wmemstream.c
> +++ b/libio/wmemstream.c
> @@ -85,8 +85,10 @@ open_wmemstream (bufloc, sizeloc)
>  
>    buf = calloc (1, _IO_BUFSIZ);
>    if (buf == NULL)
> -    return NULL;
> -
> +    {
> +      free (new_f);
> +      return NULL;
> +    }
>    _IO_no_init (&new_f->fp._sf._sbf._f, 0, 0, &new_f->wd, &_IO_wmem_jumps);
>    _IO_fwide (&new_f->fp._sf._sbf._f, 1);
>    _IO_wstr_init_static (&new_f->fp._sf._sbf._f, buf,
> -- 
> 1.8.4

-- 

Collapsed Backbone


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]