From nobody Sat Feb 7 05:57:07 2026 Delivered-To: importer@patchew.org Received-SPF: pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) client-ip=66.175.222.108; envelope-from=bounce+27952+103808+1787277+3901457@groups.io; helo=mail02.groups.io; Authentication-Results: mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) smtp.mailfrom=bounce+27952+103808+1787277+3901457@groups.io ARC-Seal: i=1; a=rsa-sha256; t=1682957357; cv=none; d=zohomail.com; s=zohoarc; b=CjwKZGdLRHilmFu0zNIoeWYltJ4J1SWxaSlLBxjPi1N6ZGeTKpSn2tWamWwkUWo8jKdePOZicocmNsUwOY1EcOZ7X42FZZtlWSmSHt4S6vIRY+UQNN7M1+6Txr4M+Ihgg2cGq6sSmHKc75esD8BD7oqJ4DshIGItMaBF/HkdP1w= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1682957357; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Subscribe:List-Id:List-Help:List-Unsubscribe:MIME-Version:Message-ID:Reply-To:References:Sender:Subject:To; bh=E5M3eeta4PeN+MWkFYXNdf2IFq1QbaYbB+CFSum0E/k=; b=IUubyRziOueRioub1gF6RT8FYLzBpWrW18apr5wbTFBGJ8BIubqaH3ebQ2sLRZLu/X8niHuyiprQ0uv7DuZdED7o1N96Pcgjus/lqng2QoiTRwIMjNYcla8Wxae/GZvA3LHls4ofUcfdX22v7MPW15rWRzHQDsk4yvjXZvgI41E= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass; spf=pass (zohomail.com: domain of groups.io designates 66.175.222.108 as permitted sender) smtp.mailfrom=bounce+27952+103808+1787277+3901457@groups.io Received: from mail02.groups.io (mail02.groups.io [66.175.222.108]) by mx.zohomail.com with SMTPS id 1682957357089983.5831120531186; Mon, 1 May 2023 09:09:17 -0700 (PDT) Return-Path: X-Received: by 127.0.0.2 with SMTP id Uv7kYY1788612xAyeQz1LmVv; Mon, 01 May 2023 09:09:16 -0700 X-Received: from out1-smtp.messagingengine.com (out1-smtp.messagingengine.com [66.111.4.25]) by mx.groups.io with SMTP id smtpd.web11.98346.1682957355984198267 for ; Mon, 01 May 2023 09:09:16 -0700 X-Received: from compute5.internal (compute5.nyi.internal [10.202.2.45]) by mailout.nyi.internal (Postfix) with ESMTP id 507675C0163; Mon, 1 May 2023 12:09:15 -0400 (EDT) X-Received: from mailfrontend1 ([10.202.2.162]) by compute5.internal (MEProxy); Mon, 01 May 2023 12:09:15 -0400 X-ME-Sender: X-ME-Received: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedvhedrfedvgedgleekucetufdoteggodetrfdotf fvucfrrhhofhhilhgvmecuhfgrshhtofgrihhlpdfqfgfvpdfurfetoffkrfgpnffqhgen uceurghilhhouhhtmecufedttdenucesvcftvggtihhpihgvnhhtshculddquddttddmne cujfgurhephffvvefufffkofgjfhgggfestdekredtredttdenucfhrhhomheptfgvsggv tggtrgcuvehrrghnuceorhgvsggvtggtrgessghsughiohdrtghomheqnecuggftrfgrth htvghrnhepjedvveefleffteeltdelheejgefftddvueetgfdvheeugfdvhfdvvefguddu ueejnecuffhomhgrihhnpegushgtrdhinhgtpdgvughkihhirdhhohhsthenucevlhhush htvghrufhiiigvpedtnecurfgrrhgrmhepmhgrihhlfhhrohhmpehrvggsvggttggrsegs shguihhordgtohhm X-ME-Proxy: Feedback-ID: i5b994698:Fastmail X-Received: by mail.messagingengine.com (Postfix) with ESMTPA; Mon, 1 May 2023 12:09:13 -0400 (EDT) From: "Rebecca Cran" To: devel@edk2.groups.io, Liming Gao , Bob Feng , Yuwei Chen , Michael D Kinney , Michael Kubacki , Sean Brogan , Chasel Chiu , Nate DeSimone , Star Zeng , Andrew Fish , Ray Ni , Leif Lindholm , Zhiguang Liu , Jian J Wang , Xiaoyu Lu , Guomin Jiang , Gua Guo , Ard Biesheuvel , Pedro Falcato , Gerd Hoffmann , mhaeuser@posteo.de Cc: Rebecca Cran Subject: [edk2-devel] [PATCH v6 08/16] Add GCC and GCCNOLTO toolchains to tools_def.txt and update packages Date: Mon, 1 May 2023 10:08:31 -0600 Message-Id: <20230501160839.884391-9-rebecca@bsdio.com> In-Reply-To: <20230501160839.884391-1-rebecca@bsdio.com> References: <20230501160839.884391-1-rebecca@bsdio.com> MIME-Version: 1.0 Precedence: Bulk List-Unsubscribe: List-Subscribe: List-Help: Sender: devel@edk2.groups.io List-Id: Mailing-List: list devel@edk2.groups.io; contact devel+owner@edk2.groups.io Reply-To: devel@edk2.groups.io,rebecca@bsdio.com X-Gm-Message-State: LHq0VWAAcoZQX7AUn0LQ46X5x1787277AA= Content-Transfer-Encoding: quoted-printable DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=groups.io; q=dns/txt; s=20140610; t=1682957356; bh=MJJQRjQC74G6ngnY3fnPwVfya07PJsrhlL6DN1V/SqE=; h=Cc:Date:From:Reply-To:Subject:To; b=J7V+JfUjNXAj/8MZO+XBLmGLRWwPD9erTOhYeUO4GD5f93uFGPFTH9BqQBA+CjzostS hQBkctkc/QOC2I3jx7gqqkisyiUa5VMILYH26tRPjbpGiwt90nQWhqGxbCf5yv90r5Wqg OGyqPCi+hSoPZxCHaIa4kncofZeBMT1zeog= X-ZohoMail-DKIM: pass (identity @groups.io) X-ZM-MESSAGEID: 1682957358927100001 Content-Type: text/plain; charset="utf-8" Add a 'GCC' toolchain that's a copy of the existing GCC5 definition. Add a 'GCCNOLTO' toolchain that's a copy of the existing GCC49 toolchain. Update build flags in CryptoPkg, EmulatorPkg, IntelFsp2Pkg and UnitTestFrameworkPkg to add flags for the new toolchains. Signed-off-by: Rebecca Cran Reviewed-by tag for the CryptoPkg changes please? Reviewed-by tag for the IntelFsp2Pkg changes please? --- UnitTestFrameworkPkg/UnitTestFrameworkPkgHost.dsc.inc | 4 + IntelFsp2Pkg/Tools/Tests/QemuFspPkg.dsc | 8 +- CryptoPkg/Library/OpensslLib/OpensslLib.inf | 1 + CryptoPkg/Library/OpensslLib/OpensslLibAccel.inf | 1 + CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf | 1 + CryptoPkg/Library/OpensslLib/OpensslLibFull.inf | 1 + CryptoPkg/Library/OpensslLib/OpensslLibFullAccel.inf | 2 + EmulatorPkg/Unix/Host/Host.inf | 2 + BaseTools/Conf/tools_def.template | 366 ++++++++++++++= ++++++ 9 files changed, 385 insertions(+), 1 deletion(-) diff --git a/UnitTestFrameworkPkg/UnitTestFrameworkPkgHost.dsc.inc b/UnitTe= stFrameworkPkg/UnitTestFrameworkPkgHost.dsc.inc index 7866c36e6693..9bdbbf3a222c 100644 --- a/UnitTestFrameworkPkg/UnitTestFrameworkPkgHost.dsc.inc +++ b/UnitTestFrameworkPkg/UnitTestFrameworkPkgHost.dsc.inc @@ -31,6 +31,10 @@ [BuildOptions] !endif GCC:*_GCC5_*_CC_FLAGS =3D --coverage GCC:*_GCC5_*_DLINK_FLAGS =3D --coverage + GCC:*_GCCNOLTO_*_CC_FLAGS =3D --coverage + GCC:*_GCCNOLTO_*_DLINK_FLAGS =3D --coverage + GCC:*_GCC_*_CC_FLAGS =3D --coverage + GCC:*_GCC_*_DLINK_FLAGS =3D --coverage [BuildOptions.common.EDKII.HOST_APPLICATION] # # MSFT diff --git a/IntelFsp2Pkg/Tools/Tests/QemuFspPkg.dsc b/IntelFsp2Pkg/Tools/T= ests/QemuFspPkg.dsc index 31558121185d..34409f8b80d5 100644 --- a/IntelFsp2Pkg/Tools/Tests/QemuFspPkg.dsc +++ b/IntelFsp2Pkg/Tools/Tests/QemuFspPkg.dsc @@ -461,10 +461,16 @@ [Components.IA32] ##########################################################################= ######################### [BuildOptions] # Append build options for EDK and EDKII drivers (=3D is Append, =3D=3D is= Replace) - # Enable link-time optimization when building with GCC49 + # Enable link-time optimization when building with GCC49 or GCCNOLTO *_GCC49_IA32_CC_FLAGS =3D -flto *_GCC49_IA32_DLINK_FLAGS =3D -flto + *_GCCNOLTO_IA32_CC_FLAGS =3D -flto + *_GCCNOLTO_IA32_DLINK_FLAGS =3D -flto *_GCC5_IA32_CC_FLAGS =3D -fno-pic *_GCC5_IA32_DLINK_FLAGS =3D -no-pie *_GCC5_IA32_ASLCC_FLAGS =3D -fno-pic *_GCC5_IA32_ASLDLINK_FLAGS =3D -no-pie + *_GCC_IA32_CC_FLAGS =3D -fno-pic + *_GCC_IA32_DLINK_FLAGS =3D -no-pie + *_GCC_IA32_ASLCC_FLAGS =3D -fno-pic + *_GCC_IA32_ASLDLINK_FLAGS =3D -no-pie diff --git a/CryptoPkg/Library/OpensslLib/OpensslLib.inf b/CryptoPkg/Librar= y/OpensslLib/OpensslLib.inf index 86a00b1c4b2a..0669f3035b85 100644 --- a/CryptoPkg/Library/OpensslLib/OpensslLib.inf +++ b/CryptoPkg/Library/OpensslLib/OpensslLib.inf @@ -644,6 +644,7 @@ [BuildOptions] GCC:*_CLANGPDB_*_CC_FLAGS =3D -std=3Dc99 -Wno-error=3Duninitialized -Wno= -error=3Dincompatible-pointer-types -Wno-error=3Dpointer-sign -Wno-error=3D= implicit-function-declaration -Wno-error=3Dignored-pragma-optimize # Revisit after switching to 3.0 branch GCC:*_GCC5_*_CC_FLAGS =3D -Wno-unused-but-set-variable + GCC:*_GCC_*_CC_FLAGS =3D -Wno-unused-but-set-variable =20 # suppress the following warnings in openssl so we don't break the build= with warnings-as-errors: # 1295: Deprecated declaration - give arg types diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibAccel.inf b/CryptoPkg/L= ibrary/OpensslLib/OpensslLibAccel.inf index 2e4f95909b51..45fd4799d748 100644 --- a/CryptoPkg/Library/OpensslLib/OpensslLibAccel.inf +++ b/CryptoPkg/Library/OpensslLib/OpensslLibAccel.inf @@ -692,6 +692,7 @@ [BuildOptions] GCC:*_CLANGPDB_*_CC_FLAGS =3D -std=3Dc99 -Wno-error=3Duninitialized -Wno= -error=3Dincompatible-pointer-types -Wno-error=3Dpointer-sign -Wno-error=3D= implicit-function-declaration -Wno-error=3Dignored-pragma-optimize # Revisit after switching to 3.0 branch GCC:*_GCC5_*_CC_FLAGS =3D -Wno-unused-but-set-variable + GCC:*_GCC_*_CC_FLAGS =3D -Wno-unused-but-set-variable =20 # suppress the following warnings in openssl so we don't break the build= with warnings-as-errors: # 1295: Deprecated declaration - give arg types diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf b/CryptoPkg/= Library/OpensslLib/OpensslLibCrypto.inf index 637d4769e8ca..44292f589b6c 100644 --- a/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf +++ b/CryptoPkg/Library/OpensslLib/OpensslLibCrypto.inf @@ -594,6 +594,7 @@ [BuildOptions] GCC:*_CLANGPDB_*_CC_FLAGS =3D -std=3Dc99 -Wno-error=3Duninitialized -Wno= -error=3Dincompatible-pointer-types -Wno-error=3Dpointer-sign -Wno-error=3D= implicit-function-declaration -Wno-error=3Dignored-pragma-optimize # Revisit after switching to 3.0 branch GCC:*_GCC5_*_CC_FLAGS =3D -Wno-unused-but-set-variable + GCC:*_GCC_*_CC_FLAGS =3D -Wno-unused-but-set-variable =20 # suppress the following warnings in openssl so we don't break the build= with warnings-as-errors: # 1295: Deprecated declaration - give arg types diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibFull.inf b/CryptoPkg/Li= brary/OpensslLib/OpensslLibFull.inf index c5f90221fc66..7c07521dcf1e 100644 --- a/CryptoPkg/Library/OpensslLib/OpensslLibFull.inf +++ b/CryptoPkg/Library/OpensslLib/OpensslLibFull.inf @@ -699,6 +699,7 @@ [BuildOptions] GCC:*_CLANGPDB_*_CC_FLAGS =3D -std=3Dc99 -Wno-error=3Duninitialized -Wno= -error=3Dincompatible-pointer-types -Wno-error=3Dpointer-sign -Wno-error=3D= implicit-function-declaration -Wno-error=3Dignored-pragma-optimize # Revisit after switching to 3.0 branch GCC:*_GCC5_*_CC_FLAGS =3D -Wno-unused-but-set-variable + GCC:*_GCC_*_CC_FLAGS =3D -Wno-unused-but-set-variable =20 # suppress the following warnings in openssl so we don't break the build= with warnings-as-errors: # 1295: Deprecated declaration - give arg types diff --git a/CryptoPkg/Library/OpensslLib/OpensslLibFullAccel.inf b/CryptoP= kg/Library/OpensslLib/OpensslLibFullAccel.inf index 076295244a2a..62846e37a456 100644 --- a/CryptoPkg/Library/OpensslLib/OpensslLibFullAccel.inf +++ b/CryptoPkg/Library/OpensslLib/OpensslLibFullAccel.inf @@ -747,6 +747,8 @@ [BuildOptions] GCC:*_CLANGPDB_*_CC_FLAGS =3D -std=3Dc99 -Wno-error=3Duninitialized -Wno= -error=3Dincompatible-pointer-types -Wno-error=3Dpointer-sign -Wno-error=3D= implicit-function-declaration -Wno-error=3Dignored-pragma-optimize # Revisit after switching to 3.0 branch GCC:*_GCC5_*_CC_FLAGS =3D -Wno-unused-but-set-variable + GCC:*_GCC_*_CC_FLAGS =3D -Wno-unused-but-set-variable + =20 # suppress the following warnings in openssl so we don't break the build= with warnings-as-errors: # 1295: Deprecated declaration - give arg types diff --git a/EmulatorPkg/Unix/Host/Host.inf b/EmulatorPkg/Unix/Host/Host.inf index f5ebbed68344..90e8c36b6186 100644 --- a/EmulatorPkg/Unix/Host/Host.inf +++ b/EmulatorPkg/Unix/Host/Host.inf @@ -123,7 +123,9 @@ [BuildOptions] GCC:*_*_X64_CC_FLAGS =3D=3D -m64 -g -fshort-wchar -fno-strict-aliasing = -Wall -malign-double -idirafter/usr/include -c -include $(DEST_DIR_DEBUG)/A= utoGen.h -DSTRING_ARRAY_NAME=3D$(BASE_NAME)Strings GCC:*_GCC48_X64_CC_FLAGS =3D "-DEFIAPI=3D__attribute__((ms_abi))" GCC:*_GCC49_X64_CC_FLAGS =3D "-DEFIAPI=3D__attribute__((ms_abi))" + GCC:*_GCCNOLTO_X64_CC_FLAGS =3D "-DEFIAPI=3D__attribute__((ms_abi))" GCC:*_GCC5_X64_CC_FLAGS =3D "-DEFIAPI=3D__attribute__((ms_abi))" -flto = -DUSING_LTO -Os + GCC:*_GCC_X64_CC_FLAGS =3D "-DEFIAPI=3D__attribute__((ms_abi))" -flto -= DUSING_LTO -Os GCC:*_*_X64_PP_FLAGS =3D=3D -m64 -E -x assembler-with-cpp -include $(DE= ST_DIR_DEBUG)/AutoGen.h GCC:*_*_X64_ASM_FLAGS =3D=3D -m64 -c -x assembler -imacros $(DEST_DIR_D= EBUG)/AutoGen.h =20 diff --git a/BaseTools/Conf/tools_def.template b/BaseTools/Conf/tools_def.t= emplate index d0fa158552df..f85120244267 100755 --- a/BaseTools/Conf/tools_def.template +++ b/BaseTools/Conf/tools_def.template @@ -77,8 +77,13 @@ DEFINE GCC48_X64_PREFIX =3D ENV(GCC48_BIN) DEFINE GCC49_IA32_PREFIX =3D ENV(GCC49_BIN) DEFINE GCC49_X64_PREFIX =3D ENV(GCC49_BIN) =20 +DEFINE GCCNOLTO_IA32_PREFIX =3D ENV(GCCNOLTO_BIN) +DEFINE GCCNOLTO_X64_PREFIX =3D ENV(GCCNOLTO_BIN) + DEFINE GCC5_IA32_PREFIX =3D ENV(GCC5_BIN) DEFINE GCC5_X64_PREFIX =3D ENV(GCC5_BIN) +DEFINE GCC_IA32_PREFIX =3D ENV(GCC_BIN) +DEFINE GCC_X64_PREFIX =3D ENV(GCC_BIN) DEFINE GCC_HOST_PREFIX =3D ENV(GCC_HOST_BIN) =20 DEFINE UNIX_IASL_BIN =3D ENV(IASL_PREFIX)iasl @@ -1139,6 +1144,150 @@ RELEASE_GCC49_AARCH64_DLINK_XIPFLAGS =3D -z common-= page-size=3D0x20 NOOPT_GCC49_AARCH64_DLINK_FLAGS =3D DEF(GCC49_AARCH64_DLINK_FLAGS) -O0 NOOPT_GCC49_AARCH64_DLINK_XIPFLAGS =3D -z common-page-size=3D0x20 -O0 =20 +##########################################################################= ########## +# +# GCC NOLTO - This configuration is used to compile under Linux to produce +# PE/COFF binaries using GCC without Link Time Optimization +# +##########################################################################= ########## +*_GCCNOLTO_*_*_FAMILY =3D GCC + +*_GCCNOLTO_*_MAKE_PATH =3D DEF(GCC_HOST_PREFIX)make +*_GCCNOLTO_*_*_DLL =3D ENV(GCCNOLTO_DLL) +*_GCCNOLTO_*_ASL_PATH =3D DEF(UNIX_IASL_BIN) + +*_GCCNOLTO_*_PP_FLAGS =3D DEF(GCC_PP_FLAGS) +*_GCCNOLTO_*_ASLPP_FLAGS =3D DEF(GCC_ASLPP_FLAGS) +*_GCCNOLTO_*_ASLCC_FLAGS =3D DEF(GCC_ASLCC_FLAGS) +*_GCCNOLTO_*_VFRPP_FLAGS =3D DEF(GCC_VFRPP_FLAGS) +*_GCCNOLTO_*_APP_FLAGS =3D +*_GCCNOLTO_*_ASL_FLAGS =3D DEF(IASL_FLAGS) +*_GCCNOLTO_*_ASL_OUTFLAGS =3D DEF(IASL_OUTFLAGS) +*_GCCNOLTO_*_DEPS_FLAGS =3D DEF(GCC_DEPS_FLAGS) + +################## +# GCCNOLTO IA32 definitions +################## +*_GCCNOLTO_IA32_OBJCOPY_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)objcopy +*_GCCNOLTO_IA32_CC_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)gcc +*_GCCNOLTO_IA32_SLINK_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)ar +*_GCCNOLTO_IA32_DLINK_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)gcc +*_GCCNOLTO_IA32_ASLDLINK_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)gcc +*_GCCNOLTO_IA32_ASM_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)gcc +*_GCCNOLTO_IA32_PP_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)gcc +*_GCCNOLTO_IA32_VFRPP_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)gcc +*_GCCNOLTO_IA32_ASLCC_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)gcc +*_GCCNOLTO_IA32_ASLPP_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)gcc +*_GCCNOLTO_IA32_RC_PATH =3D DEF(GCCNOLTO_IA32_PREFIX)objcopy + +*_GCCNOLTO_IA32_ASLCC_FLAGS =3D DEF(GCC49_ASLCC_FLAGS) -m32 +*_GCCNOLTO_IA32_ASLDLINK_FLAGS =3D DEF(GCC49_IA32_X64_ASLDLINK_FLAGS= ) -Wl,-m,elf_i386 +*_GCCNOLTO_IA32_ASM_FLAGS =3D DEF(GCC49_ASM_FLAGS) -m32 -march= =3Di386 +*_GCCNOLTO_IA32_DLINK_FLAGS =3D DEF(GCC49_IA32_X64_DLINK_FLAGS) -= Wl,-m,elf_i386,--oformat=3Delf32-i386 +*_GCCNOLTO_IA32_DLINK2_FLAGS =3D DEF(GCC49_IA32_DLINK2_FLAGS) +*_GCCNOLTO_IA32_RC_FLAGS =3D DEF(GCC_IA32_RC_FLAGS) +*_GCCNOLTO_IA32_OBJCOPY_FLAGS =3D +*_GCCNOLTO_IA32_NASM_FLAGS =3D -f elf32 + + DEBUG_GCCNOLTO_IA32_CC_FLAGS =3D DEF(GCC49_IA32_CC_FLAGS) +RELEASE_GCCNOLTO_IA32_CC_FLAGS =3D DEF(GCC49_IA32_CC_FLAGS) -Wno-unu= sed-but-set-variable -Wno-unused-const-variable + NOOPT_GCCNOLTO_IA32_CC_FLAGS =3D DEF(GCC49_IA32_CC_FLAGS) -O0 + +################## +# GCCNOLTO X64 definitions +################## +*_GCCNOLTO_X64_OBJCOPY_PATH =3D DEF(GCCNOLTO_X64_PREFIX)objcopy +*_GCCNOLTO_X64_CC_PATH =3D DEF(GCCNOLTO_X64_PREFIX)gcc +*_GCCNOLTO_X64_SLINK_PATH =3D DEF(GCCNOLTO_X64_PREFIX)ar +*_GCCNOLTO_X64_DLINK_PATH =3D DEF(GCCNOLTO_X64_PREFIX)gcc +*_GCCNOLTO_X64_ASLDLINK_PATH =3D DEF(GCCNOLTO_X64_PREFIX)gcc +*_GCCNOLTO_X64_ASM_PATH =3D DEF(GCCNOLTO_X64_PREFIX)gcc +*_GCCNOLTO_X64_PP_PATH =3D DEF(GCCNOLTO_X64_PREFIX)gcc +*_GCCNOLTO_X64_VFRPP_PATH =3D DEF(GCCNOLTO_X64_PREFIX)gcc +*_GCCNOLTO_X64_ASLCC_PATH =3D DEF(GCCNOLTO_X64_PREFIX)gcc +*_GCCNOLTO_X64_ASLPP_PATH =3D DEF(GCCNOLTO_X64_PREFIX)gcc +*_GCCNOLTO_X64_RC_PATH =3D DEF(GCCNOLTO_X64_PREFIX)objcopy + +*_GCCNOLTO_X64_ASLCC_FLAGS =3D DEF(GCC49_ASLCC_FLAGS) -m64 +*_GCCNOLTO_X64_ASLDLINK_FLAGS =3D DEF(GCC49_IA32_X64_ASLDLINK_FLAGS)= -Wl,-m,elf_x86_64 +*_GCCNOLTO_X64_ASM_FLAGS =3D DEF(GCC49_ASM_FLAGS) -m64 +*_GCCNOLTO_X64_DLINK_FLAGS =3D DEF(GCC49_X64_DLINK_FLAGS) +*_GCCNOLTO_X64_DLINK2_FLAGS =3D DEF(GCC49_X64_DLINK2_FLAGS) +*_GCCNOLTO_X64_RC_FLAGS =3D DEF(GCC_X64_RC_FLAGS) +*_GCCNOLTO_X64_OBJCOPY_FLAGS =3D +*_GCCNOLTO_X64_NASM_FLAGS =3D -f elf64 + + DEBUG_GCCNOLTO_X64_CC_FLAGS =3D DEF(GCC49_X64_CC_FLAGS) +RELEASE_GCCNOLTO_X64_CC_FLAGS =3D DEF(GCC49_X64_CC_FLAGS) -Wno-unuse= d-but-set-variable -Wno-unused-const-variable + NOOPT_GCCNOLTO_X64_CC_FLAGS =3D DEF(GCC49_X64_CC_FLAGS) -O0 + +################## +# GCCNOLTO ARM definitions +################## +*_GCCNOLTO_ARM_CC_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)gcc +*_GCCNOLTO_ARM_SLINK_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)ar +*_GCCNOLTO_ARM_DLINK_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)gcc +*_GCCNOLTO_ARM_ASLDLINK_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)gcc +*_GCCNOLTO_ARM_ASM_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)gcc +*_GCCNOLTO_ARM_PP_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)gcc +*_GCCNOLTO_ARM_VFRPP_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)gcc +*_GCCNOLTO_ARM_ASLCC_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)gcc +*_GCCNOLTO_ARM_ASLPP_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)gcc +*_GCCNOLTO_ARM_RC_PATH =3D ENV(GCCNOLTO_ARM_PREFIX)objcopy + +*_GCCNOLTO_ARM_ASLCC_FLAGS =3D DEF(GCC49_ASLCC_FLAGS) +*_GCCNOLTO_ARM_ASLDLINK_FLAGS =3D DEF(GCC49_ARM_ASLDLINK_FLAGS) +*_GCCNOLTO_ARM_ASM_FLAGS =3D DEF(GCC49_ARM_ASM_FLAGS) +*_GCCNOLTO_ARM_DLINK_FLAGS =3D DEF(GCC49_ARM_DLINK_FLAGS) +*_GCCNOLTO_ARM_DLINK2_FLAGS =3D DEF(GCC49_ARM_DLINK2_FLAGS) +*_GCCNOLTO_ARM_DTCPP_FLAGS =3D DEF(GCC_DTCPP_FLAGS) +*_GCCNOLTO_ARM_PLATFORM_FLAGS =3D -march=3Darmv7-a +*_GCCNOLTO_ARM_PP_FLAGS =3D $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS) +*_GCCNOLTO_ARM_RC_FLAGS =3D DEF(GCC_ARM_RC_FLAGS) +*_GCCNOLTO_ARM_VFRPP_FLAGS =3D $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FL= AGS) +*_GCCNOLTO_ARM_CC_XIPFLAGS =3D DEF(GCC49_ARM_CC_XIPFLAGS) + + DEBUG_GCCNOLTO_ARM_CC_FLAGS =3D DEF(GCC49_ARM_CC_FLAGS) -O0 +RELEASE_GCCNOLTO_ARM_CC_FLAGS =3D DEF(GCC49_ARM_CC_FLAGS) -Wno-unuse= d-but-set-variable -Wno-unused-const-variable + NOOPT_GCCNOLTO_ARM_CC_FLAGS =3D DEF(GCC49_ARM_CC_FLAGS) -O0 + +################## +# GCCNOLTO AARCH64 definitions +################## +*_GCCNOLTO_AARCH64_CC_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)gcc +*_GCCNOLTO_AARCH64_SLINK_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)ar +*_GCCNOLTO_AARCH64_DLINK_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)gcc +*_GCCNOLTO_AARCH64_ASLDLINK_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)gcc +*_GCCNOLTO_AARCH64_ASM_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)gcc +*_GCCNOLTO_AARCH64_PP_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)gcc +*_GCCNOLTO_AARCH64_VFRPP_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)gcc +*_GCCNOLTO_AARCH64_ASLCC_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)gcc +*_GCCNOLTO_AARCH64_ASLPP_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)gcc +*_GCCNOLTO_AARCH64_RC_PATH =3D ENV(GCCNOLTO_AARCH64_PREFIX)objcopy + +*_GCCNOLTO_AARCH64_ASLCC_FLAGS =3D DEF(GCC49_ASLCC_FLAGS) +*_GCCNOLTO_AARCH64_ASLDLINK_FLAGS =3D DEF(GCC49_AARCH64_ASLDLINK_FLAGS) +*_GCCNOLTO_AARCH64_ASM_FLAGS =3D DEF(GCC49_AARCH64_ASM_FLAGS) +*_GCCNOLTO_AARCH64_DLINK2_FLAGS =3D DEF(GCC49_AARCH64_DLINK2_FLAGS) +*_GCCNOLTO_AARCH64_DTCPP_FLAGS =3D DEF(GCC_DTCPP_FLAGS) +*_GCCNOLTO_AARCH64_PLATFORM_FLAGS =3D +*_GCCNOLTO_AARCH64_PP_FLAGS =3D $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS) +*_GCCNOLTO_AARCH64_RC_FLAGS =3D DEF(GCC_AARCH64_RC_FLAGS) +*_GCCNOLTO_AARCH64_VFRPP_FLAGS =3D $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FL= AGS) +*_GCCNOLTO_AARCH64_CC_XIPFLAGS =3D DEF(GCC49_AARCH64_CC_XIPFLAGS) + + DEBUG_GCCNOLTO_AARCH64_CC_FLAGS =3D DEF(GCC49_AARCH64_CC_FLAGS) -O0 + DEBUG_GCCNOLTO_AARCH64_DLINK_FLAGS =3D DEF(GCC49_AARCH64_DLINK_FLAGS) + DEBUG_GCCNOLTO_AARCH64_DLINK_XIPFLAGS =3D -z common-page-size=3D0x20 + +RELEASE_GCCNOLTO_AARCH64_CC_FLAGS =3D DEF(GCC49_AARCH64_CC_FLAGS) -Wno= -unused-but-set-variable -Wno-unused-const-variable +RELEASE_GCCNOLTO_AARCH64_DLINK_FLAGS =3D DEF(GCC49_AARCH64_DLINK_FLAGS) +RELEASE_GCCNOLTO_AARCH64_DLINK_XIPFLAGS =3D -z common-page-size=3D0x20 + + NOOPT_GCCNOLTO_AARCH64_CC_FLAGS =3D DEF(GCC49_AARCH64_CC_FLAGS) -O0 + NOOPT_GCCNOLTO_AARCH64_DLINK_FLAGS =3D DEF(GCC49_AARCH64_DLINK_FLAGS) -= O0 + NOOPT_GCCNOLTO_AARCH64_DLINK_XIPFLAGS =3D -z common-page-size=3D0x20 -O0 + ##########################################################################= ########## # # GCC 5 - This configuration is used to compile under Linux to produce @@ -1356,6 +1505,223 @@ RELEASE_GCC5_AARCH64_DLINK_XIPFLAGS =3D -z common-p= age-size=3D0x20 DEBUG_GCC5_LOONGARCH64_CC_FLAGS =3D DEF(GCC5_LOONGARCH64_CC_FLAGS) RELEASE_GCC5_LOONGARCH64_CC_FLAGS =3D DEF(GCC5_LOONGARCH64_CC_FLAGS)= -Wno-unused-but-set-variable -Wno-unused-variable =20 +##########################################################################= ########## +# +# GCC - This configuration is used to compile under Linux to produce +# PE/COFF binaries using GCC 5 or newer +# +##########################################################################= ########## +*_GCC_*_*_FAMILY =3D GCC + +*_GCC_*_MAKE_PATH =3D DEF(GCC_HOST_PREFIX)make +*_GCC_*_*_DLL =3D ENV(GCC_DLL) +*_GCC_*_ASL_PATH =3D DEF(UNIX_IASL_BIN) + +*_GCC_*_PP_FLAGS =3D DEF(GCC_PP_FLAGS) +*_GCC_*_ASLPP_FLAGS =3D DEF(GCC_ASLPP_FLAGS) +*_GCC_*_ASLCC_FLAGS =3D DEF(GCC_ASLCC_FLAGS) +*_GCC_*_VFRPP_FLAGS =3D DEF(GCC_VFRPP_FLAGS) +*_GCC_*_APP_FLAGS =3D +*_GCC_*_ASL_FLAGS =3D DEF(IASL_FLAGS) +*_GCC_*_ASL_OUTFLAGS =3D DEF(IASL_OUTFLAGS) +*_GCC_*_DEPS_FLAGS =3D DEF(GCC_DEPS_FLAGS) + +################## +# GCC IA32 definitions +################## +*_GCC_IA32_OBJCOPY_PATH =3D DEF(GCC_IA32_PREFIX)objcopy +*_GCC_IA32_CC_PATH =3D DEF(GCC_IA32_PREFIX)gcc +*_GCC_IA32_SLINK_PATH =3D DEF(GCC_IA32_PREFIX)gcc-ar +*_GCC_IA32_DLINK_PATH =3D DEF(GCC_IA32_PREFIX)gcc +*_GCC_IA32_ASLDLINK_PATH =3D DEF(GCC_IA32_PREFIX)gcc +*_GCC_IA32_ASM_PATH =3D DEF(GCC_IA32_PREFIX)gcc +*_GCC_IA32_PP_PATH =3D DEF(GCC_IA32_PREFIX)gcc +*_GCC_IA32_VFRPP_PATH =3D DEF(GCC_IA32_PREFIX)gcc +*_GCC_IA32_ASLCC_PATH =3D DEF(GCC_IA32_PREFIX)gcc +*_GCC_IA32_ASLPP_PATH =3D DEF(GCC_IA32_PREFIX)gcc +*_GCC_IA32_RC_PATH =3D DEF(GCC_IA32_PREFIX)objcopy + +*_GCC_IA32_ASLCC_FLAGS =3D DEF(GCC5_ASLCC_FLAGS) -m32 +*_GCC_IA32_ASLDLINK_FLAGS =3D DEF(GCC5_IA32_X64_ASLDLINK_FLAGS) -Wl,= -m,elf_i386 -no-pie +*_GCC_IA32_ASM_FLAGS =3D DEF(GCC5_ASM_FLAGS) -m32 -march=3Di386 +*_GCC_IA32_DLINK2_FLAGS =3D DEF(GCC5_IA32_DLINK2_FLAGS) -no-pie +*_GCC_IA32_RC_FLAGS =3D DEF(GCC_IA32_RC_FLAGS) +*_GCC_IA32_OBJCOPY_FLAGS =3D +*_GCC_IA32_NASM_FLAGS =3D -f elf32 + + DEBUG_GCC_IA32_CC_FLAGS =3D DEF(GCC5_IA32_CC_FLAGS) -flto + DEBUG_GCC_IA32_DLINK_FLAGS =3D DEF(GCC5_IA32_X64_DLINK_FLAGS) -flto -= Os -Wl,-m,elf_i386,--oformat=3Delf32-i386 + +RELEASE_GCC_IA32_CC_FLAGS =3D DEF(GCC5_IA32_CC_FLAGS) -flto -Wno-unu= sed-but-set-variable -Wno-unused-const-variable +RELEASE_GCC_IA32_DLINK_FLAGS =3D DEF(GCC5_IA32_X64_DLINK_FLAGS) -flto -= Os -Wl,-m,elf_i386,--oformat=3Delf32-i386 + + NOOPT_GCC_IA32_CC_FLAGS =3D DEF(GCC5_IA32_CC_FLAGS) -O0 + NOOPT_GCC_IA32_DLINK_FLAGS =3D DEF(GCC5_IA32_X64_DLINK_FLAGS) -Wl,-m,= elf_i386,--oformat=3Delf32-i386 -O0 + +################## +# GCC X64 definitions +################## +*_GCC_X64_OBJCOPY_PATH =3D DEF(GCC_X64_PREFIX)objcopy +*_GCC_X64_CC_PATH =3D DEF(GCC_X64_PREFIX)gcc +*_GCC_X64_SLINK_PATH =3D DEF(GCC_X64_PREFIX)gcc-ar +*_GCC_X64_DLINK_PATH =3D DEF(GCC_X64_PREFIX)gcc +*_GCC_X64_ASLDLINK_PATH =3D DEF(GCC_X64_PREFIX)gcc +*_GCC_X64_ASM_PATH =3D DEF(GCC_X64_PREFIX)gcc +*_GCC_X64_PP_PATH =3D DEF(GCC_X64_PREFIX)gcc +*_GCC_X64_VFRPP_PATH =3D DEF(GCC_X64_PREFIX)gcc +*_GCC_X64_ASLCC_PATH =3D DEF(GCC_X64_PREFIX)gcc +*_GCC_X64_ASLPP_PATH =3D DEF(GCC_X64_PREFIX)gcc +*_GCC_X64_RC_PATH =3D DEF(GCC_X64_PREFIX)objcopy + +*_GCC_X64_ASLCC_FLAGS =3D DEF(GCC5_ASLCC_FLAGS) -m64 +*_GCC_X64_ASLDLINK_FLAGS =3D DEF(GCC5_IA32_X64_ASLDLINK_FLAGS) -Wl,= -m,elf_x86_64 +*_GCC_X64_ASM_FLAGS =3D DEF(GCC5_ASM_FLAGS) -m64 +*_GCC_X64_DLINK2_FLAGS =3D DEF(GCC5_X64_DLINK2_FLAGS) +*_GCC_X64_RC_FLAGS =3D DEF(GCC_X64_RC_FLAGS) +*_GCC_X64_OBJCOPY_FLAGS =3D +*_GCC_X64_NASM_FLAGS =3D -f elf64 + + DEBUG_GCC_X64_CC_FLAGS =3D DEF(GCC5_X64_CC_FLAGS) -flto -DUSING_L= TO + DEBUG_GCC_X64_DLINK_FLAGS =3D DEF(GCC5_X64_DLINK_FLAGS) -flto -Os + +RELEASE_GCC_X64_CC_FLAGS =3D DEF(GCC5_X64_CC_FLAGS) -flto -DUSING_L= TO -Wno-unused-but-set-variable -Wno-unused-const-variable +RELEASE_GCC_X64_DLINK_FLAGS =3D DEF(GCC5_X64_DLINK_FLAGS) -flto -Os + + NOOPT_GCC_X64_CC_FLAGS =3D DEF(GCC5_X64_CC_FLAGS) -O0 + NOOPT_GCC_X64_DLINK_FLAGS =3D DEF(GCC5_X64_DLINK_FLAGS) -O0 + +################## +# GCC ARM definitions +################## +*_GCC_ARM_CC_PATH =3D ENV(GCC_ARM_PREFIX)gcc +*_GCC_ARM_SLINK_PATH =3D ENV(GCC_ARM_PREFIX)gcc-ar +*_GCC_ARM_DLINK_PATH =3D ENV(GCC_ARM_PREFIX)gcc +*_GCC_ARM_ASLDLINK_PATH =3D ENV(GCC_ARM_PREFIX)gcc +*_GCC_ARM_ASM_PATH =3D ENV(GCC_ARM_PREFIX)gcc +*_GCC_ARM_PP_PATH =3D ENV(GCC_ARM_PREFIX)gcc +*_GCC_ARM_VFRPP_PATH =3D ENV(GCC_ARM_PREFIX)gcc +*_GCC_ARM_ASLCC_PATH =3D ENV(GCC_ARM_PREFIX)gcc +*_GCC_ARM_ASLPP_PATH =3D ENV(GCC_ARM_PREFIX)gcc +*_GCC_ARM_RC_PATH =3D ENV(GCC_ARM_PREFIX)objcopy + +*_GCC_ARM_ASLCC_FLAGS =3D DEF(GCC5_ASLCC_FLAGS) +*_GCC_ARM_ASLDLINK_FLAGS =3D DEF(GCC5_ARM_ASLDLINK_FLAGS) +*_GCC_ARM_ASM_FLAGS =3D DEF(GCC5_ARM_ASM_FLAGS) +*_GCC_ARM_DLINK2_FLAGS =3D DEF(GCC5_ARM_DLINK2_FLAGS) +*_GCC_ARM_DTCPP_FLAGS =3D DEF(GCC_DTCPP_FLAGS) +*_GCC_ARM_PLATFORM_FLAGS =3D -march=3Darmv7-a -mfloat-abi=3Dsoft +*_GCC_ARM_PP_FLAGS =3D $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS) +*_GCC_ARM_RC_FLAGS =3D DEF(GCC_ARM_RC_FLAGS) +*_GCC_ARM_VFRPP_FLAGS =3D $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS) +*_GCC_ARM_CC_XIPFLAGS =3D DEF(GCC5_ARM_CC_XIPFLAGS) + + DEBUG_GCC_ARM_CC_FLAGS =3D DEF(GCC5_ARM_CC_FLAGS) -flto -Wno-unus= ed-but-set-variable -Wno-unused-const-variable + DEBUG_GCC_ARM_DLINK_FLAGS =3D DEF(GCC5_ARM_DLINK_FLAGS) -flto -Os -L= $(WORKSPACE)/ArmPkg/Library/GccLto -llto-arm -Wl,-plugin-opt=3D-pass-throug= h=3D-llto-arm + +RELEASE_GCC_ARM_CC_FLAGS =3D DEF(GCC5_ARM_CC_FLAGS) -flto -Wno-unus= ed-but-set-variable -Wno-unused-const-variable +RELEASE_GCC_ARM_DLINK_FLAGS =3D DEF(GCC5_ARM_DLINK_FLAGS) -flto -Os -L= $(WORKSPACE)/ArmPkg/Library/GccLto -llto-arm -Wl,-plugin-opt=3D-pass-throug= h=3D-llto-arm + + NOOPT_GCC_ARM_CC_FLAGS =3D DEF(GCC5_ARM_CC_FLAGS) -O0 + NOOPT_GCC_ARM_DLINK_FLAGS =3D DEF(GCC5_ARM_DLINK_FLAGS) -O0 + +################## +# GCC AARCH64 definitions +################## +*_GCC_AARCH64_CC_PATH =3D ENV(GCC_AARCH64_PREFIX)gcc +*_GCC_AARCH64_SLINK_PATH =3D ENV(GCC_AARCH64_PREFIX)gcc-ar +*_GCC_AARCH64_DLINK_PATH =3D ENV(GCC_AARCH64_PREFIX)gcc +*_GCC_AARCH64_ASLDLINK_PATH =3D ENV(GCC_AARCH64_PREFIX)gcc +*_GCC_AARCH64_ASM_PATH =3D ENV(GCC_AARCH64_PREFIX)gcc +*_GCC_AARCH64_PP_PATH =3D ENV(GCC_AARCH64_PREFIX)gcc +*_GCC_AARCH64_VFRPP_PATH =3D ENV(GCC_AARCH64_PREFIX)gcc +*_GCC_AARCH64_ASLCC_PATH =3D ENV(GCC_AARCH64_PREFIX)gcc +*_GCC_AARCH64_ASLPP_PATH =3D ENV(GCC_AARCH64_PREFIX)gcc +*_GCC_AARCH64_RC_PATH =3D ENV(GCC_AARCH64_PREFIX)objcopy + +*_GCC_AARCH64_ASLCC_FLAGS =3D DEF(GCC5_ASLCC_FLAGS) +*_GCC_AARCH64_ASLDLINK_FLAGS =3D DEF(GCC5_AARCH64_ASLDLINK_FLAGS) +*_GCC_AARCH64_ASM_FLAGS =3D DEF(GCC5_AARCH64_ASM_FLAGS) +*_GCC_AARCH64_DLINK2_FLAGS =3D DEF(GCC5_AARCH64_DLINK2_FLAGS) +*_GCC_AARCH64_DTCPP_FLAGS =3D DEF(GCC_DTCPP_FLAGS) +*_GCC_AARCH64_PLATFORM_FLAGS =3D +*_GCC_AARCH64_PP_FLAGS =3D $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS) +*_GCC_AARCH64_RC_FLAGS =3D DEF(GCC_AARCH64_RC_FLAGS) DEF(GCC_AARC= H64_RC_BTI_FLAGS) +*_GCC_AARCH64_VFRPP_FLAGS =3D $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS) +*_GCC_AARCH64_CC_XIPFLAGS =3D DEF(GCC5_AARCH64_CC_XIPFLAGS) + + DEBUG_GCC_AARCH64_CC_FLAGS =3D DEF(GCC5_AARCH64_CC_FLAGS) -flto -Wno-= unused-but-set-variable -Wno-unused-const-variable + DEBUG_GCC_AARCH64_DLINK_FLAGS =3D DEF(GCC5_AARCH64_DLINK_FLAGS) -flto -O= s -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-aarch64 -Wl,-plugin-opt=3D-pas= s-through=3D-llto-aarch64 -Wno-lto-type-mismatch + DEBUG_GCC_AARCH64_DLINK_XIPFLAGS =3D -z common-page-size=3D0x20 + +RELEASE_GCC_AARCH64_CC_FLAGS =3D DEF(GCC5_AARCH64_CC_FLAGS) -flto -Wno-= unused-but-set-variable -Wno-unused-const-variable +RELEASE_GCC_AARCH64_DLINK_FLAGS =3D DEF(GCC5_AARCH64_DLINK_FLAGS) -flto -O= s -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-aarch64 -Wl,-plugin-opt=3D-pas= s-through=3D-llto-aarch64 -Wno-lto-type-mismatch +RELEASE_GCC_AARCH64_DLINK_XIPFLAGS =3D -z common-page-size=3D0x20 + + NOOPT_GCC_AARCH64_CC_FLAGS =3D DEF(GCC5_AARCH64_CC_FLAGS) -O0 + NOOPT_GCC_AARCH64_DLINK_FLAGS =3D DEF(GCC5_AARCH64_DLINK_FLAGS) -O0 + NOOPT_GCC_AARCH64_DLINK_XIPFLAGS =3D -z common-page-size=3D0x20 -O0 + +##########################################################################= ########## +# +# GCC RISC-V This configuration is used to compile under Linux to produce +# PE/COFF binaries using GCC RISC-V tool chain +# +##########################################################################= ########## + +################## +# GCC RISCV64 definitions +################## +*_GCC_RISCV64_OBJCOPY_PATH =3D ENV(GCC_RISCV64_PREFIX)objcopy +*_GCC_RISCV64_CC_PATH =3D ENV(GCC_RISCV64_PREFIX)gcc +*_GCC_RISCV64_SLINK_PATH =3D ENV(GCC_RISCV64_PREFIX)gcc-ar +*_GCC_RISCV64_DLINK_PATH =3D ENV(GCC_RISCV64_PREFIX)gcc +*_GCC_RISCV64_ASLDLINK_PATH =3D ENV(GCC_RISCV64_PREFIX)gcc +*_GCC_RISCV64_ASM_PATH =3D ENV(GCC_RISCV64_PREFIX)gcc +*_GCC_RISCV64_PP_PATH =3D ENV(GCC_RISCV64_PREFIX)gcc +*_GCC_RISCV64_VFRPP_PATH =3D ENV(GCC_RISCV64_PREFIX)gcc +*_GCC_RISCV64_ASLCC_PATH =3D ENV(GCC_RISCV64_PREFIX)gcc +*_GCC_RISCV64_ASLPP_PATH =3D ENV(GCC_RISCV64_PREFIX)gcc +*_GCC_RISCV64_RC_PATH =3D ENV(GCC_RISCV64_PREFIX)objcopy + +*_GCC_RISCV64_ASLCC_FLAGS =3D DEF(GCC_ASLCC_FLAGS) +*_GCC_RISCV64_ASLDLINK_FLAGS =3D DEF(GCC5_RISCV32_RISCV64_ASLDLINK_F= LAGS) +*_GCC_RISCV64_ASM_FLAGS =3D DEF(GCC5_RISCV64_ASM_FLAGS) +*_GCC_RISCV64_CC_FLAGS =3D DEF(GCC5_RISCV64_CC_FLAGS) -save-te= mps +*_GCC_RISCV64_DLINK_FLAGS =3D DEF(GCC5_RISCV64_DLINK_FLAGS) +*_GCC_RISCV64_DLINK2_FLAGS =3D DEF(GCC5_RISCV64_DLINK2_FLAGS) +*_GCC_RISCV64_RC_FLAGS =3D DEF(GCC_RISCV64_RC_FLAGS) +*_GCC_RISCV64_OBJCOPY_FLAGS =3D +*_GCC_RISCV64_DTCPP_FLAGS =3D DEF(GCC_DTCPP_FLAGS) +*_GCC_RISCV64_PP_FLAGS =3D DEF(GCC_PP_FLAGS) DEF(GCC5_RISCV_OP= ENSBI_TYPES) + +################## +# GCC LOONGARCH64 definitions +################## +*_GCC_LOONGARCH64_OBJCOPY_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)objc= opy +*_GCC_LOONGARCH64_CC_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)gcc +*_GCC_LOONGARCH64_SLINK_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)gcc-= ar +*_GCC_LOONGARCH64_DLINK_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)gcc +*_GCC_LOONGARCH64_ASLDLINK_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)gcc +*_GCC_LOONGARCH64_ASM_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)gcc +*_GCC_LOONGARCH64_PP_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)gcc +*_GCC_LOONGARCH64_VFRPP_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)gcc +*_GCC_LOONGARCH64_ASLCC_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)gcc +*_GCC_LOONGARCH64_ASLPP_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)gcc +*_GCC_LOONGARCH64_RC_PATH =3D ENV(GCC_LOONGARCH64_PREFIX)objc= opy + +*_GCC_LOONGARCH64_ASLCC_FLAGS =3D DEF(GCC_ASLCC_FLAGS) +*_GCC_LOONGARCH64_ASLDLINK_FLAGS =3D DEF(GCC5_LOONGARCH64_ASLDLINK_F= LAGS) +*_GCC_LOONGARCH64_ASM_FLAGS =3D DEF(GCC5_LOONGARCH64_ASM_FLAGS) +*_GCC_LOONGARCH64_DLINK_FLAGS =3D DEF(GCC5_LOONGARCH64_DLINK_FLAG= S) +*_GCC_LOONGARCH64_DLINK2_FLAGS =3D DEF(GCC5_LOONGARCH64_DLINK2_FLA= GS) +*_GCC_LOONGARCH64_RC_FLAGS =3D DEF(GCC_LOONGARCH64_RC_FLAGS) +*_GCC_LOONGARCH64_OBJCOPY_FLAGS =3D +*_GCC_LOONGARCH64_NASM_FLAGS =3D -f elf32 +*_GCC_LOONGARCH64_PP_FLAGS =3D DEF(GCC5_LOONGARCH64_PP_FLAGS) + +DEBUG_GCC_LOONGARCH64_CC_FLAGS =3D DEF(GCC5_LOONGARCH64_CC_FLAGS) +RELEASE_GCC_LOONGARCH64_CC_FLAGS =3D DEF(GCC5_LOONGARCH64_CC_FLAGS) = -Wno-unused-but-set-variable -Wno-unused-variable + ##########################################################################= ########## # # CLANG35 - This configuration is used to compile under Linux to produce --=20 2.39.2 -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D- Groups.io Links: You receive all messages sent to this group. View/Reply Online (#103808): https://edk2.groups.io/g/devel/message/103808 Mute This Topic: https://groups.io/mt/98618987/1787277 Group Owner: devel+owner@edk2.groups.io Unsubscribe: https://edk2.groups.io/g/devel/unsub [importer@patchew.org] -=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-=3D-