mirror of
https://github.com/reactos/reactos.git
synced 2025-04-05 21:21:33 +00:00
Gregor Schneider <grschneider@gmail.com>
- Return error code "buffer overflow" instead of "buffer too small" and only do that if really necessary - Only append 0 if Length parameter allows to do so - Use uppercase letters Aleksey Bragin <aleksey@reactos.org> - Wrap it into PSEH, however commented out till a solution for the bootloader is found (linking freeldr with PSEH is not very beautiful). See issue #3583 for more details. svn path=/trunk/; revision=34995
This commit is contained in:
parent
0e213bbc00
commit
6e81d0c92b
1 changed files with 22 additions and 8 deletions
|
@ -1515,6 +1515,7 @@ RtlLargeIntegerToChar(
|
|||
IN ULONG Length,
|
||||
IN OUT PCHAR String)
|
||||
{
|
||||
NTSTATUS Status = STATUS_SUCCESS;
|
||||
ULONG Radix;
|
||||
CHAR temp[65];
|
||||
ULONGLONG v = Value->QuadPart;
|
||||
|
@ -1538,19 +1539,32 @@ RtlLargeIntegerToChar(
|
|||
if (i < 10)
|
||||
*tp = i + '0';
|
||||
else
|
||||
*tp = i + 'a' - 10;
|
||||
*tp = i + 'A' - 10;
|
||||
tp++;
|
||||
}
|
||||
|
||||
if ((ULONG)((ULONG_PTR)tp - (ULONG_PTR)temp) >= Length)
|
||||
return STATUS_BUFFER_TOO_SMALL;
|
||||
if ((ULONG)((ULONG_PTR)tp - (ULONG_PTR)temp) > Length)
|
||||
return STATUS_BUFFER_OVERFLOW;
|
||||
|
||||
sp = String;
|
||||
while (tp > temp)
|
||||
*sp++ = *--tp;
|
||||
*sp = 0;
|
||||
//_SEH_TRY
|
||||
{
|
||||
sp = String;
|
||||
while (tp > temp)
|
||||
*sp++ = *--tp;
|
||||
|
||||
return STATUS_SUCCESS;
|
||||
if((ULONG)((ULONG_PTR)sp - (ULONG_PTR)String) < Length)
|
||||
*sp = 0;
|
||||
}
|
||||
#if 0
|
||||
_SEH_HANDLE
|
||||
{
|
||||
/* Get the error code */
|
||||
Status = _SEH_GetExceptionCode();
|
||||
}
|
||||
_SEH_END;
|
||||
#endif
|
||||
|
||||
return Status;
|
||||
}
|
||||
|
||||
/*
|
||||
|
|
Loading…
Reference in a new issue