]> sourceware.org Git - newlib-cygwin.git/commitdiff
Fix potential memory leak in argz_replace
authorDavid Stacey <drstacey@tiscali.co.uk>
Wed, 27 May 2015 10:08:29 +0000 (12:08 +0200)
committerCorinna Vinschen <corinna@vinschen.de>
Wed, 27 May 2015 11:30:20 +0000 (13:30 +0200)
Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
newlib/ChangeLog
newlib/libc/argz/argz_replace.c

index a70fefea9988b8d61220583c2906114eadc1d3ac..d1b0afec863867c5620c43564213aa9162b50fc1 100644 (file)
@@ -1,3 +1,7 @@
+2015-05-27  David Stacey  <drstacey@tiscali.co.uk>
+
+       * libc/argz/argz_replace.c: Fix potential memory leak.
+
 2015-05-26  DJ Delorie  <dj@redhat.com>
 
        * libm/math/e_sqrt.c (__ieee754_sqrt): Don't truncate constant to
index cb01eaef5218a26d985ff941aee62af7a1b349a4..6bfd04b8a41f673d428fcf1e3ab455b5478d5f1f 100644 (file)
@@ -71,7 +71,10 @@ _DEFUN (argz_replace, (argz, argz_len, str, with, replace_count),
 
       /* reallocate argz, and copy over the new value. */
       if(!(*argz = (char *)realloc(*argz, new_argz_len)))
-        return ENOMEM;
+        {
+          free(new_argz);
+          return ENOMEM;
+        }
 
       memcpy(*argz, new_argz, new_argz_len);
       *argz_len = new_argz_len;
This page took 0.050171 seconds and 5 git commands to generate.