diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog index bdd910456..f39f69baa 100644 --- a/winsup/cygwin/ChangeLog +++ b/winsup/cygwin/ChangeLog @@ -1,3 +1,8 @@ +2009-01-23 Corinna Vinschen + + * smallprint.cc (__small_vsprintf): Use already available buffer tmp + in wfillin case. + 2009-01-22 Christopher Faylor * select.cc (peek_serial): Add hack to allow proper operation with diff --git a/winsup/cygwin/smallprint.cc b/winsup/cygwin/smallprint.cc index b646a9cee..0f307b0d2 100644 --- a/winsup/cygwin/smallprint.cc +++ b/winsup/cygwin/smallprint.cc @@ -195,18 +195,15 @@ __small_vsprintf (char *dst, const char *fmt, va_list ap) us = va_arg (ap, PUNICODE_STRING); wfillin: { - char *tmpbuf; - - if (!sys_wcstombs_alloc (&tmpbuf, HEAP_NOTHEAP, us->Buffer, - us->Length / sizeof (WCHAR))) + if (!sys_wcstombs (tmp, NT_MAX_PATH, us->Buffer, + us->Length / sizeof (WCHAR))) { s = "invalid UNICODE_STRING"; goto fillin; } - char *tmp = tmpbuf; - for (i = 0; *tmp && i < n; i++) - *dst++ = *tmp++; - free (tmpbuf); + char *t = tmp; + for (i = 0; *t && i < n; i++) + *dst++ = *t++; } break; default: