mirror of
				https://git.proxmox.com/git/mirror_edk2
				synced 2025-10-26 07:19:35 +00:00 
			
		
		
		
	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,13 +358,38 @@ 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,  | ||||||
|  |               (VOID **) &SmmCommRegionTable | ||||||
|  |               ); | ||||||
|  |     if (!EFI_ERROR (Status)) { | ||||||
|  |       ASSERT (SmmCommRegionTable != NULL); | ||||||
|  |       SmmCommMemRegion = (EFI_MEMORY_DESCRIPTOR *) (SmmCommRegionTable + 1); | ||||||
|  |       for (Index = 0; Index < SmmCommRegionTable->NumberOfEntries; Index ++) { | ||||||
|  |         if (SmmCommMemRegion->Type == EfiConventionalMemory) { | ||||||
|  |           break; | ||||||
|  |         } | ||||||
|  |         SmmCommMemRegion = (EFI_MEMORY_DESCRIPTOR *) ((UINT8 *) SmmCommMemRegion + SmmCommRegionTable->DescriptorSize); | ||||||
|  |       } | ||||||
|  |       ASSERT (Index < SmmCommRegionTable->NumberOfEntries); | ||||||
|  |       ASSERT (SmmCommMemRegion->PhysicalStart > 0); | ||||||
|  |       ASSERT (SmmCommMemRegion->NumberOfPages > 0); | ||||||
|  |       ReservedMemSize = (UINTN) SmmCommMemRegion->NumberOfPages * EFI_PAGE_SIZE; | ||||||
|  |      | ||||||
|  |       //
 | ||||||
|  |       // Check enough reserved memory space
 | ||||||
|  |       //
 | ||||||
|  |       if (ReservedMemSize > SMM_BOOT_RECORD_COMM_SIZE) { | ||||||
|  |         SmmBootRecordCommBuffer = (VOID *) (UINTN) SmmCommMemRegion->PhysicalStart; | ||||||
|         SmmCommBufferHeader = (EFI_SMM_COMMUNICATE_HEADER*)SmmBootRecordCommBuffer; |         SmmCommBufferHeader = (EFI_SMM_COMMUNICATE_HEADER*)SmmBootRecordCommBuffer; | ||||||
|         SmmCommData = (SMM_BOOT_RECORD_COMMUNICATE*)SmmCommBufferHeader->Data; |         SmmCommData = (SMM_BOOT_RECORD_COMMUNICATE*)SmmCommBufferHeader->Data; | ||||||
|         ZeroMem((UINT8*)SmmCommData, sizeof(SMM_BOOT_RECORD_COMMUNICATE)); |         ZeroMem((UINT8*)SmmCommData, sizeof(SMM_BOOT_RECORD_COMMUNICATE)); | ||||||
| @ -378,13 +410,22 @@ InstallFirmwarePerformanceDataTable ( | |||||||
|           //
 |           //
 | ||||||
|           // Get all boot records
 |           // Get all boot records
 | ||||||
|           //
 |           //
 | ||||||
|       SmmCommData->Function       = SMM_FPDT_FUNCTION_GET_BOOT_RECORD_DATA; |           SmmCommData->Function       = SMM_FPDT_FUNCTION_GET_BOOT_RECORD_DATA_BY_OFFSET; | ||||||
|       SmmCommData->BootRecordData = AllocateZeroPool(SmmCommData->BootRecordSize); |           SmmBootRecordDataSize       = SmmCommData->BootRecordSize; | ||||||
|       ASSERT (SmmCommData->BootRecordData != NULL); |           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); |             Status = Communication->Communicate (Communication, SmmBootRecordCommBuffer, &CommSize); | ||||||
|             ASSERT_EFI_ERROR (Status); |             ASSERT_EFI_ERROR (Status); | ||||||
|             ASSERT_EFI_ERROR(SmmCommData->ReturnStatus); |             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
	
	Block a user
	 Liming Gao
						Liming Gao