From: jjohnstn Date: Mon, 12 Mar 2007 20:30:07 +0000 (+0000) Subject: 2007-03-12 Eric Blake X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=20db64f56520d9341ea09df3bc94a36141410413;p=pf3gnuchains%2Fpf3gnuchains3x.git 2007-03-12 Eric Blake * libc/stdio/fvwrite.c (__sfvwrite_r): Fix reentrancy. * libc/stdio/vasprintf.c (vasprintf, _vasprintf_r): Pass failed allocation to caller. * libc/stdio/asprintf.c (_asprintf_r, asprintf): Likewise. * libc/stdio/asiprintf.c (_asiprintf_r, asiprintf): Likewise. * libc/stdio/vasiprintf.c (vasiprintf, _vasiprintf_r): Likewise. --- diff --git a/newlib/ChangeLog b/newlib/ChangeLog index a2d6a63832..13e006f76c 100644 --- a/newlib/ChangeLog +++ b/newlib/ChangeLog @@ -1,3 +1,12 @@ +2007-03-12 Eric Blake + + * libc/stdio/fvwrite.c (__sfvwrite_r): Fix reentrancy. + * libc/stdio/vasprintf.c (vasprintf, _vasprintf_r): Pass failed + allocation to caller. + * libc/stdio/asprintf.c (_asprintf_r, asprintf): Likewise. + * libc/stdio/asiprintf.c (_asiprintf_r, asiprintf): Likewise. + * libc/stdio/vasiprintf.c (vasiprintf, _vasiprintf_r): Likewise. + 2007-02-23 Jeff Johnston * libm/math/w_pow.c: Fix typo in documentation comment. diff --git a/newlib/libc/stdio/asiprintf.c b/newlib/libc/stdio/asiprintf.c index e8e10bf38e..afb1f7c33d 100644 --- a/newlib/libc/stdio/asiprintf.c +++ b/newlib/libc/stdio/asiprintf.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1990 The Regents of the University of California. + * Copyright (c) 1990, 2007 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted @@ -57,8 +57,11 @@ _asiprintf_r(ptr, strp, fmt, va_alist) #endif ret = vfiprintf (&f, fmt, ap); va_end (ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return (ret); } @@ -79,7 +82,7 @@ asiprintf(strp, fmt, va_alist) int ret; va_list ap; FILE f; - + /* mark a zero-length reallocatable buffer */ f._flags = __SWR | __SSTR | __SMBF; f._bf._base = f._p = NULL; @@ -92,8 +95,11 @@ asiprintf(strp, fmt, va_alist) #endif ret = vfiprintf (&f, fmt, ap); va_end (ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return (ret); } diff --git a/newlib/libc/stdio/asprintf.c b/newlib/libc/stdio/asprintf.c index 928e8497a6..39536800be 100644 --- a/newlib/libc/stdio/asprintf.c +++ b/newlib/libc/stdio/asprintf.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1990 The Regents of the University of California. + * Copyright (c) 1990, 2007 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted @@ -57,8 +57,11 @@ _asprintf_r(ptr, strp, fmt, va_alist) #endif ret = vfprintf (&f, fmt, ap); va_end (ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return (ret); } @@ -79,7 +82,7 @@ asprintf(strp, fmt, va_alist) int ret; va_list ap; FILE f; - + /* mark a zero-length reallocatable buffer */ f._flags = __SWR | __SSTR | __SMBF; f._bf._base = f._p = NULL; @@ -92,8 +95,11 @@ asprintf(strp, fmt, va_alist) #endif ret = vfprintf (&f, fmt, ap); va_end (ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return (ret); } diff --git a/newlib/libc/stdio/fvwrite.c b/newlib/libc/stdio/fvwrite.c index ef461d31d8..21167c7f17 100644 --- a/newlib/libc/stdio/fvwrite.c +++ b/newlib/libc/stdio/fvwrite.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1990, 2006 The Regents of the University of California. + * Copyright (c) 1990, 2006, 2007 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted @@ -129,7 +129,7 @@ _DEFUN(__sfvwrite_r, (ptr, fp, uio), { if (len >= w && fp->_flags & __SMBF) { /* must be asprintf family */ - unsigned char *ptr; + unsigned char *str; int curpos = (fp->_p - fp->_bf._base); /* Choose a geometric growth factor to avoid quadratic realloc behavior, but use a rate less @@ -141,17 +141,16 @@ _DEFUN(__sfvwrite_r, (ptr, fp, uio), int newsize = fp->_bf._size * 3 / 2; if (newsize < curpos + len + 1) newsize = curpos + len + 1; - ptr = (unsigned char *)_realloc_r (_REENT, - fp->_bf._base, - newsize); - if (!ptr) + str = (unsigned char *)_realloc_r (ptr, fp->_bf._base, + newsize); + if (!str) { /* Free buffer which is no longer used. */ - _free_r (_REENT, fp->_bf._base); + _free_r (ptr, fp->_bf._base); goto err; } - fp->_bf._base = ptr; - fp->_p = ptr + curpos; + fp->_bf._base = str; + fp->_p = str + curpos; fp->_bf._size = newsize; w = len; fp->_w = newsize - curpos; diff --git a/newlib/libc/stdio/vasiprintf.c b/newlib/libc/stdio/vasiprintf.c index 721d6fb29e..72aa19d110 100644 --- a/newlib/libc/stdio/vasiprintf.c +++ b/newlib/libc/stdio/vasiprintf.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1990 The Regents of the University of California. + * Copyright (c) 1990, 2007 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted @@ -46,8 +46,11 @@ _DEFUN(vasiprintf, (strp, fmt, ap), f._bf._size = f._w = 0; f._file = -1; /* No file. */ ret = _vfiprintf_r (_REENT, &f, fmt, ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return ret; } @@ -68,8 +71,10 @@ _DEFUN(_vasiprintf_r, (ptr, strp, fmt, ap), f._bf._size = f._w = 0; f._file = -1; /* No file. */ ret = _vfiprintf_r (ptr, &f, fmt, ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return ret; } - diff --git a/newlib/libc/stdio/vasprintf.c b/newlib/libc/stdio/vasprintf.c index 43197d5824..2c8065cbca 100644 --- a/newlib/libc/stdio/vasprintf.c +++ b/newlib/libc/stdio/vasprintf.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 1990 The Regents of the University of California. + * Copyright (c) 1990, 2007 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted @@ -46,8 +46,11 @@ _DEFUN(vasprintf, (strp, fmt, ap), f._bf._size = f._w = 0; f._file = -1; /* No file. */ ret = _vfprintf_r (_REENT, &f, fmt, ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return ret; } @@ -68,8 +71,10 @@ _DEFUN(_vasprintf_r, (ptr, strp, fmt, ap), f._bf._size = f._w = 0; f._file = -1; /* No file. */ ret = _vfprintf_r (ptr, &f, fmt, ap); - *f._p = 0; - *strp = f._bf._base; + if (ret >= 0) + { + *f._p = 0; + *strp = f._bf._base; + } return ret; } -