1## @file 2# Cryptographic Library Instance for SMM driver. 3# 4# Caution: This module requires additional review when modified. 5# This library will have external input - signature. 6# This external input must be validated carefully to avoid security issues such as 7# buffer overflow or integer overflow. 8# 9# Note: MD4 Digest functions, SHA-384 Digest functions, SHA-512 Digest functions, 10# HMAC-MD5 functions, HMAC-SHA1 functions, AES/TDES/ARC4 functions, RSA external 11# functions, PKCS#7 SignedData sign functions, Diffie-Hellman functions, and 12# authenticode signature verification functions are not supported in this instance. 13# 14# Copyright (c) 2010 - 2014, Intel Corporation. All rights reserved.<BR> 15# This program and the accompanying materials 16# are licensed and made available under the terms and conditions of the BSD License 17# which accompanies this distribution. The full text of the license may be found at 18# http://opensource.org/licenses/bsd-license.php 19# 20# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, 21# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. 22# 23## 24 25[Defines] 26 INF_VERSION = 0x00010005 27 BASE_NAME = SmmCryptLib 28 MODULE_UNI_FILE = SmmCryptLib.uni 29 FILE_GUID = 028080a3-8958-4a62-a1a8-0fa1da162007 30 MODULE_TYPE = DXE_SMM_DRIVER 31 VERSION_STRING = 1.0 32 PI_SPECIFICATION_VERSION = 0x0001000A 33 LIBRARY_CLASS = BaseCryptLib|DXE_SMM_DRIVER SMM_CORE 34 35# 36# The following information is for reference only and not required by the build tools. 37# 38# VALID_ARCHITECTURES = IA32 X64 ARM AARCH64 39# 40 41[Sources] 42 Hash/CryptMd4Null.c 43 Hash/CryptMd5.c 44 Hash/CryptSha1.c 45 Hash/CryptSha256.c 46 Hash/CryptSha512Null.c 47 Hmac/CryptHmacMd5Null.c 48 Hmac/CryptHmacSha1Null.c 49 Cipher/CryptAesNull.c 50 Cipher/CryptTdesNull.c 51 Cipher/CryptArc4Null.c 52 Pk/CryptRsaBasic.c 53 Pk/CryptRsaExtNull.c 54 Pk/CryptPkcs7SignNull.c 55 Pk/CryptPkcs7Verify.c 56 Pk/CryptDhNull.c 57 Pk/CryptX509.c 58 Pk/CryptAuthenticodeNull.c 59 Pk/CryptTsNull.c 60 Pem/CryptPem.c 61 62 SysCall/CrtWrapper.c 63 SysCall/ConstantTimeClock.c 64 SysCall/BaseMemAllocation.c 65 66[Sources.Ia32] 67 Rand/CryptRandTsc.c 68 69[Sources.X64] 70 Rand/CryptRandTsc.c 71 72[Sources.IPF] 73 Rand/CryptRandItc.c 74 75[Sources.ARM] 76 Rand/CryptRand.c 77 78[Sources.AARCH64] 79 Rand/CryptRand.c 80 81[Packages] 82 MdePkg/MdePkg.dec 83 CryptoPkg/CryptoPkg.dec 84 85[LibraryClasses] 86 BaseLib 87 IoLib 88 BaseMemoryLib 89 MemoryAllocationLib 90 OpensslLib 91 IntrinsicLib 92 PrintLib 93 94# 95# Remove these [BuildOptions] after this library is cleaned up 96# 97[BuildOptions] 98 GCC:*_GCC44_IA32_CC_FLAGS = "-D__cdecl=__attribute__((cdecl))" "-D__declspec(t)=__attribute__((t))" 99 XCODE:*_*_*_CC_FLAGS = -mmmx -msse 100