Commit b7fcb956 authored by Alexandre Julliard's avatar Alexandre Julliard

ntdll: Avoid memory allocations in RtlUpcaseUnicodeString functions.

parent 0e97fe86
...@@ -1100,18 +1100,29 @@ NTSTATUS WINAPI RtlDowncaseUnicodeString( ...@@ -1100,18 +1100,29 @@ NTSTATUS WINAPI RtlDowncaseUnicodeString(
* NOTES * NOTES
* writes terminating 0 * writes terminating 0
*/ */
NTSTATUS WINAPI RtlUpcaseUnicodeStringToAnsiString( STRING *dst, NTSTATUS WINAPI RtlUpcaseUnicodeStringToAnsiString( STRING *ansi,
const UNICODE_STRING *src, const UNICODE_STRING *uni,
BOOLEAN doalloc ) BOOLEAN doalloc )
{ {
NTSTATUS ret; NTSTATUS ret = STATUS_SUCCESS;
UNICODE_STRING upcase; DWORD len = RtlUnicodeStringToAnsiSize( uni );
if (!(ret = RtlUpcaseUnicodeString( &upcase, src, TRUE ))) ansi->Length = len - 1;
if (doalloc)
{
ansi->MaximumLength = len;
if (!(ansi->Buffer = RtlAllocateHeap( GetProcessHeap(), 0, len )))
return STATUS_NO_MEMORY;
}
else if (ansi->MaximumLength < len)
{ {
ret = RtlUnicodeStringToAnsiString( dst, &upcase, doalloc ); if (!ansi->MaximumLength) return STATUS_BUFFER_OVERFLOW;
RtlFreeUnicodeString( &upcase ); ansi->Length = ansi->MaximumLength - 1;
ret = STATUS_BUFFER_OVERFLOW;
} }
RtlUpcaseUnicodeToMultiByteN( ansi->Buffer, ansi->Length, NULL, uni->Buffer, uni->Length );
ansi->Buffer[ansi->Length] = 0;
return ret; return ret;
} }
...@@ -1128,18 +1139,29 @@ NTSTATUS WINAPI RtlUpcaseUnicodeStringToAnsiString( STRING *dst, ...@@ -1128,18 +1139,29 @@ NTSTATUS WINAPI RtlUpcaseUnicodeStringToAnsiString( STRING *dst,
* NOTES * NOTES
* writes terminating 0 * writes terminating 0
*/ */
NTSTATUS WINAPI RtlUpcaseUnicodeStringToOemString( STRING *dst, NTSTATUS WINAPI RtlUpcaseUnicodeStringToOemString( STRING *oem,
const UNICODE_STRING *src, const UNICODE_STRING *uni,
BOOLEAN doalloc ) BOOLEAN doalloc )
{ {
NTSTATUS ret; NTSTATUS ret = STATUS_SUCCESS;
UNICODE_STRING upcase; DWORD len = RtlUnicodeStringToAnsiSize( uni );
if (!(ret = RtlUpcaseUnicodeString( &upcase, src, TRUE ))) oem->Length = len - 1;
if (doalloc)
{ {
ret = RtlUnicodeStringToOemString( dst, &upcase, doalloc ); oem->MaximumLength = len;
RtlFreeUnicodeString( &upcase ); if (!(oem->Buffer = RtlAllocateHeap( GetProcessHeap(), 0, len )))
return STATUS_NO_MEMORY;
} }
else if (oem->MaximumLength < len)
{
if (!oem->MaximumLength) return STATUS_BUFFER_OVERFLOW;
oem->Length = oem->MaximumLength - 1;
ret = STATUS_BUFFER_OVERFLOW;
}
RtlUpcaseUnicodeToOemN( oem->Buffer, oem->Length, NULL, uni->Buffer, uni->Length );
oem->Buffer[oem->Length] = 0;
return ret; return ret;
} }
...@@ -1160,38 +1182,22 @@ NTSTATUS WINAPI RtlUpcaseUnicodeStringToCountedOemString( STRING *oem, ...@@ -1160,38 +1182,22 @@ NTSTATUS WINAPI RtlUpcaseUnicodeStringToCountedOemString( STRING *oem,
const UNICODE_STRING *uni, const UNICODE_STRING *uni,
BOOLEAN doalloc ) BOOLEAN doalloc )
{ {
NTSTATUS ret; NTSTATUS ret = STATUS_SUCCESS;
UNICODE_STRING upcase; DWORD len = RtlUnicodeStringToOemSize( uni ) - 1;
WCHAR tmp[32];
upcase.Buffer = tmp;
upcase.MaximumLength = sizeof(tmp);
ret = RtlUpcaseUnicodeString( &upcase, uni, FALSE );
if (ret == STATUS_BUFFER_OVERFLOW) ret = RtlUpcaseUnicodeString( &upcase, uni, TRUE );
if (!ret) oem->Length = len;
if (doalloc)
{ {
DWORD len = RtlUnicodeStringToOemSize( &upcase ) - 1; oem->MaximumLength = len;
oem->Length = len; if (!(oem->Buffer = RtlAllocateHeap( GetProcessHeap(), 0, len ))) return STATUS_NO_MEMORY;
if (doalloc) }
{ else if (oem->MaximumLength < len)
oem->MaximumLength = len; {
if (!(oem->Buffer = RtlAllocateHeap( GetProcessHeap(), 0, len ))) ret = STATUS_BUFFER_OVERFLOW;
{ oem->Length = oem->MaximumLength;
ret = STATUS_NO_MEMORY; if (!oem->MaximumLength) return ret;
goto done;
}
}
else if (oem->MaximumLength < len)
{
ret = STATUS_BUFFER_OVERFLOW;
oem->Length = oem->MaximumLength;
if (!oem->MaximumLength) goto done;
}
RtlUnicodeToOemN( oem->Buffer, oem->Length, NULL, upcase.Buffer, upcase.Length );
done:
if (upcase.Buffer != tmp) RtlFreeUnicodeString( &upcase );
} }
RtlUpcaseUnicodeToOemN( oem->Buffer, oem->Length, NULL, uni->Buffer, uni->Length );
return ret; return ret;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment