[edk2-devel] [PATCH v7 2/3] CryptoPkg/OpensslLib: Add native instruction support for X64
Yao, Jiewen
jiewen.yao at intel.com
Wed Jul 21 11:44:45 UTC 2021
Reviewed-by: Jiewen Yao <Jiewen.yao at intel.com>
> -----Original Message-----
> From: christopher.zurcher at outlook.com <christopher.zurcher at outlook.com>
> Sent: Wednesday, July 21, 2021 6:07 AM
> To: devel at edk2.groups.io
> Cc: Yao, Jiewen <jiewen.yao at intel.com>; Wang, Jian J <jian.j.wang at intel.com>;
> Lu, XiaoyuX <xiaoyux.lu at intel.com>; Kinney, Michael D
> <michael.d.kinney at intel.com>; Ard Biesheuvel <ardb at kernel.org>
> Subject: [PATCH v7 2/3] CryptoPkg/OpensslLib: Add native instruction support
> for X64
>
> From: Christopher Zurcher <christopher.zurcher at microsoft.com>
>
> BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=2507
>
> Adding OpensslLibX64.inf and modifying process_files.pl to process this
> file and generate the necessary assembly files.
> Adding OpensslLibX64Gcc.inf to allow building with GCC toolchain.
> ApiHooks.c contains a stub function for a Windows API call.
> uefi-asm.conf contains the limited assembly configurations for OpenSSL.
>
> Cc: Jiewen Yao <jiewen.yao at intel.com>
> Cc: Jian J Wang <jian.j.wang at intel.com>
> Cc: Xiaoyu Lu <xiaoyux.lu at intel.com>
> Cc: Mike Kinney <michael.d.kinney at intel.com>
> Cc: Ard Biesheuvel <ardb at kernel.org>
> Signed-off-by: Christopher Zurcher <christopher.zurcher at microsoft.com>
> ---
> CryptoPkg/CryptoPkg.ci.yaml | 21 +-
> CryptoPkg/Library/Include/CrtLibSupport.h | 2 +
> CryptoPkg/Library/Include/openssl/opensslconf.h | 3 -
> CryptoPkg/Library/OpensslLib/OpensslLib.inf | 2 +-
> CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c | 44 ++
> CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf | 2 +-
> CryptoPkg/Library/OpensslLib/OpensslLibX64.inf | 653
> ++++++++++++++++++++
> CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf | 653
> ++++++++++++++++++++
> CryptoPkg/Library/OpensslLib/UefiAsm.conf | 30 +
> CryptoPkg/Library/OpensslLib/X64/ApiHooks.c | 22 +
> CryptoPkg/Library/OpensslLib/process_files.pl | 241 ++++++--
> 11 files changed, 1619 insertions(+), 54 deletions(-)
>
> diff --git a/CryptoPkg/CryptoPkg.ci.yaml b/CryptoPkg/CryptoPkg.ci.yaml
> index 5d7c340ae5..1448299073 100644
> --- a/CryptoPkg/CryptoPkg.ci.yaml
> +++ b/CryptoPkg/CryptoPkg.ci.yaml
> @@ -7,7 +7,11 @@
> ##
> {
> "LicenseCheck": {
> - "IgnoreFiles": []
> + "IgnoreFiles": [
> + # These directories contain auto-generated OpenSSL content
> + "Library/OpensslLib/X64",
> + "Library/OpensslLib/X64Gcc"
> + ]
> },
> "EccCheck": {
> ## Exception sample looks like below:
> @@ -23,8 +27,13 @@
> "Test/UnitTest",
> # This has OpenSSL interfaces that aren't UEFI spec compliant
> "Library/BaseCryptLib/SysCall/UnitTestHostCrtWrapper.c",
> - # this has OpenSSL interfaces that aren't UEFI spec compliant
> - "Library/OpensslLib/rand_pool.c"
> + # This has OpenSSL interfaces that aren't UEFI spec compliant
> + "Library/OpensslLib/rand_pool.c",
> + # This has OpenSSL interfaces that aren't UEFI spec compliant
> + "Library/Include/CrtLibSupport.h",
> + # These directories contain auto-generated OpenSSL content
> + "Library/OpensslLib/X64",
> + "Library/OpensslLib/X64Gcc"
> ]
> },
> "CompilerPlugin": {
> @@ -51,7 +60,11 @@
> },
> "DscCompleteCheck": {
> "DscPath": "CryptoPkg.dsc",
> - "IgnoreInf": []
> + "IgnoreInf": [
> + # These are alternatives to OpensslLib.inf
> + "CryptoPkg/Library/OpensslLib/OpensslLibX64.inf",
> + "CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf"
> + ]
> },
> "GuidCheck": {
> "IgnoreGuidName": [],
> diff --git a/CryptoPkg/Library/Include/CrtLibSupport.h
> b/CryptoPkg/Library/Include/CrtLibSupport.h
> index b1dff03bdc..17d7f29ba2 100644
> --- a/CryptoPkg/Library/Include/CrtLibSupport.h
> +++ b/CryptoPkg/Library/Include/CrtLibSupport.h
> @@ -102,6 +102,7 @@ SPDX-License-Identifier: BSD-2-Clause-Patent
> //
> typedef UINTN size_t;
> typedef UINTN u_int;
> +typedef INTN ptrdiff_t;
> typedef INTN ssize_t;
> typedef INT32 time_t;
> typedef UINT8 __uint8_t;
> @@ -109,6 +110,7 @@ typedef UINT8 sa_family_t;
> typedef UINT8 u_char;
> typedef UINT32 uid_t;
> typedef UINT32 gid_t;
> +typedef CHAR16 wchar_t;
>
> //
> // File operations are not required for EFI building,
> diff --git a/CryptoPkg/Library/Include/openssl/opensslconf.h
> b/CryptoPkg/Library/Include/openssl/opensslconf.h
> index e5652be5ca..b8d59aebe8 100644
> --- a/CryptoPkg/Library/Include/openssl/opensslconf.h
> +++ b/CryptoPkg/Library/Include/openssl/opensslconf.h
> @@ -112,9 +112,6 @@ extern "C" {
> #ifndef OPENSSL_NO_ASAN
> # define OPENSSL_NO_ASAN
> #endif
> -#ifndef OPENSSL_NO_ASM
> -# define OPENSSL_NO_ASM
> -#endif
> #ifndef OPENSSL_NO_ASYNC
> # define OPENSSL_NO_ASYNC
> #endif
> diff --git a/CryptoPkg/Library/OpensslLib/OpensslLib.inf
> b/CryptoPkg/Library/OpensslLib/OpensslLib.inf
> index b00bb74ce6..d84bde056a 100644
> --- a/CryptoPkg/Library/OpensslLib/OpensslLib.inf
> +++ b/CryptoPkg/Library/OpensslLib/OpensslLib.inf
> @@ -16,7 +16,7 @@
> VERSION_STRING = 1.0
> LIBRARY_CLASS = OpensslLib
> DEFINE OPENSSL_PATH = openssl
> - DEFINE OPENSSL_FLAGS = -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT
> -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE
> + DEFINE OPENSSL_FLAGS = -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT
> -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE -
> DOPENSSL_NO_ASM
>
> #
> # VALID_ARCHITECTURES = IA32 X64 ARM AARCH64
> diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c
> b/CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c
> new file mode 100644
> index 0000000000..74ae1ac20c
> --- /dev/null
> +++ b/CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c
> @@ -0,0 +1,44 @@
> +/** @file
> + Constructor to initialize CPUID data for OpenSSL assembly operations.
> +
> +Copyright (c) 2020, Intel Corporation. All rights reserved.<BR>
> +SPDX-License-Identifier: BSD-2-Clause-Patent
> +
> +**/
> +
> +#include <Uefi.h>
> +
> +
> +/**
> + An internal OpenSSL function which fetches a local copy of the hardware
> + capability flags.
> +
> +**/
> +extern
> +VOID
> +OPENSSL_cpuid_setup (
> + VOID
> + );
> +
> +/**
> + Constructor routine for OpensslLib.
> +
> + The constructor calls an internal OpenSSL function which fetches a local copy
> + of the hardware capability flags, used to enable native crypto instructions.
> +
> + @param None
> +
> + @retval EFI_SUCCESS The construction succeeded.
> +
> +**/
> +EFI_STATUS
> +EFIAPI
> +OpensslLibConstructor (
> + VOID
> + )
> +{
> + OPENSSL_cpuid_setup ();
> +
> + return EFI_SUCCESS;
> +}
> +
> diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf
> b/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf
> index 3557711bd8..cdeed0d073 100644
> --- a/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf
> +++ b/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf
> @@ -16,7 +16,7 @@
> VERSION_STRING = 1.0
> LIBRARY_CLASS = OpensslLib
> DEFINE OPENSSL_PATH = openssl
> - DEFINE OPENSSL_FLAGS = -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT
> -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE
> + DEFINE OPENSSL_FLAGS = -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT
> -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE -
> DOPENSSL_NO_ASM
>
> #
> # VALID_ARCHITECTURES = IA32 X64 ARM AARCH64
> diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibX64.inf
> b/CryptoPkg/Library/OpensslLib/OpensslLibX64.inf
> new file mode 100644
> index 0000000000..b92feaf1bf
> --- /dev/null
> +++ b/CryptoPkg/Library/OpensslLib/OpensslLibX64.inf
> @@ -0,0 +1,653 @@
> +## @file
> +# This module provides OpenSSL Library implementation.
> +#
> +# Copyright (c) 2010 - 2020, Intel Corporation. All rights reserved.<BR>
> +# (C) Copyright 2020 Hewlett Packard Enterprise Development LP<BR>
> +# SPDX-License-Identifier: BSD-2-Clause-Patent
> +#
> +##
> +
> +[Defines]
> + INF_VERSION = 0x00010005
> + BASE_NAME = OpensslLibX64
> + MODULE_UNI_FILE = OpensslLib.uni
> + FILE_GUID = 18125E50-0117-4DD0-BE54-4784AD995FEF
> + MODULE_TYPE = BASE
> + VERSION_STRING = 1.0
> + LIBRARY_CLASS = OpensslLib
> + DEFINE OPENSSL_PATH = openssl
> + DEFINE OPENSSL_FLAGS = -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT
> -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE
> + DEFINE OPENSSL_FLAGS_CONFIG = -DOPENSSL_CPUID_OBJ -DSHA1_ASM -
> DSHA256_ASM -DSHA512_ASM -DAESNI_ASM -DVPAES_ASM -DGHASH_ASM
> + CONSTRUCTOR = OpensslLibConstructor
> +
> +#
> +# VALID_ARCHITECTURES = X64
> +#
> +
> +[Sources.X64]
> + OpensslLibConstructor.c
> + $(OPENSSL_PATH)/e_os.h
> + $(OPENSSL_PATH)/ms/uplink.h
> +# Autogenerated files list starts here
> + X64/crypto/aes/aesni-mb-x86_64.nasm
> + X64/crypto/aes/aesni-sha1-x86_64.nasm
> + X64/crypto/aes/aesni-sha256-x86_64.nasm
> + X64/crypto/aes/aesni-x86_64.nasm
> + X64/crypto/aes/vpaes-x86_64.nasm
> + X64/crypto/modes/aesni-gcm-x86_64.nasm
> + X64/crypto/modes/ghash-x86_64.nasm
> + X64/crypto/sha/sha1-mb-x86_64.nasm
> + X64/crypto/sha/sha1-x86_64.nasm
> + X64/crypto/sha/sha256-mb-x86_64.nasm
> + X64/crypto/sha/sha256-x86_64.nasm
> + X64/crypto/sha/sha512-x86_64.nasm
> + X64/crypto/x86_64cpuid.nasm
> + $(OPENSSL_PATH)/crypto/aes/aes_cbc.c
> + $(OPENSSL_PATH)/crypto/aes/aes_cfb.c
> + $(OPENSSL_PATH)/crypto/aes/aes_core.c
> + $(OPENSSL_PATH)/crypto/aes/aes_ige.c
> + $(OPENSSL_PATH)/crypto/aes/aes_misc.c
> + $(OPENSSL_PATH)/crypto/aes/aes_ofb.c
> + $(OPENSSL_PATH)/crypto/aes/aes_wrap.c
> + $(OPENSSL_PATH)/crypto/aria/aria.c
> + $(OPENSSL_PATH)/crypto/asn1/a_bitstr.c
> + $(OPENSSL_PATH)/crypto/asn1/a_d2i_fp.c
> + $(OPENSSL_PATH)/crypto/asn1/a_digest.c
> + $(OPENSSL_PATH)/crypto/asn1/a_dup.c
> + $(OPENSSL_PATH)/crypto/asn1/a_gentm.c
> + $(OPENSSL_PATH)/crypto/asn1/a_i2d_fp.c
> + $(OPENSSL_PATH)/crypto/asn1/a_int.c
> + $(OPENSSL_PATH)/crypto/asn1/a_mbstr.c
> + $(OPENSSL_PATH)/crypto/asn1/a_object.c
> + $(OPENSSL_PATH)/crypto/asn1/a_octet.c
> + $(OPENSSL_PATH)/crypto/asn1/a_print.c
> + $(OPENSSL_PATH)/crypto/asn1/a_sign.c
> + $(OPENSSL_PATH)/crypto/asn1/a_strex.c
> + $(OPENSSL_PATH)/crypto/asn1/a_strnid.c
> + $(OPENSSL_PATH)/crypto/asn1/a_time.c
> + $(OPENSSL_PATH)/crypto/asn1/a_type.c
> + $(OPENSSL_PATH)/crypto/asn1/a_utctm.c
> + $(OPENSSL_PATH)/crypto/asn1/a_utf8.c
> + $(OPENSSL_PATH)/crypto/asn1/a_verify.c
> + $(OPENSSL_PATH)/crypto/asn1/ameth_lib.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_err.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_gen.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_item_list.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_lib.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_par.c
> + $(OPENSSL_PATH)/crypto/asn1/asn_mime.c
> + $(OPENSSL_PATH)/crypto/asn1/asn_moid.c
> + $(OPENSSL_PATH)/crypto/asn1/asn_mstbl.c
> + $(OPENSSL_PATH)/crypto/asn1/asn_pack.c
> + $(OPENSSL_PATH)/crypto/asn1/bio_asn1.c
> + $(OPENSSL_PATH)/crypto/asn1/bio_ndef.c
> + $(OPENSSL_PATH)/crypto/asn1/d2i_pr.c
> + $(OPENSSL_PATH)/crypto/asn1/d2i_pu.c
> + $(OPENSSL_PATH)/crypto/asn1/evp_asn1.c
> + $(OPENSSL_PATH)/crypto/asn1/f_int.c
> + $(OPENSSL_PATH)/crypto/asn1/f_string.c
> + $(OPENSSL_PATH)/crypto/asn1/i2d_pr.c
> + $(OPENSSL_PATH)/crypto/asn1/i2d_pu.c
> + $(OPENSSL_PATH)/crypto/asn1/n_pkey.c
> + $(OPENSSL_PATH)/crypto/asn1/nsseq.c
> + $(OPENSSL_PATH)/crypto/asn1/p5_pbe.c
> + $(OPENSSL_PATH)/crypto/asn1/p5_pbev2.c
> + $(OPENSSL_PATH)/crypto/asn1/p5_scrypt.c
> + $(OPENSSL_PATH)/crypto/asn1/p8_pkey.c
> + $(OPENSSL_PATH)/crypto/asn1/t_bitst.c
> + $(OPENSSL_PATH)/crypto/asn1/t_pkey.c
> + $(OPENSSL_PATH)/crypto/asn1/t_spki.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_dec.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_enc.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_fre.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_new.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_prn.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_scn.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_typ.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_utl.c
> + $(OPENSSL_PATH)/crypto/asn1/x_algor.c
> + $(OPENSSL_PATH)/crypto/asn1/x_bignum.c
> + $(OPENSSL_PATH)/crypto/asn1/x_info.c
> + $(OPENSSL_PATH)/crypto/asn1/x_int64.c
> + $(OPENSSL_PATH)/crypto/asn1/x_long.c
> + $(OPENSSL_PATH)/crypto/asn1/x_pkey.c
> + $(OPENSSL_PATH)/crypto/asn1/x_sig.c
> + $(OPENSSL_PATH)/crypto/asn1/x_spki.c
> + $(OPENSSL_PATH)/crypto/asn1/x_val.c
> + $(OPENSSL_PATH)/crypto/async/arch/async_null.c
> + $(OPENSSL_PATH)/crypto/async/arch/async_posix.c
> + $(OPENSSL_PATH)/crypto/async/arch/async_win.c
> + $(OPENSSL_PATH)/crypto/async/async.c
> + $(OPENSSL_PATH)/crypto/async/async_err.c
> + $(OPENSSL_PATH)/crypto/async/async_wait.c
> + $(OPENSSL_PATH)/crypto/bio/b_addr.c
> + $(OPENSSL_PATH)/crypto/bio/b_dump.c
> + $(OPENSSL_PATH)/crypto/bio/b_sock.c
> + $(OPENSSL_PATH)/crypto/bio/b_sock2.c
> + $(OPENSSL_PATH)/crypto/bio/bf_buff.c
> + $(OPENSSL_PATH)/crypto/bio/bf_lbuf.c
> + $(OPENSSL_PATH)/crypto/bio/bf_nbio.c
> + $(OPENSSL_PATH)/crypto/bio/bf_null.c
> + $(OPENSSL_PATH)/crypto/bio/bio_cb.c
> + $(OPENSSL_PATH)/crypto/bio/bio_err.c
> + $(OPENSSL_PATH)/crypto/bio/bio_lib.c
> + $(OPENSSL_PATH)/crypto/bio/bio_meth.c
> + $(OPENSSL_PATH)/crypto/bio/bss_acpt.c
> + $(OPENSSL_PATH)/crypto/bio/bss_bio.c
> + $(OPENSSL_PATH)/crypto/bio/bss_conn.c
> + $(OPENSSL_PATH)/crypto/bio/bss_dgram.c
> + $(OPENSSL_PATH)/crypto/bio/bss_fd.c
> + $(OPENSSL_PATH)/crypto/bio/bss_file.c
> + $(OPENSSL_PATH)/crypto/bio/bss_log.c
> + $(OPENSSL_PATH)/crypto/bio/bss_mem.c
> + $(OPENSSL_PATH)/crypto/bio/bss_null.c
> + $(OPENSSL_PATH)/crypto/bio/bss_sock.c
> + $(OPENSSL_PATH)/crypto/bn/bn_add.c
> + $(OPENSSL_PATH)/crypto/bn/bn_asm.c
> + $(OPENSSL_PATH)/crypto/bn/bn_blind.c
> + $(OPENSSL_PATH)/crypto/bn/bn_const.c
> + $(OPENSSL_PATH)/crypto/bn/bn_ctx.c
> + $(OPENSSL_PATH)/crypto/bn/bn_depr.c
> + $(OPENSSL_PATH)/crypto/bn/bn_dh.c
> + $(OPENSSL_PATH)/crypto/bn/bn_div.c
> + $(OPENSSL_PATH)/crypto/bn/bn_err.c
> + $(OPENSSL_PATH)/crypto/bn/bn_exp.c
> + $(OPENSSL_PATH)/crypto/bn/bn_exp2.c
> + $(OPENSSL_PATH)/crypto/bn/bn_gcd.c
> + $(OPENSSL_PATH)/crypto/bn/bn_gf2m.c
> + $(OPENSSL_PATH)/crypto/bn/bn_intern.c
> + $(OPENSSL_PATH)/crypto/bn/bn_kron.c
> + $(OPENSSL_PATH)/crypto/bn/bn_lib.c
> + $(OPENSSL_PATH)/crypto/bn/bn_mod.c
> + $(OPENSSL_PATH)/crypto/bn/bn_mont.c
> + $(OPENSSL_PATH)/crypto/bn/bn_mpi.c
> + $(OPENSSL_PATH)/crypto/bn/bn_mul.c
> + $(OPENSSL_PATH)/crypto/bn/bn_nist.c
> + $(OPENSSL_PATH)/crypto/bn/bn_prime.c
> + $(OPENSSL_PATH)/crypto/bn/bn_print.c
> + $(OPENSSL_PATH)/crypto/bn/bn_rand.c
> + $(OPENSSL_PATH)/crypto/bn/bn_recp.c
> + $(OPENSSL_PATH)/crypto/bn/bn_shift.c
> + $(OPENSSL_PATH)/crypto/bn/bn_sqr.c
> + $(OPENSSL_PATH)/crypto/bn/bn_sqrt.c
> + $(OPENSSL_PATH)/crypto/bn/bn_srp.c
> + $(OPENSSL_PATH)/crypto/bn/bn_word.c
> + $(OPENSSL_PATH)/crypto/bn/bn_x931p.c
> + $(OPENSSL_PATH)/crypto/buffer/buf_err.c
> + $(OPENSSL_PATH)/crypto/buffer/buffer.c
> + $(OPENSSL_PATH)/crypto/cmac/cm_ameth.c
> + $(OPENSSL_PATH)/crypto/cmac/cm_pmeth.c
> + $(OPENSSL_PATH)/crypto/cmac/cmac.c
> + $(OPENSSL_PATH)/crypto/comp/c_zlib.c
> + $(OPENSSL_PATH)/crypto/comp/comp_err.c
> + $(OPENSSL_PATH)/crypto/comp/comp_lib.c
> + $(OPENSSL_PATH)/crypto/conf/conf_api.c
> + $(OPENSSL_PATH)/crypto/conf/conf_def.c
> + $(OPENSSL_PATH)/crypto/conf/conf_err.c
> + $(OPENSSL_PATH)/crypto/conf/conf_lib.c
> + $(OPENSSL_PATH)/crypto/conf/conf_mall.c
> + $(OPENSSL_PATH)/crypto/conf/conf_mod.c
> + $(OPENSSL_PATH)/crypto/conf/conf_sap.c
> + $(OPENSSL_PATH)/crypto/conf/conf_ssl.c
> + $(OPENSSL_PATH)/crypto/cpt_err.c
> + $(OPENSSL_PATH)/crypto/cryptlib.c
> + $(OPENSSL_PATH)/crypto/ctype.c
> + $(OPENSSL_PATH)/crypto/cversion.c
> + $(OPENSSL_PATH)/crypto/dh/dh_ameth.c
> + $(OPENSSL_PATH)/crypto/dh/dh_asn1.c
> + $(OPENSSL_PATH)/crypto/dh/dh_check.c
> + $(OPENSSL_PATH)/crypto/dh/dh_depr.c
> + $(OPENSSL_PATH)/crypto/dh/dh_err.c
> + $(OPENSSL_PATH)/crypto/dh/dh_gen.c
> + $(OPENSSL_PATH)/crypto/dh/dh_kdf.c
> + $(OPENSSL_PATH)/crypto/dh/dh_key.c
> + $(OPENSSL_PATH)/crypto/dh/dh_lib.c
> + $(OPENSSL_PATH)/crypto/dh/dh_meth.c
> + $(OPENSSL_PATH)/crypto/dh/dh_pmeth.c
> + $(OPENSSL_PATH)/crypto/dh/dh_prn.c
> + $(OPENSSL_PATH)/crypto/dh/dh_rfc5114.c
> + $(OPENSSL_PATH)/crypto/dh/dh_rfc7919.c
> + $(OPENSSL_PATH)/crypto/dso/dso_dl.c
> + $(OPENSSL_PATH)/crypto/dso/dso_dlfcn.c
> + $(OPENSSL_PATH)/crypto/dso/dso_err.c
> + $(OPENSSL_PATH)/crypto/dso/dso_lib.c
> + $(OPENSSL_PATH)/crypto/dso/dso_openssl.c
> + $(OPENSSL_PATH)/crypto/dso/dso_vms.c
> + $(OPENSSL_PATH)/crypto/dso/dso_win32.c
> + $(OPENSSL_PATH)/crypto/ebcdic.c
> + $(OPENSSL_PATH)/crypto/err/err.c
> + $(OPENSSL_PATH)/crypto/err/err_prn.c
> + $(OPENSSL_PATH)/crypto/evp/bio_b64.c
> + $(OPENSSL_PATH)/crypto/evp/bio_enc.c
> + $(OPENSSL_PATH)/crypto/evp/bio_md.c
> + $(OPENSSL_PATH)/crypto/evp/bio_ok.c
> + $(OPENSSL_PATH)/crypto/evp/c_allc.c
> + $(OPENSSL_PATH)/crypto/evp/c_alld.c
> + $(OPENSSL_PATH)/crypto/evp/cmeth_lib.c
> + $(OPENSSL_PATH)/crypto/evp/digest.c
> + $(OPENSSL_PATH)/crypto/evp/e_aes.c
> + $(OPENSSL_PATH)/crypto/evp/e_aes_cbc_hmac_sha1.c
> + $(OPENSSL_PATH)/crypto/evp/e_aes_cbc_hmac_sha256.c
> + $(OPENSSL_PATH)/crypto/evp/e_aria.c
> + $(OPENSSL_PATH)/crypto/evp/e_bf.c
> + $(OPENSSL_PATH)/crypto/evp/e_camellia.c
> + $(OPENSSL_PATH)/crypto/evp/e_cast.c
> + $(OPENSSL_PATH)/crypto/evp/e_chacha20_poly1305.c
> + $(OPENSSL_PATH)/crypto/evp/e_des.c
> + $(OPENSSL_PATH)/crypto/evp/e_des3.c
> + $(OPENSSL_PATH)/crypto/evp/e_idea.c
> + $(OPENSSL_PATH)/crypto/evp/e_null.c
> + $(OPENSSL_PATH)/crypto/evp/e_old.c
> + $(OPENSSL_PATH)/crypto/evp/e_rc2.c
> + $(OPENSSL_PATH)/crypto/evp/e_rc4.c
> + $(OPENSSL_PATH)/crypto/evp/e_rc4_hmac_md5.c
> + $(OPENSSL_PATH)/crypto/evp/e_rc5.c
> + $(OPENSSL_PATH)/crypto/evp/e_seed.c
> + $(OPENSSL_PATH)/crypto/evp/e_sm4.c
> + $(OPENSSL_PATH)/crypto/evp/e_xcbc_d.c
> + $(OPENSSL_PATH)/crypto/evp/encode.c
> + $(OPENSSL_PATH)/crypto/evp/evp_cnf.c
> + $(OPENSSL_PATH)/crypto/evp/evp_enc.c
> + $(OPENSSL_PATH)/crypto/evp/evp_err.c
> + $(OPENSSL_PATH)/crypto/evp/evp_key.c
> + $(OPENSSL_PATH)/crypto/evp/evp_lib.c
> + $(OPENSSL_PATH)/crypto/evp/evp_pbe.c
> + $(OPENSSL_PATH)/crypto/evp/evp_pkey.c
> + $(OPENSSL_PATH)/crypto/evp/m_md2.c
> + $(OPENSSL_PATH)/crypto/evp/m_md4.c
> + $(OPENSSL_PATH)/crypto/evp/m_md5.c
> + $(OPENSSL_PATH)/crypto/evp/m_md5_sha1.c
> + $(OPENSSL_PATH)/crypto/evp/m_mdc2.c
> + $(OPENSSL_PATH)/crypto/evp/m_null.c
> + $(OPENSSL_PATH)/crypto/evp/m_ripemd.c
> + $(OPENSSL_PATH)/crypto/evp/m_sha1.c
> + $(OPENSSL_PATH)/crypto/evp/m_sha3.c
> + $(OPENSSL_PATH)/crypto/evp/m_sigver.c
> + $(OPENSSL_PATH)/crypto/evp/m_wp.c
> + $(OPENSSL_PATH)/crypto/evp/names.c
> + $(OPENSSL_PATH)/crypto/evp/p5_crpt.c
> + $(OPENSSL_PATH)/crypto/evp/p5_crpt2.c
> + $(OPENSSL_PATH)/crypto/evp/p_dec.c
> + $(OPENSSL_PATH)/crypto/evp/p_enc.c
> + $(OPENSSL_PATH)/crypto/evp/p_lib.c
> + $(OPENSSL_PATH)/crypto/evp/p_open.c
> + $(OPENSSL_PATH)/crypto/evp/p_seal.c
> + $(OPENSSL_PATH)/crypto/evp/p_sign.c
> + $(OPENSSL_PATH)/crypto/evp/p_verify.c
> + $(OPENSSL_PATH)/crypto/evp/pbe_scrypt.c
> + $(OPENSSL_PATH)/crypto/evp/pmeth_fn.c
> + $(OPENSSL_PATH)/crypto/evp/pmeth_gn.c
> + $(OPENSSL_PATH)/crypto/evp/pmeth_lib.c
> + $(OPENSSL_PATH)/crypto/ex_data.c
> + $(OPENSSL_PATH)/crypto/getenv.c
> + $(OPENSSL_PATH)/crypto/hmac/hm_ameth.c
> + $(OPENSSL_PATH)/crypto/hmac/hm_pmeth.c
> + $(OPENSSL_PATH)/crypto/hmac/hmac.c
> + $(OPENSSL_PATH)/crypto/init.c
> + $(OPENSSL_PATH)/crypto/kdf/hkdf.c
> + $(OPENSSL_PATH)/crypto/kdf/kdf_err.c
> + $(OPENSSL_PATH)/crypto/kdf/scrypt.c
> + $(OPENSSL_PATH)/crypto/kdf/tls1_prf.c
> + $(OPENSSL_PATH)/crypto/lhash/lh_stats.c
> + $(OPENSSL_PATH)/crypto/lhash/lhash.c
> + $(OPENSSL_PATH)/crypto/md5/md5_dgst.c
> + $(OPENSSL_PATH)/crypto/md5/md5_one.c
> + $(OPENSSL_PATH)/crypto/mem.c
> + $(OPENSSL_PATH)/crypto/mem_dbg.c
> + $(OPENSSL_PATH)/crypto/mem_sec.c
> + $(OPENSSL_PATH)/crypto/modes/cbc128.c
> + $(OPENSSL_PATH)/crypto/modes/ccm128.c
> + $(OPENSSL_PATH)/crypto/modes/cfb128.c
> + $(OPENSSL_PATH)/crypto/modes/ctr128.c
> + $(OPENSSL_PATH)/crypto/modes/cts128.c
> + $(OPENSSL_PATH)/crypto/modes/gcm128.c
> + $(OPENSSL_PATH)/crypto/modes/ocb128.c
> + $(OPENSSL_PATH)/crypto/modes/ofb128.c
> + $(OPENSSL_PATH)/crypto/modes/wrap128.c
> + $(OPENSSL_PATH)/crypto/modes/xts128.c
> + $(OPENSSL_PATH)/crypto/o_dir.c
> + $(OPENSSL_PATH)/crypto/o_fips.c
> + $(OPENSSL_PATH)/crypto/o_fopen.c
> + $(OPENSSL_PATH)/crypto/o_init.c
> + $(OPENSSL_PATH)/crypto/o_str.c
> + $(OPENSSL_PATH)/crypto/o_time.c
> + $(OPENSSL_PATH)/crypto/objects/o_names.c
> + $(OPENSSL_PATH)/crypto/objects/obj_dat.c
> + $(OPENSSL_PATH)/crypto/objects/obj_err.c
> + $(OPENSSL_PATH)/crypto/objects/obj_lib.c
> + $(OPENSSL_PATH)/crypto/objects/obj_xref.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_asn.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_cl.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_err.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_ext.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_ht.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_lib.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_prn.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_srv.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_vfy.c
> + $(OPENSSL_PATH)/crypto/ocsp/v3_ocsp.c
> + $(OPENSSL_PATH)/crypto/pem/pem_all.c
> + $(OPENSSL_PATH)/crypto/pem/pem_err.c
> + $(OPENSSL_PATH)/crypto/pem/pem_info.c
> + $(OPENSSL_PATH)/crypto/pem/pem_lib.c
> + $(OPENSSL_PATH)/crypto/pem/pem_oth.c
> + $(OPENSSL_PATH)/crypto/pem/pem_pk8.c
> + $(OPENSSL_PATH)/crypto/pem/pem_pkey.c
> + $(OPENSSL_PATH)/crypto/pem/pem_sign.c
> + $(OPENSSL_PATH)/crypto/pem/pem_x509.c
> + $(OPENSSL_PATH)/crypto/pem/pem_xaux.c
> + $(OPENSSL_PATH)/crypto/pem/pvkfmt.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_add.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_asn.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_attr.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_crpt.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_crt.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_decr.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_init.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_key.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_kiss.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_mutl.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_npas.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_p8d.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_p8e.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_sbag.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_utl.c
> + $(OPENSSL_PATH)/crypto/pkcs12/pk12err.c
> + $(OPENSSL_PATH)/crypto/pkcs7/bio_pk7.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_asn1.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_attr.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_doit.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_lib.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_mime.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_smime.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pkcs7err.c
> + $(OPENSSL_PATH)/crypto/rand/drbg_ctr.c
> + $(OPENSSL_PATH)/crypto/rand/drbg_lib.c
> + $(OPENSSL_PATH)/crypto/rand/rand_egd.c
> + $(OPENSSL_PATH)/crypto/rand/rand_err.c
> + $(OPENSSL_PATH)/crypto/rand/rand_lib.c
> + $(OPENSSL_PATH)/crypto/rand/rand_unix.c
> + $(OPENSSL_PATH)/crypto/rand/rand_vms.c
> + $(OPENSSL_PATH)/crypto/rand/rand_win.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_ameth.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_asn1.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_chk.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_crpt.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_depr.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_err.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_gen.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_lib.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_meth.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_mp.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_none.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_oaep.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_ossl.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_pk1.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_pmeth.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_prn.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_pss.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_saos.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_sign.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_ssl.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_x931.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_x931g.c
> + $(OPENSSL_PATH)/crypto/sha/keccak1600.c
> + $(OPENSSL_PATH)/crypto/sha/sha1_one.c
> + $(OPENSSL_PATH)/crypto/sha/sha1dgst.c
> + $(OPENSSL_PATH)/crypto/sha/sha256.c
> + $(OPENSSL_PATH)/crypto/sha/sha512.c
> + $(OPENSSL_PATH)/crypto/siphash/siphash.c
> + $(OPENSSL_PATH)/crypto/siphash/siphash_ameth.c
> + $(OPENSSL_PATH)/crypto/siphash/siphash_pmeth.c
> + $(OPENSSL_PATH)/crypto/sm3/m_sm3.c
> + $(OPENSSL_PATH)/crypto/sm3/sm3.c
> + $(OPENSSL_PATH)/crypto/sm4/sm4.c
> + $(OPENSSL_PATH)/crypto/stack/stack.c
> + $(OPENSSL_PATH)/crypto/threads_none.c
> + $(OPENSSL_PATH)/crypto/threads_pthread.c
> + $(OPENSSL_PATH)/crypto/threads_win.c
> + $(OPENSSL_PATH)/crypto/txt_db/txt_db.c
> + $(OPENSSL_PATH)/crypto/ui/ui_err.c
> + $(OPENSSL_PATH)/crypto/ui/ui_lib.c
> + $(OPENSSL_PATH)/crypto/ui/ui_null.c
> + $(OPENSSL_PATH)/crypto/ui/ui_openssl.c
> + $(OPENSSL_PATH)/crypto/ui/ui_util.c
> + $(OPENSSL_PATH)/crypto/uid.c
> + $(OPENSSL_PATH)/crypto/x509/by_dir.c
> + $(OPENSSL_PATH)/crypto/x509/by_file.c
> + $(OPENSSL_PATH)/crypto/x509/t_crl.c
> + $(OPENSSL_PATH)/crypto/x509/t_req.c
> + $(OPENSSL_PATH)/crypto/x509/t_x509.c
> + $(OPENSSL_PATH)/crypto/x509/x509_att.c
> + $(OPENSSL_PATH)/crypto/x509/x509_cmp.c
> + $(OPENSSL_PATH)/crypto/x509/x509_d2.c
> + $(OPENSSL_PATH)/crypto/x509/x509_def.c
> + $(OPENSSL_PATH)/crypto/x509/x509_err.c
> + $(OPENSSL_PATH)/crypto/x509/x509_ext.c
> + $(OPENSSL_PATH)/crypto/x509/x509_lu.c
> + $(OPENSSL_PATH)/crypto/x509/x509_meth.c
> + $(OPENSSL_PATH)/crypto/x509/x509_obj.c
> + $(OPENSSL_PATH)/crypto/x509/x509_r2x.c
> + $(OPENSSL_PATH)/crypto/x509/x509_req.c
> + $(OPENSSL_PATH)/crypto/x509/x509_set.c
> + $(OPENSSL_PATH)/crypto/x509/x509_trs.c
> + $(OPENSSL_PATH)/crypto/x509/x509_txt.c
> + $(OPENSSL_PATH)/crypto/x509/x509_v3.c
> + $(OPENSSL_PATH)/crypto/x509/x509_vfy.c
> + $(OPENSSL_PATH)/crypto/x509/x509_vpm.c
> + $(OPENSSL_PATH)/crypto/x509/x509cset.c
> + $(OPENSSL_PATH)/crypto/x509/x509name.c
> + $(OPENSSL_PATH)/crypto/x509/x509rset.c
> + $(OPENSSL_PATH)/crypto/x509/x509spki.c
> + $(OPENSSL_PATH)/crypto/x509/x509type.c
> + $(OPENSSL_PATH)/crypto/x509/x_all.c
> + $(OPENSSL_PATH)/crypto/x509/x_attrib.c
> + $(OPENSSL_PATH)/crypto/x509/x_crl.c
> + $(OPENSSL_PATH)/crypto/x509/x_exten.c
> + $(OPENSSL_PATH)/crypto/x509/x_name.c
> + $(OPENSSL_PATH)/crypto/x509/x_pubkey.c
> + $(OPENSSL_PATH)/crypto/x509/x_req.c
> + $(OPENSSL_PATH)/crypto/x509/x_x509.c
> + $(OPENSSL_PATH)/crypto/x509/x_x509a.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_cache.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_data.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_lib.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_map.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_node.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_tree.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_addr.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_admis.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_akey.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_akeya.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_alt.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_asid.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_bcons.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_bitst.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_conf.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_cpols.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_crld.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_enum.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_extku.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_genn.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_ia5.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_info.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_int.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_lib.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_ncons.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pci.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pcia.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pcons.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pku.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pmaps.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_prn.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_purp.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_skey.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_sxnet.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_tlsf.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_utl.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3err.c
> + $(OPENSSL_PATH)/crypto/arm_arch.h
> + $(OPENSSL_PATH)/crypto/mips_arch.h
> + $(OPENSSL_PATH)/crypto/ppc_arch.h
> + $(OPENSSL_PATH)/crypto/s390x_arch.h
> + $(OPENSSL_PATH)/crypto/sparc_arch.h
> + $(OPENSSL_PATH)/crypto/vms_rms.h
> + $(OPENSSL_PATH)/crypto/aes/aes_local.h
> + $(OPENSSL_PATH)/crypto/asn1/asn1_item_list.h
> + $(OPENSSL_PATH)/crypto/asn1/asn1_local.h
> + $(OPENSSL_PATH)/crypto/asn1/charmap.h
> + $(OPENSSL_PATH)/crypto/asn1/standard_methods.h
> + $(OPENSSL_PATH)/crypto/asn1/tbl_standard.h
> + $(OPENSSL_PATH)/crypto/async/async_local.h
> + $(OPENSSL_PATH)/crypto/async/arch/async_null.h
> + $(OPENSSL_PATH)/crypto/async/arch/async_posix.h
> + $(OPENSSL_PATH)/crypto/async/arch/async_win.h
> + $(OPENSSL_PATH)/crypto/bio/bio_local.h
> + $(OPENSSL_PATH)/crypto/bn/bn_local.h
> + $(OPENSSL_PATH)/crypto/bn/bn_prime.h
> + $(OPENSSL_PATH)/crypto/bn/rsaz_exp.h
> + $(OPENSSL_PATH)/crypto/comp/comp_local.h
> + $(OPENSSL_PATH)/crypto/conf/conf_def.h
> + $(OPENSSL_PATH)/crypto/conf/conf_local.h
> + $(OPENSSL_PATH)/crypto/dh/dh_local.h
> + $(OPENSSL_PATH)/crypto/dso/dso_local.h
> + $(OPENSSL_PATH)/crypto/evp/evp_local.h
> + $(OPENSSL_PATH)/crypto/hmac/hmac_local.h
> + $(OPENSSL_PATH)/crypto/lhash/lhash_local.h
> + $(OPENSSL_PATH)/crypto/md5/md5_local.h
> + $(OPENSSL_PATH)/crypto/modes/modes_local.h
> + $(OPENSSL_PATH)/crypto/objects/obj_dat.h
> + $(OPENSSL_PATH)/crypto/objects/obj_local.h
> + $(OPENSSL_PATH)/crypto/objects/obj_xref.h
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_local.h
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_local.h
> + $(OPENSSL_PATH)/crypto/rand/rand_local.h
> + $(OPENSSL_PATH)/crypto/rsa/rsa_local.h
> + $(OPENSSL_PATH)/crypto/sha/sha_local.h
> + $(OPENSSL_PATH)/crypto/siphash/siphash_local.h
> + $(OPENSSL_PATH)/crypto/sm3/sm3_local.h
> + $(OPENSSL_PATH)/crypto/store/store_local.h
> + $(OPENSSL_PATH)/crypto/ui/ui_local.h
> + $(OPENSSL_PATH)/crypto/x509/x509_local.h
> + $(OPENSSL_PATH)/crypto/x509v3/ext_dat.h
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_local.h
> + $(OPENSSL_PATH)/crypto/x509v3/standard_exts.h
> + $(OPENSSL_PATH)/crypto/x509v3/v3_admis.h
> + $(OPENSSL_PATH)/ssl/bio_ssl.c
> + $(OPENSSL_PATH)/ssl/d1_lib.c
> + $(OPENSSL_PATH)/ssl/d1_msg.c
> + $(OPENSSL_PATH)/ssl/d1_srtp.c
> + $(OPENSSL_PATH)/ssl/methods.c
> + $(OPENSSL_PATH)/ssl/packet.c
> + $(OPENSSL_PATH)/ssl/pqueue.c
> + $(OPENSSL_PATH)/ssl/record/dtls1_bitmap.c
> + $(OPENSSL_PATH)/ssl/record/rec_layer_d1.c
> + $(OPENSSL_PATH)/ssl/record/rec_layer_s3.c
> + $(OPENSSL_PATH)/ssl/record/ssl3_buffer.c
> + $(OPENSSL_PATH)/ssl/record/ssl3_record.c
> + $(OPENSSL_PATH)/ssl/record/ssl3_record_tls13.c
> + $(OPENSSL_PATH)/ssl/s3_cbc.c
> + $(OPENSSL_PATH)/ssl/s3_enc.c
> + $(OPENSSL_PATH)/ssl/s3_lib.c
> + $(OPENSSL_PATH)/ssl/s3_msg.c
> + $(OPENSSL_PATH)/ssl/ssl_asn1.c
> + $(OPENSSL_PATH)/ssl/ssl_cert.c
> + $(OPENSSL_PATH)/ssl/ssl_ciph.c
> + $(OPENSSL_PATH)/ssl/ssl_conf.c
> + $(OPENSSL_PATH)/ssl/ssl_err.c
> + $(OPENSSL_PATH)/ssl/ssl_init.c
> + $(OPENSSL_PATH)/ssl/ssl_lib.c
> + $(OPENSSL_PATH)/ssl/ssl_mcnf.c
> + $(OPENSSL_PATH)/ssl/ssl_rsa.c
> + $(OPENSSL_PATH)/ssl/ssl_sess.c
> + $(OPENSSL_PATH)/ssl/ssl_stat.c
> + $(OPENSSL_PATH)/ssl/ssl_txt.c
> + $(OPENSSL_PATH)/ssl/ssl_utst.c
> + $(OPENSSL_PATH)/ssl/statem/extensions.c
> + $(OPENSSL_PATH)/ssl/statem/extensions_clnt.c
> + $(OPENSSL_PATH)/ssl/statem/extensions_cust.c
> + $(OPENSSL_PATH)/ssl/statem/extensions_srvr.c
> + $(OPENSSL_PATH)/ssl/statem/statem.c
> + $(OPENSSL_PATH)/ssl/statem/statem_clnt.c
> + $(OPENSSL_PATH)/ssl/statem/statem_dtls.c
> + $(OPENSSL_PATH)/ssl/statem/statem_lib.c
> + $(OPENSSL_PATH)/ssl/statem/statem_srvr.c
> + $(OPENSSL_PATH)/ssl/t1_enc.c
> + $(OPENSSL_PATH)/ssl/t1_lib.c
> + $(OPENSSL_PATH)/ssl/t1_trce.c
> + $(OPENSSL_PATH)/ssl/tls13_enc.c
> + $(OPENSSL_PATH)/ssl/tls_srp.c
> + $(OPENSSL_PATH)/ssl/packet_local.h
> + $(OPENSSL_PATH)/ssl/ssl_cert_table.h
> + $(OPENSSL_PATH)/ssl/ssl_local.h
> + $(OPENSSL_PATH)/ssl/record/record.h
> + $(OPENSSL_PATH)/ssl/record/record_local.h
> + $(OPENSSL_PATH)/ssl/statem/statem.h
> + $(OPENSSL_PATH)/ssl/statem/statem_local.h
> +# Autogenerated files list ends here
> + buildinf.h
> + ossl_store.c
> + rand_pool.c
> + X64/ApiHooks.c
> +
> +[Packages]
> + MdePkg/MdePkg.dec
> + CryptoPkg/CryptoPkg.dec
> +
> +[LibraryClasses]
> + BaseLib
> + DebugLib
> + RngLib
> + PrintLib
> +
> +[BuildOptions]
> + #
> + # Disables the following Visual Studio compiler warnings brought by openssl
> source,
> + # so we do not break the build with /WX option:
> + # C4090: 'function' : different 'const' qualifiers
> + # C4132: 'object' : const object should be initialized (tls13_enc.c)
> + # C4210: nonstandard extension used: function given file scope
> + # C4244: conversion from type1 to type2, possible loss of data
> + # C4245: conversion from type1 to type2, signed/unsigned mismatch
> + # C4267: conversion from size_t to type, possible loss of data
> + # C4306: 'identifier' : conversion from 'type1' to 'type2' of greater size
> + # C4310: cast truncates constant value
> + # C4389: 'operator' : signed/unsigned mismatch (xxxx)
> + # C4700: uninitialized local variable 'name' used. (conf_sap.c(71))
> + # C4702: unreachable code
> + # C4706: assignment within conditional expression
> + # C4819: The file contains a character that cannot be represented in the
> current code page
> + #
> + MSFT:*_*_X64_CC_FLAGS = -U_WIN32 -U_WIN64 -U_MSC_VER
> $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) /wd4090 /wd4132 /wd4210
> /wd4244 /wd4245 /wd4267 /wd4306 /wd4310 /wd4700 /wd4389 /wd4702
> /wd4706 /wd4819
> +
> + INTEL:*_*_X64_CC_FLAGS = -U_WIN32 -U_WIN64 -U_MSC_VER -U__ICC
> $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) /w
> +
> + #
> + # Suppress the following build warnings in openssl so we don't break the build
> with -Werror
> + # -Werror=maybe-uninitialized: there exist some other paths for which the
> variable is not initialized.
> + # -Werror=format: Check calls to printf and scanf, etc., to make sure that the
> arguments supplied have
> + # types appropriate to the format string specified.
> + # -Werror=unused-but-set-variable: Warn whenever a local variable is
> assigned to, but otherwise unused (aside from its declaration).
> + #
> + GCC:*_*_X64_CC_FLAGS = -UWIN32 -U_WIN32 -U_WIN64
> $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) -Wno-error=maybe-uninitialized
> -Wno-error=format -Wno-format -Wno-error=unused-but-set-variable -
> DNO_MSABI_VA_FUNCS
> +
> + # suppress the following warnings in openssl so we don't break the build with
> warnings-as-errors:
> + # 1295: Deprecated declaration <entity> - give arg types
> + # 550: <entity> was set but never used
> + # 1293: assignment in condition
> + # 111: statement is unreachable (invariably "break;" after "return X;" in case
> statement)
> + # 68: integer conversion resulted in a change of sign ("if (Status == -1)")
> + # 177: <entity> was declared but never referenced
> + # 223: function <entity> declared implicitly
> + # 144: a value of type <type> cannot be used to initialize an entity of type
> <type>
> + # 513: a value of type <type> cannot be assigned to an entity of type <type>
> + # 188: enumerated type mixed with another type (i.e. passing an integer as an
> enum without a cast)
> + # 1296: Extended constant initialiser used
> + # 128: loop is not reachable - may be emitted inappropriately if code follows
> a conditional return
> + # from the function that evaluates to true at compile time
> + # 546: transfer of control bypasses initialization - may be emitted
> inappropriately if the uninitialized
> + # variable is never referenced after the jump
> + # 1: ignore "#1-D: last line of file ends without a newline"
> + # 3017: <entity> may be used before being set (NOTE: This was fixed in
> OpenSSL 1.1 HEAD with
> + # commit d9b8b89bec4480de3a10bdaf9425db371c19145b, and can be
> dropped then.)
> + XCODE:*_*_X64_CC_FLAGS = -mmmx -msse -U_WIN32 -U_WIN64
> $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) -w -std=c99 -Wno-
> error=uninitialized
> diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf
> b/CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf
> new file mode 100644
> index 0000000000..4ffdd8cd06
> --- /dev/null
> +++ b/CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf
> @@ -0,0 +1,653 @@
> +## @file
> +# This module provides OpenSSL Library implementation.
> +#
> +# Copyright (c) 2010 - 2020, Intel Corporation. All rights reserved.<BR>
> +# (C) Copyright 2020 Hewlett Packard Enterprise Development LP<BR>
> +# SPDX-License-Identifier: BSD-2-Clause-Patent
> +#
> +##
> +
> +[Defines]
> + INF_VERSION = 0x00010005
> + BASE_NAME = OpensslLibX64Gcc
> + MODULE_UNI_FILE = OpensslLib.uni
> + FILE_GUID = DD90DB9D-6A3F-4F2B-87BF-A8F2BBEF982F
> + MODULE_TYPE = BASE
> + VERSION_STRING = 1.0
> + LIBRARY_CLASS = OpensslLib
> + DEFINE OPENSSL_PATH = openssl
> + DEFINE OPENSSL_FLAGS = -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT
> -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE
> + DEFINE OPENSSL_FLAGS_CONFIG = -DOPENSSL_CPUID_OBJ -DSHA1_ASM -
> DSHA256_ASM -DSHA512_ASM -DAESNI_ASM -DVPAES_ASM -DGHASH_ASM
> + CONSTRUCTOR = OpensslLibConstructor
> +
> +#
> +# VALID_ARCHITECTURES = X64
> +#
> +
> +[Sources.X64]
> + OpensslLibConstructor.c
> + $(OPENSSL_PATH)/e_os.h
> + $(OPENSSL_PATH)/ms/uplink.h
> +# Autogenerated files list starts here
> + X64Gcc/crypto/aes/aesni-mb-x86_64.S
> + X64Gcc/crypto/aes/aesni-sha1-x86_64.S
> + X64Gcc/crypto/aes/aesni-sha256-x86_64.S
> + X64Gcc/crypto/aes/aesni-x86_64.S
> + X64Gcc/crypto/aes/vpaes-x86_64.S
> + X64Gcc/crypto/modes/aesni-gcm-x86_64.S
> + X64Gcc/crypto/modes/ghash-x86_64.S
> + X64Gcc/crypto/sha/sha1-mb-x86_64.S
> + X64Gcc/crypto/sha/sha1-x86_64.S
> + X64Gcc/crypto/sha/sha256-mb-x86_64.S
> + X64Gcc/crypto/sha/sha256-x86_64.S
> + X64Gcc/crypto/sha/sha512-x86_64.S
> + X64Gcc/crypto/x86_64cpuid.S
> + $(OPENSSL_PATH)/crypto/aes/aes_cbc.c
> + $(OPENSSL_PATH)/crypto/aes/aes_cfb.c
> + $(OPENSSL_PATH)/crypto/aes/aes_core.c
> + $(OPENSSL_PATH)/crypto/aes/aes_ige.c
> + $(OPENSSL_PATH)/crypto/aes/aes_misc.c
> + $(OPENSSL_PATH)/crypto/aes/aes_ofb.c
> + $(OPENSSL_PATH)/crypto/aes/aes_wrap.c
> + $(OPENSSL_PATH)/crypto/aria/aria.c
> + $(OPENSSL_PATH)/crypto/asn1/a_bitstr.c
> + $(OPENSSL_PATH)/crypto/asn1/a_d2i_fp.c
> + $(OPENSSL_PATH)/crypto/asn1/a_digest.c
> + $(OPENSSL_PATH)/crypto/asn1/a_dup.c
> + $(OPENSSL_PATH)/crypto/asn1/a_gentm.c
> + $(OPENSSL_PATH)/crypto/asn1/a_i2d_fp.c
> + $(OPENSSL_PATH)/crypto/asn1/a_int.c
> + $(OPENSSL_PATH)/crypto/asn1/a_mbstr.c
> + $(OPENSSL_PATH)/crypto/asn1/a_object.c
> + $(OPENSSL_PATH)/crypto/asn1/a_octet.c
> + $(OPENSSL_PATH)/crypto/asn1/a_print.c
> + $(OPENSSL_PATH)/crypto/asn1/a_sign.c
> + $(OPENSSL_PATH)/crypto/asn1/a_strex.c
> + $(OPENSSL_PATH)/crypto/asn1/a_strnid.c
> + $(OPENSSL_PATH)/crypto/asn1/a_time.c
> + $(OPENSSL_PATH)/crypto/asn1/a_type.c
> + $(OPENSSL_PATH)/crypto/asn1/a_utctm.c
> + $(OPENSSL_PATH)/crypto/asn1/a_utf8.c
> + $(OPENSSL_PATH)/crypto/asn1/a_verify.c
> + $(OPENSSL_PATH)/crypto/asn1/ameth_lib.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_err.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_gen.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_item_list.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_lib.c
> + $(OPENSSL_PATH)/crypto/asn1/asn1_par.c
> + $(OPENSSL_PATH)/crypto/asn1/asn_mime.c
> + $(OPENSSL_PATH)/crypto/asn1/asn_moid.c
> + $(OPENSSL_PATH)/crypto/asn1/asn_mstbl.c
> + $(OPENSSL_PATH)/crypto/asn1/asn_pack.c
> + $(OPENSSL_PATH)/crypto/asn1/bio_asn1.c
> + $(OPENSSL_PATH)/crypto/asn1/bio_ndef.c
> + $(OPENSSL_PATH)/crypto/asn1/d2i_pr.c
> + $(OPENSSL_PATH)/crypto/asn1/d2i_pu.c
> + $(OPENSSL_PATH)/crypto/asn1/evp_asn1.c
> + $(OPENSSL_PATH)/crypto/asn1/f_int.c
> + $(OPENSSL_PATH)/crypto/asn1/f_string.c
> + $(OPENSSL_PATH)/crypto/asn1/i2d_pr.c
> + $(OPENSSL_PATH)/crypto/asn1/i2d_pu.c
> + $(OPENSSL_PATH)/crypto/asn1/n_pkey.c
> + $(OPENSSL_PATH)/crypto/asn1/nsseq.c
> + $(OPENSSL_PATH)/crypto/asn1/p5_pbe.c
> + $(OPENSSL_PATH)/crypto/asn1/p5_pbev2.c
> + $(OPENSSL_PATH)/crypto/asn1/p5_scrypt.c
> + $(OPENSSL_PATH)/crypto/asn1/p8_pkey.c
> + $(OPENSSL_PATH)/crypto/asn1/t_bitst.c
> + $(OPENSSL_PATH)/crypto/asn1/t_pkey.c
> + $(OPENSSL_PATH)/crypto/asn1/t_spki.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_dec.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_enc.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_fre.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_new.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_prn.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_scn.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_typ.c
> + $(OPENSSL_PATH)/crypto/asn1/tasn_utl.c
> + $(OPENSSL_PATH)/crypto/asn1/x_algor.c
> + $(OPENSSL_PATH)/crypto/asn1/x_bignum.c
> + $(OPENSSL_PATH)/crypto/asn1/x_info.c
> + $(OPENSSL_PATH)/crypto/asn1/x_int64.c
> + $(OPENSSL_PATH)/crypto/asn1/x_long.c
> + $(OPENSSL_PATH)/crypto/asn1/x_pkey.c
> + $(OPENSSL_PATH)/crypto/asn1/x_sig.c
> + $(OPENSSL_PATH)/crypto/asn1/x_spki.c
> + $(OPENSSL_PATH)/crypto/asn1/x_val.c
> + $(OPENSSL_PATH)/crypto/async/arch/async_null.c
> + $(OPENSSL_PATH)/crypto/async/arch/async_posix.c
> + $(OPENSSL_PATH)/crypto/async/arch/async_win.c
> + $(OPENSSL_PATH)/crypto/async/async.c
> + $(OPENSSL_PATH)/crypto/async/async_err.c
> + $(OPENSSL_PATH)/crypto/async/async_wait.c
> + $(OPENSSL_PATH)/crypto/bio/b_addr.c
> + $(OPENSSL_PATH)/crypto/bio/b_dump.c
> + $(OPENSSL_PATH)/crypto/bio/b_sock.c
> + $(OPENSSL_PATH)/crypto/bio/b_sock2.c
> + $(OPENSSL_PATH)/crypto/bio/bf_buff.c
> + $(OPENSSL_PATH)/crypto/bio/bf_lbuf.c
> + $(OPENSSL_PATH)/crypto/bio/bf_nbio.c
> + $(OPENSSL_PATH)/crypto/bio/bf_null.c
> + $(OPENSSL_PATH)/crypto/bio/bio_cb.c
> + $(OPENSSL_PATH)/crypto/bio/bio_err.c
> + $(OPENSSL_PATH)/crypto/bio/bio_lib.c
> + $(OPENSSL_PATH)/crypto/bio/bio_meth.c
> + $(OPENSSL_PATH)/crypto/bio/bss_acpt.c
> + $(OPENSSL_PATH)/crypto/bio/bss_bio.c
> + $(OPENSSL_PATH)/crypto/bio/bss_conn.c
> + $(OPENSSL_PATH)/crypto/bio/bss_dgram.c
> + $(OPENSSL_PATH)/crypto/bio/bss_fd.c
> + $(OPENSSL_PATH)/crypto/bio/bss_file.c
> + $(OPENSSL_PATH)/crypto/bio/bss_log.c
> + $(OPENSSL_PATH)/crypto/bio/bss_mem.c
> + $(OPENSSL_PATH)/crypto/bio/bss_null.c
> + $(OPENSSL_PATH)/crypto/bio/bss_sock.c
> + $(OPENSSL_PATH)/crypto/bn/bn_add.c
> + $(OPENSSL_PATH)/crypto/bn/bn_asm.c
> + $(OPENSSL_PATH)/crypto/bn/bn_blind.c
> + $(OPENSSL_PATH)/crypto/bn/bn_const.c
> + $(OPENSSL_PATH)/crypto/bn/bn_ctx.c
> + $(OPENSSL_PATH)/crypto/bn/bn_depr.c
> + $(OPENSSL_PATH)/crypto/bn/bn_dh.c
> + $(OPENSSL_PATH)/crypto/bn/bn_div.c
> + $(OPENSSL_PATH)/crypto/bn/bn_err.c
> + $(OPENSSL_PATH)/crypto/bn/bn_exp.c
> + $(OPENSSL_PATH)/crypto/bn/bn_exp2.c
> + $(OPENSSL_PATH)/crypto/bn/bn_gcd.c
> + $(OPENSSL_PATH)/crypto/bn/bn_gf2m.c
> + $(OPENSSL_PATH)/crypto/bn/bn_intern.c
> + $(OPENSSL_PATH)/crypto/bn/bn_kron.c
> + $(OPENSSL_PATH)/crypto/bn/bn_lib.c
> + $(OPENSSL_PATH)/crypto/bn/bn_mod.c
> + $(OPENSSL_PATH)/crypto/bn/bn_mont.c
> + $(OPENSSL_PATH)/crypto/bn/bn_mpi.c
> + $(OPENSSL_PATH)/crypto/bn/bn_mul.c
> + $(OPENSSL_PATH)/crypto/bn/bn_nist.c
> + $(OPENSSL_PATH)/crypto/bn/bn_prime.c
> + $(OPENSSL_PATH)/crypto/bn/bn_print.c
> + $(OPENSSL_PATH)/crypto/bn/bn_rand.c
> + $(OPENSSL_PATH)/crypto/bn/bn_recp.c
> + $(OPENSSL_PATH)/crypto/bn/bn_shift.c
> + $(OPENSSL_PATH)/crypto/bn/bn_sqr.c
> + $(OPENSSL_PATH)/crypto/bn/bn_sqrt.c
> + $(OPENSSL_PATH)/crypto/bn/bn_srp.c
> + $(OPENSSL_PATH)/crypto/bn/bn_word.c
> + $(OPENSSL_PATH)/crypto/bn/bn_x931p.c
> + $(OPENSSL_PATH)/crypto/buffer/buf_err.c
> + $(OPENSSL_PATH)/crypto/buffer/buffer.c
> + $(OPENSSL_PATH)/crypto/cmac/cm_ameth.c
> + $(OPENSSL_PATH)/crypto/cmac/cm_pmeth.c
> + $(OPENSSL_PATH)/crypto/cmac/cmac.c
> + $(OPENSSL_PATH)/crypto/comp/c_zlib.c
> + $(OPENSSL_PATH)/crypto/comp/comp_err.c
> + $(OPENSSL_PATH)/crypto/comp/comp_lib.c
> + $(OPENSSL_PATH)/crypto/conf/conf_api.c
> + $(OPENSSL_PATH)/crypto/conf/conf_def.c
> + $(OPENSSL_PATH)/crypto/conf/conf_err.c
> + $(OPENSSL_PATH)/crypto/conf/conf_lib.c
> + $(OPENSSL_PATH)/crypto/conf/conf_mall.c
> + $(OPENSSL_PATH)/crypto/conf/conf_mod.c
> + $(OPENSSL_PATH)/crypto/conf/conf_sap.c
> + $(OPENSSL_PATH)/crypto/conf/conf_ssl.c
> + $(OPENSSL_PATH)/crypto/cpt_err.c
> + $(OPENSSL_PATH)/crypto/cryptlib.c
> + $(OPENSSL_PATH)/crypto/ctype.c
> + $(OPENSSL_PATH)/crypto/cversion.c
> + $(OPENSSL_PATH)/crypto/dh/dh_ameth.c
> + $(OPENSSL_PATH)/crypto/dh/dh_asn1.c
> + $(OPENSSL_PATH)/crypto/dh/dh_check.c
> + $(OPENSSL_PATH)/crypto/dh/dh_depr.c
> + $(OPENSSL_PATH)/crypto/dh/dh_err.c
> + $(OPENSSL_PATH)/crypto/dh/dh_gen.c
> + $(OPENSSL_PATH)/crypto/dh/dh_kdf.c
> + $(OPENSSL_PATH)/crypto/dh/dh_key.c
> + $(OPENSSL_PATH)/crypto/dh/dh_lib.c
> + $(OPENSSL_PATH)/crypto/dh/dh_meth.c
> + $(OPENSSL_PATH)/crypto/dh/dh_pmeth.c
> + $(OPENSSL_PATH)/crypto/dh/dh_prn.c
> + $(OPENSSL_PATH)/crypto/dh/dh_rfc5114.c
> + $(OPENSSL_PATH)/crypto/dh/dh_rfc7919.c
> + $(OPENSSL_PATH)/crypto/dso/dso_dl.c
> + $(OPENSSL_PATH)/crypto/dso/dso_dlfcn.c
> + $(OPENSSL_PATH)/crypto/dso/dso_err.c
> + $(OPENSSL_PATH)/crypto/dso/dso_lib.c
> + $(OPENSSL_PATH)/crypto/dso/dso_openssl.c
> + $(OPENSSL_PATH)/crypto/dso/dso_vms.c
> + $(OPENSSL_PATH)/crypto/dso/dso_win32.c
> + $(OPENSSL_PATH)/crypto/ebcdic.c
> + $(OPENSSL_PATH)/crypto/err/err.c
> + $(OPENSSL_PATH)/crypto/err/err_prn.c
> + $(OPENSSL_PATH)/crypto/evp/bio_b64.c
> + $(OPENSSL_PATH)/crypto/evp/bio_enc.c
> + $(OPENSSL_PATH)/crypto/evp/bio_md.c
> + $(OPENSSL_PATH)/crypto/evp/bio_ok.c
> + $(OPENSSL_PATH)/crypto/evp/c_allc.c
> + $(OPENSSL_PATH)/crypto/evp/c_alld.c
> + $(OPENSSL_PATH)/crypto/evp/cmeth_lib.c
> + $(OPENSSL_PATH)/crypto/evp/digest.c
> + $(OPENSSL_PATH)/crypto/evp/e_aes.c
> + $(OPENSSL_PATH)/crypto/evp/e_aes_cbc_hmac_sha1.c
> + $(OPENSSL_PATH)/crypto/evp/e_aes_cbc_hmac_sha256.c
> + $(OPENSSL_PATH)/crypto/evp/e_aria.c
> + $(OPENSSL_PATH)/crypto/evp/e_bf.c
> + $(OPENSSL_PATH)/crypto/evp/e_camellia.c
> + $(OPENSSL_PATH)/crypto/evp/e_cast.c
> + $(OPENSSL_PATH)/crypto/evp/e_chacha20_poly1305.c
> + $(OPENSSL_PATH)/crypto/evp/e_des.c
> + $(OPENSSL_PATH)/crypto/evp/e_des3.c
> + $(OPENSSL_PATH)/crypto/evp/e_idea.c
> + $(OPENSSL_PATH)/crypto/evp/e_null.c
> + $(OPENSSL_PATH)/crypto/evp/e_old.c
> + $(OPENSSL_PATH)/crypto/evp/e_rc2.c
> + $(OPENSSL_PATH)/crypto/evp/e_rc4.c
> + $(OPENSSL_PATH)/crypto/evp/e_rc4_hmac_md5.c
> + $(OPENSSL_PATH)/crypto/evp/e_rc5.c
> + $(OPENSSL_PATH)/crypto/evp/e_seed.c
> + $(OPENSSL_PATH)/crypto/evp/e_sm4.c
> + $(OPENSSL_PATH)/crypto/evp/e_xcbc_d.c
> + $(OPENSSL_PATH)/crypto/evp/encode.c
> + $(OPENSSL_PATH)/crypto/evp/evp_cnf.c
> + $(OPENSSL_PATH)/crypto/evp/evp_enc.c
> + $(OPENSSL_PATH)/crypto/evp/evp_err.c
> + $(OPENSSL_PATH)/crypto/evp/evp_key.c
> + $(OPENSSL_PATH)/crypto/evp/evp_lib.c
> + $(OPENSSL_PATH)/crypto/evp/evp_pbe.c
> + $(OPENSSL_PATH)/crypto/evp/evp_pkey.c
> + $(OPENSSL_PATH)/crypto/evp/m_md2.c
> + $(OPENSSL_PATH)/crypto/evp/m_md4.c
> + $(OPENSSL_PATH)/crypto/evp/m_md5.c
> + $(OPENSSL_PATH)/crypto/evp/m_md5_sha1.c
> + $(OPENSSL_PATH)/crypto/evp/m_mdc2.c
> + $(OPENSSL_PATH)/crypto/evp/m_null.c
> + $(OPENSSL_PATH)/crypto/evp/m_ripemd.c
> + $(OPENSSL_PATH)/crypto/evp/m_sha1.c
> + $(OPENSSL_PATH)/crypto/evp/m_sha3.c
> + $(OPENSSL_PATH)/crypto/evp/m_sigver.c
> + $(OPENSSL_PATH)/crypto/evp/m_wp.c
> + $(OPENSSL_PATH)/crypto/evp/names.c
> + $(OPENSSL_PATH)/crypto/evp/p5_crpt.c
> + $(OPENSSL_PATH)/crypto/evp/p5_crpt2.c
> + $(OPENSSL_PATH)/crypto/evp/p_dec.c
> + $(OPENSSL_PATH)/crypto/evp/p_enc.c
> + $(OPENSSL_PATH)/crypto/evp/p_lib.c
> + $(OPENSSL_PATH)/crypto/evp/p_open.c
> + $(OPENSSL_PATH)/crypto/evp/p_seal.c
> + $(OPENSSL_PATH)/crypto/evp/p_sign.c
> + $(OPENSSL_PATH)/crypto/evp/p_verify.c
> + $(OPENSSL_PATH)/crypto/evp/pbe_scrypt.c
> + $(OPENSSL_PATH)/crypto/evp/pmeth_fn.c
> + $(OPENSSL_PATH)/crypto/evp/pmeth_gn.c
> + $(OPENSSL_PATH)/crypto/evp/pmeth_lib.c
> + $(OPENSSL_PATH)/crypto/ex_data.c
> + $(OPENSSL_PATH)/crypto/getenv.c
> + $(OPENSSL_PATH)/crypto/hmac/hm_ameth.c
> + $(OPENSSL_PATH)/crypto/hmac/hm_pmeth.c
> + $(OPENSSL_PATH)/crypto/hmac/hmac.c
> + $(OPENSSL_PATH)/crypto/init.c
> + $(OPENSSL_PATH)/crypto/kdf/hkdf.c
> + $(OPENSSL_PATH)/crypto/kdf/kdf_err.c
> + $(OPENSSL_PATH)/crypto/kdf/scrypt.c
> + $(OPENSSL_PATH)/crypto/kdf/tls1_prf.c
> + $(OPENSSL_PATH)/crypto/lhash/lh_stats.c
> + $(OPENSSL_PATH)/crypto/lhash/lhash.c
> + $(OPENSSL_PATH)/crypto/md5/md5_dgst.c
> + $(OPENSSL_PATH)/crypto/md5/md5_one.c
> + $(OPENSSL_PATH)/crypto/mem.c
> + $(OPENSSL_PATH)/crypto/mem_dbg.c
> + $(OPENSSL_PATH)/crypto/mem_sec.c
> + $(OPENSSL_PATH)/crypto/modes/cbc128.c
> + $(OPENSSL_PATH)/crypto/modes/ccm128.c
> + $(OPENSSL_PATH)/crypto/modes/cfb128.c
> + $(OPENSSL_PATH)/crypto/modes/ctr128.c
> + $(OPENSSL_PATH)/crypto/modes/cts128.c
> + $(OPENSSL_PATH)/crypto/modes/gcm128.c
> + $(OPENSSL_PATH)/crypto/modes/ocb128.c
> + $(OPENSSL_PATH)/crypto/modes/ofb128.c
> + $(OPENSSL_PATH)/crypto/modes/wrap128.c
> + $(OPENSSL_PATH)/crypto/modes/xts128.c
> + $(OPENSSL_PATH)/crypto/o_dir.c
> + $(OPENSSL_PATH)/crypto/o_fips.c
> + $(OPENSSL_PATH)/crypto/o_fopen.c
> + $(OPENSSL_PATH)/crypto/o_init.c
> + $(OPENSSL_PATH)/crypto/o_str.c
> + $(OPENSSL_PATH)/crypto/o_time.c
> + $(OPENSSL_PATH)/crypto/objects/o_names.c
> + $(OPENSSL_PATH)/crypto/objects/obj_dat.c
> + $(OPENSSL_PATH)/crypto/objects/obj_err.c
> + $(OPENSSL_PATH)/crypto/objects/obj_lib.c
> + $(OPENSSL_PATH)/crypto/objects/obj_xref.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_asn.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_cl.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_err.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_ext.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_ht.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_lib.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_prn.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_srv.c
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_vfy.c
> + $(OPENSSL_PATH)/crypto/ocsp/v3_ocsp.c
> + $(OPENSSL_PATH)/crypto/pem/pem_all.c
> + $(OPENSSL_PATH)/crypto/pem/pem_err.c
> + $(OPENSSL_PATH)/crypto/pem/pem_info.c
> + $(OPENSSL_PATH)/crypto/pem/pem_lib.c
> + $(OPENSSL_PATH)/crypto/pem/pem_oth.c
> + $(OPENSSL_PATH)/crypto/pem/pem_pk8.c
> + $(OPENSSL_PATH)/crypto/pem/pem_pkey.c
> + $(OPENSSL_PATH)/crypto/pem/pem_sign.c
> + $(OPENSSL_PATH)/crypto/pem/pem_x509.c
> + $(OPENSSL_PATH)/crypto/pem/pem_xaux.c
> + $(OPENSSL_PATH)/crypto/pem/pvkfmt.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_add.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_asn.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_attr.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_crpt.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_crt.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_decr.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_init.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_key.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_kiss.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_mutl.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_npas.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_p8d.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_p8e.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_sbag.c
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_utl.c
> + $(OPENSSL_PATH)/crypto/pkcs12/pk12err.c
> + $(OPENSSL_PATH)/crypto/pkcs7/bio_pk7.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_asn1.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_attr.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_doit.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_lib.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_mime.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pk7_smime.c
> + $(OPENSSL_PATH)/crypto/pkcs7/pkcs7err.c
> + $(OPENSSL_PATH)/crypto/rand/drbg_ctr.c
> + $(OPENSSL_PATH)/crypto/rand/drbg_lib.c
> + $(OPENSSL_PATH)/crypto/rand/rand_egd.c
> + $(OPENSSL_PATH)/crypto/rand/rand_err.c
> + $(OPENSSL_PATH)/crypto/rand/rand_lib.c
> + $(OPENSSL_PATH)/crypto/rand/rand_unix.c
> + $(OPENSSL_PATH)/crypto/rand/rand_vms.c
> + $(OPENSSL_PATH)/crypto/rand/rand_win.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_ameth.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_asn1.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_chk.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_crpt.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_depr.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_err.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_gen.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_lib.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_meth.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_mp.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_none.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_oaep.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_ossl.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_pk1.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_pmeth.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_prn.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_pss.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_saos.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_sign.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_ssl.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_x931.c
> + $(OPENSSL_PATH)/crypto/rsa/rsa_x931g.c
> + $(OPENSSL_PATH)/crypto/sha/keccak1600.c
> + $(OPENSSL_PATH)/crypto/sha/sha1_one.c
> + $(OPENSSL_PATH)/crypto/sha/sha1dgst.c
> + $(OPENSSL_PATH)/crypto/sha/sha256.c
> + $(OPENSSL_PATH)/crypto/sha/sha512.c
> + $(OPENSSL_PATH)/crypto/siphash/siphash.c
> + $(OPENSSL_PATH)/crypto/siphash/siphash_ameth.c
> + $(OPENSSL_PATH)/crypto/siphash/siphash_pmeth.c
> + $(OPENSSL_PATH)/crypto/sm3/m_sm3.c
> + $(OPENSSL_PATH)/crypto/sm3/sm3.c
> + $(OPENSSL_PATH)/crypto/sm4/sm4.c
> + $(OPENSSL_PATH)/crypto/stack/stack.c
> + $(OPENSSL_PATH)/crypto/threads_none.c
> + $(OPENSSL_PATH)/crypto/threads_pthread.c
> + $(OPENSSL_PATH)/crypto/threads_win.c
> + $(OPENSSL_PATH)/crypto/txt_db/txt_db.c
> + $(OPENSSL_PATH)/crypto/ui/ui_err.c
> + $(OPENSSL_PATH)/crypto/ui/ui_lib.c
> + $(OPENSSL_PATH)/crypto/ui/ui_null.c
> + $(OPENSSL_PATH)/crypto/ui/ui_openssl.c
> + $(OPENSSL_PATH)/crypto/ui/ui_util.c
> + $(OPENSSL_PATH)/crypto/uid.c
> + $(OPENSSL_PATH)/crypto/x509/by_dir.c
> + $(OPENSSL_PATH)/crypto/x509/by_file.c
> + $(OPENSSL_PATH)/crypto/x509/t_crl.c
> + $(OPENSSL_PATH)/crypto/x509/t_req.c
> + $(OPENSSL_PATH)/crypto/x509/t_x509.c
> + $(OPENSSL_PATH)/crypto/x509/x509_att.c
> + $(OPENSSL_PATH)/crypto/x509/x509_cmp.c
> + $(OPENSSL_PATH)/crypto/x509/x509_d2.c
> + $(OPENSSL_PATH)/crypto/x509/x509_def.c
> + $(OPENSSL_PATH)/crypto/x509/x509_err.c
> + $(OPENSSL_PATH)/crypto/x509/x509_ext.c
> + $(OPENSSL_PATH)/crypto/x509/x509_lu.c
> + $(OPENSSL_PATH)/crypto/x509/x509_meth.c
> + $(OPENSSL_PATH)/crypto/x509/x509_obj.c
> + $(OPENSSL_PATH)/crypto/x509/x509_r2x.c
> + $(OPENSSL_PATH)/crypto/x509/x509_req.c
> + $(OPENSSL_PATH)/crypto/x509/x509_set.c
> + $(OPENSSL_PATH)/crypto/x509/x509_trs.c
> + $(OPENSSL_PATH)/crypto/x509/x509_txt.c
> + $(OPENSSL_PATH)/crypto/x509/x509_v3.c
> + $(OPENSSL_PATH)/crypto/x509/x509_vfy.c
> + $(OPENSSL_PATH)/crypto/x509/x509_vpm.c
> + $(OPENSSL_PATH)/crypto/x509/x509cset.c
> + $(OPENSSL_PATH)/crypto/x509/x509name.c
> + $(OPENSSL_PATH)/crypto/x509/x509rset.c
> + $(OPENSSL_PATH)/crypto/x509/x509spki.c
> + $(OPENSSL_PATH)/crypto/x509/x509type.c
> + $(OPENSSL_PATH)/crypto/x509/x_all.c
> + $(OPENSSL_PATH)/crypto/x509/x_attrib.c
> + $(OPENSSL_PATH)/crypto/x509/x_crl.c
> + $(OPENSSL_PATH)/crypto/x509/x_exten.c
> + $(OPENSSL_PATH)/crypto/x509/x_name.c
> + $(OPENSSL_PATH)/crypto/x509/x_pubkey.c
> + $(OPENSSL_PATH)/crypto/x509/x_req.c
> + $(OPENSSL_PATH)/crypto/x509/x_x509.c
> + $(OPENSSL_PATH)/crypto/x509/x_x509a.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_cache.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_data.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_lib.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_map.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_node.c
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_tree.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_addr.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_admis.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_akey.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_akeya.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_alt.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_asid.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_bcons.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_bitst.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_conf.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_cpols.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_crld.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_enum.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_extku.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_genn.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_ia5.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_info.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_int.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_lib.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_ncons.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pci.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pcia.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pcons.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pku.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_pmaps.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_prn.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_purp.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_skey.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_sxnet.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_tlsf.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3_utl.c
> + $(OPENSSL_PATH)/crypto/x509v3/v3err.c
> + $(OPENSSL_PATH)/crypto/arm_arch.h
> + $(OPENSSL_PATH)/crypto/mips_arch.h
> + $(OPENSSL_PATH)/crypto/ppc_arch.h
> + $(OPENSSL_PATH)/crypto/s390x_arch.h
> + $(OPENSSL_PATH)/crypto/sparc_arch.h
> + $(OPENSSL_PATH)/crypto/vms_rms.h
> + $(OPENSSL_PATH)/crypto/aes/aes_local.h
> + $(OPENSSL_PATH)/crypto/asn1/asn1_item_list.h
> + $(OPENSSL_PATH)/crypto/asn1/asn1_local.h
> + $(OPENSSL_PATH)/crypto/asn1/charmap.h
> + $(OPENSSL_PATH)/crypto/asn1/standard_methods.h
> + $(OPENSSL_PATH)/crypto/asn1/tbl_standard.h
> + $(OPENSSL_PATH)/crypto/async/async_local.h
> + $(OPENSSL_PATH)/crypto/async/arch/async_null.h
> + $(OPENSSL_PATH)/crypto/async/arch/async_posix.h
> + $(OPENSSL_PATH)/crypto/async/arch/async_win.h
> + $(OPENSSL_PATH)/crypto/bio/bio_local.h
> + $(OPENSSL_PATH)/crypto/bn/bn_local.h
> + $(OPENSSL_PATH)/crypto/bn/bn_prime.h
> + $(OPENSSL_PATH)/crypto/bn/rsaz_exp.h
> + $(OPENSSL_PATH)/crypto/comp/comp_local.h
> + $(OPENSSL_PATH)/crypto/conf/conf_def.h
> + $(OPENSSL_PATH)/crypto/conf/conf_local.h
> + $(OPENSSL_PATH)/crypto/dh/dh_local.h
> + $(OPENSSL_PATH)/crypto/dso/dso_local.h
> + $(OPENSSL_PATH)/crypto/evp/evp_local.h
> + $(OPENSSL_PATH)/crypto/hmac/hmac_local.h
> + $(OPENSSL_PATH)/crypto/lhash/lhash_local.h
> + $(OPENSSL_PATH)/crypto/md5/md5_local.h
> + $(OPENSSL_PATH)/crypto/modes/modes_local.h
> + $(OPENSSL_PATH)/crypto/objects/obj_dat.h
> + $(OPENSSL_PATH)/crypto/objects/obj_local.h
> + $(OPENSSL_PATH)/crypto/objects/obj_xref.h
> + $(OPENSSL_PATH)/crypto/ocsp/ocsp_local.h
> + $(OPENSSL_PATH)/crypto/pkcs12/p12_local.h
> + $(OPENSSL_PATH)/crypto/rand/rand_local.h
> + $(OPENSSL_PATH)/crypto/rsa/rsa_local.h
> + $(OPENSSL_PATH)/crypto/sha/sha_local.h
> + $(OPENSSL_PATH)/crypto/siphash/siphash_local.h
> + $(OPENSSL_PATH)/crypto/sm3/sm3_local.h
> + $(OPENSSL_PATH)/crypto/store/store_local.h
> + $(OPENSSL_PATH)/crypto/ui/ui_local.h
> + $(OPENSSL_PATH)/crypto/x509/x509_local.h
> + $(OPENSSL_PATH)/crypto/x509v3/ext_dat.h
> + $(OPENSSL_PATH)/crypto/x509v3/pcy_local.h
> + $(OPENSSL_PATH)/crypto/x509v3/standard_exts.h
> + $(OPENSSL_PATH)/crypto/x509v3/v3_admis.h
> + $(OPENSSL_PATH)/ssl/bio_ssl.c
> + $(OPENSSL_PATH)/ssl/d1_lib.c
> + $(OPENSSL_PATH)/ssl/d1_msg.c
> + $(OPENSSL_PATH)/ssl/d1_srtp.c
> + $(OPENSSL_PATH)/ssl/methods.c
> + $(OPENSSL_PATH)/ssl/packet.c
> + $(OPENSSL_PATH)/ssl/pqueue.c
> + $(OPENSSL_PATH)/ssl/record/dtls1_bitmap.c
> + $(OPENSSL_PATH)/ssl/record/rec_layer_d1.c
> + $(OPENSSL_PATH)/ssl/record/rec_layer_s3.c
> + $(OPENSSL_PATH)/ssl/record/ssl3_buffer.c
> + $(OPENSSL_PATH)/ssl/record/ssl3_record.c
> + $(OPENSSL_PATH)/ssl/record/ssl3_record_tls13.c
> + $(OPENSSL_PATH)/ssl/s3_cbc.c
> + $(OPENSSL_PATH)/ssl/s3_enc.c
> + $(OPENSSL_PATH)/ssl/s3_lib.c
> + $(OPENSSL_PATH)/ssl/s3_msg.c
> + $(OPENSSL_PATH)/ssl/ssl_asn1.c
> + $(OPENSSL_PATH)/ssl/ssl_cert.c
> + $(OPENSSL_PATH)/ssl/ssl_ciph.c
> + $(OPENSSL_PATH)/ssl/ssl_conf.c
> + $(OPENSSL_PATH)/ssl/ssl_err.c
> + $(OPENSSL_PATH)/ssl/ssl_init.c
> + $(OPENSSL_PATH)/ssl/ssl_lib.c
> + $(OPENSSL_PATH)/ssl/ssl_mcnf.c
> + $(OPENSSL_PATH)/ssl/ssl_rsa.c
> + $(OPENSSL_PATH)/ssl/ssl_sess.c
> + $(OPENSSL_PATH)/ssl/ssl_stat.c
> + $(OPENSSL_PATH)/ssl/ssl_txt.c
> + $(OPENSSL_PATH)/ssl/ssl_utst.c
> + $(OPENSSL_PATH)/ssl/statem/extensions.c
> + $(OPENSSL_PATH)/ssl/statem/extensions_clnt.c
> + $(OPENSSL_PATH)/ssl/statem/extensions_cust.c
> + $(OPENSSL_PATH)/ssl/statem/extensions_srvr.c
> + $(OPENSSL_PATH)/ssl/statem/statem.c
> + $(OPENSSL_PATH)/ssl/statem/statem_clnt.c
> + $(OPENSSL_PATH)/ssl/statem/statem_dtls.c
> + $(OPENSSL_PATH)/ssl/statem/statem_lib.c
> + $(OPENSSL_PATH)/ssl/statem/statem_srvr.c
> + $(OPENSSL_PATH)/ssl/t1_enc.c
> + $(OPENSSL_PATH)/ssl/t1_lib.c
> + $(OPENSSL_PATH)/ssl/t1_trce.c
> + $(OPENSSL_PATH)/ssl/tls13_enc.c
> + $(OPENSSL_PATH)/ssl/tls_srp.c
> + $(OPENSSL_PATH)/ssl/packet_local.h
> + $(OPENSSL_PATH)/ssl/ssl_cert_table.h
> + $(OPENSSL_PATH)/ssl/ssl_local.h
> + $(OPENSSL_PATH)/ssl/record/record.h
> + $(OPENSSL_PATH)/ssl/record/record_local.h
> + $(OPENSSL_PATH)/ssl/statem/statem.h
> + $(OPENSSL_PATH)/ssl/statem/statem_local.h
> +# Autogenerated files list ends here
> + buildinf.h
> + ossl_store.c
> + rand_pool.c
> + X64/ApiHooks.c
> +
> +[Packages]
> + MdePkg/MdePkg.dec
> + CryptoPkg/CryptoPkg.dec
> +
> +[LibraryClasses]
> + BaseLib
> + DebugLib
> + RngLib
> + PrintLib
> +
> +[BuildOptions]
> + #
> + # Disables the following Visual Studio compiler warnings brought by openssl
> source,
> + # so we do not break the build with /WX option:
> + # C4090: 'function' : different 'const' qualifiers
> + # C4132: 'object' : const object should be initialized (tls13_enc.c)
> + # C4210: nonstandard extension used: function given file scope
> + # C4244: conversion from type1 to type2, possible loss of data
> + # C4245: conversion from type1 to type2, signed/unsigned mismatch
> + # C4267: conversion from size_t to type, possible loss of data
> + # C4306: 'identifier' : conversion from 'type1' to 'type2' of greater size
> + # C4310: cast truncates constant value
> + # C4389: 'operator' : signed/unsigned mismatch (xxxx)
> + # C4700: uninitialized local variable 'name' used. (conf_sap.c(71))
> + # C4702: unreachable code
> + # C4706: assignment within conditional expression
> + # C4819: The file contains a character that cannot be represented in the
> current code page
> + #
> + MSFT:*_*_X64_CC_FLAGS = -U_WIN32 -U_WIN64 -U_MSC_VER
> $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) /wd4090 /wd4132 /wd4210
> /wd4244 /wd4245 /wd4267 /wd4306 /wd4310 /wd4700 /wd4389 /wd4702
> /wd4706 /wd4819
> +
> + INTEL:*_*_X64_CC_FLAGS = -U_WIN32 -U_WIN64 -U_MSC_VER -U__ICC
> $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) /w
> +
> + #
> + # Suppress the following build warnings in openssl so we don't break the build
> with -Werror
> + # -Werror=maybe-uninitialized: there exist some other paths for which the
> variable is not initialized.
> + # -Werror=format: Check calls to printf and scanf, etc., to make sure that the
> arguments supplied have
> + # types appropriate to the format string specified.
> + # -Werror=unused-but-set-variable: Warn whenever a local variable is
> assigned to, but otherwise unused (aside from its declaration).
> + #
> + GCC:*_*_X64_CC_FLAGS = -UWIN32 -U_WIN32 -U_WIN64
> $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) -Wno-error=maybe-uninitialized
> -Wno-error=format -Wno-format -Wno-error=unused-but-set-variable -
> DNO_MSABI_VA_FUNCS
> +
> + # suppress the following warnings in openssl so we don't break the build with
> warnings-as-errors:
> + # 1295: Deprecated declaration <entity> - give arg types
> + # 550: <entity> was set but never used
> + # 1293: assignment in condition
> + # 111: statement is unreachable (invariably "break;" after "return X;" in case
> statement)
> + # 68: integer conversion resulted in a change of sign ("if (Status == -1)")
> + # 177: <entity> was declared but never referenced
> + # 223: function <entity> declared implicitly
> + # 144: a value of type <type> cannot be used to initialize an entity of type
> <type>
> + # 513: a value of type <type> cannot be assigned to an entity of type <type>
> + # 188: enumerated type mixed with another type (i.e. passing an integer as an
> enum without a cast)
> + # 1296: Extended constant initialiser used
> + # 128: loop is not reachable - may be emitted inappropriately if code follows
> a conditional return
> + # from the function that evaluates to true at compile time
> + # 546: transfer of control bypasses initialization - may be emitted
> inappropriately if the uninitialized
> + # variable is never referenced after the jump
> + # 1: ignore "#1-D: last line of file ends without a newline"
> + # 3017: <entity> may be used before being set (NOTE: This was fixed in
> OpenSSL 1.1 HEAD with
> + # commit d9b8b89bec4480de3a10bdaf9425db371c19145b, and can be
> dropped then.)
> + XCODE:*_*_X64_CC_FLAGS = -mmmx -msse -U_WIN32 -U_WIN64
> $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) -w -std=c99 -Wno-
> error=uninitialized
> diff --git a/CryptoPkg/Library/OpensslLib/UefiAsm.conf
> b/CryptoPkg/Library/OpensslLib/UefiAsm.conf
> new file mode 100644
> index 0000000000..2c2978d696
> --- /dev/null
> +++ b/CryptoPkg/Library/OpensslLib/UefiAsm.conf
> @@ -0,0 +1,30 @@
> +## -*- mode: perl; -*-
> +# UEFI assembly openssl configuration targets.
> +#
> +# Copyright (c) 2020, Intel Corporation. All rights reserved.<BR>
> +#
> +# SPDX-License-Identifier: BSD-2-Clause-Patent
> +#
> +##
> +
> +my %targets = (
> +#### UEFI
> + "UEFI-x86_64" => {
> + perlasm_scheme => "nasm",
> + # inherit_from => [ "UEFI", asm("x86_64_asm") ],
> + inherit_from => [ "UEFI" ],
> + cpuid_asm_src => "x86_64cpuid.s",
> + aes_asm_src => "aes_core.c aes_cbc.c vpaes-x86_64.s aesni-x86_64.s
> aesni-sha1-x86_64.s aesni-sha256-x86_64.s aesni-mb-x86_64.s",
> + sha1_asm_src => "sha1-x86_64.s sha256-x86_64.s sha512-x86_64.s
> sha1-mb-x86_64.s sha256-mb-x86_64.s",
> + modes_asm_src => "ghash-x86_64.s aesni-gcm-x86_64.s",
> + },
> + "UEFI-x86_64-GCC" => {
> + perlasm_scheme => "elf",
> + # inherit_from => [ "UEFI", asm("x86_64_asm") ],
> + inherit_from => [ "UEFI" ],
> + cpuid_asm_src => "x86_64cpuid.s",
> + aes_asm_src => "aes_core.c aes_cbc.c vpaes-x86_64.s aesni-x86_64.s
> aesni-sha1-x86_64.s aesni-sha256-x86_64.s aesni-mb-x86_64.s",
> + sha1_asm_src => "sha1-x86_64.s sha256-x86_64.s sha512-x86_64.s
> sha1-mb-x86_64.s sha256-mb-x86_64.s",
> + modes_asm_src => "ghash-x86_64.s aesni-gcm-x86_64.s",
> + },
> +);
> diff --git a/CryptoPkg/Library/OpensslLib/X64/ApiHooks.c
> b/CryptoPkg/Library/OpensslLib/X64/ApiHooks.c
> new file mode 100644
> index 0000000000..0c8043aa8e
> --- /dev/null
> +++ b/CryptoPkg/Library/OpensslLib/X64/ApiHooks.c
> @@ -0,0 +1,22 @@
> +/** @file
> + OpenSSL Library API hooks.
> +
> +Copyright (c) 2020, Intel Corporation. All rights reserved.<BR>
> +SPDX-License-Identifier: BSD-2-Clause-Patent
> +
> +**/
> +
> +#include <Uefi.h>
> +
> +/**
> + Stub function for win64 API call.
> +
> +**/
> +VOID *
> +__imp_RtlVirtualUnwind (
> + VOID * Args
> + )
> +{
> + return NULL;
> +}
> +
> diff --git a/CryptoPkg/Library/OpensslLib/process_files.pl
> b/CryptoPkg/Library/OpensslLib/process_files.pl
> index 57ce195394..42bff05fa6 100755
> --- a/CryptoPkg/Library/OpensslLib/process_files.pl
> +++ b/CryptoPkg/Library/OpensslLib/process_files.pl
> @@ -9,9 +9,65 @@
> # do not need to do this, since the results are stored in the EDK2
> # git repository for them.
> #
> +# Due to the script wrapping required to process the OpenSSL
> +# configuration data, each native architecture must be processed
> +# individually by the maintainer (in addition to the standard version):
> +# ./process_files.pl
> +# ./process_files.pl X64
> +# ./process_files.pl [Arch]
> +
> use strict;
> use Cwd;
> use File::Copy;
> +use File::Basename;
> +use File::Path qw(make_path remove_tree);
> +use Text::Tabs;
> +
> +my $comment_character;
> +
> +#
> +# OpenSSL perlasm generator script does not transfer the copyright header
> +#
> +sub copy_license_header
> +{
> + my @args = split / /, shift; #Separate args by spaces
> + my $source = $args[1]; #Source file is second (after "perl")
> + my $target = pop @args; #Target file is always last
> + chop ($target); #Remove newline char
> +
> + my $temp_file_name = "license.tmp";
> + open (my $source_file, "<" . $source) || die $source;
> + open (my $target_file, "<" . $target) || die $target;
> + open (my $temp_file, ">" . $temp_file_name) || die $temp_file_name;
> +
> + #Add "generated file" warning
> + $source =~ s/^..//; #Remove leading "./"
> + print ($temp_file "$comment_character WARNING: do not edit!\r\n");
> + print ($temp_file "$comment_character Generated from $source\r\n");
> + print ($temp_file "$comment_character\r\n");
> +
> + #Copy source file header to temp file
> + while (my $line = <$source_file>) {
> + next if ($line =~ /#!/); #Ignore shebang line
> + $line =~ s/#/$comment_character/; #Fix comment character for
> assembly
> + $line =~ s/\s+$/\r\n/; #Trim trailing whitepsace, fixup line endings
> + print ($temp_file $line);
> + last if ($line =~ /http/); #Last line of copyright header contains a web link
> + }
> + print ($temp_file "\r\n");
> + #Retrieve generated assembly contents
> + while (my $line = <$target_file>) {
> + $line =~ s/\s+$/\r\n/; #Trim trailing whitepsace, fixup line endings
> + print ($temp_file expand ($line)); #expand() replaces tabs with spaces
> + }
> +
> + close ($source_file);
> + close ($target_file);
> + close ($temp_file);
> +
> + move ($temp_file_name, $target) ||
> + die "Cannot replace \"" . $target . "\"!";
> +}
>
> #
> # Find the openssl directory name for use lib. We have to do this
> @@ -21,10 +77,57 @@ use File::Copy;
> #
> my $inf_file;
> my $OPENSSL_PATH;
> +my $uefi_config;
> +my $extension;
> +my $arch;
> my @inf;
>
> BEGIN {
> $inf_file = "OpensslLib.inf";
> + $uefi_config = "UEFI";
> + $arch = shift;
> +
> + if (defined $arch) {
> + if (uc ($arch) eq "X64") {
> + $arch = "X64";
> + $inf_file = "OpensslLibX64.inf";
> + $uefi_config = "UEFI-x86_64";
> + $extension = "nasm";
> + $comment_character = ";";
> + } elsif (uc ($arch) eq "X64GCC") {
> + $arch = "X64Gcc";
> + $inf_file = "OpensslLibX64Gcc.inf";
> + $uefi_config = "UEFI-x86_64-GCC";
> + $extension = "S";
> + $comment_character = "#";
> + } else {
> + die "Unsupported architecture \"" . $arch . "\"!";
> + }
> + if ($extension eq "nasm") {
> + if (`nasm -v 2>&1`) {
> + #Presence of nasm executable will trigger inclusion of AVX instructions
> + die "\nCannot run assembly generators with NASM in path!\n\n";
> + }
> + }
> +
> + # Prepare assembly folder
> + if (-d $arch) {
> + opendir my $dir, $arch ||
> + die "Cannot open assembly folder \"" . $arch . "\"!";
> + while (defined (my $file = readdir $dir)) {
> + if (-d "$arch/$file") {
> + next if $file eq ".";
> + next if $file eq "..";
> + remove_tree ("$arch/$file", {safe => 1}) ||
> + die "Cannot clean assembly folder \"" . "$arch/$file" . "\"!";
> + }
> + }
> +
> + } else {
> + mkdir $arch ||
> + die "Cannot create assembly folder \"" . $arch . "\"!";
> + }
> + }
>
> # Read the contents of the inf file
> open( FD, "<" . $inf_file ) ||
> @@ -47,9 +150,9 @@ BEGIN {
> # Configure UEFI
> system(
> "./Configure",
> - "UEFI",
> + "--config=../UefiAsm.conf",
> + "$uefi_config",
> "no-afalgeng",
> - "no-asm",
> "no-async",
> "no-autoerrinit",
> "no-autoload-config",
> @@ -129,23 +232,53 @@ BEGIN {
> # Retrieve file lists from OpenSSL configdata
> #
> use configdata qw/%unified_info/;
> +use configdata qw/%config/;
> +use configdata qw/%target/;
> +
> +#
> +# Collect build flags from configdata
> +#
> +my $flags = "";
> +foreach my $f (@{$config{lib_defines}}) {
> + $flags .= " -D$f";
> +}
>
> my @cryptofilelist = ();
> my @sslfilelist = ();
> +my @asmfilelist = ();
> +my @asmbuild = ();
> foreach my $product ((@{$unified_info{libraries}},
> @{$unified_info{engines}})) {
> foreach my $o (@{$unified_info{sources}->{$product}}) {
> foreach my $s (@{$unified_info{sources}->{$o}}) {
> - next if ($unified_info{generate}->{$s});
> - next if $s =~ "crypto/bio/b_print.c";
> -
> # No need to add unused files in UEFI.
> # So it can reduce porting time, compile time, library size.
> + next if $s =~ "crypto/bio/b_print.c";
> next if $s =~ "crypto/rand/randfile.c";
> next if $s =~ "crypto/store/";
> next if $s =~ "crypto/err/err_all.c";
> next if $s =~ "crypto/aes/aes_ecb.c";
>
> + if ($unified_info{generate}->{$s}) {
> + if (defined $arch) {
> + my $buildstring = "perl";
> + foreach my $arg (@{$unified_info{generate}->{$s}}) {
> + if ($arg =~ ".pl") {
> + $buildstring .= " ./openssl/$arg";
> + } elsif ($arg =~ "PERLASM_SCHEME") {
> + $buildstring .= " $target{perlasm_scheme}";
> + } elsif ($arg =~ "LIB_CFLAGS") {
> + $buildstring .= "$flags";
> + }
> + }
> + ($s, my $path, undef) = fileparse($s, qr/\.[^.]*/);
> + $buildstring .= " ./$arch/$path$s.$extension";
> + make_path ("./$arch/$path");
> + push @asmbuild, "$buildstring\n";
> + push @asmfilelist, " $arch/$path$s.$extension\r\n";
> + }
> + next;
> + }
> if ($product =~ "libssl") {
> push @sslfilelist, ' $(OPENSSL_PATH)/' . $s . "\r\n";
> next;
> @@ -183,15 +316,31 @@ foreach (@headers){
> }
>
>
> +#
> +# Generate assembly files
> +#
> +if (@asmbuild) {
> + print "\n--> Generating assembly files ... ";
> + foreach my $buildstring (@asmbuild) {
> + system ("$buildstring");
> + copy_license_header ($buildstring);
> + }
> + print "Done!";
> +}
> +
> #
> # Update OpensslLib.inf with autogenerated file list
> #
> my @new_inf = ();
> my $subbing = 0;
> -print "\n--> Updating OpensslLib.inf ... ";
> +print "\n--> Updating $inf_file ... ";
> foreach (@inf) {
> + if ($_ =~ "DEFINE OPENSSL_FLAGS_CONFIG") {
> + push @new_inf, " DEFINE OPENSSL_FLAGS_CONFIG =" . $flags . "\r\n";
> + next;
> + }
> if ( $_ =~ "# Autogenerated files list starts here" ) {
> - push @new_inf, $_, @cryptofilelist, @sslfilelist;
> + push @new_inf, $_, @asmfilelist, @cryptofilelist, @sslfilelist;
> $subbing = 1;
> next;
> }
> @@ -216,49 +365,51 @@ rename( $new_inf_file, $inf_file ) ||
> die "rename $inf_file";
> print "Done!";
>
> -#
> -# Update OpensslLibCrypto.inf with auto-generated file list (no libssl)
> -#
> -$inf_file = "OpensslLibCrypto.inf";
> -
> -# Read the contents of the inf file
> - at inf = ();
> - at new_inf = ();
> -open( FD, "<" . $inf_file ) ||
> - die "Cannot open \"" . $inf_file . "\"!";
> - at inf = (<FD>);
> -close(FD) ||
> - die "Cannot close \"" . $inf_file . "\"!";
> +if (!defined $arch) {
> + #
> + # Update OpensslLibCrypto.inf with auto-generated file list (no libssl)
> + #
> + $inf_file = "OpensslLibCrypto.inf";
>
> -$subbing = 0;
> -print "\n--> Updating OpensslLibCrypto.inf ... ";
> -foreach (@inf) {
> - if ( $_ =~ "# Autogenerated files list starts here" ) {
> - push @new_inf, $_, @cryptofilelist;
> - $subbing = 1;
> - next;
> - }
> - if ( $_ =~ "# Autogenerated files list ends here" ) {
> - push @new_inf, $_;
> - $subbing = 0;
> - next;
> + # Read the contents of the inf file
> + @inf = ();
> + @new_inf = ();
> + open( FD, "<" . $inf_file ) ||
> + die "Cannot open \"" . $inf_file . "\"!";
> + @inf = (<FD>);
> + close(FD) ||
> + die "Cannot close \"" . $inf_file . "\"!";
> +
> + $subbing = 0;
> + print "\n--> Updating OpensslLibCrypto.inf ... ";
> + foreach (@inf) {
> + if ( $_ =~ "# Autogenerated files list starts here" ) {
> + push @new_inf, $_, @cryptofilelist;
> + $subbing = 1;
> + next;
> + }
> + if ( $_ =~ "# Autogenerated files list ends here" ) {
> + push @new_inf, $_;
> + $subbing = 0;
> + next;
> + }
> +
> + push @new_inf, $_
> + unless ($subbing);
> }
>
> - push @new_inf, $_
> - unless ($subbing);
> + $new_inf_file = $inf_file . ".new";
> + open( FD, ">" . $new_inf_file ) ||
> + die $new_inf_file;
> + print( FD @new_inf ) ||
> + die $new_inf_file;
> + close(FD) ||
> + die $new_inf_file;
> + rename( $new_inf_file, $inf_file ) ||
> + die "rename $inf_file";
> + print "Done!";
> }
>
> -$new_inf_file = $inf_file . ".new";
> -open( FD, ">" . $new_inf_file ) ||
> - die $new_inf_file;
> -print( FD @new_inf ) ||
> - die $new_inf_file;
> -close(FD) ||
> - die $new_inf_file;
> -rename( $new_inf_file, $inf_file ) ||
> - die "rename $inf_file";
> -print "Done!";
> -
> #
> # Copy opensslconf.h and dso_conf.h generated from OpenSSL Configuration
> #
> --
> 2.32.0.windows.1
-=-=-=-=-=-=-=-=-=-=-=-
Groups.io Links: You receive all messages sent to this group.
View/Reply Online (#78020): https://edk2.groups.io/g/devel/message/78020
Mute This Topic: https://groups.io/mt/84344205/1813853
Group Owner: devel+owner at edk2.groups.io
Unsubscribe: https://edk2.groups.io/g/devel/unsub [edk2-devel-archive at redhat.com]
-=-=-=-=-=-=-=-=-=-=-=-
More information about the edk2-devel-archive
mailing list