2007-10-17 03:54:36 +02:00
|
|
|
#
|
2022-01-10 15:30:29 +01:00
|
|
|
# Copyright (c) 2006 - 2022, Intel Corporation. All rights reserved.<BR>
|
2010-05-18 07:04:32 +02:00
|
|
|
# Portions copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR>
|
2020-07-23 02:41:29 +02:00
|
|
|
# Portions copyright (c) 2011 - 2019, ARM Ltd. All rights reserved.<BR>
|
2016-03-16 09:23:02 +01:00
|
|
|
# Copyright (c) 2015, Hewlett-Packard Development Company, L.P.<BR>
|
2020-04-23 15:52:33 +02:00
|
|
|
# (C) Copyright 2020, Hewlett Packard Enterprise Development LP<BR>
|
2022-09-06 13:25:29 +02:00
|
|
|
# Copyright (c) 2022, Loongson Technology Corporation Limited. All rights reserved.<BR>
|
2019-10-08 04:54:21 +02:00
|
|
|
# Copyright (c) Microsoft Corporation
|
2007-10-17 03:54:36 +02:00
|
|
|
#
|
2019-04-04 01:03:11 +02:00
|
|
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
2007-10-17 03:54:36 +02:00
|
|
|
#
|
2019-10-08 04:54:21 +02:00
|
|
|
#
|
|
|
|
# Increase this version tag any time you want user to get warning about updating this
|
|
|
|
# file in the Conf dir. By default it does not do update existing conf dirs.
|
|
|
|
#
|
|
|
|
# 2.00 - Initial version with changes for CI
|
|
|
|
# - Change RC path to use plugin
|
2023-04-16 17:01:43 +02:00
|
|
|
# 3.00 - Update toolchains
|
|
|
|
# - Add support for ARM and AARCH64 to CLANGDWARF
|
|
|
|
# - Remove VS2008, VS2010, VS2012, VS2013, CLANG35, CLANG38, EBC
|
|
|
|
# - Add GCC and GCCNOLTO
|
|
|
|
# - Deprecate GCC48, GCC49 and GCC5.
|
2019-10-08 04:54:21 +02:00
|
|
|
#
|
2023-04-16 17:01:43 +02:00
|
|
|
#!VERSION=3.00
|
2007-10-17 03:54:36 +02:00
|
|
|
|
|
|
|
IDENTIFIER = Default TOOL_CHAIN_CONF
|
|
|
|
|
|
|
|
# common path macros
|
2016-10-28 04:38:11 +02:00
|
|
|
DEFINE VS2015_BIN = ENV(VS2015_PREFIX)Vc\bin
|
|
|
|
DEFINE VS2015_DLL = ENV(VS2015_PREFIX)Common7\IDE;DEF(VS2015_BIN)
|
2015-12-03 04:19:01 +01:00
|
|
|
DEFINE VS2015_BINX64 = DEF(VS2015_BIN)\x86_amd64
|
|
|
|
|
2016-10-28 04:38:11 +02:00
|
|
|
DEFINE VS2015x86_BIN = ENV(VS2015_PREFIX)Vc\bin
|
|
|
|
DEFINE VS2015x86_DLL = ENV(VS2015_PREFIX)Common7\IDE;DEF(VS2015x86_BIN)
|
2015-12-03 04:19:01 +01:00
|
|
|
DEFINE VS2015x86_BINX64 = DEF(VS2015x86_BIN)\x86_amd64
|
|
|
|
|
2019-09-19 10:52:25 +02:00
|
|
|
DEFINE VS_HOST = x86
|
2017-11-22 17:26:08 +01:00
|
|
|
|
2019-09-19 10:52:25 +02:00
|
|
|
DEFINE VS2017_BIN = ENV(VS2017_PREFIX)bin
|
|
|
|
DEFINE VS2017_BIN_HOST = DEF(VS2017_BIN)\HostDEF(VS_HOST)\DEF(VS_HOST)
|
|
|
|
DEFINE VS2017_BIN_IA32 = DEF(VS2017_BIN)\HostDEF(VS_HOST)\x86
|
|
|
|
DEFINE VS2017_BIN_X64 = DEF(VS2017_BIN)\HostDEF(VS_HOST)\x64
|
|
|
|
DEFINE VS2017_BIN_ARM = DEF(VS2017_BIN)\HostDEF(VS_HOST)\arm
|
|
|
|
DEFINE VS2017_BIN_AARCH64 = DEF(VS2017_BIN)\HostDEF(VS_HOST)\arm64
|
|
|
|
|
|
|
|
DEFINE VS2019_BIN = ENV(VS2019_PREFIX)bin
|
|
|
|
DEFINE VS2019_BIN_HOST = DEF(VS2019_BIN)\HostDEF(VS_HOST)\DEF(VS_HOST)
|
|
|
|
DEFINE VS2019_BIN_IA32 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\x86
|
|
|
|
DEFINE VS2019_BIN_X64 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\x64
|
|
|
|
DEFINE VS2019_BIN_ARM = DEF(VS2019_BIN)\HostDEF(VS_HOST)\arm
|
|
|
|
DEFINE VS2019_BIN_AARCH64 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\arm64
|
|
|
|
|
2019-10-08 04:54:21 +02:00
|
|
|
#
|
|
|
|
# Resource compiler
|
|
|
|
#
|
|
|
|
DEFINE RC_PATH = ENV(WINSDK_PATH_FOR_RC_EXE)\rc.exe
|
|
|
|
|
2019-09-19 10:52:25 +02:00
|
|
|
DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX)
|
|
|
|
DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX)
|
2009-11-09 12:47:35 +01:00
|
|
|
|
2015-12-03 04:19:01 +01:00
|
|
|
# Microsoft Visual Studio 2015 Professional Edition
|
2019-09-19 10:52:25 +02:00
|
|
|
DEFINE WINSDK81_BIN = ENV(WINSDK81_PREFIX)x86\
|
|
|
|
DEFINE WINSDK81x86_BIN = ENV(WINSDK81x86_PREFIX)x64
|
2015-12-03 04:19:01 +01:00
|
|
|
|
2019-09-19 10:52:25 +02:00
|
|
|
# Microsoft Visual Studio 2017/2019 Professional Edition
|
|
|
|
DEFINE WINSDK10_BIN = ENV(WINSDK10_PREFIX)DEF(VS_HOST)
|
2017-11-22 17:26:08 +01:00
|
|
|
|
2009-11-09 12:47:35 +01:00
|
|
|
# These defines are needed for certain Microsoft Visual Studio tools that
|
|
|
|
# are used by other toolchains. An example is that ICC on Windows normally
|
|
|
|
# uses Microsoft's nmake.exe.
|
|
|
|
|
2016-10-28 04:38:11 +02:00
|
|
|
DEFINE WINDDK_BIN16 = ENV(WINDDK3790_PREFIX)bin16
|
|
|
|
DEFINE WINDDK_BINX64 = ENV(WINDDK3790_PREFIX)win64\x86\amd64
|
2007-10-17 03:54:36 +02:00
|
|
|
|
2009-04-14 05:20:33 +02:00
|
|
|
DEFINE CYGWIN_BIN = c:/cygwin/bin
|
2009-11-09 12:47:35 +01:00
|
|
|
DEFINE CYGWIN_BINIA32 = c:/cygwin/opt/tiano/i386-tiano-pe/i386-tiano-pe/bin/
|
2009-08-15 07:05:00 +02:00
|
|
|
DEFINE CYGWIN_BINX64 = c:/cygwin/opt/tiano/x86_64-pc-mingw64/x86_64-pc-mingw64/bin/
|
2009-04-14 05:20:33 +02:00
|
|
|
|
2014-11-18 03:38:20 +01:00
|
|
|
DEFINE GCC48_IA32_PREFIX = ENV(GCC48_BIN)
|
|
|
|
DEFINE GCC48_X64_PREFIX = ENV(GCC48_BIN)
|
2014-01-10 06:25:50 +01:00
|
|
|
|
2014-11-18 03:38:20 +01:00
|
|
|
DEFINE GCC49_IA32_PREFIX = ENV(GCC49_BIN)
|
|
|
|
DEFINE GCC49_X64_PREFIX = ENV(GCC49_BIN)
|
2014-07-28 19:37:10 +02:00
|
|
|
|
2023-04-12 20:35:11 +02:00
|
|
|
DEFINE GCCNOLTO_IA32_PREFIX = ENV(GCCNOLTO_BIN)
|
|
|
|
DEFINE GCCNOLTO_X64_PREFIX = ENV(GCCNOLTO_BIN)
|
|
|
|
|
2016-07-17 23:20:10 +02:00
|
|
|
DEFINE GCC5_IA32_PREFIX = ENV(GCC5_BIN)
|
|
|
|
DEFINE GCC5_X64_PREFIX = ENV(GCC5_BIN)
|
2023-04-12 20:35:11 +02:00
|
|
|
DEFINE GCC_IA32_PREFIX = ENV(GCC_BIN)
|
|
|
|
DEFINE GCC_X64_PREFIX = ENV(GCC_BIN)
|
2018-04-25 12:11:42 +02:00
|
|
|
DEFINE GCC_HOST_PREFIX = ENV(GCC_HOST_BIN)
|
2016-07-17 23:20:10 +02:00
|
|
|
|
2014-07-01 09:10:10 +02:00
|
|
|
DEFINE UNIX_IASL_BIN = ENV(IASL_PREFIX)iasl
|
2016-10-28 04:38:11 +02:00
|
|
|
DEFINE WIN_IASL_BIN = ENV(IASL_PREFIX)iasl.exe
|
2009-04-14 05:20:33 +02:00
|
|
|
|
2009-12-29 07:16:53 +01:00
|
|
|
DEFINE IASL_FLAGS =
|
2009-06-17 11:34:46 +02:00
|
|
|
DEFINE IASL_OUTFLAGS = -p
|
2009-12-29 07:16:53 +01:00
|
|
|
|
|
|
|
DEFINE DEFAULT_WIN_ASL_BIN = DEF(WIN_IASL_BIN)
|
|
|
|
DEFINE DEFAULT_WIN_ASL_FLAGS = DEF(IASL_FLAGS)
|
|
|
|
DEFINE DEFAULT_WIN_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
2009-04-13 14:50:50 +02:00
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
# MSFT Build Flag for included header file list generation
|
|
|
|
DEFINE MSFT_DEPS_FLAGS = /showIncludes
|
|
|
|
|
2010-10-11 08:26:52 +02:00
|
|
|
DEFINE MSFT_ASLPP_FLAGS = /nologo /E /C /FIAutoGen.h
|
2010-11-15 03:51:34 +01:00
|
|
|
DEFINE MSFT_ASLCC_FLAGS = /nologo /c /FIAutoGen.h /TC /Dmain=ReferenceAcpiTable
|
2011-05-11 12:26:49 +02:00
|
|
|
DEFINE MSFT_ASLDLINK_FLAGS = /NODEFAULTLIB /ENTRY:ReferenceAcpiTable /SUBSYSTEM:CONSOLE
|
2009-04-13 14:50:50 +02:00
|
|
|
|
2018-02-27 18:47:06 +01:00
|
|
|
DEFINE DTCPP_BIN = ENV(DTCPP_PREFIX)cpp
|
2017-08-29 15:21:02 +02:00
|
|
|
DEFINE DTC_BIN = ENV(DTC_PREFIX)dtc
|
|
|
|
|
2007-10-17 03:54:36 +02:00
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# format: TARGET_TOOLCHAIN_ARCH_COMMANDTYPE_ATTRIBUTE = <string>
|
2007-12-25 10:15:38 +01:00
|
|
|
# priority:
|
2007-10-17 03:54:36 +02:00
|
|
|
# TARGET_TOOLCHAIN_ARCH_COMMANDTYPE_ATTRIBUTE (Highest)
|
|
|
|
# ******_TOOLCHAIN_ARCH_COMMANDTYPE_ATTRIBUTE
|
|
|
|
# TARGET_*********_ARCH_COMMANDTYPE_ATTRIBUTE
|
|
|
|
# ******_*********_ARCH_COMMANDTYPE_ATTRIBUTE
|
|
|
|
# TARGET_TOOLCHAIN_****_COMMANDTYPE_ATTRIBUTE
|
|
|
|
# ******_TOOLCHAIN_****_COMMANDTYPE_ATTRIBUTE
|
|
|
|
# TARGET_*********_****_COMMANDTYPE_ATTRIBUTE
|
|
|
|
# ******_*********_****_COMMANDTYPE_ATTRIBUTE
|
|
|
|
# TARGET_TOOLCHAIN_ARCH_***********_ATTRIBUTE
|
|
|
|
# ******_TOOLCHAIN_ARCH_***********_ATTRIBUTE
|
|
|
|
# TARGET_*********_ARCH_***********_ATTRIBUTE
|
|
|
|
# ******_*********_ARCH_***********_ATTRIBUTE
|
|
|
|
# TARGET_TOOLCHAIN_****_***********_ATTRIBUTE
|
|
|
|
# ******_TOOLCHAIN_****_***********_ATTRIBUTE
|
|
|
|
# TARGET_*********_****_***********_ATTRIBUTE
|
|
|
|
# ******_*********_****_***********_ATTRIBUTE (Lowest)
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# Supported Tool Chains
|
|
|
|
# =====================
|
2015-12-03 04:19:01 +01:00
|
|
|
# VS2015 -win32- Requires:
|
2023-04-02 17:36:16 +02:00
|
|
|
# Microsoft Visual Studio 2015 Professional Edition, Update 3
|
2015-12-03 04:19:01 +01:00
|
|
|
# Optional:
|
|
|
|
# Required to build platforms or ACPI tables:
|
|
|
|
# Intel(r) ACPI Compiler (iasl.exe) from
|
|
|
|
# https://acpica.org/downloads
|
2017-11-22 17:26:08 +01:00
|
|
|
# VS2017 -win32- Requires:
|
2018-02-23 10:50:03 +01:00
|
|
|
# Microsoft Visual Studio 2017 version 15.2 (15.4 for ARM64) or later
|
2017-11-22 17:26:08 +01:00
|
|
|
# Optional:
|
|
|
|
# Required to build platforms or ACPI tables:
|
|
|
|
# Intel(r) ACPI Compiler (iasl.exe) from
|
|
|
|
# https://acpica.org/downloads
|
2018-01-12 14:33:31 +01:00
|
|
|
# Note:
|
2018-02-23 10:50:03 +01:00
|
|
|
# Building of XIP firmware images for ARM/ARM64 is not currently supported (only applications).
|
2018-01-12 14:33:31 +01:00
|
|
|
# /FILEALIGN:4096 and other changes are needed for ARM firmware builds.
|
2019-09-19 10:52:25 +02:00
|
|
|
# VS2019 -win32- Requires:
|
|
|
|
# Microsoft Visual Studio 2019 version 16.2 or later
|
|
|
|
# Optional:
|
|
|
|
# Required to build platforms or ACPI tables:
|
|
|
|
# Intel(r) ACPI Compiler (iasl.exe) from
|
|
|
|
# https://acpica.org/downloads
|
|
|
|
# Note:
|
|
|
|
# Building of XIP firmware images for ARM/ARM64 is not currently supported (only applications).
|
|
|
|
# /FILEALIGN:4096 and other changes are needed for ARM firmware builds.
|
2023-04-16 14:55:25 +02:00
|
|
|
# GCCNOLTO -Linux,Windows- Requires:
|
2014-11-24 03:43:17 +01:00
|
|
|
# GCC 4.9 targeting x86_64-linux-gnu, aarch64-linux-gnu, or arm-linux-gnueabi
|
2014-07-28 19:37:10 +02:00
|
|
|
# Optional:
|
|
|
|
# Required to build platforms or ACPI tables:
|
2015-06-29 05:10:25 +02:00
|
|
|
# Intel(r) ACPI Compiler from
|
|
|
|
# https://acpica.org/downloads
|
2023-04-16 14:55:25 +02:00
|
|
|
# GCC -Linux,Windows- Requires:
|
2022-09-06 13:25:29 +02:00
|
|
|
# GCC 5 with LTO support, targeting x86_64-linux-gnu, aarch64-linux-gnu, arm-linux-gnueabi, riscv64-linux-gnu or loongarch64-linux-gnu
|
2016-07-17 23:20:10 +02:00
|
|
|
# Optional:
|
|
|
|
# Required to build platforms or ACPI tables:
|
|
|
|
# Intel(r) ACPI Compiler from
|
|
|
|
# https://acpica.org/downloads
|
2020-04-23 15:52:33 +02:00
|
|
|
#
|
2019-11-14 09:00:53 +01:00
|
|
|
# CLANGPDB -Linux, Windows, Mac- Requires:
|
2019-10-17 08:55:46 +02:00
|
|
|
# Clang 9 or above from http://releases.llvm.org/
|
|
|
|
# Optional:
|
|
|
|
# Required to compile nasm source:
|
|
|
|
# nasm compiler from
|
|
|
|
# NASM -- http://www.nasm.us/
|
2021-06-02 10:11:45 +02:00
|
|
|
# CLANGDWARF -Linux, Windows, Mac- Requires:
|
|
|
|
# Clang 9 or above from http://releases.llvm.org/
|
2021-06-02 10:11:43 +02:00
|
|
|
# Optional:
|
2021-06-02 10:11:45 +02:00
|
|
|
# Required to compile nasm source:
|
|
|
|
# nasm compiler from
|
|
|
|
# NASM -- http://www.nasm.us/
|
2015-12-03 04:19:01 +01:00
|
|
|
# VS2015x86 -win64- Requires:
|
2023-04-02 17:36:16 +02:00
|
|
|
# Microsoft Visual Studio 2015 (x86) Update 3 or above
|
2015-12-03 04:19:01 +01:00
|
|
|
# Optional:
|
|
|
|
# Required to build platforms or ACPI tables:
|
|
|
|
# Intel(r) ACPI Compiler (iasl.exe) from
|
|
|
|
# https://acpica.org/downloads
|
2007-10-17 03:54:36 +02:00
|
|
|
#
|
2023-04-16 14:55:25 +02:00
|
|
|
# Deprecated Tool Chains
|
|
|
|
# ======================
|
|
|
|
# GCC48 -Linux,Windows- Requires:
|
|
|
|
# GCC 4.8 targeting x86_64-linux-gnu, aarch64-linux-gnu, or arm-linux-gnueabi
|
|
|
|
# Optional:
|
|
|
|
# Required to build platforms or ACPI tables:
|
|
|
|
# Intel(r) ACPI Compiler from
|
|
|
|
# https://acpica.org/downloads
|
|
|
|
# GCC49 -Linux,Windows- Requires:
|
|
|
|
# GCC 4.9 targeting x86_64-linux-gnu, aarch64-linux-gnu, or arm-linux-gnueabi
|
|
|
|
# Optional:
|
|
|
|
# Required to build platforms or ACPI tables:
|
|
|
|
# Intel(r) ACPI Compiler from
|
|
|
|
# https://acpica.org/downloads
|
|
|
|
# GCC5 -Linux,Windows- Requires:
|
|
|
|
# GCC 5 with LTO support, targeting x86_64-linux-gnu, aarch64-linux-gnu, arm-linux-gnueabi, riscv64-linux-gnu or loongarch64-linux-gnu
|
|
|
|
# Optional:
|
|
|
|
# Required to build platforms or ACPI tables:
|
|
|
|
# Intel(r) ACPI Compiler from
|
|
|
|
# https://acpica.org/downloads
|
|
|
|
#
|
2007-10-17 03:54:36 +02:00
|
|
|
####################################################################################
|
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# Supported Tool Chain Family
|
|
|
|
# ===========================
|
|
|
|
# MSFT - Microsoft
|
|
|
|
# GCC - GNU GCC
|
|
|
|
# INTEL - INTEL
|
2009-04-13 14:50:50 +02:00
|
|
|
####################################################################################
|
|
|
|
####################################################################################
|
|
|
|
#
|
2014-08-19 01:03:17 +02:00
|
|
|
# Other Supported Tools
|
|
|
|
# =====================
|
2016-07-14 13:29:10 +02:00
|
|
|
# NASM -- http://www.nasm.us/
|
2022-01-10 15:30:29 +01:00
|
|
|
# - NASM 2.15.05 or later for use with the GCC toolchain family
|
|
|
|
# - NASM 2.15.05 or later for use with all other toolchain families
|
2014-08-19 01:03:17 +02:00
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
####################################################################################
|
|
|
|
#
|
2009-04-13 14:50:50 +02:00
|
|
|
# Intel ACPI Source Language Compiler (Template)
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
# *_*_*_ASL_FAMILY = INTEL
|
|
|
|
#
|
|
|
|
# *_*_*_ASL_PATH = C:\ASL\iasl.exe
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# Microsoft ACPI Source Language Compiler (Template)
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
# *_*_*_ASL_FAMILY = MSFT
|
|
|
|
#
|
|
|
|
# *_*_*_ASL_PATH = C:\ASL\asl.exe
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
|
2015-12-03 04:19:01 +01:00
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# Microsoft Visual Studio 2015
|
|
|
|
#
|
|
|
|
# VS2015 - Microsoft Visual Studio 2015 Professional Edition with Intel ASL
|
|
|
|
# ASL - Intel ACPI Source Language Compiler
|
|
|
|
####################################################################################
|
|
|
|
# VS2015 - Microsoft Visual Studio 2015 Professional Edition
|
|
|
|
*_VS2015_*_*_FAMILY = MSFT
|
|
|
|
|
|
|
|
*_VS2015_*_MAKE_PATH = DEF(VS2015_BIN)\nmake.exe
|
|
|
|
*_VS2015_*_MAKE_FLAGS = /nologo
|
|
|
|
*_VS2015_*_RC_PATH = DEF(WINSDK81_BIN)\rc.exe
|
|
|
|
|
|
|
|
*_VS2015_*_SLINK_FLAGS = /NOLOGO /LTCG
|
|
|
|
*_VS2015_*_APP_FLAGS = /nologo /E /TC
|
|
|
|
*_VS2015_*_PP_FLAGS = /nologo /E /TC /FIAutoGen.h
|
|
|
|
*_VS2015_*_VFRPP_FLAGS = /nologo /E /TC /DVFRCOMPILE /FI$(MODULE_NAME)StrDefs.h
|
2017-08-24 06:38:01 +02:00
|
|
|
*_VS2015_*_DLINK2_FLAGS =
|
2019-12-02 09:24:19 +01:00
|
|
|
*_VS2015_*_DEPS_FLAGS = DEF(MSFT_DEPS_FLAGS)
|
2015-12-03 04:19:01 +01:00
|
|
|
*_VS2015_*_ASM16_PATH = DEF(VS2015_BIN)\ml.exe
|
|
|
|
|
|
|
|
##################
|
|
|
|
# ASL definitions
|
|
|
|
##################
|
|
|
|
*_VS2015_*_ASL_PATH = DEF(DEFAULT_WIN_ASL_BIN)
|
|
|
|
*_VS2015_*_ASL_FLAGS = DEF(DEFAULT_WIN_ASL_FLAGS)
|
|
|
|
*_VS2015_*_ASL_OUTFLAGS = DEF(DEFAULT_WIN_ASL_OUTFLAGS)
|
|
|
|
*_VS2015_*_ASLCC_FLAGS = DEF(MSFT_ASLCC_FLAGS)
|
|
|
|
*_VS2015_*_ASLPP_FLAGS = DEF(MSFT_ASLPP_FLAGS)
|
|
|
|
*_VS2015_*_ASLDLINK_FLAGS = DEF(MSFT_ASLDLINK_FLAGS)
|
|
|
|
|
|
|
|
##################
|
|
|
|
# IA32 definitions
|
|
|
|
##################
|
|
|
|
*_VS2015_IA32_*_DLL = DEF(VS2015_DLL)
|
|
|
|
|
|
|
|
*_VS2015_IA32_CC_PATH = DEF(VS2015_BIN)\cl.exe
|
|
|
|
*_VS2015_IA32_VFRPP_PATH = DEF(VS2015_BIN)\cl.exe
|
|
|
|
*_VS2015_IA32_SLINK_PATH = DEF(VS2015_BIN)\lib.exe
|
|
|
|
*_VS2015_IA32_DLINK_PATH = DEF(VS2015_BIN)\link.exe
|
|
|
|
*_VS2015_IA32_APP_PATH = DEF(VS2015_BIN)\cl.exe
|
|
|
|
*_VS2015_IA32_PP_PATH = DEF(VS2015_BIN)\cl.exe
|
|
|
|
*_VS2015_IA32_ASM_PATH = DEF(VS2015_BIN)\ml.exe
|
|
|
|
*_VS2015_IA32_ASLCC_PATH = DEF(VS2015_BIN)\cl.exe
|
|
|
|
*_VS2015_IA32_ASLPP_PATH = DEF(VS2015_BIN)\cl.exe
|
|
|
|
*_VS2015_IA32_ASLDLINK_PATH = DEF(VS2015_BIN)\link.exe
|
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
DEBUG_VS2015_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Gw
|
|
|
|
RELEASE_VS2015_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw
|
|
|
|
NOOPT_VS2015_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od
|
2015-12-03 04:19:01 +01:00
|
|
|
|
|
|
|
DEBUG_VS2015_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
|
|
|
|
RELEASE_VS2015_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd
|
|
|
|
NOOPT_VS2015_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
|
|
|
|
|
|
|
|
DEBUG_VS2015_IA32_NASM_FLAGS = -Ox -f win32 -g
|
|
|
|
RELEASE_VS2015_IA32_NASM_FLAGS = -Ox -f win32
|
|
|
|
NOOPT_VS2015_IA32_NASM_FLAGS = -O0 -f win32 -g
|
|
|
|
|
|
|
|
DEBUG_VS2015_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2015_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2015_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
|
|
|
|
##################
|
|
|
|
# X64 definitions
|
|
|
|
##################
|
|
|
|
*_VS2015_X64_*_DLL = DEF(VS2015_DLL)
|
|
|
|
|
|
|
|
*_VS2015_X64_CC_PATH = DEF(VS2015_BINX64)\cl.exe
|
|
|
|
*_VS2015_X64_PP_PATH = DEF(VS2015_BINX64)\cl.exe
|
|
|
|
*_VS2015_X64_APP_PATH = DEF(VS2015_BINX64)\cl.exe
|
|
|
|
*_VS2015_X64_VFRPP_PATH = DEF(VS2015_BINX64)\cl.exe
|
|
|
|
*_VS2015_X64_ASM_PATH = DEF(VS2015_BINX64)\ml64.exe
|
|
|
|
*_VS2015_X64_SLINK_PATH = DEF(VS2015_BINX64)\lib.exe
|
|
|
|
*_VS2015_X64_DLINK_PATH = DEF(VS2015_BINX64)\link.exe
|
|
|
|
*_VS2015_X64_ASLCC_PATH = DEF(VS2015_BINX64)\cl.exe
|
|
|
|
*_VS2015_X64_ASLPP_PATH = DEF(VS2015_BINX64)\cl.exe
|
|
|
|
*_VS2015_X64_ASLDLINK_PATH = DEF(VS2015_BINX64)\link.exe
|
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
DEBUG_VS2015_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Gw
|
|
|
|
RELEASE_VS2015_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw
|
|
|
|
NOOPT_VS2015_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od
|
2015-12-03 04:19:01 +01:00
|
|
|
|
|
|
|
DEBUG_VS2015_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
|
|
|
|
RELEASE_VS2015_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd
|
|
|
|
NOOPT_VS2015_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
|
|
|
|
|
|
|
|
DEBUG_VS2015_X64_NASM_FLAGS = -Ox -f win64 -g
|
|
|
|
RELEASE_VS2015_X64_NASM_FLAGS = -Ox -f win64
|
|
|
|
NOOPT_VS2015_X64_NASM_FLAGS = -O0 -f win64 -g
|
|
|
|
|
|
|
|
DEBUG_VS2015_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2015_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2015_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
|
|
|
|
####################################################################################
|
|
|
|
# VS2015x86 - Microsoft Visual Studio 2015 (x86) professional with Intel ASL
|
|
|
|
# ASL - Intel ACPI Source Language Compiler (iasl.exe)
|
|
|
|
####################################################################################
|
|
|
|
# VS2015x86 - Microsoft Visual Studio 2015 (x86) professional Edition with Intel ASL
|
|
|
|
*_VS2015x86_*_*_FAMILY = MSFT
|
|
|
|
|
|
|
|
*_VS2015x86_*_MAKE_PATH = DEF(VS2015x86_BIN)\nmake.exe
|
2021-04-09 23:58:24 +02:00
|
|
|
*_VS2015x86_*_MAKE_FLAGS = /nologo
|
2015-12-03 04:19:01 +01:00
|
|
|
*_VS2015x86_*_RC_PATH = DEF(WINSDK81x86_BIN)\rc.exe
|
|
|
|
|
|
|
|
*_VS2015x86_*_SLINK_FLAGS = /NOLOGO /LTCG
|
|
|
|
*_VS2015x86_*_APP_FLAGS = /nologo /E /TC
|
|
|
|
*_VS2015x86_*_PP_FLAGS = /nologo /E /TC /FIAutoGen.h
|
|
|
|
*_VS2015x86_*_VFRPP_FLAGS = /nologo /E /TC /DVFRCOMPILE /FI$(MODULE_NAME)StrDefs.h
|
2017-08-24 06:38:01 +02:00
|
|
|
*_VS2015x86_*_DLINK2_FLAGS =
|
2019-12-02 09:24:19 +01:00
|
|
|
*_VS2015x86_*_DEPS_FLAGS = DEF(MSFT_DEPS_FLAGS)
|
2015-12-03 04:19:01 +01:00
|
|
|
*_VS2015x86_*_ASM16_PATH = DEF(VS2015x86_BIN)\ml.exe
|
|
|
|
|
|
|
|
##################
|
|
|
|
# ASL definitions
|
|
|
|
##################
|
|
|
|
*_VS2015x86_*_ASL_PATH = DEF(WIN_IASL_BIN)
|
|
|
|
*_VS2015x86_*_ASL_FLAGS = DEF(DEFAULT_WIN_ASL_FLAGS)
|
|
|
|
*_VS2015x86_*_ASL_OUTFLAGS = DEF(DEFAULT_WIN_ASL_OUTFLAGS)
|
|
|
|
*_VS2015x86_*_ASLCC_FLAGS = DEF(MSFT_ASLCC_FLAGS)
|
|
|
|
*_VS2015x86_*_ASLPP_FLAGS = DEF(MSFT_ASLPP_FLAGS)
|
|
|
|
*_VS2015x86_*_ASLDLINK_FLAGS = DEF(MSFT_ASLDLINK_FLAGS)
|
|
|
|
|
|
|
|
##################
|
|
|
|
# IA32 definitions
|
|
|
|
##################
|
|
|
|
*_VS2015x86_IA32_*_DLL = DEF(VS2015x86_DLL)
|
|
|
|
|
|
|
|
*_VS2015x86_IA32_CC_PATH = DEF(VS2015x86_BIN)\cl.exe
|
|
|
|
*_VS2015x86_IA32_VFRPP_PATH = DEF(VS2015x86_BIN)\cl.exe
|
|
|
|
*_VS2015x86_IA32_ASLCC_PATH = DEF(VS2015x86_BIN)\cl.exe
|
|
|
|
*_VS2015x86_IA32_ASLPP_PATH = DEF(VS2015x86_BIN)\cl.exe
|
|
|
|
*_VS2015x86_IA32_SLINK_PATH = DEF(VS2015x86_BIN)\lib.exe
|
|
|
|
*_VS2015x86_IA32_DLINK_PATH = DEF(VS2015x86_BIN)\link.exe
|
|
|
|
*_VS2015x86_IA32_ASLDLINK_PATH= DEF(VS2015x86_BIN)\link.exe
|
|
|
|
*_VS2015x86_IA32_APP_PATH = DEF(VS2015x86_BIN)\cl.exe
|
|
|
|
*_VS2015x86_IA32_PP_PATH = DEF(VS2015x86_BIN)\cl.exe
|
|
|
|
*_VS2015x86_IA32_ASM_PATH = DEF(VS2015x86_BIN)\ml.exe
|
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
DEBUG_VS2015x86_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Gw
|
|
|
|
RELEASE_VS2015x86_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw
|
|
|
|
NOOPT_VS2015x86_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od
|
2015-12-03 04:19:01 +01:00
|
|
|
|
|
|
|
DEBUG_VS2015x86_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
|
|
|
|
RELEASE_VS2015x86_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd
|
|
|
|
NOOPT_VS2015x86_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
|
|
|
|
|
|
|
|
DEBUG_VS2015x86_IA32_NASM_FLAGS = -Ox -f win32 -g
|
|
|
|
RELEASE_VS2015x86_IA32_NASM_FLAGS = -Ox -f win32
|
|
|
|
NOOPT_VS2015x86_IA32_NASM_FLAGS = -O0 -f win32 -g
|
|
|
|
|
|
|
|
DEBUG_VS2015x86_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2015x86_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2015x86_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
|
|
|
|
##################
|
|
|
|
# X64 definitions
|
|
|
|
##################
|
|
|
|
*_VS2015x86_X64_*_DLL = DEF(VS2015x86_DLL)
|
|
|
|
|
|
|
|
*_VS2015x86_X64_CC_PATH = DEF(VS2015x86_BINX64)\cl.exe
|
|
|
|
*_VS2015x86_X64_PP_PATH = DEF(VS2015x86_BINX64)\cl.exe
|
|
|
|
*_VS2015x86_X64_APP_PATH = DEF(VS2015x86_BINX64)\cl.exe
|
|
|
|
*_VS2015x86_X64_VFRPP_PATH = DEF(VS2015x86_BINX64)\cl.exe
|
|
|
|
*_VS2015x86_X64_ASLCC_PATH = DEF(VS2015x86_BINX64)\cl.exe
|
|
|
|
*_VS2015x86_X64_ASLPP_PATH = DEF(VS2015x86_BINX64)\cl.exe
|
|
|
|
*_VS2015x86_X64_ASM_PATH = DEF(VS2015x86_BINX64)\ml64.exe
|
|
|
|
*_VS2015x86_X64_SLINK_PATH = DEF(VS2015x86_BINX64)\lib.exe
|
|
|
|
*_VS2015x86_X64_DLINK_PATH = DEF(VS2015x86_BINX64)\link.exe
|
|
|
|
*_VS2015x86_X64_ASLDLINK_PATH = DEF(VS2015x86_BINX64)\link.exe
|
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
DEBUG_VS2015x86_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Gw
|
|
|
|
RELEASE_VS2015x86_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw
|
|
|
|
NOOPT_VS2015x86_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od
|
2015-12-03 04:19:01 +01:00
|
|
|
|
|
|
|
DEBUG_VS2015x86_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
|
|
|
|
RELEASE_VS2015x86_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd
|
|
|
|
NOOPT_VS2015x86_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
|
|
|
|
|
|
|
|
DEBUG_VS2015x86_X64_NASM_FLAGS = -Ox -f win64 -g
|
|
|
|
RELEASE_VS2015x86_X64_NASM_FLAGS = -Ox -f win64
|
|
|
|
NOOPT_VS2015x86_X64_NASM_FLAGS = -O0 -f win64 -g
|
|
|
|
|
|
|
|
DEBUG_VS2015x86_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2015x86_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2015x86_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
|
2017-11-22 17:26:08 +01:00
|
|
|
####################################################################################
|
|
|
|
# VS2017 - Microsoft Visual Studio 2017 with Intel ASL
|
|
|
|
# ASL - Intel ACPI Source Language Compiler (iasl.exe)
|
|
|
|
####################################################################################
|
|
|
|
# VS2017 - Microsoft Visual Studio 2017 professional Edition with Intel ASL
|
|
|
|
*_VS2017_*_*_FAMILY = MSFT
|
|
|
|
*_VS2017_*_*_DLL = DEF(VS2017_BIN_HOST)
|
|
|
|
|
|
|
|
*_VS2017_*_MAKE_PATH = DEF(VS2017_BIN_HOST)\nmake.exe
|
2021-04-09 23:58:24 +02:00
|
|
|
*_VS2017_*_MAKE_FLAGS = /nologo
|
2019-10-08 04:54:21 +02:00
|
|
|
*_VS2017_*_RC_PATH = DEF(RC_PATH)
|
2017-11-22 17:26:08 +01:00
|
|
|
|
|
|
|
*_VS2017_*_SLINK_FLAGS = /NOLOGO /LTCG
|
|
|
|
*_VS2017_*_APP_FLAGS = /nologo /E /TC
|
|
|
|
*_VS2017_*_PP_FLAGS = /nologo /E /TC /FIAutoGen.h
|
|
|
|
*_VS2017_*_VFRPP_FLAGS = /nologo /E /TC /DVFRCOMPILE /FI$(MODULE_NAME)StrDefs.h
|
|
|
|
*_VS2017_*_DLINK2_FLAGS = /WHOLEARCHIVE
|
|
|
|
*_VS2017_*_ASM16_PATH = DEF(VS2017_BIN_IA32)\ml.exe
|
2019-12-02 09:24:19 +01:00
|
|
|
*_VS2017_*_DEPS_FLAGS = DEF(MSFT_DEPS_FLAGS)
|
2017-11-22 17:26:08 +01:00
|
|
|
##################
|
|
|
|
# ASL definitions
|
|
|
|
##################
|
|
|
|
*_VS2017_*_ASL_PATH = DEF(WIN_IASL_BIN)
|
|
|
|
*_VS2017_*_ASL_FLAGS = DEF(DEFAULT_WIN_ASL_FLAGS)
|
|
|
|
*_VS2017_*_ASL_OUTFLAGS = DEF(DEFAULT_WIN_ASL_OUTFLAGS)
|
|
|
|
*_VS2017_*_ASLCC_FLAGS = DEF(MSFT_ASLCC_FLAGS)
|
|
|
|
*_VS2017_*_ASLPP_FLAGS = DEF(MSFT_ASLPP_FLAGS)
|
|
|
|
*_VS2017_*_ASLDLINK_FLAGS = DEF(MSFT_ASLDLINK_FLAGS)
|
|
|
|
|
|
|
|
##################
|
|
|
|
# IA32 definitions
|
|
|
|
##################
|
|
|
|
*_VS2017_IA32_CC_PATH = DEF(VS2017_BIN_IA32)\cl.exe
|
|
|
|
*_VS2017_IA32_VFRPP_PATH = DEF(VS2017_BIN_IA32)\cl.exe
|
|
|
|
*_VS2017_IA32_ASLCC_PATH = DEF(VS2017_BIN_IA32)\cl.exe
|
|
|
|
*_VS2017_IA32_ASLPP_PATH = DEF(VS2017_BIN_IA32)\cl.exe
|
|
|
|
*_VS2017_IA32_SLINK_PATH = DEF(VS2017_BIN_IA32)\lib.exe
|
|
|
|
*_VS2017_IA32_DLINK_PATH = DEF(VS2017_BIN_IA32)\link.exe
|
|
|
|
*_VS2017_IA32_ASLDLINK_PATH= DEF(VS2017_BIN_IA32)\link.exe
|
|
|
|
*_VS2017_IA32_APP_PATH = DEF(VS2017_BIN_IA32)\cl.exe
|
|
|
|
*_VS2017_IA32_PP_PATH = DEF(VS2017_BIN_IA32)\cl.exe
|
|
|
|
*_VS2017_IA32_ASM_PATH = DEF(VS2017_BIN_IA32)\ml.exe
|
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
DEBUG_VS2017_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Gw
|
|
|
|
RELEASE_VS2017_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw
|
|
|
|
NOOPT_VS2017_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od
|
2017-11-22 17:26:08 +01:00
|
|
|
|
|
|
|
DEBUG_VS2017_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
|
|
|
|
RELEASE_VS2017_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd
|
|
|
|
NOOPT_VS2017_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
|
|
|
|
|
|
|
|
DEBUG_VS2017_IA32_NASM_FLAGS = -Ox -f win32 -g
|
|
|
|
RELEASE_VS2017_IA32_NASM_FLAGS = -Ox -f win32
|
|
|
|
NOOPT_VS2017_IA32_NASM_FLAGS = -O0 -f win32 -g
|
|
|
|
|
|
|
|
DEBUG_VS2017_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2017_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2017_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
|
|
|
|
##################
|
|
|
|
# X64 definitions
|
|
|
|
##################
|
|
|
|
*_VS2017_X64_CC_PATH = DEF(VS2017_BIN_X64)\cl.exe
|
|
|
|
*_VS2017_X64_PP_PATH = DEF(VS2017_BIN_X64)\cl.exe
|
|
|
|
*_VS2017_X64_APP_PATH = DEF(VS2017_BIN_X64)\cl.exe
|
|
|
|
*_VS2017_X64_VFRPP_PATH = DEF(VS2017_BIN_X64)\cl.exe
|
|
|
|
*_VS2017_X64_ASLCC_PATH = DEF(VS2017_BIN_X64)\cl.exe
|
|
|
|
*_VS2017_X64_ASLPP_PATH = DEF(VS2017_BIN_X64)\cl.exe
|
|
|
|
*_VS2017_X64_ASM_PATH = DEF(VS2017_BIN_X64)\ml64.exe
|
|
|
|
*_VS2017_X64_SLINK_PATH = DEF(VS2017_BIN_X64)\lib.exe
|
|
|
|
*_VS2017_X64_DLINK_PATH = DEF(VS2017_BIN_X64)\link.exe
|
|
|
|
*_VS2017_X64_ASLDLINK_PATH = DEF(VS2017_BIN_X64)\link.exe
|
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
DEBUG_VS2017_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Gw
|
|
|
|
RELEASE_VS2017_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw
|
|
|
|
NOOPT_VS2017_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od
|
2017-11-22 17:26:08 +01:00
|
|
|
|
|
|
|
DEBUG_VS2017_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
|
|
|
|
RELEASE_VS2017_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd
|
|
|
|
NOOPT_VS2017_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
|
|
|
|
|
|
|
|
DEBUG_VS2017_X64_NASM_FLAGS = -Ox -f win64 -g
|
|
|
|
RELEASE_VS2017_X64_NASM_FLAGS = -Ox -f win64
|
|
|
|
NOOPT_VS2017_X64_NASM_FLAGS = -O0 -f win64 -g
|
|
|
|
|
2018-06-22 04:33:12 +02:00
|
|
|
DEBUG_VS2017_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4281 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2017_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4281 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2017_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4281 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
2017-11-22 17:26:08 +01:00
|
|
|
|
2018-01-12 14:33:31 +01:00
|
|
|
#################
|
|
|
|
# ARM definitions
|
|
|
|
#################
|
|
|
|
*_VS2017_ARM_CC_PATH = DEF(VS2017_BIN_ARM)\cl.exe
|
|
|
|
*_VS2017_ARM_VFRPP_PATH = DEF(VS2017_BIN_ARM)\cl.exe
|
|
|
|
*_VS2017_ARM_SLINK_PATH = DEF(VS2017_BIN_ARM)\lib.exe
|
|
|
|
*_VS2017_ARM_DLINK_PATH = DEF(VS2017_BIN_ARM)\link.exe
|
|
|
|
*_VS2017_ARM_APP_PATH = DEF(VS2017_BIN_ARM)\cl.exe
|
|
|
|
*_VS2017_ARM_PP_PATH = DEF(VS2017_BIN_ARM)\cl.exe
|
|
|
|
*_VS2017_ARM_ASM_PATH = DEF(VS2017_BIN_ARM)\armasm.exe
|
|
|
|
*_VS2017_ARM_ASLCC_PATH = DEF(VS2017_BIN_ARM)\cl.exe
|
|
|
|
*_VS2017_ARM_ASLPP_PATH = DEF(VS2017_BIN_ARM)\cl.exe
|
|
|
|
*_VS2017_ARM_ASLDLINK_PATH = DEF(VS2017_BIN_ARM)\link.exe
|
|
|
|
|
2019-11-22 19:48:21 +01:00
|
|
|
DEBUG_VS2017_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gw /Oi-
|
2018-01-12 14:33:31 +01:00
|
|
|
RELEASE_VS2017_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi-
|
2019-11-22 19:48:21 +01:00
|
|
|
NOOPT_VS2017_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Od /Oi-
|
2018-01-12 14:33:31 +01:00
|
|
|
|
|
|
|
DEBUG_VS2017_ARM_ASM_FLAGS = /nologo /g
|
|
|
|
RELEASE_VS2017_ARM_ASM_FLAGS = /nologo
|
|
|
|
NOOPT_VS2017_ARM_ASM_FLAGS = /nologo
|
|
|
|
|
|
|
|
DEBUG_VS2017_ARM_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2017_ARM_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2017_ARM_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
|
2018-02-23 10:50:03 +01:00
|
|
|
#####################
|
|
|
|
# AARCH64 definitions
|
|
|
|
#####################
|
|
|
|
*_VS2017_AARCH64_CC_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2017_AARCH64_VFRPP_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2017_AARCH64_SLINK_PATH = DEF(VS2017_BIN_AARCH64)\lib.exe
|
|
|
|
*_VS2017_AARCH64_DLINK_PATH = DEF(VS2017_BIN_AARCH64)\link.exe
|
|
|
|
*_VS2017_AARCH64_APP_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2017_AARCH64_PP_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2017_AARCH64_ASM_PATH = DEF(VS2017_BIN_AARCH64)\armasm64.exe
|
|
|
|
*_VS2017_AARCH64_ASLCC_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2017_AARCH64_ASLPP_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2017_AARCH64_ASLDLINK_PATH = DEF(VS2017_BIN_AARCH64)\link.exe
|
|
|
|
|
2019-11-22 19:48:21 +01:00
|
|
|
DEBUG_VS2017_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gw /Oi-
|
2018-02-23 10:50:03 +01:00
|
|
|
RELEASE_VS2017_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi-
|
2019-11-22 19:48:21 +01:00
|
|
|
NOOPT_VS2017_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Od /Oi-
|
2018-02-23 10:50:03 +01:00
|
|
|
|
|
|
|
DEBUG_VS2017_AARCH64_ASM_FLAGS = /nologo /g
|
|
|
|
RELEASE_VS2017_AARCH64_ASM_FLAGS = /nologo
|
|
|
|
NOOPT_VS2017_AARCH64_ASM_FLAGS = /nologo
|
|
|
|
|
|
|
|
DEBUG_VS2017_AARCH64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2017_AARCH64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2017_AARCH64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /DRIVER /DEBUG
|
|
|
|
|
2019-09-19 10:52:25 +02:00
|
|
|
####################################################################################
|
|
|
|
# VS2019 - Microsoft Visual Studio 2019 with Intel ASL
|
|
|
|
# ASL - Intel ACPI Source Language Compiler (iasl.exe)
|
|
|
|
####################################################################################
|
|
|
|
# VS2019 - Microsoft Visual Studio 2017 professional Edition with Intel ASL
|
|
|
|
*_VS2019_*_*_FAMILY = MSFT
|
|
|
|
*_VS2019_*_*_DLL = DEF(VS2019_BIN_HOST)
|
|
|
|
|
|
|
|
*_VS2019_*_MAKE_PATH = DEF(VS2019_BIN_HOST)\nmake.exe
|
2021-04-09 23:58:24 +02:00
|
|
|
*_VS2019_*_MAKE_FLAGS = /nologo
|
2019-10-08 04:54:21 +02:00
|
|
|
*_VS2019_*_RC_PATH = DEF(RC_PATH)
|
2019-09-19 10:52:25 +02:00
|
|
|
|
|
|
|
*_VS2019_*_SLINK_FLAGS = /NOLOGO /LTCG
|
|
|
|
*_VS2019_*_APP_FLAGS = /nologo /E /TC
|
|
|
|
*_VS2019_*_PP_FLAGS = /nologo /E /TC /FIAutoGen.h
|
|
|
|
*_VS2019_*_VFRPP_FLAGS = /nologo /E /TC /DVFRCOMPILE /FI$(MODULE_NAME)StrDefs.h
|
|
|
|
*_VS2019_*_DLINK2_FLAGS = /WHOLEARCHIVE
|
|
|
|
*_VS2019_*_ASM16_PATH = DEF(VS2019_BIN_IA32)\ml.exe
|
2019-12-02 09:24:19 +01:00
|
|
|
*_VS2019_*_DEPS_FLAGS = DEF(MSFT_DEPS_FLAGS)
|
2019-09-19 10:52:25 +02:00
|
|
|
##################
|
|
|
|
# ASL definitions
|
|
|
|
##################
|
|
|
|
*_VS2019_*_ASL_PATH = DEF(WIN_IASL_BIN)
|
|
|
|
*_VS2019_*_ASL_FLAGS = DEF(DEFAULT_WIN_ASL_FLAGS)
|
|
|
|
*_VS2019_*_ASL_OUTFLAGS = DEF(DEFAULT_WIN_ASL_OUTFLAGS)
|
|
|
|
*_VS2019_*_ASLCC_FLAGS = DEF(MSFT_ASLCC_FLAGS)
|
|
|
|
*_VS2019_*_ASLPP_FLAGS = DEF(MSFT_ASLPP_FLAGS)
|
|
|
|
*_VS2019_*_ASLDLINK_FLAGS = DEF(MSFT_ASLDLINK_FLAGS)
|
|
|
|
|
|
|
|
##################
|
|
|
|
# IA32 definitions
|
|
|
|
##################
|
|
|
|
*_VS2019_IA32_CC_PATH = DEF(VS2019_BIN_IA32)\cl.exe
|
|
|
|
*_VS2019_IA32_VFRPP_PATH = DEF(VS2019_BIN_IA32)\cl.exe
|
|
|
|
*_VS2019_IA32_ASLCC_PATH = DEF(VS2019_BIN_IA32)\cl.exe
|
|
|
|
*_VS2019_IA32_ASLPP_PATH = DEF(VS2019_BIN_IA32)\cl.exe
|
|
|
|
*_VS2019_IA32_SLINK_PATH = DEF(VS2019_BIN_IA32)\lib.exe
|
|
|
|
*_VS2019_IA32_DLINK_PATH = DEF(VS2019_BIN_IA32)\link.exe
|
|
|
|
*_VS2019_IA32_ASLDLINK_PATH= DEF(VS2019_BIN_IA32)\link.exe
|
|
|
|
*_VS2019_IA32_APP_PATH = DEF(VS2019_BIN_IA32)\cl.exe
|
|
|
|
*_VS2019_IA32_PP_PATH = DEF(VS2019_BIN_IA32)\cl.exe
|
|
|
|
*_VS2019_IA32_ASM_PATH = DEF(VS2019_BIN_IA32)\ml.exe
|
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
DEBUG_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Gw
|
|
|
|
RELEASE_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw
|
|
|
|
NOOPT_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od
|
2019-09-19 10:52:25 +02:00
|
|
|
|
|
|
|
DEBUG_VS2019_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
|
|
|
|
RELEASE_VS2019_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd
|
|
|
|
NOOPT_VS2019_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
|
|
|
|
|
|
|
|
DEBUG_VS2019_IA32_NASM_FLAGS = -Ox -f win32 -g
|
|
|
|
RELEASE_VS2019_IA32_NASM_FLAGS = -Ox -f win32
|
|
|
|
NOOPT_VS2019_IA32_NASM_FLAGS = -O0 -f win32 -g
|
|
|
|
|
|
|
|
DEBUG_VS2019_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2019_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2019_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
|
|
|
|
##################
|
|
|
|
# X64 definitions
|
|
|
|
##################
|
|
|
|
*_VS2019_X64_CC_PATH = DEF(VS2019_BIN_X64)\cl.exe
|
|
|
|
*_VS2019_X64_PP_PATH = DEF(VS2019_BIN_X64)\cl.exe
|
|
|
|
*_VS2019_X64_APP_PATH = DEF(VS2019_BIN_X64)\cl.exe
|
|
|
|
*_VS2019_X64_VFRPP_PATH = DEF(VS2019_BIN_X64)\cl.exe
|
|
|
|
*_VS2019_X64_ASLCC_PATH = DEF(VS2019_BIN_X64)\cl.exe
|
|
|
|
*_VS2019_X64_ASLPP_PATH = DEF(VS2019_BIN_X64)\cl.exe
|
|
|
|
*_VS2019_X64_ASM_PATH = DEF(VS2019_BIN_X64)\ml64.exe
|
|
|
|
*_VS2019_X64_SLINK_PATH = DEF(VS2019_BIN_X64)\lib.exe
|
|
|
|
*_VS2019_X64_DLINK_PATH = DEF(VS2019_BIN_X64)\link.exe
|
|
|
|
*_VS2019_X64_ASLDLINK_PATH = DEF(VS2019_BIN_X64)\link.exe
|
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
DEBUG_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Gw
|
|
|
|
RELEASE_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw
|
|
|
|
NOOPT_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od
|
2019-09-19 10:52:25 +02:00
|
|
|
|
|
|
|
DEBUG_VS2019_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
|
|
|
|
RELEASE_VS2019_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd
|
|
|
|
NOOPT_VS2019_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
|
|
|
|
|
|
|
|
DEBUG_VS2019_X64_NASM_FLAGS = -Ox -f win64 -g
|
|
|
|
RELEASE_VS2019_X64_NASM_FLAGS = -Ox -f win64
|
|
|
|
NOOPT_VS2019_X64_NASM_FLAGS = -O0 -f win64 -g
|
|
|
|
|
|
|
|
DEBUG_VS2019_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4281 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2019_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4281 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2019_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4281 /OPT:REF /OPT:ICF=10 /MAP /ALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
|
|
|
|
#################
|
|
|
|
# ARM definitions
|
|
|
|
#################
|
|
|
|
*_VS2019_ARM_CC_PATH = DEF(VS2019_BIN_ARM)\cl.exe
|
|
|
|
*_VS2019_ARM_VFRPP_PATH = DEF(VS2019_BIN_ARM)\cl.exe
|
|
|
|
*_VS2019_ARM_SLINK_PATH = DEF(VS2019_BIN_ARM)\lib.exe
|
|
|
|
*_VS2019_ARM_DLINK_PATH = DEF(VS2019_BIN_ARM)\link.exe
|
|
|
|
*_VS2019_ARM_APP_PATH = DEF(VS2019_BIN_ARM)\cl.exe
|
|
|
|
*_VS2019_ARM_PP_PATH = DEF(VS2019_BIN_ARM)\cl.exe
|
|
|
|
*_VS2019_ARM_ASM_PATH = DEF(VS2019_BIN_ARM)\armasm.exe
|
|
|
|
*_VS2019_ARM_ASLCC_PATH = DEF(VS2019_BIN_ARM)\cl.exe
|
|
|
|
*_VS2019_ARM_ASLPP_PATH = DEF(VS2019_BIN_ARM)\cl.exe
|
|
|
|
*_VS2019_ARM_ASLDLINK_PATH = DEF(VS2019_BIN_ARM)\link.exe
|
|
|
|
|
2019-11-22 19:48:21 +01:00
|
|
|
DEBUG_VS2019_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gw /Oi-
|
2019-09-19 10:52:25 +02:00
|
|
|
RELEASE_VS2019_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi-
|
2019-11-22 19:48:21 +01:00
|
|
|
NOOPT_VS2019_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Od /Oi-
|
2019-09-19 10:52:25 +02:00
|
|
|
|
|
|
|
DEBUG_VS2019_ARM_ASM_FLAGS = /nologo /g
|
|
|
|
RELEASE_VS2019_ARM_ASM_FLAGS = /nologo
|
|
|
|
NOOPT_VS2019_ARM_ASM_FLAGS = /nologo
|
|
|
|
|
|
|
|
DEBUG_VS2019_ARM_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2019_ARM_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2019_ARM_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DRIVER /DEBUG
|
|
|
|
|
|
|
|
#####################
|
|
|
|
# AARCH64 definitions
|
|
|
|
#####################
|
|
|
|
*_VS2019_AARCH64_CC_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2019_AARCH64_VFRPP_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2019_AARCH64_SLINK_PATH = DEF(VS2019_BIN_AARCH64)\lib.exe
|
|
|
|
*_VS2019_AARCH64_DLINK_PATH = DEF(VS2019_BIN_AARCH64)\link.exe
|
|
|
|
*_VS2019_AARCH64_APP_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2019_AARCH64_PP_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2019_AARCH64_ASM_PATH = DEF(VS2019_BIN_AARCH64)\armasm64.exe
|
|
|
|
*_VS2019_AARCH64_ASLCC_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2019_AARCH64_ASLPP_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
|
|
|
|
*_VS2019_AARCH64_ASLDLINK_PATH = DEF(VS2019_BIN_AARCH64)\link.exe
|
|
|
|
|
2019-11-22 19:48:21 +01:00
|
|
|
DEBUG_VS2019_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gw /Oi-
|
2019-09-19 10:52:25 +02:00
|
|
|
RELEASE_VS2019_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi-
|
2019-11-22 19:48:21 +01:00
|
|
|
NOOPT_VS2019_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Od /Oi-
|
2019-09-19 10:52:25 +02:00
|
|
|
|
|
|
|
DEBUG_VS2019_AARCH64_ASM_FLAGS = /nologo /g
|
|
|
|
RELEASE_VS2019_AARCH64_ASM_FLAGS = /nologo
|
|
|
|
NOOPT_VS2019_AARCH64_ASM_FLAGS = /nologo
|
|
|
|
|
|
|
|
DEBUG_VS2019_AARCH64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /DRIVER /DEBUG
|
|
|
|
RELEASE_VS2019_AARCH64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /DRIVER /MERGE:.rdata=.data
|
|
|
|
NOOPT_VS2019_AARCH64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /MAP /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:ARM64 /LTCG /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /DRIVER /DEBUG
|
|
|
|
|
2009-04-13 14:50:50 +02:00
|
|
|
####################################################################################
|
|
|
|
# GCC Common
|
|
|
|
####################################################################################
|
|
|
|
|
|
|
|
*_*_*_OBJCOPY_PATH = echo
|
|
|
|
*_*_*_OBJCOPY_FLAGS = objcopy not needed for
|
|
|
|
*_*_*_SYMRENAME_PATH = echo
|
|
|
|
*_*_*_SYMRENAME_FLAGS = Symbol renaming not needed for
|
2023-05-06 04:45:07 +02:00
|
|
|
DEBUG_*_*_OBJCOPY_ADDDEBUGFLAG = --add-gnu-debuglink="$(DEBUG_DIR)/$(MODULE_NAME).debug"
|
2011-10-29 08:59:30 +02:00
|
|
|
RELEASE_*_*_OBJCOPY_ADDDEBUGFLAG =
|
2023-05-06 04:45:07 +02:00
|
|
|
NOOPT_*_*_OBJCOPY_ADDDEBUGFLAG = --add-gnu-debuglink="$(DEBUG_DIR)/$(MODULE_NAME).debug"
|
2022-01-20 15:59:56 +01:00
|
|
|
*_*_*_OBJCOPY_STRIPFLAG = --strip-unneeded -R .eh_frame
|
2018-01-05 10:24:22 +01:00
|
|
|
*_*_*_DTC_FLAGS = -H epapr
|
2018-02-27 18:47:06 +01:00
|
|
|
*_*_*_DTCPP_PATH = DEF(DTCPP_BIN)
|
|
|
|
*_*_*_DTC_PATH = DEF(DTC_BIN)
|
2009-04-13 14:50:50 +02:00
|
|
|
|
2017-04-06 02:45:32 +02:00
|
|
|
DEFINE GCC_ALL_CC_FLAGS = -g -Os -fshort-wchar -fno-builtin -fno-strict-aliasing -Wall -Werror -Wno-array-bounds -include AutoGen.h -fno-common
|
2023-01-05 16:43:54 +01:00
|
|
|
DEFINE GCC_ARM_CC_FLAGS = DEF(GCC_ALL_CC_FLAGS) -mlittle-endian -mabi=aapcs -fno-short-enums -funsigned-char -ffunction-sections -fdata-sections -fomit-frame-pointer -Wno-address -mthumb -fno-pic -fno-pie
|
2022-09-06 13:25:29 +02:00
|
|
|
DEFINE GCC_LOONGARCH64_CC_FLAGS = DEF(GCC_ALL_CC_FLAGS) -mabi=lp64d -fno-asynchronous-unwind-tables -fno-plt -Wno-address -fno-short-enums -fsigned-char -ffunction-sections -fdata-sections
|
2016-08-08 12:33:06 +02:00
|
|
|
DEFINE GCC_ARM_CC_XIPFLAGS = -mno-unaligned-access
|
2020-07-23 02:41:29 +02:00
|
|
|
DEFINE GCC_AARCH64_CC_FLAGS = DEF(GCC_ALL_CC_FLAGS) -mlittle-endian -fno-short-enums -fverbose-asm -funsigned-char -ffunction-sections -fdata-sections -Wno-address -fno-asynchronous-unwind-tables -fno-unwind-tables -fno-pic -fno-pie -ffixed-x18
|
2017-07-13 14:44:27 +02:00
|
|
|
DEFINE GCC_AARCH64_CC_XIPFLAGS = -mstrict-align -mgeneral-regs-only
|
2010-03-01 00:39:39 +01:00
|
|
|
DEFINE GCC_DLINK_FLAGS_COMMON = -nostdlib --pie
|
2016-07-23 10:19:46 +02:00
|
|
|
DEFINE GCC_DLINK2_FLAGS_COMMON = -Wl,--script=$(EDK_TOOLS_PATH)/Scripts/GccBase.lds
|
2009-12-29 07:16:53 +01:00
|
|
|
DEFINE GCC_IA32_X64_DLINK_COMMON = DEF(GCC_DLINK_FLAGS_COMMON) --gc-sections
|
2016-07-23 10:19:46 +02:00
|
|
|
DEFINE GCC_ARM_AARCH64_DLINK_COMMON= -Wl,--emit-relocs -nostdlib -Wl,--gc-sections -u $(IMAGE_ENTRY_POINT) -Wl,-e,$(IMAGE_ENTRY_POINT),-Map,$(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
2022-09-06 13:25:29 +02:00
|
|
|
DEFINE GCC_LOONGARCH64_DLINK_COMMON= -Wl,--emit-relocs -nostdlib -Wl,--gc-sections -u $(IMAGE_ENTRY_POINT) -Wl,-e,$(IMAGE_ENTRY_POINT),-Map,$(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
2018-12-12 13:11:04 +01:00
|
|
|
DEFINE GCC_ARM_DLINK_FLAGS = DEF(GCC_ARM_AARCH64_DLINK_COMMON) -z common-page-size=0x20 -Wl,--pic-veneer
|
2015-08-03 10:23:05 +02:00
|
|
|
DEFINE GCC_AARCH64_DLINK_FLAGS = DEF(GCC_ARM_AARCH64_DLINK_COMMON) -z common-page-size=0x20
|
2022-09-06 13:25:29 +02:00
|
|
|
DEFINE GCC_LOONGARCH64_DLINK_FLAGS = DEF(GCC_LOONGARCH64_DLINK_COMMON) -z common-page-size=0x20
|
2017-11-21 17:02:14 +01:00
|
|
|
DEFINE GCC_ARM_AARCH64_ASLDLINK_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0 DEF(GCC_DLINK2_FLAGS_COMMON) -z common-page-size=0x20
|
2009-04-13 14:50:50 +02:00
|
|
|
DEFINE GCC_IA32_X64_ASLDLINK_FLAGS = DEF(GCC_IA32_X64_DLINK_COMMON) --entry _ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT)
|
2017-11-21 17:02:14 +01:00
|
|
|
DEFINE GCC_ARM_ASLDLINK_FLAGS = DEF(GCC_ARM_DLINK_FLAGS) -Wl,--entry,ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT) DEF(GCC_ARM_AARCH64_ASLDLINK_FLAGS)
|
|
|
|
DEFINE GCC_AARCH64_ASLDLINK_FLAGS = DEF(GCC_AARCH64_DLINK_FLAGS) -Wl,--entry,ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT) DEF(GCC_ARM_AARCH64_ASLDLINK_FLAGS)
|
2022-09-06 13:25:29 +02:00
|
|
|
DEFINE GCC_LOONGARCH64_ASLDLINK_FLAGS = DEF(GCC_LOONGARCH64_DLINK_FLAGS) -Wl,--entry,ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT)
|
2009-04-13 14:50:50 +02:00
|
|
|
DEFINE GCC_IA32_X64_DLINK_FLAGS = DEF(GCC_IA32_X64_DLINK_COMMON) --entry _$(IMAGE_ENTRY_POINT) --file-alignment 0x20 --section-alignment 0x20 -Map $(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
2019-10-17 08:55:45 +02:00
|
|
|
DEFINE GCC_ASM_FLAGS = -c -x assembler -imacros AutoGen.h
|
|
|
|
DEFINE GCC_PP_FLAGS = -E -x assembler-with-cpp -include AutoGen.h
|
|
|
|
DEFINE GCC_VFRPP_FLAGS = -x c -E -P -DVFRCOMPILE --include $(MODULE_NAME)StrDefs.h
|
2016-11-14 07:37:26 +01:00
|
|
|
DEFINE GCC_ASLPP_FLAGS = -x c -E -include AutoGen.h
|
2009-12-29 07:16:53 +01:00
|
|
|
DEFINE GCC_ASLCC_FLAGS = -x c
|
|
|
|
DEFINE GCC_WINDRES_FLAGS = -J rc -O coff
|
2019-10-17 08:55:45 +02:00
|
|
|
DEFINE GCC_DTCPP_FLAGS = -E -x assembler-with-cpp -imacros AutoGen.h -nostdinc -undef
|
2022-09-06 13:25:29 +02:00
|
|
|
DEFINE GCC_IA32_RC_FLAGS = -I binary -O elf32-i386 -B i386 --rename-section .data=.hii
|
|
|
|
DEFINE GCC_X64_RC_FLAGS = -I binary -O elf64-x86-64 -B i386 --rename-section .data=.hii
|
|
|
|
DEFINE GCC_ARM_RC_FLAGS = -I binary -O elf32-littlearm -B arm --rename-section .data=.hii
|
|
|
|
DEFINE GCC_AARCH64_RC_FLAGS = -I binary -O elf64-littleaarch64 -B aarch64 --rename-section .data=.hii
|
2023-03-26 10:58:35 +02:00
|
|
|
DEFINE GCC_AARCH64_RC_BTI_FLAGS = --add-section .note.gnu.property=$(WORKSPACE)/ArmPkg/Library/GnuNoteBti.bin --set-section-flags .note.gnu.property=alloc,readonly
|
2022-09-06 13:25:29 +02:00
|
|
|
DEFINE GCC_RISCV64_RC_FLAGS = -I binary -O elf64-littleriscv -B riscv --rename-section .data=.hii
|
|
|
|
DEFINE GCC_LOONGARCH64_RC_FLAGS = -I binary -O elf64-loongarch -B loongarch64 --rename-section .data=.hii
|
2009-12-29 07:16:53 +01:00
|
|
|
|
2019-12-02 09:24:19 +01:00
|
|
|
# GCC Build Flag for included header file list generation
|
|
|
|
DEFINE GCC_DEPS_FLAGS = -MMD -MF $@.deps
|
|
|
|
|
2020-07-07 10:35:22 +02:00
|
|
|
DEFINE GCC48_ALL_CC_FLAGS = DEF(GCC_ALL_CC_FLAGS) -ffunction-sections -fdata-sections -DSTRING_ARRAY_NAME=$(BASE_NAME)Strings
|
2019-01-03 01:51:22 +01:00
|
|
|
DEFINE GCC48_IA32_X64_DLINK_COMMON = -nostdlib -Wl,-n,-q,--gc-sections -z common-page-size=0x20
|
2022-11-30 10:44:14 +01:00
|
|
|
DEFINE GCC48_IA32_CC_FLAGS = DEF(GCC48_ALL_CC_FLAGS) -m32 -march=i586 -malign-double -fno-stack-protector -D EFI32 -fno-asynchronous-unwind-tables -Wno-address -fno-omit-frame-pointer
|
|
|
|
DEFINE GCC48_X64_CC_FLAGS = DEF(GCC48_ALL_CC_FLAGS) -m64 -fno-stack-protector "-DEFIAPI=__attribute__((ms_abi))" -maccumulate-outgoing-args -mno-red-zone -Wno-address -mcmodel=small -fpie -fno-asynchronous-unwind-tables -Wno-address -fno-omit-frame-pointer
|
2019-01-03 01:51:22 +01:00
|
|
|
DEFINE GCC48_IA32_X64_ASLDLINK_FLAGS = DEF(GCC48_IA32_X64_DLINK_COMMON) -Wl,--entry,ReferenceAcpiTable -u ReferenceAcpiTable
|
|
|
|
DEFINE GCC48_IA32_X64_DLINK_FLAGS = DEF(GCC48_IA32_X64_DLINK_COMMON) -Wl,--entry,$(IMAGE_ENTRY_POINT) -u $(IMAGE_ENTRY_POINT) -Wl,-Map,$(DEST_DIR_DEBUG)/$(BASE_NAME).map,--whole-archive
|
2019-01-03 01:23:40 +01:00
|
|
|
DEFINE GCC48_IA32_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x220 DEF(GCC_DLINK2_FLAGS_COMMON)
|
2019-01-03 01:40:47 +01:00
|
|
|
DEFINE GCC48_X64_DLINK_FLAGS = DEF(GCC48_IA32_X64_DLINK_FLAGS) -Wl,-melf_x86_64,--oformat=elf64-x86-64,-pie
|
2019-01-03 01:23:40 +01:00
|
|
|
DEFINE GCC48_X64_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x228 DEF(GCC_DLINK2_FLAGS_COMMON)
|
|
|
|
DEFINE GCC48_ASM_FLAGS = DEF(GCC_ASM_FLAGS)
|
2023-01-05 15:20:16 +01:00
|
|
|
DEFINE GCC48_ARM_ASM_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_ASM_FLAGS) -mlittle-endian
|
|
|
|
DEFINE GCC48_AARCH64_ASM_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_ASM_FLAGS) -mlittle-endian
|
|
|
|
DEFINE GCC48_ARM_CC_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_ARM_CC_FLAGS) -fstack-protector -mword-relocations
|
BaseTools/Conf/tools_def.template: drop ARM/AARCH support from GCC46/GCC47
This drops ARM and AARCH64 support from the GCC46 and GCC47 toolchain
definitions, which are on the list to be removed, along with VS2003,
VS2005, VS2008, VS2010, DDK3790, UNIXGCC, GCC44, GCC45, ELFGCC, CYGGCC,
ICC, ICC11 and MYTOOLS.
Since GCC46 and GCC47 are the only ones on that list that support ARM
and/or AARCH64, let's give Liming a hand and cover the ARM side of
things first, so that everything that remains to be removed is x86
only.
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org>
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Ref: https://bugzilla.tianocore.org/show_bug.cgi?id=1377
Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Cc: Leif Lindholm <leif.lindholm@linaro.org>
Cc: Liming Gao <liming.gao@intel.com>
[lersek@redhat.com: add bugzilla reference and CCs]
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
Reviewed-by: Jordan Justen <jordan.l.justen@intel.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
2018-12-08 10:32:42 +01:00
|
|
|
DEFINE GCC48_ARM_CC_XIPFLAGS = DEF(GCC_ARM_CC_XIPFLAGS)
|
2023-01-05 15:20:16 +01:00
|
|
|
DEFINE GCC48_AARCH64_CC_FLAGS = $(PLATFORM_FLAGS) -mcmodel=large DEF(GCC_AARCH64_CC_FLAGS)
|
BaseTools/Conf/tools_def.template: drop ARM/AARCH support from GCC46/GCC47
This drops ARM and AARCH64 support from the GCC46 and GCC47 toolchain
definitions, which are on the list to be removed, along with VS2003,
VS2005, VS2008, VS2010, DDK3790, UNIXGCC, GCC44, GCC45, ELFGCC, CYGGCC,
ICC, ICC11 and MYTOOLS.
Since GCC46 and GCC47 are the only ones on that list that support ARM
and/or AARCH64, let's give Liming a hand and cover the ARM side of
things first, so that everything that remains to be removed is x86
only.
Contributed-under: TianoCore Contribution Agreement 1.1
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org>
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Ref: https://bugzilla.tianocore.org/show_bug.cgi?id=1377
Cc: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Cc: Leif Lindholm <leif.lindholm@linaro.org>
Cc: Liming Gao <liming.gao@intel.com>
[lersek@redhat.com: add bugzilla reference and CCs]
Signed-off-by: Laszlo Ersek <lersek@redhat.com>
Reviewed-by: Jordan Justen <jordan.l.justen@intel.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com>
2018-12-08 10:32:42 +01:00
|
|
|
DEFINE GCC48_AARCH64_CC_XIPFLAGS = DEF(GCC_AARCH64_CC_XIPFLAGS)
|
|
|
|
DEFINE GCC48_ARM_DLINK_FLAGS = DEF(GCC_ARM_DLINK_FLAGS) -Wl,--oformat=elf32-littlearm
|
|
|
|
DEFINE GCC48_ARM_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x220
|
|
|
|
DEFINE GCC48_AARCH64_DLINK_FLAGS = DEF(GCC_AARCH64_DLINK_FLAGS)
|
|
|
|
DEFINE GCC48_AARCH64_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x228
|
|
|
|
DEFINE GCC48_ARM_ASLDLINK_FLAGS = DEF(GCC_ARM_ASLDLINK_FLAGS) -Wl,--oformat=elf32-littlearm
|
|
|
|
DEFINE GCC48_AARCH64_ASLDLINK_FLAGS = DEF(GCC_AARCH64_ASLDLINK_FLAGS)
|
2019-01-14 15:04:49 +01:00
|
|
|
DEFINE GCC48_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
2011-11-25 07:21:03 +01:00
|
|
|
|
2020-02-04 05:54:56 +01:00
|
|
|
DEFINE GCC49_IA32_CC_FLAGS = DEF(GCC48_IA32_CC_FLAGS) -fno-pic -fno-pie
|
2014-07-28 19:37:10 +02:00
|
|
|
DEFINE GCC49_X64_CC_FLAGS = DEF(GCC48_X64_CC_FLAGS)
|
2016-07-23 10:19:46 +02:00
|
|
|
DEFINE GCC49_IA32_X64_DLINK_COMMON = -nostdlib -Wl,-n,-q,--gc-sections -z common-page-size=0x40
|
2019-01-02 22:23:31 +01:00
|
|
|
DEFINE GCC49_IA32_X64_ASLDLINK_FLAGS = DEF(GCC49_IA32_X64_DLINK_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0 DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--entry,ReferenceAcpiTable -u ReferenceAcpiTable
|
2017-08-24 08:28:45 +02:00
|
|
|
DEFINE GCC49_IA32_X64_DLINK_FLAGS = DEF(GCC49_IA32_X64_DLINK_COMMON) -Wl,--entry,$(IMAGE_ENTRY_POINT) -u $(IMAGE_ENTRY_POINT) -Wl,-Map,$(DEST_DIR_DEBUG)/$(BASE_NAME).map,--whole-archive
|
2015-08-03 10:23:59 +02:00
|
|
|
DEFINE GCC49_IA32_DLINK2_FLAGS = DEF(GCC48_IA32_DLINK2_FLAGS)
|
2017-08-23 10:04:04 +02:00
|
|
|
DEFINE GCC49_X64_DLINK_FLAGS = DEF(GCC49_IA32_X64_DLINK_FLAGS) -Wl,-melf_x86_64,--oformat=elf64-x86-64,-pie
|
2015-08-03 10:23:59 +02:00
|
|
|
DEFINE GCC49_X64_DLINK2_FLAGS = DEF(GCC48_X64_DLINK2_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
DEFINE GCC49_ASM_FLAGS = DEF(GCC48_ASM_FLAGS)
|
|
|
|
DEFINE GCC49_ARM_ASM_FLAGS = DEF(GCC48_ARM_ASM_FLAGS)
|
|
|
|
DEFINE GCC49_AARCH64_ASM_FLAGS = DEF(GCC48_AARCH64_ASM_FLAGS)
|
|
|
|
DEFINE GCC49_ARM_CC_FLAGS = DEF(GCC48_ARM_CC_FLAGS)
|
2016-08-08 12:33:06 +02:00
|
|
|
DEFINE GCC49_ARM_CC_XIPFLAGS = DEF(GCC48_ARM_CC_XIPFLAGS)
|
2023-01-05 15:20:16 +01:00
|
|
|
DEFINE GCC49_AARCH64_CC_FLAGS = $(PLATFORM_FLAGS) DEF(GCC48_ALL_CC_FLAGS) DEF(GCC_AARCH64_CC_FLAGS) -mcmodel=small
|
2016-01-11 09:50:49 +01:00
|
|
|
DEFINE GCC49_AARCH64_CC_XIPFLAGS = DEF(GCC48_AARCH64_CC_XIPFLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
DEFINE GCC49_ARM_DLINK_FLAGS = DEF(GCC48_ARM_DLINK_FLAGS)
|
2015-10-01 16:01:07 +02:00
|
|
|
DEFINE GCC49_ARM_DLINK2_FLAGS = DEF(GCC48_ARM_DLINK2_FLAGS)
|
2018-12-10 15:13:39 +01:00
|
|
|
DEFINE GCC49_AARCH64_DLINK_FLAGS = DEF(GCC48_AARCH64_DLINK_FLAGS) -z common-page-size=0x1000
|
2015-08-03 10:23:05 +02:00
|
|
|
DEFINE GCC49_AARCH64_DLINK2_FLAGS = DEF(GCC48_AARCH64_DLINK2_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
DEFINE GCC49_ARM_ASLDLINK_FLAGS = DEF(GCC48_ARM_ASLDLINK_FLAGS)
|
2015-07-06 17:57:50 +02:00
|
|
|
DEFINE GCC49_AARCH64_ASLDLINK_FLAGS = DEF(GCC48_AARCH64_ASLDLINK_FLAGS)
|
2019-01-14 15:04:49 +01:00
|
|
|
DEFINE GCC49_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
|
2020-02-04 05:54:56 +01:00
|
|
|
DEFINE GCC5_IA32_CC_FLAGS = DEF(GCC49_IA32_CC_FLAGS)
|
2017-04-06 02:45:32 +02:00
|
|
|
DEFINE GCC5_X64_CC_FLAGS = DEF(GCC49_X64_CC_FLAGS)
|
2016-07-17 23:20:10 +02:00
|
|
|
DEFINE GCC5_IA32_X64_DLINK_COMMON = DEF(GCC49_IA32_X64_DLINK_COMMON)
|
|
|
|
DEFINE GCC5_IA32_X64_ASLDLINK_FLAGS = DEF(GCC49_IA32_X64_ASLDLINK_FLAGS)
|
2016-09-30 09:30:59 +02:00
|
|
|
DEFINE GCC5_IA32_X64_DLINK_FLAGS = DEF(GCC49_IA32_X64_DLINK_FLAGS)
|
2016-08-02 16:15:31 +02:00
|
|
|
DEFINE GCC5_IA32_DLINK2_FLAGS = DEF(GCC49_IA32_DLINK2_FLAGS) -Wno-error
|
2016-09-30 09:30:59 +02:00
|
|
|
DEFINE GCC5_X64_DLINK_FLAGS = DEF(GCC49_X64_DLINK_FLAGS)
|
2016-08-02 16:15:31 +02:00
|
|
|
DEFINE GCC5_X64_DLINK2_FLAGS = DEF(GCC49_X64_DLINK2_FLAGS) -Wno-error
|
2016-07-17 23:20:10 +02:00
|
|
|
DEFINE GCC5_ASM_FLAGS = DEF(GCC49_ASM_FLAGS)
|
|
|
|
DEFINE GCC5_ARM_ASM_FLAGS = DEF(GCC49_ARM_ASM_FLAGS)
|
|
|
|
DEFINE GCC5_AARCH64_ASM_FLAGS = DEF(GCC49_AARCH64_ASM_FLAGS)
|
|
|
|
DEFINE GCC5_ARM_CC_FLAGS = DEF(GCC49_ARM_CC_FLAGS)
|
2016-08-08 12:33:06 +02:00
|
|
|
DEFINE GCC5_ARM_CC_XIPFLAGS = DEF(GCC49_ARM_CC_XIPFLAGS)
|
2016-07-17 23:20:10 +02:00
|
|
|
DEFINE GCC5_AARCH64_CC_FLAGS = DEF(GCC49_AARCH64_CC_FLAGS)
|
|
|
|
DEFINE GCC5_AARCH64_CC_XIPFLAGS = DEF(GCC49_AARCH64_CC_XIPFLAGS)
|
2017-11-21 17:02:14 +01:00
|
|
|
DEFINE GCC5_ARM_DLINK_FLAGS = DEF(GCC49_ARM_DLINK_FLAGS)
|
2016-08-02 16:15:31 +02:00
|
|
|
DEFINE GCC5_ARM_DLINK2_FLAGS = DEF(GCC49_ARM_DLINK2_FLAGS) -Wno-error
|
2017-11-21 17:02:14 +01:00
|
|
|
DEFINE GCC5_AARCH64_DLINK_FLAGS = DEF(GCC49_AARCH64_DLINK_FLAGS)
|
2016-08-02 16:15:31 +02:00
|
|
|
DEFINE GCC5_AARCH64_DLINK2_FLAGS = DEF(GCC49_AARCH64_DLINK2_FLAGS) -Wno-error
|
2017-11-21 17:02:14 +01:00
|
|
|
DEFINE GCC5_ARM_ASLDLINK_FLAGS = DEF(GCC49_ARM_ASLDLINK_FLAGS)
|
|
|
|
DEFINE GCC5_AARCH64_ASLDLINK_FLAGS = DEF(GCC49_AARCH64_ASLDLINK_FLAGS)
|
2019-01-14 15:04:49 +01:00
|
|
|
DEFINE GCC5_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS) -fno-lto
|
2016-07-17 23:20:10 +02:00
|
|
|
|
2020-04-23 15:52:33 +02:00
|
|
|
DEFINE GCC5_RISCV_ALL_CC_FLAGS = -g -fshort-wchar -fno-strict-aliasing -Wall -Werror -Wno-array-bounds -ffunction-sections -fdata-sections -include AutoGen.h -fno-common -DSTRING_ARRAY_NAME=$(BASE_NAME)Strings -msmall-data-limit=0
|
|
|
|
DEFINE GCC5_RISCV_ALL_DLINK_COMMON = -nostdlib -Wl,-n,-q,--gc-sections -z common-page-size=0x40
|
|
|
|
DEFINE GCC5_RISCV_ALL_DLINK_FLAGS = DEF(GCC5_RISCV_ALL_DLINK_COMMON) -Wl,--entry,$(IMAGE_ENTRY_POINT) -u $(IMAGE_ENTRY_POINT) -Wl,-Map,$(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
|
|
|
DEFINE GCC5_RISCV_ALL_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x220,--script=$(EDK_TOOLS_PATH)/Scripts/GccBase.lds
|
|
|
|
DEFINE GCC5_RISCV_ALL_ASM_FLAGS = -c -x assembler -imacros $(DEST_DIR_DEBUG)/AutoGen.h
|
|
|
|
DEFINE GCC5_RISCV_ALL_CC_FLAGS_WARNING_DISABLE = -Wno-tautological-compare -Wno-pointer-compare
|
|
|
|
|
|
|
|
DEFINE GCC5_RISCV_OPENSBI_TYPES = -DOPENSBI_EXTERNAL_SBI_TYPES=OpensbiTypes.h
|
|
|
|
|
2023-02-22 03:37:10 +01:00
|
|
|
DEFINE GCC5_RISCV64_ARCH = rv64gc
|
2020-04-23 15:52:33 +02:00
|
|
|
DEFINE GCC5_RISCV32_RISCV64_ASLDLINK_FLAGS = DEF(GCC5_RISCV_ALL_DLINK_COMMON) -Wl,--entry,ReferenceAcpiTable -u ReferenceAcpiTable
|
|
|
|
DEFINE GCC5_RISCV64_CC_FLAGS = DEF(GCC5_RISCV_ALL_CC_FLAGS) DEF(GCC5_RISCV_ALL_CC_FLAGS_WARNING_DISABLE) DEF(GCC5_RISCV_OPENSBI_TYPES) -march=DEF(GCC5_RISCV64_ARCH) -fno-builtin -fno-builtin-memcpy -fno-stack-protector -Wno-address -fno-asynchronous-unwind-tables -Wno-unused-but-set-variable -fpack-struct=8 -mcmodel=medany -mabi=lp64 -mno-relax
|
|
|
|
DEFINE GCC5_RISCV64_DLINK_FLAGS = DEF(GCC5_RISCV_ALL_DLINK_FLAGS) -Wl,-melf64lriscv,--oformat=elf64-littleriscv,--no-relax
|
|
|
|
DEFINE GCC5_RISCV64_DLINK2_FLAGS = DEF(GCC5_RISCV_ALL_DLINK2_FLAGS)
|
|
|
|
DEFINE GCC5_RISCV64_ASM_FLAGS = DEF(GCC5_RISCV_ALL_ASM_FLAGS) -march=DEF(GCC5_RISCV64_ARCH) -mcmodel=medany -mabi=lp64
|
2022-09-06 13:25:29 +02:00
|
|
|
|
|
|
|
DEFINE GCC5_LOONGARCH64_CC_FLAGS = DEF(GCC_LOONGARCH64_CC_FLAGS) -march=loongarch64 -mno-memcpy -Werror -Wno-maybe-uninitialized -Wno-stringop-overflow -Wno-pointer-to-int-cast -no-pie -fno-stack-protector -mno-explicit-relocs
|
|
|
|
DEFINE GCC5_LOONGARCH64_DLINK_FLAGS = DEF(GCC_LOONGARCH64_DLINK_FLAGS)
|
|
|
|
DEFINE GCC5_LOONGARCH64_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x228
|
|
|
|
DEFINE GCC5_LOONGARCH64_ASLDLINK_FLAGS = DEF(GCC_LOONGARCH64_ASLDLINK_FLAGS) DEF(GCC5_LOONGARCH64_DLINK2_FLAGS)
|
|
|
|
DEFINE GCC5_LOONGARCH64_ASM_FLAGS = -x assembler-with-cpp -mabi=lp64d -march=loongarch64 -fno-builtin -c -Wall -mno-explicit-relocs
|
|
|
|
DEFINE GCC5_LOONGARCH64_PP_FLAGS = -mabi=lp64d -march=loongarch64 DEF(GCC_PP_FLAGS)
|
|
|
|
|
2014-01-10 06:25:50 +01:00
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# GCC 4.8 - This configuration is used to compile under Linux to produce
|
|
|
|
# PE/COFF binaries using GCC 4.8.
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
*_GCC48_*_*_FAMILY = GCC
|
|
|
|
|
2018-04-25 12:11:42 +02:00
|
|
|
*_GCC48_*_MAKE_PATH = DEF(GCC_HOST_PREFIX)make
|
2014-11-18 03:38:20 +01:00
|
|
|
*_GCC48_*_*_DLL = ENV(GCC48_DLL)
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_*_ASL_PATH = DEF(UNIX_IASL_BIN)
|
|
|
|
|
|
|
|
*_GCC48_*_PP_FLAGS = DEF(GCC_PP_FLAGS)
|
|
|
|
*_GCC48_*_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS)
|
|
|
|
*_GCC48_*_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_GCC48_*_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS)
|
|
|
|
*_GCC48_*_APP_FLAGS =
|
|
|
|
*_GCC48_*_ASL_FLAGS = DEF(IASL_FLAGS)
|
|
|
|
*_GCC48_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
2019-12-02 09:24:19 +01:00
|
|
|
*_GCC48_*_DEPS_FLAGS = DEF(GCC_DEPS_FLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC48 IA32 definitions
|
|
|
|
##################
|
|
|
|
*_GCC48_IA32_OBJCOPY_PATH = DEF(GCC48_IA32_PREFIX)objcopy
|
|
|
|
*_GCC48_IA32_CC_PATH = DEF(GCC48_IA32_PREFIX)gcc
|
|
|
|
*_GCC48_IA32_SLINK_PATH = DEF(GCC48_IA32_PREFIX)ar
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC48_IA32_DLINK_PATH = DEF(GCC48_IA32_PREFIX)gcc
|
|
|
|
*_GCC48_IA32_ASLDLINK_PATH = DEF(GCC48_IA32_PREFIX)gcc
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_IA32_ASM_PATH = DEF(GCC48_IA32_PREFIX)gcc
|
|
|
|
*_GCC48_IA32_PP_PATH = DEF(GCC48_IA32_PREFIX)gcc
|
|
|
|
*_GCC48_IA32_VFRPP_PATH = DEF(GCC48_IA32_PREFIX)gcc
|
|
|
|
*_GCC48_IA32_ASLCC_PATH = DEF(GCC48_IA32_PREFIX)gcc
|
|
|
|
*_GCC48_IA32_ASLPP_PATH = DEF(GCC48_IA32_PREFIX)gcc
|
|
|
|
*_GCC48_IA32_RC_PATH = DEF(GCC48_IA32_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC48_IA32_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS) -m32
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC48_IA32_ASLDLINK_FLAGS = DEF(GCC48_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_i386
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_IA32_ASM_FLAGS = DEF(GCC48_ASM_FLAGS) -m32 -march=i386
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC48_IA32_DLINK_FLAGS = DEF(GCC48_IA32_X64_DLINK_FLAGS) -Wl,-m,elf_i386,--oformat=elf32-i386
|
2015-08-03 10:22:16 +02:00
|
|
|
*_GCC48_IA32_DLINK2_FLAGS = DEF(GCC48_IA32_DLINK2_FLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_IA32_RC_FLAGS = DEF(GCC_IA32_RC_FLAGS)
|
2019-01-02 22:29:43 +01:00
|
|
|
*_GCC48_IA32_OBJCOPY_FLAGS =
|
2014-09-01 19:07:19 +02:00
|
|
|
*_GCC48_IA32_NASM_FLAGS = -f elf32
|
2014-01-10 06:25:50 +01:00
|
|
|
|
2023-01-25 10:20:59 +01:00
|
|
|
DEBUG_GCC48_IA32_CC_FLAGS = DEF(GCC48_IA32_CC_FLAGS)
|
|
|
|
RELEASE_GCC48_IA32_CC_FLAGS = DEF(GCC48_IA32_CC_FLAGS) -Wno-unused-but-set-variable
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC48_IA32_CC_FLAGS = DEF(GCC48_IA32_CC_FLAGS) -O0
|
2016-03-24 07:28:20 +01:00
|
|
|
|
2014-01-10 06:25:50 +01:00
|
|
|
##################
|
|
|
|
# GCC48 X64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC48_X64_OBJCOPY_PATH = DEF(GCC48_X64_PREFIX)objcopy
|
|
|
|
*_GCC48_X64_CC_PATH = DEF(GCC48_X64_PREFIX)gcc
|
|
|
|
*_GCC48_X64_SLINK_PATH = DEF(GCC48_X64_PREFIX)ar
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC48_X64_DLINK_PATH = DEF(GCC48_X64_PREFIX)gcc
|
|
|
|
*_GCC48_X64_ASLDLINK_PATH = DEF(GCC48_X64_PREFIX)gcc
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_X64_ASM_PATH = DEF(GCC48_X64_PREFIX)gcc
|
|
|
|
*_GCC48_X64_PP_PATH = DEF(GCC48_X64_PREFIX)gcc
|
|
|
|
*_GCC48_X64_VFRPP_PATH = DEF(GCC48_X64_PREFIX)gcc
|
|
|
|
*_GCC48_X64_ASLCC_PATH = DEF(GCC48_X64_PREFIX)gcc
|
|
|
|
*_GCC48_X64_ASLPP_PATH = DEF(GCC48_X64_PREFIX)gcc
|
|
|
|
*_GCC48_X64_RC_PATH = DEF(GCC48_X64_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC48_X64_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS) -m64
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC48_X64_ASLDLINK_FLAGS = DEF(GCC48_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_x86_64
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_X64_ASM_FLAGS = DEF(GCC48_ASM_FLAGS) -m64
|
|
|
|
*_GCC48_X64_DLINK_FLAGS = DEF(GCC48_X64_DLINK_FLAGS)
|
2015-08-03 10:22:16 +02:00
|
|
|
*_GCC48_X64_DLINK2_FLAGS = DEF(GCC48_X64_DLINK2_FLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_X64_RC_FLAGS = DEF(GCC_X64_RC_FLAGS)
|
2019-01-02 22:29:43 +01:00
|
|
|
*_GCC48_X64_OBJCOPY_FLAGS =
|
2014-09-01 19:07:19 +02:00
|
|
|
*_GCC48_X64_NASM_FLAGS = -f elf64
|
2014-01-10 06:25:50 +01:00
|
|
|
|
2023-01-25 10:20:59 +01:00
|
|
|
DEBUG_GCC48_X64_CC_FLAGS = DEF(GCC48_X64_CC_FLAGS)
|
|
|
|
RELEASE_GCC48_X64_CC_FLAGS = DEF(GCC48_X64_CC_FLAGS) -Wno-unused-but-set-variable
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC48_X64_CC_FLAGS = DEF(GCC48_X64_CC_FLAGS) -O0
|
2016-03-24 07:28:20 +01:00
|
|
|
|
2014-01-10 06:25:50 +01:00
|
|
|
##################
|
|
|
|
# GCC48 ARM definitions
|
|
|
|
##################
|
|
|
|
*_GCC48_ARM_CC_PATH = ENV(GCC48_ARM_PREFIX)gcc
|
|
|
|
*_GCC48_ARM_SLINK_PATH = ENV(GCC48_ARM_PREFIX)ar
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC48_ARM_DLINK_PATH = ENV(GCC48_ARM_PREFIX)gcc
|
|
|
|
*_GCC48_ARM_ASLDLINK_PATH = ENV(GCC48_ARM_PREFIX)gcc
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_ARM_ASM_PATH = ENV(GCC48_ARM_PREFIX)gcc
|
|
|
|
*_GCC48_ARM_PP_PATH = ENV(GCC48_ARM_PREFIX)gcc
|
|
|
|
*_GCC48_ARM_VFRPP_PATH = ENV(GCC48_ARM_PREFIX)gcc
|
|
|
|
*_GCC48_ARM_ASLCC_PATH = ENV(GCC48_ARM_PREFIX)gcc
|
|
|
|
*_GCC48_ARM_ASLPP_PATH = ENV(GCC48_ARM_PREFIX)gcc
|
|
|
|
*_GCC48_ARM_RC_PATH = ENV(GCC48_ARM_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC48_ARM_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_ARM_ASLDLINK_FLAGS = DEF(GCC48_ARM_ASLDLINK_FLAGS)
|
|
|
|
*_GCC48_ARM_ASM_FLAGS = DEF(GCC48_ARM_ASM_FLAGS)
|
|
|
|
*_GCC48_ARM_DLINK_FLAGS = DEF(GCC48_ARM_DLINK_FLAGS)
|
2015-10-01 16:01:07 +02:00
|
|
|
*_GCC48_ARM_DLINK2_FLAGS = DEF(GCC48_ARM_DLINK2_FLAGS)
|
2017-08-29 15:21:02 +02:00
|
|
|
*_GCC48_ARM_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_ARM_PLATFORM_FLAGS = -march=armv7-a
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC48_ARM_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_ARM_RC_FLAGS = DEF(GCC_ARM_RC_FLAGS)
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC48_ARM_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
2016-08-08 12:33:06 +02:00
|
|
|
*_GCC48_ARM_CC_XIPFLAGS = DEF(GCC48_ARM_CC_XIPFLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
|
|
|
|
DEBUG_GCC48_ARM_CC_FLAGS = DEF(GCC48_ARM_CC_FLAGS) -O0
|
|
|
|
RELEASE_GCC48_ARM_CC_FLAGS = DEF(GCC48_ARM_CC_FLAGS) -Wno-unused-but-set-variable
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC48_ARM_CC_FLAGS = DEF(GCC48_ARM_CC_FLAGS) -O0
|
2014-01-10 06:25:50 +01:00
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC48 AARCH64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC48_AARCH64_CC_PATH = ENV(GCC48_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC48_AARCH64_SLINK_PATH = ENV(GCC48_AARCH64_PREFIX)ar
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC48_AARCH64_DLINK_PATH = ENV(GCC48_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC48_AARCH64_ASLDLINK_PATH = ENV(GCC48_AARCH64_PREFIX)gcc
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_AARCH64_ASM_PATH = ENV(GCC48_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC48_AARCH64_PP_PATH = ENV(GCC48_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC48_AARCH64_VFRPP_PATH = ENV(GCC48_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC48_AARCH64_ASLCC_PATH = ENV(GCC48_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC48_AARCH64_ASLPP_PATH = ENV(GCC48_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC48_AARCH64_RC_PATH = ENV(GCC48_AARCH64_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC48_AARCH64_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_AARCH64_ASLDLINK_FLAGS = DEF(GCC48_AARCH64_ASLDLINK_FLAGS)
|
|
|
|
*_GCC48_AARCH64_ASM_FLAGS = DEF(GCC48_AARCH64_ASM_FLAGS)
|
|
|
|
*_GCC48_AARCH64_DLINK_FLAGS = DEF(GCC48_AARCH64_DLINK_FLAGS)
|
2015-08-03 10:23:05 +02:00
|
|
|
*_GCC48_AARCH64_DLINK2_FLAGS = DEF(GCC48_AARCH64_DLINK2_FLAGS)
|
2017-08-29 15:21:02 +02:00
|
|
|
*_GCC48_AARCH64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_AARCH64_PLATFORM_FLAGS =
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC48_AARCH64_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
*_GCC48_AARCH64_RC_FLAGS = DEF(GCC_AARCH64_RC_FLAGS)
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC48_AARCH64_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
2016-01-11 09:50:49 +01:00
|
|
|
*_GCC48_AARCH64_CC_XIPFLAGS = DEF(GCC48_AARCH64_CC_XIPFLAGS)
|
2014-01-10 06:25:50 +01:00
|
|
|
|
|
|
|
DEBUG_GCC48_AARCH64_CC_FLAGS = DEF(GCC48_AARCH64_CC_FLAGS) -O0
|
2017-09-16 01:06:02 +02:00
|
|
|
RELEASE_GCC48_AARCH64_CC_FLAGS = DEF(GCC48_AARCH64_CC_FLAGS) -Wno-unused-but-set-variable
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC48_AARCH64_CC_FLAGS = DEF(GCC48_AARCH64_CC_FLAGS) -O0
|
2014-01-10 06:25:50 +01:00
|
|
|
|
2014-07-28 19:37:10 +02:00
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# GCC 4.9 - This configuration is used to compile under Linux to produce
|
|
|
|
# PE/COFF binaries using GCC 4.9.
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
*_GCC49_*_*_FAMILY = GCC
|
|
|
|
|
2018-04-25 12:11:42 +02:00
|
|
|
*_GCC49_*_MAKE_PATH = DEF(GCC_HOST_PREFIX)make
|
2014-11-18 03:38:20 +01:00
|
|
|
*_GCC49_*_*_DLL = ENV(GCC49_DLL)
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_*_ASL_PATH = DEF(UNIX_IASL_BIN)
|
|
|
|
|
|
|
|
*_GCC49_*_PP_FLAGS = DEF(GCC_PP_FLAGS)
|
|
|
|
*_GCC49_*_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS)
|
|
|
|
*_GCC49_*_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_GCC49_*_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS)
|
|
|
|
*_GCC49_*_APP_FLAGS =
|
|
|
|
*_GCC49_*_ASL_FLAGS = DEF(IASL_FLAGS)
|
|
|
|
*_GCC49_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
2019-12-02 09:24:19 +01:00
|
|
|
*_GCC49_*_DEPS_FLAGS = DEF(GCC_DEPS_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC49 IA32 definitions
|
|
|
|
##################
|
|
|
|
*_GCC49_IA32_OBJCOPY_PATH = DEF(GCC49_IA32_PREFIX)objcopy
|
|
|
|
*_GCC49_IA32_CC_PATH = DEF(GCC49_IA32_PREFIX)gcc
|
|
|
|
*_GCC49_IA32_SLINK_PATH = DEF(GCC49_IA32_PREFIX)ar
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC49_IA32_DLINK_PATH = DEF(GCC49_IA32_PREFIX)gcc
|
|
|
|
*_GCC49_IA32_ASLDLINK_PATH = DEF(GCC49_IA32_PREFIX)gcc
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_IA32_ASM_PATH = DEF(GCC49_IA32_PREFIX)gcc
|
|
|
|
*_GCC49_IA32_PP_PATH = DEF(GCC49_IA32_PREFIX)gcc
|
|
|
|
*_GCC49_IA32_VFRPP_PATH = DEF(GCC49_IA32_PREFIX)gcc
|
|
|
|
*_GCC49_IA32_ASLCC_PATH = DEF(GCC49_IA32_PREFIX)gcc
|
|
|
|
*_GCC49_IA32_ASLPP_PATH = DEF(GCC49_IA32_PREFIX)gcc
|
|
|
|
*_GCC49_IA32_RC_PATH = DEF(GCC49_IA32_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC49_IA32_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS) -m32
|
2018-06-18 10:23:49 +02:00
|
|
|
*_GCC49_IA32_ASLDLINK_FLAGS = DEF(GCC49_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_i386
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_IA32_ASM_FLAGS = DEF(GCC49_ASM_FLAGS) -m32 -march=i386
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC49_IA32_DLINK_FLAGS = DEF(GCC49_IA32_X64_DLINK_FLAGS) -Wl,-m,elf_i386,--oformat=elf32-i386
|
2018-06-18 10:23:49 +02:00
|
|
|
*_GCC49_IA32_DLINK2_FLAGS = DEF(GCC49_IA32_DLINK2_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_IA32_RC_FLAGS = DEF(GCC_IA32_RC_FLAGS)
|
2019-01-02 22:29:43 +01:00
|
|
|
*_GCC49_IA32_OBJCOPY_FLAGS =
|
2014-09-01 19:07:19 +02:00
|
|
|
*_GCC49_IA32_NASM_FLAGS = -f elf32
|
2014-07-28 19:37:10 +02:00
|
|
|
|
2023-01-25 10:20:59 +01:00
|
|
|
DEBUG_GCC49_IA32_CC_FLAGS = DEF(GCC49_IA32_CC_FLAGS)
|
|
|
|
RELEASE_GCC49_IA32_CC_FLAGS = DEF(GCC49_IA32_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-const-variable
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC49_IA32_CC_FLAGS = DEF(GCC49_IA32_CC_FLAGS) -O0
|
2016-03-24 07:28:20 +01:00
|
|
|
|
2014-07-28 19:37:10 +02:00
|
|
|
##################
|
|
|
|
# GCC49 X64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC49_X64_OBJCOPY_PATH = DEF(GCC49_X64_PREFIX)objcopy
|
|
|
|
*_GCC49_X64_CC_PATH = DEF(GCC49_X64_PREFIX)gcc
|
|
|
|
*_GCC49_X64_SLINK_PATH = DEF(GCC49_X64_PREFIX)ar
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC49_X64_DLINK_PATH = DEF(GCC49_X64_PREFIX)gcc
|
|
|
|
*_GCC49_X64_ASLDLINK_PATH = DEF(GCC49_X64_PREFIX)gcc
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_X64_ASM_PATH = DEF(GCC49_X64_PREFIX)gcc
|
|
|
|
*_GCC49_X64_PP_PATH = DEF(GCC49_X64_PREFIX)gcc
|
|
|
|
*_GCC49_X64_VFRPP_PATH = DEF(GCC49_X64_PREFIX)gcc
|
|
|
|
*_GCC49_X64_ASLCC_PATH = DEF(GCC49_X64_PREFIX)gcc
|
|
|
|
*_GCC49_X64_ASLPP_PATH = DEF(GCC49_X64_PREFIX)gcc
|
|
|
|
*_GCC49_X64_RC_PATH = DEF(GCC49_X64_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC49_X64_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS) -m64
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC49_X64_ASLDLINK_FLAGS = DEF(GCC49_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_x86_64
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_X64_ASM_FLAGS = DEF(GCC49_ASM_FLAGS) -m64
|
|
|
|
*_GCC49_X64_DLINK_FLAGS = DEF(GCC49_X64_DLINK_FLAGS)
|
2015-08-03 10:22:16 +02:00
|
|
|
*_GCC49_X64_DLINK2_FLAGS = DEF(GCC49_X64_DLINK2_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_X64_RC_FLAGS = DEF(GCC_X64_RC_FLAGS)
|
2019-01-02 22:29:43 +01:00
|
|
|
*_GCC49_X64_OBJCOPY_FLAGS =
|
2014-09-01 19:07:19 +02:00
|
|
|
*_GCC49_X64_NASM_FLAGS = -f elf64
|
2014-07-28 19:37:10 +02:00
|
|
|
|
2023-01-25 10:20:59 +01:00
|
|
|
DEBUG_GCC49_X64_CC_FLAGS = DEF(GCC49_X64_CC_FLAGS)
|
|
|
|
RELEASE_GCC49_X64_CC_FLAGS = DEF(GCC49_X64_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-const-variable
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC49_X64_CC_FLAGS = DEF(GCC49_X64_CC_FLAGS) -O0
|
2016-03-24 07:28:20 +01:00
|
|
|
|
2014-07-28 19:37:10 +02:00
|
|
|
##################
|
|
|
|
# GCC49 ARM definitions
|
|
|
|
##################
|
|
|
|
*_GCC49_ARM_CC_PATH = ENV(GCC49_ARM_PREFIX)gcc
|
|
|
|
*_GCC49_ARM_SLINK_PATH = ENV(GCC49_ARM_PREFIX)ar
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC49_ARM_DLINK_PATH = ENV(GCC49_ARM_PREFIX)gcc
|
|
|
|
*_GCC49_ARM_ASLDLINK_PATH = ENV(GCC49_ARM_PREFIX)gcc
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_ARM_ASM_PATH = ENV(GCC49_ARM_PREFIX)gcc
|
|
|
|
*_GCC49_ARM_PP_PATH = ENV(GCC49_ARM_PREFIX)gcc
|
|
|
|
*_GCC49_ARM_VFRPP_PATH = ENV(GCC49_ARM_PREFIX)gcc
|
|
|
|
*_GCC49_ARM_ASLCC_PATH = ENV(GCC49_ARM_PREFIX)gcc
|
|
|
|
*_GCC49_ARM_ASLPP_PATH = ENV(GCC49_ARM_PREFIX)gcc
|
|
|
|
*_GCC49_ARM_RC_PATH = ENV(GCC49_ARM_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC49_ARM_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_ARM_ASLDLINK_FLAGS = DEF(GCC49_ARM_ASLDLINK_FLAGS)
|
|
|
|
*_GCC49_ARM_ASM_FLAGS = DEF(GCC49_ARM_ASM_FLAGS)
|
|
|
|
*_GCC49_ARM_DLINK_FLAGS = DEF(GCC49_ARM_DLINK_FLAGS)
|
2015-10-01 16:01:07 +02:00
|
|
|
*_GCC49_ARM_DLINK2_FLAGS = DEF(GCC49_ARM_DLINK2_FLAGS)
|
2017-08-29 15:21:02 +02:00
|
|
|
*_GCC49_ARM_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_ARM_PLATFORM_FLAGS = -march=armv7-a
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC49_ARM_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_ARM_RC_FLAGS = DEF(GCC_ARM_RC_FLAGS)
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC49_ARM_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
2016-08-08 12:33:06 +02:00
|
|
|
*_GCC49_ARM_CC_XIPFLAGS = DEF(GCC49_ARM_CC_XIPFLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
|
|
|
|
DEBUG_GCC49_ARM_CC_FLAGS = DEF(GCC49_ARM_CC_FLAGS) -O0
|
2017-09-08 09:01:31 +02:00
|
|
|
RELEASE_GCC49_ARM_CC_FLAGS = DEF(GCC49_ARM_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-const-variable
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC49_ARM_CC_FLAGS = DEF(GCC49_ARM_CC_FLAGS) -O0
|
2014-07-28 19:37:10 +02:00
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC49 AARCH64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC49_AARCH64_CC_PATH = ENV(GCC49_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC49_AARCH64_SLINK_PATH = ENV(GCC49_AARCH64_PREFIX)ar
|
2016-07-23 10:19:46 +02:00
|
|
|
*_GCC49_AARCH64_DLINK_PATH = ENV(GCC49_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC49_AARCH64_ASLDLINK_PATH = ENV(GCC49_AARCH64_PREFIX)gcc
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_AARCH64_ASM_PATH = ENV(GCC49_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC49_AARCH64_PP_PATH = ENV(GCC49_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC49_AARCH64_VFRPP_PATH = ENV(GCC49_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC49_AARCH64_ASLCC_PATH = ENV(GCC49_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC49_AARCH64_ASLPP_PATH = ENV(GCC49_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC49_AARCH64_RC_PATH = ENV(GCC49_AARCH64_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC49_AARCH64_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_AARCH64_ASLDLINK_FLAGS = DEF(GCC49_AARCH64_ASLDLINK_FLAGS)
|
|
|
|
*_GCC49_AARCH64_ASM_FLAGS = DEF(GCC49_AARCH64_ASM_FLAGS)
|
2015-08-03 10:23:05 +02:00
|
|
|
*_GCC49_AARCH64_DLINK2_FLAGS = DEF(GCC49_AARCH64_DLINK2_FLAGS)
|
2017-08-29 15:21:02 +02:00
|
|
|
*_GCC49_AARCH64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_AARCH64_PLATFORM_FLAGS =
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC49_AARCH64_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
*_GCC49_AARCH64_RC_FLAGS = DEF(GCC_AARCH64_RC_FLAGS)
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC49_AARCH64_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
2016-01-11 09:50:49 +01:00
|
|
|
*_GCC49_AARCH64_CC_XIPFLAGS = DEF(GCC49_AARCH64_CC_XIPFLAGS)
|
2014-07-28 19:37:10 +02:00
|
|
|
|
2018-12-10 15:13:39 +01:00
|
|
|
DEBUG_GCC49_AARCH64_CC_FLAGS = DEF(GCC49_AARCH64_CC_FLAGS) -O0
|
|
|
|
DEBUG_GCC49_AARCH64_DLINK_FLAGS = DEF(GCC49_AARCH64_DLINK_FLAGS)
|
2016-07-27 12:08:20 +02:00
|
|
|
DEBUG_GCC49_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
|
2016-03-25 12:33:28 +01:00
|
|
|
|
2018-12-10 15:13:39 +01:00
|
|
|
RELEASE_GCC49_AARCH64_CC_FLAGS = DEF(GCC49_AARCH64_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-const-variable
|
2016-03-25 12:33:28 +01:00
|
|
|
RELEASE_GCC49_AARCH64_DLINK_FLAGS = DEF(GCC49_AARCH64_DLINK_FLAGS)
|
2018-12-10 15:13:39 +01:00
|
|
|
RELEASE_GCC49_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
|
2014-07-28 19:37:10 +02:00
|
|
|
|
2018-12-10 15:13:39 +01:00
|
|
|
NOOPT_GCC49_AARCH64_CC_FLAGS = DEF(GCC49_AARCH64_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCC49_AARCH64_DLINK_FLAGS = DEF(GCC49_AARCH64_DLINK_FLAGS) -O0
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC49_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20 -O0
|
|
|
|
|
2023-04-12 20:35:11 +02:00
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# GCC NOLTO - This configuration is used to compile under Linux to produce
|
|
|
|
# PE/COFF binaries using GCC without Link Time Optimization
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
*_GCCNOLTO_*_*_FAMILY = GCC
|
|
|
|
|
|
|
|
*_GCCNOLTO_*_MAKE_PATH = DEF(GCC_HOST_PREFIX)make
|
|
|
|
*_GCCNOLTO_*_*_DLL = ENV(GCCNOLTO_DLL)
|
|
|
|
*_GCCNOLTO_*_ASL_PATH = DEF(UNIX_IASL_BIN)
|
|
|
|
|
|
|
|
*_GCCNOLTO_*_PP_FLAGS = DEF(GCC_PP_FLAGS)
|
|
|
|
*_GCCNOLTO_*_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS)
|
|
|
|
*_GCCNOLTO_*_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_GCCNOLTO_*_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS)
|
|
|
|
*_GCCNOLTO_*_APP_FLAGS =
|
|
|
|
*_GCCNOLTO_*_ASL_FLAGS = DEF(IASL_FLAGS)
|
|
|
|
*_GCCNOLTO_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
|
|
|
*_GCCNOLTO_*_DEPS_FLAGS = DEF(GCC_DEPS_FLAGS)
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCCNOLTO IA32 definitions
|
|
|
|
##################
|
|
|
|
*_GCCNOLTO_IA32_OBJCOPY_PATH = DEF(GCCNOLTO_IA32_PREFIX)objcopy
|
|
|
|
*_GCCNOLTO_IA32_CC_PATH = DEF(GCCNOLTO_IA32_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_IA32_SLINK_PATH = DEF(GCCNOLTO_IA32_PREFIX)ar
|
|
|
|
*_GCCNOLTO_IA32_DLINK_PATH = DEF(GCCNOLTO_IA32_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_IA32_ASLDLINK_PATH = DEF(GCCNOLTO_IA32_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_IA32_ASM_PATH = DEF(GCCNOLTO_IA32_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_IA32_PP_PATH = DEF(GCCNOLTO_IA32_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_IA32_VFRPP_PATH = DEF(GCCNOLTO_IA32_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_IA32_ASLCC_PATH = DEF(GCCNOLTO_IA32_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_IA32_ASLPP_PATH = DEF(GCCNOLTO_IA32_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_IA32_RC_PATH = DEF(GCCNOLTO_IA32_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCCNOLTO_IA32_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS) -m32
|
|
|
|
*_GCCNOLTO_IA32_ASLDLINK_FLAGS = DEF(GCC49_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_i386
|
|
|
|
*_GCCNOLTO_IA32_ASM_FLAGS = DEF(GCC49_ASM_FLAGS) -m32 -march=i386
|
|
|
|
*_GCCNOLTO_IA32_DLINK_FLAGS = DEF(GCC49_IA32_X64_DLINK_FLAGS) -Wl,-m,elf_i386,--oformat=elf32-i386
|
|
|
|
*_GCCNOLTO_IA32_DLINK2_FLAGS = DEF(GCC49_IA32_DLINK2_FLAGS)
|
|
|
|
*_GCCNOLTO_IA32_RC_FLAGS = DEF(GCC_IA32_RC_FLAGS)
|
|
|
|
*_GCCNOLTO_IA32_OBJCOPY_FLAGS =
|
|
|
|
*_GCCNOLTO_IA32_NASM_FLAGS = -f elf32
|
|
|
|
|
|
|
|
DEBUG_GCCNOLTO_IA32_CC_FLAGS = DEF(GCC49_IA32_CC_FLAGS)
|
|
|
|
RELEASE_GCCNOLTO_IA32_CC_FLAGS = DEF(GCC49_IA32_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
NOOPT_GCCNOLTO_IA32_CC_FLAGS = DEF(GCC49_IA32_CC_FLAGS) -O0
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCCNOLTO X64 definitions
|
|
|
|
##################
|
|
|
|
*_GCCNOLTO_X64_OBJCOPY_PATH = DEF(GCCNOLTO_X64_PREFIX)objcopy
|
|
|
|
*_GCCNOLTO_X64_CC_PATH = DEF(GCCNOLTO_X64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_X64_SLINK_PATH = DEF(GCCNOLTO_X64_PREFIX)ar
|
|
|
|
*_GCCNOLTO_X64_DLINK_PATH = DEF(GCCNOLTO_X64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_X64_ASLDLINK_PATH = DEF(GCCNOLTO_X64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_X64_ASM_PATH = DEF(GCCNOLTO_X64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_X64_PP_PATH = DEF(GCCNOLTO_X64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_X64_VFRPP_PATH = DEF(GCCNOLTO_X64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_X64_ASLCC_PATH = DEF(GCCNOLTO_X64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_X64_ASLPP_PATH = DEF(GCCNOLTO_X64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_X64_RC_PATH = DEF(GCCNOLTO_X64_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCCNOLTO_X64_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS) -m64
|
|
|
|
*_GCCNOLTO_X64_ASLDLINK_FLAGS = DEF(GCC49_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_x86_64
|
|
|
|
*_GCCNOLTO_X64_ASM_FLAGS = DEF(GCC49_ASM_FLAGS) -m64
|
|
|
|
*_GCCNOLTO_X64_DLINK_FLAGS = DEF(GCC49_X64_DLINK_FLAGS)
|
|
|
|
*_GCCNOLTO_X64_DLINK2_FLAGS = DEF(GCC49_X64_DLINK2_FLAGS)
|
|
|
|
*_GCCNOLTO_X64_RC_FLAGS = DEF(GCC_X64_RC_FLAGS)
|
|
|
|
*_GCCNOLTO_X64_OBJCOPY_FLAGS =
|
|
|
|
*_GCCNOLTO_X64_NASM_FLAGS = -f elf64
|
|
|
|
|
|
|
|
DEBUG_GCCNOLTO_X64_CC_FLAGS = DEF(GCC49_X64_CC_FLAGS)
|
|
|
|
RELEASE_GCCNOLTO_X64_CC_FLAGS = DEF(GCC49_X64_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
NOOPT_GCCNOLTO_X64_CC_FLAGS = DEF(GCC49_X64_CC_FLAGS) -O0
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCCNOLTO ARM definitions
|
|
|
|
##################
|
|
|
|
*_GCCNOLTO_ARM_CC_PATH = ENV(GCCNOLTO_ARM_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_ARM_SLINK_PATH = ENV(GCCNOLTO_ARM_PREFIX)ar
|
|
|
|
*_GCCNOLTO_ARM_DLINK_PATH = ENV(GCCNOLTO_ARM_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_ARM_ASLDLINK_PATH = ENV(GCCNOLTO_ARM_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_ARM_ASM_PATH = ENV(GCCNOLTO_ARM_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_ARM_PP_PATH = ENV(GCCNOLTO_ARM_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_ARM_VFRPP_PATH = ENV(GCCNOLTO_ARM_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_ARM_ASLCC_PATH = ENV(GCCNOLTO_ARM_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_ARM_ASLPP_PATH = ENV(GCCNOLTO_ARM_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_ARM_RC_PATH = ENV(GCCNOLTO_ARM_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCCNOLTO_ARM_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS)
|
|
|
|
*_GCCNOLTO_ARM_ASLDLINK_FLAGS = DEF(GCC49_ARM_ASLDLINK_FLAGS)
|
|
|
|
*_GCCNOLTO_ARM_ASM_FLAGS = DEF(GCC49_ARM_ASM_FLAGS)
|
|
|
|
*_GCCNOLTO_ARM_DLINK_FLAGS = DEF(GCC49_ARM_DLINK_FLAGS)
|
|
|
|
*_GCCNOLTO_ARM_DLINK2_FLAGS = DEF(GCC49_ARM_DLINK2_FLAGS)
|
|
|
|
*_GCCNOLTO_ARM_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
|
|
|
*_GCCNOLTO_ARM_PLATFORM_FLAGS = -march=armv7-a
|
|
|
|
*_GCCNOLTO_ARM_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
|
|
|
*_GCCNOLTO_ARM_RC_FLAGS = DEF(GCC_ARM_RC_FLAGS)
|
|
|
|
*_GCCNOLTO_ARM_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
|
|
|
*_GCCNOLTO_ARM_CC_XIPFLAGS = DEF(GCC49_ARM_CC_XIPFLAGS)
|
|
|
|
|
|
|
|
DEBUG_GCCNOLTO_ARM_CC_FLAGS = DEF(GCC49_ARM_CC_FLAGS) -O0
|
|
|
|
RELEASE_GCCNOLTO_ARM_CC_FLAGS = DEF(GCC49_ARM_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
NOOPT_GCCNOLTO_ARM_CC_FLAGS = DEF(GCC49_ARM_CC_FLAGS) -O0
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCCNOLTO AARCH64 definitions
|
|
|
|
##################
|
|
|
|
*_GCCNOLTO_AARCH64_CC_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_AARCH64_SLINK_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)ar
|
|
|
|
*_GCCNOLTO_AARCH64_DLINK_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_AARCH64_ASLDLINK_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_AARCH64_ASM_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_AARCH64_PP_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_AARCH64_VFRPP_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_AARCH64_ASLCC_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_AARCH64_ASLPP_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)gcc
|
|
|
|
*_GCCNOLTO_AARCH64_RC_PATH = ENV(GCCNOLTO_AARCH64_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCCNOLTO_AARCH64_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS)
|
|
|
|
*_GCCNOLTO_AARCH64_ASLDLINK_FLAGS = DEF(GCC49_AARCH64_ASLDLINK_FLAGS)
|
|
|
|
*_GCCNOLTO_AARCH64_ASM_FLAGS = DEF(GCC49_AARCH64_ASM_FLAGS)
|
|
|
|
*_GCCNOLTO_AARCH64_DLINK2_FLAGS = DEF(GCC49_AARCH64_DLINK2_FLAGS)
|
|
|
|
*_GCCNOLTO_AARCH64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
|
|
|
*_GCCNOLTO_AARCH64_PLATFORM_FLAGS =
|
|
|
|
*_GCCNOLTO_AARCH64_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
|
|
|
*_GCCNOLTO_AARCH64_RC_FLAGS = DEF(GCC_AARCH64_RC_FLAGS)
|
|
|
|
*_GCCNOLTO_AARCH64_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
|
|
|
*_GCCNOLTO_AARCH64_CC_XIPFLAGS = DEF(GCC49_AARCH64_CC_XIPFLAGS)
|
|
|
|
|
|
|
|
DEBUG_GCCNOLTO_AARCH64_CC_FLAGS = DEF(GCC49_AARCH64_CC_FLAGS) -O0
|
|
|
|
DEBUG_GCCNOLTO_AARCH64_DLINK_FLAGS = DEF(GCC49_AARCH64_DLINK_FLAGS)
|
|
|
|
DEBUG_GCCNOLTO_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
|
|
|
|
|
|
|
|
RELEASE_GCCNOLTO_AARCH64_CC_FLAGS = DEF(GCC49_AARCH64_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
RELEASE_GCCNOLTO_AARCH64_DLINK_FLAGS = DEF(GCC49_AARCH64_DLINK_FLAGS)
|
|
|
|
RELEASE_GCCNOLTO_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
|
|
|
|
|
|
|
|
NOOPT_GCCNOLTO_AARCH64_CC_FLAGS = DEF(GCC49_AARCH64_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCCNOLTO_AARCH64_DLINK_FLAGS = DEF(GCC49_AARCH64_DLINK_FLAGS) -O0
|
|
|
|
NOOPT_GCCNOLTO_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20 -O0
|
|
|
|
|
2016-07-17 23:20:10 +02:00
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# GCC 5 - This configuration is used to compile under Linux to produce
|
|
|
|
# PE/COFF binaries using GCC 5
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
*_GCC5_*_*_FAMILY = GCC
|
|
|
|
|
2018-04-25 12:11:42 +02:00
|
|
|
*_GCC5_*_MAKE_PATH = DEF(GCC_HOST_PREFIX)make
|
2016-07-17 23:20:10 +02:00
|
|
|
*_GCC5_*_*_DLL = ENV(GCC5_DLL)
|
|
|
|
*_GCC5_*_ASL_PATH = DEF(UNIX_IASL_BIN)
|
|
|
|
|
|
|
|
*_GCC5_*_PP_FLAGS = DEF(GCC_PP_FLAGS)
|
|
|
|
*_GCC5_*_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS)
|
|
|
|
*_GCC5_*_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_GCC5_*_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS)
|
|
|
|
*_GCC5_*_APP_FLAGS =
|
|
|
|
*_GCC5_*_ASL_FLAGS = DEF(IASL_FLAGS)
|
|
|
|
*_GCC5_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
2019-12-02 09:24:19 +01:00
|
|
|
*_GCC5_*_DEPS_FLAGS = DEF(GCC_DEPS_FLAGS)
|
2016-07-17 23:20:10 +02:00
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC5 IA32 definitions
|
|
|
|
##################
|
|
|
|
*_GCC5_IA32_OBJCOPY_PATH = DEF(GCC5_IA32_PREFIX)objcopy
|
|
|
|
*_GCC5_IA32_CC_PATH = DEF(GCC5_IA32_PREFIX)gcc
|
|
|
|
*_GCC5_IA32_SLINK_PATH = DEF(GCC5_IA32_PREFIX)gcc-ar
|
|
|
|
*_GCC5_IA32_DLINK_PATH = DEF(GCC5_IA32_PREFIX)gcc
|
|
|
|
*_GCC5_IA32_ASLDLINK_PATH = DEF(GCC5_IA32_PREFIX)gcc
|
|
|
|
*_GCC5_IA32_ASM_PATH = DEF(GCC5_IA32_PREFIX)gcc
|
|
|
|
*_GCC5_IA32_PP_PATH = DEF(GCC5_IA32_PREFIX)gcc
|
|
|
|
*_GCC5_IA32_VFRPP_PATH = DEF(GCC5_IA32_PREFIX)gcc
|
|
|
|
*_GCC5_IA32_ASLCC_PATH = DEF(GCC5_IA32_PREFIX)gcc
|
|
|
|
*_GCC5_IA32_ASLPP_PATH = DEF(GCC5_IA32_PREFIX)gcc
|
|
|
|
*_GCC5_IA32_RC_PATH = DEF(GCC5_IA32_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC5_IA32_ASLCC_FLAGS = DEF(GCC5_ASLCC_FLAGS) -m32
|
2018-06-11 09:34:52 +02:00
|
|
|
*_GCC5_IA32_ASLDLINK_FLAGS = DEF(GCC5_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_i386 -no-pie
|
2016-07-17 23:20:10 +02:00
|
|
|
*_GCC5_IA32_ASM_FLAGS = DEF(GCC5_ASM_FLAGS) -m32 -march=i386
|
2018-06-11 09:34:52 +02:00
|
|
|
*_GCC5_IA32_DLINK2_FLAGS = DEF(GCC5_IA32_DLINK2_FLAGS) -no-pie
|
2016-07-17 23:20:10 +02:00
|
|
|
*_GCC5_IA32_RC_FLAGS = DEF(GCC_IA32_RC_FLAGS)
|
|
|
|
*_GCC5_IA32_OBJCOPY_FLAGS =
|
|
|
|
*_GCC5_IA32_NASM_FLAGS = -f elf32
|
|
|
|
|
2023-01-25 10:20:59 +01:00
|
|
|
DEBUG_GCC5_IA32_CC_FLAGS = DEF(GCC5_IA32_CC_FLAGS) -flto
|
2016-09-30 09:30:59 +02:00
|
|
|
DEBUG_GCC5_IA32_DLINK_FLAGS = DEF(GCC5_IA32_X64_DLINK_FLAGS) -flto -Os -Wl,-m,elf_i386,--oformat=elf32-i386
|
|
|
|
|
2023-01-25 10:20:59 +01:00
|
|
|
RELEASE_GCC5_IA32_CC_FLAGS = DEF(GCC5_IA32_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
2016-09-30 09:30:59 +02:00
|
|
|
RELEASE_GCC5_IA32_DLINK_FLAGS = DEF(GCC5_IA32_X64_DLINK_FLAGS) -flto -Os -Wl,-m,elf_i386,--oformat=elf32-i386
|
|
|
|
|
|
|
|
NOOPT_GCC5_IA32_CC_FLAGS = DEF(GCC5_IA32_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCC5_IA32_DLINK_FLAGS = DEF(GCC5_IA32_X64_DLINK_FLAGS) -Wl,-m,elf_i386,--oformat=elf32-i386 -O0
|
2016-07-17 23:20:10 +02:00
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC5 X64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC5_X64_OBJCOPY_PATH = DEF(GCC5_X64_PREFIX)objcopy
|
|
|
|
*_GCC5_X64_CC_PATH = DEF(GCC5_X64_PREFIX)gcc
|
|
|
|
*_GCC5_X64_SLINK_PATH = DEF(GCC5_X64_PREFIX)gcc-ar
|
|
|
|
*_GCC5_X64_DLINK_PATH = DEF(GCC5_X64_PREFIX)gcc
|
|
|
|
*_GCC5_X64_ASLDLINK_PATH = DEF(GCC5_X64_PREFIX)gcc
|
|
|
|
*_GCC5_X64_ASM_PATH = DEF(GCC5_X64_PREFIX)gcc
|
|
|
|
*_GCC5_X64_PP_PATH = DEF(GCC5_X64_PREFIX)gcc
|
|
|
|
*_GCC5_X64_VFRPP_PATH = DEF(GCC5_X64_PREFIX)gcc
|
|
|
|
*_GCC5_X64_ASLCC_PATH = DEF(GCC5_X64_PREFIX)gcc
|
|
|
|
*_GCC5_X64_ASLPP_PATH = DEF(GCC5_X64_PREFIX)gcc
|
|
|
|
*_GCC5_X64_RC_PATH = DEF(GCC5_X64_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC5_X64_ASLCC_FLAGS = DEF(GCC5_ASLCC_FLAGS) -m64
|
2016-07-17 23:20:10 +02:00
|
|
|
*_GCC5_X64_ASLDLINK_FLAGS = DEF(GCC5_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_x86_64
|
|
|
|
*_GCC5_X64_ASM_FLAGS = DEF(GCC5_ASM_FLAGS) -m64
|
|
|
|
*_GCC5_X64_DLINK2_FLAGS = DEF(GCC5_X64_DLINK2_FLAGS)
|
|
|
|
*_GCC5_X64_RC_FLAGS = DEF(GCC_X64_RC_FLAGS)
|
|
|
|
*_GCC5_X64_OBJCOPY_FLAGS =
|
|
|
|
*_GCC5_X64_NASM_FLAGS = -f elf64
|
|
|
|
|
2023-01-25 10:20:59 +01:00
|
|
|
DEBUG_GCC5_X64_CC_FLAGS = DEF(GCC5_X64_CC_FLAGS) -flto -DUSING_LTO
|
2016-09-30 09:30:59 +02:00
|
|
|
DEBUG_GCC5_X64_DLINK_FLAGS = DEF(GCC5_X64_DLINK_FLAGS) -flto -Os
|
|
|
|
|
2023-01-25 10:20:59 +01:00
|
|
|
RELEASE_GCC5_X64_CC_FLAGS = DEF(GCC5_X64_CC_FLAGS) -flto -DUSING_LTO -Wno-unused-but-set-variable -Wno-unused-const-variable
|
2016-09-30 09:30:59 +02:00
|
|
|
RELEASE_GCC5_X64_DLINK_FLAGS = DEF(GCC5_X64_DLINK_FLAGS) -flto -Os
|
|
|
|
|
|
|
|
NOOPT_GCC5_X64_CC_FLAGS = DEF(GCC5_X64_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCC5_X64_DLINK_FLAGS = DEF(GCC5_X64_DLINK_FLAGS) -O0
|
2016-07-17 23:20:10 +02:00
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC5 ARM definitions
|
|
|
|
##################
|
|
|
|
*_GCC5_ARM_CC_PATH = ENV(GCC5_ARM_PREFIX)gcc
|
|
|
|
*_GCC5_ARM_SLINK_PATH = ENV(GCC5_ARM_PREFIX)gcc-ar
|
|
|
|
*_GCC5_ARM_DLINK_PATH = ENV(GCC5_ARM_PREFIX)gcc
|
|
|
|
*_GCC5_ARM_ASLDLINK_PATH = ENV(GCC5_ARM_PREFIX)gcc
|
|
|
|
*_GCC5_ARM_ASM_PATH = ENV(GCC5_ARM_PREFIX)gcc
|
|
|
|
*_GCC5_ARM_PP_PATH = ENV(GCC5_ARM_PREFIX)gcc
|
|
|
|
*_GCC5_ARM_VFRPP_PATH = ENV(GCC5_ARM_PREFIX)gcc
|
|
|
|
*_GCC5_ARM_ASLCC_PATH = ENV(GCC5_ARM_PREFIX)gcc
|
|
|
|
*_GCC5_ARM_ASLPP_PATH = ENV(GCC5_ARM_PREFIX)gcc
|
|
|
|
*_GCC5_ARM_RC_PATH = ENV(GCC5_ARM_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC5_ARM_ASLCC_FLAGS = DEF(GCC5_ASLCC_FLAGS)
|
2016-07-17 23:20:10 +02:00
|
|
|
*_GCC5_ARM_ASLDLINK_FLAGS = DEF(GCC5_ARM_ASLDLINK_FLAGS)
|
|
|
|
*_GCC5_ARM_ASM_FLAGS = DEF(GCC5_ARM_ASM_FLAGS)
|
|
|
|
*_GCC5_ARM_DLINK2_FLAGS = DEF(GCC5_ARM_DLINK2_FLAGS)
|
2017-08-29 15:21:02 +02:00
|
|
|
*_GCC5_ARM_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
2023-01-05 16:43:54 +01:00
|
|
|
*_GCC5_ARM_PLATFORM_FLAGS = -march=armv7-a -mfloat-abi=soft
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC5_ARM_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
2016-07-17 23:20:10 +02:00
|
|
|
*_GCC5_ARM_RC_FLAGS = DEF(GCC_ARM_RC_FLAGS)
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC5_ARM_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
2016-08-08 12:33:06 +02:00
|
|
|
*_GCC5_ARM_CC_XIPFLAGS = DEF(GCC5_ARM_CC_XIPFLAGS)
|
2016-07-17 23:20:10 +02:00
|
|
|
|
2017-12-07 09:53:03 +01:00
|
|
|
DEBUG_GCC5_ARM_CC_FLAGS = DEF(GCC5_ARM_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
DEBUG_GCC5_ARM_DLINK_FLAGS = DEF(GCC5_ARM_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-arm -Wl,-plugin-opt=-pass-through=-llto-arm
|
2016-07-17 23:20:10 +02:00
|
|
|
|
2017-09-08 09:01:31 +02:00
|
|
|
RELEASE_GCC5_ARM_CC_FLAGS = DEF(GCC5_ARM_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
2016-07-17 23:20:10 +02:00
|
|
|
RELEASE_GCC5_ARM_DLINK_FLAGS = DEF(GCC5_ARM_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-arm -Wl,-plugin-opt=-pass-through=-llto-arm
|
|
|
|
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC5_ARM_CC_FLAGS = DEF(GCC5_ARM_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCC5_ARM_DLINK_FLAGS = DEF(GCC5_ARM_DLINK_FLAGS) -O0
|
|
|
|
|
2016-07-17 23:20:10 +02:00
|
|
|
##################
|
|
|
|
# GCC5 AARCH64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC5_AARCH64_CC_PATH = ENV(GCC5_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_AARCH64_SLINK_PATH = ENV(GCC5_AARCH64_PREFIX)gcc-ar
|
|
|
|
*_GCC5_AARCH64_DLINK_PATH = ENV(GCC5_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_AARCH64_ASLDLINK_PATH = ENV(GCC5_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_AARCH64_ASM_PATH = ENV(GCC5_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_AARCH64_PP_PATH = ENV(GCC5_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_AARCH64_VFRPP_PATH = ENV(GCC5_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_AARCH64_ASLCC_PATH = ENV(GCC5_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_AARCH64_ASLPP_PATH = ENV(GCC5_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_AARCH64_RC_PATH = ENV(GCC5_AARCH64_PREFIX)objcopy
|
|
|
|
|
2019-01-14 15:04:49 +01:00
|
|
|
*_GCC5_AARCH64_ASLCC_FLAGS = DEF(GCC5_ASLCC_FLAGS)
|
2016-07-17 23:20:10 +02:00
|
|
|
*_GCC5_AARCH64_ASLDLINK_FLAGS = DEF(GCC5_AARCH64_ASLDLINK_FLAGS)
|
|
|
|
*_GCC5_AARCH64_ASM_FLAGS = DEF(GCC5_AARCH64_ASM_FLAGS)
|
|
|
|
*_GCC5_AARCH64_DLINK2_FLAGS = DEF(GCC5_AARCH64_DLINK2_FLAGS)
|
2017-08-29 15:21:02 +02:00
|
|
|
*_GCC5_AARCH64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
2016-07-17 23:20:10 +02:00
|
|
|
*_GCC5_AARCH64_PLATFORM_FLAGS =
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC5_AARCH64_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
2023-03-26 10:58:35 +02:00
|
|
|
*_GCC5_AARCH64_RC_FLAGS = DEF(GCC_AARCH64_RC_FLAGS) DEF(GCC_AARCH64_RC_BTI_FLAGS)
|
2023-01-05 15:20:16 +01:00
|
|
|
*_GCC5_AARCH64_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
2016-07-17 23:20:10 +02:00
|
|
|
*_GCC5_AARCH64_CC_XIPFLAGS = DEF(GCC5_AARCH64_CC_XIPFLAGS)
|
|
|
|
|
2018-12-10 15:13:39 +01:00
|
|
|
DEBUG_GCC5_AARCH64_CC_FLAGS = DEF(GCC5_AARCH64_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
DEBUG_GCC5_AARCH64_DLINK_FLAGS = DEF(GCC5_AARCH64_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-aarch64 -Wl,-plugin-opt=-pass-through=-llto-aarch64 -Wno-lto-type-mismatch
|
2016-07-27 12:08:20 +02:00
|
|
|
DEBUG_GCC5_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
|
2016-07-17 23:20:10 +02:00
|
|
|
|
2018-12-10 15:13:39 +01:00
|
|
|
RELEASE_GCC5_AARCH64_CC_FLAGS = DEF(GCC5_AARCH64_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
BaseTools/tools_def: AARCH64: disable LTO type mismatch warnings
On AARCH64, any code that may execute with the MMU off needs to be built
with -mstrict-align, given that unaligned accesses are not allowed unless
the MMU is enabled. This does not only affect SEC and PEI modules, but
also static libraries of the BASE type, which may be linked into such
modules, as well as into modules of other types. As it turns out, the
presence of -mstrict-align is reflected in the internal representations
of the types defined in those libraries.
When -fstrict-aliasing is passed to GCC, it assumes that pointers to
objects of different types cannot refer to the same memory location, and
attempts to exploit this fact when optimizing the code. Since such
assumptions are only valid under very strict conditions which are not
guaranteed to be met in EDK2, we disable this optimization by passing
-fno-strict-aliasing by default. [*]
When LTO is in effect, this applies equally to the code generation that
may occur at link time, which is why the linker warns about unexpected
differences in type definitions between the intermediate representations
that are present in the object files being linked. This may result in
warnings such as the one below, even if -fno-strict-aliasing is used:
MdePkg/Include/Library/BaseLib.h:1712:1:
warning: type of 'StrToGuid' does not match original declaration
[-Wlto-type-mismatch]
StrToGuid (
^
MdePkg/Library/BaseLib/SafeString.c:1506:1:
note: 'StrToGuid' was previously declared here
StrToGuid (
^
MdePkg/Library/BaseLib/SafeString.c:1506:1:
note: code may be misoptimized unless -fno-strict-aliasing is used
This warning is inadvertently triggered when linking BASE libraries built
with -mstrict-align into modules of types other than SEC or PEI, since the
types are subtly different, even though the use of code that maintains
strict alignment in a module that does not care about this is unlikely to
cause problems. And even if it did, it would still only affect code built
with -fstrict-aliasing enabled, which we disable unconditionally. So let's
just silence the warning by passing -Wno-lto-type-mismatch.
[*] Leif adds: "-fstrict-aliasing is GCC default, because it is a
restriction in the C language. Because it's a bit non-obvious, things
can go hilariously wrong in very non-obvious ways, and the potential
optimization gains are unlikely to be generally relevant,
-fno-strict-aliasing is a sensible thing to always have set (like we
do)."
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Ard Biesheuvel <ard.biesheuvel@linaro.org>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Reviewed-by: Leif Lindholm <leif.lindholm@linaro.org>
2017-06-20 20:43:54 +02:00
|
|
|
RELEASE_GCC5_AARCH64_DLINK_FLAGS = DEF(GCC5_AARCH64_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-aarch64 -Wl,-plugin-opt=-pass-through=-llto-aarch64 -Wno-lto-type-mismatch
|
2018-12-10 15:13:39 +01:00
|
|
|
RELEASE_GCC5_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
|
2016-07-17 23:20:10 +02:00
|
|
|
|
2018-12-10 15:13:39 +01:00
|
|
|
NOOPT_GCC5_AARCH64_CC_FLAGS = DEF(GCC5_AARCH64_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCC5_AARCH64_DLINK_FLAGS = DEF(GCC5_AARCH64_DLINK_FLAGS) -O0
|
2016-09-30 09:30:59 +02:00
|
|
|
NOOPT_GCC5_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20 -O0
|
|
|
|
|
2020-04-23 15:52:33 +02:00
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# GCC RISC-V This configuration is used to compile under Linux to produce
|
|
|
|
# PE/COFF binaries using GCC RISC-V tool chain
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC5 RISCV64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC5_RISCV64_OBJCOPY_PATH = ENV(GCC5_RISCV64_PREFIX)objcopy
|
|
|
|
*_GCC5_RISCV64_CC_PATH = ENV(GCC5_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC5_RISCV64_SLINK_PATH = ENV(GCC5_RISCV64_PREFIX)gcc-ar
|
|
|
|
*_GCC5_RISCV64_DLINK_PATH = ENV(GCC5_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC5_RISCV64_ASLDLINK_PATH = ENV(GCC5_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC5_RISCV64_ASM_PATH = ENV(GCC5_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC5_RISCV64_PP_PATH = ENV(GCC5_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC5_RISCV64_VFRPP_PATH = ENV(GCC5_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC5_RISCV64_ASLCC_PATH = ENV(GCC5_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC5_RISCV64_ASLPP_PATH = ENV(GCC5_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC5_RISCV64_RC_PATH = ENV(GCC5_RISCV64_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCC5_RISCV64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_GCC5_RISCV64_ASLDLINK_FLAGS = DEF(GCC5_RISCV32_RISCV64_ASLDLINK_FLAGS)
|
|
|
|
*_GCC5_RISCV64_ASM_FLAGS = DEF(GCC5_RISCV64_ASM_FLAGS)
|
|
|
|
*_GCC5_RISCV64_CC_FLAGS = DEF(GCC5_RISCV64_CC_FLAGS) -save-temps
|
|
|
|
*_GCC5_RISCV64_DLINK_FLAGS = DEF(GCC5_RISCV64_DLINK_FLAGS)
|
|
|
|
*_GCC5_RISCV64_DLINK2_FLAGS = DEF(GCC5_RISCV64_DLINK2_FLAGS)
|
|
|
|
*_GCC5_RISCV64_RC_FLAGS = DEF(GCC_RISCV64_RC_FLAGS)
|
|
|
|
*_GCC5_RISCV64_OBJCOPY_FLAGS =
|
2021-05-14 08:03:03 +02:00
|
|
|
*_GCC5_RISCV64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
2023-01-05 15:29:39 +01:00
|
|
|
*_GCC5_RISCV64_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(GCC5_RISCV_OPENSBI_TYPES)
|
2020-04-23 15:52:33 +02:00
|
|
|
|
2022-09-06 13:25:29 +02:00
|
|
|
##################
|
|
|
|
# GCC5 LOONGARCH64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC5_LOONGARCH64_OBJCOPY_PATH = ENV(GCC5_LOONGARCH64_PREFIX)objcopy
|
|
|
|
*_GCC5_LOONGARCH64_CC_PATH = ENV(GCC5_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_LOONGARCH64_SLINK_PATH = ENV(GCC5_LOONGARCH64_PREFIX)gcc-ar
|
|
|
|
*_GCC5_LOONGARCH64_DLINK_PATH = ENV(GCC5_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_LOONGARCH64_ASLDLINK_PATH = ENV(GCC5_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_LOONGARCH64_ASM_PATH = ENV(GCC5_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_LOONGARCH64_PP_PATH = ENV(GCC5_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_LOONGARCH64_VFRPP_PATH = ENV(GCC5_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_LOONGARCH64_ASLCC_PATH = ENV(GCC5_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_LOONGARCH64_ASLPP_PATH = ENV(GCC5_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC5_LOONGARCH64_RC_PATH = ENV(GCC5_LOONGARCH64_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCC5_LOONGARCH64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_GCC5_LOONGARCH64_ASLDLINK_FLAGS = DEF(GCC5_LOONGARCH64_ASLDLINK_FLAGS)
|
|
|
|
*_GCC5_LOONGARCH64_ASM_FLAGS = DEF(GCC5_LOONGARCH64_ASM_FLAGS)
|
|
|
|
*_GCC5_LOONGARCH64_DLINK_FLAGS = DEF(GCC5_LOONGARCH64_DLINK_FLAGS)
|
|
|
|
*_GCC5_LOONGARCH64_DLINK2_FLAGS = DEF(GCC5_LOONGARCH64_DLINK2_FLAGS)
|
|
|
|
*_GCC5_LOONGARCH64_RC_FLAGS = DEF(GCC_LOONGARCH64_RC_FLAGS)
|
|
|
|
*_GCC5_LOONGARCH64_OBJCOPY_FLAGS =
|
|
|
|
*_GCC5_LOONGARCH64_NASM_FLAGS = -f elf32
|
|
|
|
*_GCC5_LOONGARCH64_PP_FLAGS = DEF(GCC5_LOONGARCH64_PP_FLAGS)
|
|
|
|
|
|
|
|
DEBUG_GCC5_LOONGARCH64_CC_FLAGS = DEF(GCC5_LOONGARCH64_CC_FLAGS)
|
|
|
|
RELEASE_GCC5_LOONGARCH64_CC_FLAGS = DEF(GCC5_LOONGARCH64_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-variable
|
|
|
|
|
2023-04-12 20:35:11 +02:00
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# GCC - This configuration is used to compile under Linux to produce
|
|
|
|
# PE/COFF binaries using GCC 5 or newer
|
|
|
|
#
|
|
|
|
####################################################################################
|
|
|
|
*_GCC_*_*_FAMILY = GCC
|
|
|
|
|
|
|
|
*_GCC_*_MAKE_PATH = DEF(GCC_HOST_PREFIX)make
|
|
|
|
*_GCC_*_*_DLL = ENV(GCC_DLL)
|
|
|
|
*_GCC_*_ASL_PATH = DEF(UNIX_IASL_BIN)
|
|
|
|
|
|
|
|
*_GCC_*_PP_FLAGS = DEF(GCC_PP_FLAGS)
|
|
|
|
*_GCC_*_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS)
|
|
|
|
*_GCC_*_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_GCC_*_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS)
|
|
|
|
*_GCC_*_APP_FLAGS =
|
|
|
|
*_GCC_*_ASL_FLAGS = DEF(IASL_FLAGS)
|
|
|
|
*_GCC_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
|
|
|
*_GCC_*_DEPS_FLAGS = DEF(GCC_DEPS_FLAGS)
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC IA32 definitions
|
|
|
|
##################
|
|
|
|
*_GCC_IA32_OBJCOPY_PATH = DEF(GCC_IA32_PREFIX)objcopy
|
|
|
|
*_GCC_IA32_CC_PATH = DEF(GCC_IA32_PREFIX)gcc
|
|
|
|
*_GCC_IA32_SLINK_PATH = DEF(GCC_IA32_PREFIX)gcc-ar
|
|
|
|
*_GCC_IA32_DLINK_PATH = DEF(GCC_IA32_PREFIX)gcc
|
|
|
|
*_GCC_IA32_ASLDLINK_PATH = DEF(GCC_IA32_PREFIX)gcc
|
|
|
|
*_GCC_IA32_ASM_PATH = DEF(GCC_IA32_PREFIX)gcc
|
|
|
|
*_GCC_IA32_PP_PATH = DEF(GCC_IA32_PREFIX)gcc
|
|
|
|
*_GCC_IA32_VFRPP_PATH = DEF(GCC_IA32_PREFIX)gcc
|
|
|
|
*_GCC_IA32_ASLCC_PATH = DEF(GCC_IA32_PREFIX)gcc
|
|
|
|
*_GCC_IA32_ASLPP_PATH = DEF(GCC_IA32_PREFIX)gcc
|
|
|
|
*_GCC_IA32_RC_PATH = DEF(GCC_IA32_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCC_IA32_ASLCC_FLAGS = DEF(GCC5_ASLCC_FLAGS) -m32
|
|
|
|
*_GCC_IA32_ASLDLINK_FLAGS = DEF(GCC5_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_i386 -no-pie
|
|
|
|
*_GCC_IA32_ASM_FLAGS = DEF(GCC5_ASM_FLAGS) -m32 -march=i386
|
|
|
|
*_GCC_IA32_DLINK2_FLAGS = DEF(GCC5_IA32_DLINK2_FLAGS) -no-pie
|
|
|
|
*_GCC_IA32_RC_FLAGS = DEF(GCC_IA32_RC_FLAGS)
|
|
|
|
*_GCC_IA32_OBJCOPY_FLAGS =
|
|
|
|
*_GCC_IA32_NASM_FLAGS = -f elf32
|
|
|
|
|
|
|
|
DEBUG_GCC_IA32_CC_FLAGS = DEF(GCC5_IA32_CC_FLAGS) -flto
|
|
|
|
DEBUG_GCC_IA32_DLINK_FLAGS = DEF(GCC5_IA32_X64_DLINK_FLAGS) -flto -Os -Wl,-m,elf_i386,--oformat=elf32-i386
|
|
|
|
|
|
|
|
RELEASE_GCC_IA32_CC_FLAGS = DEF(GCC5_IA32_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
RELEASE_GCC_IA32_DLINK_FLAGS = DEF(GCC5_IA32_X64_DLINK_FLAGS) -flto -Os -Wl,-m,elf_i386,--oformat=elf32-i386
|
|
|
|
|
|
|
|
NOOPT_GCC_IA32_CC_FLAGS = DEF(GCC5_IA32_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCC_IA32_DLINK_FLAGS = DEF(GCC5_IA32_X64_DLINK_FLAGS) -Wl,-m,elf_i386,--oformat=elf32-i386 -O0
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC X64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC_X64_OBJCOPY_PATH = DEF(GCC_X64_PREFIX)objcopy
|
|
|
|
*_GCC_X64_CC_PATH = DEF(GCC_X64_PREFIX)gcc
|
|
|
|
*_GCC_X64_SLINK_PATH = DEF(GCC_X64_PREFIX)gcc-ar
|
|
|
|
*_GCC_X64_DLINK_PATH = DEF(GCC_X64_PREFIX)gcc
|
|
|
|
*_GCC_X64_ASLDLINK_PATH = DEF(GCC_X64_PREFIX)gcc
|
|
|
|
*_GCC_X64_ASM_PATH = DEF(GCC_X64_PREFIX)gcc
|
|
|
|
*_GCC_X64_PP_PATH = DEF(GCC_X64_PREFIX)gcc
|
|
|
|
*_GCC_X64_VFRPP_PATH = DEF(GCC_X64_PREFIX)gcc
|
|
|
|
*_GCC_X64_ASLCC_PATH = DEF(GCC_X64_PREFIX)gcc
|
|
|
|
*_GCC_X64_ASLPP_PATH = DEF(GCC_X64_PREFIX)gcc
|
|
|
|
*_GCC_X64_RC_PATH = DEF(GCC_X64_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCC_X64_ASLCC_FLAGS = DEF(GCC5_ASLCC_FLAGS) -m64
|
|
|
|
*_GCC_X64_ASLDLINK_FLAGS = DEF(GCC5_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_x86_64
|
|
|
|
*_GCC_X64_ASM_FLAGS = DEF(GCC5_ASM_FLAGS) -m64
|
|
|
|
*_GCC_X64_DLINK2_FLAGS = DEF(GCC5_X64_DLINK2_FLAGS)
|
|
|
|
*_GCC_X64_RC_FLAGS = DEF(GCC_X64_RC_FLAGS)
|
|
|
|
*_GCC_X64_OBJCOPY_FLAGS =
|
|
|
|
*_GCC_X64_NASM_FLAGS = -f elf64
|
|
|
|
|
|
|
|
DEBUG_GCC_X64_CC_FLAGS = DEF(GCC5_X64_CC_FLAGS) -flto -DUSING_LTO
|
|
|
|
DEBUG_GCC_X64_DLINK_FLAGS = DEF(GCC5_X64_DLINK_FLAGS) -flto -Os
|
|
|
|
|
|
|
|
RELEASE_GCC_X64_CC_FLAGS = DEF(GCC5_X64_CC_FLAGS) -flto -DUSING_LTO -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
RELEASE_GCC_X64_DLINK_FLAGS = DEF(GCC5_X64_DLINK_FLAGS) -flto -Os
|
|
|
|
|
|
|
|
NOOPT_GCC_X64_CC_FLAGS = DEF(GCC5_X64_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCC_X64_DLINK_FLAGS = DEF(GCC5_X64_DLINK_FLAGS) -O0
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC ARM definitions
|
|
|
|
##################
|
|
|
|
*_GCC_ARM_CC_PATH = ENV(GCC_ARM_PREFIX)gcc
|
|
|
|
*_GCC_ARM_SLINK_PATH = ENV(GCC_ARM_PREFIX)gcc-ar
|
|
|
|
*_GCC_ARM_DLINK_PATH = ENV(GCC_ARM_PREFIX)gcc
|
|
|
|
*_GCC_ARM_ASLDLINK_PATH = ENV(GCC_ARM_PREFIX)gcc
|
|
|
|
*_GCC_ARM_ASM_PATH = ENV(GCC_ARM_PREFIX)gcc
|
|
|
|
*_GCC_ARM_PP_PATH = ENV(GCC_ARM_PREFIX)gcc
|
|
|
|
*_GCC_ARM_VFRPP_PATH = ENV(GCC_ARM_PREFIX)gcc
|
|
|
|
*_GCC_ARM_ASLCC_PATH = ENV(GCC_ARM_PREFIX)gcc
|
|
|
|
*_GCC_ARM_ASLPP_PATH = ENV(GCC_ARM_PREFIX)gcc
|
|
|
|
*_GCC_ARM_RC_PATH = ENV(GCC_ARM_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCC_ARM_ASLCC_FLAGS = DEF(GCC5_ASLCC_FLAGS)
|
|
|
|
*_GCC_ARM_ASLDLINK_FLAGS = DEF(GCC5_ARM_ASLDLINK_FLAGS)
|
|
|
|
*_GCC_ARM_ASM_FLAGS = DEF(GCC5_ARM_ASM_FLAGS)
|
|
|
|
*_GCC_ARM_DLINK2_FLAGS = DEF(GCC5_ARM_DLINK2_FLAGS)
|
|
|
|
*_GCC_ARM_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
|
|
|
*_GCC_ARM_PLATFORM_FLAGS = -march=armv7-a -mfloat-abi=soft
|
|
|
|
*_GCC_ARM_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
|
|
|
*_GCC_ARM_RC_FLAGS = DEF(GCC_ARM_RC_FLAGS)
|
|
|
|
*_GCC_ARM_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
|
|
|
*_GCC_ARM_CC_XIPFLAGS = DEF(GCC5_ARM_CC_XIPFLAGS)
|
|
|
|
|
|
|
|
DEBUG_GCC_ARM_CC_FLAGS = DEF(GCC5_ARM_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
DEBUG_GCC_ARM_DLINK_FLAGS = DEF(GCC5_ARM_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-arm -Wl,-plugin-opt=-pass-through=-llto-arm
|
|
|
|
|
|
|
|
RELEASE_GCC_ARM_CC_FLAGS = DEF(GCC5_ARM_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
RELEASE_GCC_ARM_DLINK_FLAGS = DEF(GCC5_ARM_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-arm -Wl,-plugin-opt=-pass-through=-llto-arm
|
|
|
|
|
|
|
|
NOOPT_GCC_ARM_CC_FLAGS = DEF(GCC5_ARM_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCC_ARM_DLINK_FLAGS = DEF(GCC5_ARM_DLINK_FLAGS) -O0
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC AARCH64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC_AARCH64_CC_PATH = ENV(GCC_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC_AARCH64_SLINK_PATH = ENV(GCC_AARCH64_PREFIX)gcc-ar
|
|
|
|
*_GCC_AARCH64_DLINK_PATH = ENV(GCC_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC_AARCH64_ASLDLINK_PATH = ENV(GCC_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC_AARCH64_ASM_PATH = ENV(GCC_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC_AARCH64_PP_PATH = ENV(GCC_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC_AARCH64_VFRPP_PATH = ENV(GCC_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC_AARCH64_ASLCC_PATH = ENV(GCC_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC_AARCH64_ASLPP_PATH = ENV(GCC_AARCH64_PREFIX)gcc
|
|
|
|
*_GCC_AARCH64_RC_PATH = ENV(GCC_AARCH64_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCC_AARCH64_ASLCC_FLAGS = DEF(GCC5_ASLCC_FLAGS)
|
|
|
|
*_GCC_AARCH64_ASLDLINK_FLAGS = DEF(GCC5_AARCH64_ASLDLINK_FLAGS)
|
|
|
|
*_GCC_AARCH64_ASM_FLAGS = DEF(GCC5_AARCH64_ASM_FLAGS)
|
|
|
|
*_GCC_AARCH64_DLINK2_FLAGS = DEF(GCC5_AARCH64_DLINK2_FLAGS)
|
|
|
|
*_GCC_AARCH64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
|
|
|
*_GCC_AARCH64_PLATFORM_FLAGS =
|
|
|
|
*_GCC_AARCH64_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
|
|
|
|
*_GCC_AARCH64_RC_FLAGS = DEF(GCC_AARCH64_RC_FLAGS) DEF(GCC_AARCH64_RC_BTI_FLAGS)
|
|
|
|
*_GCC_AARCH64_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
|
|
|
|
*_GCC_AARCH64_CC_XIPFLAGS = DEF(GCC5_AARCH64_CC_XIPFLAGS)
|
|
|
|
|
|
|
|
DEBUG_GCC_AARCH64_CC_FLAGS = DEF(GCC5_AARCH64_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
DEBUG_GCC_AARCH64_DLINK_FLAGS = DEF(GCC5_AARCH64_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-aarch64 -Wl,-plugin-opt=-pass-through=-llto-aarch64 -Wno-lto-type-mismatch
|
|
|
|
DEBUG_GCC_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
|
|
|
|
|
|
|
|
RELEASE_GCC_AARCH64_CC_FLAGS = DEF(GCC5_AARCH64_CC_FLAGS) -flto -Wno-unused-but-set-variable -Wno-unused-const-variable
|
|
|
|
RELEASE_GCC_AARCH64_DLINK_FLAGS = DEF(GCC5_AARCH64_DLINK_FLAGS) -flto -Os -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-aarch64 -Wl,-plugin-opt=-pass-through=-llto-aarch64 -Wno-lto-type-mismatch
|
|
|
|
RELEASE_GCC_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
|
|
|
|
|
|
|
|
NOOPT_GCC_AARCH64_CC_FLAGS = DEF(GCC5_AARCH64_CC_FLAGS) -O0
|
|
|
|
NOOPT_GCC_AARCH64_DLINK_FLAGS = DEF(GCC5_AARCH64_DLINK_FLAGS) -O0
|
|
|
|
NOOPT_GCC_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20 -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 = ENV(GCC_RISCV64_PREFIX)objcopy
|
|
|
|
*_GCC_RISCV64_CC_PATH = ENV(GCC_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC_RISCV64_SLINK_PATH = ENV(GCC_RISCV64_PREFIX)gcc-ar
|
|
|
|
*_GCC_RISCV64_DLINK_PATH = ENV(GCC_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC_RISCV64_ASLDLINK_PATH = ENV(GCC_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC_RISCV64_ASM_PATH = ENV(GCC_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC_RISCV64_PP_PATH = ENV(GCC_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC_RISCV64_VFRPP_PATH = ENV(GCC_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC_RISCV64_ASLCC_PATH = ENV(GCC_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC_RISCV64_ASLPP_PATH = ENV(GCC_RISCV64_PREFIX)gcc
|
|
|
|
*_GCC_RISCV64_RC_PATH = ENV(GCC_RISCV64_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCC_RISCV64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_GCC_RISCV64_ASLDLINK_FLAGS = DEF(GCC5_RISCV32_RISCV64_ASLDLINK_FLAGS)
|
|
|
|
*_GCC_RISCV64_ASM_FLAGS = DEF(GCC5_RISCV64_ASM_FLAGS)
|
|
|
|
*_GCC_RISCV64_CC_FLAGS = DEF(GCC5_RISCV64_CC_FLAGS) -save-temps
|
|
|
|
*_GCC_RISCV64_DLINK_FLAGS = DEF(GCC5_RISCV64_DLINK_FLAGS)
|
|
|
|
*_GCC_RISCV64_DLINK2_FLAGS = DEF(GCC5_RISCV64_DLINK2_FLAGS)
|
|
|
|
*_GCC_RISCV64_RC_FLAGS = DEF(GCC_RISCV64_RC_FLAGS)
|
|
|
|
*_GCC_RISCV64_OBJCOPY_FLAGS =
|
|
|
|
*_GCC_RISCV64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
|
|
|
*_GCC_RISCV64_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(GCC5_RISCV_OPENSBI_TYPES)
|
|
|
|
|
|
|
|
##################
|
|
|
|
# GCC LOONGARCH64 definitions
|
|
|
|
##################
|
|
|
|
*_GCC_LOONGARCH64_OBJCOPY_PATH = ENV(GCC_LOONGARCH64_PREFIX)objcopy
|
|
|
|
*_GCC_LOONGARCH64_CC_PATH = ENV(GCC_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC_LOONGARCH64_SLINK_PATH = ENV(GCC_LOONGARCH64_PREFIX)gcc-ar
|
|
|
|
*_GCC_LOONGARCH64_DLINK_PATH = ENV(GCC_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC_LOONGARCH64_ASLDLINK_PATH = ENV(GCC_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC_LOONGARCH64_ASM_PATH = ENV(GCC_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC_LOONGARCH64_PP_PATH = ENV(GCC_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC_LOONGARCH64_VFRPP_PATH = ENV(GCC_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC_LOONGARCH64_ASLCC_PATH = ENV(GCC_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC_LOONGARCH64_ASLPP_PATH = ENV(GCC_LOONGARCH64_PREFIX)gcc
|
|
|
|
*_GCC_LOONGARCH64_RC_PATH = ENV(GCC_LOONGARCH64_PREFIX)objcopy
|
|
|
|
|
|
|
|
*_GCC_LOONGARCH64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_GCC_LOONGARCH64_ASLDLINK_FLAGS = DEF(GCC5_LOONGARCH64_ASLDLINK_FLAGS)
|
|
|
|
*_GCC_LOONGARCH64_ASM_FLAGS = DEF(GCC5_LOONGARCH64_ASM_FLAGS)
|
|
|
|
*_GCC_LOONGARCH64_DLINK_FLAGS = DEF(GCC5_LOONGARCH64_DLINK_FLAGS)
|
|
|
|
*_GCC_LOONGARCH64_DLINK2_FLAGS = DEF(GCC5_LOONGARCH64_DLINK2_FLAGS)
|
|
|
|
*_GCC_LOONGARCH64_RC_FLAGS = DEF(GCC_LOONGARCH64_RC_FLAGS)
|
|
|
|
*_GCC_LOONGARCH64_OBJCOPY_FLAGS =
|
|
|
|
*_GCC_LOONGARCH64_NASM_FLAGS = -f elf32
|
|
|
|
*_GCC_LOONGARCH64_PP_FLAGS = DEF(GCC5_LOONGARCH64_PP_FLAGS)
|
|
|
|
|
|
|
|
DEBUG_GCC_LOONGARCH64_CC_FLAGS = DEF(GCC5_LOONGARCH64_CC_FLAGS)
|
|
|
|
RELEASE_GCC_LOONGARCH64_CC_FLAGS = DEF(GCC5_LOONGARCH64_CC_FLAGS) -Wno-unused-but-set-variable -Wno-unused-variable
|
|
|
|
|
2019-10-17 08:55:46 +02:00
|
|
|
####################################################################################
|
|
|
|
#
|
2019-11-14 09:00:53 +01:00
|
|
|
# CLANGPDB - This configuration is used to compile under Windows/Linux/Mac to produce
|
2019-10-17 08:55:46 +02:00
|
|
|
# PE/COFF binaries using LLVM/Clang/LLD with Link Time Optimization enabled
|
|
|
|
#
|
|
|
|
####################################################################################
|
2019-11-14 09:00:53 +01:00
|
|
|
*_CLANGPDB_*_*_FAMILY = GCC
|
|
|
|
*_CLANGPDB_*_*_BUILDRULEFAMILY = CLANGPDB
|
|
|
|
*_CLANGPDB_*_MAKE_PATH = ENV(CLANG_HOST_BIN)make
|
|
|
|
*_CLANGPDB_*_*_DLL = ENV(CLANGPDB_DLL)
|
|
|
|
*_CLANGPDB_*_ASL_PATH = DEF(UNIX_IASL_BIN)
|
2019-10-17 08:55:46 +02:00
|
|
|
|
2019-11-14 09:00:53 +01:00
|
|
|
*_CLANGPDB_*_APP_FLAGS =
|
|
|
|
*_CLANGPDB_*_ASL_FLAGS = DEF(DEFAULT_WIN_ASL_FLAGS)
|
|
|
|
*_CLANGPDB_*_ASL_OUTFLAGS = DEF(DEFAULT_WIN_ASL_OUTFLAGS)
|
|
|
|
*_CLANGPDB_*_ASLDLINK_FLAGS = DEF(MSFT_ASLDLINK_FLAGS)
|
2019-12-02 09:24:19 +01:00
|
|
|
*_CLANGPDB_*_DEPS_FLAGS = DEF(GCC_DEPS_FLAGS)
|
2019-10-17 08:55:46 +02:00
|
|
|
|
2019-11-14 09:00:53 +01:00
|
|
|
DEFINE CLANGPDB_IA32_PREFIX = ENV(CLANG_BIN)
|
|
|
|
DEFINE CLANGPDB_X64_PREFIX = ENV(CLANG_BIN)
|
2019-10-17 08:55:46 +02:00
|
|
|
|
2020-02-11 07:52:59 +01:00
|
|
|
DEFINE CLANGPDB_IA32_TARGET = -target i686-unknown-windows-gnu
|
|
|
|
DEFINE CLANGPDB_X64_TARGET = -target x86_64-unknown-windows-gnu
|
2019-10-17 08:55:46 +02:00
|
|
|
|
2023-05-06 01:36:44 +02:00
|
|
|
DEFINE CLANGPDB_WARNING_OVERRIDES = -Wno-parentheses-equality -Wno-tautological-compare -Wno-tautological-constant-out-of-range-compare -Wno-empty-body -Wno-unused-const-variable -Wno-varargs -Wno-unknown-warning-option -Wno-unused-but-set-variable -Wno-unused-const-variable -Wno-unaligned-access -Wno-microsoft-enum-forward-reference
|
BaseTools: Use SEH exceptions in CLANGPDB for IA32
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2628
This patch reduces the size of IA32 binaries by ensuring that
no .debug_frame / .eh_frame sections are generated through forcing
SEH exception model, which is already the default in clang for X64.
EDK II does not support exceptions, and in future we should disable
them instead of switching to some other variant. Currently this
is not possible due to the following LLVM bugs:
https://bugs.llvm.org/show_bug.cgi?id=45324
https://bugs.llvm.org/show_bug.cgi?id=45325
Upon applying this patch OvmfPkgIA32.dsc compilation in DEBUG mode
gets the following size decrease with clang 9.0.1.
Before: FV Space Information
SECFV [11%Full] 212992 total, 24512 used, 188480 free
PEIFV [22%Full] 917504 total, 203048 used, 714456 free
DXEFV [36%Full] 11534336 total, 4215672 used, 7318664 free
FVMAIN_COMPACT [37%Full] 3440640 total, 1287776 used, 2152864 free
After: FV Space Information
SECFV [10%Full] 212992 total, 22112 used, 190880 free
PEIFV [19%Full] 917504 total, 176392 used, 741112 free
DXEFV [31%Full] 11534336 total, 3657112 used, 7877224 free
FVMAIN_COMPACT [33%Full] 3440640 total, 1153896 used, 2286744 free
Cc: Liming Gao <liming.gao@intel.com>
Cc: Marvin H?user <mhaeuser@outlook.de>
Cc: Zhiguang Liu <zhiguang.liu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Reviewed-by: Zhiguang Liu <zhiguang.liu@intel.com>
Signed-off-by: Vitaly Cheptsov <vit9696@protonmail.com>
2020-03-27 11:45:59 +01:00
|
|
|
DEFINE CLANGPDB_ALL_CC_FLAGS = DEF(GCC48_ALL_CC_FLAGS) DEF(CLANGPDB_WARNING_OVERRIDES) -fno-stack-protector -funsigned-char -ftrap-function=undefined_behavior_has_been_optimized_away_by_clang -Wno-address -Wno-shift-negative-value -Wno-unknown-pragmas -Wno-incompatible-library-redeclaration -Wno-null-dereference -mno-implicit-float -mms-bitfields -mno-stack-arg-probe -nostdlib -nostdlibinc -fseh-exceptions
|
2019-10-17 08:55:46 +02:00
|
|
|
|
|
|
|
###########################
|
2019-11-14 09:00:53 +01:00
|
|
|
# CLANGPDB IA32 definitions
|
2019-10-17 08:55:46 +02:00
|
|
|
###########################
|
2019-11-14 09:00:53 +01:00
|
|
|
*_CLANGPDB_IA32_CC_PATH = DEF(CLANGPDB_IA32_PREFIX)clang
|
|
|
|
*_CLANGPDB_IA32_SLINK_PATH = DEF(CLANGPDB_IA32_PREFIX)llvm-lib
|
|
|
|
*_CLANGPDB_IA32_DLINK_PATH = DEF(CLANGPDB_IA32_PREFIX)lld-link
|
|
|
|
*_CLANGPDB_IA32_ASLDLINK_PATH = DEF(CLANGPDB_IA32_PREFIX)lld-link
|
|
|
|
*_CLANGPDB_IA32_ASM_PATH = DEF(CLANGPDB_IA32_PREFIX)clang
|
|
|
|
*_CLANGPDB_IA32_PP_PATH = DEF(CLANGPDB_IA32_PREFIX)clang
|
|
|
|
*_CLANGPDB_IA32_VFRPP_PATH = DEF(CLANGPDB_IA32_PREFIX)clang
|
|
|
|
*_CLANGPDB_IA32_ASLCC_PATH = DEF(CLANGPDB_IA32_PREFIX)clang
|
|
|
|
*_CLANGPDB_IA32_ASLPP_PATH = DEF(CLANGPDB_IA32_PREFIX)clang
|
|
|
|
*_CLANGPDB_IA32_RC_PATH = DEF(CLANGPDB_IA32_PREFIX)llvm-rc
|
|
|
|
|
|
|
|
*_CLANGPDB_IA32_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -m32 -fno-lto DEF(CLANGPDB_IA32_TARGET)
|
|
|
|
*_CLANGPDB_IA32_ASM_FLAGS = DEF(GCC_ASM_FLAGS) -m32 -march=i386 DEF(CLANGPDB_IA32_TARGET)
|
|
|
|
*_CLANGPDB_IA32_OBJCOPY_FLAGS =
|
|
|
|
*_CLANGPDB_IA32_NASM_FLAGS = -f win32
|
|
|
|
*_CLANGPDB_IA32_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGPDB_IA32_TARGET)
|
|
|
|
*_CLANGPDB_IA32_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGPDB_IA32_TARGET)
|
|
|
|
*_CLANGPDB_IA32_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGPDB_IA32_TARGET)
|
|
|
|
|
2022-12-16 20:50:20 +01:00
|
|
|
DEBUG_CLANGPDB_IA32_CC_FLAGS = DEF(CLANGPDB_ALL_CC_FLAGS) -m32 -Oz -flto -march=i586 DEF(CLANGPDB_IA32_TARGET) -gcodeview -malign-double
|
BaseTools: Use SEH exceptions in CLANGPDB for IA32
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2628
This patch reduces the size of IA32 binaries by ensuring that
no .debug_frame / .eh_frame sections are generated through forcing
SEH exception model, which is already the default in clang for X64.
EDK II does not support exceptions, and in future we should disable
them instead of switching to some other variant. Currently this
is not possible due to the following LLVM bugs:
https://bugs.llvm.org/show_bug.cgi?id=45324
https://bugs.llvm.org/show_bug.cgi?id=45325
Upon applying this patch OvmfPkgIA32.dsc compilation in DEBUG mode
gets the following size decrease with clang 9.0.1.
Before: FV Space Information
SECFV [11%Full] 212992 total, 24512 used, 188480 free
PEIFV [22%Full] 917504 total, 203048 used, 714456 free
DXEFV [36%Full] 11534336 total, 4215672 used, 7318664 free
FVMAIN_COMPACT [37%Full] 3440640 total, 1287776 used, 2152864 free
After: FV Space Information
SECFV [10%Full] 212992 total, 22112 used, 190880 free
PEIFV [19%Full] 917504 total, 176392 used, 741112 free
DXEFV [31%Full] 11534336 total, 3657112 used, 7877224 free
FVMAIN_COMPACT [33%Full] 3440640 total, 1153896 used, 2286744 free
Cc: Liming Gao <liming.gao@intel.com>
Cc: Marvin H?user <mhaeuser@outlook.de>
Cc: Zhiguang Liu <zhiguang.liu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Reviewed-by: Zhiguang Liu <zhiguang.liu@intel.com>
Signed-off-by: Vitaly Cheptsov <vit9696@protonmail.com>
2020-03-27 11:45:59 +01:00
|
|
|
DEBUG_CLANGPDB_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /ALIGN:32 /FILEALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DEBUG:GHASH /MLLVM:-exception-model=wineh /lldmap
|
2019-11-14 09:00:53 +01:00
|
|
|
DEBUG_CLANGPDB_IA32_DLINK2_FLAGS =
|
|
|
|
|
2022-12-16 20:50:20 +01:00
|
|
|
RELEASE_CLANGPDB_IA32_CC_FLAGS = DEF(CLANGPDB_ALL_CC_FLAGS) -m32 -Oz -flto -march=i586 DEF(CLANGPDB_IA32_TARGET) -malign-double
|
BaseTools: Use SEH exceptions in CLANGPDB for IA32
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2628
This patch reduces the size of IA32 binaries by ensuring that
no .debug_frame / .eh_frame sections are generated through forcing
SEH exception model, which is already the default in clang for X64.
EDK II does not support exceptions, and in future we should disable
them instead of switching to some other variant. Currently this
is not possible due to the following LLVM bugs:
https://bugs.llvm.org/show_bug.cgi?id=45324
https://bugs.llvm.org/show_bug.cgi?id=45325
Upon applying this patch OvmfPkgIA32.dsc compilation in DEBUG mode
gets the following size decrease with clang 9.0.1.
Before: FV Space Information
SECFV [11%Full] 212992 total, 24512 used, 188480 free
PEIFV [22%Full] 917504 total, 203048 used, 714456 free
DXEFV [36%Full] 11534336 total, 4215672 used, 7318664 free
FVMAIN_COMPACT [37%Full] 3440640 total, 1287776 used, 2152864 free
After: FV Space Information
SECFV [10%Full] 212992 total, 22112 used, 190880 free
PEIFV [19%Full] 917504 total, 176392 used, 741112 free
DXEFV [31%Full] 11534336 total, 3657112 used, 7877224 free
FVMAIN_COMPACT [33%Full] 3440640 total, 1153896 used, 2286744 free
Cc: Liming Gao <liming.gao@intel.com>
Cc: Marvin H?user <mhaeuser@outlook.de>
Cc: Zhiguang Liu <zhiguang.liu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Reviewed-by: Zhiguang Liu <zhiguang.liu@intel.com>
Signed-off-by: Vitaly Cheptsov <vit9696@protonmail.com>
2020-03-27 11:45:59 +01:00
|
|
|
RELEASE_CLANGPDB_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /ALIGN:32 /FILEALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /MERGE:.rdata=.data /MLLVM:-exception-model=wineh /lldmap
|
2019-11-14 09:00:53 +01:00
|
|
|
RELEASE_CLANGPDB_IA32_DLINK2_FLAGS =
|
|
|
|
|
2022-12-16 20:50:20 +01:00
|
|
|
NOOPT_CLANGPDB_IA32_CC_FLAGS = DEF(CLANGPDB_ALL_CC_FLAGS) -m32 -O0 -march=i586 DEF(CLANGPDB_IA32_TARGET) -gcodeview -malign-double
|
BaseTools: Use SEH exceptions in CLANGPDB for IA32
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2628
This patch reduces the size of IA32 binaries by ensuring that
no .debug_frame / .eh_frame sections are generated through forcing
SEH exception model, which is already the default in clang for X64.
EDK II does not support exceptions, and in future we should disable
them instead of switching to some other variant. Currently this
is not possible due to the following LLVM bugs:
https://bugs.llvm.org/show_bug.cgi?id=45324
https://bugs.llvm.org/show_bug.cgi?id=45325
Upon applying this patch OvmfPkgIA32.dsc compilation in DEBUG mode
gets the following size decrease with clang 9.0.1.
Before: FV Space Information
SECFV [11%Full] 212992 total, 24512 used, 188480 free
PEIFV [22%Full] 917504 total, 203048 used, 714456 free
DXEFV [36%Full] 11534336 total, 4215672 used, 7318664 free
FVMAIN_COMPACT [37%Full] 3440640 total, 1287776 used, 2152864 free
After: FV Space Information
SECFV [10%Full] 212992 total, 22112 used, 190880 free
PEIFV [19%Full] 917504 total, 176392 used, 741112 free
DXEFV [31%Full] 11534336 total, 3657112 used, 7877224 free
FVMAIN_COMPACT [33%Full] 3440640 total, 1153896 used, 2286744 free
Cc: Liming Gao <liming.gao@intel.com>
Cc: Marvin H?user <mhaeuser@outlook.de>
Cc: Zhiguang Liu <zhiguang.liu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Reviewed-by: Zhiguang Liu <zhiguang.liu@intel.com>
Signed-off-by: Vitaly Cheptsov <vit9696@protonmail.com>
2020-03-27 11:45:59 +01:00
|
|
|
NOOPT_CLANGPDB_IA32_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /ALIGN:32 /FILEALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /MACHINE:X86 /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DEBUG:GHASH /MLLVM:-exception-model=wineh /lldmap
|
2019-11-14 09:00:53 +01:00
|
|
|
NOOPT_CLANGPDB_IA32_DLINK2_FLAGS =
|
2019-10-17 08:55:46 +02:00
|
|
|
|
|
|
|
##########################
|
|
|
|
# CLANGWIN X64 definitions
|
|
|
|
##########################
|
2019-11-14 09:00:53 +01:00
|
|
|
*_CLANGPDB_X64_CC_PATH = DEF(CLANGPDB_X64_PREFIX)clang
|
|
|
|
*_CLANGPDB_X64_SLINK_PATH = DEF(CLANGPDB_X64_PREFIX)llvm-lib
|
|
|
|
*_CLANGPDB_X64_DLINK_PATH = DEF(CLANGPDB_X64_PREFIX)lld-link
|
|
|
|
*_CLANGPDB_X64_ASLDLINK_PATH = DEF(CLANGPDB_X64_PREFIX)lld-link
|
|
|
|
*_CLANGPDB_X64_ASM_PATH = DEF(CLANGPDB_X64_PREFIX)clang
|
|
|
|
*_CLANGPDB_X64_PP_PATH = DEF(CLANGPDB_X64_PREFIX)clang
|
|
|
|
*_CLANGPDB_X64_VFRPP_PATH = DEF(CLANGPDB_X64_PREFIX)clang
|
|
|
|
*_CLANGPDB_X64_ASLCC_PATH = DEF(CLANGPDB_X64_PREFIX)clang
|
|
|
|
*_CLANGPDB_X64_ASLPP_PATH = DEF(CLANGPDB_X64_PREFIX)clang
|
|
|
|
*_CLANGPDB_X64_RC_PATH = DEF(CLANGPDB_IA32_PREFIX)llvm-rc
|
|
|
|
|
|
|
|
*_CLANGPDB_X64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -m64 -fno-lto DEF(CLANGPDB_X64_TARGET)
|
|
|
|
*_CLANGPDB_X64_ASM_FLAGS = DEF(GCC_ASM_FLAGS) -m64 DEF(CLANGPDB_X64_TARGET)
|
|
|
|
*_CLANGPDB_X64_OBJCOPY_FLAGS =
|
|
|
|
*_CLANGPDB_X64_NASM_FLAGS = -f win64
|
|
|
|
*_CLANGPDB_X64_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGPDB_X64_TARGET)
|
|
|
|
*_CLANGPDB_X64_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGPDB_X64_TARGET)
|
|
|
|
*_CLANGPDB_X64_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGPDB_X64_TARGET)
|
|
|
|
|
2020-02-07 05:02:19 +01:00
|
|
|
DEBUG_CLANGPDB_X64_CC_FLAGS = DEF(CLANGPDB_ALL_CC_FLAGS) -m64 "-DEFIAPI=__attribute__((ms_abi))" -mno-red-zone -mcmodel=small -Oz -flto DEF(CLANGPDB_X64_TARGET) -gcodeview -funwind-tables
|
BaseTools: Use SEH exceptions in CLANGPDB for IA32
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2628
This patch reduces the size of IA32 binaries by ensuring that
no .debug_frame / .eh_frame sections are generated through forcing
SEH exception model, which is already the default in clang for X64.
EDK II does not support exceptions, and in future we should disable
them instead of switching to some other variant. Currently this
is not possible due to the following LLVM bugs:
https://bugs.llvm.org/show_bug.cgi?id=45324
https://bugs.llvm.org/show_bug.cgi?id=45325
Upon applying this patch OvmfPkgIA32.dsc compilation in DEBUG mode
gets the following size decrease with clang 9.0.1.
Before: FV Space Information
SECFV [11%Full] 212992 total, 24512 used, 188480 free
PEIFV [22%Full] 917504 total, 203048 used, 714456 free
DXEFV [36%Full] 11534336 total, 4215672 used, 7318664 free
FVMAIN_COMPACT [37%Full] 3440640 total, 1287776 used, 2152864 free
After: FV Space Information
SECFV [10%Full] 212992 total, 22112 used, 190880 free
PEIFV [19%Full] 917504 total, 176392 used, 741112 free
DXEFV [31%Full] 11534336 total, 3657112 used, 7877224 free
FVMAIN_COMPACT [33%Full] 3440640 total, 1153896 used, 2286744 free
Cc: Liming Gao <liming.gao@intel.com>
Cc: Marvin H?user <mhaeuser@outlook.de>
Cc: Zhiguang Liu <zhiguang.liu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Reviewed-by: Zhiguang Liu <zhiguang.liu@intel.com>
Signed-off-by: Vitaly Cheptsov <vit9696@protonmail.com>
2020-03-27 11:45:59 +01:00
|
|
|
DEBUG_CLANGPDB_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /ALIGN:32 /FILEALIGN:32 /Machine:X64 /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DEBUG:GHASH /MLLVM:-exception-model=wineh /lldmap
|
2019-11-14 09:00:53 +01:00
|
|
|
DEBUG_CLANGPDB_X64_DLINK2_FLAGS =
|
2020-02-07 05:02:19 +01:00
|
|
|
DEBUG_CLANGPDB_X64_GENFW_FLAGS = --keepexceptiontable
|
2019-11-14 09:00:53 +01:00
|
|
|
|
2020-02-07 05:02:19 +01:00
|
|
|
RELEASE_CLANGPDB_X64_CC_FLAGS = DEF(CLANGPDB_ALL_CC_FLAGS) -m64 "-DEFIAPI=__attribute__((ms_abi))" -mno-red-zone -mcmodel=small -Oz -flto DEF(CLANGPDB_X64_TARGET) -fno-unwind-tables
|
BaseTools: Use SEH exceptions in CLANGPDB for IA32
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2628
This patch reduces the size of IA32 binaries by ensuring that
no .debug_frame / .eh_frame sections are generated through forcing
SEH exception model, which is already the default in clang for X64.
EDK II does not support exceptions, and in future we should disable
them instead of switching to some other variant. Currently this
is not possible due to the following LLVM bugs:
https://bugs.llvm.org/show_bug.cgi?id=45324
https://bugs.llvm.org/show_bug.cgi?id=45325
Upon applying this patch OvmfPkgIA32.dsc compilation in DEBUG mode
gets the following size decrease with clang 9.0.1.
Before: FV Space Information
SECFV [11%Full] 212992 total, 24512 used, 188480 free
PEIFV [22%Full] 917504 total, 203048 used, 714456 free
DXEFV [36%Full] 11534336 total, 4215672 used, 7318664 free
FVMAIN_COMPACT [37%Full] 3440640 total, 1287776 used, 2152864 free
After: FV Space Information
SECFV [10%Full] 212992 total, 22112 used, 190880 free
PEIFV [19%Full] 917504 total, 176392 used, 741112 free
DXEFV [31%Full] 11534336 total, 3657112 used, 7877224 free
FVMAIN_COMPACT [33%Full] 3440640 total, 1153896 used, 2286744 free
Cc: Liming Gao <liming.gao@intel.com>
Cc: Marvin H?user <mhaeuser@outlook.de>
Cc: Zhiguang Liu <zhiguang.liu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Reviewed-by: Zhiguang Liu <zhiguang.liu@intel.com>
Signed-off-by: Vitaly Cheptsov <vit9696@protonmail.com>
2020-03-27 11:45:59 +01:00
|
|
|
RELEASE_CLANGPDB_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /IGNORE:4254 /OPT:REF /OPT:ICF=10 /ALIGN:32 /FILEALIGN:32 /SECTION:.xdata,D /SECTION:.pdata,D /Machine:X64 /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /MERGE:.rdata=.data /MLLVM:-exception-model=wineh /lldmap
|
2019-11-14 09:00:53 +01:00
|
|
|
RELEASE_CLANGPDB_X64_DLINK2_FLAGS =
|
2020-02-07 05:02:19 +01:00
|
|
|
RELEASE_CLANGPDB_X64_GENFW_FLAGS =
|
2019-11-14 09:00:53 +01:00
|
|
|
|
2020-02-07 05:02:19 +01:00
|
|
|
NOOPT_CLANGPDB_X64_CC_FLAGS = DEF(CLANGPDB_ALL_CC_FLAGS) -m64 "-DEFIAPI=__attribute__((ms_abi))" -mno-red-zone -mcmodel=small -O0 DEF(CLANGPDB_X64_TARGET) -gcodeview -funwind-tables
|
BaseTools: Use SEH exceptions in CLANGPDB for IA32
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2628
This patch reduces the size of IA32 binaries by ensuring that
no .debug_frame / .eh_frame sections are generated through forcing
SEH exception model, which is already the default in clang for X64.
EDK II does not support exceptions, and in future we should disable
them instead of switching to some other variant. Currently this
is not possible due to the following LLVM bugs:
https://bugs.llvm.org/show_bug.cgi?id=45324
https://bugs.llvm.org/show_bug.cgi?id=45325
Upon applying this patch OvmfPkgIA32.dsc compilation in DEBUG mode
gets the following size decrease with clang 9.0.1.
Before: FV Space Information
SECFV [11%Full] 212992 total, 24512 used, 188480 free
PEIFV [22%Full] 917504 total, 203048 used, 714456 free
DXEFV [36%Full] 11534336 total, 4215672 used, 7318664 free
FVMAIN_COMPACT [37%Full] 3440640 total, 1287776 used, 2152864 free
After: FV Space Information
SECFV [10%Full] 212992 total, 22112 used, 190880 free
PEIFV [19%Full] 917504 total, 176392 used, 741112 free
DXEFV [31%Full] 11534336 total, 3657112 used, 7877224 free
FVMAIN_COMPACT [33%Full] 3440640 total, 1153896 used, 2286744 free
Cc: Liming Gao <liming.gao@intel.com>
Cc: Marvin H?user <mhaeuser@outlook.de>
Cc: Zhiguang Liu <zhiguang.liu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
Reviewed-by: Zhiguang Liu <zhiguang.liu@intel.com>
Signed-off-by: Vitaly Cheptsov <vit9696@protonmail.com>
2020-03-27 11:45:59 +01:00
|
|
|
NOOPT_CLANGPDB_X64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF /OPT:ICF=10 /ALIGN:32 /FILEALIGN:32 /Machine:X64 /DLL /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /SAFESEH:NO /BASE:0 /DEBUG:GHASH /MLLVM:-exception-model=wineh /lldmap
|
2019-11-14 09:00:53 +01:00
|
|
|
NOOPT_CLANGPDB_X64_DLINK2_FLAGS =
|
2020-02-07 05:02:19 +01:00
|
|
|
NOOPT_CLANGPDB_X64_GENFW_FLAGS = --keepexceptiontable
|
2010-07-21 04:46:15 +02:00
|
|
|
|
2021-06-02 10:11:45 +02:00
|
|
|
####################################################################################
|
|
|
|
#
|
|
|
|
# CLANGDWARF - This configuration is used to compile under Windows/Linux/Mac to produce
|
|
|
|
# ELF binaries using LLVM/Clang/LLD with Link Time Optimization enabled
|
2021-06-02 10:11:43 +02:00
|
|
|
#
|
|
|
|
####################################################################################
|
2021-06-02 10:11:45 +02:00
|
|
|
*_CLANGDWARF_*_*_FAMILY = GCC
|
2023-05-10 00:30:28 +02:00
|
|
|
|
2021-06-02 10:11:45 +02:00
|
|
|
*_CLANGDWARF_*_MAKE_PATH = ENV(CLANG_HOST_BIN)make
|
|
|
|
*_CLANGDWARF_*_*_DLL = ENV(CLANGDWARF_DLL)
|
|
|
|
*_CLANGDWARF_*_ASL_PATH = DEF(UNIX_IASL_BIN)
|
2021-06-02 10:11:43 +02:00
|
|
|
|
2021-06-02 10:11:45 +02:00
|
|
|
*_CLANGDWARF_*_APP_FLAGS =
|
|
|
|
*_CLANGDWARF_*_ASL_FLAGS = DEF(IASL_FLAGS)
|
|
|
|
*_CLANGDWARF_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
2021-06-02 10:11:43 +02:00
|
|
|
|
2021-06-02 10:11:45 +02:00
|
|
|
DEFINE CLANGDWARF_IA32_PREFIX = ENV(CLANG_BIN)
|
|
|
|
DEFINE CLANGDWARF_X64_PREFIX = ENV(CLANG_BIN)
|
2021-06-02 10:11:43 +02:00
|
|
|
|
|
|
|
# LLVM/CLANG doesn't support -n link option. So, it can't share the same IA32_X64_DLINK_COMMON flag.
|
|
|
|
# LLVM/CLANG doesn't support common page size. So, it can't share the same GccBase.lds script.
|
2021-06-02 10:11:45 +02:00
|
|
|
DEFINE CLANGDWARF_IA32_X64_DLINK_COMMON = -nostdlib -Wl,-q,--gc-sections -z max-page-size=0x40
|
|
|
|
DEFINE CLANGDWARF_DLINK2_FLAGS_COMMON = -Wl,--script=$(EDK_TOOLS_PATH)/Scripts/ClangBase.lds
|
|
|
|
DEFINE CLANGDWARF_IA32_X64_ASLDLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0 DEF(CLANGDWARF_DLINK2_FLAGS_COMMON) -Wl,--entry,ReferenceAcpiTable -u ReferenceAcpiTable
|
2023-04-03 16:29:15 +02:00
|
|
|
DEFINE CLANGDWARF_IA32_X64_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_COMMON) -Wl,--entry,$(IMAGE_ENTRY_POINT) -u $(IMAGE_ENTRY_POINT) -Wl,-Map,$(DEST_DIR_DEBUG)/$(BASE_NAME).map,--whole-archive -Wl,-z,notext
|
2021-06-02 10:11:45 +02:00
|
|
|
DEFINE CLANGDWARF_IA32_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x220 DEF(CLANGDWARF_DLINK2_FLAGS_COMMON)
|
|
|
|
DEFINE CLANGDWARF_X64_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x228 DEF(CLANGDWARF_DLINK2_FLAGS_COMMON)
|
2021-06-02 10:11:43 +02:00
|
|
|
|
2023-05-01 15:36:16 +02:00
|
|
|
DEFINE CLANGDWARF_IA32_TARGET = -target i686-pc-linux-gnu
|
|
|
|
DEFINE CLANGDWARF_X64_TARGET = -target x86_64-pc-linux-gnu
|
|
|
|
|
2023-05-10 16:44:09 +02:00
|
|
|
DEFINE CLANGDWARF_WARNING_OVERRIDES = -Wno-parentheses-equality -Wno-tautological-compare -Wno-tautological-constant-out-of-range-compare -Wno-empty-body -Wno-unused-const-variable -Wno-varargs -Wno-unknown-warning-option -Wno-unused-but-set-variable -Wno-unused-const-variable -Wno-unaligned-access -Wno-unneeded-internal-declaration
|
2023-05-01 15:36:16 +02:00
|
|
|
DEFINE CLANGDWARF_ALL_CC_FLAGS = DEF(GCC48_ALL_CC_FLAGS) DEF(CLANGDWARF_WARNING_OVERRIDES) -fno-stack-protector -mms-bitfields -Wno-address -Wno-shift-negative-value -Wno-unknown-pragmas -Wno-incompatible-library-redeclaration -fno-asynchronous-unwind-tables -mno-sse -mno-mmx -msoft-float -mno-implicit-float -ftrap-function=undefined_behavior_has_been_optimized_away_by_clang -funsigned-char -fno-ms-extensions -Wno-null-dereference
|
|
|
|
|
2021-06-02 10:11:43 +02:00
|
|
|
###########################
|
2021-06-02 10:11:45 +02:00
|
|
|
# CLANGDWARF IA32 definitions
|
2021-06-02 10:11:43 +02:00
|
|
|
###########################
|
2021-06-02 10:11:45 +02:00
|
|
|
*_CLANGDWARF_IA32_CC_PATH = DEF(CLANGDWARF_IA32_PREFIX)clang
|
|
|
|
*_CLANGDWARF_IA32_SLINK_PATH = DEF(CLANGDWARF_IA32_PREFIX)llvm-ar
|
|
|
|
*_CLANGDWARF_IA32_DLINK_PATH = DEF(CLANGDWARF_IA32_PREFIX)clang
|
|
|
|
*_CLANGDWARF_IA32_ASLDLINK_PATH = DEF(CLANGDWARF_IA32_PREFIX)clang
|
|
|
|
*_CLANGDWARF_IA32_ASM_PATH = DEF(CLANGDWARF_IA32_PREFIX)clang
|
|
|
|
*_CLANGDWARF_IA32_PP_PATH = DEF(CLANGDWARF_IA32_PREFIX)clang
|
|
|
|
*_CLANGDWARF_IA32_VFRPP_PATH = DEF(CLANGDWARF_IA32_PREFIX)clang
|
|
|
|
*_CLANGDWARF_IA32_ASLCC_PATH = DEF(CLANGDWARF_IA32_PREFIX)clang
|
|
|
|
*_CLANGDWARF_IA32_ASLPP_PATH = DEF(CLANGDWARF_IA32_PREFIX)clang
|
2023-05-10 00:33:00 +02:00
|
|
|
*_CLANGDWARF_IA32_RC_PATH = DEF(CLANGDWARF_IA32_PREFIX)llvm-objcopy
|
2021-06-02 10:11:45 +02:00
|
|
|
|
2023-05-01 15:36:16 +02:00
|
|
|
*_CLANGDWARF_IA32_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -m32 -fno-lto DEF(CLANGDWARF_IA32_TARGET)
|
2023-04-05 20:09:09 +02:00
|
|
|
*_CLANGDWARF_IA32_ASLDLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_i386 -fuse-ld=lld -no-pie
|
2023-05-01 15:36:16 +02:00
|
|
|
*_CLANGDWARF_IA32_ASM_FLAGS = DEF(GCC5_ASM_FLAGS) -m32 -march=i386 DEF(CLANGDWARF_IA32_TARGET)
|
2021-06-02 10:11:45 +02:00
|
|
|
*_CLANGDWARF_IA32_RC_FLAGS = DEF(GCC_IA32_RC_FLAGS)
|
|
|
|
*_CLANGDWARF_IA32_OBJCOPY_FLAGS =
|
|
|
|
*_CLANGDWARF_IA32_NASM_FLAGS = -f elf32
|
2023-05-01 15:36:16 +02:00
|
|
|
*_CLANGDWARF_IA32_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGDWARF_IA32_TARGET)
|
|
|
|
*_CLANGDWARF_IA32_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGDWARF_IA32_TARGET)
|
|
|
|
*_CLANGDWARF_IA32_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGDWARF_IA32_TARGET)
|
2021-06-02 10:11:45 +02:00
|
|
|
|
2023-05-01 15:36:16 +02:00
|
|
|
DEBUG_CLANGDWARF_IA32_CC_FLAGS = DEF(CLANGDWARF_ALL_CC_FLAGS) -fno-pic -fno-pie -m32 -Oz -flto -march=i586 DEF(CLANGDWARF_IA32_TARGET) -g -malign-double
|
2021-06-02 10:11:45 +02:00
|
|
|
DEBUG_CLANGDWARF_IA32_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_FLAGS) -flto -Wl,-O3 -Wl,-melf_i386 -Wl,--oformat,elf32-i386
|
2023-04-05 20:09:09 +02:00
|
|
|
DEBUG_CLANGDWARF_IA32_DLINK2_FLAGS = DEF(CLANGDWARF_IA32_DLINK2_FLAGS) -O3 -fuse-ld=lld -no-pie
|
2021-06-02 10:11:45 +02:00
|
|
|
|
2023-05-01 15:36:16 +02:00
|
|
|
RELEASE_CLANGDWARF_IA32_CC_FLAGS = DEF(CLANGDWARF_ALL_CC_FLAGS) -fno-pic -fno-pie -m32 -Oz -flto -march=i586 DEF(CLANGDWARF_IA32_TARGET) -malign-double
|
2021-06-02 10:11:45 +02:00
|
|
|
RELEASE_CLANGDWARF_IA32_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_FLAGS) -flto -Wl,-O3 -Wl,-melf_i386 -Wl,--oformat,elf32-i386
|
2023-04-05 20:09:09 +02:00
|
|
|
RELEASE_CLANGDWARF_IA32_DLINK2_FLAGS = DEF(CLANGDWARF_IA32_DLINK2_FLAGS) -O3 -fuse-ld=lld -no-pie
|
2021-06-02 10:11:45 +02:00
|
|
|
|
2023-05-01 15:36:16 +02:00
|
|
|
NOOPT_CLANGDWARF_IA32_CC_FLAGS = DEF(CLANGDWARF_ALL_CC_FLAGS) -fno-pic -fno-pie -m32 -O0 -march=i586 DEF(CLANGDWARF_IA32_TARGET) -g -malign-double
|
2021-06-02 10:11:45 +02:00
|
|
|
NOOPT_CLANGDWARF_IA32_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_FLAGS) -Wl,-O0 -Wl,-melf_i386 -Wl,--oformat,elf32-i386
|
2023-04-05 20:09:09 +02:00
|
|
|
NOOPT_CLANGDWARF_IA32_DLINK2_FLAGS = DEF(CLANGDWARF_IA32_DLINK2_FLAGS) -O0 -fuse-ld=lld -no-pie
|
2021-06-02 10:11:43 +02:00
|
|
|
|
|
|
|
##########################
|
2021-06-02 10:11:45 +02:00
|
|
|
# CLANGDWARF X64 definitions
|
2021-06-02 10:11:43 +02:00
|
|
|
##########################
|
2021-06-02 10:11:45 +02:00
|
|
|
*_CLANGDWARF_X64_CC_PATH = DEF(CLANGDWARF_X64_PREFIX)clang
|
|
|
|
*_CLANGDWARF_X64_SLINK_PATH = DEF(CLANGDWARF_X64_PREFIX)llvm-ar
|
|
|
|
*_CLANGDWARF_X64_DLINK_PATH = DEF(CLANGDWARF_X64_PREFIX)clang
|
|
|
|
*_CLANGDWARF_X64_ASLDLINK_PATH = DEF(CLANGDWARF_X64_PREFIX)clang
|
|
|
|
*_CLANGDWARF_X64_ASM_PATH = DEF(CLANGDWARF_X64_PREFIX)clang
|
|
|
|
*_CLANGDWARF_X64_PP_PATH = DEF(CLANGDWARF_X64_PREFIX)clang
|
|
|
|
*_CLANGDWARF_X64_VFRPP_PATH = DEF(CLANGDWARF_X64_PREFIX)clang
|
|
|
|
*_CLANGDWARF_X64_ASLCC_PATH = DEF(CLANGDWARF_X64_PREFIX)clang
|
|
|
|
*_CLANGDWARF_X64_ASLPP_PATH = DEF(CLANGDWARF_X64_PREFIX)clang
|
2023-05-10 00:33:00 +02:00
|
|
|
*_CLANGDWARF_X64_RC_PATH = DEF(CLANGDWARF_X64_PREFIX)llvm-objcopy
|
2021-06-02 10:11:45 +02:00
|
|
|
|
2023-05-01 15:36:16 +02:00
|
|
|
*_CLANGDWARF_X64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -m64 -fno-lto DEF(CLANGDWARF_X64_TARGET)
|
2021-06-02 10:11:45 +02:00
|
|
|
*_CLANGDWARF_X64_ASLDLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_x86_64 -fuse-ld=lld
|
2023-05-01 15:36:16 +02:00
|
|
|
*_CLANGDWARF_X64_ASM_FLAGS = DEF(GCC5_ASM_FLAGS) -m64 DEF(CLANGDWARF_X64_TARGET)
|
2021-06-02 10:11:45 +02:00
|
|
|
*_CLANGDWARF_X64_RC_FLAGS = DEF(GCC_X64_RC_FLAGS)
|
|
|
|
*_CLANGDWARF_X64_OBJCOPY_FLAGS =
|
|
|
|
*_CLANGDWARF_X64_NASM_FLAGS = -f elf64
|
2023-05-01 15:36:16 +02:00
|
|
|
*_CLANGDWARF_X64_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGDWARF_X64_TARGET)
|
|
|
|
*_CLANGDWARF_X64_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGDWARF_X64_TARGET)
|
|
|
|
*_CLANGDWARF_X64_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGDWARF_X64_TARGET)
|
2021-06-02 10:11:45 +02:00
|
|
|
|
2023-05-24 16:05:51 +02:00
|
|
|
DEBUG_CLANGDWARF_X64_CC_FLAGS = DEF(CLANGDWARF_ALL_CC_FLAGS) -m64 "-DEFIAPI=__attribute__((ms_abi))" -mno-red-zone -mcmodel=small -fpie -fdirect-access-external-data -Oz -flto DEF(CLANGDWARF_X64_TARGET) -g
|
2021-06-02 10:11:45 +02:00
|
|
|
DEBUG_CLANGDWARF_X64_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_FLAGS) -flto -Wl,-O3 -Wl,-melf_x86_64 -Wl,--oformat,elf64-x86-64 -Wl,-pie -mcmodel=small -Wl,--apply-dynamic-relocs
|
|
|
|
DEBUG_CLANGDWARF_X64_DLINK2_FLAGS = DEF(CLANGDWARF_X64_DLINK2_FLAGS) -O3 -fuse-ld=lld
|
|
|
|
|
2023-05-24 16:05:51 +02:00
|
|
|
RELEASE_CLANGDWARF_X64_CC_FLAGS = DEF(CLANGDWARF_ALL_CC_FLAGS) -m64 "-DEFIAPI=__attribute__((ms_abi))" -mno-red-zone -mcmodel=small -fpie -fdirect-access-external-data -Oz -flto DEF(CLANGDWARF_X64_TARGET)
|
2021-06-02 10:11:45 +02:00
|
|
|
RELEASE_CLANGDWARF_X64_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_FLAGS) -flto -Wl,-O3 -Wl,-melf_x86_64 -Wl,--oformat,elf64-x86-64 -Wl,-pie -mcmodel=small -Wl,--apply-dynamic-relocs
|
|
|
|
RELEASE_CLANGDWARF_X64_DLINK2_FLAGS = DEF(CLANGDWARF_X64_DLINK2_FLAGS) -O3 -fuse-ld=lld
|
|
|
|
|
2023-05-24 16:05:51 +02:00
|
|
|
NOOPT_CLANGDWARF_X64_CC_FLAGS = DEF(CLANGDWARF_ALL_CC_FLAGS) -m64 "-DEFIAPI=__attribute__((ms_abi))" -mno-red-zone -mcmodel=small -fpie -fdirect-access-external-data -O0 DEF(CLANGDWARF_X64_TARGET) -g
|
2021-06-02 10:11:45 +02:00
|
|
|
NOOPT_CLANGDWARF_X64_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_FLAGS) -Wl,-O0 -Wl,-melf_x86_64 -Wl,--oformat,elf64-x86-64 -Wl,-pie -mcmodel=small -Wl,--apply-dynamic-relocs
|
|
|
|
NOOPT_CLANGDWARF_X64_DLINK2_FLAGS = DEF(CLANGDWARF_X64_DLINK2_FLAGS) -O0 -fuse-ld=lld
|
2021-06-02 10:11:43 +02:00
|
|
|
|
2023-05-01 15:44:50 +02:00
|
|
|
##################
|
|
|
|
# CLANGDWARF ARM definitions
|
|
|
|
##################
|
|
|
|
DEFINE CLANGDWARF_ARM_TARGET = -target arm-linux-gnueabi
|
|
|
|
DEFINE CLANGDWARF_ARM_CC_FLAGS = DEF(GCC_ARM_CC_FLAGS) DEF(CLANGDWARF_ARM_TARGET) DEF(CLANGDWARF_WARNING_OVERRIDES) -mno-movt
|
|
|
|
DEFINE CLANGDWARF_ARM_DLINK_FLAGS = DEF(CLANGDWARF_ARM_TARGET) DEF(GCC_ARM_DLINK_FLAGS)
|
|
|
|
|
|
|
|
*_CLANGDWARF_ARM_PP_FLAGS = DEF(GCC_PP_FLAGS)
|
|
|
|
*_CLANGDWARF_ARM_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_CLANGDWARF_ARM_APP_FLAGS =
|
|
|
|
*_CLANGDWARF_ARM_ASL_FLAGS = DEF(IASL_FLAGS)
|
|
|
|
*_CLANGDWARF_ARM_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
|
|
|
*_CLANGDWARF_ARM_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
|
|
|
|
|
|
|
*_CLANGDWARF_ARM_CC_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_ARM_ASM_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_ARM_PP_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_ARM_VFRPP_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_ARM_ASLCC_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_ARM_ASLPP_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_ARM_DLINK_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_ARM_ASLDLINK_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
|
|
|
|
*_CLANGDWARF_ARM_SLINK_PATH = ENV(CLANGDWARF_BIN)llvm-ar
|
2023-05-11 08:55:20 +02:00
|
|
|
*_CLANGDWARF_ARM_RC_PATH = ENV(CLANGDWARF_BIN)llvm-objcopy
|
2023-05-01 15:44:50 +02:00
|
|
|
|
|
|
|
*_CLANGDWARF_ARM_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -fno-lto
|
|
|
|
*_CLANGDWARF_ARM_ASLDLINK_FLAGS = DEF(CLANGDWARF_ARM_TARGET) DEF(GCC_ARM_ASLDLINK_FLAGS)
|
|
|
|
*_CLANGDWARF_ARM_ASM_FLAGS = DEF(GCC_ASM_FLAGS) DEF(CLANGDWARF_ARM_TARGET) $(PLATFORM_FLAGS) -Qunused-arguments
|
|
|
|
*_CLANGDWARF_ARM_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x220
|
|
|
|
*_CLANGDWARF_ARM_PLATFORM_FLAGS = -march=armv7-a
|
|
|
|
*_CLANGDWARF_ARM_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGDWARF_ARM_TARGET) $(PLATFORM_FLAGS)
|
|
|
|
*_CLANGDWARF_ARM_RC_FLAGS = DEF(GCC_ARM_RC_FLAGS)
|
|
|
|
*_CLANGDWARF_ARM_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGDWARF_ARM_TARGET) $(PLATFORM_FLAGS)
|
|
|
|
*_CLANGDWARF_ARM_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGDWARF_ARM_TARGET)
|
|
|
|
*_CLANGDWARF_ARM_CC_XIPFLAGS = DEF(GCC_ARM_CC_XIPFLAGS)
|
|
|
|
|
|
|
|
DEBUG_CLANGDWARF_ARM_CC_FLAGS = DEF(CLANGDWARF_ARM_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O1
|
2023-05-01 15:50:37 +02:00
|
|
|
DEBUG_CLANGDWARF_ARM_DLINK_FLAGS = DEF(CLANGDWARF_ARM_DLINK_FLAGS) -flto -Wl,-O1 -fuse-ld=lld -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-arm -Wl,-plugin-opt=-pass-through=-llto-arm -Wl,--no-pie,--no-relax
|
2023-05-01 15:44:50 +02:00
|
|
|
NOOPT_CLANGDWARF_ARM_CC_FLAGS = DEF(CLANGDWARF_ARM_CC_FLAGS) $(PLATFORM_FLAGS) -O0
|
2023-05-01 15:50:37 +02:00
|
|
|
NOOPT_CLANGDWARF_ARM_DLINK_FLAGS = DEF(CLANGDWARF_ARM_DLINK_FLAGS) -fuse-ld=lld -Wl,--no-pie,--no-relax
|
2023-05-01 15:44:50 +02:00
|
|
|
RELEASE_CLANGDWARF_ARM_CC_FLAGS = DEF(CLANGDWARF_ARM_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O3
|
2023-05-01 15:50:37 +02:00
|
|
|
RELEASE_CLANGDWARF_ARM_DLINK_FLAGS = DEF(CLANGDWARF_ARM_DLINK_FLAGS) -flto -Wl,-O3 -fuse-ld=lld -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-arm -Wl,-plugin-opt=-pass-through=-llto-arm -Wl,--no-pie,--no-relax
|
2023-05-01 15:44:50 +02:00
|
|
|
|
|
|
|
##################
|
|
|
|
# CLANGDWARF AARCH64 definitions
|
|
|
|
##################
|
|
|
|
DEFINE CLANGDWARF_AARCH64_TARGET = -target aarch64-linux-gnu
|
|
|
|
DEFINE CLANGDWARF_AARCH64_CC_FLAGS = DEF(GCC_AARCH64_CC_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET) -mcmodel=small DEF(CLANGDWARF_WARNING_OVERRIDES)
|
|
|
|
DEFINE CLANGDWARF_AARCH64_DLINK_FLAGS = DEF(CLANGDWARF_AARCH64_TARGET) DEF(GCC_AARCH64_DLINK_FLAGS) -z common-page-size=0x1000
|
|
|
|
|
|
|
|
*_CLANGDWARF_AARCH64_PP_FLAGS = DEF(GCC_PP_FLAGS)
|
|
|
|
*_CLANGDWARF_AARCH64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
|
|
|
|
*_CLANGDWARF_AARCH64_APP_FLAGS =
|
|
|
|
*_CLANGDWARF_AARCH64_ASL_FLAGS = DEF(IASL_FLAGS)
|
|
|
|
*_CLANGDWARF_AARCH64_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
|
|
|
*_CLANGDWARF_AARCH64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
|
|
|
|
|
|
|
|
*_CLANGDWARF_AARCH64_CC_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_AARCH64_ASM_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_AARCH64_PP_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_AARCH64_VFRPP_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_AARCH64_ASLCC_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_AARCH64_ASLPP_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_AARCH64_DLINK_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
*_CLANGDWARF_AARCH64_ASLDLINK_PATH = ENV(CLANGDWARF_BIN)clang
|
|
|
|
|
|
|
|
*_CLANGDWARF_AARCH64_SLINK_PATH = ENV(CLANGDWARF_BIN)llvm-ar
|
2023-05-10 00:33:00 +02:00
|
|
|
*_CLANGDWARF_AARCH64_RC_PATH = ENV(CLANGDWARF_BIN)llvm-objcopy
|
2023-05-01 15:44:50 +02:00
|
|
|
|
|
|
|
*_CLANGDWARF_AARCH64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -fno-lto
|
|
|
|
*_CLANGDWARF_AARCH64_ASLDLINK_FLAGS = DEF(CLANGDWARF_AARCH64_TARGET) DEF(GCC_AARCH64_ASLDLINK_FLAGS)
|
|
|
|
*_CLANGDWARF_AARCH64_ASM_FLAGS = DEF(GCC_ASM_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET) $(PLATFORM_FLAGS) -Qunused-arguments
|
|
|
|
*_CLANGDWARF_AARCH64_DLINK_FLAGS = DEF(CLANGDWARF_AARCH64_TARGET) DEF(GCC_AARCH64_DLINK_FLAGS) -z common-page-size=0x1000
|
|
|
|
*_CLANGDWARF_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
|
|
|
|
*_CLANGDWARF_AARCH64_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x228
|
|
|
|
*_CLANGDWARF_AARCH64_PLATFORM_FLAGS =
|
|
|
|
*_CLANGDWARF_AARCH64_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET) $(PLATFORM_FLAGS)
|
|
|
|
*_CLANGDWARF_AARCH64_RC_FLAGS = DEF(GCC_AARCH64_RC_FLAGS) DEF(GCC_AARCH64_RC_BTI_FLAGS)
|
|
|
|
*_CLANGDWARF_AARCH64_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET) $(PLATFORM_FLAGS)
|
|
|
|
*_CLANGDWARF_AARCH64_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET)
|
|
|
|
*_CLANGDWARF_AARCH64_CC_XIPFLAGS = DEF(GCC_AARCH64_CC_XIPFLAGS)
|
|
|
|
|
|
|
|
DEBUG_CLANGDWARF_AARCH64_CC_FLAGS = DEF(CLANGDWARF_AARCH64_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O1
|
2023-05-01 15:50:37 +02:00
|
|
|
DEBUG_CLANGDWARF_AARCH64_DLINK_FLAGS = DEF(CLANGDWARF_AARCH64_DLINK_FLAGS) -flto -Wl,-O1 -fuse-ld=lld -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-aarch64 -Wl,-plugin-opt=-pass-through=-llto-aarch64 -Wl,--no-pie,--no-relax
|
2023-05-01 15:44:50 +02:00
|
|
|
NOOPT_CLANGDWARF_AARCH64_CC_FLAGS = DEF(CLANGDWARF_AARCH64_CC_FLAGS) $(PLATFORM_FLAGS) -O0
|
2023-05-01 15:50:37 +02:00
|
|
|
NOOPT_CLANGDWARF_AARCH64_DLINK_FLAGS = DEF(CLANGDWARF_AARCH64_DLINK_FLAGS) -fuse-ld=lld -Wl,--no-pie,--no-relax
|
2023-05-01 15:44:50 +02:00
|
|
|
RELEASE_CLANGDWARF_AARCH64_CC_FLAGS = DEF(CLANGDWARF_AARCH64_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O3
|
2023-05-01 15:50:37 +02:00
|
|
|
RELEASE_CLANGDWARF_AARCH64_DLINK_FLAGS = DEF(CLANGDWARF_AARCH64_DLINK_FLAGS) -flto -Wl,-O3 -fuse-ld=lld -L$(WORKSPACE)/ArmPkg/Library/GccLto -llto-aarch64 -Wl,-plugin-opt=-pass-through=-llto-aarch64 -Wl,--no-pie,--no-relax
|
2023-05-01 15:44:50 +02:00
|
|
|
|
2010-06-28 11:33:10 +02:00
|
|
|
#
|
2014-08-29 20:29:46 +02:00
|
|
|
#
|
|
|
|
# XCODE5 support
|
|
|
|
#
|
|
|
|
|
|
|
|
*_XCODE5_*_*_FAMILY = GCC
|
|
|
|
*_XCODE5_*_*_BUILDRULEFAMILY = XCODE
|
|
|
|
|
2017-05-16 20:59:52 +02:00
|
|
|
#
|
|
|
|
# use xcode-select to change Xcode version of command line tools
|
|
|
|
#
|
|
|
|
*_XCODE5_*_MAKE_PATH = make
|
|
|
|
*_XCODE5_*_CC_PATH = clang
|
|
|
|
*_XCODE5_*_SLINK_PATH = libtool
|
|
|
|
*_XCODE5_*_DLINK_PATH = ld
|
|
|
|
*_XCODE5_*_ASM_PATH = as
|
|
|
|
*_XCODE5_*_PP_PATH = clang
|
|
|
|
*_XCODE5_*_VFRPP_PATH = clang
|
|
|
|
*_XCODE5_*_ASL_PATH = iasl
|
|
|
|
*_XCODE5_*_ASLCC_PATH = clang
|
|
|
|
*_XCODE5_*_ASLPP_PATH = clang
|
|
|
|
*_XCODE5_*_ASLDLINK_PATH = ld
|
|
|
|
*_XCODE5_*_DSYMUTIL_PATH = /usr/bin/dsymutil
|
|
|
|
*_XCODE5_*_MTOC_PATH = /usr/local/bin/mtoc
|
2019-12-02 09:24:19 +01:00
|
|
|
*_XCODE5_*_DEPS_FLAGS = DEF(GCC_DEPS_FLAGS)
|
2014-08-29 20:29:46 +02:00
|
|
|
|
2017-05-16 20:59:52 +02:00
|
|
|
##################
|
|
|
|
# ASL definitions
|
|
|
|
##################
|
|
|
|
*_XCODE5_*_ASLCC_FLAGS = -x c -save-temps -g -O0 -fshort-wchar -fno-strict-aliasing -Wall -Werror -Wno-missing-braces -c -include AutoGen.h
|
|
|
|
*_XCODE5_*_ASLDLINK_FLAGS = -e _ReferenceAcpiTable -preload -segalign 0x20 -pie -seg1addr 0x240 -read_only_relocs suppress -map $(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
|
|
|
*_XCODE5_*_ASLPP_FLAGS = -x c -E -include AutoGen.h
|
|
|
|
*_XCODE5_*_ASL_FLAGS =
|
|
|
|
*_XCODE5_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
|
|
|
|
|
|
|
|
##################
|
|
|
|
# MTOC definitions
|
|
|
|
##################
|
2014-08-29 20:29:46 +02:00
|
|
|
|
|
|
|
DEBUG_XCODE5_*_MTOC_FLAGS = -align 0x20 -d $(DEBUG_DIR)/$(MODULE_NAME).dll
|
|
|
|
NOOPT_XCODE5_*_MTOC_FLAGS = -align 0x20 -d $(DEBUG_DIR)/$(MODULE_NAME).dll
|
2019-01-02 22:29:43 +01:00
|
|
|
RELEASE_XCODE5_*_MTOC_FLAGS = -align 0x20
|
2014-08-29 20:29:46 +02:00
|
|
|
|
|
|
|
####################
|
|
|
|
# IA-32 definitions
|
|
|
|
####################
|
|
|
|
DEBUG_XCODE5_IA32_DLINK_FLAGS = -arch i386 -u _$(IMAGE_ENTRY_POINT) -e _$(IMAGE_ENTRY_POINT) -preload -segalign 0x20 -pie -all_load -dead_strip -seg1addr 0x240 -read_only_relocs suppress -map $(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
|
|
|
NOOPT_XCODE5_IA32_DLINK_FLAGS = -arch i386 -u _$(IMAGE_ENTRY_POINT) -e _$(IMAGE_ENTRY_POINT) -preload -segalign 0x20 -pie -all_load -dead_strip -seg1addr 0x240 -read_only_relocs suppress -map $(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
|
|
|
RELEASE_XCODE5_IA32_DLINK_FLAGS = -arch i386 -u _$(IMAGE_ENTRY_POINT) -e _$(IMAGE_ENTRY_POINT) -preload -segalign 0x20 -pie -all_load -dead_strip -seg1addr 0x240 -read_only_relocs suppress -map $(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
|
|
|
|
|
|
|
*_XCODE5_IA32_SLINK_FLAGS = -static -o
|
|
|
|
DEBUG_XCODE5_IA32_ASM_FLAGS = -arch i386 -g
|
|
|
|
NOOPT_XCODE5_IA32_ASM_FLAGS = -arch i386 -g
|
2019-01-02 22:29:43 +01:00
|
|
|
RELEASE_XCODE5_IA32_ASM_FLAGS = -arch i386
|
2014-09-10 18:48:59 +02:00
|
|
|
*_XCODE5_IA32_NASM_FLAGS = -f macho32
|
2014-08-29 20:29:46 +02:00
|
|
|
|
|
|
|
|
2017-12-08 15:49:02 +01:00
|
|
|
DEBUG_XCODE5_IA32_CC_FLAGS = -arch i386 -c -g -Os -Wall -Werror -include AutoGen.h -funsigned-char -fno-stack-protector -fno-builtin -fshort-wchar -fasm-blocks -mdynamic-no-pic -mno-implicit-float -mms-bitfields -msoft-float -Wno-unused-parameter -Wno-missing-braces -Wno-missing-field-initializers -Wno-tautological-compare -Wno-sign-compare -Wno-varargs -ftrap-function=undefined_behavior_has_been_optimized_away_by_clang $(PLATFORM_FLAGS)
|
2018-01-10 16:24:26 +01:00
|
|
|
RELEASE_XCODE5_IA32_CC_FLAGS = -arch i386 -c -Os -Wall -Werror -include AutoGen.h -funsigned-char -fno-stack-protector -fno-builtin -fshort-wchar -fasm-blocks -mdynamic-no-pic -mno-implicit-float -mms-bitfields -msoft-float -Wno-unused-parameter -Wno-missing-braces -Wno-missing-field-initializers -Wno-tautological-compare -Wno-sign-compare -Wno-varargs -Wno-unused-const-variable -ftrap-function=undefined_behavior_has_been_optimized_away_by_clang $(PLATFORM_FLAGS)
|
2017-12-08 15:49:02 +01:00
|
|
|
NOOPT_XCODE5_IA32_CC_FLAGS = -arch i386 -c -g -O0 -Wall -Werror -include AutoGen.h -funsigned-char -fno-stack-protector -fno-builtin -fshort-wchar -fasm-blocks -mdynamic-no-pic -mno-implicit-float -mms-bitfields -msoft-float -Wno-unused-parameter -Wno-missing-braces -Wno-missing-field-initializers -Wno-tautological-compare -Wno-sign-compare -Wno-varargs -ftrap-function=undefined_behavior_has_been_optimized_away_by_clang $(PLATFORM_FLAGS)
|
2014-08-29 20:29:46 +02:00
|
|
|
|
|
|
|
##################
|
|
|
|
# X64 definitions
|
|
|
|
##################
|
|
|
|
DEBUG_XCODE5_X64_DLINK_FLAGS = -arch x86_64 -u _$(IMAGE_ENTRY_POINT) -e _$(IMAGE_ENTRY_POINT) -preload -segalign 0x20 -pie -all_load -dead_strip -seg1addr 0x240 -map $(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
|
|
|
NOOPT_XCODE5_X64_DLINK_FLAGS = -arch x86_64 -u _$(IMAGE_ENTRY_POINT) -e _$(IMAGE_ENTRY_POINT) -preload -segalign 0x20 -pie -all_load -dead_strip -seg1addr 0x240 -map $(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
|
|
|
RELEASE_XCODE5_X64_DLINK_FLAGS = -arch x86_64 -u _$(IMAGE_ENTRY_POINT) -e _$(IMAGE_ENTRY_POINT) -preload -segalign 0x20 -pie -all_load -dead_strip -seg1addr 0x240 -map $(DEST_DIR_DEBUG)/$(BASE_NAME).map
|
|
|
|
|
|
|
|
*_XCODE5_X64_SLINK_FLAGS = -static -o
|
|
|
|
DEBUG_XCODE5_X64_ASM_FLAGS = -arch x86_64 -g
|
|
|
|
NOOPT_XCODE5_X64_ASM_FLAGS = -arch x86_64 -g
|
2019-01-02 22:29:43 +01:00
|
|
|
RELEASE_XCODE5_X64_ASM_FLAGS = -arch x86_64
|
2014-09-10 18:48:59 +02:00
|
|
|
*_XCODE5_X64_NASM_FLAGS = -f macho64
|
2019-10-17 08:55:45 +02:00
|
|
|
*_XCODE5_*_PP_FLAGS = -E -x assembler-with-cpp -include AutoGen.h
|
|
|
|
*_XCODE5_*_VFRPP_FLAGS = -x c -E -P -DVFRCOMPILE -include $(MODULE_NAME)StrDefs.h
|
2014-08-29 20:29:46 +02:00
|
|
|
|
2019-08-15 22:11:59 +02:00
|
|
|
DEBUG_XCODE5_X64_CC_FLAGS = -target x86_64-pc-win32-macho -c -g -gdwarf -Os -Wall -Werror -Wextra -include AutoGen.h -funsigned-char -fno-ms-extensions -fno-stack-protector -fno-builtin -fshort-wchar -mno-implicit-float -mms-bitfields -Wno-unused-parameter -Wno-missing-braces -Wno-missing-field-initializers -Wno-tautological-compare -Wno-sign-compare -Wno-varargs -ftrap-function=undefined_behavior_has_been_optimized_away_by_clang -D NO_MSABI_VA_FUNCS $(PLATFORM_FLAGS)
|
|
|
|
NOOPT_XCODE5_X64_CC_FLAGS = -target x86_64-pc-win32-macho -c -g -gdwarf -O0 -Wall -Werror -Wextra -include AutoGen.h -funsigned-char -fno-ms-extensions -fno-stack-protector -fno-builtin -fshort-wchar -mno-implicit-float -mms-bitfields -Wno-unused-parameter -Wno-missing-braces -Wno-missing-field-initializers -Wno-tautological-compare -Wno-sign-compare -Wno-varargs -ftrap-function=undefined_behavior_has_been_optimized_away_by_clang -D NO_MSABI_VA_FUNCS $(PLATFORM_FLAGS)
|
2018-01-10 16:24:26 +01:00
|
|
|
RELEASE_XCODE5_X64_CC_FLAGS = -target x86_64-pc-win32-macho -c -Os -Wall -Werror -Wextra -include AutoGen.h -funsigned-char -fno-ms-extensions -fno-stack-protector -fno-builtin -fshort-wchar -mno-implicit-float -mms-bitfields -Wno-unused-parameter -Wno-missing-braces -Wno-missing-field-initializers -Wno-tautological-compare -Wno-sign-compare -Wno-varargs -Wno-unused-const-variable -ftrap-function=undefined_behavior_has_been_optimized_away_by_clang -D NO_MSABI_VA_FUNCS $(PLATFORM_FLAGS)
|
2014-08-29 20:29:46 +02:00
|
|
|
|
2010-07-21 04:46:15 +02:00
|
|
|
#################
|
2019-02-06 08:44:39 +01:00
|
|
|
# ASM 16 linker definitions
|
2010-07-21 04:46:15 +02:00
|
|
|
#################
|
|
|
|
*_*_*_ASMLINK_PATH = DEF(WINDDK_BIN16)\link16.exe
|
|
|
|
*_*_*_ASMLINK_FLAGS = /nologo /tiny
|
2009-09-11 05:14:43 +02:00
|
|
|
|
2008-08-07 05:29:10 +02:00
|
|
|
##################
|
|
|
|
# VfrCompiler definitions
|
|
|
|
##################
|
2008-08-10 05:56:03 +02:00
|
|
|
*_*_*_VFR_PATH = VfrCompile
|
2008-08-07 05:29:10 +02:00
|
|
|
*_*_*_VFR_FLAGS = -l -n
|
2008-08-21 15:11:01 +02:00
|
|
|
|
2009-05-03 08:40:59 +02:00
|
|
|
##################
|
|
|
|
# OptionRom tool definitions
|
|
|
|
##################
|
|
|
|
*_*_*_OPTROM_PATH = EfiRom
|
|
|
|
*_*_*_OPTROM_FLAGS = -e
|
|
|
|
|
2010-09-06 03:58:00 +02:00
|
|
|
##################
|
|
|
|
# GenFw tool definitions
|
|
|
|
##################
|
|
|
|
*_*_*_GENFW_PATH = GenFw
|
2010-11-15 03:51:34 +01:00
|
|
|
*_*_*_GENFW_FLAGS =
|
2010-09-06 03:58:00 +02:00
|
|
|
|
2008-08-21 15:11:01 +02:00
|
|
|
##################
|
|
|
|
# Asl Compiler definitions
|
|
|
|
##################
|
2010-11-15 03:51:34 +01:00
|
|
|
*_*_*_ASLCC_FLAGS = /nologo /c /FIAutoGen.h /TC /Dmain=ReferenceAcpiTable
|
2011-05-11 12:26:49 +02:00
|
|
|
*_*_*_ASLDLINK_FLAGS = /NODEFAULTLIB /ENTRY:ReferenceAcpiTable /SUBSYSTEM:CONSOLE
|
2008-08-21 15:11:01 +02:00
|
|
|
*_*_*_ASLPP_FLAGS = /nologo /EP /C
|
|
|
|
*_*_*_ASL_FLAGS =
|
2008-11-27 10:15:52 +01:00
|
|
|
|
2011-08-26 09:46:26 +02:00
|
|
|
##################
|
|
|
|
# GenCrc32 tool definitions
|
|
|
|
##################
|
|
|
|
*_*_*_CRC32_PATH = GenCrc32
|
|
|
|
*_*_*_CRC32_GUID = FC1BCDB0-7D31-49AA-936A-A4600D9DD083
|
|
|
|
|
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Michael Kinney <michael.d.kinney@intel.com>
Reviewed-by: Yingke Liu <yingke.d.liu@intel.com>
Add support for RSA 2048 SHA 256 signing and verification encoded in a PI FFS GUIDED Encapsulation Section. The primary use case of this feature is in support of signing and verification of encapsulated FVs for Recovery and Capsule Update, but can potentially be used for signing and verification of any content that can be stored in a PI conformant FFS file. Signing operations are performed from python scripts that wrap OpenSsl command line utilities. Verification operations are performed using the OpenSsl libraries in the CryptoPkg.
The guided encapsulation sections uses the UEFI 2.4 Specification defined GUID called EFI_CERT_TYPE_RSA2048_SHA256_GUID. The data layout for the encapsulation section starts with the UEFI 2.4 Specification defined structure called EFI_CERT_BLOCK_RSA_2048_SHA256 followed immediately by the data. The signing tool included in these patches performs encode/decode operations using this data layout. HashType is set to the UEFI 2.4 Specification defined GUID called EFI_HASH_ALGORITHM_SHA256_GUID.
MdePkg/Include/Guid/WinCertificate.h
=================================
//
// WIN_CERTIFICATE_UEFI_GUID.CertType
//
#define EFI_CERT_TYPE_RSA2048_SHA256_GUID \
{0xa7717414, 0xc616, 0x4977, {0x94, 0x20, 0x84, 0x47, 0x12, 0xa7, 0x35, 0xbf } }
///
/// WIN_CERTIFICATE_UEFI_GUID.CertData
///
typedef struct {
EFI_GUID HashType;
UINT8 PublicKey[256];
UINT8 Signature[256];
} EFI_CERT_BLOCK_RSA_2048_SHA256;
MdePkg/Include/Protocol/Hash.h
=================================
#define EFI_HASH_ALGORITHM_SHA256_GUID \
{ \
0x51aa59de, 0xfdf2, 0x4ea3, {0xbc, 0x63, 0x87, 0x5f, 0xb7, 0x84, 0x2e, 0xe9 } \
}
The verification operations require the use of public key(s). A new PCD called gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer is added to the SecurityPkg that supports one or more SHA 256 hashes of the public keys. A SHA 256 hash is performed to minimize the FLASH overhead of storing the public keys. When a verification operation is performed, a SHA 256 hash is performed on EFI_CERT_BLOCK_RSA_2048_SHA256.PublicKey and a check is made to see if that hash matches any of the hashes in the new PCD. It is recommended that this PCD always be configured in the DSC file as storage type of [PcdsDynamixExVpd], so the public keys are stored in a protected read-only region.
While working on this feature, I noticed that the CRC32 signing and verification feature was incomplete. It only supported CRC32 based verification in the DXE Phase, so the attached patches also provide support for CRC32 based verification in the PEI Phase.
I also noticed that the most common method for incorporating guided section extraction libraries was to directly link them to the DXE Core, which is not very flexible. The attached patches also add a generic section extraction PEIM and a generic section extraction DXE driver that can each be linked against one or more section extraction libraries. This provides a platform developer with the option of providing section extraction services with the DXE Core or providing section extraction services with these generic PEIM/DXE Drivers.
Patch Summary
==============
1) BaseTools - Rsa2049Sha256Sign python script that can perform test signing or custom signing of PI FFS file GUIDed sections
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard OS path or in path specified by OS environment variable called OPENSSL_PATH
c. Provides standard EDK II command line arguments for a tool that encodes/decodes guided encapsulation section
Rsa2048Sha256Sign - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256Sign -e|-d [options] <input_file>
positional arguments:
input_file specify the input filename
optional arguments:
-e encode file
-d decode file
-o filename, --output filename
specify the output filename
--private-key PRIVATEKEYFILE
specify the private key filename. If not specified, a
test signing key is used.
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
2) BaseTools - Rsa2049Sha256GenerateKeys python script that can generate new private/public key and PCD value that is SHA 256 hash of public key using OpenSsl command line utilities.
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard path or in path specified by OS environment variable called OPENSSL_PATH
Rsa2048Sha256GenerateKeys - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256GenerateKeys [options]
optional arguments:
-o [filename [filename ...]], --output [filename [filename ...]]
specify the output private key filename in PEM format
-i [filename [filename ...]], --input [filename [filename ...]]
specify the input private key filename in PEM format
--public-key-hash PUBLICKEYHASHFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in binary format
--public-key-hash-c PUBLICKEYHASHCFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in C structure format
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
3) BaseTools\Conf\tools_def.template
a. Define GUID/Tool to perform RSA 2048 SHA 256 test signing and instructions on how to use alternate private/public key
b. GUID is EFI_CERT_TYPE_RSA2048_SHA256_GUID
c. Tool is Rsa2049Sha256Sign
4) MdeModulePkg\Library\PeiCrc32GuidedSectionExtractionLib
a. Add peer for DxeCrc32GuidedSectionExtractionLib so both PEI and DXE phases can perform basic integrity checks of PEI and DXE components
5) MdeModulePkg\Universal\SectionExtractionPei
a. Generic PEIM that can link against one or more NULL section extraction library instances to provided one or more GUIDED Section Extraction PPIs
6) MdeModulePkg\Universal\SectionExtractionDxe
a. Generic DXE Driver that can link against one or more NULL section extraction library instances to provide one or more GUIDED Section Extraction Protocols.
7) SecurityPkg\Library\PeiRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs PEI phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
8) SecurityPkg\Library\DxeRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs DXE phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@15800 6f19259b-4bc3-4df7-8a09-765794883524
2014-08-14 08:30:10 +02:00
|
|
|
##################
|
|
|
|
# Rsa2048Sha256Sign tool definitions
|
|
|
|
#
|
2019-02-06 08:44:39 +01:00
|
|
|
# Notes: This tool definition uses a test signing key for development purposes only.
|
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Michael Kinney <michael.d.kinney@intel.com>
Reviewed-by: Yingke Liu <yingke.d.liu@intel.com>
Add support for RSA 2048 SHA 256 signing and verification encoded in a PI FFS GUIDED Encapsulation Section. The primary use case of this feature is in support of signing and verification of encapsulated FVs for Recovery and Capsule Update, but can potentially be used for signing and verification of any content that can be stored in a PI conformant FFS file. Signing operations are performed from python scripts that wrap OpenSsl command line utilities. Verification operations are performed using the OpenSsl libraries in the CryptoPkg.
The guided encapsulation sections uses the UEFI 2.4 Specification defined GUID called EFI_CERT_TYPE_RSA2048_SHA256_GUID. The data layout for the encapsulation section starts with the UEFI 2.4 Specification defined structure called EFI_CERT_BLOCK_RSA_2048_SHA256 followed immediately by the data. The signing tool included in these patches performs encode/decode operations using this data layout. HashType is set to the UEFI 2.4 Specification defined GUID called EFI_HASH_ALGORITHM_SHA256_GUID.
MdePkg/Include/Guid/WinCertificate.h
=================================
//
// WIN_CERTIFICATE_UEFI_GUID.CertType
//
#define EFI_CERT_TYPE_RSA2048_SHA256_GUID \
{0xa7717414, 0xc616, 0x4977, {0x94, 0x20, 0x84, 0x47, 0x12, 0xa7, 0x35, 0xbf } }
///
/// WIN_CERTIFICATE_UEFI_GUID.CertData
///
typedef struct {
EFI_GUID HashType;
UINT8 PublicKey[256];
UINT8 Signature[256];
} EFI_CERT_BLOCK_RSA_2048_SHA256;
MdePkg/Include/Protocol/Hash.h
=================================
#define EFI_HASH_ALGORITHM_SHA256_GUID \
{ \
0x51aa59de, 0xfdf2, 0x4ea3, {0xbc, 0x63, 0x87, 0x5f, 0xb7, 0x84, 0x2e, 0xe9 } \
}
The verification operations require the use of public key(s). A new PCD called gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer is added to the SecurityPkg that supports one or more SHA 256 hashes of the public keys. A SHA 256 hash is performed to minimize the FLASH overhead of storing the public keys. When a verification operation is performed, a SHA 256 hash is performed on EFI_CERT_BLOCK_RSA_2048_SHA256.PublicKey and a check is made to see if that hash matches any of the hashes in the new PCD. It is recommended that this PCD always be configured in the DSC file as storage type of [PcdsDynamixExVpd], so the public keys are stored in a protected read-only region.
While working on this feature, I noticed that the CRC32 signing and verification feature was incomplete. It only supported CRC32 based verification in the DXE Phase, so the attached patches also provide support for CRC32 based verification in the PEI Phase.
I also noticed that the most common method for incorporating guided section extraction libraries was to directly link them to the DXE Core, which is not very flexible. The attached patches also add a generic section extraction PEIM and a generic section extraction DXE driver that can each be linked against one or more section extraction libraries. This provides a platform developer with the option of providing section extraction services with the DXE Core or providing section extraction services with these generic PEIM/DXE Drivers.
Patch Summary
==============
1) BaseTools - Rsa2049Sha256Sign python script that can perform test signing or custom signing of PI FFS file GUIDed sections
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard OS path or in path specified by OS environment variable called OPENSSL_PATH
c. Provides standard EDK II command line arguments for a tool that encodes/decodes guided encapsulation section
Rsa2048Sha256Sign - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256Sign -e|-d [options] <input_file>
positional arguments:
input_file specify the input filename
optional arguments:
-e encode file
-d decode file
-o filename, --output filename
specify the output filename
--private-key PRIVATEKEYFILE
specify the private key filename. If not specified, a
test signing key is used.
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
2) BaseTools - Rsa2049Sha256GenerateKeys python script that can generate new private/public key and PCD value that is SHA 256 hash of public key using OpenSsl command line utilities.
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard path or in path specified by OS environment variable called OPENSSL_PATH
Rsa2048Sha256GenerateKeys - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256GenerateKeys [options]
optional arguments:
-o [filename [filename ...]], --output [filename [filename ...]]
specify the output private key filename in PEM format
-i [filename [filename ...]], --input [filename [filename ...]]
specify the input private key filename in PEM format
--public-key-hash PUBLICKEYHASHFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in binary format
--public-key-hash-c PUBLICKEYHASHCFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in C structure format
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
3) BaseTools\Conf\tools_def.template
a. Define GUID/Tool to perform RSA 2048 SHA 256 test signing and instructions on how to use alternate private/public key
b. GUID is EFI_CERT_TYPE_RSA2048_SHA256_GUID
c. Tool is Rsa2049Sha256Sign
4) MdeModulePkg\Library\PeiCrc32GuidedSectionExtractionLib
a. Add peer for DxeCrc32GuidedSectionExtractionLib so both PEI and DXE phases can perform basic integrity checks of PEI and DXE components
5) MdeModulePkg\Universal\SectionExtractionPei
a. Generic PEIM that can link against one or more NULL section extraction library instances to provided one or more GUIDED Section Extraction PPIs
6) MdeModulePkg\Universal\SectionExtractionDxe
a. Generic DXE Driver that can link against one or more NULL section extraction library instances to provide one or more GUIDED Section Extraction Protocols.
7) SecurityPkg\Library\PeiRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs PEI phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
8) SecurityPkg\Library\DxeRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs DXE phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@15800 6f19259b-4bc3-4df7-8a09-765794883524
2014-08-14 08:30:10 +02:00
|
|
|
# The tool Rsa2048Sha256GenerateKeys can be used to generate a new private/public key
|
|
|
|
# and the gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer PCD value.
|
|
|
|
# A custom tool/script can be implemented using the new private/public key with
|
2019-02-06 08:44:39 +01:00
|
|
|
# the Rsa2048Sha256Sign tool and this tool definition can be updated to use a
|
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Michael Kinney <michael.d.kinney@intel.com>
Reviewed-by: Yingke Liu <yingke.d.liu@intel.com>
Add support for RSA 2048 SHA 256 signing and verification encoded in a PI FFS GUIDED Encapsulation Section. The primary use case of this feature is in support of signing and verification of encapsulated FVs for Recovery and Capsule Update, but can potentially be used for signing and verification of any content that can be stored in a PI conformant FFS file. Signing operations are performed from python scripts that wrap OpenSsl command line utilities. Verification operations are performed using the OpenSsl libraries in the CryptoPkg.
The guided encapsulation sections uses the UEFI 2.4 Specification defined GUID called EFI_CERT_TYPE_RSA2048_SHA256_GUID. The data layout for the encapsulation section starts with the UEFI 2.4 Specification defined structure called EFI_CERT_BLOCK_RSA_2048_SHA256 followed immediately by the data. The signing tool included in these patches performs encode/decode operations using this data layout. HashType is set to the UEFI 2.4 Specification defined GUID called EFI_HASH_ALGORITHM_SHA256_GUID.
MdePkg/Include/Guid/WinCertificate.h
=================================
//
// WIN_CERTIFICATE_UEFI_GUID.CertType
//
#define EFI_CERT_TYPE_RSA2048_SHA256_GUID \
{0xa7717414, 0xc616, 0x4977, {0x94, 0x20, 0x84, 0x47, 0x12, 0xa7, 0x35, 0xbf } }
///
/// WIN_CERTIFICATE_UEFI_GUID.CertData
///
typedef struct {
EFI_GUID HashType;
UINT8 PublicKey[256];
UINT8 Signature[256];
} EFI_CERT_BLOCK_RSA_2048_SHA256;
MdePkg/Include/Protocol/Hash.h
=================================
#define EFI_HASH_ALGORITHM_SHA256_GUID \
{ \
0x51aa59de, 0xfdf2, 0x4ea3, {0xbc, 0x63, 0x87, 0x5f, 0xb7, 0x84, 0x2e, 0xe9 } \
}
The verification operations require the use of public key(s). A new PCD called gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer is added to the SecurityPkg that supports one or more SHA 256 hashes of the public keys. A SHA 256 hash is performed to minimize the FLASH overhead of storing the public keys. When a verification operation is performed, a SHA 256 hash is performed on EFI_CERT_BLOCK_RSA_2048_SHA256.PublicKey and a check is made to see if that hash matches any of the hashes in the new PCD. It is recommended that this PCD always be configured in the DSC file as storage type of [PcdsDynamixExVpd], so the public keys are stored in a protected read-only region.
While working on this feature, I noticed that the CRC32 signing and verification feature was incomplete. It only supported CRC32 based verification in the DXE Phase, so the attached patches also provide support for CRC32 based verification in the PEI Phase.
I also noticed that the most common method for incorporating guided section extraction libraries was to directly link them to the DXE Core, which is not very flexible. The attached patches also add a generic section extraction PEIM and a generic section extraction DXE driver that can each be linked against one or more section extraction libraries. This provides a platform developer with the option of providing section extraction services with the DXE Core or providing section extraction services with these generic PEIM/DXE Drivers.
Patch Summary
==============
1) BaseTools - Rsa2049Sha256Sign python script that can perform test signing or custom signing of PI FFS file GUIDed sections
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard OS path or in path specified by OS environment variable called OPENSSL_PATH
c. Provides standard EDK II command line arguments for a tool that encodes/decodes guided encapsulation section
Rsa2048Sha256Sign - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256Sign -e|-d [options] <input_file>
positional arguments:
input_file specify the input filename
optional arguments:
-e encode file
-d decode file
-o filename, --output filename
specify the output filename
--private-key PRIVATEKEYFILE
specify the private key filename. If not specified, a
test signing key is used.
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
2) BaseTools - Rsa2049Sha256GenerateKeys python script that can generate new private/public key and PCD value that is SHA 256 hash of public key using OpenSsl command line utilities.
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard path or in path specified by OS environment variable called OPENSSL_PATH
Rsa2048Sha256GenerateKeys - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256GenerateKeys [options]
optional arguments:
-o [filename [filename ...]], --output [filename [filename ...]]
specify the output private key filename in PEM format
-i [filename [filename ...]], --input [filename [filename ...]]
specify the input private key filename in PEM format
--public-key-hash PUBLICKEYHASHFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in binary format
--public-key-hash-c PUBLICKEYHASHCFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in C structure format
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
3) BaseTools\Conf\tools_def.template
a. Define GUID/Tool to perform RSA 2048 SHA 256 test signing and instructions on how to use alternate private/public key
b. GUID is EFI_CERT_TYPE_RSA2048_SHA256_GUID
c. Tool is Rsa2049Sha256Sign
4) MdeModulePkg\Library\PeiCrc32GuidedSectionExtractionLib
a. Add peer for DxeCrc32GuidedSectionExtractionLib so both PEI and DXE phases can perform basic integrity checks of PEI and DXE components
5) MdeModulePkg\Universal\SectionExtractionPei
a. Generic PEIM that can link against one or more NULL section extraction library instances to provided one or more GUIDED Section Extraction PPIs
6) MdeModulePkg\Universal\SectionExtractionDxe
a. Generic DXE Driver that can link against one or more NULL section extraction library instances to provide one or more GUIDED Section Extraction Protocols.
7) SecurityPkg\Library\PeiRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs PEI phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
8) SecurityPkg\Library\DxeRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs DXE phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@15800 6f19259b-4bc3-4df7-8a09-765794883524
2014-08-14 08:30:10 +02:00
|
|
|
# custom tool/script.
|
|
|
|
#
|
|
|
|
# Generate new private/public key and gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer PCD value
|
|
|
|
#
|
|
|
|
# Rsa2048Sha256GenerateKeys.py -o MyKey.pem --public-key-hash-c MyKey.pcd
|
|
|
|
#
|
|
|
|
# Custom script example (MyRsa2048Sha256Sign.cmd):
|
|
|
|
#
|
|
|
|
# Rsa2048Sha256Sign --private-key MyKey.pem %1 %2 %3 %4 %5 %6 %7 %8 %9
|
|
|
|
#
|
2019-01-02 22:29:43 +01:00
|
|
|
# WARNING: Vendors that uses private keys are responsible for proper management and protection
|
|
|
|
# of private keys. Vendors may choose to use infrastructure such as signing servers
|
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Michael Kinney <michael.d.kinney@intel.com>
Reviewed-by: Yingke Liu <yingke.d.liu@intel.com>
Add support for RSA 2048 SHA 256 signing and verification encoded in a PI FFS GUIDED Encapsulation Section. The primary use case of this feature is in support of signing and verification of encapsulated FVs for Recovery and Capsule Update, but can potentially be used for signing and verification of any content that can be stored in a PI conformant FFS file. Signing operations are performed from python scripts that wrap OpenSsl command line utilities. Verification operations are performed using the OpenSsl libraries in the CryptoPkg.
The guided encapsulation sections uses the UEFI 2.4 Specification defined GUID called EFI_CERT_TYPE_RSA2048_SHA256_GUID. The data layout for the encapsulation section starts with the UEFI 2.4 Specification defined structure called EFI_CERT_BLOCK_RSA_2048_SHA256 followed immediately by the data. The signing tool included in these patches performs encode/decode operations using this data layout. HashType is set to the UEFI 2.4 Specification defined GUID called EFI_HASH_ALGORITHM_SHA256_GUID.
MdePkg/Include/Guid/WinCertificate.h
=================================
//
// WIN_CERTIFICATE_UEFI_GUID.CertType
//
#define EFI_CERT_TYPE_RSA2048_SHA256_GUID \
{0xa7717414, 0xc616, 0x4977, {0x94, 0x20, 0x84, 0x47, 0x12, 0xa7, 0x35, 0xbf } }
///
/// WIN_CERTIFICATE_UEFI_GUID.CertData
///
typedef struct {
EFI_GUID HashType;
UINT8 PublicKey[256];
UINT8 Signature[256];
} EFI_CERT_BLOCK_RSA_2048_SHA256;
MdePkg/Include/Protocol/Hash.h
=================================
#define EFI_HASH_ALGORITHM_SHA256_GUID \
{ \
0x51aa59de, 0xfdf2, 0x4ea3, {0xbc, 0x63, 0x87, 0x5f, 0xb7, 0x84, 0x2e, 0xe9 } \
}
The verification operations require the use of public key(s). A new PCD called gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer is added to the SecurityPkg that supports one or more SHA 256 hashes of the public keys. A SHA 256 hash is performed to minimize the FLASH overhead of storing the public keys. When a verification operation is performed, a SHA 256 hash is performed on EFI_CERT_BLOCK_RSA_2048_SHA256.PublicKey and a check is made to see if that hash matches any of the hashes in the new PCD. It is recommended that this PCD always be configured in the DSC file as storage type of [PcdsDynamixExVpd], so the public keys are stored in a protected read-only region.
While working on this feature, I noticed that the CRC32 signing and verification feature was incomplete. It only supported CRC32 based verification in the DXE Phase, so the attached patches also provide support for CRC32 based verification in the PEI Phase.
I also noticed that the most common method for incorporating guided section extraction libraries was to directly link them to the DXE Core, which is not very flexible. The attached patches also add a generic section extraction PEIM and a generic section extraction DXE driver that can each be linked against one or more section extraction libraries. This provides a platform developer with the option of providing section extraction services with the DXE Core or providing section extraction services with these generic PEIM/DXE Drivers.
Patch Summary
==============
1) BaseTools - Rsa2049Sha256Sign python script that can perform test signing or custom signing of PI FFS file GUIDed sections
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard OS path or in path specified by OS environment variable called OPENSSL_PATH
c. Provides standard EDK II command line arguments for a tool that encodes/decodes guided encapsulation section
Rsa2048Sha256Sign - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256Sign -e|-d [options] <input_file>
positional arguments:
input_file specify the input filename
optional arguments:
-e encode file
-d decode file
-o filename, --output filename
specify the output filename
--private-key PRIVATEKEYFILE
specify the private key filename. If not specified, a
test signing key is used.
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
2) BaseTools - Rsa2049Sha256GenerateKeys python script that can generate new private/public key and PCD value that is SHA 256 hash of public key using OpenSsl command line utilities.
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard path or in path specified by OS environment variable called OPENSSL_PATH
Rsa2048Sha256GenerateKeys - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256GenerateKeys [options]
optional arguments:
-o [filename [filename ...]], --output [filename [filename ...]]
specify the output private key filename in PEM format
-i [filename [filename ...]], --input [filename [filename ...]]
specify the input private key filename in PEM format
--public-key-hash PUBLICKEYHASHFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in binary format
--public-key-hash-c PUBLICKEYHASHCFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in C structure format
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
3) BaseTools\Conf\tools_def.template
a. Define GUID/Tool to perform RSA 2048 SHA 256 test signing and instructions on how to use alternate private/public key
b. GUID is EFI_CERT_TYPE_RSA2048_SHA256_GUID
c. Tool is Rsa2049Sha256Sign
4) MdeModulePkg\Library\PeiCrc32GuidedSectionExtractionLib
a. Add peer for DxeCrc32GuidedSectionExtractionLib so both PEI and DXE phases can perform basic integrity checks of PEI and DXE components
5) MdeModulePkg\Universal\SectionExtractionPei
a. Generic PEIM that can link against one or more NULL section extraction library instances to provided one or more GUIDED Section Extraction PPIs
6) MdeModulePkg\Universal\SectionExtractionDxe
a. Generic DXE Driver that can link against one or more NULL section extraction library instances to provide one or more GUIDED Section Extraction Protocols.
7) SecurityPkg\Library\PeiRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs PEI phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
8) SecurityPkg\Library\DxeRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs DXE phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@15800 6f19259b-4bc3-4df7-8a09-765794883524
2014-08-14 08:30:10 +02:00
|
|
|
# or signing portals to support the management and protection of private keys.
|
|
|
|
#
|
|
|
|
##################
|
|
|
|
*_*_*_RSA2048SHA256SIGN_PATH = Rsa2048Sha256Sign
|
|
|
|
*_*_*_RSA2048SHA256SIGN_GUID = A7717414-C616-4977-9420-844712A735BF
|
|
|
|
|
2017-03-23 03:16:16 +01:00
|
|
|
##################
|
|
|
|
# BrotliCompress tool definitions
|
|
|
|
##################
|
|
|
|
*_*_*_BROTLI_PATH = BrotliCompress
|
|
|
|
*_*_*_BROTLI_GUID = 3D532050-5CDA-4FD0-879E-0F7F630D5AFB
|
|
|
|
|
2009-01-08 09:46:46 +01:00
|
|
|
##################
|
2009-05-01 08:45:01 +02:00
|
|
|
# LzmaCompress tool definitions
|
2009-01-08 09:46:46 +01:00
|
|
|
##################
|
2009-05-01 08:45:01 +02:00
|
|
|
*_*_*_LZMA_PATH = LzmaCompress
|
|
|
|
*_*_*_LZMA_GUID = EE4E5898-3914-4259-9D6E-DC7BD79403CF
|
|
|
|
|
2012-04-10 09:18:20 +02:00
|
|
|
##################
|
|
|
|
# LzmaF86Compress tool definitions with converter for x86 code.
|
|
|
|
# It can improve the compression ratio if the input file is IA32 or X64 PE image.
|
|
|
|
##################
|
|
|
|
*_*_*_LZMAF86_PATH = LzmaF86Compress
|
|
|
|
*_*_*_LZMAF86_GUID = D42AE6BD-1352-4bfb-909A-CA72A6EAE889
|
|
|
|
|
2009-05-01 08:45:01 +02:00
|
|
|
##################
|
|
|
|
# TianoCompress tool definitions
|
|
|
|
##################
|
|
|
|
*_*_*_TIANO_PATH = TianoCompress
|
|
|
|
*_*_*_TIANO_GUID = A31280AD-481E-41B6-95E8-127F4C984779
|
2009-04-13 14:50:50 +02:00
|
|
|
|
2010-09-06 03:58:00 +02:00
|
|
|
##################
|
|
|
|
# BPDG tool definitions
|
|
|
|
##################
|
|
|
|
*_*_*_VPDTOOL_PATH = BPDG
|
|
|
|
*_*_*_VPDTOOL_GUID = 8C3D856A-9BE6-468E-850A-24F7A8D38E08
|
Contributed-under: TianoCore Contribution Agreement 1.0
Signed-off-by: Michael Kinney <michael.d.kinney@intel.com>
Reviewed-by: Yingke Liu <yingke.d.liu@intel.com>
Add support for RSA 2048 SHA 256 signing and verification encoded in a PI FFS GUIDED Encapsulation Section. The primary use case of this feature is in support of signing and verification of encapsulated FVs for Recovery and Capsule Update, but can potentially be used for signing and verification of any content that can be stored in a PI conformant FFS file. Signing operations are performed from python scripts that wrap OpenSsl command line utilities. Verification operations are performed using the OpenSsl libraries in the CryptoPkg.
The guided encapsulation sections uses the UEFI 2.4 Specification defined GUID called EFI_CERT_TYPE_RSA2048_SHA256_GUID. The data layout for the encapsulation section starts with the UEFI 2.4 Specification defined structure called EFI_CERT_BLOCK_RSA_2048_SHA256 followed immediately by the data. The signing tool included in these patches performs encode/decode operations using this data layout. HashType is set to the UEFI 2.4 Specification defined GUID called EFI_HASH_ALGORITHM_SHA256_GUID.
MdePkg/Include/Guid/WinCertificate.h
=================================
//
// WIN_CERTIFICATE_UEFI_GUID.CertType
//
#define EFI_CERT_TYPE_RSA2048_SHA256_GUID \
{0xa7717414, 0xc616, 0x4977, {0x94, 0x20, 0x84, 0x47, 0x12, 0xa7, 0x35, 0xbf } }
///
/// WIN_CERTIFICATE_UEFI_GUID.CertData
///
typedef struct {
EFI_GUID HashType;
UINT8 PublicKey[256];
UINT8 Signature[256];
} EFI_CERT_BLOCK_RSA_2048_SHA256;
MdePkg/Include/Protocol/Hash.h
=================================
#define EFI_HASH_ALGORITHM_SHA256_GUID \
{ \
0x51aa59de, 0xfdf2, 0x4ea3, {0xbc, 0x63, 0x87, 0x5f, 0xb7, 0x84, 0x2e, 0xe9 } \
}
The verification operations require the use of public key(s). A new PCD called gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer is added to the SecurityPkg that supports one or more SHA 256 hashes of the public keys. A SHA 256 hash is performed to minimize the FLASH overhead of storing the public keys. When a verification operation is performed, a SHA 256 hash is performed on EFI_CERT_BLOCK_RSA_2048_SHA256.PublicKey and a check is made to see if that hash matches any of the hashes in the new PCD. It is recommended that this PCD always be configured in the DSC file as storage type of [PcdsDynamixExVpd], so the public keys are stored in a protected read-only region.
While working on this feature, I noticed that the CRC32 signing and verification feature was incomplete. It only supported CRC32 based verification in the DXE Phase, so the attached patches also provide support for CRC32 based verification in the PEI Phase.
I also noticed that the most common method for incorporating guided section extraction libraries was to directly link them to the DXE Core, which is not very flexible. The attached patches also add a generic section extraction PEIM and a generic section extraction DXE driver that can each be linked against one or more section extraction libraries. This provides a platform developer with the option of providing section extraction services with the DXE Core or providing section extraction services with these generic PEIM/DXE Drivers.
Patch Summary
==============
1) BaseTools - Rsa2049Sha256Sign python script that can perform test signing or custom signing of PI FFS file GUIDed sections
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard OS path or in path specified by OS environment variable called OPENSSL_PATH
c. Provides standard EDK II command line arguments for a tool that encodes/decodes guided encapsulation section
Rsa2048Sha256Sign - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256Sign -e|-d [options] <input_file>
positional arguments:
input_file specify the input filename
optional arguments:
-e encode file
-d decode file
-o filename, --output filename
specify the output filename
--private-key PRIVATEKEYFILE
specify the private key filename. If not specified, a
test signing key is used.
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
2) BaseTools - Rsa2049Sha256GenerateKeys python script that can generate new private/public key and PCD value that is SHA 256 hash of public key using OpenSsl command line utilities.
a. Wrapper for a set of OpenSsl command line utility operations
b. OpenSsl command line tool must be installed in location that is in standard path or in path specified by OS environment variable called OPENSSL_PATH
Rsa2048Sha256GenerateKeys - Copyright (c) 2013 - 2014, Intel Corporation. All rights reserved.
usage: Rsa2048Sha256GenerateKeys [options]
optional arguments:
-o [filename [filename ...]], --output [filename [filename ...]]
specify the output private key filename in PEM format
-i [filename [filename ...]], --input [filename [filename ...]]
specify the input private key filename in PEM format
--public-key-hash PUBLICKEYHASHFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in binary format
--public-key-hash-c PUBLICKEYHASHCFILE
specify the public key hash filename that is SHA 256
hash of 2048 bit RSA public key in C structure format
-v, --verbose increase output messages
-q, --quiet reduce output messages
--debug [0-9] set debug level
--version display the program version and exit
-h, --help display this help text
3) BaseTools\Conf\tools_def.template
a. Define GUID/Tool to perform RSA 2048 SHA 256 test signing and instructions on how to use alternate private/public key
b. GUID is EFI_CERT_TYPE_RSA2048_SHA256_GUID
c. Tool is Rsa2049Sha256Sign
4) MdeModulePkg\Library\PeiCrc32GuidedSectionExtractionLib
a. Add peer for DxeCrc32GuidedSectionExtractionLib so both PEI and DXE phases can perform basic integrity checks of PEI and DXE components
5) MdeModulePkg\Universal\SectionExtractionPei
a. Generic PEIM that can link against one or more NULL section extraction library instances to provided one or more GUIDED Section Extraction PPIs
6) MdeModulePkg\Universal\SectionExtractionDxe
a. Generic DXE Driver that can link against one or more NULL section extraction library instances to provide one or more GUIDED Section Extraction Protocols.
7) SecurityPkg\Library\PeiRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs PEI phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
8) SecurityPkg\Library\DxeRsa2048Sha256GuidedSectionExtractLib
a. NULL library instances that performs DXE phase RSA 2048 SHA 256 signature verification using OpenSsl libraries from CryptoPkg.
b. Based on algorithms from SecurityPkg Authenticated Variable services
c. Uses public key from gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer.
git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@15800 6f19259b-4bc3-4df7-8a09-765794883524
2014-08-14 08:30:10 +02:00
|
|
|
|
2016-08-15 11:12:12 +02:00
|
|
|
##################
|
|
|
|
# Pkcs7Sign tool definitions
|
|
|
|
##################
|
|
|
|
*_*_*_PKCS7SIGN_PATH = Pkcs7Sign
|
|
|
|
*_*_*_PKCS7SIGN_GUID = 4AAFD29D-68DF-49EE-8AA9-347D375665A7
|
|
|
|
|
2014-08-19 01:03:17 +02:00
|
|
|
##################
|
|
|
|
# NASM tool definitions
|
|
|
|
##################
|
|
|
|
*_*_*_NASM_PATH = ENV(NASM_PREFIX)nasm
|
|
|
|
# NASMB uses NASM produce a .bin from a .nasmb NASM source file
|
|
|
|
*_*_*_NASMB_FLAGS = -f bin
|
2015-05-26 12:32:47 +02:00
|
|
|
|
|
|
|
#################
|
|
|
|
# Build rule order
|
|
|
|
#################
|
2017-08-02 22:30:06 +02:00
|
|
|
*_*_*_*_BUILDRULEORDER = nasm asm Asm ASM S s nasmb asm16
|