X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=edksetup.bat;h=7aa167549bb2d88c08723338641149a43d4dcf0b;hb=6d92ae11d14abe39f2587a360bc5d6c370325cad;hp=9b3d0c98ccbf58233f1d41af10836960337bf3ba;hpb=3ecfb292563051f59830f500c1ac086ed1fe7492;p=mirror_edk2.git
diff --git a/edksetup.bat b/edksetup.bat
old mode 100644
new mode 100755
index 9b3d0c98cc..7aa167549b
--- a/edksetup.bat
+++ b/edksetup.bat
@@ -1,6 +1,9 @@
+@REM @file
+@REM Windows batch file to setup a WORKSPACE environment
@REM
-@REM Copyright (c) 2006, Intel Corporation
-@REM All rights reserved. This program and the accompanying materials
+@REM Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.
+@REM (C) Copyright 2016 Hewlett Packard Enterprise Development LP
+@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
@@ -9,13 +12,10 @@
@REM WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
@REM
-@REM set following environment in this file or in command shell
-@REM set JAVA_HOME=C:\Java\jdk1.5.0_04
-@REM set ANT_HOME=C:\ANT
-@REM set XMLBEANS_HOME=C:\xmlbeans
@REM set CYGWIN_HOME=C:\cygwin
-@REM usage: edksetup.bat [Rebuild] [ForceRebuild]
+@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.
@@ -26,231 +26,144 @@
@echo off
@REM
-@REM Check the required system environment variables
+@REM Set the WORKSPACE to the current working directory
@REM
+pushd .
+cd %~dp0
-:check_vc
-if defined VCINSTALLDIR goto check_cygwin
-if defined VS71COMNTOOLS (
- call "%VS71COMNTOOLS%\vsvars32.bat"
-) else (
- echo.
- echo !!! WARNING !!!! Cannot find Visual Studio !!!
- echo.
+if not defined WORKSPACE (
+ goto SetWorkSpace
)
-:check_cygwin
-if defined CYGWIN_HOME goto check_java
-if exist c:\cygwin (
- set CYGWIN_HOME=c:\cygwin
-) else (
- echo.
- echo !!! WARNING !!!! Not set CYGWIN_HOME, gcc build may not be used !!!
- echo.
+if %WORKSPACE% == %CD% (
+ @REM Workspace is not changed.
+ goto ParseArgs
)
-:check_java
-if "%JAVA_HOME%"=="" goto no_jdk
-
-:check_ant
-if "%ANT_HOME%"=="" goto no_ant
-if not exist %ANT_HOME%\lib\ant-contrib.jar goto no_antcontrib
-
-:check_xmlbeans
-if "%XMLBEANS_HOME%"=="" goto no_xmlbeans
-if not exist %XMLBEANS_HOME%\lib\saxon8.jar goto no_saxon8
-
-@REM
-@REM Set the WORKSPACE to the current working directory
-@REM
-set WORKSPACE=%CD%
-
-set FRAMEWORK_TOOLS_PATH=%WORKSPACE%\Tools\bin
-
-if defined WORKSPACE_TOOLS_PATH goto check_path
-set PATH=%FRAMEWORK_TOOLS_PATH%;%JAVA_HOME%\bin;%ANT_HOME%\bin;%XMLBEANS_HOME%\bin;%PATH%
-set WORKSPACE_TOOLS_PATH=%FRAMEWORK_TOOLS_PATH%
-echo Setting the PATH variable to include the FRAMEWORK_TOOLS_PATH for this WORKSPACE
-goto path_ok
-
-:check_path
-if "%FRAMEWORK_TOOLS_PATH%"=="%WORKSPACE_TOOLS_PATH%" goto path_ok
-set PATH=%FRAMEWORK_TOOLS_PATH%;%PATH%
-set WORKSPACE_TOOLS_PATH=%WORKSPACE%\Tools\bin
-echo Resetting the PATH variable to include the FRAMEWORK_TOOLS_PATH for this WORKSPACE
-
-:path_ok
-
-@if "%1"=="-h" goto Usage
-@if "%1"=="-help" goto Usage
-@if "%1"=="--help" goto Usage
-@if "%1"=="/h" goto Usage
-@if "%1"=="/?" goto Usage
-@if "%1"=="/help" goto Usage
-
-@IF NOT EXIST "Tools\Jars\Common.jar" goto NormalBuild
-@IF NOT EXIST "Tools\Jars\PcdTools.jar" goto NormalBuild
-@IF NOT EXIST "Tools\Jars\GenBuild.jar" goto NormalBuild
-@IF NOT EXIST "Tools\Jars\SurfaceArea.jar" goto NormalBuild
-@IF NOT EXIST "Tools\Jars\cpptasks.jar" goto NormalBuild
-@IF NOT EXIST "Tools\Jars\frameworktasks.jar" goto NormalBuild
-@IF NOT EXIST "Tools\bin\FrameworkWizard.jar" goto NormalBuild
-@IF NOT EXIST "Tools\bin\CompressDll.dll" goto NormalBuild
-@IF NOT EXIST "Tools\bin\CompressDll.lib" goto NormalBuild
-@IF NOT EXIST "Tools\bin\CreateMtFile.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\EfiCompress.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\EfiRom.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\FlashMap.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\FwImage.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\GenAcpiTable.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\GenCRC32Section.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\GenCapsuleHdr.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\GenDepex.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\GenFfsFile.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\GenFvImage.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\GenSection.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\GenTEImage.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\GuidChk.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\MakeDeps.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\ModifyInf.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\PeiRebase_Ia32.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\PeiRebase_Ipf.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\PeiRebase_X64.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\SecApResetVectorFixup.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\SecFixup.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\SetStamp.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\SplitFile.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\StrGather.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\Strip.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\VfrCompile.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\ZeroDebugData.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\antlr.exe" goto NormalBuild
-@IF NOT EXIST "Tools\bin\dlg.exe" goto NormalBuild
-
-@if "%1"=="Rebuild" goto NormalBuild
-@if "%1"=="ForceRebuild" goto ForceBuild
-@if NOT "%1"=="" goto Usage
-
-goto skipbuild
-
-:ForceBuild
-call ant -noclasspath -f %WORKSPACE%\Tools\build.xml cleanall
-
-:NormalBuild
-@REM
-@REM Start to build the Framework Tools
-@REM
-
-echo.
-echo Building the Framework Tools
-echo.
-
-@REM
-@REM We are going to create the SurfaceArea.jar file first so that the other
-@REM Java Programs can use it.
-@REM It needs the XMLBEANS libraries in order to compile.
-@REM
-set CLASSPATH=%XMLBEANS_HOME%\lib
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\jsr173_1.0_api.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xbean.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xbean_xpath.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xmlpublic.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\saxon8.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\resolver.jar
-
-call ant -f %WORKSPACE%\Tools\build.xml SurfaceArea
-
-@REM
-@REM Now we can make the other Java Programs
-@REM All of the remaining Java Programs require the SurfaceArea library to compile
-@REM
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\SurfaceArea.jar
-
-call ant -f %WORKSPACE%\Tools\build.xml JavaCode
-
-@REM
-@REM We have all of the Java Programs and add-in classes created, so we can start
-@REM using the cpp-tasks to create our tools
-@REM
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\Common.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\PcdTools.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\GenBuild.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\cpptasks.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\frameworktasks.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Bin\FrameworkWizard.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Bin\MigrationTools.jar
-
-call ant -f %WORKSPACE%\Tools\build.xml C_Code
-
-@REM
-@REM Done!!!
-@REM
-goto end
-
-:no_jdk
-echo.
-echo !!! Please install Java, and set JAVA_HOME !!!
-echo.
-goto end
+:SetWorkSpace
+@REM set new workspace
+@REM clear EFI_SOURCE and EDK_SOURCE for the new workspace
+if not defined WORKSPACE (
+ set WORKSPACE=%CD%
+ set EFI_SOURCE=
+ set EDK_SOURCE=
+)
-:no_ant
-echo.
-echo !!! Please install Apache Ant, and set ANT_HOME !!!
-echo.
-goto end
+: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"=="NewBuild" shift
+if not defined EDK_TOOLS_PATH (
+ if exist %WORKSPACE%\BaseTools (
+ set EDK_TOOLS_PATH=%WORKSPACE%\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
+ )
+ )
+)
-:no_antcontrib
-echo.
-echo !!! Please install Ant-contrib to ANT_HOME !!!
-echo.
-goto end
+:checkNt32Flag
+if exist %EDK_TOOLS_PATH%\Source set BASE_TOOLS_PATH=%EDK_TOOLS_PATH%
+
+@REM The Nt32 Emluation 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 (
+ call "%BASE_TOOLS_PATH%\get_vsvars.bat"
+ )
+ shift
+)
-:no_xmlbeans
-echo.
-echo !!! Please install XML Beans, and set XMLBEANS_HOME !!!
-echo.
-goto end
+: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
+ @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.
+)
-:no_saxon8
-echo.
-echo !!! Please copy saxon8.jar file to XMLBEANS_HOME\lib !!!
-echo.
-goto end
+:check_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.
+ )
+)
-:skipbuild
-@REM
-@REM This just sets up the CLASSPATH, the rest of the environment should have been set already.
-@REM
-echo.
-echo WORKSPACE: %WORKSPACE%
-echo JAVA_HOME: %JAVA_HOME%
-echo ANT_HOME: %ANT_HOME%
-echo XMLBEANS_HOME: %XMLBEANS_HOME%
-echo CYGWIN_HOME: %CYGWIN_HOME%
-echo PATH: %PATH%
-echo.
-set CLASSPATH=%XMLBEANS_HOME%\lib
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\jsr173_1.0_api.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xbean.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xbean_xpath.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xmlpublic.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\saxon8.jar
-set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\resolver.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\SurfaceArea.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\Common.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\PcdTools.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\GenBuild.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\cpptasks.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\frameworktasks.jar
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Bin\FrameworkWizard.jar
-echo CLASSPATH: %CLASSPATH%
-goto end
+:cygwin_done
+if "%1"=="" goto end
:Usage
-echo.
-echo Usage: %0 [Rebuild] [ForceRebuild]
-echo.
+ @echo.
+ @echo Usage: "%0 [-h | -help | --help | /h | /help | /?] [--nt32 [X64]] [Reconfig]"
+ @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.
+ @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
+ @echo respectively if they do not exist. Use option [Reconfig] to force the copy.
+ @echo.
+ goto end
:end
-@echo on
+ popd