From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mga04.intel.com (mga04.intel.com [192.55.52.120]) by mx.groups.io with SMTP id smtpd.web10.2886.1626867891321050908 for ; Wed, 21 Jul 2021 04:44:51 -0700 Authentication-Results: mx.groups.io; dkim=pass header.i=@intel.onmicrosoft.com header.s=selector2-intel-onmicrosoft-com header.b=b6fgTuir; spf=pass (domain: intel.com, ip: 192.55.52.120, mailfrom: jiewen.yao@intel.com) X-IronPort-AV: E=McAfee;i="6200,9189,10051"; a="209517568" X-IronPort-AV: E=Sophos;i="5.84,258,1620716400"; d="scan'208";a="209517568" Received: from orsmga008.jf.intel.com ([10.7.209.65]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 21 Jul 2021 04:44:49 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.84,258,1620716400"; d="scan'208";a="462370797" Received: from fmsmsx605.amr.corp.intel.com ([10.18.126.85]) by orsmga008.jf.intel.com with ESMTP; 21 Jul 2021 04:44:49 -0700 Received: from fmsmsx608.amr.corp.intel.com (10.18.126.88) by fmsmsx605.amr.corp.intel.com (10.18.126.85) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2242.4; Wed, 21 Jul 2021 04:44:48 -0700 Received: from fmsmsx603.amr.corp.intel.com (10.18.126.83) by fmsmsx608.amr.corp.intel.com (10.18.126.88) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2242.10; Wed, 21 Jul 2021 04:44:48 -0700 Received: from fmsedg601.ED.cps.intel.com (10.1.192.135) by fmsmsx603.amr.corp.intel.com (10.18.126.83) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2242.10 via Frontend Transport; Wed, 21 Jul 2021 04:44:48 -0700 Received: from NAM04-DM6-obe.outbound.protection.outlook.com (104.47.73.42) by edgegateway.intel.com (192.55.55.70) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2242.10; Wed, 21 Jul 2021 04:44:48 -0700 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=O3OELAPeZXCNdzv4LF491KQMG2Hj2eGk0hlhXStStUu/l+k825TXOESEKQRGy9CxHyK89TlTNi80wVJFl9jPRf1A7c/L2Ajio9OiAQsKf8WvUM+fg7aEBuLvgas+zEN0gc9A57v8FKqof35H04LKDEGsUXdu0ygb1sc5QHDfvdiENK4KOIoOiKc+GeQA6ZI2zebceJp5HMhCPjAWw3Hd57yC1fTLeyQQHyLkme732SPeSkS0fjgCLGE+fCS5Gngxw9kLurY1SM8t+W3lxwIXK30mcMNASUoy5a+5iYAi3z/zn5zmi43IgHwJRjzz6LK4vn4KZ+/ymn6B2eQvs0kPUA== 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=OBIS0dLyNNKj8NMmUmPeD9I0iOxmbFlzrk54v6M5MkM=; b=oBe4ShMuub/rFbfezsMI61IE/t1CQBbhDFBPillxsHDEs/dWjfgxJW5t659RO/7P4y5x64vPO2dwHo43BUgRTm3nbWfWbhGqNWbHej576SNiYvcyrLRWZXMwqqz4mtSRIIjhM4jlswDRhjtXSWdDEpowpm6vmOP2/EeNTMQzonniqmBGjKs5MuDkOC7AAHSK5gL+HeALIqLl4/nQtQdKDT3w4hbNRlWf5Yi66XT7Fce/NPOsiHRRCh6hhQ3PK/w4x3TC+zCPN3l8ipvJJoSHN3f12Op/JkWfUYicatQRsa98vlQOo8vukzKDCB6MYuJw+FavflLXEbNa9z643GXz6w== 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=OBIS0dLyNNKj8NMmUmPeD9I0iOxmbFlzrk54v6M5MkM=; b=b6fgTuirofSK+IyPLPf9EZRb6r2OCQfF3y8JB88THpO+sQDUjb5U8/F6SItNCTwq8AFlSycOK+BLxXE7RZ0v4fZPQ84n4p5ddUWMjGzAoS7KOHiM2w3Bhz34h0Dfz56x+9Vp3nPCi6CHozN3RmLzl0kbaTJcnPxnlgc8EkheGFQ= Received: from PH0PR11MB4885.namprd11.prod.outlook.com (2603:10b6:510:35::14) by PH0PR11MB5079.namprd11.prod.outlook.com (2603:10b6:510:3d::6) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.4331.21; Wed, 21 Jul 2021 11:44:45 +0000 Received: from PH0PR11MB4885.namprd11.prod.outlook.com ([fe80::6c99:8170:1c3c:9121]) by PH0PR11MB4885.namprd11.prod.outlook.com ([fe80::6c99:8170:1c3c:9121%3]) with mapi id 15.20.4331.034; Wed, 21 Jul 2021 11:44:45 +0000 From: "Yao, Jiewen" To: "christopher.zurcher@outlook.com" , "devel@edk2.groups.io" CC: "Wang, Jian J" , "Lu, XiaoyuX" , "Kinney, Michael D" , "Ard Biesheuvel" Subject: Re: [PATCH v7 2/3] CryptoPkg/OpensslLib: Add native instruction support for X64 Thread-Topic: [PATCH v7 2/3] CryptoPkg/OpensslLib: Add native instruction support for X64 Thread-Index: AQHXfbOZapFMJJ0ZckmwmV4dYitJ1KtNUATA Date: Wed, 21 Jul 2021 11:44:45 +0000 Message-ID: References: <20210720220646.659-1-christopher.zurcher@outlook.com> In-Reply-To: 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: outlook.com; dkim=none (message not signed) header.d=none;outlook.com; dmarc=none action=none header.from=intel.com; x-ms-publictraffictype: Email x-ms-office365-filtering-correlation-id: 9d77b89e-43f0-4c53-da00-08d94c3ceff5 x-ms-traffictypediagnostic: PH0PR11MB5079: x-ms-exchange-transport-forked: True x-microsoft-antispam-prvs: x-ms-oob-tlc-oobclassifiers: OLM:121; x-ms-exchange-senderadcheck: 1 x-ms-exchange-antispam-relay: 0 x-microsoft-antispam: BCL:0; x-microsoft-antispam-message-info: /nrUw159kHY9iboLISoeCfo8Jw5pZJQvvIwb0iWzPhr78eMWPvUzz5uHTziBSvlRl6Y51DekbB+QrTTrhGdmD86X9qpvafHXcu/uXbjQPH78QGYiMcJzjbWYRDkEfovuea5NU939KmuB/ilFGu68eFUBrT2vDuQyKqB//hFa3IuagH1llZvBE7of4T1BKMnkAXV6mYrI/jXsCtfyr+KdQvTWppdJqEPqeRaMFA/RpfQ6cdLIfqzR9tOr/p5Ca4Hz5lOHyQ4og9E26zTBJqyurl5JEXfWO5VAdg/+ZBW14g7yeBviYDIBEvajRvolfDMCfjTVKAUxYp3LKVK+CQ+XY6vJ3sz+tvI7+25csI1gyWjIGv1T0LAj8h3gPXTaYWwj/lvH9Fi6Arbi4jUz9rggBKAli9JdoLU5+yFbag3OFoyn7jsGVCL717IVU5Iro7UqKOTUf8IDmWjq5S305fBne2u5c0u3X8IwUBKuJpwQIkH4mWpgn86VsdSiYnJd1iLqzyJ2JqG7n/ThtI2EWAWnIY/H4ir+wDF393E9C1wbUeuTRyK346um0X72TgOhAgKRVO24mSBzzSrFC37QE7vlUQij9YVkVpdBXn9Monjc8oWiOuTQXutXH1y9AZa8C5uh6demjI4fXi9NYmt5EXO5/+251olCVCHKVfIFBHXOExBGsNezof0ZS0ygbeU6aocmXBtf5ChO5cWrXfPDOqxqpkZ0DaI9ifabsu1VzWMeltZZSsYEN5/O7lF5erliPlrSxJzS8BHCEYbVfHlDHGucRRyfz8fqGZTNqiJC2FwiWiGjHxieHW+Z/8MjZb/4J6z3 x-forefront-antispam-report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PH0PR11MB4885.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(4636009)(346002)(39860400002)(376002)(396003)(366004)(136003)(7696005)(110136005)(33656002)(478600001)(186003)(26005)(66446008)(86362001)(8936002)(122000001)(5660300002)(64756008)(45080400002)(8676002)(4326008)(30864003)(2906002)(19627235002)(71200400001)(966005)(66556008)(66476007)(76116006)(316002)(66946007)(6506007)(53546011)(55016002)(9686003)(54906003)(38100700002)(52536014)(83380400001)(38070700004)(579004)(559001)(545624004);DIR:OUT;SFP:1102; x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: =?us-ascii?Q?1WQ0z4jeWDjIINYwLI0N57mbeyo02a3kUySw9DjRsvevN+VwMT+oifmkSo1i?= =?us-ascii?Q?oTT3umzvIt2io1vXIru1iBN8+7xx7S9XoEXUjHT5/phUiOVgHDkaDHs3CcpA?= =?us-ascii?Q?xgMpXwPP8O0lgOKEskQHeVqfsWvQvFrBkzx5vlRoSnLuRz7mC3O6tTw2uN+K?= =?us-ascii?Q?2ESmFULHJE3R4oSxOKhJpIZJPUxlBq3tvAf8Jefd9WQhhkCxanrvcNGnSRWn?= =?us-ascii?Q?xP+WfjRPFjXoJ2UqZxIgZFmRw5YCsE8IqTEyZ2tGSewVFSQMvgo4o9QL9s1N?= =?us-ascii?Q?5RSPkmT2GhbIUlYMyiGu7VYPRVqBkWzhkQ5I2JNyC0CRS6GKQsSqhDjkM50/?= =?us-ascii?Q?q/LuHd+mefvOjAvJ652OFWDdzlJNpHmIr3AbVW+V7ORAGMMeJHHxvJZqCN3T?= =?us-ascii?Q?O0rKu1SAIfCkutLk9EYYfqkftCNCfsEMePZ66j/BWqQ9u1HgZh+EEsKk6lXM?= =?us-ascii?Q?4MKmD1nVY0LDdZrxWlUzhzoSZhhwG7pBWSi0BEpwJTn3pv9j9NAaO5V3d547?= =?us-ascii?Q?jXMQBLLNYh0bHEZc6DlrzCb39Ykj3J3MdIQyiUmrAXGGz8PiXKHHcTfBrTRA?= =?us-ascii?Q?gQ3SGj9PHtMPIiUburumuJJ2gIjH6hLqJL2AlqtvsTIDDLCCREt3b7yKcEQd?= =?us-ascii?Q?e6n77rkMUCWiFUAC8fHPmq+yPmSOZR+SkCYYvvtZRIGZrIdGqSwWyc7ETZb8?= =?us-ascii?Q?V/2RQuo7sHix2jFR5nrn03fSLdd3opMdeuI1PdyyIXY938LpR+cXIrJa9JEx?= =?us-ascii?Q?ry0T0Y3w16X3Iec5857s4pBcefgLvW/4BkjP5I+eLLJhJ9nxxMJsV/enKA+1?= =?us-ascii?Q?VkK4a4/6NBIoe8vTtgtow2EffKO1i5RsDfP+yPlKZquXCy0/FrYjPE8h6D3k?= =?us-ascii?Q?fDpqjFV5Fqqm53E948q2v/7i2WeBgkiIgliLEzDN1kc8GluA/eCYSQF9z8Lh?= =?us-ascii?Q?GJUx524uZAeIpFkzMWIHy6O3+AR307V8xiLw+WGZZFHza0ZdIVLaKTzG6IEC?= =?us-ascii?Q?3LNjxyU+lwVKQwXHIG5nja4aFa5rSLx8LNaAHSL9KPpCtYs34qUF9bKCqBLn?= =?us-ascii?Q?hnkRGz+0DcfiJf7K8Ll4gJil5ta2F8waYvjZLeEO/Hjq8ad3AYufpgF4t5oA?= =?us-ascii?Q?2ufHZjKVNCahU2LSRHXyMhgSASBaQ02DiW9H8XwH8OndvcaQfZBCG1tZZf9Z?= =?us-ascii?Q?YEkutLbXJlrOdo8vvYc5ZbCm5EenDiIwW2eoUF8oH2JlsabwzcOkfU8Wgyk0?= =?us-ascii?Q?JoSA4+vuvc/Ef0n7g2JrT6a5cL5Gf7BzkriXqT78DirnFmKQUOjQpjBToen+?= =?us-ascii?Q?qcHqIdGJXQ4fg4tx7lJA+jnp?= MIME-Version: 1.0 X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: PH0PR11MB4885.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-Network-Message-Id: 9d77b89e-43f0-4c53-da00-08d94c3ceff5 X-MS-Exchange-CrossTenant-originalarrivaltime: 21 Jul 2021 11:44:45.5220 (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: 2p9AWTRy6l7DHhjrgyFnIO2fRwFZv2jVLhyaoC2Tz5khEeNq4xVVK2kqS+lHCE4sXuhhOzvPgZFNTafRKcV2hA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH0PR11MB5079 Return-Path: jiewen.yao@intel.com X-OriginatorOrg: intel.com Content-Language: en-US Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable Reviewed-by: Jiewen Yao > -----Original Message----- > From: christopher.zurcher@outlook.com > Sent: Wednesday, July 21, 2021 6:07 AM > To: devel@edk2.groups.io > Cc: Yao, Jiewen ; Wang, Jian J ; > Lu, XiaoyuX ; Kinney, Michael D > ; Ard Biesheuvel > Subject: [PATCH v7 2/3] CryptoPkg/OpensslLib: Add native instruction supp= ort > for X64 >=20 > From: Christopher Zurcher >=20 > BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=3D2507 >=20 > 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. >=20 > Cc: Jiewen Yao > Cc: Jian J Wang > Cc: Xiaoyu Lu > Cc: Mike Kinney > Cc: Ard Biesheuvel > Signed-off-by: Christopher Zurcher > --- > CryptoPkg/CryptoPkg.ci.yaml | 21 +- > CryptoPkg/Library/Include/CrtLibSupport.h | 2 + > CryptoPkg/Library/Include/openssl/opensslconf.h | 3 - > CryptoPkg/Library/OpensslLib/OpensslLib.inf | 2 +- > CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c | 44 ++ > CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf | 2 +- > CryptoPkg/Library/OpensslLib/OpensslLibX64.inf | 653 > ++++++++++++++++++++ > CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf | 653 > ++++++++++++++++++++ > CryptoPkg/Library/OpensslLib/UefiAsm.conf | 30 + > CryptoPkg/Library/OpensslLib/X64/ApiHooks.c | 22 + > CryptoPkg/Library/OpensslLib/process_files.pl | 241 ++++++-- > 11 files changed, 1619 insertions(+), 54 deletions(-) >=20 > diff --git a/CryptoPkg/CryptoPkg.ci.yaml b/CryptoPkg/CryptoPkg.ci.yaml > index 5d7c340ae5..1448299073 100644 > --- a/CryptoPkg/CryptoPkg.ci.yaml > +++ b/CryptoPkg/CryptoPkg.ci.yaml > @@ -7,7 +7,11 @@ > ## > { > "LicenseCheck": { > - "IgnoreFiles": [] > + "IgnoreFiles": [ > + # These directories contain auto-generated OpenSSL content > + "Library/OpensslLib/X64", > + "Library/OpensslLib/X64Gcc" > + ] > }, > "EccCheck": { > ## Exception sample looks like below: > @@ -23,8 +27,13 @@ > "Test/UnitTest", > # This has OpenSSL interfaces that aren't UEFI spec complian= t > "Library/BaseCryptLib/SysCall/UnitTestHostCrtWrapper.c", > - # this has OpenSSL interfaces that aren't UEFI spec complian= t > - "Library/OpensslLib/rand_pool.c" > + # This has OpenSSL interfaces that aren't UEFI spec complian= t > + "Library/OpensslLib/rand_pool.c", > + # This has OpenSSL interfaces that aren't UEFI spec complian= t > + "Library/Include/CrtLibSupport.h", > + # These directories contain auto-generated OpenSSL content > + "Library/OpensslLib/X64", > + "Library/OpensslLib/X64Gcc" > ] > }, > "CompilerPlugin": { > @@ -51,7 +60,11 @@ > }, > "DscCompleteCheck": { > "DscPath": "CryptoPkg.dsc", > - "IgnoreInf": [] > + "IgnoreInf": [ > + # These are alternatives to OpensslLib.inf > + "CryptoPkg/Library/OpensslLib/OpensslLibX64.inf", > + "CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf" > + ] > }, > "GuidCheck": { > "IgnoreGuidName": [], > diff --git a/CryptoPkg/Library/Include/CrtLibSupport.h > b/CryptoPkg/Library/Include/CrtLibSupport.h > index b1dff03bdc..17d7f29ba2 100644 > --- a/CryptoPkg/Library/Include/CrtLibSupport.h > +++ b/CryptoPkg/Library/Include/CrtLibSupport.h > @@ -102,6 +102,7 @@ SPDX-License-Identifier: BSD-2-Clause-Patent > // > typedef UINTN size_t; > typedef UINTN u_int; > +typedef INTN ptrdiff_t; > typedef INTN ssize_t; > typedef INT32 time_t; > typedef UINT8 __uint8_t; > @@ -109,6 +110,7 @@ typedef UINT8 sa_family_t; > typedef UINT8 u_char; > typedef UINT32 uid_t; > typedef UINT32 gid_t; > +typedef CHAR16 wchar_t; >=20 > // > // File operations are not required for EFI building, > diff --git a/CryptoPkg/Library/Include/openssl/opensslconf.h > b/CryptoPkg/Library/Include/openssl/opensslconf.h > index e5652be5ca..b8d59aebe8 100644 > --- a/CryptoPkg/Library/Include/openssl/opensslconf.h > +++ b/CryptoPkg/Library/Include/openssl/opensslconf.h > @@ -112,9 +112,6 @@ extern "C" { > #ifndef OPENSSL_NO_ASAN > # define OPENSSL_NO_ASAN > #endif > -#ifndef OPENSSL_NO_ASM > -# define OPENSSL_NO_ASM > -#endif > #ifndef OPENSSL_NO_ASYNC > # define OPENSSL_NO_ASYNC > #endif > diff --git a/CryptoPkg/Library/OpensslLib/OpensslLib.inf > b/CryptoPkg/Library/OpensslLib/OpensslLib.inf > index b00bb74ce6..d84bde056a 100644 > --- a/CryptoPkg/Library/OpensslLib/OpensslLib.inf > +++ b/CryptoPkg/Library/OpensslLib/OpensslLib.inf > @@ -16,7 +16,7 @@ > VERSION_STRING =3D 1.0 > LIBRARY_CLASS =3D OpensslLib > DEFINE OPENSSL_PATH =3D openssl > - DEFINE OPENSSL_FLAGS =3D -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRIN= T > -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE > + DEFINE OPENSSL_FLAGS =3D -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRIN= T > -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE - > DOPENSSL_NO_ASM >=20 > # > # VALID_ARCHITECTURES =3D IA32 X64 ARM AARCH64 > diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c > b/CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c > new file mode 100644 > index 0000000000..74ae1ac20c > --- /dev/null > +++ b/CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c > @@ -0,0 +1,44 @@ > +/** @file > + Constructor to initialize CPUID data for OpenSSL assembly operations. > + > +Copyright (c) 2020, Intel Corporation. All rights reserved.
> +SPDX-License-Identifier: BSD-2-Clause-Patent > + > +**/ > + > +#include > + > + > +/** > + An internal OpenSSL function which fetches a local copy of the hardwar= e > + capability flags. > + > +**/ > +extern > +VOID > +OPENSSL_cpuid_setup ( > + VOID > + ); > + > +/** > + Constructor routine for OpensslLib. > + > + The constructor calls an internal OpenSSL function which fetches a loc= al copy > + of the hardware capability flags, used to enable native crypto instruc= tions. > + > + @param None > + > + @retval EFI_SUCCESS The construction succeeded. > + > +**/ > +EFI_STATUS > +EFIAPI > +OpensslLibConstructor ( > + VOID > + ) > +{ > + OPENSSL_cpuid_setup (); > + > + return EFI_SUCCESS; > +} > + > diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf > b/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf > index 3557711bd8..cdeed0d073 100644 > --- a/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf > +++ b/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf > @@ -16,7 +16,7 @@ > VERSION_STRING =3D 1.0 > LIBRARY_CLASS =3D OpensslLib > DEFINE OPENSSL_PATH =3D openssl > - DEFINE OPENSSL_FLAGS =3D -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRIN= T > -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE > + DEFINE OPENSSL_FLAGS =3D -DL_ENDIAN -DOPENSSL_SMALL_FOOTPRIN= T > -D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE - > DOPENSSL_NO_ASM >=20 > # > # VALID_ARCHITECTURES =3D IA32 X64 ARM AARCH64 > diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibX64.inf > b/CryptoPkg/Library/OpensslLib/OpensslLibX64.inf > new file mode 100644 > index 0000000000..b92feaf1bf > --- /dev/null > +++ b/CryptoPkg/Library/OpensslLib/OpensslLibX64.inf > @@ -0,0 +1,653 @@ > +## @file > +# This module provides OpenSSL Library implementation. > +# > +# Copyright (c) 2010 - 2020, Intel Corporation. All rights reserved. > +# (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-4784AD995FE= F > + 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_FOOTPRIN= T > -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.X64] > + OpensslLibConstructor.c > + $(OPENSSL_PATH)/e_os.h > + $(OPENSSL_PATH)/ms/uplink.h > +# Autogenerated files list starts here > + X64/crypto/aes/aesni-mb-x86_64.nasm > + X64/crypto/aes/aesni-sha1-x86_64.nasm > + X64/crypto/aes/aesni-sha256-x86_64.nasm > + X64/crypto/aes/aesni-x86_64.nasm > + X64/crypto/aes/vpaes-x86_64.nasm > + X64/crypto/modes/aesni-gcm-x86_64.nasm > + X64/crypto/modes/ghash-x86_64.nasm > + X64/crypto/sha/sha1-mb-x86_64.nasm > + X64/crypto/sha/sha1-x86_64.nasm > + X64/crypto/sha/sha256-mb-x86_64.nasm > + X64/crypto/sha/sha256-x86_64.nasm > + X64/crypto/sha/sha512-x86_64.nasm > + X64/crypto/x86_64cpuid.nasm > + $(OPENSSL_PATH)/crypto/aes/aes_cbc.c > + $(OPENSSL_PATH)/crypto/aes/aes_cfb.c > + $(OPENSSL_PATH)/crypto/aes/aes_core.c > + $(OPENSSL_PATH)/crypto/aes/aes_ige.c > + $(OPENSSL_PATH)/crypto/aes/aes_misc.c > + $(OPENSSL_PATH)/crypto/aes/aes_ofb.c > + $(OPENSSL_PATH)/crypto/aes/aes_wrap.c > + $(OPENSSL_PATH)/crypto/aria/aria.c > + $(OPENSSL_PATH)/crypto/asn1/a_bitstr.c > + $(OPENSSL_PATH)/crypto/asn1/a_d2i_fp.c > + $(OPENSSL_PATH)/crypto/asn1/a_digest.c > + $(OPENSSL_PATH)/crypto/asn1/a_dup.c > + $(OPENSSL_PATH)/crypto/asn1/a_gentm.c > + $(OPENSSL_PATH)/crypto/asn1/a_i2d_fp.c > + $(OPENSSL_PATH)/crypto/asn1/a_int.c > + $(OPENSSL_PATH)/crypto/asn1/a_mbstr.c > + $(OPENSSL_PATH)/crypto/asn1/a_object.c > + $(OPENSSL_PATH)/crypto/asn1/a_octet.c > + $(OPENSSL_PATH)/crypto/asn1/a_print.c > + $(OPENSSL_PATH)/crypto/asn1/a_sign.c > + $(OPENSSL_PATH)/crypto/asn1/a_strex.c > + $(OPENSSL_PATH)/crypto/asn1/a_strnid.c > + $(OPENSSL_PATH)/crypto/asn1/a_time.c > + $(OPENSSL_PATH)/crypto/asn1/a_type.c > + $(OPENSSL_PATH)/crypto/asn1/a_utctm.c > + $(OPENSSL_PATH)/crypto/asn1/a_utf8.c > + $(OPENSSL_PATH)/crypto/asn1/a_verify.c > + $(OPENSSL_PATH)/crypto/asn1/ameth_lib.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_err.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_gen.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_item_list.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_lib.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_par.c > + $(OPENSSL_PATH)/crypto/asn1/asn_mime.c > + $(OPENSSL_PATH)/crypto/asn1/asn_moid.c > + $(OPENSSL_PATH)/crypto/asn1/asn_mstbl.c > + $(OPENSSL_PATH)/crypto/asn1/asn_pack.c > + $(OPENSSL_PATH)/crypto/asn1/bio_asn1.c > + $(OPENSSL_PATH)/crypto/asn1/bio_ndef.c > + $(OPENSSL_PATH)/crypto/asn1/d2i_pr.c > + $(OPENSSL_PATH)/crypto/asn1/d2i_pu.c > + $(OPENSSL_PATH)/crypto/asn1/evp_asn1.c > + $(OPENSSL_PATH)/crypto/asn1/f_int.c > + $(OPENSSL_PATH)/crypto/asn1/f_string.c > + $(OPENSSL_PATH)/crypto/asn1/i2d_pr.c > + $(OPENSSL_PATH)/crypto/asn1/i2d_pu.c > + $(OPENSSL_PATH)/crypto/asn1/n_pkey.c > + $(OPENSSL_PATH)/crypto/asn1/nsseq.c > + $(OPENSSL_PATH)/crypto/asn1/p5_pbe.c > + $(OPENSSL_PATH)/crypto/asn1/p5_pbev2.c > + $(OPENSSL_PATH)/crypto/asn1/p5_scrypt.c > + $(OPENSSL_PATH)/crypto/asn1/p8_pkey.c > + $(OPENSSL_PATH)/crypto/asn1/t_bitst.c > + $(OPENSSL_PATH)/crypto/asn1/t_pkey.c > + $(OPENSSL_PATH)/crypto/asn1/t_spki.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_dec.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_enc.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_fre.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_new.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_prn.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_scn.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_typ.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_utl.c > + $(OPENSSL_PATH)/crypto/asn1/x_algor.c > + $(OPENSSL_PATH)/crypto/asn1/x_bignum.c > + $(OPENSSL_PATH)/crypto/asn1/x_info.c > + $(OPENSSL_PATH)/crypto/asn1/x_int64.c > + $(OPENSSL_PATH)/crypto/asn1/x_long.c > + $(OPENSSL_PATH)/crypto/asn1/x_pkey.c > + $(OPENSSL_PATH)/crypto/asn1/x_sig.c > + $(OPENSSL_PATH)/crypto/asn1/x_spki.c > + $(OPENSSL_PATH)/crypto/asn1/x_val.c > + $(OPENSSL_PATH)/crypto/async/arch/async_null.c > + $(OPENSSL_PATH)/crypto/async/arch/async_posix.c > + $(OPENSSL_PATH)/crypto/async/arch/async_win.c > + $(OPENSSL_PATH)/crypto/async/async.c > + $(OPENSSL_PATH)/crypto/async/async_err.c > + $(OPENSSL_PATH)/crypto/async/async_wait.c > + $(OPENSSL_PATH)/crypto/bio/b_addr.c > + $(OPENSSL_PATH)/crypto/bio/b_dump.c > + $(OPENSSL_PATH)/crypto/bio/b_sock.c > + $(OPENSSL_PATH)/crypto/bio/b_sock2.c > + $(OPENSSL_PATH)/crypto/bio/bf_buff.c > + $(OPENSSL_PATH)/crypto/bio/bf_lbuf.c > + $(OPENSSL_PATH)/crypto/bio/bf_nbio.c > + $(OPENSSL_PATH)/crypto/bio/bf_null.c > + $(OPENSSL_PATH)/crypto/bio/bio_cb.c > + $(OPENSSL_PATH)/crypto/bio/bio_err.c > + $(OPENSSL_PATH)/crypto/bio/bio_lib.c > + $(OPENSSL_PATH)/crypto/bio/bio_meth.c > + $(OPENSSL_PATH)/crypto/bio/bss_acpt.c > + $(OPENSSL_PATH)/crypto/bio/bss_bio.c > + $(OPENSSL_PATH)/crypto/bio/bss_conn.c > + $(OPENSSL_PATH)/crypto/bio/bss_dgram.c > + $(OPENSSL_PATH)/crypto/bio/bss_fd.c > + $(OPENSSL_PATH)/crypto/bio/bss_file.c > + $(OPENSSL_PATH)/crypto/bio/bss_log.c > + $(OPENSSL_PATH)/crypto/bio/bss_mem.c > + $(OPENSSL_PATH)/crypto/bio/bss_null.c > + $(OPENSSL_PATH)/crypto/bio/bss_sock.c > + $(OPENSSL_PATH)/crypto/bn/bn_add.c > + $(OPENSSL_PATH)/crypto/bn/bn_asm.c > + $(OPENSSL_PATH)/crypto/bn/bn_blind.c > + $(OPENSSL_PATH)/crypto/bn/bn_const.c > + $(OPENSSL_PATH)/crypto/bn/bn_ctx.c > + $(OPENSSL_PATH)/crypto/bn/bn_depr.c > + $(OPENSSL_PATH)/crypto/bn/bn_dh.c > + $(OPENSSL_PATH)/crypto/bn/bn_div.c > + $(OPENSSL_PATH)/crypto/bn/bn_err.c > + $(OPENSSL_PATH)/crypto/bn/bn_exp.c > + $(OPENSSL_PATH)/crypto/bn/bn_exp2.c > + $(OPENSSL_PATH)/crypto/bn/bn_gcd.c > + $(OPENSSL_PATH)/crypto/bn/bn_gf2m.c > + $(OPENSSL_PATH)/crypto/bn/bn_intern.c > + $(OPENSSL_PATH)/crypto/bn/bn_kron.c > + $(OPENSSL_PATH)/crypto/bn/bn_lib.c > + $(OPENSSL_PATH)/crypto/bn/bn_mod.c > + $(OPENSSL_PATH)/crypto/bn/bn_mont.c > + $(OPENSSL_PATH)/crypto/bn/bn_mpi.c > + $(OPENSSL_PATH)/crypto/bn/bn_mul.c > + $(OPENSSL_PATH)/crypto/bn/bn_nist.c > + $(OPENSSL_PATH)/crypto/bn/bn_prime.c > + $(OPENSSL_PATH)/crypto/bn/bn_print.c > + $(OPENSSL_PATH)/crypto/bn/bn_rand.c > + $(OPENSSL_PATH)/crypto/bn/bn_recp.c > + $(OPENSSL_PATH)/crypto/bn/bn_shift.c > + $(OPENSSL_PATH)/crypto/bn/bn_sqr.c > + $(OPENSSL_PATH)/crypto/bn/bn_sqrt.c > + $(OPENSSL_PATH)/crypto/bn/bn_srp.c > + $(OPENSSL_PATH)/crypto/bn/bn_word.c > + $(OPENSSL_PATH)/crypto/bn/bn_x931p.c > + $(OPENSSL_PATH)/crypto/buffer/buf_err.c > + $(OPENSSL_PATH)/crypto/buffer/buffer.c > + $(OPENSSL_PATH)/crypto/cmac/cm_ameth.c > + $(OPENSSL_PATH)/crypto/cmac/cm_pmeth.c > + $(OPENSSL_PATH)/crypto/cmac/cmac.c > + $(OPENSSL_PATH)/crypto/comp/c_zlib.c > + $(OPENSSL_PATH)/crypto/comp/comp_err.c > + $(OPENSSL_PATH)/crypto/comp/comp_lib.c > + $(OPENSSL_PATH)/crypto/conf/conf_api.c > + $(OPENSSL_PATH)/crypto/conf/conf_def.c > + $(OPENSSL_PATH)/crypto/conf/conf_err.c > + $(OPENSSL_PATH)/crypto/conf/conf_lib.c > + $(OPENSSL_PATH)/crypto/conf/conf_mall.c > + $(OPENSSL_PATH)/crypto/conf/conf_mod.c > + $(OPENSSL_PATH)/crypto/conf/conf_sap.c > + $(OPENSSL_PATH)/crypto/conf/conf_ssl.c > + $(OPENSSL_PATH)/crypto/cpt_err.c > + $(OPENSSL_PATH)/crypto/cryptlib.c > + $(OPENSSL_PATH)/crypto/ctype.c > + $(OPENSSL_PATH)/crypto/cversion.c > + $(OPENSSL_PATH)/crypto/dh/dh_ameth.c > + $(OPENSSL_PATH)/crypto/dh/dh_asn1.c > + $(OPENSSL_PATH)/crypto/dh/dh_check.c > + $(OPENSSL_PATH)/crypto/dh/dh_depr.c > + $(OPENSSL_PATH)/crypto/dh/dh_err.c > + $(OPENSSL_PATH)/crypto/dh/dh_gen.c > + $(OPENSSL_PATH)/crypto/dh/dh_kdf.c > + $(OPENSSL_PATH)/crypto/dh/dh_key.c > + $(OPENSSL_PATH)/crypto/dh/dh_lib.c > + $(OPENSSL_PATH)/crypto/dh/dh_meth.c > + $(OPENSSL_PATH)/crypto/dh/dh_pmeth.c > + $(OPENSSL_PATH)/crypto/dh/dh_prn.c > + $(OPENSSL_PATH)/crypto/dh/dh_rfc5114.c > + $(OPENSSL_PATH)/crypto/dh/dh_rfc7919.c > + $(OPENSSL_PATH)/crypto/dso/dso_dl.c > + $(OPENSSL_PATH)/crypto/dso/dso_dlfcn.c > + $(OPENSSL_PATH)/crypto/dso/dso_err.c > + $(OPENSSL_PATH)/crypto/dso/dso_lib.c > + $(OPENSSL_PATH)/crypto/dso/dso_openssl.c > + $(OPENSSL_PATH)/crypto/dso/dso_vms.c > + $(OPENSSL_PATH)/crypto/dso/dso_win32.c > + $(OPENSSL_PATH)/crypto/ebcdic.c > + $(OPENSSL_PATH)/crypto/err/err.c > + $(OPENSSL_PATH)/crypto/err/err_prn.c > + $(OPENSSL_PATH)/crypto/evp/bio_b64.c > + $(OPENSSL_PATH)/crypto/evp/bio_enc.c > + $(OPENSSL_PATH)/crypto/evp/bio_md.c > + $(OPENSSL_PATH)/crypto/evp/bio_ok.c > + $(OPENSSL_PATH)/crypto/evp/c_allc.c > + $(OPENSSL_PATH)/crypto/evp/c_alld.c > + $(OPENSSL_PATH)/crypto/evp/cmeth_lib.c > + $(OPENSSL_PATH)/crypto/evp/digest.c > + $(OPENSSL_PATH)/crypto/evp/e_aes.c > + $(OPENSSL_PATH)/crypto/evp/e_aes_cbc_hmac_sha1.c > + $(OPENSSL_PATH)/crypto/evp/e_aes_cbc_hmac_sha256.c > + $(OPENSSL_PATH)/crypto/evp/e_aria.c > + $(OPENSSL_PATH)/crypto/evp/e_bf.c > + $(OPENSSL_PATH)/crypto/evp/e_camellia.c > + $(OPENSSL_PATH)/crypto/evp/e_cast.c > + $(OPENSSL_PATH)/crypto/evp/e_chacha20_poly1305.c > + $(OPENSSL_PATH)/crypto/evp/e_des.c > + $(OPENSSL_PATH)/crypto/evp/e_des3.c > + $(OPENSSL_PATH)/crypto/evp/e_idea.c > + $(OPENSSL_PATH)/crypto/evp/e_null.c > + $(OPENSSL_PATH)/crypto/evp/e_old.c > + $(OPENSSL_PATH)/crypto/evp/e_rc2.c > + $(OPENSSL_PATH)/crypto/evp/e_rc4.c > + $(OPENSSL_PATH)/crypto/evp/e_rc4_hmac_md5.c > + $(OPENSSL_PATH)/crypto/evp/e_rc5.c > + $(OPENSSL_PATH)/crypto/evp/e_seed.c > + $(OPENSSL_PATH)/crypto/evp/e_sm4.c > + $(OPENSSL_PATH)/crypto/evp/e_xcbc_d.c > + $(OPENSSL_PATH)/crypto/evp/encode.c > + $(OPENSSL_PATH)/crypto/evp/evp_cnf.c > + $(OPENSSL_PATH)/crypto/evp/evp_enc.c > + $(OPENSSL_PATH)/crypto/evp/evp_err.c > + $(OPENSSL_PATH)/crypto/evp/evp_key.c > + $(OPENSSL_PATH)/crypto/evp/evp_lib.c > + $(OPENSSL_PATH)/crypto/evp/evp_pbe.c > + $(OPENSSL_PATH)/crypto/evp/evp_pkey.c > + $(OPENSSL_PATH)/crypto/evp/m_md2.c > + $(OPENSSL_PATH)/crypto/evp/m_md4.c > + $(OPENSSL_PATH)/crypto/evp/m_md5.c > + $(OPENSSL_PATH)/crypto/evp/m_md5_sha1.c > + $(OPENSSL_PATH)/crypto/evp/m_mdc2.c > + $(OPENSSL_PATH)/crypto/evp/m_null.c > + $(OPENSSL_PATH)/crypto/evp/m_ripemd.c > + $(OPENSSL_PATH)/crypto/evp/m_sha1.c > + $(OPENSSL_PATH)/crypto/evp/m_sha3.c > + $(OPENSSL_PATH)/crypto/evp/m_sigver.c > + $(OPENSSL_PATH)/crypto/evp/m_wp.c > + $(OPENSSL_PATH)/crypto/evp/names.c > + $(OPENSSL_PATH)/crypto/evp/p5_crpt.c > + $(OPENSSL_PATH)/crypto/evp/p5_crpt2.c > + $(OPENSSL_PATH)/crypto/evp/p_dec.c > + $(OPENSSL_PATH)/crypto/evp/p_enc.c > + $(OPENSSL_PATH)/crypto/evp/p_lib.c > + $(OPENSSL_PATH)/crypto/evp/p_open.c > + $(OPENSSL_PATH)/crypto/evp/p_seal.c > + $(OPENSSL_PATH)/crypto/evp/p_sign.c > + $(OPENSSL_PATH)/crypto/evp/p_verify.c > + $(OPENSSL_PATH)/crypto/evp/pbe_scrypt.c > + $(OPENSSL_PATH)/crypto/evp/pmeth_fn.c > + $(OPENSSL_PATH)/crypto/evp/pmeth_gn.c > + $(OPENSSL_PATH)/crypto/evp/pmeth_lib.c > + $(OPENSSL_PATH)/crypto/ex_data.c > + $(OPENSSL_PATH)/crypto/getenv.c > + $(OPENSSL_PATH)/crypto/hmac/hm_ameth.c > + $(OPENSSL_PATH)/crypto/hmac/hm_pmeth.c > + $(OPENSSL_PATH)/crypto/hmac/hmac.c > + $(OPENSSL_PATH)/crypto/init.c > + $(OPENSSL_PATH)/crypto/kdf/hkdf.c > + $(OPENSSL_PATH)/crypto/kdf/kdf_err.c > + $(OPENSSL_PATH)/crypto/kdf/scrypt.c > + $(OPENSSL_PATH)/crypto/kdf/tls1_prf.c > + $(OPENSSL_PATH)/crypto/lhash/lh_stats.c > + $(OPENSSL_PATH)/crypto/lhash/lhash.c > + $(OPENSSL_PATH)/crypto/md5/md5_dgst.c > + $(OPENSSL_PATH)/crypto/md5/md5_one.c > + $(OPENSSL_PATH)/crypto/mem.c > + $(OPENSSL_PATH)/crypto/mem_dbg.c > + $(OPENSSL_PATH)/crypto/mem_sec.c > + $(OPENSSL_PATH)/crypto/modes/cbc128.c > + $(OPENSSL_PATH)/crypto/modes/ccm128.c > + $(OPENSSL_PATH)/crypto/modes/cfb128.c > + $(OPENSSL_PATH)/crypto/modes/ctr128.c > + $(OPENSSL_PATH)/crypto/modes/cts128.c > + $(OPENSSL_PATH)/crypto/modes/gcm128.c > + $(OPENSSL_PATH)/crypto/modes/ocb128.c > + $(OPENSSL_PATH)/crypto/modes/ofb128.c > + $(OPENSSL_PATH)/crypto/modes/wrap128.c > + $(OPENSSL_PATH)/crypto/modes/xts128.c > + $(OPENSSL_PATH)/crypto/o_dir.c > + $(OPENSSL_PATH)/crypto/o_fips.c > + $(OPENSSL_PATH)/crypto/o_fopen.c > + $(OPENSSL_PATH)/crypto/o_init.c > + $(OPENSSL_PATH)/crypto/o_str.c > + $(OPENSSL_PATH)/crypto/o_time.c > + $(OPENSSL_PATH)/crypto/objects/o_names.c > + $(OPENSSL_PATH)/crypto/objects/obj_dat.c > + $(OPENSSL_PATH)/crypto/objects/obj_err.c > + $(OPENSSL_PATH)/crypto/objects/obj_lib.c > + $(OPENSSL_PATH)/crypto/objects/obj_xref.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_asn.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_cl.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_err.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_ext.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_ht.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_lib.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_prn.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_srv.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_vfy.c > + $(OPENSSL_PATH)/crypto/ocsp/v3_ocsp.c > + $(OPENSSL_PATH)/crypto/pem/pem_all.c > + $(OPENSSL_PATH)/crypto/pem/pem_err.c > + $(OPENSSL_PATH)/crypto/pem/pem_info.c > + $(OPENSSL_PATH)/crypto/pem/pem_lib.c > + $(OPENSSL_PATH)/crypto/pem/pem_oth.c > + $(OPENSSL_PATH)/crypto/pem/pem_pk8.c > + $(OPENSSL_PATH)/crypto/pem/pem_pkey.c > + $(OPENSSL_PATH)/crypto/pem/pem_sign.c > + $(OPENSSL_PATH)/crypto/pem/pem_x509.c > + $(OPENSSL_PATH)/crypto/pem/pem_xaux.c > + $(OPENSSL_PATH)/crypto/pem/pvkfmt.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_add.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_asn.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_attr.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_crpt.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_crt.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_decr.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_init.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_key.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_kiss.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_mutl.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_npas.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_p8d.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_p8e.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_sbag.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_utl.c > + $(OPENSSL_PATH)/crypto/pkcs12/pk12err.c > + $(OPENSSL_PATH)/crypto/pkcs7/bio_pk7.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_asn1.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_attr.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_doit.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_lib.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_mime.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_smime.c > + $(OPENSSL_PATH)/crypto/pkcs7/pkcs7err.c > + $(OPENSSL_PATH)/crypto/rand/drbg_ctr.c > + $(OPENSSL_PATH)/crypto/rand/drbg_lib.c > + $(OPENSSL_PATH)/crypto/rand/rand_egd.c > + $(OPENSSL_PATH)/crypto/rand/rand_err.c > + $(OPENSSL_PATH)/crypto/rand/rand_lib.c > + $(OPENSSL_PATH)/crypto/rand/rand_unix.c > + $(OPENSSL_PATH)/crypto/rand/rand_vms.c > + $(OPENSSL_PATH)/crypto/rand/rand_win.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_ameth.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_asn1.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_chk.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_crpt.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_depr.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_err.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_gen.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_lib.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_meth.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_mp.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_none.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_oaep.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_ossl.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_pk1.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_pmeth.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_prn.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_pss.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_saos.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_sign.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_ssl.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_x931.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_x931g.c > + $(OPENSSL_PATH)/crypto/sha/keccak1600.c > + $(OPENSSL_PATH)/crypto/sha/sha1_one.c > + $(OPENSSL_PATH)/crypto/sha/sha1dgst.c > + $(OPENSSL_PATH)/crypto/sha/sha256.c > + $(OPENSSL_PATH)/crypto/sha/sha512.c > + $(OPENSSL_PATH)/crypto/siphash/siphash.c > + $(OPENSSL_PATH)/crypto/siphash/siphash_ameth.c > + $(OPENSSL_PATH)/crypto/siphash/siphash_pmeth.c > + $(OPENSSL_PATH)/crypto/sm3/m_sm3.c > + $(OPENSSL_PATH)/crypto/sm3/sm3.c > + $(OPENSSL_PATH)/crypto/sm4/sm4.c > + $(OPENSSL_PATH)/crypto/stack/stack.c > + $(OPENSSL_PATH)/crypto/threads_none.c > + $(OPENSSL_PATH)/crypto/threads_pthread.c > + $(OPENSSL_PATH)/crypto/threads_win.c > + $(OPENSSL_PATH)/crypto/txt_db/txt_db.c > + $(OPENSSL_PATH)/crypto/ui/ui_err.c > + $(OPENSSL_PATH)/crypto/ui/ui_lib.c > + $(OPENSSL_PATH)/crypto/ui/ui_null.c > + $(OPENSSL_PATH)/crypto/ui/ui_openssl.c > + $(OPENSSL_PATH)/crypto/ui/ui_util.c > + $(OPENSSL_PATH)/crypto/uid.c > + $(OPENSSL_PATH)/crypto/x509/by_dir.c > + $(OPENSSL_PATH)/crypto/x509/by_file.c > + $(OPENSSL_PATH)/crypto/x509/t_crl.c > + $(OPENSSL_PATH)/crypto/x509/t_req.c > + $(OPENSSL_PATH)/crypto/x509/t_x509.c > + $(OPENSSL_PATH)/crypto/x509/x509_att.c > + $(OPENSSL_PATH)/crypto/x509/x509_cmp.c > + $(OPENSSL_PATH)/crypto/x509/x509_d2.c > + $(OPENSSL_PATH)/crypto/x509/x509_def.c > + $(OPENSSL_PATH)/crypto/x509/x509_err.c > + $(OPENSSL_PATH)/crypto/x509/x509_ext.c > + $(OPENSSL_PATH)/crypto/x509/x509_lu.c > + $(OPENSSL_PATH)/crypto/x509/x509_meth.c > + $(OPENSSL_PATH)/crypto/x509/x509_obj.c > + $(OPENSSL_PATH)/crypto/x509/x509_r2x.c > + $(OPENSSL_PATH)/crypto/x509/x509_req.c > + $(OPENSSL_PATH)/crypto/x509/x509_set.c > + $(OPENSSL_PATH)/crypto/x509/x509_trs.c > + $(OPENSSL_PATH)/crypto/x509/x509_txt.c > + $(OPENSSL_PATH)/crypto/x509/x509_v3.c > + $(OPENSSL_PATH)/crypto/x509/x509_vfy.c > + $(OPENSSL_PATH)/crypto/x509/x509_vpm.c > + $(OPENSSL_PATH)/crypto/x509/x509cset.c > + $(OPENSSL_PATH)/crypto/x509/x509name.c > + $(OPENSSL_PATH)/crypto/x509/x509rset.c > + $(OPENSSL_PATH)/crypto/x509/x509spki.c > + $(OPENSSL_PATH)/crypto/x509/x509type.c > + $(OPENSSL_PATH)/crypto/x509/x_all.c > + $(OPENSSL_PATH)/crypto/x509/x_attrib.c > + $(OPENSSL_PATH)/crypto/x509/x_crl.c > + $(OPENSSL_PATH)/crypto/x509/x_exten.c > + $(OPENSSL_PATH)/crypto/x509/x_name.c > + $(OPENSSL_PATH)/crypto/x509/x_pubkey.c > + $(OPENSSL_PATH)/crypto/x509/x_req.c > + $(OPENSSL_PATH)/crypto/x509/x_x509.c > + $(OPENSSL_PATH)/crypto/x509/x_x509a.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_cache.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_data.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_lib.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_map.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_node.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_tree.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_addr.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_admis.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_akey.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_akeya.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_alt.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_asid.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_bcons.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_bitst.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_conf.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_cpols.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_crld.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_enum.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_extku.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_genn.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_ia5.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_info.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_int.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_lib.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_ncons.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pci.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pcia.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pcons.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pku.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pmaps.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_prn.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_purp.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_skey.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_sxnet.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_tlsf.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_utl.c > + $(OPENSSL_PATH)/crypto/x509v3/v3err.c > + $(OPENSSL_PATH)/crypto/arm_arch.h > + $(OPENSSL_PATH)/crypto/mips_arch.h > + $(OPENSSL_PATH)/crypto/ppc_arch.h > + $(OPENSSL_PATH)/crypto/s390x_arch.h > + $(OPENSSL_PATH)/crypto/sparc_arch.h > + $(OPENSSL_PATH)/crypto/vms_rms.h > + $(OPENSSL_PATH)/crypto/aes/aes_local.h > + $(OPENSSL_PATH)/crypto/asn1/asn1_item_list.h > + $(OPENSSL_PATH)/crypto/asn1/asn1_local.h > + $(OPENSSL_PATH)/crypto/asn1/charmap.h > + $(OPENSSL_PATH)/crypto/asn1/standard_methods.h > + $(OPENSSL_PATH)/crypto/asn1/tbl_standard.h > + $(OPENSSL_PATH)/crypto/async/async_local.h > + $(OPENSSL_PATH)/crypto/async/arch/async_null.h > + $(OPENSSL_PATH)/crypto/async/arch/async_posix.h > + $(OPENSSL_PATH)/crypto/async/arch/async_win.h > + $(OPENSSL_PATH)/crypto/bio/bio_local.h > + $(OPENSSL_PATH)/crypto/bn/bn_local.h > + $(OPENSSL_PATH)/crypto/bn/bn_prime.h > + $(OPENSSL_PATH)/crypto/bn/rsaz_exp.h > + $(OPENSSL_PATH)/crypto/comp/comp_local.h > + $(OPENSSL_PATH)/crypto/conf/conf_def.h > + $(OPENSSL_PATH)/crypto/conf/conf_local.h > + $(OPENSSL_PATH)/crypto/dh/dh_local.h > + $(OPENSSL_PATH)/crypto/dso/dso_local.h > + $(OPENSSL_PATH)/crypto/evp/evp_local.h > + $(OPENSSL_PATH)/crypto/hmac/hmac_local.h > + $(OPENSSL_PATH)/crypto/lhash/lhash_local.h > + $(OPENSSL_PATH)/crypto/md5/md5_local.h > + $(OPENSSL_PATH)/crypto/modes/modes_local.h > + $(OPENSSL_PATH)/crypto/objects/obj_dat.h > + $(OPENSSL_PATH)/crypto/objects/obj_local.h > + $(OPENSSL_PATH)/crypto/objects/obj_xref.h > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_local.h > + $(OPENSSL_PATH)/crypto/pkcs12/p12_local.h > + $(OPENSSL_PATH)/crypto/rand/rand_local.h > + $(OPENSSL_PATH)/crypto/rsa/rsa_local.h > + $(OPENSSL_PATH)/crypto/sha/sha_local.h > + $(OPENSSL_PATH)/crypto/siphash/siphash_local.h > + $(OPENSSL_PATH)/crypto/sm3/sm3_local.h > + $(OPENSSL_PATH)/crypto/store/store_local.h > + $(OPENSSL_PATH)/crypto/ui/ui_local.h > + $(OPENSSL_PATH)/crypto/x509/x509_local.h > + $(OPENSSL_PATH)/crypto/x509v3/ext_dat.h > + $(OPENSSL_PATH)/crypto/x509v3/pcy_local.h > + $(OPENSSL_PATH)/crypto/x509v3/standard_exts.h > + $(OPENSSL_PATH)/crypto/x509v3/v3_admis.h > + $(OPENSSL_PATH)/ssl/bio_ssl.c > + $(OPENSSL_PATH)/ssl/d1_lib.c > + $(OPENSSL_PATH)/ssl/d1_msg.c > + $(OPENSSL_PATH)/ssl/d1_srtp.c > + $(OPENSSL_PATH)/ssl/methods.c > + $(OPENSSL_PATH)/ssl/packet.c > + $(OPENSSL_PATH)/ssl/pqueue.c > + $(OPENSSL_PATH)/ssl/record/dtls1_bitmap.c > + $(OPENSSL_PATH)/ssl/record/rec_layer_d1.c > + $(OPENSSL_PATH)/ssl/record/rec_layer_s3.c > + $(OPENSSL_PATH)/ssl/record/ssl3_buffer.c > + $(OPENSSL_PATH)/ssl/record/ssl3_record.c > + $(OPENSSL_PATH)/ssl/record/ssl3_record_tls13.c > + $(OPENSSL_PATH)/ssl/s3_cbc.c > + $(OPENSSL_PATH)/ssl/s3_enc.c > + $(OPENSSL_PATH)/ssl/s3_lib.c > + $(OPENSSL_PATH)/ssl/s3_msg.c > + $(OPENSSL_PATH)/ssl/ssl_asn1.c > + $(OPENSSL_PATH)/ssl/ssl_cert.c > + $(OPENSSL_PATH)/ssl/ssl_ciph.c > + $(OPENSSL_PATH)/ssl/ssl_conf.c > + $(OPENSSL_PATH)/ssl/ssl_err.c > + $(OPENSSL_PATH)/ssl/ssl_init.c > + $(OPENSSL_PATH)/ssl/ssl_lib.c > + $(OPENSSL_PATH)/ssl/ssl_mcnf.c > + $(OPENSSL_PATH)/ssl/ssl_rsa.c > + $(OPENSSL_PATH)/ssl/ssl_sess.c > + $(OPENSSL_PATH)/ssl/ssl_stat.c > + $(OPENSSL_PATH)/ssl/ssl_txt.c > + $(OPENSSL_PATH)/ssl/ssl_utst.c > + $(OPENSSL_PATH)/ssl/statem/extensions.c > + $(OPENSSL_PATH)/ssl/statem/extensions_clnt.c > + $(OPENSSL_PATH)/ssl/statem/extensions_cust.c > + $(OPENSSL_PATH)/ssl/statem/extensions_srvr.c > + $(OPENSSL_PATH)/ssl/statem/statem.c > + $(OPENSSL_PATH)/ssl/statem/statem_clnt.c > + $(OPENSSL_PATH)/ssl/statem/statem_dtls.c > + $(OPENSSL_PATH)/ssl/statem/statem_lib.c > + $(OPENSSL_PATH)/ssl/statem/statem_srvr.c > + $(OPENSSL_PATH)/ssl/t1_enc.c > + $(OPENSSL_PATH)/ssl/t1_lib.c > + $(OPENSSL_PATH)/ssl/t1_trce.c > + $(OPENSSL_PATH)/ssl/tls13_enc.c > + $(OPENSSL_PATH)/ssl/tls_srp.c > + $(OPENSSL_PATH)/ssl/packet_local.h > + $(OPENSSL_PATH)/ssl/ssl_cert_table.h > + $(OPENSSL_PATH)/ssl/ssl_local.h > + $(OPENSSL_PATH)/ssl/record/record.h > + $(OPENSSL_PATH)/ssl/record/record_local.h > + $(OPENSSL_PATH)/ssl/statem/statem.h > + $(OPENSSL_PATH)/ssl/statem/statem_local.h > +# Autogenerated files list ends here > + buildinf.h > + ossl_store.c > + rand_pool.c > + X64/ApiHooks.c > + > +[Packages] > + MdePkg/MdePkg.dec > + CryptoPkg/CryptoPkg.dec > + > +[LibraryClasses] > + BaseLib > + DebugLib > + RngLib > + PrintLib > + > +[BuildOptions] > + # > + # Disables the following Visual Studio compiler warnings brought by op= enssl > source, > + # so we do not break the build with /WX option: > + # C4090: 'function' : different 'const' qualifiers > + # C4132: 'object' : const object should be initialized (tls13_enc.c) > + # C4210: nonstandard extension used: function given file scope > + # C4244: conversion from type1 to type2, possible loss of data > + # C4245: conversion from type1 to type2, signed/unsigned mismatch > + # C4267: conversion from size_t to type, possible loss of data > + # C4306: 'identifier' : conversion from 'type1' to 'type2' of greate= r size > + # C4310: cast truncates constant value > + # C4389: 'operator' : signed/unsigned mismatch (xxxx) > + # C4700: uninitialized local variable 'name' used. (conf_sap.c(71)) > + # C4702: unreachable code > + # C4706: assignment within conditional expression > + # C4819: The file contains a character that cannot be represented in= the > current code page > + # > + MSFT:*_*_X64_CC_FLAGS =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 t= he build > with -Werror > + # -Werror=3Dmaybe-uninitialized: there exist some other paths for wh= ich the > variable is not initialized. > + # -Werror=3Dformat: Check calls to printf and scanf, etc., to make s= ure that the > arguments supplied have > + # types appropriate to the format string specified. > + # -Werror=3Dunused-but-set-variable: Warn whenever a local variable = is > assigned to, but otherwise unused (aside from its declaration). > + # > + GCC:*_*_X64_CC_FLAGS =3D -UWIN32 -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 bui= ld with > warnings-as-errors: > + # 1295: Deprecated declaration - give arg types > + # 550: was set but never used > + # 1293: assignment in condition > + # 111: statement is unreachable (invariably "break;" after "return X;= " in case > statement) > + # 68: integer conversion resulted in a change of sign ("if (Status = =3D=3D -1)") > + # 177: 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 integ= er as an > enum without a cast) > + # 1296: Extended constant initialiser used > + # 128: loop is not reachable - may be emitted inappropriately if code= follows > a conditional return > + # from the function that evaluates to true at compile time > + # 546: transfer of control bypasses initialization - may be emitted > inappropriately if the uninitialized > + # variable is never referenced after the jump > + # 1: ignore "#1-D: last line of file ends without a newline" > + # 3017: 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=3Duninitialized > diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf > b/CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf > new file mode 100644 > index 0000000000..4ffdd8cd06 > --- /dev/null > +++ b/CryptoPkg/Library/OpensslLib/OpensslLibX64Gcc.inf > @@ -0,0 +1,653 @@ > +## @file > +# This module provides OpenSSL Library implementation. > +# > +# Copyright (c) 2010 - 2020, Intel Corporation. All rights reserved. > +# (C) Copyright 2020 Hewlett Packard Enterprise Development LP
> +# SPDX-License-Identifier: BSD-2-Clause-Patent > +# > +## > + > +[Defines] > + INF_VERSION =3D 0x00010005 > + BASE_NAME =3D OpensslLibX64Gcc > + MODULE_UNI_FILE =3D OpensslLib.uni > + FILE_GUID =3D DD90DB9D-6A3F-4F2B-87BF-A8F2BBEF982= F > + 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_FOOTPRIN= T > -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.X64] > + OpensslLibConstructor.c > + $(OPENSSL_PATH)/e_os.h > + $(OPENSSL_PATH)/ms/uplink.h > +# Autogenerated files list starts here > + X64Gcc/crypto/aes/aesni-mb-x86_64.S > + X64Gcc/crypto/aes/aesni-sha1-x86_64.S > + X64Gcc/crypto/aes/aesni-sha256-x86_64.S > + X64Gcc/crypto/aes/aesni-x86_64.S > + X64Gcc/crypto/aes/vpaes-x86_64.S > + X64Gcc/crypto/modes/aesni-gcm-x86_64.S > + X64Gcc/crypto/modes/ghash-x86_64.S > + X64Gcc/crypto/sha/sha1-mb-x86_64.S > + X64Gcc/crypto/sha/sha1-x86_64.S > + X64Gcc/crypto/sha/sha256-mb-x86_64.S > + X64Gcc/crypto/sha/sha256-x86_64.S > + X64Gcc/crypto/sha/sha512-x86_64.S > + X64Gcc/crypto/x86_64cpuid.S > + $(OPENSSL_PATH)/crypto/aes/aes_cbc.c > + $(OPENSSL_PATH)/crypto/aes/aes_cfb.c > + $(OPENSSL_PATH)/crypto/aes/aes_core.c > + $(OPENSSL_PATH)/crypto/aes/aes_ige.c > + $(OPENSSL_PATH)/crypto/aes/aes_misc.c > + $(OPENSSL_PATH)/crypto/aes/aes_ofb.c > + $(OPENSSL_PATH)/crypto/aes/aes_wrap.c > + $(OPENSSL_PATH)/crypto/aria/aria.c > + $(OPENSSL_PATH)/crypto/asn1/a_bitstr.c > + $(OPENSSL_PATH)/crypto/asn1/a_d2i_fp.c > + $(OPENSSL_PATH)/crypto/asn1/a_digest.c > + $(OPENSSL_PATH)/crypto/asn1/a_dup.c > + $(OPENSSL_PATH)/crypto/asn1/a_gentm.c > + $(OPENSSL_PATH)/crypto/asn1/a_i2d_fp.c > + $(OPENSSL_PATH)/crypto/asn1/a_int.c > + $(OPENSSL_PATH)/crypto/asn1/a_mbstr.c > + $(OPENSSL_PATH)/crypto/asn1/a_object.c > + $(OPENSSL_PATH)/crypto/asn1/a_octet.c > + $(OPENSSL_PATH)/crypto/asn1/a_print.c > + $(OPENSSL_PATH)/crypto/asn1/a_sign.c > + $(OPENSSL_PATH)/crypto/asn1/a_strex.c > + $(OPENSSL_PATH)/crypto/asn1/a_strnid.c > + $(OPENSSL_PATH)/crypto/asn1/a_time.c > + $(OPENSSL_PATH)/crypto/asn1/a_type.c > + $(OPENSSL_PATH)/crypto/asn1/a_utctm.c > + $(OPENSSL_PATH)/crypto/asn1/a_utf8.c > + $(OPENSSL_PATH)/crypto/asn1/a_verify.c > + $(OPENSSL_PATH)/crypto/asn1/ameth_lib.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_err.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_gen.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_item_list.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_lib.c > + $(OPENSSL_PATH)/crypto/asn1/asn1_par.c > + $(OPENSSL_PATH)/crypto/asn1/asn_mime.c > + $(OPENSSL_PATH)/crypto/asn1/asn_moid.c > + $(OPENSSL_PATH)/crypto/asn1/asn_mstbl.c > + $(OPENSSL_PATH)/crypto/asn1/asn_pack.c > + $(OPENSSL_PATH)/crypto/asn1/bio_asn1.c > + $(OPENSSL_PATH)/crypto/asn1/bio_ndef.c > + $(OPENSSL_PATH)/crypto/asn1/d2i_pr.c > + $(OPENSSL_PATH)/crypto/asn1/d2i_pu.c > + $(OPENSSL_PATH)/crypto/asn1/evp_asn1.c > + $(OPENSSL_PATH)/crypto/asn1/f_int.c > + $(OPENSSL_PATH)/crypto/asn1/f_string.c > + $(OPENSSL_PATH)/crypto/asn1/i2d_pr.c > + $(OPENSSL_PATH)/crypto/asn1/i2d_pu.c > + $(OPENSSL_PATH)/crypto/asn1/n_pkey.c > + $(OPENSSL_PATH)/crypto/asn1/nsseq.c > + $(OPENSSL_PATH)/crypto/asn1/p5_pbe.c > + $(OPENSSL_PATH)/crypto/asn1/p5_pbev2.c > + $(OPENSSL_PATH)/crypto/asn1/p5_scrypt.c > + $(OPENSSL_PATH)/crypto/asn1/p8_pkey.c > + $(OPENSSL_PATH)/crypto/asn1/t_bitst.c > + $(OPENSSL_PATH)/crypto/asn1/t_pkey.c > + $(OPENSSL_PATH)/crypto/asn1/t_spki.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_dec.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_enc.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_fre.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_new.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_prn.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_scn.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_typ.c > + $(OPENSSL_PATH)/crypto/asn1/tasn_utl.c > + $(OPENSSL_PATH)/crypto/asn1/x_algor.c > + $(OPENSSL_PATH)/crypto/asn1/x_bignum.c > + $(OPENSSL_PATH)/crypto/asn1/x_info.c > + $(OPENSSL_PATH)/crypto/asn1/x_int64.c > + $(OPENSSL_PATH)/crypto/asn1/x_long.c > + $(OPENSSL_PATH)/crypto/asn1/x_pkey.c > + $(OPENSSL_PATH)/crypto/asn1/x_sig.c > + $(OPENSSL_PATH)/crypto/asn1/x_spki.c > + $(OPENSSL_PATH)/crypto/asn1/x_val.c > + $(OPENSSL_PATH)/crypto/async/arch/async_null.c > + $(OPENSSL_PATH)/crypto/async/arch/async_posix.c > + $(OPENSSL_PATH)/crypto/async/arch/async_win.c > + $(OPENSSL_PATH)/crypto/async/async.c > + $(OPENSSL_PATH)/crypto/async/async_err.c > + $(OPENSSL_PATH)/crypto/async/async_wait.c > + $(OPENSSL_PATH)/crypto/bio/b_addr.c > + $(OPENSSL_PATH)/crypto/bio/b_dump.c > + $(OPENSSL_PATH)/crypto/bio/b_sock.c > + $(OPENSSL_PATH)/crypto/bio/b_sock2.c > + $(OPENSSL_PATH)/crypto/bio/bf_buff.c > + $(OPENSSL_PATH)/crypto/bio/bf_lbuf.c > + $(OPENSSL_PATH)/crypto/bio/bf_nbio.c > + $(OPENSSL_PATH)/crypto/bio/bf_null.c > + $(OPENSSL_PATH)/crypto/bio/bio_cb.c > + $(OPENSSL_PATH)/crypto/bio/bio_err.c > + $(OPENSSL_PATH)/crypto/bio/bio_lib.c > + $(OPENSSL_PATH)/crypto/bio/bio_meth.c > + $(OPENSSL_PATH)/crypto/bio/bss_acpt.c > + $(OPENSSL_PATH)/crypto/bio/bss_bio.c > + $(OPENSSL_PATH)/crypto/bio/bss_conn.c > + $(OPENSSL_PATH)/crypto/bio/bss_dgram.c > + $(OPENSSL_PATH)/crypto/bio/bss_fd.c > + $(OPENSSL_PATH)/crypto/bio/bss_file.c > + $(OPENSSL_PATH)/crypto/bio/bss_log.c > + $(OPENSSL_PATH)/crypto/bio/bss_mem.c > + $(OPENSSL_PATH)/crypto/bio/bss_null.c > + $(OPENSSL_PATH)/crypto/bio/bss_sock.c > + $(OPENSSL_PATH)/crypto/bn/bn_add.c > + $(OPENSSL_PATH)/crypto/bn/bn_asm.c > + $(OPENSSL_PATH)/crypto/bn/bn_blind.c > + $(OPENSSL_PATH)/crypto/bn/bn_const.c > + $(OPENSSL_PATH)/crypto/bn/bn_ctx.c > + $(OPENSSL_PATH)/crypto/bn/bn_depr.c > + $(OPENSSL_PATH)/crypto/bn/bn_dh.c > + $(OPENSSL_PATH)/crypto/bn/bn_div.c > + $(OPENSSL_PATH)/crypto/bn/bn_err.c > + $(OPENSSL_PATH)/crypto/bn/bn_exp.c > + $(OPENSSL_PATH)/crypto/bn/bn_exp2.c > + $(OPENSSL_PATH)/crypto/bn/bn_gcd.c > + $(OPENSSL_PATH)/crypto/bn/bn_gf2m.c > + $(OPENSSL_PATH)/crypto/bn/bn_intern.c > + $(OPENSSL_PATH)/crypto/bn/bn_kron.c > + $(OPENSSL_PATH)/crypto/bn/bn_lib.c > + $(OPENSSL_PATH)/crypto/bn/bn_mod.c > + $(OPENSSL_PATH)/crypto/bn/bn_mont.c > + $(OPENSSL_PATH)/crypto/bn/bn_mpi.c > + $(OPENSSL_PATH)/crypto/bn/bn_mul.c > + $(OPENSSL_PATH)/crypto/bn/bn_nist.c > + $(OPENSSL_PATH)/crypto/bn/bn_prime.c > + $(OPENSSL_PATH)/crypto/bn/bn_print.c > + $(OPENSSL_PATH)/crypto/bn/bn_rand.c > + $(OPENSSL_PATH)/crypto/bn/bn_recp.c > + $(OPENSSL_PATH)/crypto/bn/bn_shift.c > + $(OPENSSL_PATH)/crypto/bn/bn_sqr.c > + $(OPENSSL_PATH)/crypto/bn/bn_sqrt.c > + $(OPENSSL_PATH)/crypto/bn/bn_srp.c > + $(OPENSSL_PATH)/crypto/bn/bn_word.c > + $(OPENSSL_PATH)/crypto/bn/bn_x931p.c > + $(OPENSSL_PATH)/crypto/buffer/buf_err.c > + $(OPENSSL_PATH)/crypto/buffer/buffer.c > + $(OPENSSL_PATH)/crypto/cmac/cm_ameth.c > + $(OPENSSL_PATH)/crypto/cmac/cm_pmeth.c > + $(OPENSSL_PATH)/crypto/cmac/cmac.c > + $(OPENSSL_PATH)/crypto/comp/c_zlib.c > + $(OPENSSL_PATH)/crypto/comp/comp_err.c > + $(OPENSSL_PATH)/crypto/comp/comp_lib.c > + $(OPENSSL_PATH)/crypto/conf/conf_api.c > + $(OPENSSL_PATH)/crypto/conf/conf_def.c > + $(OPENSSL_PATH)/crypto/conf/conf_err.c > + $(OPENSSL_PATH)/crypto/conf/conf_lib.c > + $(OPENSSL_PATH)/crypto/conf/conf_mall.c > + $(OPENSSL_PATH)/crypto/conf/conf_mod.c > + $(OPENSSL_PATH)/crypto/conf/conf_sap.c > + $(OPENSSL_PATH)/crypto/conf/conf_ssl.c > + $(OPENSSL_PATH)/crypto/cpt_err.c > + $(OPENSSL_PATH)/crypto/cryptlib.c > + $(OPENSSL_PATH)/crypto/ctype.c > + $(OPENSSL_PATH)/crypto/cversion.c > + $(OPENSSL_PATH)/crypto/dh/dh_ameth.c > + $(OPENSSL_PATH)/crypto/dh/dh_asn1.c > + $(OPENSSL_PATH)/crypto/dh/dh_check.c > + $(OPENSSL_PATH)/crypto/dh/dh_depr.c > + $(OPENSSL_PATH)/crypto/dh/dh_err.c > + $(OPENSSL_PATH)/crypto/dh/dh_gen.c > + $(OPENSSL_PATH)/crypto/dh/dh_kdf.c > + $(OPENSSL_PATH)/crypto/dh/dh_key.c > + $(OPENSSL_PATH)/crypto/dh/dh_lib.c > + $(OPENSSL_PATH)/crypto/dh/dh_meth.c > + $(OPENSSL_PATH)/crypto/dh/dh_pmeth.c > + $(OPENSSL_PATH)/crypto/dh/dh_prn.c > + $(OPENSSL_PATH)/crypto/dh/dh_rfc5114.c > + $(OPENSSL_PATH)/crypto/dh/dh_rfc7919.c > + $(OPENSSL_PATH)/crypto/dso/dso_dl.c > + $(OPENSSL_PATH)/crypto/dso/dso_dlfcn.c > + $(OPENSSL_PATH)/crypto/dso/dso_err.c > + $(OPENSSL_PATH)/crypto/dso/dso_lib.c > + $(OPENSSL_PATH)/crypto/dso/dso_openssl.c > + $(OPENSSL_PATH)/crypto/dso/dso_vms.c > + $(OPENSSL_PATH)/crypto/dso/dso_win32.c > + $(OPENSSL_PATH)/crypto/ebcdic.c > + $(OPENSSL_PATH)/crypto/err/err.c > + $(OPENSSL_PATH)/crypto/err/err_prn.c > + $(OPENSSL_PATH)/crypto/evp/bio_b64.c > + $(OPENSSL_PATH)/crypto/evp/bio_enc.c > + $(OPENSSL_PATH)/crypto/evp/bio_md.c > + $(OPENSSL_PATH)/crypto/evp/bio_ok.c > + $(OPENSSL_PATH)/crypto/evp/c_allc.c > + $(OPENSSL_PATH)/crypto/evp/c_alld.c > + $(OPENSSL_PATH)/crypto/evp/cmeth_lib.c > + $(OPENSSL_PATH)/crypto/evp/digest.c > + $(OPENSSL_PATH)/crypto/evp/e_aes.c > + $(OPENSSL_PATH)/crypto/evp/e_aes_cbc_hmac_sha1.c > + $(OPENSSL_PATH)/crypto/evp/e_aes_cbc_hmac_sha256.c > + $(OPENSSL_PATH)/crypto/evp/e_aria.c > + $(OPENSSL_PATH)/crypto/evp/e_bf.c > + $(OPENSSL_PATH)/crypto/evp/e_camellia.c > + $(OPENSSL_PATH)/crypto/evp/e_cast.c > + $(OPENSSL_PATH)/crypto/evp/e_chacha20_poly1305.c > + $(OPENSSL_PATH)/crypto/evp/e_des.c > + $(OPENSSL_PATH)/crypto/evp/e_des3.c > + $(OPENSSL_PATH)/crypto/evp/e_idea.c > + $(OPENSSL_PATH)/crypto/evp/e_null.c > + $(OPENSSL_PATH)/crypto/evp/e_old.c > + $(OPENSSL_PATH)/crypto/evp/e_rc2.c > + $(OPENSSL_PATH)/crypto/evp/e_rc4.c > + $(OPENSSL_PATH)/crypto/evp/e_rc4_hmac_md5.c > + $(OPENSSL_PATH)/crypto/evp/e_rc5.c > + $(OPENSSL_PATH)/crypto/evp/e_seed.c > + $(OPENSSL_PATH)/crypto/evp/e_sm4.c > + $(OPENSSL_PATH)/crypto/evp/e_xcbc_d.c > + $(OPENSSL_PATH)/crypto/evp/encode.c > + $(OPENSSL_PATH)/crypto/evp/evp_cnf.c > + $(OPENSSL_PATH)/crypto/evp/evp_enc.c > + $(OPENSSL_PATH)/crypto/evp/evp_err.c > + $(OPENSSL_PATH)/crypto/evp/evp_key.c > + $(OPENSSL_PATH)/crypto/evp/evp_lib.c > + $(OPENSSL_PATH)/crypto/evp/evp_pbe.c > + $(OPENSSL_PATH)/crypto/evp/evp_pkey.c > + $(OPENSSL_PATH)/crypto/evp/m_md2.c > + $(OPENSSL_PATH)/crypto/evp/m_md4.c > + $(OPENSSL_PATH)/crypto/evp/m_md5.c > + $(OPENSSL_PATH)/crypto/evp/m_md5_sha1.c > + $(OPENSSL_PATH)/crypto/evp/m_mdc2.c > + $(OPENSSL_PATH)/crypto/evp/m_null.c > + $(OPENSSL_PATH)/crypto/evp/m_ripemd.c > + $(OPENSSL_PATH)/crypto/evp/m_sha1.c > + $(OPENSSL_PATH)/crypto/evp/m_sha3.c > + $(OPENSSL_PATH)/crypto/evp/m_sigver.c > + $(OPENSSL_PATH)/crypto/evp/m_wp.c > + $(OPENSSL_PATH)/crypto/evp/names.c > + $(OPENSSL_PATH)/crypto/evp/p5_crpt.c > + $(OPENSSL_PATH)/crypto/evp/p5_crpt2.c > + $(OPENSSL_PATH)/crypto/evp/p_dec.c > + $(OPENSSL_PATH)/crypto/evp/p_enc.c > + $(OPENSSL_PATH)/crypto/evp/p_lib.c > + $(OPENSSL_PATH)/crypto/evp/p_open.c > + $(OPENSSL_PATH)/crypto/evp/p_seal.c > + $(OPENSSL_PATH)/crypto/evp/p_sign.c > + $(OPENSSL_PATH)/crypto/evp/p_verify.c > + $(OPENSSL_PATH)/crypto/evp/pbe_scrypt.c > + $(OPENSSL_PATH)/crypto/evp/pmeth_fn.c > + $(OPENSSL_PATH)/crypto/evp/pmeth_gn.c > + $(OPENSSL_PATH)/crypto/evp/pmeth_lib.c > + $(OPENSSL_PATH)/crypto/ex_data.c > + $(OPENSSL_PATH)/crypto/getenv.c > + $(OPENSSL_PATH)/crypto/hmac/hm_ameth.c > + $(OPENSSL_PATH)/crypto/hmac/hm_pmeth.c > + $(OPENSSL_PATH)/crypto/hmac/hmac.c > + $(OPENSSL_PATH)/crypto/init.c > + $(OPENSSL_PATH)/crypto/kdf/hkdf.c > + $(OPENSSL_PATH)/crypto/kdf/kdf_err.c > + $(OPENSSL_PATH)/crypto/kdf/scrypt.c > + $(OPENSSL_PATH)/crypto/kdf/tls1_prf.c > + $(OPENSSL_PATH)/crypto/lhash/lh_stats.c > + $(OPENSSL_PATH)/crypto/lhash/lhash.c > + $(OPENSSL_PATH)/crypto/md5/md5_dgst.c > + $(OPENSSL_PATH)/crypto/md5/md5_one.c > + $(OPENSSL_PATH)/crypto/mem.c > + $(OPENSSL_PATH)/crypto/mem_dbg.c > + $(OPENSSL_PATH)/crypto/mem_sec.c > + $(OPENSSL_PATH)/crypto/modes/cbc128.c > + $(OPENSSL_PATH)/crypto/modes/ccm128.c > + $(OPENSSL_PATH)/crypto/modes/cfb128.c > + $(OPENSSL_PATH)/crypto/modes/ctr128.c > + $(OPENSSL_PATH)/crypto/modes/cts128.c > + $(OPENSSL_PATH)/crypto/modes/gcm128.c > + $(OPENSSL_PATH)/crypto/modes/ocb128.c > + $(OPENSSL_PATH)/crypto/modes/ofb128.c > + $(OPENSSL_PATH)/crypto/modes/wrap128.c > + $(OPENSSL_PATH)/crypto/modes/xts128.c > + $(OPENSSL_PATH)/crypto/o_dir.c > + $(OPENSSL_PATH)/crypto/o_fips.c > + $(OPENSSL_PATH)/crypto/o_fopen.c > + $(OPENSSL_PATH)/crypto/o_init.c > + $(OPENSSL_PATH)/crypto/o_str.c > + $(OPENSSL_PATH)/crypto/o_time.c > + $(OPENSSL_PATH)/crypto/objects/o_names.c > + $(OPENSSL_PATH)/crypto/objects/obj_dat.c > + $(OPENSSL_PATH)/crypto/objects/obj_err.c > + $(OPENSSL_PATH)/crypto/objects/obj_lib.c > + $(OPENSSL_PATH)/crypto/objects/obj_xref.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_asn.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_cl.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_err.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_ext.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_ht.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_lib.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_prn.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_srv.c > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_vfy.c > + $(OPENSSL_PATH)/crypto/ocsp/v3_ocsp.c > + $(OPENSSL_PATH)/crypto/pem/pem_all.c > + $(OPENSSL_PATH)/crypto/pem/pem_err.c > + $(OPENSSL_PATH)/crypto/pem/pem_info.c > + $(OPENSSL_PATH)/crypto/pem/pem_lib.c > + $(OPENSSL_PATH)/crypto/pem/pem_oth.c > + $(OPENSSL_PATH)/crypto/pem/pem_pk8.c > + $(OPENSSL_PATH)/crypto/pem/pem_pkey.c > + $(OPENSSL_PATH)/crypto/pem/pem_sign.c > + $(OPENSSL_PATH)/crypto/pem/pem_x509.c > + $(OPENSSL_PATH)/crypto/pem/pem_xaux.c > + $(OPENSSL_PATH)/crypto/pem/pvkfmt.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_add.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_asn.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_attr.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_crpt.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_crt.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_decr.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_init.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_key.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_kiss.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_mutl.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_npas.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_p8d.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_p8e.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_sbag.c > + $(OPENSSL_PATH)/crypto/pkcs12/p12_utl.c > + $(OPENSSL_PATH)/crypto/pkcs12/pk12err.c > + $(OPENSSL_PATH)/crypto/pkcs7/bio_pk7.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_asn1.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_attr.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_doit.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_lib.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_mime.c > + $(OPENSSL_PATH)/crypto/pkcs7/pk7_smime.c > + $(OPENSSL_PATH)/crypto/pkcs7/pkcs7err.c > + $(OPENSSL_PATH)/crypto/rand/drbg_ctr.c > + $(OPENSSL_PATH)/crypto/rand/drbg_lib.c > + $(OPENSSL_PATH)/crypto/rand/rand_egd.c > + $(OPENSSL_PATH)/crypto/rand/rand_err.c > + $(OPENSSL_PATH)/crypto/rand/rand_lib.c > + $(OPENSSL_PATH)/crypto/rand/rand_unix.c > + $(OPENSSL_PATH)/crypto/rand/rand_vms.c > + $(OPENSSL_PATH)/crypto/rand/rand_win.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_ameth.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_asn1.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_chk.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_crpt.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_depr.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_err.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_gen.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_lib.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_meth.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_mp.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_none.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_oaep.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_ossl.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_pk1.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_pmeth.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_prn.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_pss.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_saos.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_sign.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_ssl.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_x931.c > + $(OPENSSL_PATH)/crypto/rsa/rsa_x931g.c > + $(OPENSSL_PATH)/crypto/sha/keccak1600.c > + $(OPENSSL_PATH)/crypto/sha/sha1_one.c > + $(OPENSSL_PATH)/crypto/sha/sha1dgst.c > + $(OPENSSL_PATH)/crypto/sha/sha256.c > + $(OPENSSL_PATH)/crypto/sha/sha512.c > + $(OPENSSL_PATH)/crypto/siphash/siphash.c > + $(OPENSSL_PATH)/crypto/siphash/siphash_ameth.c > + $(OPENSSL_PATH)/crypto/siphash/siphash_pmeth.c > + $(OPENSSL_PATH)/crypto/sm3/m_sm3.c > + $(OPENSSL_PATH)/crypto/sm3/sm3.c > + $(OPENSSL_PATH)/crypto/sm4/sm4.c > + $(OPENSSL_PATH)/crypto/stack/stack.c > + $(OPENSSL_PATH)/crypto/threads_none.c > + $(OPENSSL_PATH)/crypto/threads_pthread.c > + $(OPENSSL_PATH)/crypto/threads_win.c > + $(OPENSSL_PATH)/crypto/txt_db/txt_db.c > + $(OPENSSL_PATH)/crypto/ui/ui_err.c > + $(OPENSSL_PATH)/crypto/ui/ui_lib.c > + $(OPENSSL_PATH)/crypto/ui/ui_null.c > + $(OPENSSL_PATH)/crypto/ui/ui_openssl.c > + $(OPENSSL_PATH)/crypto/ui/ui_util.c > + $(OPENSSL_PATH)/crypto/uid.c > + $(OPENSSL_PATH)/crypto/x509/by_dir.c > + $(OPENSSL_PATH)/crypto/x509/by_file.c > + $(OPENSSL_PATH)/crypto/x509/t_crl.c > + $(OPENSSL_PATH)/crypto/x509/t_req.c > + $(OPENSSL_PATH)/crypto/x509/t_x509.c > + $(OPENSSL_PATH)/crypto/x509/x509_att.c > + $(OPENSSL_PATH)/crypto/x509/x509_cmp.c > + $(OPENSSL_PATH)/crypto/x509/x509_d2.c > + $(OPENSSL_PATH)/crypto/x509/x509_def.c > + $(OPENSSL_PATH)/crypto/x509/x509_err.c > + $(OPENSSL_PATH)/crypto/x509/x509_ext.c > + $(OPENSSL_PATH)/crypto/x509/x509_lu.c > + $(OPENSSL_PATH)/crypto/x509/x509_meth.c > + $(OPENSSL_PATH)/crypto/x509/x509_obj.c > + $(OPENSSL_PATH)/crypto/x509/x509_r2x.c > + $(OPENSSL_PATH)/crypto/x509/x509_req.c > + $(OPENSSL_PATH)/crypto/x509/x509_set.c > + $(OPENSSL_PATH)/crypto/x509/x509_trs.c > + $(OPENSSL_PATH)/crypto/x509/x509_txt.c > + $(OPENSSL_PATH)/crypto/x509/x509_v3.c > + $(OPENSSL_PATH)/crypto/x509/x509_vfy.c > + $(OPENSSL_PATH)/crypto/x509/x509_vpm.c > + $(OPENSSL_PATH)/crypto/x509/x509cset.c > + $(OPENSSL_PATH)/crypto/x509/x509name.c > + $(OPENSSL_PATH)/crypto/x509/x509rset.c > + $(OPENSSL_PATH)/crypto/x509/x509spki.c > + $(OPENSSL_PATH)/crypto/x509/x509type.c > + $(OPENSSL_PATH)/crypto/x509/x_all.c > + $(OPENSSL_PATH)/crypto/x509/x_attrib.c > + $(OPENSSL_PATH)/crypto/x509/x_crl.c > + $(OPENSSL_PATH)/crypto/x509/x_exten.c > + $(OPENSSL_PATH)/crypto/x509/x_name.c > + $(OPENSSL_PATH)/crypto/x509/x_pubkey.c > + $(OPENSSL_PATH)/crypto/x509/x_req.c > + $(OPENSSL_PATH)/crypto/x509/x_x509.c > + $(OPENSSL_PATH)/crypto/x509/x_x509a.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_cache.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_data.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_lib.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_map.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_node.c > + $(OPENSSL_PATH)/crypto/x509v3/pcy_tree.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_addr.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_admis.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_akey.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_akeya.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_alt.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_asid.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_bcons.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_bitst.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_conf.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_cpols.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_crld.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_enum.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_extku.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_genn.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_ia5.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_info.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_int.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_lib.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_ncons.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pci.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pcia.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pcons.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pku.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_pmaps.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_prn.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_purp.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_skey.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_sxnet.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_tlsf.c > + $(OPENSSL_PATH)/crypto/x509v3/v3_utl.c > + $(OPENSSL_PATH)/crypto/x509v3/v3err.c > + $(OPENSSL_PATH)/crypto/arm_arch.h > + $(OPENSSL_PATH)/crypto/mips_arch.h > + $(OPENSSL_PATH)/crypto/ppc_arch.h > + $(OPENSSL_PATH)/crypto/s390x_arch.h > + $(OPENSSL_PATH)/crypto/sparc_arch.h > + $(OPENSSL_PATH)/crypto/vms_rms.h > + $(OPENSSL_PATH)/crypto/aes/aes_local.h > + $(OPENSSL_PATH)/crypto/asn1/asn1_item_list.h > + $(OPENSSL_PATH)/crypto/asn1/asn1_local.h > + $(OPENSSL_PATH)/crypto/asn1/charmap.h > + $(OPENSSL_PATH)/crypto/asn1/standard_methods.h > + $(OPENSSL_PATH)/crypto/asn1/tbl_standard.h > + $(OPENSSL_PATH)/crypto/async/async_local.h > + $(OPENSSL_PATH)/crypto/async/arch/async_null.h > + $(OPENSSL_PATH)/crypto/async/arch/async_posix.h > + $(OPENSSL_PATH)/crypto/async/arch/async_win.h > + $(OPENSSL_PATH)/crypto/bio/bio_local.h > + $(OPENSSL_PATH)/crypto/bn/bn_local.h > + $(OPENSSL_PATH)/crypto/bn/bn_prime.h > + $(OPENSSL_PATH)/crypto/bn/rsaz_exp.h > + $(OPENSSL_PATH)/crypto/comp/comp_local.h > + $(OPENSSL_PATH)/crypto/conf/conf_def.h > + $(OPENSSL_PATH)/crypto/conf/conf_local.h > + $(OPENSSL_PATH)/crypto/dh/dh_local.h > + $(OPENSSL_PATH)/crypto/dso/dso_local.h > + $(OPENSSL_PATH)/crypto/evp/evp_local.h > + $(OPENSSL_PATH)/crypto/hmac/hmac_local.h > + $(OPENSSL_PATH)/crypto/lhash/lhash_local.h > + $(OPENSSL_PATH)/crypto/md5/md5_local.h > + $(OPENSSL_PATH)/crypto/modes/modes_local.h > + $(OPENSSL_PATH)/crypto/objects/obj_dat.h > + $(OPENSSL_PATH)/crypto/objects/obj_local.h > + $(OPENSSL_PATH)/crypto/objects/obj_xref.h > + $(OPENSSL_PATH)/crypto/ocsp/ocsp_local.h > + $(OPENSSL_PATH)/crypto/pkcs12/p12_local.h > + $(OPENSSL_PATH)/crypto/rand/rand_local.h > + $(OPENSSL_PATH)/crypto/rsa/rsa_local.h > + $(OPENSSL_PATH)/crypto/sha/sha_local.h > + $(OPENSSL_PATH)/crypto/siphash/siphash_local.h > + $(OPENSSL_PATH)/crypto/sm3/sm3_local.h > + $(OPENSSL_PATH)/crypto/store/store_local.h > + $(OPENSSL_PATH)/crypto/ui/ui_local.h > + $(OPENSSL_PATH)/crypto/x509/x509_local.h > + $(OPENSSL_PATH)/crypto/x509v3/ext_dat.h > + $(OPENSSL_PATH)/crypto/x509v3/pcy_local.h > + $(OPENSSL_PATH)/crypto/x509v3/standard_exts.h > + $(OPENSSL_PATH)/crypto/x509v3/v3_admis.h > + $(OPENSSL_PATH)/ssl/bio_ssl.c > + $(OPENSSL_PATH)/ssl/d1_lib.c > + $(OPENSSL_PATH)/ssl/d1_msg.c > + $(OPENSSL_PATH)/ssl/d1_srtp.c > + $(OPENSSL_PATH)/ssl/methods.c > + $(OPENSSL_PATH)/ssl/packet.c > + $(OPENSSL_PATH)/ssl/pqueue.c > + $(OPENSSL_PATH)/ssl/record/dtls1_bitmap.c > + $(OPENSSL_PATH)/ssl/record/rec_layer_d1.c > + $(OPENSSL_PATH)/ssl/record/rec_layer_s3.c > + $(OPENSSL_PATH)/ssl/record/ssl3_buffer.c > + $(OPENSSL_PATH)/ssl/record/ssl3_record.c > + $(OPENSSL_PATH)/ssl/record/ssl3_record_tls13.c > + $(OPENSSL_PATH)/ssl/s3_cbc.c > + $(OPENSSL_PATH)/ssl/s3_enc.c > + $(OPENSSL_PATH)/ssl/s3_lib.c > + $(OPENSSL_PATH)/ssl/s3_msg.c > + $(OPENSSL_PATH)/ssl/ssl_asn1.c > + $(OPENSSL_PATH)/ssl/ssl_cert.c > + $(OPENSSL_PATH)/ssl/ssl_ciph.c > + $(OPENSSL_PATH)/ssl/ssl_conf.c > + $(OPENSSL_PATH)/ssl/ssl_err.c > + $(OPENSSL_PATH)/ssl/ssl_init.c > + $(OPENSSL_PATH)/ssl/ssl_lib.c > + $(OPENSSL_PATH)/ssl/ssl_mcnf.c > + $(OPENSSL_PATH)/ssl/ssl_rsa.c > + $(OPENSSL_PATH)/ssl/ssl_sess.c > + $(OPENSSL_PATH)/ssl/ssl_stat.c > + $(OPENSSL_PATH)/ssl/ssl_txt.c > + $(OPENSSL_PATH)/ssl/ssl_utst.c > + $(OPENSSL_PATH)/ssl/statem/extensions.c > + $(OPENSSL_PATH)/ssl/statem/extensions_clnt.c > + $(OPENSSL_PATH)/ssl/statem/extensions_cust.c > + $(OPENSSL_PATH)/ssl/statem/extensions_srvr.c > + $(OPENSSL_PATH)/ssl/statem/statem.c > + $(OPENSSL_PATH)/ssl/statem/statem_clnt.c > + $(OPENSSL_PATH)/ssl/statem/statem_dtls.c > + $(OPENSSL_PATH)/ssl/statem/statem_lib.c > + $(OPENSSL_PATH)/ssl/statem/statem_srvr.c > + $(OPENSSL_PATH)/ssl/t1_enc.c > + $(OPENSSL_PATH)/ssl/t1_lib.c > + $(OPENSSL_PATH)/ssl/t1_trce.c > + $(OPENSSL_PATH)/ssl/tls13_enc.c > + $(OPENSSL_PATH)/ssl/tls_srp.c > + $(OPENSSL_PATH)/ssl/packet_local.h > + $(OPENSSL_PATH)/ssl/ssl_cert_table.h > + $(OPENSSL_PATH)/ssl/ssl_local.h > + $(OPENSSL_PATH)/ssl/record/record.h > + $(OPENSSL_PATH)/ssl/record/record_local.h > + $(OPENSSL_PATH)/ssl/statem/statem.h > + $(OPENSSL_PATH)/ssl/statem/statem_local.h > +# Autogenerated files list ends here > + buildinf.h > + ossl_store.c > + rand_pool.c > + X64/ApiHooks.c > + > +[Packages] > + MdePkg/MdePkg.dec > + CryptoPkg/CryptoPkg.dec > + > +[LibraryClasses] > + BaseLib > + DebugLib > + RngLib > + PrintLib > + > +[BuildOptions] > + # > + # Disables the following Visual Studio compiler warnings brought by op= enssl > source, > + # so we do not break the build with /WX option: > + # C4090: 'function' : different 'const' qualifiers > + # C4132: 'object' : const object should be initialized (tls13_enc.c) > + # C4210: nonstandard extension used: function given file scope > + # C4244: conversion from type1 to type2, possible loss of data > + # C4245: conversion from type1 to type2, signed/unsigned mismatch > + # C4267: conversion from size_t to type, possible loss of data > + # C4306: 'identifier' : conversion from 'type1' to 'type2' of greate= r size > + # C4310: cast truncates constant value > + # C4389: 'operator' : signed/unsigned mismatch (xxxx) > + # C4700: uninitialized local variable 'name' used. (conf_sap.c(71)) > + # C4702: unreachable code > + # C4706: assignment within conditional expression > + # C4819: The file contains a character that cannot be represented in= the > current code page > + # > + MSFT:*_*_X64_CC_FLAGS =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 t= he build > with -Werror > + # -Werror=3Dmaybe-uninitialized: there exist some other paths for wh= ich the > variable is not initialized. > + # -Werror=3Dformat: Check calls to printf and scanf, etc., to make s= ure that the > arguments supplied have > + # types appropriate to the format string specified. > + # -Werror=3Dunused-but-set-variable: Warn whenever a local variable = is > assigned to, but otherwise unused (aside from its declaration). > + # > + GCC:*_*_X64_CC_FLAGS =3D -UWIN32 -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 bui= ld with > warnings-as-errors: > + # 1295: Deprecated declaration - give arg types > + # 550: was set but never used > + # 1293: assignment in condition > + # 111: statement is unreachable (invariably "break;" after "return X;= " in case > statement) > + # 68: integer conversion resulted in a change of sign ("if (Status = =3D=3D -1)") > + # 177: 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 integ= er as an > enum without a cast) > + # 1296: Extended constant initialiser used > + # 128: loop is not reachable - may be emitted inappropriately if code= follows > a conditional return > + # from the function that evaluates to true at compile time > + # 546: transfer of control bypasses initialization - may be emitted > inappropriately if the uninitialized > + # variable is never referenced after the jump > + # 1: ignore "#1-D: last line of file ends without a newline" > + # 3017: 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=3Duninitialized > diff --git a/CryptoPkg/Library/OpensslLib/UefiAsm.conf > b/CryptoPkg/Library/OpensslLib/UefiAsm.conf > new file mode 100644 > index 0000000000..2c2978d696 > --- /dev/null > +++ b/CryptoPkg/Library/OpensslLib/UefiAsm.conf > @@ -0,0 +1,30 @@ > +## -*- mode: perl; -*- > +# UEFI assembly openssl configuration targets. > +# > +# Copyright (c) 2020, Intel Corporation. All rights reserved.
> +# > +# SPDX-License-Identifier: BSD-2-Clause-Patent > +# > +## > + > +my %targets =3D ( > +#### UEFI > + "UEFI-x86_64" =3D> { > + perlasm_scheme =3D> "nasm", > + # inherit_from =3D> [ "UEFI", asm("x86_64_asm") ], > + inherit_from =3D> [ "UEFI" ], > + cpuid_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_6= 4.s > sha1-mb-x86_64.s sha256-mb-x86_64.s", > + modes_asm_src =3D> "ghash-x86_64.s aesni-gcm-x86_64.s", > + }, > + "UEFI-x86_64-GCC" =3D> { > + perlasm_scheme =3D> "elf", > + # inherit_from =3D> [ "UEFI", asm("x86_64_asm") ], > + inherit_from =3D> [ "UEFI" ], > + cpuid_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_6= 4.s > sha1-mb-x86_64.s sha256-mb-x86_64.s", > + modes_asm_src =3D> "ghash-x86_64.s aesni-gcm-x86_64.s", > + }, > +); > diff --git a/CryptoPkg/Library/OpensslLib/X64/ApiHooks.c > b/CryptoPkg/Library/OpensslLib/X64/ApiHooks.c > new file mode 100644 > index 0000000000..0c8043aa8e > --- /dev/null > +++ b/CryptoPkg/Library/OpensslLib/X64/ApiHooks.c > @@ -0,0 +1,22 @@ > +/** @file > + OpenSSL Library API hooks. > + > +Copyright (c) 2020, Intel Corporation. All rights reserved.
> +SPDX-License-Identifier: BSD-2-Clause-Patent > + > +**/ > + > +#include > + > +/** > + Stub function for win64 API call. > + > +**/ > +VOID * > +__imp_RtlVirtualUnwind ( > + VOID * Args > + ) > +{ > + return NULL; > +} > + > diff --git a/CryptoPkg/Library/OpensslLib/process_files.pl > b/CryptoPkg/Library/OpensslLib/process_files.pl > index 57ce195394..42bff05fa6 100755 > --- a/CryptoPkg/Library/OpensslLib/process_files.pl > +++ b/CryptoPkg/Library/OpensslLib/process_files.pl > @@ -9,9 +9,65 @@ > # do not need to do this, since the results are stored in the EDK2 > # git repository for them. > # > +# Due to the script wrapping required to process the OpenSSL > +# configuration data, each native architecture must be processed > +# individually by the maintainer (in addition to the standard version): > +# ./process_files.pl > +# ./process_files.pl X64 > +# ./process_files.pl [Arch] > + > use strict; > use Cwd; > use File::Copy; > +use File::Basename; > +use File::Path qw(make_path remove_tree); > +use Text::Tabs; > + > +my $comment_character; > + > +# > +# OpenSSL perlasm generator script does not transfer the copyright heade= r > +# > +sub copy_license_header > +{ > + my @args =3D split / /, shift; #Separate args by spaces > + my $source =3D $args[1]; #Source file is second (after "per= l") > + 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_file, "<" . $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 "$comment_character WARNING: do not edit!\r\n"); > + print ($temp_file "$comment_character Generated from $source\r\n"); > + print ($temp_file "$comment_character\r\n"); > + > + #Copy source file header to temp file > + while (my $line =3D <$source_file>) { > + next if ($line =3D~ /#!/); #Ignore shebang line > + $line =3D~ s/#/$comment_character/; #Fix comment char= acter for > assembly > + $line =3D~ s/\s+$/\r\n/; #Trim trailing whitepsace, fixup l= ine endings > + print ($temp_file $line); > + last if ($line =3D~ /http/); #Last line of copyright header con= tains a web link > + } > + print ($temp_file "\r\n"); > + #Retrieve generated assembly contents > + while (my $line =3D <$target_file>) { > + $line =3D~ s/\s+$/\r\n/; #Trim trailing whitepsace, fixup l= ine 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 . "\"!"; > +} >=20 > # > # Find the openssl directory name for use lib. We have to do this > @@ -21,10 +77,57 @@ use File::Copy; > # > my $inf_file; > my $OPENSSL_PATH; > +my $uefi_config; > +my $extension; > +my $arch; > my @inf; >=20 > BEGIN { > $inf_file =3D "OpensslLib.inf"; > + $uefi_config =3D "UEFI"; > + $arch =3D shift; > + > + if (defined $arch) { > + if (uc ($arch) eq "X64") { > + $arch =3D "X64"; > + $inf_file =3D "OpensslLibX64.inf"; > + $uefi_config =3D "UEFI-x86_64"; > + $extension =3D "nasm"; > + $comment_character =3D ";"; > + } elsif (uc ($arch) eq "X64GCC") { > + $arch =3D "X64Gcc"; > + $inf_file =3D "OpensslLibX64Gcc.inf"; > + $uefi_config =3D "UEFI-x86_64-GCC"; > + $extension =3D "S"; > + $comment_character =3D "#"; > + } else { > + die "Unsupported architecture \"" . $arch . "\"!"; > + } > + if ($extension eq "nasm") { > + if (`nasm -v 2>&1`) { > + #Presence of nasm executable will trigger inclusion of A= VX instructions > + die "\nCannot run assembly generators with NASM in path!= \n\n"; > + } > + } > + > + # Prepare assembly folder > + if (-d $arch) { > + opendir my $dir, $arch || > + die "Cannot open assembly folder \"" . $arch . "\"!"; > + while (defined (my $file =3D readdir $dir)) { > + if (-d "$arch/$file") { > + next if $file eq "."; > + next if $file eq ".."; > + remove_tree ("$arch/$file", {safe =3D> 1}) || > + die "Cannot clean assembly folder \"" . "$arch/$f= ile" . "\"!"; > + } > + } > + > + } else { > + mkdir $arch || > + die "Cannot create assembly folder \"" . $arch . "\"!"; > + } > + } >=20 > # Read the contents of the inf file > open( FD, "<" . $inf_file ) || > @@ -47,9 +150,9 @@ BEGIN { > # Configure UEFI > system( > "./Configure", > - "UEFI", > + "--config=3D../UefiAsm.conf", > + "$uefi_config", > "no-afalgeng", > - "no-asm", > "no-async", > "no-autoerrinit", > "no-autoload-config", > @@ -129,23 +232,53 @@ BEGIN { > # Retrieve file lists from OpenSSL configdata > # > use configdata qw/%unified_info/; > +use configdata qw/%config/; > +use configdata qw/%target/; > + > +# > +# Collect build flags from configdata > +# > +my $flags =3D ""; > +foreach my $f (@{$config{lib_defines}}) { > + $flags .=3D " -D$f"; > +} >=20 > my @cryptofilelist =3D (); > my @sslfilelist =3D (); > +my @asmfilelist =3D (); > +my @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 UEFI. > # So it can reduce porting time, compile time, library size. > + next 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"; >=20 > + if ($unified_info{generate}->{$s}) { > + if (defined $arch) { > + my $buildstring =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/$path"); > + push @asmbuild, "$buildstring\n"; > + push @asmfilelist, " $arch/$path$s.$extension\r\n"; > + } > + next; > + } > if ($product =3D~ "libssl") { > push @sslfilelist, ' $(OPENSSL_PATH)/' . $s . "\r\n"; > next; > @@ -183,15 +316,31 @@ foreach (@headers){ > } >=20 >=20 > +# > +# 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; > + } > if ( $_ =3D~ "# Autogenerated files list starts here" ) { > - push @new_inf, $_, @cryptofilelist, @sslfilelist; > + push @new_inf, $_, @asmfilelist, @cryptofilelist, @sslfilelist; > $subbing =3D 1; > next; > } > @@ -216,49 +365,51 @@ rename( $new_inf_file, $inf_file ) || > die "rename $inf_file"; > print "Done!"; >=20 > -# > -# Update OpensslLibCrypto.inf with auto-generated file list (no libssl) > -# > -$inf_file =3D "OpensslLibCrypto.inf"; > - > -# Read the contents 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 . "\"!"; > +if (!defined $arch) { > + # > + # Update OpensslLibCrypto.inf with auto-generated file list (no libs= sl) > + # > + $inf_file =3D "OpensslLibCrypto.inf"; >=20 > -$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; > + # Read the contents 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); > } >=20 > - 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_file ) || > + die "rename $inf_file"; > + print "Done!"; > } >=20 > -$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 > # > -- > 2.32.0.windows.1