From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mga05.intel.com (mga05.intel.com [192.55.52.43]) by mx.groups.io with SMTP id smtpd.web10.3721.1600993697289222385 for ; Thu, 24 Sep 2020 17:28:17 -0700 Authentication-Results: mx.groups.io; dkim=pass header.i=@intel.onmicrosoft.com header.s=selector2-intel-onmicrosoft-com header.b=KUkQSt93; spf=pass (domain: intel.com, ip: 192.55.52.43, mailfrom: christopher.j.zurcher@intel.com) IronPort-SDR: V3pqLk4KeLwmMofrofGNw8WPIuzF1Um5/0jUVf/D1LG2RovvXy6rbHxFxOb8svS0aMLxlP+P0Q AbrCLJ65FJuQ== X-IronPort-AV: E=McAfee;i="6000,8403,9754"; a="246177256" X-IronPort-AV: E=Sophos;i="5.77,299,1596524400"; d="scan'208";a="246177256" X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by fmsmga105.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 24 Sep 2020 17:28:16 -0700 IronPort-SDR: 3LUM/V9hbnMXvzM/HoFmLDRyVlHh330H9PlZ27DQwzDeBXsPT7oAKGhvWEDj9AeIFcDu1OSzDS 3iPn2k1tBOGg== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.77,299,1596524400"; d="scan'208";a="310600345" Received: from orsmsx603.amr.corp.intel.com ([10.22.229.16]) by orsmga006.jf.intel.com with ESMTP; 24 Sep 2020 17:28:15 -0700 Received: from orsmsx610.amr.corp.intel.com (10.22.229.23) by ORSMSX603.amr.corp.intel.com (10.22.229.16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5; Thu, 24 Sep 2020 17:28:15 -0700 Received: from orsmsx601.amr.corp.intel.com (10.22.229.14) by ORSMSX610.amr.corp.intel.com (10.22.229.23) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5; Thu, 24 Sep 2020 17:28:14 -0700 Received: from ORSEDG601.ED.cps.intel.com (10.7.248.6) by orsmsx601.amr.corp.intel.com (10.22.229.14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.1713.5 via Frontend Transport; Thu, 24 Sep 2020 17:28:14 -0700 Received: from NAM11-DM6-obe.outbound.protection.outlook.com (104.47.57.175) by edgegateway.intel.com (134.134.137.102) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.1713.5; Thu, 24 Sep 2020 17:28:08 -0700 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=N1eBwws+1XaUNQMCctb6+1StvgkfsBq/k7SUBhWtuCNwj+caXwTZ178SSvWVZ6KRiTxthG1iU0hrKz9lD5snBJeund1tVVmIa523eC6Y254iQCEulRgI7CqOn7BOkU2cSlUjl1gT8T6EtO9COeA0++AODUDlvp+iFTWlOEQCL0MlKv6lmfwpApnjcK6w3Dkotb0vjY4O9xpSsGKM2khvBUnbUvllKaK7lJKw46mGEz8AghcuUxE+muaTohZKAHZ+XENcJDsC2+9huJlzTzKSUujFHraRKrcg4y4Bo72r5cc+Isx7x8O/T0o+k6abBnmVH6+e6Z/pU50X9pk+NGIJ/Q== 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=YRTKKse/Tx5VbScgZ2DxZg2oxT3xsYSoS6H1jV6lQOQ=; b=BY56Uh2fP7Fe7WsFBDH/pBnXOIUUXH0HwmFsw3hpCnASZD4LGwGLbr4pC+pCKduNiMOmVwRh7dtr7azkpu4qLh22LFaM2WqQTUcR9s2cn8FqFAfM2RbHjH2F70pcWfSRfSLLG/5L7tUpiDuCdab0dLSYpMhksd2eyr+MEfTpYvO2s/ri8guRXxeHMbqtjET75z+IouLmvgwQA+MIQNM6OMvCEU4W40LHZ+VBTqcnTg59XOXp5O/cvRu3SD6oyroIdU/Rs2affH8kxIJ39U1DtVSCpMrAz2ctA3TiYlHu0R9+5I3zWKiaEFw/cGxiM0D4don2LXVGwJvXyaQj3iwmBg== 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=YRTKKse/Tx5VbScgZ2DxZg2oxT3xsYSoS6H1jV6lQOQ=; b=KUkQSt93UIS0qA5vsDQi76n7oJN15NawvSRqRmnshipB30fA09O0Bejt0a2+sm9dmo6/RiN/gU9iXOmurjBEirmbAdkaQBJtO6JgADPD5P0ASmR8zHoCvhsj9a6VANxA4OaUEu3CZ1wuxZTgrRvDKKsl8zMiX3thbDB8sYepuko= Received: from MWHPR1101MB2125.namprd11.prod.outlook.com (2603:10b6:301:4d::10) by MWHPR11MB1709.namprd11.prod.outlook.com (2603:10b6:300:25::22) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3412.22; Fri, 25 Sep 2020 00:28:04 +0000 Received: from MWHPR1101MB2125.namprd11.prod.outlook.com ([fe80::6cbb:9c13:41f0:ce20]) by MWHPR1101MB2125.namprd11.prod.outlook.com ([fe80::6cbb:9c13:41f0:ce20%3]) with mapi id 15.20.3412.020; Fri, 25 Sep 2020 00:28:04 +0000 From: "Zurcher, Christopher J" To: "Yao, Jiewen" , "Jiang, Guomin" , "devel@edk2.groups.io" CC: "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: AQHWafWk4Fp7/vSvg0yxS46YX8nrdKk2MGcggAhJsvCACWVbYIAAKRzAgCM344CACdON8IAAvBfQgAL9IlA= Date: Fri, 25 Sep 2020 00:28:03 +0000 Message-ID: References: <20200804002429.3897-1-christopher.j.zurcher@intel.com> <20200804002429.3897-2-christopher.j.zurcher@intel.com> <162C7E6ED8CEF542.12673@groups.io> In-Reply-To: Accept-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: dlp-version: 11.5.1.3 dlp-reaction: no-action dlp-product: dlpe-windows authentication-results: intel.com; dkim=none (message not signed) header.d=none;intel.com; dmarc=none action=none header.from=intel.com; x-originating-ip: [50.53.185.44] x-ms-publictraffictype: Email x-ms-office365-filtering-correlation-id: 4be343d8-23d8-428d-df45-08d860e9de32 x-ms-traffictypediagnostic: MWHPR11MB1709: x-ms-exchange-transport-forked: True x-microsoft-antispam-prvs: x-ms-oob-tlc-oobclassifiers: OLM:5797; x-ms-exchange-senderadcheck: 1 x-microsoft-antispam: BCL:0; x-microsoft-antispam-message-info: 1RuugmjtXaXW4dsNM/X/b7xxNrmDAT1cdcrPioQEmoUxszKwGbfg/GXsOi496dFFZCek2+ViDTHccZWkE3Xh4xhdADmMjMqfM3qzm9B19fkt6fc8ALNsFjS70M6qYY/4IE5aNEkH2jeiuHbgJRuTAlKLhLU7SvFtEBrb6XnCTj5P7qsY+iVhkVc53s0ZHr634xpuzMRr5i5SOMn6uHwlWrDrR3xH02Ymh32K+cqlJYAreyb7x+q8DAN78UOFg0x8FhSUHN+teQCR35JCTI2SgUFH4dQo31zLZmkHMAkWkG/oVOG4a6ymMy6XzHs9DS67aObEN0cZvKwr3bbboM1z+KZ4qTjMJoA9aP4DyBykh9+Gn53T25fd4Pc10ongCTMnu2EewVDCByPXjGcratrnvfJxOyt6TMa85sHHhG7BkfiPFHv9qGzZwL2eIg3Ip9WbXTHqO2DQcCDOKGSpViL0oA== x-forefront-antispam-report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:MWHPR1101MB2125.namprd11.prod.outlook.com;PTR:;CAT:NONE;SFS:(4636009)(366004)(39860400002)(376002)(136003)(396003)(346002)(66946007)(66476007)(66556008)(66446008)(316002)(33656002)(8936002)(55016002)(54906003)(186003)(26005)(53546011)(2906002)(9686003)(4326008)(478600001)(7696005)(110136005)(6506007)(5660300002)(966005)(71200400001)(52536014)(76116006)(86362001)(8676002)(83380400001)(64756008)(19627235002)(30864003)(559001)(579004)(545624004);DIR:OUT;SFP:1102; x-ms-exchange-antispam-messagedata: 5TKxcFrF4gB06pqcyRUucYtJx6k6eENn3kKtN9SK5+M6tRDPqjAKNDpybwZubfPPdCERn0aJPxKhmafoe/9iKxNJ1AoU0Gis3aaIHIW2NLO8QGhTu9rY4tdWZDEJTXc+f3P1etufBeIWwwV8ZLzfnYJkWdhHLeAih1tCti6p7H07VX2USHZ9hEgO2y+TKSanzuz4amUOlfbBqq2mKA3oS5JLA22JkMYeQSZ8+Pw5MiGeFnQKcT2LSY+ow45Tb1mMXjO2XZwz6LNTYPzsPuCljS4sarWJBFJO9BNnLHhupmsg4EPX7Fn2yoIhfznrAl+2m/clr/8rZM3x4DD2pm8WDD5UpYxZD/2B4foXdM9zD705WIRiENp3MTk23IJInDuBWm6s4rtbZ99iVE7ybM48xm8uvOdUZrjhjNi5REUKqtwKt//aEMUsyhrDE0D/G/ccayBW85STZIGR8hiY9uZqZN9Fk0I2dBe7mqHAB2o+i87zpkFDLs9I/uhdJcqL7WjEJ0MrYRTqBhA5xNdsPg97kmNGWKW0K6Cq1GbqQOsKaM2m0YuT1IjImFMzq32iJxhDA9ZrZoj8iv6LVcgH+TXDmCSEDlqR1G0/dfT0vlcDYfEEuTEc5E5u9rMvfbowLtHks5VimEpQQ8cUXqmMxWrHuA== MIME-Version: 1.0 X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: MWHPR1101MB2125.namprd11.prod.outlook.com X-MS-Exchange-CrossTenant-Network-Message-Id: 4be343d8-23d8-428d-df45-08d860e9de32 X-MS-Exchange-CrossTenant-originalarrivaltime: 25 Sep 2020 00:28:04.0369 (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: AmIMXBshnFNMOmasGhapMggTg0eOwtZvyuC8QaNimI1GBylLuua3kUNov3cGsTOWxXi/dYuVsXQCxYo82WJe/5i6tq2jEQpNHP9OnGg9rws= X-MS-Exchange-Transport-CrossTenantHeadersStamped: MWHPR11MB1709 Return-Path: christopher.j.zurcher@intel.com X-OriginatorOrg: intel.com Content-Language: en-US Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable I was able to successfully build and run the non-optimized code with LLVM, = but the optimized version returns this error during build: C:\Program Files\LLVM\lib\clang\9.0.0\include\stdatomic.h:91:17: error: un= known type name 'wchar_t' typedef _Atomic(wchar_t) atomic_wchar_t; Is there a known build issue with CLANGPDB and the stdatomic.h file? Thanks, Christopher Zurcher > -----Original Message----- > From: Yao, Jiewen > Sent: Tuesday, September 22, 2020 19:35 > To: Zurcher, Christopher J ; Jiang, Guo= min > ; devel@edk2.groups.io > Cc: Wang, Jian J ; Lu, XiaoyuX ; > Ard Biesheuvel > Subject: RE: [edk2-devel] [PATCH v2 1/2] CryptoPkg/OpensslLib: Add nativ= e > instruction support for X64 >=20 > For GCC, please refer to > https://github.com/tianocore/tianocore.github.io/wiki/Using-EDK-II-with- > Native-GCC >=20 > For LLVM, please refer to > https://github.com/tianocore/tianocore.github.io/wiki/CLANG9-Tools-Chain >=20 > Thank you > Yao Jiewen >=20 > > -----Original Message----- > > From: Zurcher, Christopher J > > Sent: Tuesday, September 22, 2020 11:22 PM > > To: Jiang, Guomin ; devel@edk2.groups.io; Yao, > > Jiewen > > Cc: Wang, Jian J ; Lu, XiaoyuX > ; > > Ard Biesheuvel > > Subject: RE: [edk2-devel] [PATCH v2 1/2] CryptoPkg/OpensslLib: Add nat= ive > > instruction support for X64 > > > > I have unit tested SHA1, SHA512, and AES as well. > > I do not have the build environment available to test GCC and LLVM. > > > > -- > > Christopher Zurcher > > > > > -----Original Message----- > > > From: Jiang, Guomin > > > Sent: Wednesday, September 16, 2020 02:17 > > > To: devel@edk2.groups.io; Yao, Jiewen ; Zurche= r, > > > Christopher J > > > Cc: Wang, Jian J ; Lu, XiaoyuX > > ; > > > Ard Biesheuvel > > > Subject: RE: [edk2-devel] [PATCH v2 1/2] CryptoPkg/OpensslLib: Add n= ative > > > instruction support for X64 > > > > > > Hi Zurcher, > > > > > > > [Jiewen] Since you also add other sha (sha1, sha512) and aesni, I = think > > > those > > > > need unit test for them too. > > > > > > Can you update the status about it? > > > > > > > [Jiewen] I think we need support build with GCC and LLVM, and with= X64. > > > > > > It is better to support the GCC and LLVM. > > > > > > Thanks > > > Guomin > > > > > > > -----Original Message----- > > > > From: devel@edk2.groups.io On Behalf Of Yao= , > > > > Jiewen > > > > Sent: Tuesday, August 25, 2020 7:36 AM > > > > To: Zurcher, Christopher J ; > > > > devel@edk2.groups.io > > > > Cc: Wang, Jian J ; Lu, XiaoyuX > > > > ; Ard Biesheuvel > > > > Subject: Re: [edk2-devel] [PATCH v2 1/2] CryptoPkg/OpensslLib: Add > native > > > > instruction support for X64 > > > > > > > > Below: > > > > > > > > > -----Original Message----- > > > > > From: Zurcher, Christopher J > > > > > Sent: Tuesday, August 25, 2020 5:26 AM > > > > > To: devel@edk2.groups.io; Zurcher, Christopher J > > > > > ; Yao, Jiewen > > > > > Cc: Wang, Jian J ; Lu, XiaoyuX > > > > ; > > > > > Ard Biesheuvel > > > > > Subject: RE: [edk2-devel] [PATCH v2 1/2] CryptoPkg/OpensslLib: A= dd > native > > > > > instruction support for X64 > > > > > > > > > > 1) I have confirmed that the ApiHooks.c file is still required e= ven > > > without > > > > the AVX > > > > > instructions included. The x86_64 assembly files in OpenSSL set = a > flag > > > called > > > > > $win64 and automatically include calls to the RtlVirtualUnwind > function > > > if > > > > NASM > > > > > is selected as the assembler scheme. > > > > > > > > > > https://docs.microsoft.com/en-us/windows/win32/api/winnt/nf-winn= t- > > > > > rtlvirtualunwind > > > > > > > > > > I have submitted an issue against OpenSSL since I don't think us= ing > the > > > > NASM > > > > > assembler should force the inclusion of Windows-specific API hoo= ks, > but > > > > that > > > > > change cannot be made in OpenSSL 1.1.1 and we will have to wait = for > > > > OpenSSL 3 > > > > > or later to remove the stub function. > > > > > > > > > > https://github.com/openssl/openssl/issues/12712 > > > > > > > > > > > > > [Jiewen] Thanks. > > > > > > > > > 2) So far I have only built with VS. > > > > > > > > > > > > > [Jiewen] I think we need support build with GCC and LLVM, and with= X64. > > > > > > > > > > > > > 3) The X64 SHA256 implementation was successfully exercised acro= ss a > > > > large > > > > > number of devices in a production environment as a verification = step > in a > > > > multi- > > > > > GB data transfer scenario. > > > > > > > > > > > > > [Jiewen] Since you also add other sha (sha1, sha512) and aesni, I = think > > > those > > > > need unit test for them too. > > > > > > > > > > > > > Thanks, > > > > > Christopher Zurcher > > > > > > > > > > > -----Original Message----- > > > > > > From: devel@edk2.groups.io On Behalf Of > > > > Zurcher, > > > > > > Christopher J > > > > > > Sent: Tuesday, August 18, 2020 15:50 > > > > > > To: Yao, Jiewen ; devel@edk2.groups.io > > > > > > Cc: Wang, Jian J ; Lu, XiaoyuX > > > > > ; > > > > > > Ard Biesheuvel > > > > > > Subject: Re: [edk2-devel] [PATCH v2 1/2] CryptoPkg/OpensslLib:= Add > > > > native > > > > > > instruction support for X64 > > > > > > > > > > > > After further review, the ApiHooks.c file may no longer be nee= ded > since > > > > we > > > > > > are no longer including the AVX instructions. I will look over= the > > > > > > dependencies and send a new patch set if I can eliminate the A= PI > hooks > > > > file. > > > > > > > > > > > > Thanks, > > > > > > Christopher Zurcher > > > > > > > > > > > > > -----Original Message----- > > > > > > > From: Yao, Jiewen > > > > > > > Sent: Thursday, August 13, 2020 08:04 > > > > > > > To: Zurcher, Christopher J = ; > > > > > > > devel@edk2.groups.io > > > > > > > Cc: Wang, Jian J ; Lu, XiaoyuX > > > > > > ; > > > > > > > Ard Biesheuvel > > > > > > > Subject: RE: [PATCH v2 1/2] CryptoPkg/OpensslLib: Add native > > > > instruction > > > > > > > support for X64 > > > > > > > > > > > > > > Hi Christopher > > > > > > > Thanks. > > > > > > > > > > > > > > 1) Would you please help me understand more on "ApiHooks.c > contains > > > > a > > > > > stub > > > > > > > function for a Windows API call" ? > > > > > > > Why we need this? > > > > > > > If it is compiler specific in openssl, should we submit patc= h to > > > openssl to > > > > > > > exclude this with OPENSSL_SYS_UEFI? That should be a cleaner > solution > > > > for > > > > > > > UEFI. > > > > > > > > > > > > > > 2) Would you please describe what compiler you have tried? V= S? > GCC? > > > > LLVM? > > > > > > > > > > > > > > 3) Would you please describe what unit test you have done? > > > > > > > > > > > > > > Thank you > > > > > > > Yao Jiewen > > > > > > > > > > > > > > > > > > > > > > -----Original Message----- > > > > > > > > From: 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: [PATCH v2 1/2] CryptoPkg/OpensslLib: Add native > > > instruction > > > > > > > support > > > > > > > > for X64 > > > > > > > > > > > > > > > > BZ: https://bugzilla.tianocore.org/show_bug.cgi?id=3D2507 > > > > > > > > > > > > > > > > Adding OpensslLibX64.inf and modifying process_files.pl to > process > > > > this > > > > > > > > file 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. > > > > > > > > > > > > > > > > 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 | 65= 6 > > > > > > > > ++++++++++++++++++++ > > > > > > > > CryptoPkg/Library/Include/openssl/opensslconf.h | = 3 - > > > > > > > > CryptoPkg/Library/OpensslLib/ApiHooks.c | 1= 8 + > > > > > > > > CryptoPkg/Library/OpensslLib/OpensslLibConstructor.c | 3= 4 + > > > > > > > > CryptoPkg/Library/OpensslLib/process_files.pl | 22= 3 > +++++-- > > > > > > > > CryptoPkg/Library/OpensslLib/uefi-asm.conf | 1= 5 + > > > > > > > > 8 files changed, 903 insertions(+), 50 deletions(-) > > > > > > > > > > > > > > > > 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 AARCH64 > > > > > > > > > > > > > > > > diff --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 AARCH64 > > > > > > > > > > > > > > > > diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibX64.in= f > > > > > > > > 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 righ= ts > > > > > > reserved.
> > > > > > > > > > > > > > > > +# (C) Copyright 2020 Hewlett Packard Enterprise Developm= ent > > > > 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-B= E54- > > > 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 OpensslLibConstructo= r > > > > > > > > > > > > > > > > + > > > > > > > > > > > > > > > > +# > > > > > > > > > > > > > > > > +# VALID_ARCHITECTURES =3D X64 > > > > > > > > > > > > > > > > +# > > > > > > > > > > > > > > > > + > > > > > > > > > > > > > > > > +[Sources] > > > > > > > > > > > > > > > > + 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/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 warning= s > brought > > > by > > > > > > > openssl > > > > > > > > source, > > > > > > > > > > > > > > > > + # so we do not break the build with /WX option: > > > > > > > > > > > > > > > > + # C4090: 'function' : different 'const' qualifiers > > > > > > > > > > > > > > > > + # C4132: 'object' : const object should be initialize= d > > > (tls13_enc.c) > > > > > > > > > > > > > > > > + # C4210: nonstandard extension used: function given f= ile > scope > > > > > > > > > > > > > > > > + # C4244: conversion from type1 to type2, possible los= s of > data > > > > > > > > > > > > > > > > + # C4245: conversion from type1 to type2, signed/unsig= ned > > > > mismatch > > > > > > > > > > > > > > > > + # C4267: conversion from size_t to type, possible los= s of > data > > > > > > > > > > > > > > > > + # C4306: 'identifier' : conversion from 'type1' to 't= ype2' > of > > > > > > greater > > > > > > > size > > > > > > > > > > > > > > > > + # C4310: cast truncates constant value > > > > > > > > > > > > > > > > + # C4389: 'operator' : signed/unsigned mismatch (xxxx) > > > > > > > > > > > > > > > > + # C4700: uninitialized local variable 'name' used. > > > (conf_sap.c(71)) > > > > > > > > > > > > > > > > + # C4702: unreachable code > > > > > > > > > > > > > > > > + # C4706: assignment within conditional expression > > > > > > > > > > > > > > > > + # C4819: The file contains a character that cannot be > > > represented > > > > in > > > > > > > the > > > > > > > > current code page > > > > > > > > > > > > > > > > + # > > > > > > > > > > > > > > > > + MSFT:*_*_X64_CC_FLAGS =3D -U_WIN32 -U_WIN64 -U_MSC_V= ER > > > > > > > > $(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_V= ER - > > > > > U__ICC > > > > > > > > $(OPENSSL_FLAGS) $(OPENSSL_FLAGS_CONFIG) /w > > > > > > > > > > > > > > > > + > > > > > > > > > > > > > > > > + # > > > > > > > > > > > > > > > > + # Suppress the following build warnings in openssl so w= e > don't > > > > break > > > > > > the > > > > > > > build > > > > > > > > with -Werror > > > > > > > > > > > > > > > > + # -Werror=3Dmaybe-uninitialized: there exist some oth= er > 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 str= ing > > > specified. > > > > > > > > > > > > > > > > + # -Werror=3Dunused-but-set-variable: Warn whenever a = local > > > > variable is > > > > > > > > assigned to, but otherwise unused (aside from its declarat= ion). > > > > > > > > > > > > > > > > + # > > > > > > > > > > > > > > > > + 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-var= iable - > > > > > > > > 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 type= s > > > > > > > > > > > > > > > > + # 550: was set but never used > > > > > > > > > > > > > > > > + # 1293: assignment in condition > > > > > > > > > > > > > > > > + # 111: statement is unreachable (invariably "break;" a= fter > > > "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 initia= lize > 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 emitted > inappropriately > > > if > > > > code > > > > > > > follows > > > > > > > > a conditional return > > > > > > > > > > > > > > > > + # from the function that evaluates to true at com= pile > time > > > > > > > > > > > > > > > > + # 546: transfer of control bypasses initialization - m= ay 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: Th= is > 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 -Wn= o- > > > > > > > > error=3Duninitialized > > > > > > > > > > > > > > > > diff --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 > > > > > > > > > > > > > > > > #endif > > > > > > > > > > > > > > > > diff --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 assemb= ly > > > > 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 calls an internal OpenSSL function whic= h > 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 the Open= SSL > > > > > > > > > > > > > > > > +# configuration data, each native architecture must be > processed > > > > > > > > > > > > > > > > +# individually by the maintainer (in addition to the stan= dard > > > 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 args by s= paces > > > > > > > > > > > > > > > > + my $source =3D $args[1]; #Source file is sec= ond > (after > > > > > > "perl") > > > > > > > > > > > > > > > > + my $target =3D pop @args; #Target file is alw= ays > 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 "; WARNING: do not edit!\r\n"); > > > > > > > > > > > > > > > > + print ($temp_file "; Generated from $source\r\n"); > > > > > > > > > > > > > > > > + print ($temp_file ";\r\n"); > > > > > > > > > > > > > > > > + > > > > > > > > > > > > > > > > + #Copy source file header to temp file > > > > > > > > > > > > > > > > + while (my $line =3D <$source_file>) { > > > > > > > > > > > > > > > > + next if ($line =3D~ /#!/); #Ignore shebang lin= e > > > > > > > > > > > > > > > > + $line =3D~ s/#/;/; #Fix comment charac= ter for > > > assembly > > > > > > > > > > > > > > > > + $line =3D~ s/\s+$/\r\n/; #Trim trailing whit= epsace, > > > fixup > > > > > > line > > > > > > > endings > > > > > > > > > > > > > > > > + print ($temp_file $line); > > > > > > > > > > > > > > > > + last if ($line =3D~ /http/); #Last line of copyr= ight > header > > > > > > > contains 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 whit= epsace, > > > fixup > > > > > > line > > > > > > > endings > > > > > > > > > > > > > > > > + print ($temp_file expand ($line)); #expand() rep= laces > > > 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_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"; > > > > > > > > > > > > > > > > + } else { > > > > > > > > > > > > > > > > + die "Unsupported architecture \"" . $arch . "= \"!"; > > > > > > > > > > > > > > > > + } > > > > > > > > > > > > > > > > + if ($extension eq "nasm") { > > > > > > > > > > > > > > > > + if (`nasm -v 2>&1`) { > > > > > > > > > > > > > > > > + #Presence of nasm executable will trigger > > > inclusion of > > > > > > AVX > > > > > > > instructions > > > > > > > > > > > > > > > > + die "\nCannot run assembly generators wit= h > NASM in > > > > > > > path!\n\n"; > > > > > > > > > > > > > > > > + } > > > > > > > > > > > > > > > > + } > > > > > > > > > > > > > > > > + > > > > > > > > > > > > > > > > + # Prepare 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( > > > > > > > > > > > > > > > > "./Configure", > > > > > > > > > > > > > > > > - "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 (); > > > > > > > > > > > > > > > > +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"; > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > + 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_SCHEM= E") { > > > > > > > > > > > > > > > > + $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 +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; > > > > > > > > > > > > > > > > + } > > > > > > > > > > > > > > > > if ( $_ =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 li= st > (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 fil= e > list > > > (no > > > > > > > libssl) > > > > > > > > > > > > > > > > + # > > > > > > > > > > > > > > > > + $inf_file =3D "OpensslLibCrypto.inf"; > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > > -$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 h= ere" ) > { > > > > > > > > > > > > > > > > + push @new_inf, $_, @cryptofilelist; > > > > > > > > > > > > > > > > + $subbing =3D 1; > > > > > > > > > > > > > > > > + next; > > > > > > > > > > > > > > > > + } > > > > > > > > > > > > > > > > + if ( $_ =3D~ "# Autogenerated files list ends her= e" ) { > > > > > > > > > > > > > > > > + 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_file ) || > > > > > > > > > > > > > > > > + 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 OpenSS= L > > > > > 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" ], > > > > > > > > > > > > > > > > + 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_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