## @file # Cryptographic Library Instance for SMM driver. # # Caution: This module requires additional review when modified. # This library will have external input - signature. # This external input must be validated carefully to avoid security issues such as # buffer overflow or integer overflow. # # Note: SHA-384 Digest functions, SHA-512 Digest functions, # RSA external functions, PKCS#7 SignedData sign functions, Diffie-Hellman functions, and # authenticode signature verification functions are not supported in this instance. # # Copyright (c) 2010 - 2022, Intel Corporation. All rights reserved.
# SPDX-License-Identifier: BSD-2-Clause-Patent # ## [Defines] INF_VERSION = 0x00010005 BASE_NAME = SmmCryptLib MODULE_UNI_FILE = SmmCryptLib.uni FILE_GUID = 028080a3-8958-4a62-a1a8-0fa1da162007 MODULE_TYPE = DXE_SMM_DRIVER VERSION_STRING = 1.0 PI_SPECIFICATION_VERSION = 0x0001000A LIBRARY_CLASS = BaseCryptLib|DXE_SMM_DRIVER SMM_CORE MM_STANDALONE # # The following information is for reference only and not required by the build tools. # # VALID_ARCHITECTURES = IA32 X64 ARM AARCH64 # [Sources] InternalCryptLib.h Hash/CryptMd5.c Hash/CryptSha1.c Hash/CryptSha256.c Hash/CryptSm3.c Hash/CryptSha512.c Hash/CryptSha3.c Hash/CryptXkcp.c Hash/CryptCShake256.c Hash/CryptParallelHash.c Hmac/CryptHmac.c Kdf/CryptHkdfNull.c Cipher/CryptAes.c Cipher/CryptAeadAesGcmNull.c Pk/CryptRsaBasic.c Pk/CryptRsaExtNull.c Pk/CryptPkcs1Oaep.c Pk/CryptPkcs5Pbkdf2.c Pk/CryptPkcs7SignNull.c Pk/CryptPkcs7VerifyCommon.c Pk/CryptPkcs7VerifyBase.c Pk/CryptPkcs7VerifyEku.c Pk/CryptDhNull.c Pk/CryptX509.c Pk/CryptAuthenticodeNull.c Pk/CryptTsNull.c Pk/CryptRsaPss.c Pk/CryptRsaPssSignNull.c Pem/CryptPem.c SysCall/CrtWrapper.c SysCall/ConstantTimeClock.c SysCall/BaseMemAllocation.c [Sources.Ia32] Rand/CryptRandTsc.c [Sources.X64] Rand/CryptRandTsc.c [Sources.ARM] Rand/CryptRand.c [Sources.AARCH64] Rand/CryptRand.c [Packages] MdePkg/MdePkg.dec CryptoPkg/CryptoPkg.dec [LibraryClasses] BaseLib IoLib BaseMemoryLib MemoryAllocationLib OpensslLib IntrinsicLib PrintLib MmServicesTableLib SynchronizationLib [FixedPcd] gEfiCryptoPkgTokenSpaceGuid.PcdOpensslEcEnabled # # Remove these [BuildOptions] after this library is cleaned up # [BuildOptions] # # suppress the following warnings so we do not break the build with warnings-as-errors: # C4090: 'function' : different 'const' qualifiers # MSFT:*_*_*_CC_FLAGS = /wd4090 XCODE:*_*_*_CC_FLAGS = -mmmx -msse -std=c99 GCC:*_CLANG35_*_CC_FLAGS = -std=c99 GCC:*_CLANG38_*_CC_FLAGS = -std=c99 GCC:*_CLANGPDB_*_CC_FLAGS = -std=c99 -Wno-error=incompatible-pointer-types