mirror of
https://github.com/reactos/reactos.git
synced 2025-01-04 21:38:43 +00:00
This makes RtlUnicodeStringToInteger work like the win2k version. Basically
this function never checks the validity of the input string and only returns an error when the Base argument is set incorrectly. This fixes the bug while booting vmware with the pcnet card on. svn path=/trunk/; revision=9694
This commit is contained in:
parent
7d375e8c48
commit
0766c089ec
1 changed files with 20 additions and 7 deletions
|
@ -673,6 +673,13 @@ RtlPrefixUnicodeString(
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @implemented
|
* @implemented
|
||||||
|
*
|
||||||
|
* Note that regardless of success or failure status, we should leave the
|
||||||
|
* partial value in Value. An error is never returned based on the chars
|
||||||
|
* in the string.
|
||||||
|
*
|
||||||
|
* This function does check the base. Only 2, 8, 10, 16 are permitted,
|
||||||
|
* else STATUS_INVALID_PARAMETER is returned.
|
||||||
*/
|
*/
|
||||||
NTSTATUS
|
NTSTATUS
|
||||||
STDCALL
|
STDCALL
|
||||||
|
@ -686,10 +693,14 @@ RtlUnicodeStringToInteger(
|
||||||
ULONG i;
|
ULONG i;
|
||||||
ULONG Val;
|
ULONG Val;
|
||||||
BOOLEAN addneg = FALSE;
|
BOOLEAN addneg = FALSE;
|
||||||
|
NTSTATUS Status = STATUS_SUCCESS;
|
||||||
|
|
||||||
*Value = 0;
|
*Value = 0;
|
||||||
Str = String->Buffer;
|
Str = String->Buffer;
|
||||||
|
|
||||||
|
if( Base && Base != 2 && Base != 8 && Base != 10 && Base != 16 )
|
||||||
|
return STATUS_INVALID_PARAMETER;
|
||||||
|
|
||||||
for (i = 0; i < String->Length / sizeof(WCHAR); i++)
|
for (i = 0; i < String->Length / sizeof(WCHAR); i++)
|
||||||
{
|
{
|
||||||
if (*Str == L'b')
|
if (*Str == L'b')
|
||||||
|
@ -723,21 +734,21 @@ RtlUnicodeStringToInteger(
|
||||||
}
|
}
|
||||||
else if ((*Str > L'1') && (Base == 2))
|
else if ((*Str > L'1') && (Base == 2))
|
||||||
{
|
{
|
||||||
return STATUS_INVALID_PARAMETER;
|
break;
|
||||||
}
|
}
|
||||||
else if (((*Str > L'7') || (*Str < L'0')) && (Base == 8))
|
else if (((*Str > L'7') || (*Str < L'0')) && (Base == 8))
|
||||||
{
|
{
|
||||||
return STATUS_INVALID_PARAMETER;
|
break;
|
||||||
}
|
}
|
||||||
else if (((*Str > L'9') || (*Str < L'0')) && (Base == 10))
|
else if (((*Str > L'9') || (*Str < L'0')) && (Base == 10))
|
||||||
{
|
{
|
||||||
return STATUS_INVALID_PARAMETER;
|
break;
|
||||||
}
|
}
|
||||||
else if ( ((*Str > L'9') || (*Str < L'0')) &&
|
else if ( ((*Str > L'9') || (*Str < L'0')) &&
|
||||||
((towupper (*Str) > L'F') || (towupper (*Str) < L'A')) &&
|
((towupper (*Str) > L'F') || (towupper (*Str) < L'A')) &&
|
||||||
(Base == 16))
|
(Base == 16))
|
||||||
{
|
{
|
||||||
return STATUS_INVALID_PARAMETER;
|
break;
|
||||||
}
|
}
|
||||||
Str++;
|
Str++;
|
||||||
}
|
}
|
||||||
|
@ -748,8 +759,10 @@ RtlUnicodeStringToInteger(
|
||||||
Base = 10;
|
Base = 10;
|
||||||
|
|
||||||
while (iswxdigit (*Str) &&
|
while (iswxdigit (*Str) &&
|
||||||
(Val = iswdigit (*Str) ? *Str - L'0' : (iswlower (*Str)
|
(Val =
|
||||||
? towupper (*Str) : *Str) - L'A' + 10) < Base)
|
iswdigit (*Str) ?
|
||||||
|
*Str - L'0' :
|
||||||
|
(towupper (*Str) - L'A' + 10)) < Base)
|
||||||
{
|
{
|
||||||
*Value = *Value * Base + Val;
|
*Value = *Value * Base + Val;
|
||||||
Str++;
|
Str++;
|
||||||
|
@ -758,7 +771,7 @@ RtlUnicodeStringToInteger(
|
||||||
if (addneg == TRUE)
|
if (addneg == TRUE)
|
||||||
*Value *= -1;
|
*Value *= -1;
|
||||||
|
|
||||||
return STATUS_SUCCESS;
|
return Status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue