From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mga18.intel.com (mga18.intel.com [134.134.136.126]) by mx.groups.io with SMTP id smtpd.web11.12918.1597146372423900857 for ; Tue, 11 Aug 2020 04:46:12 -0700 Authentication-Results: mx.groups.io; dkim=pass header.i=@intel.onmicrosoft.com header.s=selector2-intel-onmicrosoft-com header.b=RIghmzYs; spf=pass (domain: intel.com, ip: 134.134.136.126, mailfrom: guomin.jiang@intel.com) IronPort-SDR: XsIth6evBvynlTgFaWC43oarAMQwAeKPj8RST0tFvrKM3uWPtTmbhm3s0lRxj2TBKlsfUQR3ZQ cK5YrQtjVtYw== X-IronPort-AV: E=McAfee;i="6000,8403,9709"; a="141326710" X-IronPort-AV: E=Sophos;i="5.75,461,1589266800"; d="scan'208";a="141326710" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by orsmga106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 11 Aug 2020 04:46:11 -0700 IronPort-SDR: AVLpLYB3MeqKPmKhMc/8Wq/UDPexvQua3nRhItnP/Qw5vIrrmRNAgvmfJpj+AuLfeRGmO2Jowy RDtQc1mygZmQ== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.75,461,1589266800"; d="scan'208";a="332476671" Received: from orsmsx604-2.jf.intel.com (HELO ORSMSX604.amr.corp.intel.com) ([10.22.229.84]) by FMSMGA003.fm.intel.com with ESMTP; 11 Aug 2020 04:46:11 -0700 Received: from orsmsx604.amr.corp.intel.com (10.22.229.17) by ORSMSX604.amr.corp.intel.com (10.22.229.17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5; Tue, 11 Aug 2020 04:46:10 -0700 Received: from ORSEDG002.ED.cps.intel.com (10.7.248.5) by orsmsx604.amr.corp.intel.com (10.22.229.17) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256) id 15.1.1713.5 via Frontend Transport; Tue, 11 Aug 2020 04:46:10 -0700 Received: from NAM11-BN8-obe.outbound.protection.outlook.com (104.47.58.172) by edgegateway.intel.com (134.134.137.101) with Microsoft SMTP Server (TLS) id 14.3.439.0; Tue, 11 Aug 2020 04:46:10 -0700 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=d3KJZgYbjn9WdHZzThVNSI3qduPBt1FyfUuI4J1pf3DTlok7C7XjVOEXIjdWFAI+thb5kTCOrDaDDaAUP+FnQMGOQvWt+5RzWRLMXxMez8JRzzREuGn3Al8jNwiStyUfMZmgcP1PrkvBVXOksr/86FNve9DIWn1sbsF3QZTY9UxZNJgpk4S1N69PS6GO/8oPrdsCqXbZfg7WhKr2sBLRx6wXePzLizyvQFr3s9iO9Rn1Vi5OPYfDgtKXApG/5f6b4KjmtQCUTdqzPABUr9K3V+YnBZtM6PEr0hhnkIWtcaKC1aWTx8oZOc3RT+PZ5o72pmagj1PoIG2wAcRx8ViW9w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Sbu83+lIsOn2MIk03sT8vHKNNlwsTp3EWkUK807iyXI=; b=O3rrSzchakSHMiLEJOMNK3uwLWdYMPfGUa9gGEPTZqZBTdutj0jE3UL/ErZHFNMrWiMHiaKIa5OOVil+yjrO06zqWoagr9Ol+Ipl39ubJEN14LY0HPJsp+vAoQteRzefB8CSawR778ju6v0U1hRqGAdo3fQnmvEJd/lellQ2Kw3c7QFlsLp+IMbeJzBnjl0UHWgKWTTWU2VQD2oJ7UIxBUd75K/MJ9wiivA3m+mkpn8RfQyoqHh5sRU6IdBPk3KlgthGHgVaZqEgLu/++/O06e0HLR4ZhZqfPsBWAjwfJdgxEgI34DRUpStjegsfYK4TGBm9VweUNgoGKbmT2p4yHg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=intel.com; dmarc=pass action=none header.from=intel.com; dkim=pass header.d=intel.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=intel.onmicrosoft.com; s=selector2-intel-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=Sbu83+lIsOn2MIk03sT8vHKNNlwsTp3EWkUK807iyXI=; b=RIghmzYsfCmD4kL8OnaXIMsVcDpCMaCfuU58bD4h9nqph4CwVDMyxvmdhBoGcss5NKXZVXjBCJaDPz1EnJECgO1Dvnkf9KkvuEqPmGO1YuTIefQdNz5jcTOh5t4YwAB3QVs2qORS66OPAoALBgoUkWTWTFMzBJCtG1NLJBoGm3w= Received: from DM6PR11MB2955.namprd11.prod.outlook.com (2603:10b6:5:65::31) by DM5PR11MB1339.namprd11.prod.outlook.com (2603:10b6:3:d::20) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3261.15; Tue, 11 Aug 2020 11:46:08 +0000 Received: from DM6PR11MB2955.namprd11.prod.outlook.com ([fe80::6d20:b482:b693:52c0]) by DM6PR11MB2955.namprd11.prod.outlook.com ([fe80::6d20:b482:b693:52c0%7]) with mapi id 15.20.3261.025; Tue, 11 Aug 2020 11:46:07 +0000 From: "Guomin Jiang" To: "devel@edk2.groups.io" , "Zurcher, Christopher J" CC: "Yao, Jiewen" , "Wang, Jian J" , "Lu, XiaoyuX" , Ard Biesheuvel Subject: Re: [edk2-devel] [PATCH v2 1/2] CryptoPkg/OpensslLib: Add native instruction support for X64 Thread-Topic: [edk2-devel] [PATCH v2 1/2] CryptoPkg/OpensslLib: Add native instruction support for X64 Thread-Index: AQHWafW8LMdHFEdn70a+py1CWdnln6ky1Y4Q Date: Tue, 11 Aug 2020 11:46:07 +0000 Message-ID: References: <20200804002429.3897-1-christopher.j.zurcher@intel.com> <20200804002429.3897-2-christopher.j.zurcher@intel.com> In-Reply-To: <20200804002429.3897-2-christopher.j.zurcher@intel.com> Accept-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: dlp-version: 11.5.1.3 dlp-product: dlpe-windows dlp-reaction: no-action authentication-results: edk2.groups.io; dkim=none (message not signed) header.d=none;edk2.groups.io; dmarc=none action=none header.from=intel.com; x-originating-ip: [192.198.147.203] x-ms-publictraffictype: Email x-ms-office365-filtering-correlation-id: 9be101d4-7c98-44d3-7922-08d83dec22df x-ms-traffictypediagnostic: DM5PR11MB1339: x-ms-exchange-transport-forked: True x-microsoft-antispam-prvs: x-ms-oob-tlc-oobclassifiers: OLM:192; x-ms-exchange-senderadcheck: 1 x-microsoft-antispam: BCL:0; x-microsoft-antispam-message-info: jAE8kER1or0r8+am8oqKaKelytdGb7dMkDv3Ibh1jbE08n2dLbdR205dah5M25DfSKWyAl31ql3fktjZUE+nkPOeSjuXgPDwfWT0h7oHhp0L78YfwTjTM/RUog4Y+5uj7olMlUTXqth1k5OIvZZJLhrU2CTPMSjgbhKFEnN/h5sRdBs+Dlv5O0d2m5w0B4znefIJ6bb7Ge3P0fSXD/MK3dV223kQZkp9OlDSDtWEjGcyIcVcrsoIQPbKDxMLTBON/OiDBZgikff3Kh4EcGn+w2G4oNjHBgDuKlDghqknoQ/gp88zG+f3kzYH/9/SdJg799htGzFFn/3F0+XR9+4OzoYCDE+cvNuLxhgE22t5HKkKEp9KJb0JXsHU2d72nmRAzWcir85Dluf/NVbfZyEcH4KswpArG2CV6c+qyhHSbqIl8zGaxvzpe1xRsRntb+T7Hu9OPs9W9vI19XgnLx8UPA== x-forefront-antispam-report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:DM6PR11MB2955.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFTY:;SFS:(4636009)(39860400002)(366004)(376002)(346002)(396003)(136003)(30864003)(186003)(66556008)(64756008)(66446008)(8676002)(9686003)(4326008)(2906002)(76116006)(6636002)(66476007)(66946007)(33656002)(110136005)(478600001)(19627235002)(5660300002)(55016002)(54906003)(8936002)(83380400001)(53546011)(6506007)(316002)(966005)(71200400001)(26005)(52536014)(7696005)(86362001)(579004)(559001)(545624004);DIR:OUT;SFP:1102; x-ms-exchange-antispam-messagedata: F/vUu+6qWT89YN5MxKkomWQs9Elm99RJ/P5tUOr+Wrx672vqZ3n3k3i9Zdw3CWX56rJYpHM3R2m1b9aWc8tW2Ais7p2ccagxdMhVPX3oC+mSPjirQfmR9hNUCt9YyB1SbRi9jmbdacJFzr+pR2uZXHzRpe/BhVVRuD5Mt/SSXy5zxSe9a8tzS8u8hjwtTzz3ruvfZYifR8V3jkeXpIgTiCiVXh7YLdwep1J4wD/oDEPP3NwO+F3/ph6I46S1liMgXiaOz9v2JIEc/qJHBFYTESv0S4dpA3Aib+ACjwiO8xxH/Ie3BsW7mVG7BYh+xZn8felUdZ0jdQ9rMr1kgdAJ+pTBcq0Quzq/YlrZMNejWPsSGC8Z7RPD9BFeIYI6vEfNEIqoYE0xssgT8uzC2ZqIID/LApogie1UUTlwxnzr0A+ih7az2cTqVH8veHMLomk2fVWXnX+E4ua0V7PDMBQ3ISxnhRabViRgEYpSz+LzQjFLq3yOu7RkJHesPubRjmEkOajoFpb+sWLd0/t2l5t/Ef0JhbyBXSmlDs1jcIoObPSY9e0eGoY7yLq0/OfQ8oKQ7OoyQl7ARn9s1tJS04Rlk8OvABbFiHcB43pzoJzQyhBr6c0O7bl17XCe4RmxNAcNpX5frzEy2V98Ug6GlDd8qw== MIME-Version: 1.0 X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: DM6PR11MB2955.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-Network-Message-Id: 9be101d4-7c98-44d3-7922-08d83dec22df X-MS-Exchange-CrossTenant-originalarrivaltime: 11 Aug 2020 11:46:07.7813 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 46c98d88-e344-4ed4-8496-4ed7712e255d X-MS-Exchange-CrossTenant-mailboxtype: HOSTED X-MS-Exchange-CrossTenant-userprincipalname: EdhsPMaOtqHzknS1agZwPzIduzpNEyaiKz3VNzr9CZl8Q1eGlTpjuS8wOwLB8KXkQdchVJxVnOAYX1smedtFYw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DM5PR11MB1339 Return-Path: guomin.jiang@intel.com X-OriginatorOrg: intel.com Content-Language: en-US Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable It is slight complex, I will review it by 9/11/2020. Thanks. > -----Original Message----- > From: devel@edk2.groups.io On Behalf Of Zurcher, > Christopher J > Sent: Tuesday, August 4, 2020 8:24 AM > To: devel@edk2.groups.io > Cc: Yao, Jiewen ; Wang, Jian J > ; Lu, XiaoyuX ; Ard > Biesheuvel > Subject: [edk2-devel] [PATCH v2 1/2] CryptoPkg/OpensslLib: Add native > instruction support for X64 >=20 > BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=3D2507 >=20 > Adding OpensslLibX64.inf and modifying process_files.pl to process this f= ile > and generate the necessary assembly files. > ApiHooks.c contains a stub function for a Windows API call. > uefi-asm.conf contains the limited assembly configurations for OpenSSL. >=20 > Cc: Jiewen Yao > Cc: Jian J Wang > Cc: Xiaoyu Lu > Cc: Ard Biesheuvel > Signed-off-by: Christopher J Zurcher > --- > CryptoPkg/Library/OpensslLib/OpensslLib.inf | 2 +- > CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf | 2 +- > CryptoPkg/Library/OpensslLib/OpensslLibX64.inf | 656 > ++++++++++++++++++++ > CryptoPkg/Library/Include/openssl/opensslconf.h | 3 - > CryptoPkg/Library/OpensslLib/ApiHooks.c | 18 + > CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c | 34 + > CryptoPkg/Library/OpensslLib/process_files.pl | 223 +++++-- > CryptoPkg/Library/OpensslLib/uefi-asm.conf | 15 + > 8 files changed, 903 insertions(+), 50 deletions(-) >=20 > diff --git a/CryptoPkg/Library/OpensslLib/OpensslLib.inf > b/CryptoPkg/Library/OpensslLib/OpensslLib.inf > index dbbe5386a1..bd62d86936 100644 > --- a/CryptoPkg/Library/OpensslLib/OpensslLib.inf > +++ b/CryptoPkg/Library/OpensslLib/OpensslLib.inf > @@ -16,7 +16,7 @@ > VERSION_STRING =3D 1.0 LIBRARY_CLASS = =3D OpensslLib > DEFINE OPENSSL_PATH =3D openssl- DEFINE OPENSSL_FLAGS = =3D - > DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT - > D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE+ > DEFINE OPENSSL_FLAGS =3D -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT > -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE - > DOPENSSL_NO_ASM # # VALID_ARCHITECTURES =3D IA32 X64 ARM > AARCH64diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf > b/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf > index 616ccd9f62..2b7324a990 100644 > --- a/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf > +++ b/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf > @@ -16,7 +16,7 @@ > VERSION_STRING =3D 1.0 LIBRARY_CLASS = =3D OpensslLib > DEFINE OPENSSL_PATH =3D openssl- DEFINE OPENSSL_FLAGS = =3D - > DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT - > D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE+ > DEFINE OPENSSL_FLAGS =3D -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT > -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE - > DOPENSSL_NO_ASM # # VALID_ARCHITECTURES =3D IA32 X64 ARM > AARCH64diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibX64.inf > b/CryptoPkg/Library/OpensslLib/OpensslLibX64.inf > new file mode 100644 > index 0000000000..825eea0254 > --- /dev/null > +++ b/CryptoPkg/Library/OpensslLib/OpensslLibX64.inf > @@ -0,0 +1,656 @@ > +## @file+# This module provides OpenSSL Library implementation.+#+# > Copyright (c) 2010 - 2020, Intel Corporation. All rights reserved.
+# = (C) > Copyright 2020 Hewlett Packard Enterprise Development LP
+# SPDX- > License-Identifier: BSD-2-Clause-Patent+#+##++[Defines]+ INF_VERSION > =3D 0x00010005+ BASE_NAME =3D OpensslLibX64+ > MODULE_UNI_FILE =3D OpensslLib.uni+ FILE_GUID = =3D > 18125E50-0117-4DD0-BE54-4784AD995FEF+ MODULE_TYPE =3D= BASE+ > VERSION_STRING =3D 1.0+ LIBRARY_CLASS = =3D OpensslLib+ > DEFINE OPENSSL_PATH =3D openssl+ DEFINE OPENSSL_FLAGS = =3D - > DL_ENDIAN -DOPENSSL_SMALL_FOOTPRINT - > D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE+ > DEFINE OPENSSL_FLAGS_CONFIG =3D -DOPENSSL_CPUID_OBJ -DSHA1_ASM - > DSHA256_ASM -DSHA512_ASM -DAESNI_ASM -DVPAES_ASM - > DGHASH_ASM+ CONSTRUCTOR =3D OpensslLibConstructor++#+= # > VALID_ARCHITECTURES =3D X64+#++[Sources]+ OpensslLibConstructo= r.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/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+ rand_pool_noise.h+ ossl_store.c+ > rand_pool.c++[Sources.X64]+ rand_pool_noise_tsc.c+ > ApiHooks.c++[Packages]+ MdePkg/MdePkg.dec+ > CryptoPkg/CryptoPkg.dec++[LibraryClasses]+ BaseLib+ DebugLib+ > TimerLib+ PrintLib++[BuildOptions]+ #+ # Disables the following Visual > Studio compiler warnings brought by openssl source,+ # so we do not brea= k > the build with /WX option:+ # C4090: 'function' : different 'const' qu= alifiers+ > # 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: conver= sion > from type1 to type2, signed/unsigned mismatch+ # C4267: conversion fro= m > size_t to type, possible loss of data+ # C4306: 'identifier' : convers= ion from > 'type1' to 'type2' of greater size+ # C4310: cast truncates constant v= alue+ # > C4389: 'operator' : signed/unsigned mismatch (xxxx)+ # C4700: uninitia= lized > local variable 'name' used. (conf_sap.c(71))+ # C4702: unreachable cod= e+ # > C4706: assignment within conditional expression+ # C4819: The file con= tains > a character that cannot be represented in the current code page+ #+ > MSFT:*_*_X64_CC_FLAGS =3D -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 =3D -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=3Dmaybe-uninitialized: there exist some = other > paths for which the variable is not initialized.+ # -Werror=3Dformat: = Check > calls to printf and scanf, etc., to make sure that the arguments supplied > have+ # types appropriate to the format string specifi= ed.+ # - > Werror=3Dunused-but-set-variable: Warn whenever a local variable is assig= ned > to, but otherwise unused (aside from its declaration).+ #+ > GCC:*_*_X64_CC_FLAGS =3D -U_WIN32 -U_WIN64 $(OPENSSL_FLAGS) > $(OPENSSL_FLAGS_CONFIG) -Wno-error=3Dmaybe-uninitialized -Wno- > error=3Dformat -Wno-format -Wno-error=3Dunused-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 - give arg types+ # 550: was set but neve= r > used+ # 1293: assignment in condition+ # 111: statement is unreachable > (invariably "break;" after "return X;" in case statement)+ # 68: integ= er > conversion resulted in a change of sign ("if (Status =3D=3D -1)")+ # 17= 7: > was declared but never referenced+ # 223: function declared > implicitly+ # 144: a value of type cannot be used to initialize = an entity > of type + # 513: a value of type cannot be assigned to an > entity of 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 emitte= d > inappropriately if code follows a conditional return+ # from the f= unction > that evaluates to true at compile time+ # 546: transfer of control bypa= sses > 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: 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 =3D -mmmx -msse -U_WIN32 -U_WIN64 > $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) -w -std=3Dc99 -Wno- > error=3Duninitializeddiff --git > a/CryptoPkg/Library/Include/openssl/opensslconf.h > b/CryptoPkg/Library/Include/openssl/opensslconf.h > index 3a2544ea5c..e8f73c4d10 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 #endifdiff --git > a/CryptoPkg/Library/OpensslLib/ApiHooks.c > b/CryptoPkg/Library/OpensslLib/ApiHooks.c > new file mode 100644 > index 0000000000..58cff16838 > --- /dev/null > +++ b/CryptoPkg/Library/OpensslLib/ApiHooks.c > @@ -0,0 +1,18 @@ > +/** @file+ OpenSSL Library API hooks.++Copyright (c) 2020, Intel > Corporation. All rights reserved.
+SPDX-License-Identifier: BSD-2- > Clause-Patent++**/++#include ++VOID *+__imp_RtlVirtualUnwind > (+ VOID * Args+ )+{+ return NULL;+}+diff --git > a/CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c > b/CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c > new file mode 100644 > index 0000000000..ef20d2b84e > --- /dev/null > +++ b/CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c > @@ -0,0 +1,34 @@ > +/** @file+ Constructor to initialize CPUID data for OpenSSL assembly > operations.++Copyright (c) 2020, Intel Corporation. All rights > reserved.
+SPDX-License-Identifier: BSD-2-Clause- > Patent++**/++#include ++extern void OPENSSL_cpuid_setup > (void);++/**+ Constructor routine for OpensslLib.++ The constructor cal= ls 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/process_files.pl > b/CryptoPkg/Library/OpensslLib/process_files.pl > index 57ce195394..472f59bc8e 100755 > --- a/CryptoPkg/Library/OpensslLib/process_files.pl > +++ b/CryptoPkg/Library/OpensslLib/process_files.pl > @@ -9,9 +9,63 @@ > # 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 t= he > 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;++#+# OpenSSL > perlasm generator script does not transfer the copyright header+#+sub > copy_license_header+{+ my @args =3D split / /, shift; #Separate arg= s by > spaces+ my $source =3D $args[1]; #Source file is second (afte= r "perl")+ > my $target =3D pop @args; #Target file is always last+ chop ($= target); > #Remove newline char++ my $temp_file_name =3D "license.tmp";+ open > (my $source_file, "<" . $source) || die $source;+ open (my $target_fil= e, "<" > . $target) || die $target;+ open (my $temp_file, ">" . $temp_file_name= ) || > die $temp_file_name;++ #Add "generated file" warning+ $source =3D~ > s/^..//; #Remove leading "./"+ print ($temp_file "; WARNIN= G: do not > edit!\r\n");+ print ($temp_file "; Generated from $source\r\n");+ p= rint > ($temp_file ";\r\n");++ #Copy source file header to temp file+ whil= e (my > $line =3D <$source_file>) {+ next if ($line =3D~ /#!/); #Ignore= shebang line+ > $line =3D~ s/#/;/; #Fix comment character for assembly+ = $line =3D~ > s/\s+$/\r\n/; #Trim trailing whitepsace, fixup line endings+ = print > ($temp_file $line);+ last if ($line =3D~ /http/); #Last line of c= opyright header > contains a web link+ }+ print ($temp_file "\r\n");+ #Retrieve ge= nerated > assembly contents+ while (my $line =3D <$target_file>) {+ $line= =3D~ > 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 +75,41 @@ use File::Copy; > # my $inf_file; my $OPENSSL_PATH;+my $uefi_config;+my $extension;+my > $arch; my @inf; BEGIN { $inf_file =3D "OpensslLib.inf";+ $uefi_co= nfig =3D > "UEFI";+ $arch =3D shift;++ if (defined $arch) {+ if (uc ($a= rch) eq "X64") {+ > $arch =3D "X64";+ $inf_file =3D "OpensslLibX64.inf";+ = $uefi_config =3D > "UEFI-x86_64";+ $extension =3D "nasm";+ } else {+ = die > "Unsupported architecture \"" . $arch . "\"!";+ }+ if ($ext= ension 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";+ }+ }++ # Pr= epare > assembly folder+ if (-d $arch) {+ remove_tree ($arch, {= safe =3D> 1}) > ||+ die "Cannot clean assembly folder \"" . $arch . "\"!";= + } else {+ > mkdir $arch ||+ die "Cannot create assembly folder \"" . $= arch . > "\"!";+ }+ } # Read the contents of the inf file open(= FD, "<" . > $inf_file ) ||@@ -47,9 +132,9 @@ BEGIN { > # Configure UEFI system( "./Conf= igure",- > "UEFI",+ "--config=3D../uefi-asm.conf",+ "$= uefi_config", > "no-afalgeng",- "no-asm", "no-async", = "no- > autoerrinit", "no-autoload-config",@@ -129,23 +214,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 =3D > "";+foreach my $f (@{$config{lib_defines}}) {+ $flags .=3D " -D$f";+} = my > @cryptofilelist =3D (); my @sslfilelist =3D ();+my @asmfilelist =3D ();+m= y @asmbuild > =3D (); 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 =3D~ > "crypto/bio/b_print.c";- # No need to add unused files in UEF= I. # > So it can reduce porting time, compile time, library size.+ ne= xt if $s =3D~ > "crypto/bio/b_print.c"; next if $s =3D~ "crypto/rand/randfile= .c"; > next if $s =3D~ "crypto/store/"; next if $s =3D~ "crypto/err/= err_all.c"; > next if $s =3D~ "crypto/aes/aes_ecb.c"; + if ($unified_info{ge= nerate}- > >{$s}) {+ if (defined $arch) {+ my $bui= ldstring =3D "perl";+ > foreach my $arg (@{$unified_info{generate}->{$s}}) {+ = if ($arg =3D~ > ".pl") {+ $buildstring .=3D " ./openssl/$arg";= + } elsif > ($arg =3D~ "PERLASM_SCHEME") {+ $buildstring .= =3D " > $target{perlasm_scheme}";+ } elsif ($arg =3D~ "LIB= _CFLAGS") {+ > $buildstring .=3D "$flags";+ }+ = }+ ($s, my $path, > undef) =3D fileparse($s, qr/\.[^.]*/);+ $buildstring .= =3D " > ./$arch/$path$s.$extension";+ make_path ("./$arch/$pat= h");+ > push @asmbuild, "$buildstring\n";+ push @asmfilelist, = " > $arch/$path$s.$extension\r\n";+ }+ next;+ = } if > ($product =3D~ "libssl") { push @sslfilelist, ' $(OPENSS= L_PATH)/' . $s . > "\r\n"; next;@@ -183,15 +298,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 =3D (); my $subbing =3D 0;-print "\n--> Updating OpensslLib.inf = ... > ";+print "\n--> Updating $inf_file ... "; foreach (@inf) {+ if ($_ =3D= ~ "DEFINE > OPENSSL_FLAGS_CONFIG") {+ push @new_inf, " DEFINE > OPENSSL_FLAGS_CONFIG =3D" . $flags . "\r\n";+ next;+ } i= f ( $_ =3D~ "# > Autogenerated files list starts here" ) {- push @new_inf, $_, > @cryptofilelist, @sslfilelist;+ push @new_inf, $_, @asmfilelist, > @cryptofilelist, @sslfilelist; $subbing =3D 1; next; = }@@ -216,49 > +347,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 =3D "OpensslLibCryp= to.inf";-- > # Read the contents of the inf file-@inf =3D ();-@new_inf =3D ();-open( F= D, "<" . > $inf_file ) ||- die "Cannot open \"" . $inf_file . "\"!";-@inf =3D ();- > close(FD) ||- die "Cannot close \"" . $inf_file . "\"!";+if (!defined = $arch) {+ > #+ # Update OpensslLibCrypto.inf with auto-generated file list (no lib= ssl)+ > #+ $inf_file =3D "OpensslLibCrypto.inf"; -$subbing =3D 0;-print "\n-->= Updating > OpensslLibCrypto.inf ... ";-foreach (@inf) {- if ( $_ =3D~ "# Autogene= rated files > list starts here" ) {- push @new_inf, $_, @cryptofilelist;- = $subbing =3D 1;- > next;- }- if ( $_ =3D~ "# Autogenerated files list ends here" ) {- = push > @new_inf, $_;- $subbing =3D 0;- next;+ # Read the conten= ts of the inf > file+ @inf =3D ();+ @new_inf =3D ();+ open( FD, "<" . $inf_file = ) ||+ die > "Cannot open \"" . $inf_file . "\"!";+ @inf =3D ();+ close(FD) = ||+ die > "Cannot close \"" . $inf_file . "\"!";++ $subbing =3D 0;+ print "\n= --> Updating > OpensslLibCrypto.inf ... ";+ foreach (@inf) {+ if ( $_ =3D~ "# > Autogenerated files list starts here" ) {+ push @new_inf, $_, > @cryptofilelist;+ $subbing =3D 1;+ next;+ }+= if ( $_ =3D~ "# > Autogenerated files list ends here" ) {+ push @new_inf, $_;+ > $subbing =3D 0;+ next;+ }++ push @new_inf, $_+ = unless > ($subbing); } - push @new_inf, $_- unless ($subbing);+ > $new_inf_file =3D $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_f= ile ) ||+ > die "rename $inf_file";+ print "Done!"; } -$new_inf_file =3D $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 #diff --git a/CryptoPkg/Library/OpensslLib/uefi-asm.conf > b/CryptoPkg/Library/OpensslLib/uefi-asm.conf > new file mode 100644 > index 0000000000..55eedbf3ba > --- /dev/null > +++ b/CryptoPkg/Library/OpensslLib/uefi-asm.conf > @@ -0,0 +1,15 @@ > +## -*- mode: perl; -*-+## UEFI assembly openssl configuration > targets.++my %targets =3D (+#### UEFI+ "UEFI-x86_64" =3D> {+ > perlasm_scheme =3D> "nasm",+ # inherit_from =3D> [ "UEFI", > asm("x86_64_asm") ],+ inherit_from =3D> [ "UEFI" ],+ cpu= id_asm_src > =3D> "x86_64cpuid.s",+ aes_asm_src =3D> "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 =3D> "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 =3D> "ghash-x86_64.s",+ },+);-- > 2.28.0.windows.1 >=20 >=20 > -=3D-=3D-=3D-=3D-=3D-=3D > Groups.io Links: You receive all messages sent to this group. >=20 > View/Reply Online (#63682): https://edk2.groups.io/g/devel/message/63682 > Mute This Topic: https://groups.io/mt/75978612/4399222 > Group Owner: devel+owner@edk2.groups.io > Unsubscribe: https://edk2.groups.io/g/devel/unsub > [guomin.jiang@intel.com] -=3D-=3D-=3D-=3D-=3D-=3D