PrmPkg/HardwareAccessModuleConfigLib: Add initial library
Adds a PRM module configuration library for PrmSampleHardwareAccessModule that demonstrates marking a runtime MMIO range. In the case of this sample module, the range used is for HPET. Cc: Andrew Fish <afish@apple.com> Cc: Kang Gao <kang.gao@intel.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Cc: Michael Kubacki <michael.kubacki@microsoft.com> Cc: Leif Lindholm <leif@nuviainc.com> Cc: Benjamin You <benjamin.you@intel.com> Cc: Liu Yun <yun.y.liu@intel.com> Cc: Ankit Sinha <ankit.sinha@intel.com> Cc: Nate DeSimone <nathaniel.l.desimone@intel.com> Signed-off-by: Michael Kubacki <michael.kubacki@microsoft.com> Acked-by: Michael D Kinney <michael.d.kinney@intel.com> Acked-by: Liming Gao <gaoliming@byosoft.com.cn> Acked-by: Leif Lindholm <quic_llindhol@quicinc.com> Reviewed-by: Ankit Sinha <ankit.sinha@intel.com>
This commit is contained in:
		
				
					committed by
					
						![mergify[bot]](/avatar/e3df20cd7a67969c41a65f03bea54961?size=40) mergify[bot]
						mergify[bot]
					
				
			
			
				
	
			
			
			
						parent
						
							7217263514
						
					
				
				
					commit
					fec018624c
				
			| @@ -0,0 +1,104 @@ | ||||
