]> git.proxmox.com Git - mirror_edk2.git/blame - Vlv2TbltDevicePkg/Build_IFWI.bat
Vlv2TbltDevicePkg: Remove directory assumptions from build scripts
[mirror_edk2.git] / Vlv2TbltDevicePkg / Build_IFWI.bat
CommitLineData
3cbfba02
DW
1@REM @file\r
2@REM Windows batch file to build BIOS ROM\r
3@REM\r
9d87197e 4@REM Copyright (c) 2006 - 2019, Intel Corporation. All rights reserved.<BR>\r
9dc8036d 5@REM SPDX-License-Identifier: BSD-2-Clause-Patent\r
3cbfba02
DW
6@REM\r
7\r
8@echo off\r
9\r
10SetLocal EnableDelayedExpansion EnableExtensions\r
11\r
46002a4a
ZS
12@REM Go to work space directory.\r
13cd ..\r
3cbfba02
DW
14cd ..\r
15\r
16:: Assign initial values\r
17set exitCode=0\r
18set "Build_Flags= "\r
19set "Stitch_Flags= "\r
20set Arch=X64\r
21set PLATFORM_PACKAGE=Vlv2TbltDevicePkg\r
3cbfba02 22\r
9d87197e
MK
23set PLATFORM_PATH=%WORKSPACE%\r
24if not exist %PLATFORM_PATH%\%PLATFORM_PACKAGE% (\r
25 if defined PACKAGES_PATH (\r
26 for %%i IN (%PACKAGES_PATH%) DO (\r
27 if exist %%~fi\%PLATFORM_PACKAGE% (\r
28 set PLATFORM_PATH=%%~fi\r
29 goto PlatformPackageFound\r
30 )\r
31 )\r
32 ) else (\r
33 echo.\r
34 echo !!! ERROR !!! Cannot find %PLATFORM_PACKAGE% !!!\r
35 echo.\r
36 goto Exit\r
37 )\r
38)\r
39:PlatformPackageFound\r
40\r
3cbfba02
DW
41:: Parse Optional arguments\r
42:OptLoop\r
43if /i "%~1"=="/?" goto Usage\r
44\r
45if /i "%~1"=="/q" (\r
46 set Build_Flags=%Build_Flags% /q\r
47 shift\r
48 goto OptLoop\r
49)\r
50if /i "%~1"=="/l" (\r
51 set Build_Flags=%Build_Flags% /l\r
52 shift\r
53 goto OptLoop\r
54)\r
eafde7a2
MK
55if /i "%~1"=="/y" (\r
56 set Build_Flags=%Build_Flags% /y\r
57 shift\r
58 goto OptLoop\r
59)\r
eae631bc
MK
60if /i "%~1"=="/m" (\r
61 set Build_Flags=%Build_Flags% /m\r
62 shift\r
63 goto OptLoop\r
64)\r
3cbfba02
DW
65if /i "%~1" == "/c" (\r
66 set Build_Flags=%Build_Flags% /c\r
67 shift\r
68 goto OptLoop\r
69)\r
70if /i "%~1" == "/ECP" (\r
71 set Build_Flags=%Build_Flags% /ecp\r
72 shift\r
73 goto OptLoop\r
74)\r
75\r
76if /i "%~1"=="/s" (\r
77 set Build_Flags=%Build_Flags% /s\r
78 shift\r
79 goto OptLoop\r
80)\r
81\r
82if /i "%~1"=="/x64" (\r
83 set Arch=X64\r
84 set Build_Flags=%Build_Flags% /x64\r
85 shift\r
86 goto OptLoop\r
87)\r
88\r
89if /i "%~1"=="/IA32" (\r
90 set Arch=IA32\r
91 set Build_Flags=%Build_Flags% /IA32\r
92 shift\r
93 goto OptLoop\r
94)\r
95\r
96if /i "%~1"=="/nG" (\r
97 set Stitch_Flags=%Stitch_Flags% /nG\r
98 shift\r
99 goto OptLoop\r
100)\r
101if /i "%~1"=="/nM" (\r
102 set Stitch_Flags=%Stitch_Flags% /nM\r
103 shift\r
104 goto OptLoop\r
105)\r
106if /i "%~1"=="/nB" (\r
107 set Stitch_Flags=%Stitch_Flags% /nB\r
108 shift\r
109 goto OptLoop\r
110)\r
83586b5d
TH
111if /i "%~1"=="/yL" (\r
112 set Stitch_Flags=%Stitch_Flags% /yL\r
113 shift\r
114 goto OptLoop\r
115)\r
116\r
3cbfba02
DW
117\r
118:: Require 2 input parameters\r
119if "%~2"=="" goto Usage\r
120\r
121:: Assign required arguments\r
122set Platform_Type=%~1\r
123set Build_Target=%~2\r
83586b5d 124\r
3cbfba02
DW
125if "%~3"=="" (\r
126 set "IFWI_Suffix= "\r
127) else set "IFWI_Suffix=/S %~3"\r
128\r
129:: Build BIOS\r
130echo ======================================================================\r
131echo Build_IFWI: Calling BIOS build Script...\r
46002a4a
ZS
132\r
133call %PLATFORM_PATH%\%PLATFORM_PACKAGE%\bld_vlv.bat %Build_Flags% %Platform_Type% %Build_Target%\r
134\r
3cbfba02
DW
135if %ERRORLEVEL% NEQ 0 (\r
136 echo echo -- Error Building BIOS & echo.\r
137 set exitCode=1\r
138 goto exit\r
139)\r
140echo.\r
141echo Finished Building BIOS.\r
142@REM Set BIOS_ID environment variable here.\r
9d87197e 143call %WORKSPACE%\Conf\BiosId.bat\r
3cbfba02
DW
144echo BIOS_ID=%BIOS_ID%\r
145\r
146:: Set the Board_Id, Build_Type, Version_Major, and Version_Minor environment variables\r
9d87197e 147find /v "#" %WORKSPACE%\Conf\BiosId.env > ver_strings\r
3cbfba02
DW
148for /f "tokens=1,3" %%i in (ver_strings) do set %%i=%%j\r
149del /f/q ver_strings >nul\r
150set BIOS_Name=%BOARD_ID%_%Arch%_%BUILD_TYPE%_%VERSION_MAJOR%_%VERSION_MINOR%.ROM\r
151\r
152:: Start Integration process\r
153echo ======================================================================\r
154echo Build_IFWI: Calling IFWI Stitching Script...\r
9d87197e 155pushd %PLATFORM_PATH%\%PLATFORM_PACKAGE%\Stitch\r
46002a4a
ZS
156\r
157 :: IFWIStitch.bat [/nG] [/nM] [/nB] [/B BIOS.rom] [/C StitchConfig] [/S IFWISuffix]\r
9d87197e 158 call IFWIStitch.bat %Stitch_Flags% /B %BIOS_Name% %IFWI_Suffix%\r
3cbfba02 159 \r
46002a4a 160 @echo off\r
3cbfba02
DW
161popd\r
162if %ERRORLEVEL% NEQ 0 (\r
163 echo echo -- Error Stitching %BIOS_Nam% & echo.\r
164 set exitCode=1\r
165)\r
166echo.\r
167echo Build_IFWI is finished.\r
168echo The final IFWI file is located in %ROOT_DIR%\Vlv2TbltDevicePkg\Stitch\\r
169echo ======================================================================\r
170goto Exit\r
171\r
172:Usage\r
173echo Script to build BIOS firmware and stitch the entire IFWI.\r
174echo.\r
175echo Usage: Build_IFWI.bat [options] PlatformType BuildTarget [IFWI Suffix]\r
176echo.\r
3cbfba02 177echo /c CleanAll before building\r
3cbfba02
DW
178echo /x64 Set Arch to X64 (default: X64)\r
179echo /IA32 Set Arch to IA32 (default: X64)\r
83586b5d 180echo /yL Enable SPI lock\r
3cbfba02
DW
181echo. \r
182echo Platform Types: MNW2\r
183echo Build Targets: Release, Debug\r
184echo IFWI Suffix: Suffix to append to end of IFWI filename (default: MM_DD_YYYY)\r
185echo.\r
186echo See Stitch/Stitch_Config.txt for additional stitching settings.\r
187echo.\r
008e2ccf
JY
188echo If capsule update is needed, please update CAPSULE_ENABLE = TRUE in Config.dsc.\r
189echo If recovery is needed, please update RECOVERY_ENABLE = TRUE in Config.dsc.\r
190echo If either of above is TRUE, please set OPENSSL_PATH in windows evironment\r
191echo and put openssl.exe there, to generate final capsule image.\r
192echo.\r
3cbfba02
DW
193set exitCode=1\r
194\r
195:Exit\r
196@REM CD to platform package.\r
46002a4a 197cd %PLATFORM_PATH%\r
3cbfba02
DW
198exit /b %exitCode%\r
199\r
200EndLocal\r