2 # Firmware Management Protocol Device Package
4 # This package provides an implementation of a Firmware Management Protocol
5 # instance that supports the update of firmware storage devices using UEFI
6 # Capsules. The behavior of the Firmware Management Protocol instance is
7 # customized using libraries and PCDs.
9 # Copyright (c) 2016, Microsoft Corporation. All rights reserved.<BR>
10 # Copyright (c) 2018 - 2019, Intel Corporation. All rights reserved.<BR>
11 # Copyright (c) 2020, Hewlett Packard Enterprise Development LP. All rights reserved.<BR>
13 # SPDX-License-Identifier: BSD-2-Clause-Patent
18 PLATFORM_NAME = FmpDevicePkg
19 PLATFORM_GUID = 0af3d540-27c6-11e8-828b-f8597177a00a
20 PLATFORM_VERSION = 0.1
21 DSC_SPECIFICATION = 0x00010005
22 OUTPUT_DIRECTORY = Build/FmpDevicePkg
23 SUPPORTED_ARCHITECTURES = IA32|X64|ARM|AARCH64|RISCV64
24 BUILD_TARGETS = DEBUG|RELEASE|NOOPT
25 SKUID_IDENTIFIER = DEFAULT
28 # Define ESRT GUIDs for Firmware Management Protocol instances
30 DEFINE SYSTEM_FMP_ESRT_GUID = B461B3BD-E62A-4A71-841C-50BA4E500267
31 DEFINE DEVICE_FMP_ESRT_GUID = 226034C4-8B67-4536-8653-D6EE7CE5A316
34 # TRUE - Build FmpDxe module for with storage access enabled
35 # FALSE - Build FmpDxe module for with storage access disabled
37 DEFINE DEVICE_FMP_STORAGE_ACCESS_ENABLE = TRUE
40 UefiDriverEntryPoint|MdePkg/Library/UefiDriverEntryPoint/UefiDriverEntryPoint.inf
41 UefiBootServicesTableLib|MdePkg/Library/UefiBootServicesTableLib/UefiBootServicesTableLib.inf
42 UefiLib|MdePkg/Library/UefiLib/UefiLib.inf
43 UefiRuntimeServicesTableLib|MdePkg/Library/UefiRuntimeServicesTableLib/UefiRuntimeServicesTableLib.inf
44 MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf
45 DevicePathLib|MdePkg/Library/UefiDevicePathLib/UefiDevicePathLib.inf
46 BaseLib|MdePkg/Library/BaseLib/BaseLib.inf
47 BaseMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf
48 PrintLib|MdePkg/Library/BasePrintLib/BasePrintLib.inf
49 DebugLib|MdePkg/Library/UefiDebugLibStdErr/UefiDebugLibStdErr.inf
50 DebugPrintErrorLevelLib|MdePkg/Library/BaseDebugPrintErrorLevelLib/BaseDebugPrintErrorLevelLib.inf
51 PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf
52 !ifdef CONTINUOUS_INTEGRATION
53 BaseCryptLib|CryptoPkg/Library/BaseCryptLibNull/BaseCryptLibNull.inf
55 IntrinsicLib|CryptoPkg/Library/IntrinsicLib/IntrinsicLib.inf
56 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLib.inf
57 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/BaseCryptLib.inf
59 FmpAuthenticationLib|SecurityPkg/Library/FmpAuthenticationLibPkcs7/FmpAuthenticationLibPkcs7.inf
60 CapsuleUpdatePolicyLib|FmpDevicePkg/Library/CapsuleUpdatePolicyLibNull/CapsuleUpdatePolicyLibNull.inf
61 FmpPayloadHeaderLib|FmpDevicePkg/Library/FmpPayloadHeaderLibV1/FmpPayloadHeaderLibV1.inf
62 FmpDeviceLib|FmpDevicePkg/Library/FmpDeviceLibNull/FmpDeviceLibNull.inf
63 TimerLib|MdePkg/Library/BaseTimerLibNullTemplate/BaseTimerLibNullTemplate.inf
65 [LibraryClasses.ARM, LibraryClasses.AARCH64]
67 # It is not possible to prevent the ARM compiler for generic intrinsic functions.
68 # This library provides the intrinsic functions generate by a given compiler.
69 # [LibraryClasses.ARM, LibraryClasses.AARCH64] and NULL mean link this library
70 # into all ARM and AARCH64 images.
72 NULL|ArmPkg/Library/CompilerIntrinsicsLib/CompilerIntrinsicsLib.inf
74 # Add support for stack protector
75 NULL|MdePkg/Library/BaseStackCheckLib/BaseStackCheckLib.inf
78 ArmSoftFloatLib|ArmPkg/Library/ArmSoftFloatLib/ArmSoftFloatLib.inf
80 [PcdsPatchableInModule]
81 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageTypeIdGuid|{0}
87 FmpDevicePkg/Library/CapsuleUpdatePolicyLibNull/CapsuleUpdatePolicyLibNull.inf
88 FmpDevicePkg/Library/CapsuleUpdatePolicyLibOnProtocol/CapsuleUpdatePolicyLibOnProtocol.inf
89 FmpDevicePkg/Library/FmpPayloadHeaderLibV1/FmpPayloadHeaderLibV1.inf
90 FmpDevicePkg/Library/FmpDeviceLibNull/FmpDeviceLibNull.inf
91 FmpDevicePkg/FmpDxe/FmpDxeLib.inf
96 FmpDevicePkg/CapsuleUpdatePolicyDxe/CapsuleUpdatePolicyDxe.inf {
98 CapsuleUpdatePolicyLib|FmpDevicePkg/Library/CapsuleUpdatePolicyLibNull/CapsuleUpdatePolicyLibNull.inf
100 FmpDevicePkg/FmpDxe/FmpDxe.inf {
103 # FILE_GUID is used as ESRT GUID
105 FILE_GUID = $(SYSTEM_FMP_ESRT_GUID)
108 # Unicode name string that is used to populate FMP Image Descriptor for this capsule update module
110 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageIdName|L"Sample Firmware Device"
112 # Certificates used to authenticate capsule update image
114 !include BaseTools/Source/Python/Pkcs7Sign/TestRoot.cer.gFmpDevicePkgTokenSpaceGuid.PcdFmpDevicePkcs7CertBufferXdr.inc
115 <PcdsPatchableInModule>
116 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageTypeIdGuid|{GUID("$(SYSTEM_FMP_ESRT_GUID)")}
119 # Use CapsuleUpdatePolicyLib that calls the Capsule Update Policy Protocol.
120 # Depends on the CapsuleUpdatePolicyDxe module to produce the protocol.
121 # Required for FmpDxe modules that are intended to be platform independent.
123 CapsuleUpdatePolicyLib|FmpDevicePkg/Library/CapsuleUpdatePolicyLibOnProtocol/CapsuleUpdatePolicyLibOnProtocol.inf
126 FmpDevicePkg/FmpDxe/FmpDxe.inf {
129 # FILE_GUID is used as ESRT GUID
131 FILE_GUID = $(DEVICE_FMP_ESRT_GUID)
133 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceStorageAccessEnable|$(DEVICE_FMP_STORAGE_ACCESS_ENABLE)
135 !if $(DEVICE_FMP_STORAGE_ACCESS_ENABLE) == FALSE
137 # Disable test key detection
139 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceTestKeySha256Digest|{0}
142 # Unicode name string that is used to populate FMP Image Descriptor for this capsule update module
144 !if $(DEVICE_FMP_STORAGE_ACCESS_ENABLE) == TRUE
145 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageIdName|L"Sample Firmware Device"
147 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageIdName|L"Sample Firmware Device No Storage Access"
150 # Certificates used to authenticate capsule update image
152 !include BaseTools/Source/Python/Pkcs7Sign/TestRoot.cer.gFmpDevicePkgTokenSpaceGuid.PcdFmpDevicePkcs7CertBufferXdr.inc
153 <PcdsPatchableInModule>
154 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageTypeIdGuid|{GUID("$(DEVICE_FMP_ESRT_GUID)")}
157 # Directly use a platform specific CapsuleUpdatePolicyLib instance.
158 # Only works for FmpDxe modules that are build from sources and included
159 # in a system firmware image.
161 CapsuleUpdatePolicyLib|FmpDevicePkg/Library/CapsuleUpdatePolicyLibNull/CapsuleUpdatePolicyLibNull.inf
165 *_*_*_CC_FLAGS = -D DISABLE_NEW_DEPRECATED_INTERFACES