VirtualBox

source: vbox/trunk/src/VBox/Devices/EFI/Firmware/vbox-tools_def.txt

Last change on this file was 107041, checked in by vboxsync, 8 weeks ago

EFI/Firmware: Part of changes required for building the arm images on windows hosts with llvm. The executable wrapper for python scripts is because kmk has trouble finding the .cmd-files. The additions of CLANGDWARF to vbox-tools_defs.txt is copied from the BaseTools/Conf/tools_def.txt and tweaked a tiny bit. jiraref:VBP-1458

  • Property svn:eol-style set to native
File size: 68.9 KB
Line 
1#
2# Copyright (c) 2006 - 2022, Intel Corporation. All rights reserved.<BR>
3# Portions copyright (c) 2008 - 2009, Apple Inc. All rights reserved.<BR>
4# Portions copyright (c) 2011 - 2019, ARM Ltd. All rights reserved.<BR>
5# Copyright (c) 2015, Hewlett-Packard Development Company, L.P.<BR>
6# (C) Copyright 2020, Hewlett Packard Enterprise Development LP<BR>
7# Copyright (c) 2022, Loongson Technology Corporation Limited. All rights reserved.<BR>
8# Copyright (c) Microsoft Corporation
9#
10# SPDX-License-Identifier: BSD-2-Clause-Patent
11#
12
13IDENTIFIER = Default TOOL_CHAIN_CONF
14
15# common path macros
16DEFINE VS2017_DLL = @PATH_VS2017_BIN_HOST@
17DEFINE VS2017_BIN_HOST = @PATH_VS2017_BIN_HOST@
18DEFINE VS2017_BIN_IA32 = @PATH_VS2017_X86_BIN@
19DEFINE VS2017_BIN_X64 = @PATH_VS2017_AMD64_BIN@
20DEFINE VS2017_BIN_ARM = c:\no\such\directory
21DEFINE VS2017_BIN_AARCH64 = c:\no\such\directory
22
23DEFINE VS_HOST = @VS_HOST@
24
25DEFINE VS2019_BIN = @PATH_VS2019_BIN@
26DEFINE VS2019_BIN_HOST = DEF(VS2019_BIN)\HostDEF(VS_HOST)\DEF(VS_HOST)
27DEFINE VS2019_BIN_IA32 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\x86
28DEFINE VS2019_BIN_X64 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\x64
29DEFINE VS2019_BIN_ARM = DEF(VS2019_BIN)\HostDEF(VS_HOST)\arm
30DEFINE VS2019_BIN_AARCH64 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\arm64
31
32#
33# Resource compiler
34#
35DEFINE RC_PATH = @PATH_SDK_WINSDK10_BIN@\rc.exe
36DEFINE WINSDK10_BIN = @PATH_SDK_WINSDK10_BIN@
37
38#DEFINE WINSDK7_BIN = c:\no\such\directory
39
40
41# These defines are needed for certain Microsoft Visual Studio tools that
42# are used by other toolchains. An example is that ICC on Windows normally
43# uses Microsoft's nmake.exe.
44DEFINE WINDDK_BIN16 = ENV(WINDDK3790_PREFIX)bin16
45
46DEFINE EBC_BIN = C:\Program Files\Intel\EBC\Bin
47DEFINE EBC_BINx86 = C:\Program Files (x86)\Intel\EBC\Bin
48
49
50DEFINE GCC48_IA32_PREFIX = @VBOX_PATH_PREFIX_GCC32@
51DEFINE GCC48_X64_PREFIX = @VBOX_PATH_PREFIX_GCC64@
52DEFINE GCC48_AARCH64_PREFIX = @VBOX_PATH_PREFIX_GCC_AARCH64@
53DEFINE GCC48_ARM_PREFIX = @VBOX_PATH_PREFIX_GCC_ARM@
54
55DEFINE UNIX_IASL_BIN = @VBOX_IASLCMD@
56DEFINE WIN_IASL_BIN = @VBOX_IASLCMD@
57
58DEFINE IASL_FLAGS =
59DEFINE IASL_OUTFLAGS = -p
60
61DEFINE DEFAULT_WIN_ASL_BIN = DEF(WIN_IASL_BIN)
62DEFINE DEFAULT_WIN_ASL_FLAGS = DEF(IASL_FLAGS)
63DEFINE DEFAULT_WIN_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
64
65# MSFT Build Flag for included header file list generation
66DEFINE MSFT_DEPS_FLAGS = /showIncludes /MP1
67
68DEFINE MSFT_ASLPP_FLAGS = /nologo /E /C /FIAutoGen.h
69DEFINE MSFT_ASLCC_FLAGS = /nologo /c /FIAutoGen.h /TC /Dmain=ReferenceAcpiTable
70DEFINE MSFT_ASLDLINK_FLAGS = /NODEFAULTLIB /ENTRY:ReferenceAcpiTable /SUBSYSTEM:CONSOLE
71
72DEFINE DTCPP_BIN = ENV(DTCPP_PREFIX)cpp
73DEFINE DTC_BIN = ENV(DTC_PREFIX)dtc
74
75####################################################################################
76#
77# format: TARGET_TOOLCHAIN_ARCH_COMMANDTYPE_ATTRIBUTE = <string>
78# priority:
79# TARGET_TOOLCHAIN_ARCH_COMMANDTYPE_ATTRIBUTE (Highest)
80# ******_TOOLCHAIN_ARCH_COMMANDTYPE_ATTRIBUTE
81# TARGET_*********_ARCH_COMMANDTYPE_ATTRIBUTE
82# ******_*********_ARCH_COMMANDTYPE_ATTRIBUTE
83# TARGET_TOOLCHAIN_****_COMMANDTYPE_ATTRIBUTE
84# ******_TOOLCHAIN_****_COMMANDTYPE_ATTRIBUTE
85# TARGET_*********_****_COMMANDTYPE_ATTRIBUTE
86# ******_*********_****_COMMANDTYPE_ATTRIBUTE
87# TARGET_TOOLCHAIN_ARCH_***********_ATTRIBUTE
88# ******_TOOLCHAIN_ARCH_***********_ATTRIBUTE
89# TARGET_*********_ARCH_***********_ATTRIBUTE
90# ******_*********_ARCH_***********_ATTRIBUTE
91# TARGET_TOOLCHAIN_****_***********_ATTRIBUTE
92# ******_TOOLCHAIN_****_***********_ATTRIBUTE
93# TARGET_*********_****_***********_ATTRIBUTE
94# ******_*********_****_***********_ATTRIBUTE (Lowest)
95#
96####################################################################################
97####################################################################################
98#
99# Supported Tool Chains
100# =====================
101# VS2017 -win32- Requires:
102# Microsoft Visual Studio 2017 version 15.2 (15.4 for ARM64) or later
103# Optional:
104# Required to build platforms or ACPI tables:
105# Intel(r) ACPI Compiler (iasl.exe) from
106# https://acpica.org/downloads
107# Note:
108# Building of XIP firmware images for ARM/ARM64 is not currently supported (only applications).
109# /FILEALIGN:4096 and other changes are needed for ARM firmware builds.
110# VS2019 -win32- Requires:
111# Microsoft Visual Studio 2019 version 16.2 or later
112# Optional:
113# Required to build platforms or ACPI tables:
114# Intel(r) ACPI Compiler (iasl.exe) from
115# https://acpica.org/downloads
116#
117# GCC48 -Linux,Windows- Requires:
118# GCC 4.8 targeting x86_64-linux-gnu, aarch64-linux-gnu, or arm-linux-gnueabi
119# Optional:
120# Required to build platforms or ACPI tables:
121# Intel(r) ACPI Compiler from
122# https://acpica.org/downloads
123#
124# CLANGDWARF -Linux, Windows, Mac- Requires:
125# Clang 9 or above from http://releases.llvm.org/
126# Optional:
127# Required to compile nasm source:
128# nasm compiler from
129# NASM -- http://www.nasm.us/
130#
131####################################################################################
132####################################################################################
133#
134# Supported Tool Chain Family
135# ===========================
136# MSFT - Microsoft
137# GCC - GNU GCC
138####################################################################################
139####################################################################################
140#
141# Other Supported Tools
142# =====================
143# NASM -- http://www.nasm.us/
144# - NASM 2.15.05 or later for use with the GCC toolchain family
145# - NASM 2.15.05 or later for use with all other toolchain families
146#
147####################################################################################
148
149
150
151
152
153####################################################################################
154# VS2017 - Microsoft Visual Studio 2017 with Intel ASL
155# ASL - Intel ACPI Source Language Compiler (iasl.exe)
156####################################################################################
157# VS2017 - Microsoft Visual Studio 2017 professional Edition with Intel ASL
158*_VS2017_*_*_FAMILY = MSFT
159*_VS2017_*_*_DLL = DEF(VS2017_BIN_HOST)
160
161*_VS2017_*_MAKE_PATH = DEF(VS2017_BIN_HOST)\nmake.exe
162*_VS2017_*_MAKE_FLAGS = /nologo
163*_VS2017_*_RC_PATH = DEF(RC_PATH)
164
165*_VS2017_*_SLINK_FLAGS = /NOLOGO /LTCG
166*_VS2017_*_APP_FLAGS = /nologo /E /TC
167*_VS2017_*_PP_FLAGS = /nologo /E /TC /FIAutoGen.h
168*_VS2017_*_VFRPP_FLAGS = /nologo /E /TC /DVFRCOMPILE /FI$(MODULE_NAME)StrDefs.h
169*_VS2017_*_DLINK2_FLAGS = /WHOLEARCHIVE
170*_VS2017_*_ASM16_PATH = DEF(VS2017_BIN_IA32)\ml.exe
171*_VS2017_*_DEPS_FLAGS = DEF(MSFT_DEPS_FLAGS)
172##################
173# ASL definitions
174##################
175*_VS2017_*_ASL_PATH = DEF(WIN_IASL_BIN)
176*_VS2017_*_ASL_FLAGS = DEF(DEFAULT_WIN_ASL_FLAGS)
177*_VS2017_*_ASL_OUTFLAGS = DEF(DEFAULT_WIN_ASL_OUTFLAGS)
178*_VS2017_*_ASLCC_FLAGS = DEF(MSFT_ASLCC_FLAGS)
179*_VS2017_*_ASLPP_FLAGS = DEF(MSFT_ASLPP_FLAGS)
180*_VS2017_*_ASLDLINK_FLAGS = DEF(MSFT_ASLDLINK_FLAGS)
181
182##################
183# IA32 definitions
184##################
185*_VS2017_IA32_CC_PATH = DEF(VS2017_BIN_IA32)\cl.exe
186*_VS2017_IA32_VFRPP_PATH = DEF(VS2017_BIN_IA32)\cl.exe
187*_VS2017_IA32_ASLCC_PATH = DEF(VS2017_BIN_IA32)\cl.exe
188*_VS2017_IA32_ASLPP_PATH = DEF(VS2017_BIN_IA32)\cl.exe
189*_VS2017_IA32_SLINK_PATH = DEF(VS2017_BIN_IA32)\lib.exe
190*_VS2017_IA32_DLINK_PATH = DEF(VS2017_BIN_IA32)\link.exe
191*_VS2017_IA32_ASLDLINK_PATH= DEF(VS2017_BIN_IA32)\link.exe
192*_VS2017_IA32_APP_PATH = DEF(VS2017_BIN_IA32)\cl.exe
193*_VS2017_IA32_PP_PATH = DEF(VS2017_BIN_IA32)\cl.exe
194*_VS2017_IA32_ASM_PATH = DEF(VS2017_BIN_IA32)\ml.exe
195
196 *_VS2017_IA32_MAKE_FLAGS = /nologo
197 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 /MP
198RELEASE_VS2017_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP
199NOOPT_VS2017_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od /MP
200
201 DEBUG_VS2017_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
202RELEASE_VS2017_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd
203NOOPT_VS2017_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
204
205 DEBUG_VS2017_IA32_NASM_FLAGS = -Ox -f win32 -g
206RELEASE_VS2017_IA32_NASM_FLAGS = -Ox -f win32
207NOOPT_VS2017_IA32_NASM_FLAGS = -O0 -f win32 -g
208
209 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
210RELEASE_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 /DEBUG
211NOOPT_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
212
213##################
214# X64 definitions
215##################
216*_VS2017_X64_CC_PATH = DEF(VS2017_BIN_X64)\cl.exe
217*_VS2017_X64_PP_PATH = DEF(VS2017_BIN_X64)\cl.exe
218*_VS2017_X64_APP_PATH = DEF(VS2017_BIN_X64)\cl.exe
219*_VS2017_X64_VFRPP_PATH = DEF(VS2017_BIN_X64)\cl.exe
220*_VS2017_X64_ASLCC_PATH = DEF(VS2017_BIN_X64)\cl.exe
221*_VS2017_X64_ASLPP_PATH = DEF(VS2017_BIN_X64)\cl.exe
222*_VS2017_X64_ASM_PATH = DEF(VS2017_BIN_X64)\ml64.exe
223*_VS2017_X64_SLINK_PATH = DEF(VS2017_BIN_X64)\lib.exe
224*_VS2017_X64_DLINK_PATH = DEF(VS2017_BIN_X64)\link.exe
225*_VS2017_X64_ASLDLINK_PATH = DEF(VS2017_BIN_X64)\link.exe
226
227 DEBUG_VS2017_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Gw /MP
228RELEASE_VS2017_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP
229NOOPT_VS2017_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od /MP
230
231 DEBUG_VS2017_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
232RELEASE_VS2017_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd
233NOOPT_VS2017_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
234
235 DEBUG_VS2017_X64_NASM_FLAGS = -Ox -f win64 -g
236RELEASE_VS2017_X64_NASM_FLAGS = -Ox -f win64
237NOOPT_VS2017_X64_NASM_FLAGS = -O0 -f win64 -g
238
239 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
240RELEASE_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 /DEBUG
241NOOPT_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
242
243#################
244# ARM definitions
245#################
246*_VS2017_ARM_CC_PATH = DEF(VS2017_BIN_ARM)\cl.exe
247*_VS2017_ARM_VFRPP_PATH = DEF(VS2017_BIN_ARM)\cl.exe
248*_VS2017_ARM_SLINK_PATH = DEF(VS2017_BIN_ARM)\lib.exe
249*_VS2017_ARM_DLINK_PATH = DEF(VS2017_BIN_ARM)\link.exe
250*_VS2017_ARM_APP_PATH = DEF(VS2017_BIN_ARM)\cl.exe
251*_VS2017_ARM_PP_PATH = DEF(VS2017_BIN_ARM)\cl.exe
252*_VS2017_ARM_ASM_PATH = DEF(VS2017_BIN_ARM)\armasm.exe
253*_VS2017_ARM_ASLCC_PATH = DEF(VS2017_BIN_ARM)\cl.exe
254*_VS2017_ARM_ASLPP_PATH = DEF(VS2017_BIN_ARM)\cl.exe
255*_VS2017_ARM_ASLDLINK_PATH = DEF(VS2017_BIN_ARM)\link.exe
256
257 *_VS2017_ARM_MAKE_FLAGS = /nologo
258 DEBUG_VS2017_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gm /Gw /Oi-
259RELEASE_VS2017_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi-
260NOOPT_VS2017_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gm /Od /Oi-
261
262 DEBUG_VS2017_ARM_ASM_FLAGS = /nologo /g
263RELEASE_VS2017_ARM_ASM_FLAGS = /nologo
264NOOPT_VS2017_ARM_ASM_FLAGS = /nologo
265
266 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
267RELEASE_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 /DEBUG
268NOOPT_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
269
270#####################
271# AARCH64 definitions
272#####################
273*_VS2017_AARCH64_CC_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
274*_VS2017_AARCH64_VFRPP_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
275*_VS2017_AARCH64_SLINK_PATH = DEF(VS2017_BIN_AARCH64)\lib.exe
276*_VS2017_AARCH64_DLINK_PATH = DEF(VS2017_BIN_AARCH64)\link.exe
277*_VS2017_AARCH64_APP_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
278*_VS2017_AARCH64_PP_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
279*_VS2017_AARCH64_ASM_PATH = DEF(VS2017_BIN_AARCH64)\armasm64.exe
280*_VS2017_AARCH64_ASLCC_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
281*_VS2017_AARCH64_ASLPP_PATH = DEF(VS2017_BIN_AARCH64)\cl.exe
282*_VS2017_AARCH64_ASLDLINK_PATH = DEF(VS2017_BIN_AARCH64)\link.exe
283
284 *_VS2017_AARCH64_MAKE_FLAGS = /nologo
285 DEBUG_VS2017_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gm /Gw /Oi-
286RELEASE_VS2017_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi-
287NOOPT_VS2017_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gm /Od /Oi-
288
289 DEBUG_VS2017_AARCH64_ASM_FLAGS = /nologo /g
290RELEASE_VS2017_AARCH64_ASM_FLAGS = /nologo
291NOOPT_VS2017_AARCH64_ASM_FLAGS = /nologo
292
293 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
294RELEASE_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 /DEBUG
295NOOPT_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
296
297##################
298# EBC definitions
299##################
300*_VS2017_EBC_*_FAMILY = INTEL
301
302*_VS2017_EBC_PP_PATH = DEF(EBC_BINx86)\iec.exe
303*_VS2017_EBC_VFRPP_PATH = DEF(EBC_BINx86)\iec.exe
304*_VS2017_EBC_CC_PATH = DEF(EBC_BINx86)\iec.exe
305*_VS2017_EBC_SLINK_PATH = DEF(VS2017_BIN_IA32)\link.exe
306*_VS2017_EBC_DLINK_PATH = DEF(VS2017_BIN_IA32)\link.exe
307
308*_VS2017_EBC_MAKE_FLAGS = /nologo
309*_VS2017_EBC_PP_FLAGS = /nologo /E /TC /FIAutoGen.h
310*_VS2017_EBC_CC_FLAGS = /nologo /c /WX /W3 /FIAutoGen.h /D$(MODULE_ENTRY_POINT)=$(ARCH_ENTRY_POINT)
311*_VS2017_EBC_VFRPP_FLAGS = /nologo /E /TC /DVFRCOMPILE /FI$(MODULE_NAME)StrDefs.h
312*_VS2017_EBC_SLINK_FLAGS = /lib /NOLOGO /MACHINE:EBC
313*_VS2017_EBC_DLINK_FLAGS = "C:\Program Files (x86)\Intel\EBC\Lib\EbcLib.lib" /NOLOGO /NODEFAULTLIB /MACHINE:EBC /OPT:REF /ENTRY:$(IMAGE_ENTRY_POINT) /SUBSYSTEM:EFI_BOOT_SERVICE_DRIVER /MAP /ALIGN:32 /DRIVER
314
315
316####################################################################################
317# VS2019 - Microsoft Visual Studio 2019 with Intel ASL
318# ASL - Intel ACPI Source Language Compiler (iasl.exe)
319####################################################################################
320# VS2019 - Microsoft Visual Studio 2019 professional Edition with Intel ASL
321*_VS2019_*_*_FAMILY = MSFT
322*_VS2019_*_*_DLL = DEF(VS2019_BIN_HOST)
323
324*_VS2019_*_MAKE_PATH = DEF(VS2019_BIN_HOST)\nmake.exe
325*_VS2019_*_MAKE_FLAGS = /nologo
326*_VS2019_*_RC_PATH = DEF(RC_PATH)
327
328*_VS2019_*_SLINK_FLAGS = /NOLOGO /LTCG
329*_VS2019_*_APP_FLAGS = /nologo /E /TC
330*_VS2019_*_PP_FLAGS = /nologo /E /TC /FIAutoGen.h
331*_VS2019_*_VFRPP_FLAGS = /nologo /E /TC /DVFRCOMPILE /FI$(MODULE_NAME)StrDefs.h
332*_VS2019_*_DLINK2_FLAGS = /WHOLEARCHIVE
333*_VS2019_*_ASM16_PATH = DEF(VS2019_BIN_IA32)\ml.exe
334*_VS2019_*_DEPS_FLAGS = DEF(MSFT_DEPS_FLAGS)
335##################
336# ASL definitions
337##################
338*_VS2019_*_ASL_PATH = DEF(WIN_IASL_BIN)
339*_VS2019_*_ASL_FLAGS = DEF(DEFAULT_WIN_ASL_FLAGS)
340*_VS2019_*_ASL_OUTFLAGS = DEF(DEFAULT_WIN_ASL_OUTFLAGS)
341*_VS2019_*_ASLCC_FLAGS = DEF(MSFT_ASLCC_FLAGS)
342*_VS2019_*_ASLPP_FLAGS = DEF(MSFT_ASLPP_FLAGS)
343*_VS2019_*_ASLDLINK_FLAGS = DEF(MSFT_ASLDLINK_FLAGS)
344
345##################
346# IA32 definitions
347##################
348*_VS2019_IA32_CC_PATH = DEF(VS2019_BIN_IA32)\cl.exe
349*_VS2019_IA32_VFRPP_PATH = DEF(VS2019_BIN_IA32)\cl.exe
350*_VS2019_IA32_ASLCC_PATH = DEF(VS2019_BIN_IA32)\cl.exe
351*_VS2019_IA32_ASLPP_PATH = DEF(VS2019_BIN_IA32)\cl.exe
352*_VS2019_IA32_SLINK_PATH = DEF(VS2019_BIN_IA32)\lib.exe
353*_VS2019_IA32_DLINK_PATH = DEF(VS2019_BIN_IA32)\link.exe
354*_VS2019_IA32_ASLDLINK_PATH= DEF(VS2019_BIN_IA32)\link.exe
355*_VS2019_IA32_APP_PATH = DEF(VS2019_BIN_IA32)\cl.exe
356*_VS2019_IA32_PP_PATH = DEF(VS2019_BIN_IA32)\cl.exe
357*_VS2019_IA32_ASM_PATH = DEF(VS2019_BIN_IA32)\ml.exe
358
359 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 /MP
360RELEASE_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP
361NOOPT_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od /MP
362
363 DEBUG_VS2019_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
364RELEASE_VS2019_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
365NOOPT_VS2019_IA32_ASM_FLAGS = /nologo /c /WX /W3 /Cx /coff /Zd /Zi
366
367# 2024-11-16 bird: Added our include directory for CryptoPkg\Library\IntrinsicLib\Ia32\ftol2-vcc.nasm using iprt/asmdefs.mac.
368 DEBUG_VS2019_IA32_NASM_FLAGS = -Ox -f win32 -g -I@VBOX_PATH_ROOT@/include
369RELEASE_VS2019_IA32_NASM_FLAGS = -Ox -f win32 -g -I@VBOX_PATH_ROOT@/include
370NOOPT_VS2019_IA32_NASM_FLAGS = -O0 -f win32 -g -I@VBOX_PATH_ROOT@/include
371
372 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
373RELEASE_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 /DEBUG
374NOOPT_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
375
376##################
377# X64 definitions
378##################
379*_VS2019_X64_CC_PATH = DEF(VS2019_BIN_X64)\cl.exe
380*_VS2019_X64_PP_PATH = DEF(VS2019_BIN_X64)\cl.exe
381*_VS2019_X64_APP_PATH = DEF(VS2019_BIN_X64)\cl.exe
382*_VS2019_X64_VFRPP_PATH = DEF(VS2019_BIN_X64)\cl.exe
383*_VS2019_X64_ASLCC_PATH = DEF(VS2019_BIN_X64)\cl.exe
384*_VS2019_X64_ASLPP_PATH = DEF(VS2019_BIN_X64)\cl.exe
385*_VS2019_X64_ASM_PATH = DEF(VS2019_BIN_X64)\ml64.exe
386*_VS2019_X64_SLINK_PATH = DEF(VS2019_BIN_X64)\lib.exe
387*_VS2019_X64_DLINK_PATH = DEF(VS2019_BIN_X64)\link.exe
388*_VS2019_X64_ASLDLINK_PATH = DEF(VS2019_BIN_X64)\link.exe
389
390 DEBUG_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Gw /MP /volatileMetadata-
391RELEASE_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP /volatileMetadata-
392NOOPT_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od /MP /volatileMetadata-
393
394 DEBUG_VS2019_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
395RELEASE_VS2019_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
396NOOPT_VS2019_X64_ASM_FLAGS = /nologo /c /WX /W3 /Cx /Zd /Zi
397
398# 2024-11-16 bird: Added our include directory.
399 DEBUG_VS2019_X64_NASM_FLAGS = -Ox -f win64 -g -I@VBOX_PATH_ROOT@/include
400RELEASE_VS2019_X64_NASM_FLAGS = -Ox -f win64 -g -I@VBOX_PATH_ROOT@/include
401NOOPT_VS2019_X64_NASM_FLAGS = -O0 -f win64 -g -I@VBOX_PATH_ROOT@/include
402
403 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
404RELEASE_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 /DEBUG
405NOOPT_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
406
407#################
408# ARM definitions
409#################
410*_VS2019_ARM_CC_PATH = DEF(VS2019_BIN_ARM)\cl.exe
411*_VS2019_ARM_VFRPP_PATH = DEF(VS2019_BIN_ARM)\cl.exe
412*_VS2019_ARM_SLINK_PATH = DEF(VS2019_BIN_ARM)\lib.exe
413*_VS2019_ARM_DLINK_PATH = DEF(VS2019_BIN_ARM)\link.exe
414*_VS2019_ARM_APP_PATH = DEF(VS2019_BIN_ARM)\cl.exe
415*_VS2019_ARM_PP_PATH = DEF(VS2019_BIN_ARM)\cl.exe
416*_VS2019_ARM_ASM_PATH = DEF(VS2019_BIN_ARM)\armasm.exe
417*_VS2019_ARM_ASLCC_PATH = DEF(VS2019_BIN_ARM)\cl.exe
418*_VS2019_ARM_ASLPP_PATH = DEF(VS2019_BIN_ARM)\cl.exe
419*_VS2019_ARM_ASLDLINK_PATH = DEF(VS2019_BIN_ARM)\link.exe
420
421 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- /MP
422RELEASE_VS2019_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi- /MP
423NOOPT_VS2019_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Od /Oi- /MP
424
425 DEBUG_VS2019_ARM_ASM_FLAGS = /nologo /g
426RELEASE_VS2019_ARM_ASM_FLAGS = /nologo
427NOOPT_VS2019_ARM_ASM_FLAGS = /nologo
428
429 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
430RELEASE_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 /DEBUG
431NOOPT_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
432
433#####################
434# AARCH64 definitions
435#####################
436*_VS2019_AARCH64_CC_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
437*_VS2019_AARCH64_VFRPP_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
438*_VS2019_AARCH64_SLINK_PATH = DEF(VS2019_BIN_AARCH64)\lib.exe
439*_VS2019_AARCH64_DLINK_PATH = DEF(VS2019_BIN_AARCH64)\link.exe
440*_VS2019_AARCH64_APP_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
441*_VS2019_AARCH64_PP_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
442*_VS2019_AARCH64_ASM_PATH = DEF(VS2019_BIN_AARCH64)\armasm64.exe
443*_VS2019_AARCH64_ASLCC_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
444*_VS2019_AARCH64_ASLPP_PATH = DEF(VS2019_BIN_AARCH64)\cl.exe
445*_VS2019_AARCH64_ASLDLINK_PATH = DEF(VS2019_BIN_AARCH64)\link.exe
446
447 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- /MP
448RELEASE_VS2019_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi- /MP
449NOOPT_VS2019_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Od /Oi- /MP
450
451 DEBUG_VS2019_AARCH64_ASM_FLAGS = /nologo /g
452RELEASE_VS2019_AARCH64_ASM_FLAGS = /nologo
453NOOPT_VS2019_AARCH64_ASM_FLAGS = /nologo
454
455 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
456RELEASE_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 /DEBUG
457NOOPT_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
458
459####################################################################################
460# GCC Common
461####################################################################################
462
463*_*_*_OBJCOPY_PATH = echo
464*_*_*_OBJCOPY_FLAGS = objcopy not needed for
465*_*_*_SYMRENAME_PATH = echo
466*_*_*_SYMRENAME_FLAGS = Symbol renaming not needed for
467DEBUG_*_*_OBJCOPY_ADDDEBUGFLAG = --add-gnu-debuglink=$(DEBUG_DIR)/$(MODULE_NAME).debug
468RELEASE_*_*_OBJCOPY_ADDDEBUGFLAG = --add-gnu-debuglink=$(DEBUG_DIR)/$(MODULE_NAME).debug
469NOOPT_*_*_OBJCOPY_ADDDEBUGFLAG = --add-gnu-debuglink=$(DEBUG_DIR)/$(MODULE_NAME).debug
470*_*_*_DTC_FLAGS = -H epapr
471*_*_*_DTCPP_PATH = DEF(DTCPP_BIN)
472*_*_*_DTC_PATH = DEF(DTC_BIN)
473
474DEFINE GCC_ALL_CC_FLAGS = -g -Os -fshort-wchar -fno-builtin -fno-strict-aliasing -Wall -Wno-array-bounds -include AutoGen.h -fno-common
475DEFINE 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
476DEFINE GCC_IA32_CC_FLAGS = DEF(GCC_ALL_CC_FLAGS) -m32 -malign-double -freorder-blocks -freorder-blocks-and-partition -O2 -mno-stack-arg-probe @VBOX_MINGW32_Wno@
477DEFINE GCC_X64_CC_FLAGS = DEF(GCC_ALL_CC_FLAGS) -mno-red-zone -Wno-address -mno-stack-arg-probe @VBOX_MINGW32_Wno@
478DEFINE GCC_ARM_CC_XIPFLAGS = -mno-unaligned-access
479DEFINE 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
480DEFINE GCC_AARCH64_CC_XIPFLAGS = -mstrict-align -mgeneral-regs-only
481DEFINE GCC_RISCV64_CC_XIPFLAGS = -mstrict-align -mgeneral-regs-only
482DEFINE GCC_DLINK_FLAGS_COMMON = -nostdlib --pie
483DEFINE GCC_DLINK2_FLAGS_COMMON = -Wl,--script=$(EDK_TOOLS_PATH)/Scripts/GccBase.lds
484DEFINE GCC_IA32_X64_DLINK_COMMON = DEF(GCC_DLINK_FLAGS_COMMON) --gc-sections
485DEFINE 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
486DEFINE GCC_ARM_DLINK_FLAGS = DEF(GCC_ARM_AARCH64_DLINK_COMMON) -z common-page-size=0x20 -Wl,--pic-veneer
487DEFINE GCC_AARCH64_DLINK_FLAGS = DEF(GCC_ARM_AARCH64_DLINK_COMMON) -z common-page-size=0x20
488DEFINE GCC_ARM_AARCH64_ASLDLINK_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0 DEF(GCC_DLINK2_FLAGS_COMMON) -z common-page-size=0x20
489DEFINE GCC_IA32_X64_ASLDLINK_FLAGS = DEF(GCC_IA32_X64_DLINK_COMMON) --entry _ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT)
490DEFINE GCC_ARM_ASLDLINK_FLAGS = DEF(GCC_ARM_DLINK_FLAGS) -Wl,--entry,ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT) DEF(GCC_ARM_AARCH64_ASLDLINK_FLAGS)
491DEFINE GCC_AARCH64_ASLDLINK_FLAGS = DEF(GCC_AARCH64_DLINK_FLAGS) -Wl,--entry,ReferenceAcpiTable -u $(IMAGE_ENTRY_POINT) DEF(GCC_ARM_AARCH64_ASLDLINK_FLAGS)
492DEFINE 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
493DEFINE GCC_ASM_FLAGS = -c -x assembler -imacros $(DEST_DIR_DEBUG)/AutoGen.h
494DEFINE GCC_PP_FLAGS = -E -x assembler-with-cpp -include $(DEST_DIR_DEBUG)/AutoGen.h
495DEFINE GCC_VFRPP_FLAGS = -x c -E -P -DVFRCOMPILE --include $(DEST_DIR_DEBUG)/$(MODULE_NAME)StrDefs.h
496DEFINE GCC_ASLPP_FLAGS = -x c -E -include AutoGen.h
497DEFINE GCC_ASLCC_FLAGS = -x c
498DEFINE GCC_WINDRES_FLAGS = -J rc -O coff
499DEFINE GCC_DTCPP_FLAGS = -E -x assembler-with-cpp -imacros $(DEST_DIR_DEBUG)/AutoGen.h -nostdinc -undef
500DEFINE GCC_IA32_RC_FLAGS = -I binary -O elf32-i386 -B i386 --rename-section .data=.hii
501DEFINE GCC_X64_RC_FLAGS = -I binary -O elf64-x86-64 -B i386 --rename-section .data=.hii
502DEFINE GCC_ARM_RC_FLAGS = -I binary -O elf32-littlearm -B arm --rename-section .data=.hii
503DEFINE GCC_AARCH64_RC_FLAGS = -I binary -O elf64-littleaarch64 -B aarch64 --rename-section .data=.hii
504DEFINE GCC_AARCH64_RC_BTI_FLAGS = --add-section .note.gnu.property=$(WORKSPACE)/ArmPkg/Library/GnuNoteBti.bin --set-section-flags .note.gnu.property=alloc,readonly
505DEFINE GCC_RISCV64_RC_FLAGS = -I binary -O elf64-littleriscv -B riscv --rename-section .data=.hii
506
507# GCC Build Flag for included header file list generation
508DEFINE GCC_DEPS_FLAGS = -MMD -MF $@.deps
509
510DEFINE GCC48_ALL_CC_FLAGS = -g -fshort-wchar -fno-builtin -fno-strict-aliasing -Wall -Wno-array-bounds -ffunction-sections -fdata-sections -include AutoGen.h -fno-common -DSTRING_ARRAY_NAME=$(BASE_NAME)Strings
511DEFINE GCC48_IA32_X64_DLINK_COMMON = -nostdlib -Wl,-n,-q,--gc-sections -z common-page-size=0x20
512DEFINE 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-pie -fno-pic
513DEFINE 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
514DEFINE GCC48_IA32_X64_ASLDLINK_FLAGS = DEF(GCC48_IA32_X64_DLINK_COMMON) -Wl,--entry,ReferenceAcpiTable -u ReferenceAcpiTable
515DEFINE 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
516DEFINE GCC48_IA32_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x220 DEF(GCC_DLINK2_FLAGS_COMMON)
517DEFINE GCC48_X64_DLINK_FLAGS = DEF(GCC48_IA32_X64_DLINK_FLAGS) -Wl,-melf_x86_64,--oformat=elf64-x86-64,-pie
518DEFINE GCC48_X64_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x228 DEF(GCC_DLINK2_FLAGS_COMMON)
519DEFINE GCC48_ASM_FLAGS = DEF(GCC_ASM_FLAGS)
520DEFINE GCC48_ARM_ASM_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_ASM_FLAGS) -mlittle-endian
521DEFINE GCC48_AARCH64_ASM_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_ASM_FLAGS) -mlittle-endian
522DEFINE GCC48_ARM_CC_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_ARM_CC_FLAGS) -fstack-protector -mword-relocations
523DEFINE GCC48_ARM_CC_XIPFLAGS = DEF(GCC_ARM_CC_XIPFLAGS)
524DEFINE GCC48_AARCH64_CC_FLAGS = $(PLATFORM_FLAGS) -mcmodel=large DEF(GCC_AARCH64_CC_FLAGS)
525DEFINE GCC48_AARCH64_CC_XIPFLAGS = DEF(GCC_AARCH64_CC_XIPFLAGS)
526DEFINE GCC48_ARM_DLINK_FLAGS = DEF(GCC_ARM_DLINK_FLAGS) -Wl,--oformat=elf32-littlearm
527DEFINE GCC48_ARM_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x220
528DEFINE GCC48_AARCH64_DLINK_FLAGS = DEF(GCC_AARCH64_DLINK_FLAGS)
529DEFINE GCC48_AARCH64_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x228
530DEFINE GCC48_ARM_ASLDLINK_FLAGS = DEF(GCC_ARM_ASLDLINK_FLAGS) -Wl,--oformat=elf32-littlearm
531DEFINE GCC48_AARCH64_ASLDLINK_FLAGS = DEF(GCC_AARCH64_ASLDLINK_FLAGS)
532DEFINE GCC48_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
533
534DEFINE GCC49_IA32_CC_FLAGS = DEF(GCC48_IA32_CC_FLAGS) -fno-pic -fno-pie
535DEFINE GCC49_X64_CC_FLAGS = DEF(GCC48_X64_CC_FLAGS)
536DEFINE GCC49_IA32_X64_DLINK_COMMON = -nostdlib -Wl,-n,-q,--gc-sections -z common-page-size=0x40
537DEFINE 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
538DEFINE 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
539DEFINE GCC49_IA32_DLINK2_FLAGS = DEF(GCC48_IA32_DLINK2_FLAGS)
540DEFINE GCC49_X64_DLINK_FLAGS = DEF(GCC49_IA32_X64_DLINK_FLAGS) -Wl,-melf_x86_64,--oformat=elf64-x86-64,-pie
541DEFINE GCC49_X64_DLINK2_FLAGS = DEF(GCC48_X64_DLINK2_FLAGS)
542DEFINE GCC49_ASM_FLAGS = DEF(GCC48_ASM_FLAGS)
543DEFINE GCC49_ARM_ASM_FLAGS = DEF(GCC48_ARM_ASM_FLAGS)
544DEFINE GCC49_AARCH64_ASM_FLAGS = DEF(GCC48_AARCH64_ASM_FLAGS)
545DEFINE GCC49_ARM_CC_FLAGS = DEF(GCC48_ARM_CC_FLAGS)
546DEFINE GCC49_ARM_CC_XIPFLAGS = DEF(GCC48_ARM_CC_XIPFLAGS)
547DEFINE GCC49_AARCH64_CC_FLAGS = $(PLATFORM_FLAGS) DEF(GCC48_ALL_CC_FLAGS) DEF(GCC_AARCH64_CC_FLAGS) -mcmodel=small
548DEFINE GCC49_AARCH64_CC_XIPFLAGS = DEF(GCC48_AARCH64_CC_XIPFLAGS)
549DEFINE GCC49_ARM_DLINK_FLAGS = DEF(GCC48_ARM_DLINK_FLAGS)
550DEFINE GCC49_ARM_DLINK2_FLAGS = DEF(GCC48_ARM_DLINK2_FLAGS)
551DEFINE GCC49_AARCH64_DLINK_FLAGS = DEF(GCC48_AARCH64_DLINK_FLAGS) -z common-page-size=0x1000
552DEFINE GCC49_AARCH64_DLINK2_FLAGS = DEF(GCC48_AARCH64_DLINK2_FLAGS)
553DEFINE GCC49_ARM_ASLDLINK_FLAGS = DEF(GCC48_ARM_ASLDLINK_FLAGS)
554DEFINE GCC49_AARCH64_ASLDLINK_FLAGS = DEF(GCC48_AARCH64_ASLDLINK_FLAGS)
555DEFINE GCC49_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS)
556
557DEFINE GCC5_IA32_CC_FLAGS = DEF(GCC49_IA32_CC_FLAGS)
558DEFINE GCC5_X64_CC_FLAGS = DEF(GCC49_X64_CC_FLAGS)
559DEFINE GCC5_IA32_X64_DLINK_COMMON = DEF(GCC49_IA32_X64_DLINK_COMMON)
560DEFINE GCC5_IA32_X64_ASLDLINK_FLAGS = DEF(GCC49_IA32_X64_ASLDLINK_FLAGS)
561DEFINE GCC5_IA32_X64_DLINK_FLAGS = DEF(GCC49_IA32_X64_DLINK_FLAGS)
562DEFINE GCC5_IA32_DLINK2_FLAGS = DEF(GCC49_IA32_DLINK2_FLAGS) -Wno-error
563DEFINE GCC5_X64_DLINK_FLAGS = DEF(GCC49_X64_DLINK_FLAGS)
564DEFINE GCC5_X64_DLINK2_FLAGS = DEF(GCC49_X64_DLINK2_FLAGS) -Wno-error
565DEFINE GCC5_ASM_FLAGS = DEF(GCC49_ASM_FLAGS)
566DEFINE GCC5_ARM_ASM_FLAGS = DEF(GCC49_ARM_ASM_FLAGS)
567DEFINE GCC5_AARCH64_ASM_FLAGS = DEF(GCC49_AARCH64_ASM_FLAGS)
568DEFINE GCC5_ARM_CC_FLAGS = DEF(GCC49_ARM_CC_FLAGS)
569DEFINE GCC5_ARM_CC_XIPFLAGS = DEF(GCC49_ARM_CC_XIPFLAGS)
570DEFINE GCC5_AARCH64_CC_FLAGS = DEF(GCC49_AARCH64_CC_FLAGS)
571DEFINE GCC5_AARCH64_CC_XIPFLAGS = DEF(GCC49_AARCH64_CC_XIPFLAGS)
572DEFINE GCC5_ARM_DLINK_FLAGS = DEF(GCC49_ARM_DLINK_FLAGS)
573DEFINE GCC5_ARM_DLINK2_FLAGS = DEF(GCC49_ARM_DLINK2_FLAGS) -Wno-error
574DEFINE GCC5_AARCH64_DLINK_FLAGS = DEF(GCC49_AARCH64_DLINK_FLAGS)
575DEFINE GCC5_AARCH64_DLINK2_FLAGS = DEF(GCC49_AARCH64_DLINK2_FLAGS) -Wno-error
576DEFINE GCC5_ARM_ASLDLINK_FLAGS = DEF(GCC49_ARM_ASLDLINK_FLAGS)
577DEFINE GCC5_AARCH64_ASLDLINK_FLAGS = DEF(GCC49_AARCH64_ASLDLINK_FLAGS)
578DEFINE GCC5_ASLCC_FLAGS = DEF(GCC49_ASLCC_FLAGS) -fno-lto
579
580DEFINE 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
581DEFINE GCC5_RISCV_ALL_DLINK_COMMON = -nostdlib -Wl,-n,-q,--gc-sections -z common-page-size=0x40
582DEFINE 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
583DEFINE GCC5_RISCV_ALL_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x220,--script=$(EDK_TOOLS_PATH)/Scripts/GccBase.lds
584DEFINE GCC5_RISCV_ALL_ASM_FLAGS = -c -x assembler -imacros $(DEST_DIR_DEBUG)/AutoGen.h
585DEFINE GCC5_RISCV_ALL_CC_FLAGS_WARNING_DISABLE = -Wno-tautological-compare -Wno-pointer-compare
586
587DEFINE GCC5_RISCV_OPENSBI_TYPES = -DOPENSBI_EXTERNAL_SBI_TYPES=OpensbiTypes.h
588
589DEFINE GCC5_RISCV64_ARCH = rv64gc
590DEFINE GCC5_RISCV32_RISCV64_ASLDLINK_FLAGS = DEF(GCC5_RISCV_ALL_DLINK_COMMON) -Wl,--entry,ReferenceAcpiTable -u ReferenceAcpiTable
591DEFINE 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 -fno-unwind-tables -Wno-unused-but-set-variable -fpack-struct=8 -mcmodel=medany -mabi=lp64 -mno-relax
592DEFINE GCC5_RISCV64_DLINK_FLAGS = DEF(GCC5_RISCV_ALL_DLINK_FLAGS) -Wl,-melf64lriscv,--oformat=elf64-littleriscv,--no-relax
593DEFINE GCC5_RISCV64_DLINK2_FLAGS = DEF(GCC5_RISCV_ALL_DLINK2_FLAGS)
594DEFINE GCC5_RISCV64_ASM_FLAGS = DEF(GCC5_RISCV_ALL_ASM_FLAGS) -march=DEF(GCC5_RISCV64_ARCH) -mcmodel=medany -mabi=lp64
595
596
597####################################################################################
598#
599# GCC 4.8 - This configuration is used to compile under Linux to produce
600# PE/COFF binaries using GCC 4.8.
601#
602####################################################################################
603*_GCC48_*_*_FAMILY = GCC
604
605*_GCC48_*_MAKE_PATH = @KMK@
606*_GCC48_*_*_DLL = ENV(GCC48_DLL)
607*_GCC48_*_ASL_PATH = DEF(UNIX_IASL_BIN)
608
609*_GCC48_*_PP_FLAGS = DEF(GCC_PP_FLAGS)
610*_GCC48_*_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS)
611*_GCC48_*_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
612*_GCC48_*_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS)
613*_GCC48_*_APP_FLAGS =
614*_GCC48_*_ASL_FLAGS = DEF(IASL_FLAGS)
615*_GCC48_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
616
617##################
618# GCC48 IA32 definitions
619##################
620*_GCC48_IA32_OBJCOPY_PATH = DEF(GCC48_IA32_PREFIX)objcopy
621*_GCC48_IA32_CC_PATH = DEF(GCC48_IA32_PREFIX)gcc
622*_GCC48_IA32_SLINK_PATH = DEF(GCC48_IA32_PREFIX)ar
623*_GCC48_IA32_DLINK_PATH = DEF(GCC48_IA32_PREFIX)gcc
624*_GCC48_IA32_ASLDLINK_PATH = DEF(GCC48_IA32_PREFIX)gcc
625*_GCC48_IA32_ASM_PATH = DEF(GCC48_IA32_PREFIX)gcc
626*_GCC48_IA32_PP_PATH = DEF(GCC48_IA32_PREFIX)gcc
627*_GCC48_IA32_VFRPP_PATH = DEF(GCC48_IA32_PREFIX)gcc
628*_GCC48_IA32_ASLCC_PATH = DEF(GCC48_IA32_PREFIX)gcc
629*_GCC48_IA32_ASLPP_PATH = DEF(GCC48_IA32_PREFIX)gcc
630*_GCC48_IA32_RC_PATH = DEF(GCC48_IA32_PREFIX)objcopy
631
632*_GCC48_IA32_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS) -m32
633*_GCC48_IA32_ASLDLINK_FLAGS = DEF(GCC48_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_i386
634*_GCC48_IA32_ASM_FLAGS = DEF(GCC48_ASM_FLAGS) -m32 -march=i386
635*_GCC48_IA32_DLINK_FLAGS = DEF(GCC48_IA32_X64_DLINK_FLAGS) -Wl,-m,elf_i386,--oformat=elf32-i386
636*_GCC48_IA32_DLINK2_FLAGS = DEF(GCC48_IA32_DLINK2_FLAGS)
637*_GCC48_IA32_RC_FLAGS = DEF(GCC_IA32_RC_FLAGS)
638*_GCC48_IA32_OBJCOPY_FLAGS =
639*_GCC48_IA32_NASM_FLAGS = -f elf32
640
641 DEBUG_GCC48_IA32_CC_FLAGS = DEF(GCC48_IA32_CC_FLAGS) -Os
642RELEASE_GCC48_IA32_CC_FLAGS = DEF(GCC48_IA32_CC_FLAGS) -Os -Wno-unused-but-set-variable
643 NOOPT_GCC48_IA32_CC_FLAGS = DEF(GCC48_IA32_CC_FLAGS) -O0
644
645##################
646# GCC48 X64 definitions
647##################
648*_GCC48_X64_OBJCOPY_PATH = DEF(GCC48_X64_PREFIX)objcopy
649*_GCC48_X64_CC_PATH = DEF(GCC48_X64_PREFIX)gcc
650*_GCC48_X64_SLINK_PATH = DEF(GCC48_X64_PREFIX)ar
651*_GCC48_X64_DLINK_PATH = DEF(GCC48_X64_PREFIX)gcc
652*_GCC48_X64_ASLDLINK_PATH = DEF(GCC48_X64_PREFIX)gcc
653*_GCC48_X64_ASM_PATH = DEF(GCC48_X64_PREFIX)gcc
654*_GCC48_X64_PP_PATH = DEF(GCC48_X64_PREFIX)gcc
655*_GCC48_X64_VFRPP_PATH = DEF(GCC48_X64_PREFIX)gcc
656*_GCC48_X64_ASLCC_PATH = DEF(GCC48_X64_PREFIX)gcc
657*_GCC48_X64_ASLPP_PATH = DEF(GCC48_X64_PREFIX)gcc
658*_GCC48_X64_RC_PATH = DEF(GCC48_X64_PREFIX)objcopy
659
660*_GCC48_X64_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS) -m64
661*_GCC48_X64_ASLDLINK_FLAGS = DEF(GCC48_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_x86_64
662*_GCC48_X64_ASM_FLAGS = DEF(GCC48_ASM_FLAGS) -m64
663*_GCC48_X64_DLINK_FLAGS = DEF(GCC48_X64_DLINK_FLAGS)
664*_GCC48_X64_DLINK2_FLAGS = DEF(GCC48_X64_DLINK2_FLAGS)
665*_GCC48_X64_RC_FLAGS = DEF(GCC_X64_RC_FLAGS)
666*_GCC48_X64_OBJCOPY_FLAGS =
667*_GCC48_X64_NASM_FLAGS = -f elf64
668
669 DEBUG_GCC48_X64_CC_FLAGS = DEF(GCC48_X64_CC_FLAGS) -Os
670RELEASE_GCC48_X64_CC_FLAGS = DEF(GCC48_X64_CC_FLAGS) -Os -Wno-unused-but-set-variable
671 NOOPT_GCC48_X64_CC_FLAGS = DEF(GCC48_X64_CC_FLAGS) -O0
672
673##################
674# GCC48 ARM definitions
675##################
676*_GCC48_ARM_CC_PATH = DEF(GCC48_ARM_PREFIX)gcc
677*_GCC48_ARM_SLINK_PATH = DEF(GCC48_ARM_PREFIX)ar
678*_GCC48_ARM_DLINK_PATH = DEF(GCC48_ARM_PREFIX)gcc
679*_GCC48_ARM_ASLDLINK_PATH = DEF(GCC48_ARM_PREFIX)gcc
680*_GCC48_ARM_ASM_PATH = DEF(GCC48_ARM_PREFIX)gcc
681*_GCC48_ARM_PP_PATH = DEF(GCC48_ARM_PREFIX)gcc
682*_GCC48_ARM_VFRPP_PATH = DEF(GCC48_ARM_PREFIX)gcc
683*_GCC48_ARM_ASLCC_PATH = DEF(GCC48_ARM_PREFIX)gcc
684*_GCC48_ARM_ASLPP_PATH = DEF(GCC48_ARM_PREFIX)gcc
685*_GCC48_ARM_RC_PATH = DEF(GCC48_ARM_PREFIX)objcopy
686
687*_GCC48_ARM_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS)
688*_GCC48_ARM_ASLDLINK_FLAGS = DEF(GCC48_ARM_ASLDLINK_FLAGS)
689*_GCC48_ARM_ASM_FLAGS = DEF(GCC48_ARM_ASM_FLAGS)
690*_GCC48_ARM_DLINK_FLAGS = DEF(GCC48_ARM_DLINK_FLAGS)
691*_GCC48_ARM_DLINK2_FLAGS = DEF(GCC48_ARM_DLINK2_FLAGS)
692*_GCC48_ARM_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
693*_GCC48_ARM_PLATFORM_FLAGS = -march=armv7-a
694*_GCC48_ARM_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
695*_GCC48_ARM_RC_FLAGS = DEF(GCC_ARM_RC_FLAGS)
696*_GCC48_ARM_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
697*_GCC48_ARM_CC_XIPFLAGS = DEF(GCC48_ARM_CC_XIPFLAGS)
698
699 DEBUG_GCC48_ARM_CC_FLAGS = DEF(GCC48_ARM_CC_FLAGS) -O0
700RELEASE_GCC48_ARM_CC_FLAGS = DEF(GCC48_ARM_CC_FLAGS) -Wno-unused-but-set-variable
701 NOOPT_GCC48_ARM_CC_FLAGS = DEF(GCC48_ARM_CC_FLAGS) -O0
702
703##################
704# GCC48 AARCH64 definitions
705##################
706*_GCC48_AARCH64_CC_PATH = DEF(GCC48_AARCH64_PREFIX)gcc
707*_GCC48_AARCH64_SLINK_PATH = DEF(GCC48_AARCH64_PREFIX)ar
708*_GCC48_AARCH64_DLINK_PATH = DEF(GCC48_AARCH64_PREFIX)gcc
709*_GCC48_AARCH64_ASLDLINK_PATH = DEF(GCC48_AARCH64_PREFIX)gcc
710*_GCC48_AARCH64_ASM_PATH = DEF(GCC48_AARCH64_PREFIX)gcc
711*_GCC48_AARCH64_PP_PATH = DEF(GCC48_AARCH64_PREFIX)gcc
712*_GCC48_AARCH64_VFRPP_PATH = DEF(GCC48_AARCH64_PREFIX)gcc
713*_GCC48_AARCH64_ASLCC_PATH = DEF(GCC48_AARCH64_PREFIX)gcc
714*_GCC48_AARCH64_ASLPP_PATH = DEF(GCC48_AARCH64_PREFIX)gcc
715*_GCC48_AARCH64_RC_PATH = DEF(GCC48_AARCH64_PREFIX)objcopy
716
717*_GCC48_AARCH64_ASLCC_FLAGS = DEF(GCC48_ASLCC_FLAGS)
718*_GCC48_AARCH64_ASLDLINK_FLAGS = DEF(GCC48_AARCH64_ASLDLINK_FLAGS)
719*_GCC48_AARCH64_ASM_FLAGS = DEF(GCC48_AARCH64_ASM_FLAGS)
720*_GCC48_AARCH64_DLINK_FLAGS = DEF(GCC48_AARCH64_DLINK_FLAGS)
721*_GCC48_AARCH64_DLINK2_FLAGS = DEF(GCC48_AARCH64_DLINK2_FLAGS)
722*_GCC48_AARCH64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
723*_GCC48_AARCH64_PLATFORM_FLAGS =
724*_GCC48_AARCH64_PP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_PP_FLAGS)
725*_GCC48_AARCH64_RC_FLAGS = DEF(GCC_AARCH64_RC_FLAGS)
726*_GCC48_AARCH64_VFRPP_FLAGS = $(PLATFORM_FLAGS) DEF(GCC_VFRPP_FLAGS)
727*_GCC48_AARCH64_CC_XIPFLAGS = DEF(GCC48_AARCH64_CC_XIPFLAGS)
728
729 DEBUG_GCC48_AARCH64_CC_FLAGS = DEF(GCC48_AARCH64_CC_FLAGS) -O0
730RELEASE_GCC48_AARCH64_CC_FLAGS = DEF(GCC48_AARCH64_CC_FLAGS) -Wno-unused-but-set-variable
731 NOOPT_GCC48_AARCH64_CC_FLAGS = DEF(GCC48_AARCH64_CC_FLAGS) -O0
732
733####################################################################################
734#
735# CLANGDWARF - This configuration is used to compile under Windows/Linux/Mac to produce
736# ELF binaries using LLVM/Clang/LLD with Link Time Optimization enabled
737#
738####################################################################################
739*_CLANGDWARF_*_*_FAMILY = GCC
740
741*_CLANGDWARF_*_MAKE_PATH = @KMK@
742*_CLANGDWARF_*_*_DLL = @VBOX_PATH_CLANG_BIN@
743*_CLANGDWARF_*_ASL_PATH = DEF(UNIX_IASL_BIN)
744
745*_CLANGDWARF_*_APP_FLAGS =
746*_CLANGDWARF_*_ASL_FLAGS = DEF(IASL_FLAGS)
747*_CLANGDWARF_*_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
748
749DEFINE CLANGDWARF_IA32_PREFIX = @VBOX_VCC143-CLANGXX_PREFIX@
750DEFINE CLANGDWARF_X64_PREFIX = @VBOX_VCC143-CLANGXX_PREFIX@
751
752# LLVM/CLANG doesn't support -n link option. So, it can't share the same IA32_X64_DLINK_COMMON flag.
753# LLVM/CLANG doesn't support common page size. So, it can't share the same GccBase.lds script.
754DEFINE CLANGDWARF_IA32_X64_DLINK_COMMON = -nostdlib -Wl,-q,--gc-sections -z max-page-size=0x40
755DEFINE CLANGDWARF_DLINK2_FLAGS_COMMON = -Wl,--script=$(EDK_TOOLS_PATH)/Scripts/ClangBase.lds
756DEFINE 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
757DEFINE 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
758DEFINE CLANGDWARF_IA32_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x220 DEF(CLANGDWARF_DLINK2_FLAGS_COMMON)
759DEFINE CLANGDWARF_X64_DLINK2_FLAGS = -Wl,--defsym=PECOFF_HEADER_SIZE=0x228 DEF(CLANGDWARF_DLINK2_FLAGS_COMMON)
760
761DEFINE CLANGDWARF_IA32_TARGET = -target i686-pc-linux-gnu
762DEFINE CLANGDWARF_X64_TARGET = -target x86_64-pc-linux-gnu
763
764DEFINE CLANGDWARF_WARNING_OVERRIDES = -Wno-parentheses-equality -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 -Wno-int-conversion
765DEFINE 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
766
767###########################
768# CLANGDWARF IA32 definitions
769###########################
770*_CLANGDWARF_IA32_CC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
771*_CLANGDWARF_IA32_SLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@ar
772*_CLANGDWARF_IA32_DLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
773*_CLANGDWARF_IA32_ASLDLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
774*_CLANGDWARF_IA32_ASM_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
775*_CLANGDWARF_IA32_PP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
776*_CLANGDWARF_IA32_VFRPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
777*_CLANGDWARF_IA32_ASLCC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
778*_CLANGDWARF_IA32_ASLPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
779*_CLANGDWARF_IA32_RC_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@objcopy
780
781*_CLANGDWARF_IA32_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -m32 -fno-lto DEF(CLANGDWARF_IA32_TARGET)
782*_CLANGDWARF_IA32_ASLDLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_i386 -fuse-ld=lld -no-pie
783*_CLANGDWARF_IA32_ASM_FLAGS = DEF(GCC5_ASM_FLAGS) -m32 -march=i386 DEF(CLANGDWARF_IA32_TARGET)
784*_CLANGDWARF_IA32_RC_FLAGS = DEF(GCC_IA32_RC_FLAGS)
785*_CLANGDWARF_IA32_OBJCOPY_FLAGS =
786*_CLANGDWARF_IA32_NASM_FLAGS = -f elf32
787*_CLANGDWARF_IA32_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGDWARF_IA32_TARGET)
788*_CLANGDWARF_IA32_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGDWARF_IA32_TARGET)
789*_CLANGDWARF_IA32_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGDWARF_IA32_TARGET)
790
791DEBUG_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
792DEBUG_CLANGDWARF_IA32_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_FLAGS) -flto -Wl,-O3 -Wl,-melf_i386 -Wl,--oformat,elf32-i386
793DEBUG_CLANGDWARF_IA32_DLINK2_FLAGS = DEF(CLANGDWARF_IA32_DLINK2_FLAGS) -O3 -fuse-ld=lld -no-pie
794
795RELEASE_CLANGDWARF_IA32_CC_FLAGS = DEF(CLANGDWARF_ALL_CC_FLAGS) -fno-pic -fno-pie -m32 -Oz -flto -march=i586 DEF(CLANGDWARF_IA32_TARGET) -malign-double
796RELEASE_CLANGDWARF_IA32_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_FLAGS) -flto -Wl,-O3 -Wl,-melf_i386 -Wl,--oformat,elf32-i386
797RELEASE_CLANGDWARF_IA32_DLINK2_FLAGS = DEF(CLANGDWARF_IA32_DLINK2_FLAGS) -O3 -fuse-ld=lld -no-pie
798
799NOOPT_CLANGDWARF_IA32_CC_FLAGS = DEF(CLANGDWARF_ALL_CC_FLAGS) -fno-pic -fno-pie -m32 -O0 -march=i586 DEF(CLANGDWARF_IA32_TARGET) -g -malign-double
800NOOPT_CLANGDWARF_IA32_DLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_DLINK_FLAGS) -Wl,-O0 -Wl,-melf_i386 -Wl,--oformat,elf32-i386
801NOOPT_CLANGDWARF_IA32_DLINK2_FLAGS = DEF(CLANGDWARF_IA32_DLINK2_FLAGS) -O0 -fuse-ld=lld -no-pie
802
803##########################
804# CLANGDWARF X64 definitions
805##########################
806*_CLANGDWARF_X64_CC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
807*_CLANGDWARF_X64_SLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@ar
808*_CLANGDWARF_X64_DLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
809*_CLANGDWARF_X64_ASLDLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
810*_CLANGDWARF_X64_ASM_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
811*_CLANGDWARF_X64_PP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
812*_CLANGDWARF_X64_VFRPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
813*_CLANGDWARF_X64_ASLCC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
814*_CLANGDWARF_X64_ASLPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
815*_CLANGDWARF_X64_RC_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@objcopy
816
817*_CLANGDWARF_X64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -m64 -fno-lto DEF(CLANGDWARF_X64_TARGET)
818*_CLANGDWARF_X64_ASLDLINK_FLAGS = DEF(CLANGDWARF_IA32_X64_ASLDLINK_FLAGS) -Wl,-m,elf_x86_64 -fuse-ld=lld
819*_CLANGDWARF_X64_ASM_FLAGS = DEF(GCC5_ASM_FLAGS) -m64 DEF(CLANGDWARF_X64_TARGET)
820*_CLANGDWARF_X64_RC_FLAGS = DEF(GCC_X64_RC_FLAGS)
821*_CLANGDWARF_X64_OBJCOPY_FLAGS =
822*_CLANGDWARF_X64_NASM_FLAGS = -f elf64
823*_CLANGDWARF_X64_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGDWARF_X64_TARGET)
824*_CLANGDWARF_X64_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGDWARF_X64_TARGET)
825*_CLANGDWARF_X64_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGDWARF_X64_TARGET)
826
827DEBUG_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
828DEBUG_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
829DEBUG_CLANGDWARF_X64_DLINK2_FLAGS = DEF(CLANGDWARF_X64_DLINK2_FLAGS) -O3 -fuse-ld=lld
830
831RELEASE_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)
832RELEASE_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
833RELEASE_CLANGDWARF_X64_DLINK2_FLAGS = DEF(CLANGDWARF_X64_DLINK2_FLAGS) -O3 -fuse-ld=lld
834
835NOOPT_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
836NOOPT_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
837NOOPT_CLANGDWARF_X64_DLINK2_FLAGS = DEF(CLANGDWARF_X64_DLINK2_FLAGS) -O0 -fuse-ld=lld
838
839##################
840# CLANGDWARF ARM definitions
841##################
842DEFINE CLANGDWARF_ARM_TARGET = -target arm-linux-gnueabi
843DEFINE CLANGDWARF_ARM_CC_FLAGS = DEF(GCC_ARM_CC_FLAGS) DEF(CLANGDWARF_ARM_TARGET) DEF(CLANGDWARF_WARNING_OVERRIDES) -mno-movt
844DEFINE CLANGDWARF_ARM_DLINK_FLAGS = DEF(CLANGDWARF_ARM_TARGET) DEF(GCC_ARM_DLINK_FLAGS)
845
846*_CLANGDWARF_ARM_PP_FLAGS = DEF(GCC_PP_FLAGS)
847*_CLANGDWARF_ARM_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
848*_CLANGDWARF_ARM_APP_FLAGS =
849*_CLANGDWARF_ARM_ASL_FLAGS = DEF(IASL_FLAGS)
850*_CLANGDWARF_ARM_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
851*_CLANGDWARF_ARM_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
852
853*_CLANGDWARF_ARM_CC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
854*_CLANGDWARF_ARM_ASM_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
855*_CLANGDWARF_ARM_PP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
856*_CLANGDWARF_ARM_VFRPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
857*_CLANGDWARF_ARM_ASLCC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
858*_CLANGDWARF_ARM_ASLPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
859*_CLANGDWARF_ARM_DLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
860*_CLANGDWARF_ARM_ASLDLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
861
862*_CLANGDWARF_ARM_SLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@ar
863*_CLANGDWARF_ARM_RC_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@objcopy
864
865*_CLANGDWARF_ARM_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -fno-lto
866*_CLANGDWARF_ARM_ASLDLINK_FLAGS = DEF(CLANGDWARF_ARM_TARGET) DEF(GCC_ARM_ASLDLINK_FLAGS)
867*_CLANGDWARF_ARM_ASM_FLAGS = DEF(GCC_ASM_FLAGS) DEF(CLANGDWARF_ARM_TARGET) $(PLATFORM_FLAGS) -Qunused-arguments
868*_CLANGDWARF_ARM_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x220
869*_CLANGDWARF_ARM_PLATFORM_FLAGS = -march=armv7-a
870*_CLANGDWARF_ARM_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGDWARF_ARM_TARGET) $(PLATFORM_FLAGS)
871*_CLANGDWARF_ARM_RC_FLAGS = DEF(GCC_ARM_RC_FLAGS)
872*_CLANGDWARF_ARM_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGDWARF_ARM_TARGET) $(PLATFORM_FLAGS)
873*_CLANGDWARF_ARM_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGDWARF_ARM_TARGET)
874*_CLANGDWARF_ARM_CC_XIPFLAGS = DEF(GCC_ARM_CC_XIPFLAGS)
875
876 DEBUG_CLANGDWARF_ARM_CC_FLAGS = DEF(CLANGDWARF_ARM_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O1
877 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
878 NOOPT_CLANGDWARF_ARM_CC_FLAGS = DEF(CLANGDWARF_ARM_CC_FLAGS) $(PLATFORM_FLAGS) -O0
879 NOOPT_CLANGDWARF_ARM_DLINK_FLAGS = DEF(CLANGDWARF_ARM_DLINK_FLAGS) -fuse-ld=lld -Wl,--no-pie,--no-relax
880RELEASE_CLANGDWARF_ARM_CC_FLAGS = DEF(CLANGDWARF_ARM_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O3
881RELEASE_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
882
883##################
884# CLANGDWARF AARCH64 definitions
885##################
886DEFINE CLANGDWARF_AARCH64_TARGET = -target aarch64-linux-gnu
887DEFINE CLANGDWARF_AARCH64_CC_FLAGS = DEF(GCC_AARCH64_CC_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET) -mcmodel=small DEF(CLANGDWARF_WARNING_OVERRIDES)
888DEFINE CLANGDWARF_AARCH64_DLINK_FLAGS = DEF(CLANGDWARF_AARCH64_TARGET) DEF(GCC_AARCH64_DLINK_FLAGS) -z common-page-size=0x1000
889
890*_CLANGDWARF_AARCH64_PP_FLAGS = DEF(GCC_PP_FLAGS)
891*_CLANGDWARF_AARCH64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
892*_CLANGDWARF_AARCH64_APP_FLAGS =
893*_CLANGDWARF_AARCH64_ASL_FLAGS = DEF(IASL_FLAGS)
894*_CLANGDWARF_AARCH64_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
895*_CLANGDWARF_AARCH64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
896
897*_CLANGDWARF_AARCH64_CC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
898*_CLANGDWARF_AARCH64_ASM_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
899*_CLANGDWARF_AARCH64_PP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
900*_CLANGDWARF_AARCH64_VFRPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
901*_CLANGDWARF_AARCH64_ASLCC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
902*_CLANGDWARF_AARCH64_ASLPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
903*_CLANGDWARF_AARCH64_DLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
904*_CLANGDWARF_AARCH64_ASLDLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
905
906*_CLANGDWARF_AARCH64_SLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@ar
907*_CLANGDWARF_AARCH64_RC_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@objcopy
908
909*_CLANGDWARF_AARCH64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -fno-lto
910*_CLANGDWARF_AARCH64_ASLDLINK_FLAGS = DEF(CLANGDWARF_AARCH64_TARGET) DEF(GCC_AARCH64_ASLDLINK_FLAGS)
911*_CLANGDWARF_AARCH64_ASM_FLAGS = DEF(GCC_ASM_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET) $(PLATFORM_FLAGS) -Qunused-arguments
912*_CLANGDWARF_AARCH64_DLINK_FLAGS = DEF(CLANGDWARF_AARCH64_TARGET) DEF(GCC_AARCH64_DLINK_FLAGS) -z common-page-size=0x1000
913*_CLANGDWARF_AARCH64_DLINK_XIPFLAGS = -z common-page-size=0x20
914*_CLANGDWARF_AARCH64_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x228
915*_CLANGDWARF_AARCH64_PLATFORM_FLAGS =
916*_CLANGDWARF_AARCH64_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET) $(PLATFORM_FLAGS)
917*_CLANGDWARF_AARCH64_RC_FLAGS = DEF(GCC_AARCH64_RC_FLAGS) DEF(GCC_AARCH64_RC_BTI_FLAGS)
918*_CLANGDWARF_AARCH64_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET) $(PLATFORM_FLAGS)
919*_CLANGDWARF_AARCH64_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGDWARF_AARCH64_TARGET)
920*_CLANGDWARF_AARCH64_CC_XIPFLAGS = -mstrict-align
921
922 DEBUG_CLANGDWARF_AARCH64_CC_FLAGS = DEF(CLANGDWARF_AARCH64_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O1
923 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
924 NOOPT_CLANGDWARF_AARCH64_CC_FLAGS = DEF(CLANGDWARF_AARCH64_CC_FLAGS) $(PLATFORM_FLAGS) -O0
925 NOOPT_CLANGDWARF_AARCH64_DLINK_FLAGS = DEF(CLANGDWARF_AARCH64_DLINK_FLAGS) -fuse-ld=lld -Wl,--no-pie,--no-relax
926RELEASE_CLANGDWARF_AARCH64_CC_FLAGS = DEF(CLANGDWARF_AARCH64_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O3
927RELEASE_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
928
929##################
930# CLANGDWARF RISCV64 definitions
931##################
932DEFINE CLANGDWARF_RISCV64_TARGET = -target riscv64-linux-gnu
933DEFINE CLANGDWARF_RISCV64_CC_COMMON = 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 -fno-unwind-tables -Wno-unused-but-set-variable -fpack-struct=8 -mcmodel=medany -mabi=lp64 -mno-relax
934DEFINE CLANGDWARF_RISCV64_CC_FLAGS = DEF(CLANGDWARF_RISCV64_CC_COMMON) DEF(CLANGDWARF_RISCV64_TARGET) DEF(CLANGDWARF_WARNING_OVERRIDES)
935
936# This is similar to GCC flags but without -n
937DEFINE CLANGDWARF_RISCV64_ALL_DLINK_COMMON = -nostdlib -Wl,-q,--gc-sections -z common-page-size=0x40
938DEFINE CLANGDWARF_RISCV64_ALL_DLINK_FLAGS = DEF(CLANGDWARF_RISCV64_ALL_DLINK_COMMON) -Wl,--entry,$(IMAGE_ENTRY_POINT) -u $(IMAGE_ENTRY_POINT) -Wl,-Map,$(DEST_DIR_DEBUG)/$(BASE_NAME).map
939DEFINE CLANGDWARF_RISCV64_DLINK_FLAGS = DEF(CLANGDWARF_RISCV64_TARGET) DEF(CLANGDWARF_RISCV64_ALL_DLINK_FLAGS) -Wl,-melf64lriscv,--oformat=elf64-littleriscv,--no-relax
940
941*_CLANGDWARF_RISCV64_PP_FLAGS = DEF(GCC_PP_FLAGS)
942*_CLANGDWARF_RISCV64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS)
943*_CLANGDWARF_RISCV64_APP_FLAGS =
944*_CLANGDWARF_RISCV64_ASL_FLAGS = DEF(IASL_FLAGS)
945*_CLANGDWARF_RISCV64_ASL_OUTFLAGS = DEF(IASL_OUTFLAGS)
946*_CLANGDWARF_RISCV64_DTCPP_FLAGS = DEF(GCC_DTCPP_FLAGS)
947*_CLANGDWARF_RISCV64_DEPS_FLAGS = DEF(GCC_DEPS_FLAGS)
948
949*_CLANGDWARF_RISCV64_CC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
950*_CLANGDWARF_RISCV64_ASM_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
951*_CLANGDWARF_RISCV64_PP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
952*_CLANGDWARF_RISCV64_VFRPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
953*_CLANGDWARF_RISCV64_ASLCC_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
954*_CLANGDWARF_RISCV64_ASLPP_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
955*_CLANGDWARF_RISCV64_DLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
956*_CLANGDWARF_RISCV64_ASLDLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX@clang
957
958*_CLANGDWARF_RISCV64_SLINK_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@ar
959*_CLANGDWARF_RISCV64_RC_PATH = @VBOX_VCC143-CLANGXX_PREFIX2@objcopy
960
961*_CLANGDWARF_RISCV64_ASLCC_FLAGS = DEF(GCC_ASLCC_FLAGS) -fno-lto
962*_CLANGDWARF_RISCV64_ASLDLINK_FLAGS = DEF(CLANGDWARF_RISCV64_TARGET) DEF(GCC5_RISCV32_RISCV64_ASLDLINK_FLAGS)
963*_CLANGDWARF_RISCV64_ASM_FLAGS = DEF(GCC_ASM_FLAGS) DEF(CLANGDWARF_RISCV64_TARGET) $(PLATFORM_FLAGS) -Qunused-arguments -mabi=lp64 -mno-relax
964*_CLANGDWARF_RISCV64_DLINK_FLAGS = DEF(CLANGDWARF_RISCV64_TARGET) DEF(GCC5_RISCV64_DLINK_FLAGS)
965*_CLANGDWARF_RISCV64_DLINK_XIPFLAGS = -z common-page-size=0x20
966*_CLANGDWARF_RISCV64_DLINK2_FLAGS = DEF(GCC_DLINK2_FLAGS_COMMON) -Wl,--defsym=PECOFF_HEADER_SIZE=0x240
967*_CLANGDWARF_RISCV64_PLATFORM_FLAGS =
968*_CLANGDWARF_RISCV64_PP_FLAGS = DEF(GCC_PP_FLAGS) DEF(CLANGDWARF_RISCV64_TARGET) $(PLATFORM_FLAGS)
969*_CLANGDWARF_RISCV64_RC_FLAGS = DEF(GCC_RISCV64_RC_FLAGS)
970*_CLANGDWARF_RISCV64_VFRPP_FLAGS = DEF(GCC_VFRPP_FLAGS) DEF(CLANGDWARF_RISCV64_TARGET) $(PLATFORM_FLAGS)
971*_CLANGDWARF_RISCV64_ASLPP_FLAGS = DEF(GCC_ASLPP_FLAGS) DEF(CLANGDWARF_RISCV64_TARGET)
972*_CLANGDWARF_RISCV64_CC_XIPFLAGS = DEF(GCC_RISCV64_CC_XIPFLAGS)
973
974 DEBUG_CLANGDWARF_RISCV64_CC_FLAGS = DEF(CLANGDWARF_RISCV64_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O1
975 DEBUG_CLANGDWARF_RISCV64_DLINK_FLAGS = DEF(CLANGDWARF_RISCV64_DLINK_FLAGS) -flto -Wl,-O1 -fuse-ld=lld -Wl,--no-pie,--no-relax
976 NOOPT_CLANGDWARF_RISCV64_CC_FLAGS = DEF(CLANGDWARF_RISCV64_CC_FLAGS) $(PLATFORM_FLAGS) -O0
977 NOOPT_CLANGDWARF_RISCV64_DLINK_FLAGS = DEF(CLANGDWARF_RISCV64_DLINK_FLAGS) -fuse-ld=lld -Wl,--no-pie,--no-relax
978RELEASE_CLANGDWARF_RISCV64_CC_FLAGS = DEF(CLANGDWARF_RISCV64_CC_FLAGS) $(PLATFORM_FLAGS) -flto -O3
979RELEASE_CLANGDWARF_RISCV64_DLINK_FLAGS = DEF(CLANGDWARF_RISCV64_DLINK_FLAGS) -flto -Wl,-O3 -fuse-ld=lld -Wl,--no-pie,--no-relax
980
981#################
982# ASM 16 linker definitions
983#################
984*_*_*_ASMLINK_PATH = DEF(WINDDK_BIN16)\link16.exe
985*_*_*_ASMLINK_FLAGS = /nologo /tiny
986
987##################
988# VfrCompiler definitions
989##################
990*_*_*_VFR_PATH = VfrCompile
991*_*_*_VFR_FLAGS = -l -n
992
993##################
994# OptionRom tool definitions
995##################
996*_*_*_OPTROM_PATH = EfiRom
997*_*_*_OPTROM_FLAGS = -e
998
999##################
1000# GenFw tool definitions
1001##################
1002*_*_*_GENFW_PATH = GenFw
1003*_*_*_GENFW_FLAGS =
1004
1005##################
1006# Asl Compiler definitions
1007##################
1008*_*_*_ASLCC_FLAGS = /nologo /c /FIAutoGen.h /TC /Dmain=ReferenceAcpiTable
1009*_*_*_ASLDLINK_FLAGS = /NODEFAULTLIB /ENTRY:ReferenceAcpiTable /SUBSYSTEM:CONSOLE
1010*_*_*_ASLPP_FLAGS = /nologo /EP /C
1011*_*_*_ASL_FLAGS =
1012
1013##################
1014# GenCrc32 tool definitions
1015##################
1016*_*_*_CRC32_PATH = GenCrc32
1017*_*_*_CRC32_GUID = FC1BCDB0-7D31-49AA-936A-A4600D9DD083
1018
1019##################
1020# Rsa2048Sha256Sign tool definitions
1021#
1022# Notes: This tool definition uses a test signing key for development purposes only.
1023# The tool Rsa2048Sha256GenerateKeys can be used to generate a new private/public key
1024# and the gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer PCD value.
1025# A custom tool/script can be implemented using the new private/public key with
1026# the Rsa2048Sha256Sign tool and this tool definition can be updated to use a
1027# custom tool/script.
1028#
1029# Generate new private/public key and gEfiSecurityPkgTokenSpaceGuid.PcdRsa2048Sha256PublicKeyBuffer PCD value
1030#
1031# Rsa2048Sha256GenerateKeys.py -o MyKey.pem --public-key-hash-c MyKey.pcd
1032#
1033# Custom script example (MyRsa2048Sha256Sign.cmd):
1034#
1035# Rsa2048Sha256Sign --private-key MyKey.pem %1 %2 %3 %4 %5 %6 %7 %8 %9
1036#
1037# WARNING: Vendors that uses private keys are responsible for proper management and protection
1038# of private keys. Vendors may choose to use infrastructure such as signing servers
1039# or signing portals to support the management and protection of private keys.
1040#
1041##################
1042*_*_*_RSA2048SHA256SIGN_PATH = Rsa2048Sha256Sign
1043*_*_*_RSA2048SHA256SIGN_GUID = A7717414-C616-4977-9420-844712A735BF
1044
1045##################
1046# BrotliCompress tool definitions
1047##################
1048*_*_*_BROTLI_PATH = BrotliCompress
1049*_*_*_BROTLI_GUID = 3D532050-5CDA-4FD0-879E-0F7F630D5AFB
1050
1051##################
1052# LzmaCompress tool definitions
1053##################
1054*_*_*_LZMA_PATH = LzmaCompress
1055*_*_*_LZMA_GUID = EE4E5898-3914-4259-9D6E-DC7BD79403CF
1056
1057##################
1058# LzmaF86Compress tool definitions with converter for x86 code.
1059# It can improve the compression ratio if the input file is IA32 or X64 PE image.
1060##################
1061*_*_*_LZMAF86_PATH = LzmaF86Compress
1062*_*_*_LZMAF86_GUID = D42AE6BD-1352-4bfb-909A-CA72A6EAE889
1063
1064##################
1065# TianoCompress tool definitions
1066##################
1067*_*_*_TIANO_PATH = TianoCompress
1068*_*_*_TIANO_GUID = A31280AD-481E-41B6-95E8-127F4C984779
1069
1070##################
1071# BPDG tool definitions
1072##################
1073*_*_*_VPDTOOL_PATH = BPDG
1074*_*_*_VPDTOOL_GUID = 8C3D856A-9BE6-468E-850A-24F7A8D38E08
1075
1076##################
1077# Pkcs7Sign tool definitions
1078##################
1079*_*_*_PKCS7SIGN_PATH = Pkcs7Sign
1080*_*_*_PKCS7SIGN_GUID = 4AAFD29D-68DF-49EE-8AA9-347D375665A7
1081
1082##################
1083# NASM tool definitions
1084##################
1085*_*_*_NASM_PATH = @VBOX_NASMCMD@
1086# NASMB uses NASM produce a .bin from a .nasmb NASM source file
1087*_*_*_NASMB_FLAGS = -f bin -DVBOX
1088
1089#################
1090# Build rule order
1091#################
1092*_*_*_*_BUILDRULEORDER = nasm asm Asm ASM S s nasmb asm16
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette