]> git.proxmox.com Git - mirror_edk2.git/commitdiff
CryptoPkg/OpensslLib: Add native instruction support for X64
authorChristopher Zurcher <christopher.zurcher@microsoft.com>
Tue, 20 Jul 2021 22:06:45 +0000 (06:06 +0800)
committermergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
Mon, 26 Jul 2021 07:30:11 +0000 (07:30 +0000)
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@intel.com>
Cc: Jian J Wang <jian.j.wang@intel.com>
Cc: Xiaoyu Lu <xiaoyux.lu@intel.com>
Cc: Mike Kinney <michael.d.kinney@intel.com>
Cc: Ard Biesheuvel <ardb@kernel.org>
Signed-off-by: Christopher Zurcher <christopher.zurcher@microsoft.com>
Reviewed-by: Jiewen Yao <Jiewen.yao@intel.com>
CryptoPkg/CryptoPkg.ci.yaml
CryptoPkg/Library/Include/CrtLibSupport.h
CryptoPkg/Library/Include/openssl/opensslconf.h
CryptoPkg/Library/OpensslLib/OpensslLib.inf
CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c [new file with mode: 0644]
CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf
CryptoPkg/Library/OpensslLib/OpensslLibX64.inf [new file with mode: 0644]
CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf [new file with mode: 0644]
CryptoPkg/Library/OpensslLib/UefiAsm.conf [new file with mode: 0644]
CryptoPkg/Library/OpensslLib/X64/ApiHooks.c [new file with mode: 0644]
CryptoPkg/Library/OpensslLib/process_files.pl

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