mirror of https://github.com/acidanthera/audk.git
Fix the issue that if OEM SMBIOS data includes string, it will cause SmbiosFldMiscTypeOEM buffer overflow.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@10569 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
7830363c37
commit
2788ff5116
|
@ -2,7 +2,7 @@
|
|||
Common filling functions used in translating Datahub's record
|
||||
to PI SMBIOS's record.
|
||||
|
||||
Copyright (c) 2009, Intel Corporation. All rights reserved.<BR>
|
||||
Copyright (c) 2009 - 2010, Intel Corporation. All rights reserved.<BR>
|
||||
This program and the accompanying materials
|
||||
are licensed and made available under the terms and conditions of the BSD License
|
||||
which accompanies this distribution. The full text of the license may be found at
|
||||
|
@ -158,6 +158,49 @@ SmbiosEnlargeStructureBuffer (
|
|||
return EFI_SUCCESS;
|
||||
}
|
||||
|
||||
/**
|
||||
Update the structure buffer of a structure node in SMBIOS database.
|
||||
The function lead the structure pointer for SMBIOS record changed.
|
||||
|
||||
@param StructureNode The structure node whose structure buffer is to be enlarged.
|
||||
@param NewRecord The new SMBIOS record.
|
||||
|
||||
**/
|
||||
VOID
|
||||
SmbiosUpdateStructureBuffer (
|
||||
IN OUT SMBIOS_STRUCTURE_NODE *StructureNode,
|
||||
IN EFI_SMBIOS_TABLE_HEADER *NewRecord
|
||||
)
|
||||
{
|
||||
EFI_SMBIOS_PROTOCOL *Smbios;
|
||||
EFI_STATUS Status;
|
||||
UINT8 CountOfString;
|
||||
|
||||
Smbios = GetSmbiosProtocol();
|
||||
ASSERT (Smbios != NULL);
|
||||
|
||||
Status = Smbios->Remove (Smbios, StructureNode->SmbiosHandle);
|
||||
ASSERT_EFI_ERROR (Status);
|
||||
|
||||
//
|
||||
// try to use original handle to enlarge the buffer.
|
||||
//
|
||||
Status = Smbios->Add (Smbios, NULL, &StructureNode->SmbiosHandle, NewRecord);
|
||||
ASSERT_EFI_ERROR (Status);
|
||||
|
||||
StructureNode->Structure = GetSmbiosBufferFromHandle (
|
||||
StructureNode->SmbiosHandle,
|
||||
StructureNode->SmbiosType,
|
||||
NULL
|
||||
);
|
||||
GetSmbiosStructureSize (
|
||||
StructureNode->Structure,
|
||||
&StructureNode->StructureSize,
|
||||
&CountOfString
|
||||
);
|
||||
return ;
|
||||
}
|
||||
|
||||
/**
|
||||
Fill a standard Smbios string field.
|
||||
|
||||
|
|
|
@ -2391,17 +2391,14 @@ SmbiosFldMiscTypeOEM (
|
|||
ASSERT_EFI_ERROR (Status);
|
||||
|
||||
if (StructureSize < RecordDataSize) {
|
||||
Status = SmbiosEnlargeStructureBuffer (
|
||||
//
|
||||
// Create new SMBIOS table entry
|
||||
//
|
||||
SmbiosUpdateStructureBuffer (
|
||||
StructureNode,
|
||||
((EFI_SMBIOS_TABLE_HEADER *)RecordData)->Length,
|
||||
StructureSize,
|
||||
RecordDataSize
|
||||
RecordData
|
||||
);
|
||||
if (EFI_ERROR (Status)) {
|
||||
return Status;
|
||||
}
|
||||
}
|
||||
|
||||
} else {
|
||||
//
|
||||
// Copy the entire data (including the Smbios structure header),
|
||||
// but preserve the handle that is already allocated.
|
||||
|
@ -2414,6 +2411,7 @@ SmbiosFldMiscTypeOEM (
|
|||
);
|
||||
StructureNode->Structure->Handle = Handle;
|
||||
StructureNode->StructureSize = RecordDataSize;
|
||||
}
|
||||
|
||||
if (NewRecordData != NULL) {
|
||||
FreePool (NewRecordData);
|
||||
|
|
|
@ -264,6 +264,20 @@ SmbiosEnlargeStructureBuffer (
|
|||
UINTN NewBufferSize
|
||||
);
|
||||
|
||||
/**
|
||||
Update the structure buffer of a structure node in SMBIOS database.
|
||||
The function lead the structure pointer for SMBIOS record changed.
|
||||
|
||||
@param StructureNode The structure node whose structure buffer is to be enlarged.
|
||||
@param NewRecord The new SMBIOS record.
|
||||
|
||||
**/
|
||||
VOID
|
||||
SmbiosUpdateStructureBuffer (
|
||||
IN OUT SMBIOS_STRUCTURE_NODE *StructureNode,
|
||||
IN EFI_SMBIOS_TABLE_HEADER *NewRecord
|
||||
);
|
||||
|
||||
/**
|
||||
Fill a standard Smbios string field.
|
||||
|
||||
|
|
Loading…
Reference in New Issue