REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3596 Parallel hash function ParallelHash256HashAll, as defined in NIST's Special Publication 800-185, published December 2016. It utilizes multi-process to calculate the digest. Passed CI test. Onprotocol version code passed test. Cc: Jiewen Yao <jiewen.yao@intel.com> Cc: Jian J Wang <jian.j.wang@intel.com> Cc: Xiaoyu Lu <xiaoyu1.lu@intel.com> Cc: Guomin Jiang <guomin.jiang@intel.com> Cc: Siyuan Fu <siyuan.fu@intel.com> Signed-off-by: Zhihao Li <zhihao.li@intel.com> Reviewed-by: Jiewen Yao <jiewen.yao@intel.com>
		
			
				
	
	
		
			100 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			INI
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			INI
		
	
	
	
	
	
| ## @file
 | |
| #  Cryptographic Library Instance for PEIM.
 | |
| #
 | |
| #  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:
 | |
| #  HMAC-SHA256 functions, AES functions, RSA external
 | |
| #  functions, PKCS#7 SignedData sign functions, Diffie-Hellman functions, X.509
 | |
| #  certificate handler functions, authenticode signature verification functions,
 | |
| #  PEM handler functions, and pseudorandom number generator functions are not
 | |
| #  supported in this instance.
 | |
| #
 | |
| #  Copyright (c) 2010 - 2022, Intel Corporation. All rights reserved.<BR>
 | |
| #  SPDX-License-Identifier: BSD-2-Clause-Patent
 | |
| #
 | |
| ##
 | |
| 
 | |
| [Defines]
 | |
|   INF_VERSION                    = 0x00010005
 | |
|   BASE_NAME                      = PeiCryptLib
 | |
|   MODULE_UNI_FILE                = PeiCryptLib.uni
 | |
|   FILE_GUID                      = 9a2a4375-194c-4e97-9f67-547ec98d96ca
 | |
|   MODULE_TYPE                    = PEIM
 | |
|   VERSION_STRING                 = 1.0
 | |
|   LIBRARY_CLASS                  = BaseCryptLib|PEIM PEI_CORE
 | |
| 
 | |
| #
 | |
| # The following information is for reference only and not required by the build tools.
 | |
| #
 | |
| #  VALID_ARCHITECTURES           = IA32 X64
 | |
| #
 | |
| 
 | |
| [Sources]
 | |
|   InternalCryptLib.h
 | |
|   Hash/CryptMd5.c
 | |
|   Hash/CryptSha1.c
 | |
|   Hash/CryptSha256.c
 | |
|   Hash/CryptSm3.c
 | |
|   Hash/CryptSha512.c
 | |
|   Hash/CryptParallelHashNull.c
 | |
|   Hmac/CryptHmacSha256.c
 | |
|   Kdf/CryptHkdf.c
 | |
|   Cipher/CryptAesNull.c
 | |
|   Pk/CryptRsaBasic.c
 | |
|   Pk/CryptRsaExtNull.c
 | |
|   Pk/CryptPkcs1OaepNull.c
 | |
|   Pk/CryptPkcs5Pbkdf2Null.c
 | |
|   Pk/CryptPkcs7SignNull.c
 | |
|   Pk/CryptPkcs7VerifyCommon.c
 | |
|   Pk/CryptPkcs7VerifyBase.c
 | |
|   Pk/CryptPkcs7VerifyEku.c
 | |
|   Pk/CryptDhNull.c
 | |
|   Pk/CryptX509Null.c
 | |
|   Pk/CryptAuthenticodeNull.c
 | |
|   Pk/CryptTsNull.c
 | |
|   Pk/CryptRsaPss.c
 | |
|   Pk/CryptRsaPssSignNull.c
 | |
|   Pem/CryptPemNull.c
 | |
|   Rand/CryptRandNull.c
 | |
| 
 | |
|   SysCall/CrtWrapper.c
 | |
|   SysCall/ConstantTimeClock.c
 | |
|   SysCall/BaseMemAllocation.c
 | |
| 
 | |
| [Packages]
 | |
|   MdePkg/MdePkg.dec
 | |
|   CryptoPkg/CryptoPkg.dec
 | |
| 
 | |
| [LibraryClasses]
 | |
|   BaseLib
 | |
|   BaseMemoryLib
 | |
|   MemoryAllocationLib
 | |
|   DebugLib
 | |
|   OpensslLib
 | |
|   IntrinsicLib
 | |
| 
 | |
| #
 | |
| # 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
 | |
|   # C4718: 'function call' : recursive call has no side effects, deleting
 | |
|   #
 | |
|   MSFT:*_*_*_CC_FLAGS = /wd4090 /wd4718
 | |
| 
 | |
|   # -JCryptoPkg/Include : To disable the use of the system includes provided by RVCT
 | |
|   # --diag_remark=1     : Reduce severity of "#1-D: last line of file ends without a newline"
 | |
|   RVCT:*_*_ARM_CC_FLAGS = -JCryptoPkg/Include --diag_remark=1
 | |
| 
 | |
|   GCC:*_CLANG35_*_CC_FLAGS = -std=c99
 | |
|   GCC:*_CLANG38_*_CC_FLAGS = -std=c99
 | |
|   GCC:*_CLANGPDB_*_CC_FLAGS = -std=c99 -Wno-error=incompatible-pointer-types
 | |
| 
 | |
|   XCODE:*_*_*_CC_FLAGS = -std=c99
 |