X-Git-Url: https://git.proxmox.com/?p=mirror_edk2.git;a=blobdiff_plain;f=edksetup.bat;h=662ffc00605909cb82b8f834d13636b8bfe4cb54;hp=2c8c072884b87498f55c036065e9e170c296db95;hb=b0663641c977f97bef785c86978603c3a31a3d1c;hpb=4c633da4f44ff388d27176edbc6afd75470a1fc4 diff --git a/edksetup.bat b/edksetup.bat index 2c8c072884..662ffc0060 100755 --- a/edksetup.bat +++ b/edksetup.bat @@ -1,22 +1,17 @@ @REM @file @REM Windows batch file to setup a WORKSPACE environment @REM -@REM Copyright (c) 2006 - 2013, Intel Corporation. All rights reserved.
-@REM This program and the accompanying materials -@REM are licensed and made available under the terms and conditions of the BSD License -@REM which accompanies this distribution. The full text of the license may be found at -@REM http://opensource.org/licenses/bsd-license.php -@REM -@REM THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, -@REM WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. +@REM Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.
+@REM (C) Copyright 2016 Hewlett Packard Enterprise Development LP
+@REM SPDX-License-Identifier: BSD-2-Clause-Patent @REM @REM set CYGWIN_HOME=C:\cygwin -@REM usage: +@REM usage: @REM edksetup.bat [--nt32] [AntBuild] [Rebuild] [ForceRebuild] [Reconfig] @REM if the argument, skip is present, only the paths and the -@REM test and set of environment settings are performed. +@REM test and set of environment settings are performed. @REM ############################################################## @REM # You should not have to modify anything below this line @@ -31,110 +26,149 @@ pushd . cd %~dp0 if not defined WORKSPACE ( - @goto SetWorkSpace + goto SetWorkSpace ) if %WORKSPACE% == %CD% ( @REM Workspace is not changed. - @goto ParseArgs + goto ParseArgs ) :SetWorkSpace @REM set new workspace -@REM clear EFI_SOURCE and EDK_SOURCE for the new workspace -set WORKSPACE=%CD% -set EFI_SOURCE= -set EDK_SOURCE= +if not defined WORKSPACE ( + set WORKSPACE=%CD% +) :ParseArgs -@if /I "%1"=="-h" goto Usage -@if /I "%1"=="-help" goto Usage -@if /I "%1"=="--help" goto Usage -@if /I "%1"=="/h" goto Usage -@if /I "%1"=="/?" goto Usage -@if /I "%1"=="/help" goto Usage +if /I "%1"=="-h" goto Usage +if /I "%1"=="-help" goto Usage +if /I "%1"=="--help" goto Usage +if /I "%1"=="/h" goto Usage +if /I "%1"=="/?" goto Usage +if /I "%1"=="/help" goto Usage + +if /I "%1"=="NewBuild" shift +if not defined EDK_TOOLS_PATH ( + goto SetEdkToolsPath +) else ( + goto checkNt32Flag +) -@if /I not "%1"=="--nt32" goto no_nt32 +:SetEdkToolsPath +if %WORKSPACE:~-1% EQU \ ( + @set EDK_BASETOOLS=%WORKSPACE%BaseTools +) else ( + @set EDK_BASETOOLS=%WORKSPACE%\BaseTools +) +if exist %EDK_BASETOOLS% ( + set EDK_TOOLS_PATH=%EDK_BASETOOLS% + set EDK_BASETOOLS= +) else ( + if defined PACKAGES_PATH ( + for %%i IN (%PACKAGES_PATH%) DO ( + if exist %%~fi\BaseTools ( + set EDK_TOOLS_PATH=%%~fi\BaseTools + goto checkNt32Flag + ) + ) + ) else ( + echo. + echo !!! ERROR !!! Cannot find BaseTools !!! + echo. + goto BadBaseTools + ) +) -@REM Flag, --nt32 is set -@REM The Nt32 Emluation Platform requires Microsoft Libraries -@REM and headers to interface with Windows. +:checkNt32Flag +if exist %EDK_TOOLS_PATH%\Source set BASE_TOOLS_PATH=%EDK_TOOLS_PATH% -if not defined VCINSTALLDIR ( - if defined VS110COMNTOOLS ( - call "%VS110COMNTOOLS%\vsvars32.bat" +@REM The Nt32 Emulation Platform requires Microsoft Libraries +@REM and headers to interface with Windows. +if /I "%1"=="--nt32" ( + if /I "%2"=="X64" ( + shift + call "%BASE_TOOLS_PATH%\Scripts\SetVisualStudio.bat" ) else ( - if defined VS100COMNTOOLS ( - call "%VS100COMNTOOLS%\vsvars32.bat" - ) else ( - if defined VS90COMNTOOLS ( - call "%VS90COMNTOOLS%\vsvars32.bat" - ) else ( - if defined VS80COMNTOOLS ( - call "%VS80COMNTOOLS%\vsvars32.bat" - ) else ( - if defined VS71COMNTOOLS ( - call "%VS71COMNTOOLS%\vsvars32.bat" - ) else ( - echo. - echo !!! WARNING !!! Cannot find Visual Studio !!! - echo. - ) - ) - ) - ) + call "%BASE_TOOLS_PATH%\get_vsvars.bat" ) + shift ) -shift -:no_nt32 -@if /I "%1"=="NewBuild" shift -@if not defined EDK_TOOLS_PATH set EDK_TOOLS_PATH=%WORKSPACE%\BaseTools -@IF NOT EXIST "%EDK_TOOLS_PATH%\toolsetup.bat" goto BadBaseTools -@call %EDK_TOOLS_PATH%\toolsetup.bat %* -@if /I "%1"=="Reconfig" shift -@goto check_cygwin +:checkBaseTools +IF NOT EXIST "%EDK_TOOLS_PATH%\toolsetup.bat" goto BadBaseTools +call %EDK_TOOLS_PATH%\toolsetup.bat %* +if /I "%1"=="Reconfig" shift +goto check_NASM +goto check_cygwin :BadBaseTools @REM - @REM Need the BaseTools Package in order to build + REM Need the BaseTools Package in order to build @REM - echo. - echo !!! ERROR !!! The BaseTools Package was not found !!! - echo. - echo Set the system environment variable, EDK_TOOLS_PATH to the BaseTools, - echo For example, - echo set EDK_TOOLS_PATH=C:\MyTools\BaseTools - echo The setup script, toolsetup.bat must reside in this folder. - echo. - @goto end + @echo. + @echo !!! ERROR !!! The BaseTools Package was not found !!! + @echo. + @echo Set the system environment variable, EDK_TOOLS_PATH to the BaseTools, + @echo For example, + @echo set EDK_TOOLS_PATH=C:\MyTools\BaseTools + @echo The setup script, toolsetup.bat must reside in this folder. + @echo. + goto end + +:check_NASM +if not defined NASM_PREFIX ( + @echo. + @echo !!! WARNING !!! NASM_PREFIX environment variable is not set + @if exist "C:\nasm\nasm.exe" @set "NASM_PREFIX=C:\nasm\" + @if exist "C:\nasm\nasm.exe" @echo Found nasm.exe, setting the environment variable to C:\nasm\ + @if not exist "C:\nasm\nasm.exe" echo Attempting to build modules that require NASM will fail. +) :check_cygwin - @if exist c:\cygwin ( - @set CYGWIN_HOME=c:\cygwin +if defined CYGWIN_HOME ( + if not exist "%CYGWIN_HOME%" ( + @echo. + @echo !!! WARNING !!! CYGWIN_HOME not found, gcc build may not be used !!! + @echo. + ) +) else ( + if exist c:\cygwin ( + set CYGWIN_HOME=c:\cygwin ) else ( @echo. @echo !!! WARNING !!! No CYGWIN_HOME set, gcc build may not be used !!! @echo. ) +) -@if NOT "%1"=="" goto Usage -@goto end +:cygwin_done +if /I "%1"=="Rebuild" shift +if /I "%1"=="ForceRebuild" shift +if "%1"=="" goto end :Usage @echo. - @echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [--nt32] [Reconfig]" - @echo --nt32 Call vsvars32.bat for NT32 platform build. + @echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [--nt32 [X64]] [Reconfig] [Rebuild] [ForceRebuild]" + @echo --nt32 [X64] If a compiler tool chain is not available in the + @echo environment, call a script to attempt to set one up. + @echo This flag is only required if building the + @echo Nt32Pkg/Nt32Pkg.dsc system emulator. + @echo If the X64 argument is set, and a compiler tool chain is + @echo not available, attempt to set up a tool chain that will + @echo create X64 binaries. Setting these two options have the + @echo potential side effect of changing tool chains used for a + @echo rebuild. @echo. @echo Reconfig Reinstall target.txt, tools_def.txt and build_rule.txt. + @echo Rebuild Perform incremental rebuild of BaseTools binaries. + @echo ForceRebuild Force a full rebuild of BaseTools binaries. @echo. @echo Note that target.template, tools_def.template and build_rules.template - @echo will be only copied to target.txt, tools_def.txt and build_rule.txt - @echo respectively if they do not exist. Using option [Reconfig] to force the copy. + @echo will only be copied to target.txt, tools_def.txt and build_rule.txt + @echo respectively if they do not exist. Use option [Reconfig] to force the copy. @echo. - @goto end + goto end :end - @popd - @echo on - + popd