mirror of https://github.com/acidanthera/audk.git
Use SMM_VARIABLE_COMMUNICATE_HEADER_SIZE instead of OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data).
Signed-off-by: Star Zeng <star.zeng@intel.com> Reviewed-by: Ting Ye <ting.ye@intel.com> git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@13993 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
d0ad204c5b
commit
3f5c168fa8
|
@ -445,7 +445,7 @@ SmmVariableHandler (
|
||||||
//
|
//
|
||||||
// SMRAM range check already covered before
|
// SMRAM range check already covered before
|
||||||
//
|
//
|
||||||
if (InfoSize > *CommBufferSize - OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data)) {
|
if (InfoSize > *CommBufferSize - SMM_VARIABLE_COMMUNICATE_HEADER_SIZE) {
|
||||||
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
||||||
Status = EFI_ACCESS_DENIED;
|
Status = EFI_ACCESS_DENIED;
|
||||||
goto EXIT;
|
goto EXIT;
|
||||||
|
@ -467,7 +467,7 @@ SmmVariableHandler (
|
||||||
//
|
//
|
||||||
// SMRAM range check already covered before
|
// SMRAM range check already covered before
|
||||||
//
|
//
|
||||||
if (InfoSize > *CommBufferSize - OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data)) {
|
if (InfoSize > *CommBufferSize - SMM_VARIABLE_COMMUNICATE_HEADER_SIZE) {
|
||||||
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
||||||
Status = EFI_ACCESS_DENIED;
|
Status = EFI_ACCESS_DENIED;
|
||||||
goto EXIT;
|
goto EXIT;
|
||||||
|
@ -498,7 +498,7 @@ SmmVariableHandler (
|
||||||
//
|
//
|
||||||
// SMRAM range check already covered before
|
// SMRAM range check already covered before
|
||||||
//
|
//
|
||||||
if (InfoSize > *CommBufferSize - OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data)) {
|
if (InfoSize > *CommBufferSize - SMM_VARIABLE_COMMUNICATE_HEADER_SIZE) {
|
||||||
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
||||||
Status = EFI_ACCESS_DENIED;
|
Status = EFI_ACCESS_DENIED;
|
||||||
goto EXIT;
|
goto EXIT;
|
||||||
|
@ -528,7 +528,7 @@ SmmVariableHandler (
|
||||||
|
|
||||||
case SMM_VARIABLE_FUNCTION_GET_STATISTICS:
|
case SMM_VARIABLE_FUNCTION_GET_STATISTICS:
|
||||||
VariableInfo = (VARIABLE_INFO_ENTRY *) SmmVariableFunctionHeader->Data;
|
VariableInfo = (VARIABLE_INFO_ENTRY *) SmmVariableFunctionHeader->Data;
|
||||||
InfoSize = *CommBufferSize - OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data);
|
InfoSize = *CommBufferSize - SMM_VARIABLE_COMMUNICATE_HEADER_SIZE;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Do not need to check SmmVariableFunctionHeader->Data in SMRAM here.
|
// Do not need to check SmmVariableFunctionHeader->Data in SMRAM here.
|
||||||
|
@ -542,7 +542,7 @@ SmmVariableHandler (
|
||||||
}
|
}
|
||||||
|
|
||||||
Status = SmmVariableGetStatistics (VariableInfo, &InfoSize);
|
Status = SmmVariableGetStatistics (VariableInfo, &InfoSize);
|
||||||
*CommBufferSize = InfoSize + OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data);
|
*CommBufferSize = InfoSize + SMM_VARIABLE_COMMUNICATE_HEADER_SIZE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -451,7 +451,7 @@ SmmVariableHandler (
|
||||||
//
|
//
|
||||||
// SMRAM range check already covered before
|
// SMRAM range check already covered before
|
||||||
//
|
//
|
||||||
if (InfoSize > *CommBufferSize - OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data)) {
|
if (InfoSize > *CommBufferSize - SMM_VARIABLE_COMMUNICATE_HEADER_SIZE) {
|
||||||
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
||||||
Status = EFI_ACCESS_DENIED;
|
Status = EFI_ACCESS_DENIED;
|
||||||
goto EXIT;
|
goto EXIT;
|
||||||
|
@ -473,7 +473,7 @@ SmmVariableHandler (
|
||||||
//
|
//
|
||||||
// SMRAM range check already covered before
|
// SMRAM range check already covered before
|
||||||
//
|
//
|
||||||
if (InfoSize > *CommBufferSize - OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data)) {
|
if (InfoSize > *CommBufferSize - SMM_VARIABLE_COMMUNICATE_HEADER_SIZE) {
|
||||||
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
||||||
Status = EFI_ACCESS_DENIED;
|
Status = EFI_ACCESS_DENIED;
|
||||||
goto EXIT;
|
goto EXIT;
|
||||||
|
@ -504,7 +504,7 @@ SmmVariableHandler (
|
||||||
//
|
//
|
||||||
// SMRAM range check already covered before
|
// SMRAM range check already covered before
|
||||||
//
|
//
|
||||||
if (InfoSize > *CommBufferSize - OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data)) {
|
if (InfoSize > *CommBufferSize - SMM_VARIABLE_COMMUNICATE_HEADER_SIZE) {
|
||||||
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
DEBUG ((EFI_D_ERROR, "Data size exceed communication buffer size limit!\n"));
|
||||||
Status = EFI_ACCESS_DENIED;
|
Status = EFI_ACCESS_DENIED;
|
||||||
goto EXIT;
|
goto EXIT;
|
||||||
|
@ -534,7 +534,7 @@ SmmVariableHandler (
|
||||||
|
|
||||||
case SMM_VARIABLE_FUNCTION_GET_STATISTICS:
|
case SMM_VARIABLE_FUNCTION_GET_STATISTICS:
|
||||||
VariableInfo = (VARIABLE_INFO_ENTRY *) SmmVariableFunctionHeader->Data;
|
VariableInfo = (VARIABLE_INFO_ENTRY *) SmmVariableFunctionHeader->Data;
|
||||||
InfoSize = *CommBufferSize - OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data);
|
InfoSize = *CommBufferSize - SMM_VARIABLE_COMMUNICATE_HEADER_SIZE;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Do not need to check SmmVariableFunctionHeader->Data in SMRAM here.
|
// Do not need to check SmmVariableFunctionHeader->Data in SMRAM here.
|
||||||
|
@ -548,7 +548,7 @@ SmmVariableHandler (
|
||||||
}
|
}
|
||||||
|
|
||||||
Status = SmmVariableGetStatistics (VariableInfo, &InfoSize);
|
Status = SmmVariableGetStatistics (VariableInfo, &InfoSize);
|
||||||
*CommBufferSize = InfoSize + OFFSET_OF (SMM_VARIABLE_COMMUNICATE_HEADER, Data);
|
*CommBufferSize = InfoSize + SMM_VARIABLE_COMMUNICATE_HEADER_SIZE;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
Loading…
Reference in New Issue