mirror of
https://github.com/reactos/reactos.git
synced 2025-02-23 08:55:19 +00:00
Fixed a few length calculation in NtEnumerateValueKey, which has resulted in a overflow, if the given buffer was too small.
svn path=/trunk/; revision=19227
This commit is contained in:
parent
ff83cbe019
commit
69b13c4f41
1 changed files with 3 additions and 5 deletions
|
@ -1135,18 +1135,16 @@ NtEnumerateValueKey(IN HANDLE KeyHandle,
|
|||
ROUND_UP(ValueFullInformation->DataOffset, sizeof(PVOID));
|
||||
ValueFullInformation->DataLength = ValueCell->DataSize & REG_DATA_SIZE_MASK;
|
||||
|
||||
if (Length - FIELD_OFFSET(KEY_VALUE_FULL_INFORMATION, Name[0]) <
|
||||
NameSize)
|
||||
if (Length < ValueFullInformation->DataOffset)
|
||||
{
|
||||
NameSize = Length - FIELD_OFFSET(KEY_VALUE_FULL_INFORMATION, Name[0]);
|
||||
DataSize = 0;
|
||||
Status = STATUS_BUFFER_OVERFLOW;
|
||||
CHECKPOINT;
|
||||
}
|
||||
else if (ROUND_UP(Length - FIELD_OFFSET(KEY_VALUE_FULL_INFORMATION,
|
||||
Name[0]) - NameSize, sizeof(PVOID)) < DataSize)
|
||||
else if (Length - ValueFullInformation->DataOffset < DataSize)
|
||||
{
|
||||
DataSize = ROUND_UP(Length - FIELD_OFFSET(KEY_VALUE_FULL_INFORMATION, Name[0]) - NameSize, sizeof(PVOID));
|
||||
DataSize = Length - ValueFullInformation->DataOffset;
|
||||
Status = STATUS_BUFFER_OVERFLOW;
|
||||
CHECKPOINT;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue