* [PATCH v2 0/2] *** Add VS2019 Support *** @ 2019-09-17 3:16 Cheng, Ching JenX 2019-09-17 3:16 ` [PATCH v2 1/2] Add VS2019 Toolchain def Cheng, Ching JenX 2019-09-17 3:16 ` [PATCH v2 2/2] Add VS2019 Support on ToolSetup Batches Cheng, Ching JenX 0 siblings, 2 replies; 6+ messages in thread From: Cheng, Ching JenX @ 2019-09-17 3:16 UTC (permalink / raw) To: devel In order to support VS2019 on EDK2, the following patches was modified def and batch files 1. Add VS2019 x86/64 definitions on tools_def.template 2. Add VS2019 support on toolsetup batches, and add version check with command vswhere Because VS2019 and VS2017 using the same vswhere to get the InstallationPath v2: add ARM/AARCH64/EBC Definitions, Combine VS2017_HOST and VS2019_HOST to VS_HOST Ching JenX Cheng (2): Add VS2019 Toolchain def Add VS2019 Support on ToolSetup Batches BaseTools/Conf/tools_def.template | 220 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++------------------- BaseTools/get_vsvars.bat | 37 ++++++++++++++++++++++++++++++------- BaseTools/set_vsprefix_envs.bat | 70 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++----- BaseTools/toolsetup.bat | 16 +++++++++++++--- edksetup.bat | 6 ++++-- 5 files changed, 313 insertions(+), 36 deletions(-) -- 2.21.0.windows.1 ^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH v2 1/2] Add VS2019 Toolchain def 2019-09-17 3:16 [PATCH v2 0/2] *** Add VS2019 Support *** Cheng, Ching JenX @ 2019-09-17 3:16 ` Cheng, Ching JenX 2019-09-17 6:31 ` [edk2-devel] " Pete Batard 2019-09-17 3:16 ` [PATCH v2 2/2] Add VS2019 Support on ToolSetup Batches Cheng, Ching JenX 1 sibling, 1 reply; 6+ messages in thread From: Cheng, Ching JenX @ 2019-09-17 3:16 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 v2: add ARM/AARCH64/EBC Definitions, Combine VS2017_HOST and VS2019_HOST to VS_HOST 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 | 220 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++------------------- 1 file changed, 201 insertions(+), 19 deletions(-) diff --git a/BaseTools/Conf/tools_def.template b/BaseTools/Conf/tools_def.template index 8f0e6cb6c2..88a6764f43 100755 --- a/BaseTools/Conf/tools_def.template +++ b/BaseTools/Conf/tools_def.template @@ -55,35 +55,43 @@ DEFINE VS2015x86_BIN = ENV(VS2015_PREFIX)Vc\bin DEFINE VS2015x86_DLL = ENV(VS2015_PREFIX)Common7\IDE;DEF(VS2015x86_BIN) DEFINE VS2015x86_BINX64 = DEF(VS2015x86_BIN)\x86_amd64 -DEFINE VS2017_BIN = ENV(VS2017_PREFIX)bin -DEFINE VS2017_HOST = x86 -DEFINE VS2017_BIN_HOST = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\DEF(VS2017_HOST) -DEFINE VS2017_BIN_IA32 = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\x86 -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 VS_HOST = x86 -DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) -DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) +DEFINE VS2017_BIN = ENV(VS2017_PREFIX)bin +DEFINE VS2017_BIN_HOST = DEF(VS2017_BIN)\HostDEF(VS_HOST)\DEF(VS_HOST) +DEFINE VS2017_BIN_IA32 = DEF(VS2017_BIN)\HostDEF(VS_HOST)\x86 +DEFINE VS2017_BIN_X64 = DEF(VS2017_BIN)\HostDEF(VS_HOST)\x64 +DEFINE VS2017_BIN_ARM = DEF(VS2017_BIN)\HostDEF(VS_HOST)\arm +DEFINE VS2017_BIN_AARCH64 = DEF(VS2017_BIN)\HostDEF(VS_HOST)\arm64 + +DEFINE VS2019_BIN = ENV(VS2019_PREFIX)bin +DEFINE VS2019_BIN_HOST = DEF(VS2019_BIN)\HostDEF(VS_HOST)\DEF(VS_HOST) +DEFINE VS2019_BIN_IA32 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\x86 +DEFINE VS2019_BIN_X64 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\x64 +DEFINE VS2019_BIN_ARM = DEF(VS2019_BIN)\HostDEF(VS_HOST)\arm +DEFINE VS2019_BIN_AARCH64 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\arm64 + +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(VS_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,169 @@ 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 2019 with Intel ASL +# ASL - Intel ACPI Source Language Compiler (iasl.exe) +#################################################################################### +# VS2019 - Microsoft Visual Studio 2017 professional Edition with Intel ASL +*_VS2019_*_*_FAMILY = MSFT +*_VS2019_*_*_DLL = DEF(VS2019_BIN_HOST) + +*_VS2019_*_MAKE_PATH = DEF(VS2019_BIN_HOST)\nmake.exe +*_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 + +################# +# 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 + #################################################################################### # GCC Common #################################################################################### -- 2.21.0.windows.1 ^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [edk2-devel] [PATCH v2 1/2] Add VS2019 Toolchain def 2019-09-17 3:16 ` [PATCH v2 1/2] Add VS2019 Toolchain def Cheng, Ching JenX @ 2019-09-17 6:31 ` Pete Batard 0 siblings, 0 replies; 6+ messages in thread From: Pete Batard @ 2019-09-17 6:31 UTC (permalink / raw) To: devel, ching.jenx.cheng; +Cc: Amy Chan, Bob Feng, Liming Gao On 2019.09.17 04:16, 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 > > v2: add ARM/AARCH64/EBC Definitions, Combine VS2017_HOST and VS2019_HOST to VS_HOST Both patches look good to me now. Thanks. Reviewed-by: Pete Batard <pete@akeo.ie> > > 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 | 220 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++------------------- > 1 file changed, 201 insertions(+), 19 deletions(-) > > diff --git a/BaseTools/Conf/tools_def.template b/BaseTools/Conf/tools_def.template > index 8f0e6cb6c2..88a6764f43 100755 > --- a/BaseTools/Conf/tools_def.template > +++ b/BaseTools/Conf/tools_def.template > @@ -55,35 +55,43 @@ DEFINE VS2015x86_BIN = ENV(VS2015_PREFIX)Vc\bin > DEFINE VS2015x86_DLL = ENV(VS2015_PREFIX)Common7\IDE;DEF(VS2015x86_BIN) > DEFINE VS2015x86_BINX64 = DEF(VS2015x86_BIN)\x86_amd64 > > -DEFINE VS2017_BIN = ENV(VS2017_PREFIX)bin > -DEFINE VS2017_HOST = x86 > -DEFINE VS2017_BIN_HOST = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\DEF(VS2017_HOST) > -DEFINE VS2017_BIN_IA32 = DEF(VS2017_BIN)\HostDEF(VS2017_HOST)\x86 > -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 VS_HOST = x86 > > -DEFINE WINSDK_BIN = ENV(WINSDK_PREFIX) > -DEFINE WINSDKx86_BIN = ENV(WINSDKx86_PREFIX) > +DEFINE VS2017_BIN = ENV(VS2017_PREFIX)bin > +DEFINE VS2017_BIN_HOST = DEF(VS2017_BIN)\HostDEF(VS_HOST)\DEF(VS_HOST) > +DEFINE VS2017_BIN_IA32 = DEF(VS2017_BIN)\HostDEF(VS_HOST)\x86 > +DEFINE VS2017_BIN_X64 = DEF(VS2017_BIN)\HostDEF(VS_HOST)\x64 > +DEFINE VS2017_BIN_ARM = DEF(VS2017_BIN)\HostDEF(VS_HOST)\arm > +DEFINE VS2017_BIN_AARCH64 = DEF(VS2017_BIN)\HostDEF(VS_HOST)\arm64 > + > +DEFINE VS2019_BIN = ENV(VS2019_PREFIX)bin > +DEFINE VS2019_BIN_HOST = DEF(VS2019_BIN)\HostDEF(VS_HOST)\DEF(VS_HOST) > +DEFINE VS2019_BIN_IA32 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\x86 > +DEFINE VS2019_BIN_X64 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\x64 > +DEFINE VS2019_BIN_ARM = DEF(VS2019_BIN)\HostDEF(VS_HOST)\arm > +DEFINE VS2019_BIN_AARCH64 = DEF(VS2019_BIN)\HostDEF(VS_HOST)\arm64 > + > +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(VS_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,169 @@ 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 2019 with Intel ASL > +# ASL - Intel ACPI Source Language Compiler (iasl.exe) > +#################################################################################### > +# VS2019 - Microsoft Visual Studio 2017 professional Edition with Intel ASL > +*_VS2019_*_*_FAMILY = MSFT > +*_VS2019_*_*_DLL = DEF(VS2019_BIN_HOST) > + > +*_VS2019_*_MAKE_PATH = DEF(VS2019_BIN_HOST)\nmake.exe > +*_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 > + > +################# > +# 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 > + > #################################################################################### > # GCC Common > #################################################################################### > -- > 2.21.0.windows.1 > > > > ^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH v2 2/2] Add VS2019 Support on ToolSetup Batches 2019-09-17 3:16 [PATCH v2 0/2] *** Add VS2019 Support *** Cheng, Ching JenX 2019-09-17 3:16 ` [PATCH v2 1/2] Add VS2019 Toolchain def Cheng, Ching JenX @ 2019-09-17 3:16 ` Cheng, Ching JenX 2019-09-19 8:23 ` Liming Gao 1 sibling, 1 reply; 6+ messages in thread From: Cheng, Ching JenX @ 2019-09-17 3:16 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 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 | 37 ++++++++++++++++++++++++++++++------- BaseTools/set_vsprefix_envs.bat | 70 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++----- BaseTools/toolsetup.bat | 16 +++++++++++++--- edksetup.bat | 6 ++++-- 4 files changed, 112 insertions(+), 17 deletions(-) diff --git a/BaseTools/get_vsvars.bat b/BaseTools/get_vsvars.bat index 9f3759b2a9..3beb113be2 100644 --- a/BaseTools/get_vsvars.bat +++ b/BaseTools/get_vsvars.bat @@ -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] 6+ messages in thread
* Re: [PATCH v2 2/2] Add VS2019 Support on ToolSetup Batches 2019-09-17 3:16 ` [PATCH v2 2/2] Add VS2019 Support on ToolSetup Batches Cheng, Ching JenX @ 2019-09-19 8:23 ` Liming Gao 2019-09-19 8:37 ` Cheng, Ching JenX 0 siblings, 1 reply; 6+ messages in thread From: Liming Gao @ 2019-09-19 8:23 UTC (permalink / raw) To: Cheng, Ching JenX, devel@edk2.groups.io; +Cc: Chan, Amy, Feng, Bob C Allen: In my machine, I install VS2017, but not install VS2019. I call edksetup.bat. It will set up VS2017 environment. But with this change, it will set the wrong WINSDK10_PREFIX. I add the comments in the patch. >-----Original Message----- >From: Cheng, Ching JenX >Sent: Tuesday, September 17, 2019 11:16 AM >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 v2 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 > >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 | 37 ++++++++++++++++++++++++++++++----- >-- > BaseTools/set_vsprefix_envs.bat | 70 >+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ >++++++----- > BaseTools/toolsetup.bat | 16 +++++++++++++--- > edksetup.bat | 6 ++++-- > 4 files changed, 112 insertions(+), 17 deletions(-) > >diff --git a/BaseTools/get_vsvars.bat b/BaseTools/get_vsvars.bat >index 9f3759b2a9..3beb113be2 100644 >--- a/BaseTools/get_vsvars.bat >+++ b/BaseTools/get_vsvars.bat >@@ -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\" >+ ) >+) In my machine, VS2019 is not installed. Then, WindowsSdkVerBinPath is not set. So, set "WINSDK10_PREFIX=%ProgramFiles(x86)%\Windows Kits\10\bin\" But, I install VS2017. WINSDK10_PREFIX should be set later. Here, the suggest change is to move WINSDK10_PREFIX setting into VCToolsInstallDir check condition. WINSDK10_PREFIX is only set when VCToolsInstallDir is defined. Thanks Liming >+ > :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] 6+ messages in thread
* Re: [PATCH v2 2/2] Add VS2019 Support on ToolSetup Batches 2019-09-19 8:23 ` Liming Gao @ 2019-09-19 8:37 ` Cheng, Ching JenX 0 siblings, 0 replies; 6+ messages in thread From: Cheng, Ching JenX @ 2019-09-19 8:37 UTC (permalink / raw) To: Gao, Liming, devel@edk2.groups.io; +Cc: Chan, Amy, Feng, Bob C Hi Liming, Ok, Thanks for your comments, I will prepare the patch V3 with your comments, Thanks, Best Regards, Allen > -----Original Message----- > From: Gao, Liming > Sent: Thursday, September 19, 2019 4:24 PM > To: Cheng, Ching JenX <ching.jenx.cheng@intel.com>; > devel@edk2.groups.io > Cc: Chan, Amy <amy.chan@intel.com>; Feng, Bob C <bob.c.feng@intel.com> > Subject: RE: [PATCH v2 2/2] Add VS2019 Support on ToolSetup Batches > > Allen: > In my machine, I install VS2017, but not install VS2019. I call edksetup.bat. It > will set up VS2017 environment. > But with this change, it will set the wrong WINSDK10_PREFIX. I add the > comments in the patch. > > >-----Original Message----- > >From: Cheng, Ching JenX > >Sent: Tuesday, September 17, 2019 11:16 AM > >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 v2 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 > > > >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 | 37 ++++++++++++++++++++++++++++++-- > --- > >-- > > BaseTools/set_vsprefix_envs.bat | 70 > >+++++++++++++++++++++++++++++++++++++++++++++++++++++++++ > ++ > >++++++----- > > BaseTools/toolsetup.bat | 16 +++++++++++++--- > > edksetup.bat | 6 ++++-- > > 4 files changed, 112 insertions(+), 17 deletions(-) > > > >diff --git a/BaseTools/get_vsvars.bat b/BaseTools/get_vsvars.bat index > >9f3759b2a9..3beb113be2 100644 > >--- a/BaseTools/get_vsvars.bat > >+++ b/BaseTools/get_vsvars.bat > >@@ -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\" > >+ ) > >+) > > In my machine, VS2019 is not installed. Then, WindowsSdkVerBinPath is not > set. > So, set "WINSDK10_PREFIX=%ProgramFiles(x86)%\Windows Kits\10\bin\" > But, I install VS2017. WINSDK10_PREFIX should be set later. > > Here, the suggest change is to move WINSDK10_PREFIX setting into > VCToolsInstallDir check condition. > WINSDK10_PREFIX is only set when VCToolsInstallDir is defined. > > Thanks > Liming > >+ > > :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] 6+ messages in thread
end of thread, other threads:[~2019-09-19 8:37 UTC | newest] Thread overview: 6+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2019-09-17 3:16 [PATCH v2 0/2] *** Add VS2019 Support *** Cheng, Ching JenX 2019-09-17 3:16 ` [PATCH v2 1/2] Add VS2019 Toolchain def Cheng, Ching JenX 2019-09-17 6:31 ` [edk2-devel] " Pete Batard 2019-09-17 3:16 ` [PATCH v2 2/2] Add VS2019 Support on ToolSetup Batches Cheng, Ching JenX 2019-09-19 8:23 ` Liming Gao 2019-09-19 8:37 ` Cheng, Ching JenX
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox