mirror of https://github.com/acidanthera/audk.git
MdeModulePkg-FPDT(3): Use SMM_FPDT_FUNCTION_GET_BOOT_RECORD_DATA_BY_OFFSET in FpdtDxe.
This patch enhance performance data SMM communication by using fixed SMM communication buffer. Update FpdtDxe to use fixed SMM communication buffer to get performance data by SMM_FPDT_FUNCTION_GET_BOOT_RECORD_DATA_BY_OFFSET API. This is designed to meet Microsoft WSMT table definition on FIXED_COMM_BUFFERS requirement. Cc: Liming Gao <liming.gao@intel.com> Cc: Feng Tian <feng.tian@intel.com> Cc: Laszlo Ersek <lersek@redhat.com> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Liming Gao <liming.gao@intel.com> Reviewed-by: Feng Tian <feng.tian@intel.com>
This commit is contained in:
parent
77a6e6c4f9
commit
d158ba675b
|
@ -5,7 +5,7 @@
|
||||||
for Firmware Basic Boot Performance Record and other boot performance records,
|
for Firmware Basic Boot Performance Record and other boot performance records,
|
||||||
and install FPDT to ACPI table.
|
and install FPDT to ACPI table.
|
||||||
|
|
||||||
Copyright (c) 2011 - 2015, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2011 - 2016, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
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
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -28,6 +28,7 @@
|
||||||
#include <Guid/FirmwarePerformance.h>
|
#include <Guid/FirmwarePerformance.h>
|
||||||
#include <Guid/EventGroup.h>
|
#include <Guid/EventGroup.h>
|
||||||
#include <Guid/EventLegacyBios.h>
|
#include <Guid/EventLegacyBios.h>
|
||||||
|
#include <Guid/PiSmmCommunicationRegionTable.h>
|
||||||
|
|
||||||
#include <Library/UefiBootServicesTableLib.h>
|
#include <Library/UefiBootServicesTableLib.h>
|
||||||
#include <Library/UefiRuntimeServicesTableLib.h>
|
#include <Library/UefiRuntimeServicesTableLib.h>
|
||||||
|
@ -337,6 +338,12 @@ InstallFirmwarePerformanceDataTable (
|
||||||
UINT8 *BootPerformanceData;
|
UINT8 *BootPerformanceData;
|
||||||
EFI_SMM_COMMUNICATION_PROTOCOL *Communication;
|
EFI_SMM_COMMUNICATION_PROTOCOL *Communication;
|
||||||
FIRMWARE_PERFORMANCE_VARIABLE PerformanceVariable;
|
FIRMWARE_PERFORMANCE_VARIABLE PerformanceVariable;
|
||||||
|
EDKII_PI_SMM_COMMUNICATION_REGION_TABLE *SmmCommRegionTable;
|
||||||
|
EFI_MEMORY_DESCRIPTOR *SmmCommMemRegion;
|
||||||
|
UINTN Index;
|
||||||
|
VOID *SmmBootRecordData;
|
||||||
|
UINTN SmmBootRecordDataSize;
|
||||||
|
UINTN ReservedMemSize;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Get AcpiTable Protocol.
|
// Get AcpiTable Protocol.
|
||||||
|
@ -351,40 +358,74 @@ InstallFirmwarePerformanceDataTable (
|
||||||
//
|
//
|
||||||
SmmBootRecordCommBuffer = NULL;
|
SmmBootRecordCommBuffer = NULL;
|
||||||
SmmCommData = NULL;
|
SmmCommData = NULL;
|
||||||
|
SmmBootRecordData = NULL;
|
||||||
|
SmmBootRecordDataSize = 0;
|
||||||
|
ReservedMemSize = 0;
|
||||||
Status = gBS->LocateProtocol (&gEfiSmmCommunicationProtocolGuid, NULL, (VOID **) &Communication);
|
Status = gBS->LocateProtocol (&gEfiSmmCommunicationProtocolGuid, NULL, (VOID **) &Communication);
|
||||||
if (!EFI_ERROR (Status)) {
|
if (!EFI_ERROR (Status)) {
|
||||||
//
|
//
|
||||||
// Initialize communicate buffer
|
// Initialize communicate buffer
|
||||||
|
// Get the prepared Reserved Memory Range
|
||||||
//
|
//
|
||||||
SmmBootRecordCommBuffer = AllocateZeroPool (SMM_BOOT_RECORD_COMM_SIZE);
|
Status = EfiGetSystemConfigurationTable (
|
||||||
ASSERT (SmmBootRecordCommBuffer != NULL);
|
&gEdkiiPiSmmCommunicationRegionTableGuid,
|
||||||
SmmCommBufferHeader = (EFI_SMM_COMMUNICATE_HEADER*)SmmBootRecordCommBuffer;
|
(VOID **) &SmmCommRegionTable
|
||||||
SmmCommData = (SMM_BOOT_RECORD_COMMUNICATE*)SmmCommBufferHeader->Data;
|
);
|
||||||
ZeroMem((UINT8*)SmmCommData, sizeof(SMM_BOOT_RECORD_COMMUNICATE));
|
if (!EFI_ERROR (Status)) {
|
||||||
|
ASSERT (SmmCommRegionTable != NULL);
|
||||||
CopyGuid (&SmmCommBufferHeader->HeaderGuid, &gEfiFirmwarePerformanceGuid);
|
SmmCommMemRegion = (EFI_MEMORY_DESCRIPTOR *) (SmmCommRegionTable + 1);
|
||||||
SmmCommBufferHeader->MessageLength = sizeof(SMM_BOOT_RECORD_COMMUNICATE);
|
for (Index = 0; Index < SmmCommRegionTable->NumberOfEntries; Index ++) {
|
||||||
CommSize = SMM_BOOT_RECORD_COMM_SIZE;
|
if (SmmCommMemRegion->Type == EfiConventionalMemory) {
|
||||||
|
break;
|
||||||
//
|
}
|
||||||
// Get the size of boot records.
|
SmmCommMemRegion = (EFI_MEMORY_DESCRIPTOR *) ((UINT8 *) SmmCommMemRegion + SmmCommRegionTable->DescriptorSize);
|
||||||
//
|
}
|
||||||
SmmCommData->Function = SMM_FPDT_FUNCTION_GET_BOOT_RECORD_SIZE;
|
ASSERT (Index < SmmCommRegionTable->NumberOfEntries);
|
||||||
SmmCommData->BootRecordData = NULL;
|
ASSERT (SmmCommMemRegion->PhysicalStart > 0);
|
||||||
Status = Communication->Communicate (Communication, SmmBootRecordCommBuffer, &CommSize);
|
ASSERT (SmmCommMemRegion->NumberOfPages > 0);
|
||||||
ASSERT_EFI_ERROR (Status);
|
ReservedMemSize = (UINTN) SmmCommMemRegion->NumberOfPages * EFI_PAGE_SIZE;
|
||||||
|
|
||||||
if (!EFI_ERROR (SmmCommData->ReturnStatus) && SmmCommData->BootRecordSize != 0) {
|
|
||||||
//
|
//
|
||||||
// Get all boot records
|
// Check enough reserved memory space
|
||||||
//
|
//
|
||||||
SmmCommData->Function = SMM_FPDT_FUNCTION_GET_BOOT_RECORD_DATA;
|
if (ReservedMemSize > SMM_BOOT_RECORD_COMM_SIZE) {
|
||||||
SmmCommData->BootRecordData = AllocateZeroPool(SmmCommData->BootRecordSize);
|
SmmBootRecordCommBuffer = (VOID *) (UINTN) SmmCommMemRegion->PhysicalStart;
|
||||||
ASSERT (SmmCommData->BootRecordData != NULL);
|
SmmCommBufferHeader = (EFI_SMM_COMMUNICATE_HEADER*)SmmBootRecordCommBuffer;
|
||||||
|
SmmCommData = (SMM_BOOT_RECORD_COMMUNICATE*)SmmCommBufferHeader->Data;
|
||||||
|
ZeroMem((UINT8*)SmmCommData, sizeof(SMM_BOOT_RECORD_COMMUNICATE));
|
||||||
|
|
||||||
|
CopyGuid (&SmmCommBufferHeader->HeaderGuid, &gEfiFirmwarePerformanceGuid);
|
||||||
|
SmmCommBufferHeader->MessageLength = sizeof(SMM_BOOT_RECORD_COMMUNICATE);
|
||||||
|
CommSize = SMM_BOOT_RECORD_COMM_SIZE;
|
||||||
|
|
||||||
Status = Communication->Communicate (Communication, SmmBootRecordCommBuffer, &CommSize);
|
//
|
||||||
ASSERT_EFI_ERROR (Status);
|
// Get the size of boot records.
|
||||||
ASSERT_EFI_ERROR(SmmCommData->ReturnStatus);
|
//
|
||||||
|
SmmCommData->Function = SMM_FPDT_FUNCTION_GET_BOOT_RECORD_SIZE;
|
||||||
|
SmmCommData->BootRecordData = NULL;
|
||||||
|
Status = Communication->Communicate (Communication, SmmBootRecordCommBuffer, &CommSize);
|
||||||
|
ASSERT_EFI_ERROR (Status);
|
||||||
|
|
||||||
|
if (!EFI_ERROR (SmmCommData->ReturnStatus) && SmmCommData->BootRecordSize != 0) {
|
||||||
|
//
|
||||||
|
// Get all boot records
|
||||||
|
//
|
||||||
|
SmmCommData->Function = SMM_FPDT_FUNCTION_GET_BOOT_RECORD_DATA_BY_OFFSET;
|
||||||
|
SmmBootRecordDataSize = SmmCommData->BootRecordSize;
|
||||||
|
SmmBootRecordData = AllocateZeroPool(SmmBootRecordDataSize);
|
||||||
|
ASSERT (SmmBootRecordData != NULL);
|
||||||
|
SmmCommData->BootRecordOffset = 0;
|
||||||
|
SmmCommData->BootRecordData = (VOID *) ((UINTN) SmmCommMemRegion->PhysicalStart + SMM_BOOT_RECORD_COMM_SIZE);
|
||||||
|
SmmCommData->BootRecordSize = ReservedMemSize - SMM_BOOT_RECORD_COMM_SIZE;
|
||||||
|
while (SmmCommData->BootRecordOffset < SmmBootRecordDataSize) {
|
||||||
|
Status = Communication->Communicate (Communication, SmmBootRecordCommBuffer, &CommSize);
|
||||||
|
ASSERT_EFI_ERROR (Status);
|
||||||
|
ASSERT_EFI_ERROR(SmmCommData->ReturnStatus);
|
||||||
|
CopyMem ((UINT8 *) SmmBootRecordData + SmmCommData->BootRecordOffset, SmmCommData->BootRecordData, SmmCommData->BootRecordSize);
|
||||||
|
SmmCommData->BootRecordOffset = SmmCommData->BootRecordOffset + SmmCommData->BootRecordSize;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -394,7 +435,7 @@ InstallFirmwarePerformanceDataTable (
|
||||||
//
|
//
|
||||||
BootPerformanceDataSize = sizeof (BOOT_PERFORMANCE_TABLE) + mBootRecordSize + PcdGet32 (PcdExtFpdtBootRecordPadSize);
|
BootPerformanceDataSize = sizeof (BOOT_PERFORMANCE_TABLE) + mBootRecordSize + PcdGet32 (PcdExtFpdtBootRecordPadSize);
|
||||||
if (SmmCommData != NULL) {
|
if (SmmCommData != NULL) {
|
||||||
BootPerformanceDataSize += SmmCommData->BootRecordSize;
|
BootPerformanceDataSize += SmmBootRecordDataSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
@ -430,14 +471,12 @@ InstallFirmwarePerformanceDataTable (
|
||||||
DEBUG ((EFI_D_INFO, "FPDT: ACPI Boot Performance Table address = 0x%x\n", mAcpiBootPerformanceTable));
|
DEBUG ((EFI_D_INFO, "FPDT: ACPI Boot Performance Table address = 0x%x\n", mAcpiBootPerformanceTable));
|
||||||
|
|
||||||
if (mAcpiBootPerformanceTable == NULL) {
|
if (mAcpiBootPerformanceTable == NULL) {
|
||||||
if (SmmCommData != NULL && SmmCommData->BootRecordData != NULL) {
|
if (SmmCommData != NULL && SmmBootRecordData != NULL) {
|
||||||
FreePool (SmmCommData->BootRecordData);
|
FreePool (SmmBootRecordData);
|
||||||
}
|
|
||||||
if (SmmBootRecordCommBuffer != NULL) {
|
|
||||||
FreePool (SmmBootRecordCommBuffer);
|
|
||||||
}
|
}
|
||||||
if (mAcpiS3PerformanceTable != NULL) {
|
if (mAcpiS3PerformanceTable != NULL) {
|
||||||
FreePages (mAcpiS3PerformanceTable, EFI_SIZE_TO_PAGES (sizeof (S3_PERFORMANCE_TABLE)));
|
FreePages (mAcpiS3PerformanceTable, EFI_SIZE_TO_PAGES (sizeof (S3_PERFORMANCE_TABLE)));
|
||||||
|
mAcpiS3PerformanceTable = NULL;
|
||||||
}
|
}
|
||||||
return EFI_OUT_OF_RESOURCES;
|
return EFI_OUT_OF_RESOURCES;
|
||||||
}
|
}
|
||||||
|
@ -457,17 +496,14 @@ InstallFirmwarePerformanceDataTable (
|
||||||
CopyMem (BootPerformanceData, mBootRecordBuffer, mBootRecordSize);
|
CopyMem (BootPerformanceData, mBootRecordBuffer, mBootRecordSize);
|
||||||
mAcpiBootPerformanceTable->Header.Length += mBootRecordSize;
|
mAcpiBootPerformanceTable->Header.Length += mBootRecordSize;
|
||||||
BootPerformanceData = BootPerformanceData + mBootRecordSize;
|
BootPerformanceData = BootPerformanceData + mBootRecordSize;
|
||||||
if (SmmCommData != NULL && SmmCommData->BootRecordData != NULL) {
|
if (SmmCommData != NULL && SmmBootRecordData != NULL) {
|
||||||
//
|
//
|
||||||
// Fill Boot records from SMM drivers.
|
// Fill Boot records from SMM drivers.
|
||||||
//
|
//
|
||||||
CopyMem (BootPerformanceData, SmmCommData->BootRecordData, SmmCommData->BootRecordSize);
|
CopyMem (BootPerformanceData, SmmBootRecordData, SmmBootRecordDataSize);
|
||||||
FreePool (SmmCommData->BootRecordData);
|
FreePool (SmmBootRecordData);
|
||||||
mAcpiBootPerformanceTable->Header.Length = (UINT32) (mAcpiBootPerformanceTable->Header.Length + SmmCommData->BootRecordSize);
|
mAcpiBootPerformanceTable->Header.Length = (UINT32) (mAcpiBootPerformanceTable->Header.Length + SmmBootRecordDataSize);
|
||||||
BootPerformanceData = BootPerformanceData + SmmCommData->BootRecordSize;
|
BootPerformanceData = BootPerformanceData + SmmBootRecordDataSize;
|
||||||
}
|
|
||||||
if (SmmBootRecordCommBuffer != NULL) {
|
|
||||||
FreePool (SmmBootRecordCommBuffer);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
|
@ -5,7 +5,7 @@
|
||||||
# for Firmware Basic Boot Performance Record and other boot performance records,
|
# for Firmware Basic Boot Performance Record and other boot performance records,
|
||||||
# and install FPDT to ACPI table.
|
# and install FPDT to ACPI table.
|
||||||
#
|
#
|
||||||
# Copyright (c) 2011 - 2014, Intel Corporation. All rights reserved.<BR>
|
# Copyright (c) 2011 - 2016, Intel Corporation. All rights reserved.<BR>
|
||||||
# This program and the accompanying materials
|
# This program and the accompanying materials
|
||||||
# are licensed and made available under the terms and conditions of the BSD License
|
# 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
|
# which accompanies this distribution. The full text of the license may be found at
|
||||||
|
@ -70,6 +70,7 @@
|
||||||
## SOMETIMES_CONSUMES ## UNDEFINED # StatusCode Data
|
## SOMETIMES_CONSUMES ## UNDEFINED # StatusCode Data
|
||||||
gEfiFirmwarePerformanceGuid
|
gEfiFirmwarePerformanceGuid
|
||||||
gFirmwarePerformanceS3PointerGuid ## PRODUCES ## UNDEFINED # SaveLockBox
|
gFirmwarePerformanceS3PointerGuid ## PRODUCES ## UNDEFINED # SaveLockBox
|
||||||
|
gEdkiiPiSmmCommunicationRegionTableGuid ## SOMETIMES_CONSUMES ## SystemTable
|
||||||
|
|
||||||
[Pcd]
|
[Pcd]
|
||||||
gEfiMdeModulePkgTokenSpaceGuid.PcdProgressCodeOsLoaderLoad ## CONSUMES
|
gEfiMdeModulePkgTokenSpaceGuid.PcdProgressCodeOsLoaderLoad ## CONSUMES
|
||||||
|
|
Loading…
Reference in New Issue