2 # Cryptographic Library Package for UEFI Security Implementation.
3 # PEIM, DXE Driver, and SMM Driver with all crypto services enabled.
5 # Copyright (c) 2009 - 2021, Intel Corporation. All rights reserved.<BR>
6 # Copyright (c) 2020, Hewlett Packard Enterprise Development LP. All rights reserved.<BR>
7 # Copyright (c) 2022, Loongson Technology Corporation Limited. All rights reserved.<BR>
8 # SPDX-License-Identifier: BSD-2-Clause-Patent
12 ################################################################################
14 # Defines Section - statements that will be processed to create a Makefile.
16 ################################################################################
18 PLATFORM_NAME = CryptoPkg
19 PLATFORM_GUID = E1063286-6C8C-4c25-AEF0-67A9A5B6E6B6
20 PLATFORM_VERSION = 0.98
21 DSC_SPECIFICATION = 0x00010005
22 SUPPORTED_ARCHITECTURES = IA32|X64|ARM|AARCH64|RISCV64|LOONGARCH64
23 BUILD_TARGETS = DEBUG|RELEASE|NOOPT
24 SKUID_IDENTIFIER = DEFAULT
27 # Flavor of PEI, DXE, SMM modules to build.
28 # Must be one of ALL, NONE, MIN_PEI, MIN_DXE_MIN_SMM, TARGET_UINT_TESTS.
29 # Default is ALL that is used for package build verification.
30 # ALL - Build PEIM, DXE, and SMM drivers. Protocols and PPIs
31 # publish all services.
32 # NONE - Build PEIM, DXE, and SMM drivers. Protocols and PPIs
33 # publish no services. Used to verify compiler/linker
34 # optimizations are working correctly.
35 # MIN_PEI - Build PEIM with PPI that publishes minimum required
37 # MIN_DXE_MIN_SMM - Build DXE and SMM drivers with Protocols that publish
38 # minimum required services.
39 # TARGET_UNIT_TESTS - Build target-based unit tests
41 DEFINE CRYPTO_SERVICES = ALL
42 !if $(CRYPTO_SERVICES) IN "ALL NONE MIN_PEI MIN_DXE_MIN_SMM TARGET_UNIT_TESTS"
44 !error CRYPTO_SERVICES must be set to one of ALL NONE MIN_PEI MIN_DXE_MIN_SMM TARGET_UNIT_TESTS.
48 # Define different OUTPUT_DIRECTORY for each CRYPTO_SERVICES profile
50 !if $(CRYPTO_SERVICES) == ALL
51 OUTPUT_DIRECTORY = Build/CryptoPkg/All
53 !if $(CRYPTO_SERVICES) == NONE
54 OUTPUT_DIRECTORY = Build/CryptoPkg/None
56 !if $(CRYPTO_SERVICES) == MIN_PEI
57 OUTPUT_DIRECTORY = Build/CryptoPkg/MinPei
59 !if $(CRYPTO_SERVICES) == MIN_DXE_MIN_SMM
60 OUTPUT_DIRECTORY = Build/CryptoPkg/MinDxeMinSmm
62 !if $(CRYPTO_SERVICES) == TARGET_UNIT_TESTS
63 OUTPUT_DIRECTORY = Build/CryptoPkg/TagetUnitTests
67 # Define FILE_GUID names/values for CryptoPei, CryptopDxe, and CryptoSmm
68 # drivers that are linked with different OpensslLib instances
70 DEFINE PEI_CRYPTO_GUID = C693A250-6B36-49B9-B7F3-7283F8136A72
71 DEFINE PEI_STD_GUID = EBD49F5C-6D8B-40D1-A56D-9AFA485A8661
72 DEFINE PEI_FULL_GUID = D51FCE59-6860-49C0-9B35-984470735D17
73 DEFINE PEI_STD_ACCEL_GUID = DCC9CB49-7BE2-47C6-864E-6DCC932360F9
74 DEFINE PEI_FULL_ACCEL_GUID = A10827AD-7598-4955-B661-52EE2B62B057
75 DEFINE DXE_CRYPTO_GUID = 31C17C54-325D-47D5-8622-888098F10E44
76 DEFINE DXE_STD_GUID = ADD6D05A-52A2-437B-98E7-DBFDA89352CD
77 DEFINE DXE_FULL_GUID = AA83B296-F6EA-447F-B013-E80E98629CF8
78 DEFINE DXE_STD_ACCEL_GUID = 9FBDAD27-910C-4229-9EFF-A93BB5FE18C6
79 DEFINE DXE_FULL_ACCEL_GUID = 41A491D1-A972-468B-A299-DABF415A43B7
80 DEFINE SMM_CRYPTO_GUID = 1A1C9E13-5722-4636-AB73-31328EDE8BAF
81 DEFINE SMM_STD_GUID = E4D7D1E3-E886-4412-A442-EFD6F2502DD3
82 DEFINE SMM_FULL_GUID = 1930CE7E-6598-48ED-8AB1-EBE7E85EC254
83 DEFINE SMM_STD_ACCEL_GUID = 828959D3-CEA6-4B79-B1FC-5AFA0D7F2144
84 DEFINE SMM_FULL_ACCEL_GUID = C1760694-AB3A-4532-8C6D-52D8F86EB1AA
86 !if $(CRYPTO_SERVICES) == TARGET_UNIT_TESTS
87 !include UnitTestFrameworkPkg/UnitTestFrameworkPkgTarget.dsc.inc
90 ################################################################################
92 # Library Class section - list of all Library Classes needed by this Platform.
94 ################################################################################
96 !include MdePkg/MdeLibs.dsc.inc
99 BaseLib|MdePkg/Library/BaseLib/BaseLib.inf
100 BaseMemoryLib|MdePkg/Library/BaseMemoryLib/BaseMemoryLib.inf
101 DevicePathLib|MdePkg/Library/UefiDevicePathLib/UefiDevicePathLib.inf
102 SafeIntLib|MdePkg/Library/BaseSafeIntLib/BaseSafeIntLib.inf
103 SynchronizationLib|MdePkg/Library/BaseSynchronizationLib/BaseSynchronizationLib.inf
104 TimerLib|MdePkg/Library/BaseTimerLibNullTemplate/BaseTimerLibNullTemplate.inf
105 RngLib|MdePkg/Library/BaseRngLibNull/BaseRngLibNull.inf
106 PrintLib|MdePkg/Library/BasePrintLib/BasePrintLib.inf
107 DebugLib|MdeModulePkg/Library/PeiDxeDebugLibReportStatusCode/PeiDxeDebugLibReportStatusCode.inf
108 DebugPrintErrorLevelLib|MdePkg/Library/BaseDebugPrintErrorLevelLib/BaseDebugPrintErrorLevelLib.inf
109 OemHookStatusCodeLib|MdeModulePkg/Library/OemHookStatusCodeLibNull/OemHookStatusCodeLibNull.inf
110 HashApiLib|CryptoPkg/Library/BaseHashApiLib/BaseHashApiLib.inf
111 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLib.inf
112 IntrinsicLib|CryptoPkg/Library/IntrinsicLib/IntrinsicLib.inf
114 [LibraryClasses.IA32, LibraryClasses.X64, LibraryClasses.AARCH64]
115 RngLib|MdePkg/Library/BaseRngLib/BaseRngLib.inf
117 [LibraryClasses.ARM, LibraryClasses.AARCH64]
118 ArmLib|ArmPkg/Library/ArmLib/ArmBaseLib.inf
120 # It is not possible to prevent the ARM compiler for generic intrinsic functions.
121 # This library provides the instrinsic functions generate by a given compiler.
122 # [LibraryClasses.ARM, LibraryClasses.AARCH64] and NULL mean link this library
123 # into all ARM and AARCH64 images.
125 NULL|ArmPkg/Library/CompilerIntrinsicsLib/CompilerIntrinsicsLib.inf
127 # Add support for stack protector
128 NULL|MdePkg/Library/BaseStackCheckLib/BaseStackCheckLib.inf
131 ArmSoftFloatLib|ArmPkg/Library/ArmSoftFloatLib/ArmSoftFloatLib.inf
133 [LibraryClasses.common.SEC]
134 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/SecCryptLib.inf
135 TlsLib|CryptoPkg/Library/TlsLibNull/TlsLibNull.inf
137 [LibraryClasses.common.PEIM]
138 PeimEntryPoint|MdePkg/Library/PeimEntryPoint/PeimEntryPoint.inf
139 PeiServicesTablePointerLib|MdePkg/Library/PeiServicesTablePointerLib/PeiServicesTablePointerLib.inf
140 PeiServicesLib|MdePkg/Library/PeiServicesLib/PeiServicesLib.inf
141 MemoryAllocationLib|MdePkg/Library/PeiMemoryAllocationLib/PeiMemoryAllocationLib.inf
142 HobLib|MdePkg/Library/PeiHobLib/PeiHobLib.inf
143 PcdLib|MdePkg/Library/PeiPcdLib/PeiPcdLib.inf
144 ReportStatusCodeLib|MdeModulePkg/Library/PeiReportStatusCodeLib/PeiReportStatusCodeLib.inf
145 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/PeiCryptLib.inf
146 TlsLib|CryptoPkg/Library/TlsLibNull/TlsLibNull.inf
148 [LibraryClasses.IA32.PEIM, LibraryClasses.X64.PEIM]
149 PeiServicesTablePointerLib|MdePkg/Library/PeiServicesTablePointerLibIdt/PeiServicesTablePointerLibIdt.inf
151 [LibraryClasses.common.DXE_DRIVER]
152 UefiDriverEntryPoint|MdePkg/Library/UefiDriverEntryPoint/UefiDriverEntryPoint.inf
153 UefiBootServicesTableLib|MdePkg/Library/UefiBootServicesTableLib/UefiBootServicesTableLib.inf
154 UefiRuntimeServicesTableLib|MdePkg/Library/UefiRuntimeServicesTableLib/UefiRuntimeServicesTableLib.inf
155 MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf
156 ReportStatusCodeLib|MdeModulePkg/Library/DxeReportStatusCodeLib/DxeReportStatusCodeLib.inf
157 PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf
158 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/BaseCryptLib.inf
159 TlsLib|CryptoPkg/Library/TlsLib/TlsLib.inf
161 [LibraryClasses.common.DXE_SMM_DRIVER]
162 UefiDriverEntryPoint|MdePkg/Library/UefiDriverEntryPoint/UefiDriverEntryPoint.inf
163 UefiBootServicesTableLib|MdePkg/Library/UefiBootServicesTableLib/UefiBootServicesTableLib.inf
164 SmmServicesTableLib|MdePkg/Library/SmmServicesTableLib/SmmServicesTableLib.inf
165 MmServicesTableLib|MdePkg/Library/MmServicesTableLib/MmServicesTableLib.inf
166 MemoryAllocationLib|MdePkg/Library/SmmMemoryAllocationLib/SmmMemoryAllocationLib.inf
167 ReportStatusCodeLib|MdeModulePkg/Library/SmmReportStatusCodeLib/SmmReportStatusCodeLib.inf
168 PcdLib|MdePkg/Library/DxePcdLib/DxePcdLib.inf
169 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/SmmCryptLib.inf
170 TlsLib|CryptoPkg/Library/TlsLibNull/TlsLibNull.inf
172 [LibraryClasses.common.UEFI_APPLICATION]
173 UefiApplicationEntryPoint|MdePkg/Library/UefiApplicationEntryPoint/UefiApplicationEntryPoint.inf
174 UefiBootServicesTableLib|MdePkg/Library/UefiBootServicesTableLib/UefiBootServicesTableLib.inf
175 UefiRuntimeServicesTableLib|MdePkg/Library/UefiRuntimeServicesTableLib/UefiRuntimeServicesTableLib.inf
176 MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf
177 ReportStatusCodeLib|MdePkg/Library/BaseReportStatusCodeLibNull/BaseReportStatusCodeLibNull.inf
178 PcdLib|MdePkg/Library/BasePcdLibNull/BasePcdLibNull.inf
180 ################################################################################
182 # Pcd Section - list of all EDK II PCD Entries defined by this Platform
184 ################################################################################
186 gEfiMdePkgTokenSpaceGuid.PcdDebugPropertyMask|0x0f
187 gEfiMdePkgTokenSpaceGuid.PcdDebugPrintErrorLevel|0x80000000
188 gEfiMdePkgTokenSpaceGuid.PcdReportStatusCodePropertyMask|0x06
191 # For ALL and TARGET_UINT_TESTS profiles, enable all non-deprecated families
192 # and services in PcdCryptoServiceFamilyEnable.
194 !if $(CRYPTO_SERVICES) IN "ALL TARGET_UINT_TESTS"
196 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.HmacSha256.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
197 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.HmacSha384.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
198 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Pkcs.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
199 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Dh.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
200 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Random.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
201 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
202 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha1.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
203 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha256.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
204 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha384.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
205 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha512.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
206 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.X509.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
207 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Aes.Services.GetContextSize | TRUE
208 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Aes.Services.Init | TRUE
209 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Aes.Services.CbcEncrypt | TRUE
210 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Aes.Services.CbcDecrypt | TRUE
211 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Arc4.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
212 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sm3.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
213 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Hkdf.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
214 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Tls.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
215 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.TlsSet.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
216 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.TlsGet.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
217 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.RsaPss.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
218 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.ParallelHash.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
219 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.AeadAesGcm.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
220 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Bn.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
221 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Ec.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
225 # Enable minimum set of families/services in PcdCryptoServiceFamilyEnable
226 # required by typical PEI phase.
228 !if $(CRYPTO_SERVICES) == MIN_PEI
230 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.HmacSha256.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
231 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.HmacSha384.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
232 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha1.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
233 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha256.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
234 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha384.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
235 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha512.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
236 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sm3.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
237 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Services.Pkcs1Verify | TRUE
238 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Services.New | TRUE
239 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Services.Free | TRUE
240 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Services.SetKey | TRUE
241 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Pkcs.Services.Pkcs5HashPassword | TRUE
245 # Enable minimum set of families/services in PcdCryptoServiceFamilyEnable
246 # required by typical DXE and SMM phases.
248 !if $(CRYPTO_SERVICES) == MIN_DXE_MIN_SMM
250 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.HmacSha256.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
251 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.HmacSha384.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
252 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Pkcs.Services.Pkcs1v2Encrypt | TRUE
253 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Pkcs.Services.Pkcs5HashPassword | TRUE
254 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Pkcs.Services.Pkcs7Verify | TRUE
255 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Pkcs.Services.VerifyEKUsInPkcs7Signature | TRUE
256 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Pkcs.Services.Pkcs7GetSigners | TRUE
257 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Pkcs.Services.Pkcs7FreeSigners | TRUE
258 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Pkcs.Services.AuthenticodeVerify | TRUE
259 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Random.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
260 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Services.Pkcs1Verify | TRUE
261 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Services.New | TRUE
262 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Services.Free | TRUE
263 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Services.SetKey | TRUE
264 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Rsa.Services.GetPublicKeyFromX509 | TRUE
265 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha1.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
266 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha256.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
267 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Sha256.Services.HashAll | FALSE
268 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.X509.Services.GetSubjectName | TRUE
269 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.X509.Services.GetCommonName | TRUE
270 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.X509.Services.GetOrganizationName | TRUE
271 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.X509.Services.GetTBSCert | TRUE
272 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Tls.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
273 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.TlsSet.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
274 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.TlsGet.Family | PCD_CRYPTO_SERVICE_ENABLE_FAMILY
275 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Aes.Services.GetContextSize | TRUE
276 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Aes.Services.Init | TRUE
277 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Aes.Services.CbcEncrypt | TRUE
278 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.Aes.Services.CbcDecrypt | TRUE
279 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.AeadAesGcm.Services.Encrypt | TRUE
280 gEfiCryptoPkgTokenSpaceGuid.PcdCryptoServiceFamilyEnable.AeadAesGcm.Services.Decrypt | TRUE
283 ###################################################################################################
285 # Components Section - list of the modules and components that will be processed by compilation
286 # tools and the EDK II tools to generate PE32/PE32+/Coff image files.
288 # Note: The EDK II DSC file is not used to specify how compiled binary images get placed
289 # into firmware volume images. This section is just a list of modules to compile from
290 # source into UEFI-compliant binaries.
291 # It is the FDF file that contains information on combining binary files into firmware
292 # volume images, whose concept is beyond UEFI and is described in PI specification.
293 # Binary modules do not need to be listed in this section, as they should be
294 # specified in the FDF file. For example: Shell binary (Shell_Full.efi), FAT binary (Fat.efi),
295 # Logo (Logo.bmp), and etc.
296 # There may also be modules listed in this section that are not required in the FDF file,
297 # When a module listed here is excluded from FDF file, then UEFI-compliant binary will be
298 # generated for it, but the binary will not be put into any firmware volume.
300 ###################################################################################################
303 # If profile is TARGET_UNIT_TESTS, then build target-based unit tests
304 # using the OpensslLib, BaseCryptLib, and TlsLib with the largest set of
305 # available services.
307 !if $(CRYPTO_SERVICES) == TARGET_UNIT_TESTS
308 [Components.IA32, Components.X64, Components.ARM, Components.AARCH64]
310 # Target based unit tests
312 CryptoPkg/Test/UnitTest/Library/BaseCryptLib/TestBaseCryptLibShell.inf {
314 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibFull.inf
315 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/BaseCryptLib.inf
316 TlsLib|CryptoPkg/Library/TlsLib/TlsLib.inf
318 MSFT:*_*_*_DLINK_FLAGS = /ALIGN:4096 /FILEALIGN:4096 /SUBSYSTEM:CONSOLE
319 MSFT:DEBUG_*_*_DLINK_FLAGS = /EXPORT:InitializeDriver=$(IMAGE_ENTRY_POINT) /BASE:0x10000
320 MSFT:DEBUG_*_*_DLINK_FLAGS = /EXPORT:InitializeDriver=$(IMAGE_ENTRY_POINT) /BASE:0x10000
321 MSFT:NOOPT_*_*_DLINK_FLAGS = /EXPORT:InitializeDriver=$(IMAGE_ENTRY_POINT) /BASE:0x10000
324 [Components.IA32, Components.X64]
325 CryptoPkg/Test/UnitTest/Library/BaseCryptLib/TestBaseCryptLibShell.inf {
327 FILE_GUID = B91B9A95-4D52-4501-A98F-A1711C14ED93
329 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibFullAccel.inf
330 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/BaseCryptLib.inf
331 TlsLib|CryptoPkg/Library/TlsLib/TlsLib.inf
333 MSFT:*_*_*_DLINK_FLAGS = /ALIGN:4096 /FILEALIGN:4096 /SUBSYSTEM:CONSOLE
334 MSFT:DEBUG_*_*_DLINK_FLAGS = /EXPORT:InitializeDriver=$(IMAGE_ENTRY_POINT) /BASE:0x10000
335 MSFT:DEBUG_*_*_DLINK_FLAGS = /EXPORT:InitializeDriver=$(IMAGE_ENTRY_POINT) /BASE:0x10000
336 MSFT:NOOPT_*_*_DLINK_FLAGS = /EXPORT:InitializeDriver=$(IMAGE_ENTRY_POINT) /BASE:0x10000
340 CryptoPkg/Test/UnitTest/Library/BaseCryptLib/TestBaseCryptLibShell.inf {
342 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLib.inf
343 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/BaseCryptLib.inf
344 TlsLib|CryptoPkg/Library/TlsLib/TlsLib.inf
349 # If profile is ALL, then do verification build of all library instances.
351 !if $(CRYPTO_SERVICES) == ALL
354 # Build verification of all library instances
356 CryptoPkg/Library/BaseCryptLib/BaseCryptLib.inf
357 CryptoPkg/Library/BaseCryptLib/SecCryptLib.inf
358 CryptoPkg/Library/BaseCryptLib/PeiCryptLib.inf
359 CryptoPkg/Library/BaseCryptLib/SmmCryptLib.inf
360 CryptoPkg/Library/BaseCryptLib/RuntimeCryptLib.inf
361 CryptoPkg/Library/BaseCryptLibNull/BaseCryptLibNull.inf
362 CryptoPkg/Library/IntrinsicLib/IntrinsicLib.inf
363 CryptoPkg/Library/TlsLib/TlsLib.inf
364 CryptoPkg/Library/TlsLibNull/TlsLibNull.inf
365 CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf
366 CryptoPkg/Library/OpensslLib/OpensslLib.inf
367 CryptoPkg/Library/OpensslLib/OpensslLibFull.inf
368 CryptoPkg/Library/BaseHashApiLib/BaseHashApiLib.inf
369 CryptoPkg/Library/BaseCryptLibOnProtocolPpi/PeiCryptLib.inf
370 CryptoPkg/Library/BaseCryptLibOnProtocolPpi/DxeCryptLib.inf
371 CryptoPkg/Library/BaseCryptLibOnProtocolPpi/SmmCryptLib.inf
373 # Build verification of target-based unit tests
375 CryptoPkg/Test/UnitTest/Library/BaseCryptLib/TestBaseCryptLibShell.inf {
377 UnitTestLib|UnitTestFrameworkPkg/Library/UnitTestLib/UnitTestLib.inf
378 UnitTestPersistenceLib|UnitTestFrameworkPkg/Library/UnitTestPersistenceLibNull/UnitTestPersistenceLibNull.inf
379 UnitTestResultReportLib|UnitTestFrameworkPkg/Library/UnitTestResultReportLib/UnitTestResultReportLibConOut.inf
380 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLib.inf
381 BaseCryptLib|CryptoPkg/Library/BaseCryptLib/BaseCryptLib.inf
382 TlsLib|CryptoPkg/Library/TlsLib/TlsLib.inf
385 [Components.IA32, Components.X64]
387 # Build verification of IA32/X64 specific libraries
389 CryptoPkg/Library/OpensslLib/OpensslLibAccel.inf
390 CryptoPkg/Library/OpensslLib/OpensslLibFullAccel.inf
394 # If profile is ALL or NONE or MIN_PEI, then build CryptoPei with all supported
395 # OpensslLib instances.
397 !if $(CRYPTO_SERVICES) in "ALL NONE MIN_PEI"
400 # CryptoPei with OpensslLib instance without SSL or EC services
402 CryptoPkg/Driver/CryptoPei.inf {
404 FILE_GUID = $(PEI_CRYPTO_GUID)
406 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf
409 # CryptoPei with OpensslLib instance without EC services
411 CryptoPkg/Driver/CryptoPei.inf {
413 FILE_GUID = $(PEI_STD_GUID)
415 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLib.inf
417 [Components.IA32, Components.X64, Components.ARM, Components.AARCH64]
419 # CryptoPei with OpensslLib instance with all services
421 CryptoPkg/Driver/CryptoPei.inf {
423 FILE_GUID = $(PEI_FULL_GUID)
425 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibFull.inf
428 [Components.IA32, Components.X64]
430 # CryptoPei with IA32/X64 performance optimized OpensslLib instance without EC services
431 # IA32/X64 assembly optimizations required larger alignments
433 CryptoPkg/Driver/CryptoPei.inf {
435 FILE_GUID = $(PEI_STD_ACCEL_GUID)
437 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibAccel.inf
439 MSFT:*_*_IA32_DLINK_FLAGS = /ALIGN:64
440 MSFT:*_*_X64_DLINK_FLAGS = /ALIGN:256
444 # CryptoPei with IA32/X64 performance optimized OpensslLib instance all services
445 # IA32/X64 assembly optimizations required larger alignments
447 CryptoPkg/Driver/CryptoPei.inf {
449 FILE_GUID = $(PEI_FULL_ACCEL_GUID)
451 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibFullAccel.inf
453 MSFT:*_*_IA32_DLINK_FLAGS = /ALIGN:64
454 MSFT:*_*_X64_DLINK_FLAGS = /ALIGN:256
459 # If profile is ALL or NONE or MIN_DXE_MIN_SMM, then build CryptoDxe and
460 # CryptoSmm using all supported OpensslLib instances.
462 !if $(CRYPTO_SERVICES) in "ALL NONE MIN_DXE_MIN_SMM"
465 # CryptoDxe with OpensslLib instance with no SSL or EC services
467 CryptoPkg/Driver/CryptoDxe.inf {
469 FILE_GUID = $(DXE_CRYPTO_GUID)
471 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf
472 TlsLib|CryptoPkg/Library/TlsLibNull/TlsLibNull.inf
475 # CryptoDxe with OpensslLib instance with no EC services
477 CryptoPkg/Driver/CryptoDxe.inf {
479 FILE_GUID = $(DXE_STD_GUID)
481 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLib.inf
483 [Components.IA32, Components.X64, Components.ARM, Components.AARCH64]
485 # CryptoDxe with OpensslLib instance with all services
487 CryptoPkg/Driver/CryptoDxe.inf {
489 FILE_GUID = $(DXE_FULL_GUID)
491 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibFull.inf
494 [Components.IA32, Components.X64]
496 # CryptoDxe with IA32/X64 performance optimized OpensslLib instance with no EC services
497 # with TLS feature enabled.
498 # IA32/X64 assembly optimizations required larger alignments
500 CryptoPkg/Driver/CryptoDxe.inf {
502 FILE_GUID = $(DXE_STD_ACCEL_GUID)
504 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibAccel.inf
506 MSFT:*_*_IA32_DLINK_FLAGS = /ALIGN:64
507 MSFT:*_*_X64_DLINK_FLAGS = /ALIGN:256
510 # CryptoDxe with IA32/X64 performance optimized OpensslLib instance with all services.
511 # IA32/X64 assembly optimizations required larger alignments
513 CryptoPkg/Driver/CryptoDxe.inf {
515 FILE_GUID = $(DXE_FULL_ACCEL_GUID)
517 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibFullAccel.inf
519 MSFT:*_*_IA32_DLINK_FLAGS = /ALIGN:64
520 MSFT:*_*_X64_DLINK_FLAGS = /ALIGN:256
523 # CryptoSmm with OpensslLib instance with no SSL or EC services
525 CryptoPkg/Driver/CryptoSmm.inf {
527 FILE_GUID = $(SMM_CRYPTO_GUID)
529 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf
532 # CryptoSmm with OpensslLib instance with no SSL services
534 CryptoPkg/Driver/CryptoSmm.inf {
536 FILE_GUID = $(SMM_STD_GUID)
538 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLib.inf
541 # CryptoSmm with OpensslLib instance with no all services
543 CryptoPkg/Driver/CryptoSmm.inf {
545 FILE_GUID = $(SMM_FULL_GUID)
547 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibFull.inf
550 # CryptoSmm with IA32/X64 performance optimized OpensslLib instance with no EC services
551 # IA32/X64 assembly optimizations required larger alignments
553 CryptoPkg/Driver/CryptoSmm.inf {
555 FILE_GUID = $(SMM_STD_ACCEL_GUID)
557 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibAccel.inf
559 MSFT:*_*_IA32_DLINK_FLAGS = /ALIGN:64
560 MSFT:*_*_X64_DLINK_FLAGS = /ALIGN:256
563 # CryptoSmm with IA32/X64 performance optimized OpensslLib instance with all services
564 # IA32/X64 assembly optimizations required larger alignments
566 CryptoPkg/Driver/CryptoSmm.inf {
568 FILE_GUID = $(SMM_FULL_ACCEL_GUID)
570 OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLibFullAccel.inf
572 MSFT:*_*_IA32_DLINK_FLAGS = /ALIGN:64
573 MSFT:*_*_X64_DLINK_FLAGS = /ALIGN:256
578 RELEASE_*_*_CC_FLAGS = -DMDEPKG_NDEBUG
579 *_*_*_CC_FLAGS = -D DISABLE_NEW_DEPRECATED_INTERFACES