]> git.proxmox.com Git - mirror_edk2.git/blame - FmpDevicePkg/FmpDevicePkg.dsc
FmpDevicePkg: Add YAML file for CI builds
[mirror_edk2.git] / FmpDevicePkg / FmpDevicePkg.dsc
CommitLineData
262b7a31
KM
1## @file\r
2# Firmware Management Protocol Device Package\r
3#\r
4# This package provides an implementation of a Firmware Management Protocol\r
5# instance that supports the update of firmware storage devices using UEFI\r
6# Capsules. The behavior of the Firmware Management Protocol instance is\r
7# customized using libraries and PCDs.\r
8#\r
9# Copyright (c) 2016, Microsoft Corporation. All rights reserved.<BR>\r
c40f7cc7 10# Copyright (c) 2018 - 2019, Intel Corporation. All rights reserved.<BR>\r
262b7a31 11#\r
bcef758c 12# SPDX-License-Identifier: BSD-2-Clause-Patent\r
262b7a31
KM
13#\r
14##\r
15\r
16[Defines]\r
17 PLATFORM_NAME = FmpDevicePkg\r
18 PLATFORM_GUID = 0af3d540-27c6-11e8-828b-f8597177a00a\r
19 PLATFORM_VERSION = 0.1\r
20 DSC_SPECIFICATION = 0x00010005\r
21 OUTPUT_DIRECTORY = Build/FmpDevicePkg\r
954175e5 22 SUPPORTED_ARCHITECTURES = IA32|X64|ARM|AARCH64\r
e23366d3 23 BUILD_TARGETS = DEBUG|RELEASE|NOOPT\r
262b7a31
KM
24 SKUID_IDENTIFIER = DEFAULT\r
25\r
26 #\r
27 # Define ESRT GUIDs for Firmware Management Protocol instances\r
28 #\r
ee48361c
SZ
29 DEFINE SYSTEM_FMP_ESRT_GUID = B461B3BD-E62A-4A71-841C-50BA4E500267\r
30 DEFINE DEVICE_FMP_ESRT_GUID = 226034C4-8B67-4536-8653-D6EE7CE5A316\r
262b7a31 31\r
11d35494
EJ
32 #\r
33 # TRUE - Build FmpDxe module for with storage access enabled\r
34 # FALSE - Build FmpDxe module for with storage access disabled\r
35 #\r
36 DEFINE DEVICE_FMP_STORAGE_ACCESS_ENABLE = TRUE\r
37\r
262b7a31
KM
38[LibraryClasses]\r
39 UefiDriverEntryPoint|MdePkg/Library/UefiDriverEntryPoint/UefiDriverEntryPoint.inf\r
262b7a31
KM
40 UefiBootServicesTableLib|MdePkg/Library/UefiBootServicesTableLib/UefiBootServicesTableLib.inf\r
41 UefiLib|MdePkg/Library/UefiLib/UefiLib.inf\r
42 UefiRuntimeServicesTableLib|MdePkg/Library/UefiRuntimeServicesTableLib/UefiRuntimeServicesTableLib.inf\r
262b7a31
KM
43 MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf\r
44 DevicePathLib|MdePkg/Library/UefiDevicePathLib/UefiDevicePathLib.inf\r
262b7a31
KM
45 BaseLib|MdePkg/Library/BaseLib/BaseLib.inf\r
46 BaseMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf\r
262b7a31
KM
47 PrintLib|MdePkg/Library/BasePrintLib/BasePrintLib.inf\r
48 DebugLib|MdePkg/Library/UefiDebugLibStdErr/UefiDebugLibStdErr.inf\r
49 DebugPrintErrorLevelLib|MdePkg/Library/BaseDebugPrintErrorLevelLib/BaseDebugPrintErrorLevelLib.inf\r
262b7a31 50 PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf\r
8bc648fe
MK
51!ifdef CONTINUOUS_INTEGRATION\r
52 BaseCryptLib|CryptoPkg/Library/BaseCryptLibNull/BaseCryptLibNull.inf\r
53!else\r
262b7a31 54 IntrinsicLib|CryptoPkg/Library/IntrinsicLib/IntrinsicLib.inf\r
8bc648fe 55 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLib.inf\r
262b7a31 56 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/BaseCryptLib.inf\r
8bc648fe 57!endif\r
262b7a31 58 FmpAuthenticationLib|SecurityPkg/Library/FmpAuthenticationLibPkcs7/FmpAuthenticationLibPkcs7.inf\r
262b7a31
KM
59 CapsuleUpdatePolicyLib|FmpDevicePkg/Library/CapsuleUpdatePolicyLibNull/CapsuleUpdatePolicyLibNull.inf\r
60 FmpPayloadHeaderLib|FmpDevicePkg/Library/FmpPayloadHeaderLibV1/FmpPayloadHeaderLibV1.inf\r
61 FmpDeviceLib|FmpDevicePkg/Library/FmpDeviceLibNull/FmpDeviceLibNull.inf\r
4ff8b6b1 62 TimerLib|MdePkg/Library/BaseTimerLibNullTemplate/BaseTimerLibNullTemplate.inf\r
262b7a31
KM
63\r
64[LibraryClasses.ARM, LibraryClasses.AARCH64]\r
65 #\r
66 # It is not possible to prevent the ARM compiler for generic intrinsic functions.\r
95d28836 67 # This library provides the intrinsic functions generate by a given compiler.\r
262b7a31
KM
68 # [LibraryClasses.ARM, LibraryClasses.AARCH64] and NULL mean link this library\r
69 # into all ARM and AARCH64 images.\r
70 #\r
71 NULL|ArmPkg/Library/CompilerIntrinsicsLib/CompilerIntrinsicsLib.inf\r
72\r
73 # Add support for stack protector\r
74 NULL|MdePkg/Library/BaseStackCheckLib/BaseStackCheckLib.inf\r
75\r
76[LibraryClasses.ARM]\r
77 ArmSoftFloatLib|ArmPkg/Library/ArmSoftFloatLib/ArmSoftFloatLib.inf\r
78\r
278c3d48
EJ
79[PcdsPatchableInModule]\r
80 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageTypeIdGuid|{0}\r
81\r
262b7a31
KM
82[Components]\r
83 #\r
84 # Libraries\r
85 #\r
86 FmpDevicePkg/Library/CapsuleUpdatePolicyLibNull/CapsuleUpdatePolicyLibNull.inf\r
c40f7cc7 87 FmpDevicePkg/Library/CapsuleUpdatePolicyLibOnProtocol/CapsuleUpdatePolicyLibOnProtocol.inf\r
262b7a31
KM
88 FmpDevicePkg/Library/FmpPayloadHeaderLibV1/FmpPayloadHeaderLibV1.inf\r
89 FmpDevicePkg/Library/FmpDeviceLibNull/FmpDeviceLibNull.inf\r
90 FmpDevicePkg/FmpDxe/FmpDxeLib.inf\r
91\r
92 #\r
93 # Modules\r
94 #\r
c40f7cc7
EJ
95 FmpDevicePkg/CapsuleUpdatePolicyDxe/CapsuleUpdatePolicyDxe.inf {\r
96 <LibraryClasses>\r
97 CapsuleUpdatePolicyLib|FmpDevicePkg/Library/CapsuleUpdatePolicyLibNull/CapsuleUpdatePolicyLibNull.inf\r
98 }\r
262b7a31
KM
99 FmpDevicePkg/FmpDxe/FmpDxe.inf {\r
100 <Defines>\r
101 #\r
ee48361c 102 # FILE_GUID is used as ESRT GUID\r
262b7a31 103 #\r
ee48361c 104 FILE_GUID = $(SYSTEM_FMP_ESRT_GUID)\r
278c3d48
EJ
105 <PcdsFixedAtBuild>\r
106 #\r
107 # Unicode name string that is used to populate FMP Image Descriptor for this capsule update module\r
108 #\r
109 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageIdName|L"Sample Firmware Device"\r
110 #\r
111 # Certificates used to authenticate capsule update image\r
112 #\r
113 !include BaseTools/Source/Python/Pkcs7Sign/TestRoot.cer.gFmpDevicePkgTokenSpaceGuid.PcdFmpDevicePkcs7CertBufferXdr.inc\r
114 <PcdsPatchableInModule>\r
115 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageTypeIdGuid|{GUID("$(SYSTEM_FMP_ESRT_GUID)")}\r
c40f7cc7
EJ
116 <LibraryClasses>\r
117 #\r
118 # Use CapsuleUpdatePolicyLib that calls the Capsule Update Policy Protocol.\r
119 # Depends on the CapsuleUpdatePolicyDxe module to produce the protocol.\r
120 # Required for FmpDxe modules that are intended to be platform independent.\r
121 #\r
122 CapsuleUpdatePolicyLib|FmpDevicePkg/Library/CapsuleUpdatePolicyLibOnProtocol/CapsuleUpdatePolicyLibOnProtocol.inf\r
262b7a31
KM
123 }\r
124\r
125 FmpDevicePkg/FmpDxe/FmpDxe.inf {\r
126 <Defines>\r
127 #\r
128 # FILE_GUID is used as ESRT GUID\r
129 #\r
ee48361c 130 FILE_GUID = $(DEVICE_FMP_ESRT_GUID)\r
11d35494
EJ
131 <PcdsFeatureFlag>\r
132 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceStorageAccessEnable|$(DEVICE_FMP_STORAGE_ACCESS_ENABLE)\r
278c3d48 133 <PcdsFixedAtBuild>\r
11d35494
EJ
134!if $(DEVICE_FMP_STORAGE_ACCESS_ENABLE) == FALSE\r
135 #\r
136 # Disable test key detection\r
137 #\r
138 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceTestKeySha256Digest|{0}\r
139!endif\r
278c3d48
EJ
140 #\r
141 # Unicode name string that is used to populate FMP Image Descriptor for this capsule update module\r
142 #\r
11d35494 143!if $(DEVICE_FMP_STORAGE_ACCESS_ENABLE) == TRUE\r
278c3d48 144 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageIdName|L"Sample Firmware Device"\r
11d35494
EJ
145!else\r
146 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageIdName|L"Sample Firmware Device No Storage Access"\r
147!endif\r
278c3d48
EJ
148 #\r
149 # Certificates used to authenticate capsule update image\r
150 #\r
151 !include BaseTools/Source/Python/Pkcs7Sign/TestRoot.cer.gFmpDevicePkgTokenSpaceGuid.PcdFmpDevicePkcs7CertBufferXdr.inc\r
152 <PcdsPatchableInModule>\r
153 gFmpDevicePkgTokenSpaceGuid.PcdFmpDeviceImageTypeIdGuid|{GUID("$(DEVICE_FMP_ESRT_GUID)")}\r
c40f7cc7
EJ
154 <LibraryClasses>\r
155 #\r
156 # Directly use a platform specific CapsuleUpdatePolicyLib instance.\r
157 # Only works for FmpDxe modules that are build from sources and included\r
158 # in a system firmware image.\r
159 #\r
160 CapsuleUpdatePolicyLib|FmpDevicePkg/Library/CapsuleUpdatePolicyLibNull/CapsuleUpdatePolicyLibNull.inf\r
262b7a31 161 }\r
4da45e20
SZ
162\r
163[BuildOptions]\r
164 *_*_*_CC_FLAGS = -D DISABLE_NEW_DEPRECATED_INTERFACES\r