Skip to content

Commit

Permalink
[BZ #2072]
Browse files Browse the repository at this point in the history
	* stdio-common/printf_fp.c: Fix potential memory leaks for
	malloc'ed wbuffer isn't freed in error conditions.
  • Loading branch information
Ulrich Drepper committed Apr 25, 2006
1 parent 74ed115 commit c7df983
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 7 deletions.
4 changes: 4 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
2006-04-25 Ulrich Drepper <drepper@redhat.com>

[BZ #2072]
* stdio-common/printf_fp.c: Fix potential memory leaks for
malloc'ed wbuffer isn't freed in error conditions.

[BZ #2569]
* iconv/gconv_db.c (__gconv_release_step): Fix condition of assert
call.
Expand Down
34 changes: 27 additions & 7 deletions stdio-common/printf_fp.c
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,11 @@
{ \
register const int outc = (ch); \
if (putc (outc, fp) == EOF) \
return -1; \
{ \
if (buffer_malloced) \
free (wbuffer); \
return -1; \
} \
++done; \
} while (0)

Expand All @@ -83,7 +87,11 @@
if (len > 20) \
{ \
if (PUT (fp, wide ? (const char *) wptr : ptr, outlen) != outlen) \
return -1; \
{ \
if (buffer_malloced) \
free (wbuffer); \
return -1; \
} \
ptr += outlen; \
done += outlen; \
} \
Expand All @@ -102,7 +110,11 @@
do \
{ \
if (PAD (fp, ch, len) != len) \
return -1; \
{ \
if (buffer_malloced) \
free (wbuffer); \
return -1; \
} \
done += len; \
} \
while (0)
Expand Down Expand Up @@ -200,6 +212,11 @@ ___printf_fp (FILE *fp,
/* Nonzero if this is output on a wide character stream. */
int wide = info->wide;

/* Buffer in which we produce the output. */
wchar_t *wbuffer = NULL;
/* Flag whether wbuffer is malloc'ed or not. */
int buffer_malloced = 0;

auto wchar_t hack_digit (void);

wchar_t hack_digit (void)
Expand Down Expand Up @@ -790,8 +807,7 @@ ___printf_fp (FILE *fp,

{
int width = info->width;
wchar_t *wbuffer, *wstartp, *wcp;
int buffer_malloced;
wchar_t *wstartp, *wcp;
int chars_needed;
int expscale;
int intdig_max, intdig_no = 0;
Expand Down Expand Up @@ -1109,8 +1125,12 @@ ___printf_fp (FILE *fp,
buffer = (char *) malloc (2 + chars_needed + decimal_len
+ ngroups * thousands_sep_len);
if (buffer == NULL)
/* Signal an error to the caller. */
return -1;
{
/* Signal an error to the caller. */
if (buffer_malloced)
free (wbuffer);
return -1;
}
}
else
buffer = (char *) alloca (2 + chars_needed + decimal_len
Expand Down

0 comments on commit c7df983

Please sign in to comment.