| /** @file | ||||
|  | ||||
|   The boot services environment configuration library for the Hardware Access Sample PRM module. | ||||
|  | ||||
|   Copyright (c) Microsoft Corporation | ||||
|   SPDX-License-Identifier: BSD-2-Clause-Patent | ||||
|  | ||||
| **/ | ||||
|  | ||||
| #include <Library/BaseLib.h> | ||||
| #include <Library/BaseMemoryLib.h> | ||||
| #include <Library/DebugLib.h> | ||||
| #include <Library/MemoryAllocationLib.h> | ||||
| #include <Library/UefiBootServicesTableLib.h> | ||||
| #include <Protocol/PrmConfig.h> | ||||
| #include <Samples/PrmSampleHardwareAccessModule/Hpet.h> | ||||
|  | ||||
| STATIC EFI_HANDLE  mPrmConfigProtocolHandle; | ||||
|  | ||||
| // {0ef93ed7-14ae-425b-928f-b85a6213b57e} | ||||
| STATIC CONST EFI_GUID mPrmModuleGuid = {0x0ef93ed7, 0x14ae, 0x425b, {0x92, 0x8f, 0xb8, 0x5a, 0x62, 0x13, 0xb5, 0x7e}}; | ||||
|  | ||||
| /** | ||||
|   Constructor of the PRM configuration library. | ||||
|  | ||||
|   @param[in] ImageHandle        The image handle of the driver. | ||||
|   @param[in] SystemTable        The EFI System Table pointer. | ||||
|  | ||||
|   @retval EFI_SUCCESS           The shell command handlers were installed successfully. | ||||
|   @retval EFI_UNSUPPORTED       The shell level required was not found. | ||||
| **/ | ||||
| EFI_STATUS | ||||
| EFIAPI | ||||
| HardwareAccessModuleConfigLibConstructor ( | ||||
|   IN  EFI_HANDLE                    ImageHandle, | ||||
|   IN  EFI_SYSTEM_TABLE              *SystemTable | ||||
|   ) | ||||
| { | ||||
|   EFI_STATUS                        Status; | ||||
|   PRM_RUNTIME_MMIO_RANGES           *RuntimeMmioRanges; | ||||
|   PRM_CONFIG_PROTOCOL               *PrmConfigProtocol; | ||||
|  | ||||
|   RuntimeMmioRanges = NULL; | ||||
|   PrmConfigProtocol = NULL; | ||||
|  | ||||
|   /* | ||||
|     In this sample PRM module, the protocol describing this sample module's resources is simply | ||||
|     installed in the constructor. | ||||
|  | ||||
|     However, if some data is not available until later, this constructor could register a callback | ||||
|     on the dependency for the data to be available (e.g. ability to communicate with some device) | ||||
|     and then install the protocol. The requirement is that the protocol is installed before end of DXE. | ||||
|   */ | ||||
|  | ||||
|   // Runtime MMIO Ranges structure | ||||
|  | ||||
|   // Since this sample module only uses 1 runtime MMIO range, it can use the PRM_RUNTIME_MMIO_RANGES | ||||
|   // type directly without extending the size of the data buffer for additional MMIO ranges. | ||||
|   RuntimeMmioRanges = AllocateRuntimeZeroPool (sizeof (*RuntimeMmioRanges)); | ||||
|   ASSERT (RuntimeMmioRanges != NULL); | ||||
|   if (RuntimeMmioRanges == NULL) { | ||||
|     Status = EFI_OUT_OF_RESOURCES; | ||||
|     goto Done; | ||||
|   } | ||||
|  | ||||
|   // Allocate the PRM Configuration protocol structure for this PRM module | ||||
|   PrmConfigProtocol = AllocateZeroPool (sizeof (*PrmConfigProtocol)); | ||||
|   ASSERT (PrmConfigProtocol != NULL); | ||||
|   if (PrmConfigProtocol == NULL) { | ||||
|     Status = EFI_OUT_OF_RESOURCES; | ||||
|     goto Done; | ||||
|   } | ||||
|   CopyGuid (&PrmConfigProtocol->ModuleContextBuffers.ModuleGuid, &mPrmModuleGuid); | ||||
|  | ||||
|   // Populate the Runtime MMIO Ranges structure | ||||
|   RuntimeMmioRanges->Count = 1; | ||||
|   RuntimeMmioRanges->Range[0].PhysicalBaseAddress = HPET_BASE_ADDRESS; | ||||
|   RuntimeMmioRanges->Range[0].Length = HPET_RANGE_LENGTH; | ||||
|  | ||||
|   PrmConfigProtocol->ModuleContextBuffers.RuntimeMmioRanges = RuntimeMmioRanges; | ||||
|  | ||||
|   // | ||||
|   // Install the PRM Configuration Protocol for this module. This indicates the configuration | ||||
|   // library has completed resource initialization for the PRM module. | ||||
|   // | ||||
|   Status = gBS->InstallProtocolInterface ( | ||||
|                   &mPrmConfigProtocolHandle, | ||||
|                   &gPrmConfigProtocolGuid, | ||||
|                   EFI_NATIVE_INTERFACE, | ||||
|                   (VOID *) PrmConfigProtocol | ||||
|                   ); | ||||
|  | ||||
| Done: | ||||
|   if (EFI_ERROR (Status)) { | ||||
|     if (RuntimeMmioRanges != NULL) { | ||||
|       FreePool (RuntimeMmioRanges); | ||||
|     } | ||||
|     if (PrmConfigProtocol != NULL) { | ||||
|       FreePool (PrmConfigProtocol); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   return Status; | ||||
| } | ||||
| @@ -0,0 +1,39 @@ | ||||
| ## @file | ||||
| #  Sample PRM Configuration Library Instance | ||||
| # | ||||
| #  The PRM configuration library instance is responsible for initializing and setting the corresponding | ||||
| #  PRM module's configuration in the boot environment. | ||||
| # | ||||
| #  Copyright (c) Microsoft Corporation | ||||
| # | ||||
| #  SPDX-License-Identifier: BSD-2-Clause-Patent | ||||
| # | ||||
| ## | ||||
|  | ||||
| [Defines] | ||||
|   INF_VERSION         = 0x00010005 | ||||
|   BASE_NAME           = DxeHardwareAccessModuleConfigLib | ||||
|   FILE_GUID           = 88AA72FE-AE5A-435F-A267-E24D526C666C | ||||
|   MODULE_TYPE         = DXE_DRIVER | ||||
|   VERSION_STRING      = 1.0 | ||||
|   LIBRARY_CLASS       = NULL |DXE_DRIVER | ||||
|   CONSTRUCTOR         = HardwareAccessModuleConfigLibConstructor | ||||
|  | ||||
| [Sources] | ||||
|   DxeHardwareAccessModuleConfigLib.c | ||||
|  | ||||
| [Packages] | ||||
|   MdePkg/MdePkg.dec | ||||
|   MdeModulePkg/MdeModulePkg.dec | ||||
|   PrmPkg/PrmPkg.dec | ||||
|  | ||||
| [Protocols] | ||||
|   gPrmConfigProtocolGuid | ||||
|  | ||||
| [LibraryClasses] | ||||
|   BaseLib | ||||
|   BaseMemoryLib | ||||
|   DebugLib | ||||
|   MemoryAllocationLib | ||||
|   UefiBootServicesTableLib | ||||
|   UefiDriverEntryPoint | ||||
		Reference in New Issue
	
	Block a user