* [PATCH 0/2] *** Add VS2019 Support *** @ 2019-09-11 6:08 Cheng, Ching JenX 2019-09-11 6:08 ` [PATCH 1/2] Add VS2019 Toolchain def Cheng, Ching JenX 2019-09-11 6:08 ` [PATCH 2/2] Add VS2019 Support on ToolSetup Batches Cheng, Ching JenX 0 siblings, 2 replies; 7+ messages in thread From: Cheng, Ching JenX @ 2019-09-11 6:08 UTC (permalink / raw) To: devel *** BLURB HERE *** Ching JenX Cheng (2): Add VS2019 Toolchain def Add VS2019 Support on ToolSetup Batches BaseTools/Conf/tools_def.template | 134 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++------------ BaseTools/get_vsvars.bat | 39 +++++++++++++++++++++++++++++++-------- BaseTools/set_vsprefix_envs.bat | 70 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++----- BaseTools/toolsetup.bat | 16 +++++++++++++--- edksetup.bat | 6 ++++-- 5 files changed, 235 insertions(+), 30 deletions(-) -- 2.21.0.windows.1 ^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH 1/2] Add VS2019 Toolchain def 2019-09-11 6:08 [PATCH 0/2] *** Add VS2019 Support *** Cheng, Ching JenX @ 2019-09-11 6:08 ` Cheng, Ching JenX 2019-09-11 15:43 ` [edk2-devel] " Pete Batard 2019-09-11 6:08 ` [PATCH 2/2] Add VS2019 Support on ToolSetup Batches Cheng, Ching JenX 1 sibling, 1 reply; 7+ messages in thread From: Cheng, Ching JenX @ 2019-09-11 6:08 UTC (permalink / raw) To: devel; +Cc: Amy Chan, Bob Feng, Liming Gao REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2182 In order to support VS2019, the first thing need to do is add 2019 toolchain on tools_def.template Change-Id: Id52abdc9762cf06bb9a38bbfd1153608c878d839 Cc: Amy Chan <amy.chan@intel.com> Cc: Bob Feng <bob.c.feng@intel.com> Cc: Liming Gao <liming.gao@intel.com> Signed-off-by: Ching JenX Cheng <ching.jenx.cheng@intel.com> --- BaseTools/Conf/tools_def.template | 134 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++------------ 1 file changed, 122 insertions(+), 12 deletions(-) diff --git a/BaseTools/Conf/tools_def.template b/BaseTools/Conf/tools_def.template index 8f0e6cb6c2..7585a3e5db 100755 --- a/BaseTools/Conf/tools_def.template +++ b/BaseTools/Conf/tools_def.template @@ -63,27 +63,35 @@ DEFINE VS2017_BIN_X64 = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\x64 DEFINE VS2017_BIN_ARM = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\arm DEFINE VS2017_BIN_AARCH64 = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\arm64 -DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) -DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) +DEFINE VS2019_BIN = ENV(VS2019_PREFIX)bin +DEFINE VS2019_HOST = x86 +DEFINE VS2019_BIN_HOST = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\DEF(VS2019_HOST) +DEFINE VS2019_BIN_IA32 = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\x86 +DEFINE VS2019_BIN_X64 = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\x64 +DEFINE VS2019_BIN_ARM = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\arm +DEFINE VS2019_BIN_AARCH64 = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\arm64 + +DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) +DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) # Microsoft Visual Studio 2010 -DEFINE WINSDK7_BIN = ENV(WINSDK7_PREFIX) -DEFINE WINSDK7x86_BIN = ENV(WINSDK7x86_PREFIX) +DEFINE WINSDK7_BIN = ENV(WINSDK7_PREFIX) +DEFINE WINSDK7x86_BIN = ENV(WINSDK7x86_PREFIX) # Microsoft Visual Studio 2012 Update 1 (required for rc.exe that was not included in the initial release) -DEFINE WINSDK71_BIN = ENV(WINSDK71_PREFIX) -DEFINE WINSDK71x86_BIN = ENV(WINSDK71x86_PREFIX) +DEFINE WINSDK71_BIN = ENV(WINSDK71_PREFIX) +DEFINE WINSDK71x86_BIN = ENV(WINSDK71x86_PREFIX) # Microsoft Visual Studio 2013 Professional Edition -DEFINE WINSDK8_BIN = ENV(WINSDK8_PREFIX)x86\ -DEFINE WINSDK8x86_BIN = ENV(WINSDK8x86_PREFIX)x64 +DEFINE WINSDK8_BIN = ENV(WINSDK8_PREFIX)x86\ +DEFINE WINSDK8x86_BIN = ENV(WINSDK8x86_PREFIX)x64 # Microsoft Visual Studio 2015 Professional Edition -DEFINE WINSDK81_BIN = ENV(WINSDK81_PREFIX)x86\ -DEFINE WINSDK81x86_BIN = ENV(WINSDK81x86_PREFIX)x64 +DEFINE WINSDK81_BIN = ENV(WINSDK81_PREFIX)x86\ +DEFINE WINSDK81x86_BIN = ENV(WINSDK81x86_PREFIX)x64 -# Microsoft Visual Studio 2017 Professional Edition -DEFINE WINSDK10_BIN = ENV(WINSDK10_PREFIX)DEF(VS2017_HOST) +# Microsoft Visual Studio 2017/2019 Professional Edition +DEFINE WINSDK10_BIN = ENV(WINSDK10_PREFIX)DEF(VS2017_HOST) # These defines are needed for certain Microsoft Visual Studio tools that # are used by other toolchains. An example is that ICC on Windows normally @@ -218,6 +226,17 @@ DEFINE DTC_BIN = ENV(DTC_PREFIX)dtc # 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. +# VS2019 -win32- Requires: +# Microsoft Visual Studio 2019 version 16.2 or later +# Optional: +# Required to build EBC drivers: +# Intel(r) Compiler for Efi Byte Code (Intel(r) EBC Compiler) +# 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. # GCC48 -Linux,Windows- Requires: # GCC 4.8 targeting x86_64-linux-gnu, aarch64-linux-gnu, or arm-linux-gnueabi # Optional: @@ -1691,6 +1710,97 @@ NOOPT_VS2017_AARCH64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF *_VS2017_EBC_SLINK_FLAGS = /lib /NOLOGO /MACHINE:EBC *_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 +#################################################################################### +# VS2019 - Microsoft Visual Studio 2017 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 +*_VS2019_*_MAKE_FLAG = /nologo +*_VS2019_*_RC_PATH = DEF(WINSDK10_BIN)\rc.exe + +*_VS2019_*_MAKE_FLAGS = /nologo +*_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 + +################## +# 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 + + *_VS2019_IA32_MAKE_FLAGS = /nologo + 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 +RELEASE_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP +NOOPT_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od /MP + + 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 + + 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 +RELEASE_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP +NOOPT_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od /MP + + 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 + #################################################################################### # GCC Common #################################################################################### -- 2.21.0.windows.1 ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [edk2-devel] [PATCH 1/2] Add VS2019 Toolchain def 2019-09-11 6:08 ` [PATCH 1/2] Add VS2019 Toolchain def Cheng, Ching JenX @ 2019-09-11 15:43 ` Pete Batard 2019-09-16 2:25 ` Cheng, Ching JenX 0 siblings, 1 reply; 7+ messages in thread From: Pete Batard @ 2019-09-11 15:43 UTC (permalink / raw) To: devel, ching.jenx.cheng; +Cc: Amy Chan, Bob Feng, Liming Gao Hi Ching JenX, Please see two comments inline. On 2019.09.11 07:08, Cheng, Ching JenX wrote: > REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2182 > > In order to support VS2019, > the first thing need to do is add 2019 toolchain on tools_def.template > > Change-Id: Id52abdc9762cf06bb9a38bbfd1153608c878d839 > Cc: Amy Chan <amy.chan@intel.com> > Cc: Bob Feng <bob.c.feng@intel.com> > Cc: Liming Gao <liming.gao@intel.com> > Signed-off-by: Ching JenX Cheng <ching.jenx.cheng@intel.com> > --- > BaseTools/Conf/tools_def.template | 134 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++------------ > 1 file changed, 122 insertions(+), 12 deletions(-) > > diff --git a/BaseTools/Conf/tools_def.template b/BaseTools/Conf/tools_def.template > index 8f0e6cb6c2..7585a3e5db 100755 > --- a/BaseTools/Conf/tools_def.template > +++ b/BaseTools/Conf/tools_def.template > @@ -63,27 +63,35 @@ DEFINE VS2017_BIN_X64 = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\x64 > DEFINE VS2017_BIN_ARM = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\arm > DEFINE VS2017_BIN_AARCH64 = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\arm64 > > -DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) > -DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) > +DEFINE VS2019_BIN = ENV(VS2019_PREFIX)bin > +DEFINE VS2019_HOST = x86 > +DEFINE VS2019_BIN_HOST = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\DEF(VS2019_HOST) > +DEFINE VS2019_BIN_IA32 = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\x86 > +DEFINE VS2019_BIN_X64 = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\x64 > +DEFINE VS2019_BIN_ARM = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\arm > +DEFINE VS2019_BIN_AARCH64 = DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\arm64 > + > +DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) > +DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) > > # Microsoft Visual Studio 2010 > -DEFINE WINSDK7_BIN = ENV(WINSDK7_PREFIX) > -DEFINE WINSDK7x86_BIN = ENV(WINSDK7x86_PREFIX) > +DEFINE WINSDK7_BIN = ENV(WINSDK7_PREFIX) > +DEFINE WINSDK7x86_BIN = ENV(WINSDK7x86_PREFIX) > > # Microsoft Visual Studio 2012 Update 1 (required for rc.exe that was not included in the initial release) > -DEFINE WINSDK71_BIN = ENV(WINSDK71_PREFIX) > -DEFINE WINSDK71x86_BIN = ENV(WINSDK71x86_PREFIX) > +DEFINE WINSDK71_BIN = ENV(WINSDK71_PREFIX) > +DEFINE WINSDK71x86_BIN = ENV(WINSDK71x86_PREFIX) > > # Microsoft Visual Studio 2013 Professional Edition > -DEFINE WINSDK8_BIN = ENV(WINSDK8_PREFIX)x86\ > -DEFINE WINSDK8x86_BIN = ENV(WINSDK8x86_PREFIX)x64 > +DEFINE WINSDK8_BIN = ENV(WINSDK8_PREFIX)x86\ > +DEFINE WINSDK8x86_BIN = ENV(WINSDK8x86_PREFIX)x64 > > # Microsoft Visual Studio 2015 Professional Edition > -DEFINE WINSDK81_BIN = ENV(WINSDK81_PREFIX)x86\ > -DEFINE WINSDK81x86_BIN = ENV(WINSDK81x86_PREFIX)x64 > +DEFINE WINSDK81_BIN = ENV(WINSDK81_PREFIX)x86\ > +DEFINE WINSDK81x86_BIN = ENV(WINSDK81x86_PREFIX)x64 > > -# Microsoft Visual Studio 2017 Professional Edition > -DEFINE WINSDK10_BIN = ENV(WINSDK10_PREFIX)DEF(VS2017_HOST) > +# Microsoft Visual Studio 2017/2019 Professional Edition > +DEFINE WINSDK10_BIN = ENV(WINSDK10_PREFIX)DEF(VS2017_HOST) The above line does not use the VS2019_HOST defined above, so I think we want to fix that. I wouldn't expect many people to use both VS2017 and VS2019 toolchains with a different host platform (e.g. x64 for VS2019 and x86 for VS2017) so I'd suggest that we use a single "VS_HOST" that applies to both platforms. > > # These defines are needed for certain Microsoft Visual Studio tools that > # are used by other toolchains. An example is that ICC on Windows normally > @@ -218,6 +226,17 @@ DEFINE DTC_BIN = ENV(DTC_PREFIX)dtc > # 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. > +# VS2019 -win32- Requires: > +# Microsoft Visual Studio 2019 version 16.2 or later > +# Optional: > +# Required to build EBC drivers: > +# Intel(r) Compiler for Efi Byte Code (Intel(r) EBC Compiler) > +# 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. > # GCC48 -Linux,Windows- Requires: > # GCC 4.8 targeting x86_64-linux-gnu, aarch64-linux-gnu, or arm-linux-gnueabi > # Optional: > @@ -1691,6 +1710,97 @@ NOOPT_VS2017_AARCH64_DLINK_FLAGS = /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF > *_VS2017_EBC_SLINK_FLAGS = /lib /NOLOGO /MACHINE:EBC > *_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 > > +#################################################################################### > +# VS2019 - Microsoft Visual Studio 2017 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 > +*_VS2019_*_MAKE_FLAG = /nologo > +*_VS2019_*_RC_PATH = DEF(WINSDK10_BIN)\rc.exe > + > +*_VS2019_*_MAKE_FLAGS = /nologo > +*_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 > + > +################## > +# 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 > + > + *_VS2019_IA32_MAKE_FLAGS = /nologo > + 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 > +RELEASE_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP > +NOOPT_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od /MP > + > + 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 > + > + 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 > +RELEASE_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP > +NOOPT_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od /MP > + > + 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 Why are there no ARM, AARCH64 and EBC definitions, like there are for VS2017? I am afraid there are some of us here that are actually mad enough to want to build ARM and AARCH64 EDK2 projects using Visual Studio... ;) If it helps, I can confirm that simply copy/pasting the VS2017 sections and replacing all of the "VS2017" instances with "VS2019" appears to work just fine when compiling my ARM/AARCH64 projects. I haven't tested EBC, but I expect the same to be true. Apart from that, both patches look good to me. Regards, /Pete > + > #################################################################################### > # GCC Common > #################################################################################### > ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [edk2-devel] [PATCH 1/2] Add VS2019 Toolchain def 2019-09-11 15:43 ` [edk2-devel] " Pete Batard @ 2019-09-16 2:25 ` Cheng, Ching JenX 2019-09-16 9:47 ` Pete Batard 0 siblings, 1 reply; 7+ messages in thread From: Cheng, Ching JenX @ 2019-09-16 2:25 UTC (permalink / raw) To: devel@edk2.groups.io, pete@akeo.ie; +Cc: Chan, Amy, Feng, Bob C, Gao, Liming Hi Peter, Thanks for your kind comments, For the following comments 1. I will combine VS2017_HOST and VS2019_HOST to VS_HOST to apply both VS2017 and VS2019 plateforms, 2. Sorry I just test x86/64 builds. So if it is ok, please help me to test ARM/AARCH64. Then I could update it to patch v2. Thank you, Best Regards, Allen > -----Original Message----- > From: devel@edk2.groups.io [mailto:devel@edk2.groups.io] On Behalf Of > Pete Batard > Sent: Wednesday, September 11, 2019 11:43 PM > To: devel@edk2.groups.io; Cheng, Ching JenX > <ching.jenx.cheng@intel.com> > Cc: Chan, Amy <amy.chan@intel.com>; Feng, Bob C <bob.c.feng@intel.com>; > Gao, Liming <liming.gao@intel.com> > Subject: Re: [edk2-devel] [PATCH 1/2] Add VS2019 Toolchain def > > Hi Ching JenX, > > Please see two comments inline. > > On 2019.09.11 07:08, Cheng, Ching JenX wrote: > > REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2182 > > > > In order to support VS2019, > > the first thing need to do is add 2019 toolchain on tools_def.template > > > > Change-Id: Id52abdc9762cf06bb9a38bbfd1153608c878d839 > > Cc: Amy Chan <amy.chan@intel.com> > > Cc: Bob Feng <bob.c.feng@intel.com> > > Cc: Liming Gao <liming.gao@intel.com> > > Signed-off-by: Ching JenX Cheng <ching.jenx.cheng@intel.com> > > --- > > BaseTools/Conf/tools_def.template | 134 > ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ > ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ > ++++++------------ > > 1 file changed, 122 insertions(+), 12 deletions(-) > > > > diff --git a/BaseTools/Conf/tools_def.template > > b/BaseTools/Conf/tools_def.template > > index 8f0e6cb6c2..7585a3e5db 100755 > > --- a/BaseTools/Conf/tools_def.template > > +++ b/BaseTools/Conf/tools_def.template > > @@ -63,27 +63,35 @@ DEFINE VS2017_BIN_X64 = > DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\x64 > > DEFINE VS2017_BIN_ARM = > DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\arm > > DEFINE VS2017_BIN_AARCH64 = > > DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\arm64 > > > > -DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) > > -DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) > > +DEFINE VS2019_BIN = ENV(VS2019_PREFIX)bin > > +DEFINE VS2019_HOST = x86 > > +DEFINE VS2019_BIN_HOST = > DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\DEF(VS2019_HOST) > > +DEFINE VS2019_BIN_IA32 = > DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\x86 > > +DEFINE VS2019_BIN_X64 = > DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\x64 > > +DEFINE VS2019_BIN_ARM = > DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\arm > > +DEFINE VS2019_BIN_AARCH64 = > > +DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\arm64 > > + > > +DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) > > +DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) > > > > # Microsoft Visual Studio 2010 > > -DEFINE WINSDK7_BIN = ENV(WINSDK7_PREFIX) > > -DEFINE WINSDK7x86_BIN = ENV(WINSDK7x86_PREFIX) > > +DEFINE WINSDK7_BIN = ENV(WINSDK7_PREFIX) > > +DEFINE WINSDK7x86_BIN = ENV(WINSDK7x86_PREFIX) > > > > # Microsoft Visual Studio 2012 Update 1 (required for rc.exe that was not > included in the initial release) > > -DEFINE WINSDK71_BIN = ENV(WINSDK71_PREFIX) > > -DEFINE WINSDK71x86_BIN = ENV(WINSDK71x86_PREFIX) > > +DEFINE WINSDK71_BIN = ENV(WINSDK71_PREFIX) > > +DEFINE WINSDK71x86_BIN = ENV(WINSDK71x86_PREFIX) > > > > # Microsoft Visual Studio 2013 Professional Edition > > -DEFINE WINSDK8_BIN = ENV(WINSDK8_PREFIX)x86\ > > -DEFINE WINSDK8x86_BIN = ENV(WINSDK8x86_PREFIX)x64 > > +DEFINE WINSDK8_BIN = ENV(WINSDK8_PREFIX)x86\ > > +DEFINE WINSDK8x86_BIN = ENV(WINSDK8x86_PREFIX)x64 > > > > # Microsoft Visual Studio 2015 Professional Edition > > -DEFINE WINSDK81_BIN = ENV(WINSDK81_PREFIX)x86\ > > -DEFINE WINSDK81x86_BIN = ENV(WINSDK81x86_PREFIX)x64 > > +DEFINE WINSDK81_BIN = ENV(WINSDK81_PREFIX)x86\ > > +DEFINE WINSDK81x86_BIN = ENV(WINSDK81x86_PREFIX)x64 > > > > -# Microsoft Visual Studio 2017 Professional Edition > > -DEFINE WINSDK10_BIN = ENV(WINSDK10_PREFIX)DEF(VS2017_HOST) > > +# Microsoft Visual Studio 2017/2019 Professional Edition > > +DEFINE WINSDK10_BIN = ENV(WINSDK10_PREFIX)DEF(VS2017_HOST) > > The above line does not use the VS2019_HOST defined above, so I think we > want to fix that. > > I wouldn't expect many people to use both VS2017 and VS2019 toolchains > with a different host platform (e.g. x64 for VS2019 and x86 for VS2017) so I'd > suggest that we use a single "VS_HOST" that applies to both platforms. > > > > > # These defines are needed for certain Microsoft Visual Studio tools that > > # are used by other toolchains. An example is that ICC on Windows > normally > > @@ -218,6 +226,17 @@ DEFINE DTC_BIN = ENV(DTC_PREFIX)dtc > > # 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. > > +# VS2019 -win32- Requires: > > +# Microsoft Visual Studio 2019 version 16.2 or later > > +# Optional: > > +# Required to build EBC drivers: > > +# Intel(r) Compiler for Efi Byte Code (Intel(r) EBC Compiler) > > +# 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. > > # GCC48 -Linux,Windows- Requires: > > # GCC 4.8 targeting x86_64-linux-gnu, aarch64-linux-gnu, or > arm-linux-gnueabi > > # Optional: > > @@ -1691,6 +1710,97 @@ NOOPT_VS2017_AARCH64_DLINK_FLAGS = > /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF > > *_VS2017_EBC_SLINK_FLAGS = /lib /NOLOGO /MACHINE:EBC > > *_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 > > > > > +######################################################### > ########################### > > +# VS2019 - Microsoft Visual Studio 2017 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 > > +*_VS2019_*_MAKE_FLAG = /nologo > > +*_VS2019_*_RC_PATH = DEF(WINSDK10_BIN)\rc.exe > > + > > +*_VS2019_*_MAKE_FLAGS = /nologo > > +*_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 > > + > > +################## > > +# 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 > > + > > + *_VS2019_IA32_MAKE_FLAGS = /nologo > > + 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 > > +RELEASE_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 > /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP > > +NOOPT_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 > /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od /MP > > + > > + 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 > > + > > + 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 > > +RELEASE_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 > /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP > > +NOOPT_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 > /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od /MP > > + > > + 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 > > Why are there no ARM, AARCH64 and EBC definitions, like there are for > VS2017? > > I am afraid there are some of us here that are actually mad enough to want > to build ARM and AARCH64 EDK2 projects using Visual Studio... ;) > > If it helps, I can confirm that simply copy/pasting the VS2017 sections and > replacing all of the "VS2017" instances with "VS2019" appears to work just > fine when compiling my ARM/AARCH64 projects. I haven't tested EBC, but I > expect the same to be true. > > Apart from that, both patches look good to me. > > Regards, > > /Pete > > > + > > > ########################################################## > ########################## > > # GCC Common > > > > > ########################################################## > ############ > > ############## > > > > > ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [edk2-devel] [PATCH 1/2] Add VS2019 Toolchain def 2019-09-16 2:25 ` Cheng, Ching JenX @ 2019-09-16 9:47 ` Pete Batard 0 siblings, 0 replies; 7+ messages in thread From: Pete Batard @ 2019-09-16 9:47 UTC (permalink / raw) To: Cheng, Ching JenX, devel@edk2.groups.io Cc: Chan, Amy, Feng, Bob C, Gao, Liming Hi Allen, On 2019.09.16 03:25, Cheng, Ching JenX wrote: > Hi Peter, > > Thanks for your kind comments, > For the following comments > 1. I will combine VS2017_HOST and VS2019_HOST to VS_HOST to apply both VS2017 and VS2019 plateforms, Great. > 2. Sorry I just test x86/64 builds. So if it is ok, please help me to test ARM/AARCH64. Then I could update it to patch v2. I'll be happy to help. Using Visual Studio 2019 to compile for ARM/AARCH64 is fairly easy. Here are the steps you should follow: 1. You must make sure that, when you installed Visual Studio 2019, you also installed the ARM and ARM64 build tools. These are usually not installed by default, so, if you haven't already done so, or want to confirm that they are installed, you need to launch the Visual Studio Installer and then select Modify -> Individual Components. There you need to make sure that you have both "MSVC v142 - VS 2019 C++ ARM build tools (v14.22)" and "MSVC v142 - VS 2019 C++ ARM64 build tools (v14.22)" selected. You can find a picture illustrating that step at: https://github.com/pbatard/uefi-simple#visual-studio-2019-and-armarm64-support 2. Copy the "# ARM definitions", "# AARCH64 definitions" and "# EBC definitions" below (just copy the whole section between the markers) and add them right before the "# GCC Common" section in tools_def.template. These are the exact same sections as the ones we use for VS2017, except all instances of "VS2017" have been replaced with "VS2019". Nothing else was changed. ########################## BEGIN COPY HERE ########################## ################# # 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 *_VS2019_ARM_MAKE_FLAGS = /nologo DEBUG_VS2019_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gm /Gw /Oi- RELEASE_VS2019_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi- NOOPT_VS2019_ARM_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gm /Od /Oi- 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 *_VS2019_AARCH64_MAKE_FLAGS = /nologo DEBUG_VS2019_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gm /Gw /Oi- RELEASE_VS2019_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /Oi- NOOPT_VS2019_AARCH64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Zi /Gm /Od /Oi- 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 ################## # EBC definitions ################## *_VS2019_EBC_*_FAMILY = INTEL *_VS2019_EBC_PP_PATH = DEF(EBC_BINx86)\iec.exe *_VS2019_EBC_VFRPP_PATH = DEF(EBC_BINx86)\iec.exe *_VS2019_EBC_CC_PATH = DEF(EBC_BINx86)\iec.exe *_VS2019_EBC_SLINK_PATH = DEF(VS2019_BIN_IA32)\link.exe *_VS2019_EBC_DLINK_PATH = DEF(VS2019_BIN_IA32)\link.exe *_VS2019_EBC_MAKE_FLAGS = /nologo *_VS2019_EBC_PP_FLAGS = /nologo /E /TC /FIAutoGen.h *_VS2019_EBC_CC_FLAGS = /nologo /c /WX /W3 /FIAutoGen.h /D$(MODULE_ENTRY_POINT)=$(ARCH_ENTRY_POINT) *_VS2019_EBC_VFRPP_FLAGS = /nologo /E /TC /DVFRCOMPILE /FI$(MODULE_NAME)StrDefs.h *_VS2019_EBC_SLINK_FLAGS = /lib /NOLOGO /MACHINE:EBC *_VS2019_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 ########################## END COPY HERE ########################## 3. With the above completed, you should e able to compile something like ShellPkg for ARM/AARCH64 by issuing: # ARM C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC\Auxiliary\Build\vcvarsamd64_arm.bat" edksetup.bat reconfig build -a ARM -b RELEASE -t VS2019 -p ShellPkg/ShellPkg.dsc # AARCH64 C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC\Auxiliary\Build\vcvarsamd64_arm64.bat" edksetup.bat reconfig build -a AARCH64 -b RELEASE -t VS2019 -p ShellPkg/ShellPkg.dsc I have tested ShellPkg as well as other custom applications recompilation with VS2019 for ARM/AARCH64 on my platform, and found no issues. If you need more details, please let me know. Regards, /Pete > > Thank you, > Best Regards, > Allen > >> -----Original Message----- >> From: devel@edk2.groups.io [mailto:devel@edk2.groups.io] On Behalf Of >> Pete Batard >> Sent: Wednesday, September 11, 2019 11:43 PM >> To: devel@edk2.groups.io; Cheng, Ching JenX >> <ching.jenx.cheng@intel.com> >> Cc: Chan, Amy <amy.chan@intel.com>; Feng, Bob C <bob.c.feng@intel.com>; >> Gao, Liming <liming.gao@intel.com> >> Subject: Re: [edk2-devel] [PATCH 1/2] Add VS2019 Toolchain def >> >> Hi Ching JenX, >> >> Please see two comments inline. >> >> On 2019.09.11 07:08, Cheng, Ching JenX wrote: >>> REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2182 >>> >>> In order to support VS2019, >>> the first thing need to do is add 2019 toolchain on tools_def.template >>> >>> Change-Id: Id52abdc9762cf06bb9a38bbfd1153608c878d839 >>> Cc: Amy Chan <amy.chan@intel.com> >>> Cc: Bob Feng <bob.c.feng@intel.com> >>> Cc: Liming Gao <liming.gao@intel.com> >>> Signed-off-by: Ching JenX Cheng <ching.jenx.cheng@intel.com> >>> --- >>> BaseTools/Conf/tools_def.template | 134 >> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ >> ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ >> ++++++------------ >>> 1 file changed, 122 insertions(+), 12 deletions(-) >>> >>> diff --git a/BaseTools/Conf/tools_def.template >>> b/BaseTools/Conf/tools_def.template >>> index 8f0e6cb6c2..7585a3e5db 100755 >>> --- a/BaseTools/Conf/tools_def.template >>> +++ b/BaseTools/Conf/tools_def.template >>> @@ -63,27 +63,35 @@ DEFINE VS2017_BIN_X64 = >> DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\x64 >>> DEFINE VS2017_BIN_ARM = >> DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\arm >>> DEFINE VS2017_BIN_AARCH64 = >>> DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\arm64 >>> >>> -DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) >>> -DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) >>> +DEFINE VS2019_BIN = ENV(VS2019_PREFIX)bin >>> +DEFINE VS2019_HOST = x86 >>> +DEFINE VS2019_BIN_HOST = >> DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\DEF(VS2019_HOST) >>> +DEFINE VS2019_BIN_IA32 = >> DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\x86 >>> +DEFINE VS2019_BIN_X64 = >> DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\x64 >>> +DEFINE VS2019_BIN_ARM = >> DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\arm >>> +DEFINE VS2019_BIN_AARCH64 = >>> +DEF(VS2019_BIN)\HostDEF(VS2019_HOST)\arm64 >>> + >>> +DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) >>> +DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) >>> >>> # Microsoft Visual Studio 2010 >>> -DEFINE WINSDK7_BIN = ENV(WINSDK7_PREFIX) >>> -DEFINE WINSDK7x86_BIN = ENV(WINSDK7x86_PREFIX) >>> +DEFINE WINSDK7_BIN = ENV(WINSDK7_PREFIX) >>> +DEFINE WINSDK7x86_BIN = ENV(WINSDK7x86_PREFIX) >>> >>> # Microsoft Visual Studio 2012 Update 1 (required for rc.exe that was not >> included in the initial release) >>> -DEFINE WINSDK71_BIN = ENV(WINSDK71_PREFIX) >>> -DEFINE WINSDK71x86_BIN = ENV(WINSDK71x86_PREFIX) >>> +DEFINE WINSDK71_BIN = ENV(WINSDK71_PREFIX) >>> +DEFINE WINSDK71x86_BIN = ENV(WINSDK71x86_PREFIX) >>> >>> # Microsoft Visual Studio 2013 Professional Edition >>> -DEFINE WINSDK8_BIN = ENV(WINSDK8_PREFIX)x86\ >>> -DEFINE WINSDK8x86_BIN = ENV(WINSDK8x86_PREFIX)x64 >>> +DEFINE WINSDK8_BIN = ENV(WINSDK8_PREFIX)x86\ >>> +DEFINE WINSDK8x86_BIN = ENV(WINSDK8x86_PREFIX)x64 >>> >>> # Microsoft Visual Studio 2015 Professional Edition >>> -DEFINE WINSDK81_BIN = ENV(WINSDK81_PREFIX)x86\ >>> -DEFINE WINSDK81x86_BIN = ENV(WINSDK81x86_PREFIX)x64 >>> +DEFINE WINSDK81_BIN = ENV(WINSDK81_PREFIX)x86\ >>> +DEFINE WINSDK81x86_BIN = ENV(WINSDK81x86_PREFIX)x64 >>> >>> -# Microsoft Visual Studio 2017 Professional Edition >>> -DEFINE WINSDK10_BIN = ENV(WINSDK10_PREFIX)DEF(VS2017_HOST) >>> +# Microsoft Visual Studio 2017/2019 Professional Edition >>> +DEFINE WINSDK10_BIN = ENV(WINSDK10_PREFIX)DEF(VS2017_HOST) >> >> The above line does not use the VS2019_HOST defined above, so I think we >> want to fix that. >> >> I wouldn't expect many people to use both VS2017 and VS2019 toolchains >> with a different host platform (e.g. x64 for VS2019 and x86 for VS2017) so I'd >> suggest that we use a single "VS_HOST" that applies to both platforms. >> >>> >>> # These defines are needed for certain Microsoft Visual Studio tools that >>> # are used by other toolchains. An example is that ICC on Windows >> normally >>> @@ -218,6 +226,17 @@ DEFINE DTC_BIN = ENV(DTC_PREFIX)dtc >>> # 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. >>> +# VS2019 -win32- Requires: >>> +# Microsoft Visual Studio 2019 version 16.2 or later >>> +# Optional: >>> +# Required to build EBC drivers: >>> +# Intel(r) Compiler for Efi Byte Code (Intel(r) EBC Compiler) >>> +# 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. >>> # GCC48 -Linux,Windows- Requires: >>> # GCC 4.8 targeting x86_64-linux-gnu, aarch64-linux-gnu, or >> arm-linux-gnueabi >>> # Optional: >>> @@ -1691,6 +1710,97 @@ NOOPT_VS2017_AARCH64_DLINK_FLAGS = >> /NOLOGO /NODEFAULTLIB /IGNORE:4001 /OPT:REF >>> *_VS2017_EBC_SLINK_FLAGS = /lib /NOLOGO /MACHINE:EBC >>> *_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 >>> >>> >> +######################################################### >> ########################### >>> +# VS2019 - Microsoft Visual Studio 2017 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 >>> +*_VS2019_*_MAKE_FLAG = /nologo >>> +*_VS2019_*_RC_PATH = DEF(WINSDK10_BIN)\rc.exe >>> + >>> +*_VS2019_*_MAKE_FLAGS = /nologo >>> +*_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 >>> + >>> +################## >>> +# 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 >>> + >>> + *_VS2019_IA32_MAKE_FLAGS = /nologo >>> + 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 >>> +RELEASE_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 >> /Gs32768 /D UNICODE /O1b2 /GL /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP >>> +NOOPT_VS2019_IA32_CC_FLAGS = /nologo /arch:IA32 /c /WX /GS- /W4 >> /Gs32768 /D UNICODE /FIAutoGen.h /EHs-c- /GR- /GF /Gy /Z7 /Od /MP >>> + >>> + 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 >>> + >>> + 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 >>> +RELEASE_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 >> /D UNICODE /O1b2s /GL /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Gw /MP >>> +NOOPT_VS2019_X64_CC_FLAGS = /nologo /c /WX /GS- /W4 /Gs32768 >> /D UNICODE /Gy /FIAutoGen.h /EHs-c- /GR- /GF /Z7 /Od /MP >>> + >>> + 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 >> >> Why are there no ARM, AARCH64 and EBC definitions, like there are for >> VS2017? >> >> I am afraid there are some of us here that are actually mad enough to want >> to build ARM and AARCH64 EDK2 projects using Visual Studio... ;) >> >> If it helps, I can confirm that simply copy/pasting the VS2017 sections and >> replacing all of the "VS2017" instances with "VS2019" appears to work just >> fine when compiling my ARM/AARCH64 projects. I haven't tested EBC, but I >> expect the same to be true. >> >> Apart from that, both patches look good to me. >> >> Regards, >> >> /Pete >> >>> + >>> >> ########################################################## >> ########################## >>> # GCC Common >>> >>> >> ########################################################## >> ############ >>> ############## >>> >> >> >> > ^ permalink raw reply [flat|nested] 7+ messages in thread
* [PATCH 2/2] Add VS2019 Support on ToolSetup Batches 2019-09-11 6:08 [PATCH 0/2] *** Add VS2019 Support *** Cheng, Ching JenX 2019-09-11 6:08 ` [PATCH 1/2] Add VS2019 Toolchain def Cheng, Ching JenX @ 2019-09-11 6:08 ` Cheng, Ching JenX 2019-09-16 15:52 ` Liming Gao 1 sibling, 1 reply; 7+ messages in thread From: Cheng, Ching JenX @ 2019-09-11 6:08 UTC (permalink / raw) To: devel; +Cc: Amy Chan, Bob Feng, Liming Gao REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2182 Inorder to support VS2019, we add VS2019 config process in Setup Batch Files, Because VS2019 and VS2017 could using same vswhere.exe to detect the InstallationPath, So we add the -version as the parameter of vswhere to get the correct VS2017/VS2019's InstallationPath Change-Id: I72d5ef66fd39d3d42b0b2ea57199b4fa27260ab6 Cc: Amy Chan <amy.chan@intel.com> Cc: Bob Feng <bob.c.feng@intel.com> Cc: Liming Gao <liming.gao@intel.com> Signed-off-by: Ching JenX Cheng <ching.jenx.cheng@intel.com> --- BaseTools/get_vsvars.bat | 39 +++++++++++++++++++++++++++++++-------- BaseTools/set_vsprefix_envs.bat | 70 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++----- BaseTools/toolsetup.bat | 16 +++++++++++++--- edksetup.bat | 6 ++++-- 4 files changed, 113 insertions(+), 18 deletions(-) diff --git a/BaseTools/get_vsvars.bat b/BaseTools/get_vsvars.bat index 9f3759b2a9..60c3a2c0b7 100644 --- a/BaseTools/get_vsvars.bat +++ b/BaseTools/get_vsvars.bat @@ -1,7 +1,7 @@ @REM @file @REM Windows batch file to find the Visual Studio set up script @REM -@REM Copyright (c) 2013-2014, ARM Limited. All rights reserved. +@REM Copyright (c) 2013-2019, ARM Limited. All rights reserved. @REM SPDX-License-Identifier: BSD-2-Clause-Patent @REM @@ -10,15 +10,21 @@ @echo off set SCRIPT_ERROR=0 if "%1"=="" goto main +if /I "%1"=="VS2019" goto VS2019Vars if /I "%1"=="VS2017" goto VS2017Vars if /I "%1"=="VS2015" goto VS2015Vars if /I "%1"=="VS2013" goto VS2013Vars if /I "%1"=="VS2012" goto VS2012Vars :set_vsvars -for /f "usebackq tokens=1* delims=: " %%i in (`%*`) do ( - if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" -) +if defined VCINSTALLDIR goto :EOF + call %* > vswhereInfo + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( + if /i "%%i"=="installationPath" ( + call "%%j\VC\Auxiliary\Build\vcvars32.bat" + ) + ) + del vswhereInfo goto :EOF :read_vsvars @@ -42,19 +48,36 @@ REM (Or invoke the relevant vsvars32 file beforehand). :main if defined VCINSTALLDIR goto :done + :VS2019Vars + if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" ( + if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\2019\BuildTools" ( + call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version 16,17 + ) else ( + call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -version 16,17 + ) + ) + if exist "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" ( + if exist "%ProgramFiles%\Microsoft Visual Studio\2019\BuildTools" ( + call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version 16,17 + ) else ( + call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -version 16,17 + ) + ) + if /I "%1"=="VS2019" goto ToolNotInstall + :VS2017Vars if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" ( if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\2017\BuildTools" ( - call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools + call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version 15,16 ) else ( - call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" + call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -version 15,16 ) ) if exist "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" ( if exist "%ProgramFiles%\Microsoft Visual Studio\2017\BuildTools" ( - call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools + call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version 15,16 ) else ( - call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" + call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -version 15,16 ) ) if /I "%1"=="VS2017" goto ToolNotInstall diff --git a/BaseTools/set_vsprefix_envs.bat b/BaseTools/set_vsprefix_envs.bat index 81686f5b63..46b84713a6 100644 --- a/BaseTools/set_vsprefix_envs.bat +++ b/BaseTools/set_vsprefix_envs.bat @@ -3,7 +3,7 @@ @REM however it may be executed directly from the BaseTools project folder @REM if the file is not executed within a WORKSPACE\BaseTools folder. @REM -@REM Copyright (c) 2016-2017, Intel Corporation. All rights reserved.<BR> +@REM Copyright (c) 2016-2019, Intel Corporation. All rights reserved.<BR> @REM @REM SPDX-License-Identifier: BSD-2-Clause-Patent @REM @@ -18,6 +18,7 @@ set SCRIPT_ERROR=1 goto :EOF :main +if /I "%1"=="VS2019" goto SetVS2019 if /I "%1"=="VS2017" goto SetVS2017 if /I "%1"=="VS2015" goto SetVS2015 if /I "%1"=="VS2013" goto SetVS2013 @@ -107,27 +108,86 @@ if defined VS140COMNTOOLS ( ) if /I "%1"=="VS2015" goto SetWinDDK +:SetVS2019 +if not defined VS160COMNTOOLS ( + if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" ( + if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\2019\BuildTools" ( + call "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version 16,17 > vswhereInfo + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( + if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" + ) + del vswhereInfo + ) else ( + call "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -version 16,17 > vswhereInfo + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( + if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" + ) + del vswhereInfo + ) + ) else if exist "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" ( + if exist "%ProgramFiles%\Microsoft Visual Studio\2019\BuildTools" ( + call "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version 16,17 > vswhereInfo + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( + if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" + ) + del vswhereInfo + ) else ( + call "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -version 16,17 > vswhereInfo + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( + if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" + ) + del vswhereInfo + ) + ) else ( + if /I "%1"=="VS2019" goto ToolNotInstall + goto SetWinDDK + ) +) + +if defined VCToolsInstallDir ( + if not defined VS2019_PREFIX ( + set "VS2019_PREFIX=%VCToolsInstallDir%" + ) +) +if not defined WINSDK10_PREFIX ( + if defined WindowsSdkVerBinPath ( + set "WINSDK10_PREFIX=%WindowsSdkVerBinPath%" + ) else if exist "%ProgramFiles(x86)%\Windows Kits\10\bin" ( + set "WINSDK10_PREFIX=%ProgramFiles(x86)%\Windows Kits\10\bin\" + ) else if exist "%ProgramFiles%\Windows Kits\10\bin" ( + set "WINSDK10_PREFIX=%ProgramFiles%\Windows Kits\10\bin\" + ) +) + :SetVS2017 if not defined VS150COMNTOOLS ( if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" ( if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\2017\BuildTools" ( - for /f "usebackq tokens=1* delims=: " %%i in (`"%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools`) do ( + call "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version 15,16 > vswhereInfo + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" ) + del vswhereInfo ) else ( - for /f "usebackq tokens=1* delims=: " %%i in (`"%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe"`) do ( + call "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -version 15,16 > vswhereInfo + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" ) + del vswhereInfo ) ) else if exist "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" ( if exist "%ProgramFiles%\Microsoft Visual Studio\2017\BuildTools" ( - for /f "usebackq tokens=1* delims=: " %%i in (`"%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools`) do ( + call "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version 15,16 > vswhereInfo + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" ) + del vswhereInfo ) else ( - for /f "usebackq tokens=1* delims=: " %%i in (`"%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe"`) do ( + call "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -version 15,16 > vswhereInfo + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" ) + del vswhereInfo ) ) else ( if /I "%1"=="VS2017" goto ToolNotInstall diff --git a/BaseTools/toolsetup.bat b/BaseTools/toolsetup.bat index 395694fa09..61ebf4ae09 100755 --- a/BaseTools/toolsetup.bat +++ b/BaseTools/toolsetup.bat @@ -3,7 +3,7 @@ @REM however it may be executed directly from the BaseTools project folder @REM if the file is not executed within a WORKSPACE\BaseTools folder. @REM -@REM Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR> +@REM Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.<BR> @REM (C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR> @REM @REM SPDX-License-Identifier: BSD-2-Clause-Patent @@ -42,6 +42,12 @@ if /I "%1"=="/?" goto Usage set FORCE_REBUILD=TRUE goto loop ) + if /I "%1"=="VS2019" ( + shift + set VS2019=TRUE + set VSTool=VS2019 + goto loop + ) if /I "%1"=="VS2017" ( shift set VS2017=TRUE @@ -176,7 +182,9 @@ IF NOT exist "%EDK_TOOLS_PATH%\set_vsprefix_envs.bat" ( @echo. goto end ) -if defined VS2017 ( +if defined VS2019 ( + call %EDK_TOOLS_PATH%\set_vsprefix_envs.bat VS2019 +) else if defined VS2017 ( call %EDK_TOOLS_PATH%\set_vsprefix_envs.bat VS2017 ) else if defined VS2015 ( call %EDK_TOOLS_PATH%\set_vsprefix_envs.bat VS2015 @@ -444,7 +452,7 @@ goto end :Usage @echo. - echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [ Rebuild | ForceRebuild ] [Reconfig] [base_tools_path [edk_tools_path]] [VS2017] [VS2015] [VS2013] [VS2012]" + echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [ Rebuild | ForceRebuild ] [Reconfig] [base_tools_path [edk_tools_path]] [VS2019] [VS2017] [VS2015] [VS2013] [VS2012]" @echo. @echo base_tools_path BaseTools project path, BASE_TOOLS_PATH will be set to this path. @echo edk_tools_path EDK_TOOLS_PATH will be set to this path. @@ -457,12 +465,14 @@ goto end @echo VS2013 Set the env for VS2013 build. @echo VS2015 Set the env for VS2015 build. @echo VS2017 Set the env for VS2017 build. + @echo VS2019 Set the env for VS2019 build. @echo. :end set REBUILD= set FORCE_REBUILD= set RECONFIG= +set VS2019= set VS2017= set VS2015= set VS2013= diff --git a/edksetup.bat b/edksetup.bat index 5f6028deff..024f57a4b7 100755 --- a/edksetup.bat +++ b/edksetup.bat @@ -1,7 +1,7 @@ @REM @file @REM Windows batch file to setup a WORKSPACE environment @REM -@REM Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR> +@REM Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.<BR> @REM (C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR> @REM SPDX-License-Identifier: BSD-2-Clause-Patent @REM @@ -133,6 +133,7 @@ if defined CYGWIN_HOME ( :cygwin_done if /I "%1"=="Rebuild" shift if /I "%1"=="ForceRebuild" shift +if /I "%1"=="VS2019" shift if /I "%1"=="VS2017" shift if /I "%1"=="VS2015" shift if /I "%1"=="VS2013" shift @@ -141,7 +142,7 @@ if "%1"=="" goto end :Usage @echo. - @echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [Reconfig] [Rebuild] [ForceRebuild] [VS2017] [VS2015] [VS2013] [VS2012]" + @echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [Reconfig] [Rebuild] [ForceRebuild] [VS2019] [VS2017] [VS2015] [VS2013] [VS2012]" @echo. @echo Reconfig Reinstall target.txt, tools_def.txt and build_rule.txt. @echo Rebuild Perform incremental rebuild of BaseTools binaries. @@ -150,6 +151,7 @@ if "%1"=="" goto end @echo VS2013 Set the env for VS2013 build. @echo VS2015 Set the env for VS2015 build. @echo VS2017 Set the env for VS2017 build. + @echo VS2019 Set the env for VS2019 build. @echo. @echo Note that target.template, tools_def.template and build_rules.template @echo will only be copied to target.txt, tools_def.txt and build_rule.txt -- 2.21.0.windows.1 ^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH 2/2] Add VS2019 Support on ToolSetup Batches 2019-09-11 6:08 ` [PATCH 2/2] Add VS2019 Support on ToolSetup Batches Cheng, Ching JenX @ 2019-09-16 15:52 ` Liming Gao 0 siblings, 0 replies; 7+ messages in thread From: Liming Gao @ 2019-09-16 15:52 UTC (permalink / raw) To: Cheng, Ching JenX, devel@edk2.groups.io; +Cc: Chan, Amy, Feng, Bob C Jen: I add my comments. > -----Original Message----- > From: Cheng, Ching JenX > Sent: Wednesday, September 11, 2019 2:08 PM > To: devel@edk2.groups.io > Cc: Chan, Amy <amy.chan@intel.com>; Feng, Bob C <bob.c.feng@intel.com>; Gao, Liming <liming.gao@intel.com> > Subject: [PATCH 2/2] Add VS2019 Support on ToolSetup Batches > > REF: https://bugzilla.tianocore.org/show_bug.cgi?id=2182 > > Inorder to support VS2019, we add VS2019 config process > in Setup Batch Files, > Because VS2019 and VS2017 could using same vswhere.exe > to detect the InstallationPath, > So we add the -version as the parameter of vswhere > to get the correct VS2017/VS2019's InstallationPath > > Change-Id: I72d5ef66fd39d3d42b0b2ea57199b4fa27260ab6 Remove Change-Id. > Cc: Amy Chan <amy.chan@intel.com> > Cc: Bob Feng <bob.c.feng@intel.com> > Cc: Liming Gao <liming.gao@intel.com> > Signed-off-by: Ching JenX Cheng <ching.jenx.cheng@intel.com> > --- > BaseTools/get_vsvars.bat | 39 +++++++++++++++++++++++++++++++-------- > BaseTools/set_vsprefix_envs.bat | 70 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++----- > BaseTools/toolsetup.bat | 16 +++++++++++++--- > edksetup.bat | 6 ++++-- > 4 files changed, 113 insertions(+), 18 deletions(-) > > diff --git a/BaseTools/get_vsvars.bat b/BaseTools/get_vsvars.bat > index 9f3759b2a9..60c3a2c0b7 100644 > --- a/BaseTools/get_vsvars.bat > +++ b/BaseTools/get_vsvars.bat > @@ -1,7 +1,7 @@ > @REM @file > @REM Windows batch file to find the Visual Studio set up script > @REM > -@REM Copyright (c) 2013-2014, ARM Limited. All rights reserved. > +@REM Copyright (c) 2013-2019, ARM Limited. All rights reserved. Don't update ARM Copyright. Thanks Liming > > @REM SPDX-License-Identifier: BSD-2-Clause-Patent > @REM > @@ -10,15 +10,21 @@ > @echo off > set SCRIPT_ERROR=0 > if "%1"=="" goto main > +if /I "%1"=="VS2019" goto VS2019Vars > if /I "%1"=="VS2017" goto VS2017Vars > if /I "%1"=="VS2015" goto VS2015Vars > if /I "%1"=="VS2013" goto VS2013Vars > if /I "%1"=="VS2012" goto VS2012Vars > > :set_vsvars > -for /f "usebackq tokens=1* delims=: " %%i in (`%*`) do ( > - if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" > -) > +if defined VCINSTALLDIR goto :EOF > + call %* > vswhereInfo > + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( > + if /i "%%i"=="installationPath" ( > + call "%%j\VC\Auxiliary\Build\vcvars32.bat" > + ) > + ) > + del vswhereInfo > goto :EOF > > :read_vsvars > @@ -42,19 +48,36 @@ REM (Or invoke the relevant vsvars32 file beforehand). > > :main > if defined VCINSTALLDIR goto :done > + :VS2019Vars > + if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" ( > + if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\2019\BuildTools" ( > + call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products > Microsoft.VisualStudio.Product.BuildTools -version 16,17 > + ) else ( > + call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -version 16,17 > + ) > + ) > + if exist "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" ( > + if exist "%ProgramFiles%\Microsoft Visual Studio\2019\BuildTools" ( > + call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products > Microsoft.VisualStudio.Product.BuildTools -version 16,17 > + ) else ( > + call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -version 16,17 > + ) > + ) > + if /I "%1"=="VS2019" goto ToolNotInstall > + > :VS2017Vars > if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" ( > if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\2017\BuildTools" ( > - call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products > Microsoft.VisualStudio.Product.BuildTools > + call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products > Microsoft.VisualStudio.Product.BuildTools -version 15,16 > ) else ( > - call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" > + call :set_vsvars "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -version 15,16 > ) > ) > if exist "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" ( > if exist "%ProgramFiles%\Microsoft Visual Studio\2017\BuildTools" ( > - call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products > Microsoft.VisualStudio.Product.BuildTools > + call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products > Microsoft.VisualStudio.Product.BuildTools -version 15,16 > ) else ( > - call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" > + call :set_vsvars "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -version 15,16 > ) > ) > if /I "%1"=="VS2017" goto ToolNotInstall > diff --git a/BaseTools/set_vsprefix_envs.bat b/BaseTools/set_vsprefix_envs.bat > index 81686f5b63..46b84713a6 100644 > --- a/BaseTools/set_vsprefix_envs.bat > +++ b/BaseTools/set_vsprefix_envs.bat > @@ -3,7 +3,7 @@ > @REM however it may be executed directly from the BaseTools project folder > @REM if the file is not executed within a WORKSPACE\BaseTools folder. > @REM > -@REM Copyright (c) 2016-2017, Intel Corporation. All rights reserved.<BR> > +@REM Copyright (c) 2016-2019, Intel Corporation. All rights reserved.<BR> > @REM > @REM SPDX-License-Identifier: BSD-2-Clause-Patent > @REM > @@ -18,6 +18,7 @@ set SCRIPT_ERROR=1 > goto :EOF > > :main > +if /I "%1"=="VS2019" goto SetVS2019 > if /I "%1"=="VS2017" goto SetVS2017 > if /I "%1"=="VS2015" goto SetVS2015 > if /I "%1"=="VS2013" goto SetVS2013 > @@ -107,27 +108,86 @@ if defined VS140COMNTOOLS ( > ) > if /I "%1"=="VS2015" goto SetWinDDK > > +:SetVS2019 > +if not defined VS160COMNTOOLS ( > + if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" ( > + if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\2019\BuildTools" ( > + call "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools > -version 16,17 > vswhereInfo > + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( > + if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" > + ) > + del vswhereInfo > + ) else ( > + call "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -version 16,17 > vswhereInfo > + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( > + if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" > + ) > + del vswhereInfo > + ) > + ) else if exist "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" ( > + if exist "%ProgramFiles%\Microsoft Visual Studio\2019\BuildTools" ( > + call "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version > 16,17 > vswhereInfo > + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( > + if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" > + ) > + del vswhereInfo > + ) else ( > + call "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -version 16,17 > vswhereInfo > + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( > + if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" > + ) > + del vswhereInfo > + ) > + ) else ( > + if /I "%1"=="VS2019" goto ToolNotInstall > + goto SetWinDDK > + ) > +) > + > +if defined VCToolsInstallDir ( > + if not defined VS2019_PREFIX ( > + set "VS2019_PREFIX=%VCToolsInstallDir%" > + ) > +) > +if not defined WINSDK10_PREFIX ( > + if defined WindowsSdkVerBinPath ( > + set "WINSDK10_PREFIX=%WindowsSdkVerBinPath%" > + ) else if exist "%ProgramFiles(x86)%\Windows Kits\10\bin" ( > + set "WINSDK10_PREFIX=%ProgramFiles(x86)%\Windows Kits\10\bin\" > + ) else if exist "%ProgramFiles%\Windows Kits\10\bin" ( > + set "WINSDK10_PREFIX=%ProgramFiles%\Windows Kits\10\bin\" > + ) > +) > + > :SetVS2017 > if not defined VS150COMNTOOLS ( > if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" ( > if exist "%ProgramFiles(x86)%\Microsoft Visual Studio\2017\BuildTools" ( > - for /f "usebackq tokens=1* delims=: " %%i in (`"%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products > Microsoft.VisualStudio.Product.BuildTools`) do ( > + call "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools > -version 15,16 > vswhereInfo > + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( > if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" > ) > + del vswhereInfo > ) else ( > - for /f "usebackq tokens=1* delims=: " %%i in (`"%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe"`) do ( > + call "%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe" -version 15,16 > vswhereInfo > + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( > if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" > ) > + del vswhereInfo > ) > ) else if exist "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" ( > if exist "%ProgramFiles%\Microsoft Visual Studio\2017\BuildTools" ( > - for /f "usebackq tokens=1* delims=: " %%i in (`"%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products > Microsoft.VisualStudio.Product.BuildTools`) do ( > + call "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -products Microsoft.VisualStudio.Product.BuildTools -version > 15,16 > vswhereInfo > + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( > if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" > ) > + del vswhereInfo > ) else ( > - for /f "usebackq tokens=1* delims=: " %%i in (`"%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe"`) do ( > + call "%ProgramFiles%\Microsoft Visual Studio\Installer\vswhere.exe" -version 15,16 > vswhereInfo > + for /f "usebackq tokens=1* delims=: " %%i in (vswhereInfo) do ( > if /i "%%i"=="installationPath" call "%%j\VC\Auxiliary\Build\vcvars32.bat" > ) > + del vswhereInfo > ) > ) else ( > if /I "%1"=="VS2017" goto ToolNotInstall > diff --git a/BaseTools/toolsetup.bat b/BaseTools/toolsetup.bat > index 395694fa09..61ebf4ae09 100755 > --- a/BaseTools/toolsetup.bat > +++ b/BaseTools/toolsetup.bat > @@ -3,7 +3,7 @@ > @REM however it may be executed directly from the BaseTools project folder > @REM if the file is not executed within a WORKSPACE\BaseTools folder. > @REM > -@REM Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR> > +@REM Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.<BR> > @REM (C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR> > @REM > @REM SPDX-License-Identifier: BSD-2-Clause-Patent > @@ -42,6 +42,12 @@ if /I "%1"=="/?" goto Usage > set FORCE_REBUILD=TRUE > goto loop > ) > + if /I "%1"=="VS2019" ( > + shift > + set VS2019=TRUE > + set VSTool=VS2019 > + goto loop > + ) > if /I "%1"=="VS2017" ( > shift > set VS2017=TRUE > @@ -176,7 +182,9 @@ IF NOT exist "%EDK_TOOLS_PATH%\set_vsprefix_envs.bat" ( > @echo. > goto end > ) > -if defined VS2017 ( > +if defined VS2019 ( > + call %EDK_TOOLS_PATH%\set_vsprefix_envs.bat VS2019 > +) else if defined VS2017 ( > call %EDK_TOOLS_PATH%\set_vsprefix_envs.bat VS2017 > ) else if defined VS2015 ( > call %EDK_TOOLS_PATH%\set_vsprefix_envs.bat VS2015 > @@ -444,7 +452,7 @@ goto end > > :Usage > @echo. > - echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [ Rebuild | ForceRebuild ] [Reconfig] [base_tools_path [edk_tools_path]] > [VS2017] [VS2015] [VS2013] [VS2012]" > + echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [ Rebuild | ForceRebuild ] [Reconfig] [base_tools_path [edk_tools_path]] > [VS2019] [VS2017] [VS2015] [VS2013] [VS2012]" > @echo. > @echo base_tools_path BaseTools project path, BASE_TOOLS_PATH will be set to this path. > @echo edk_tools_path EDK_TOOLS_PATH will be set to this path. > @@ -457,12 +465,14 @@ goto end > @echo VS2013 Set the env for VS2013 build. > @echo VS2015 Set the env for VS2015 build. > @echo VS2017 Set the env for VS2017 build. > + @echo VS2019 Set the env for VS2019 build. > @echo. > > :end > set REBUILD= > set FORCE_REBUILD= > set RECONFIG= > +set VS2019= > set VS2017= > set VS2015= > set VS2013= > diff --git a/edksetup.bat b/edksetup.bat > index 5f6028deff..024f57a4b7 100755 > --- a/edksetup.bat > +++ b/edksetup.bat > @@ -1,7 +1,7 @@ > @REM @file > @REM Windows batch file to setup a WORKSPACE environment > @REM > -@REM Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR> > +@REM Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.<BR> > @REM (C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR> > @REM SPDX-License-Identifier: BSD-2-Clause-Patent > @REM > @@ -133,6 +133,7 @@ if defined CYGWIN_HOME ( > :cygwin_done > if /I "%1"=="Rebuild" shift > if /I "%1"=="ForceRebuild" shift > +if /I "%1"=="VS2019" shift > if /I "%1"=="VS2017" shift > if /I "%1"=="VS2015" shift > if /I "%1"=="VS2013" shift > @@ -141,7 +142,7 @@ if "%1"=="" goto end > > :Usage > @echo. > - @echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [Reconfig] [Rebuild] [ForceRebuild] [VS2017] [VS2015] [VS2013] [VS2012]" > + @echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [Reconfig] [Rebuild] [ForceRebuild] [VS2019] [VS2017] [VS2015] [VS2013] > [VS2012]" > @echo. > @echo Reconfig Reinstall target.txt, tools_def.txt and build_rule.txt. > @echo Rebuild Perform incremental rebuild of BaseTools binaries. > @@ -150,6 +151,7 @@ if "%1"=="" goto end > @echo VS2013 Set the env for VS2013 build. > @echo VS2015 Set the env for VS2015 build. > @echo VS2017 Set the env for VS2017 build. > + @echo VS2019 Set the env for VS2019 build. > @echo. > @echo Note that target.template, tools_def.template and build_rules.template > @echo will only be copied to target.txt, tools_def.txt and build_rule.txt > -- > 2.21.0.windows.1 ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2019-09-16 15:53 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2019-09-11 6:08 [PATCH 0/2] *** Add VS2019 Support *** Cheng, Ching JenX 2019-09-11 6:08 ` [PATCH 1/2] Add VS2019 Toolchain def Cheng, Ching JenX 2019-09-11 15:43 ` [edk2-devel] " Pete Batard 2019-09-16 2:25 ` Cheng, Ching JenX 2019-09-16 9:47 ` Pete Batard 2019-09-11 6:08 ` [PATCH 2/2] Add VS2019 Support on ToolSetup Batches Cheng, Ching JenX 2019-09-16 15:52 ` Liming Gao
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox