]> git.proxmox.com Git - mirror_edk2.git/blame - Tools/Conf/BuildMacro.xml
Update BuildMacro to support LIBPATH and INCLUDEPATH.
[mirror_edk2.git] / Tools / Conf / BuildMacro.xml
CommitLineData
a1c90cf6 1<?xml version="1.0" encoding="UTF-8"?>\r
878ddf1f 2<!--\r
3Copyright (c) 2006, Intel Corporation\r
4All rights reserved. This program and the accompanying materials\r
5are licensed and made available under the terms and conditions of the BSD License\r
6which accompanies this distribution. The full text of the license may be found at\r
7http://opensource.org/licenses/bsd-license.php\r
8\r
9THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
10WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
11-->\r
12<project name="common">\r
88f858a1 13 <!--\r
14 Macro for intialize some properties. This Macro build will be called before source file build. \r
15 -->\r
16 <macrodef name="Build_Init">\r
1549f516 17 <element name="EXTRA.INC" optional="yes"/>\r
18 <element name="EXTRA.ARG" optional="yes"/>\r
19 \r
88f858a1 20 <sequential>\r
21 <var name="OBJECTS" value="" />\r
22 <var name="SDB_FILES" value="" />\r
1549f516 23\r
24 <if>\r
fd6c41f5 25 <and>\r
26 <isset property="PCH"/>\r
27 <not>\r
28 <equals arg1="${PCH}" arg2=""/>\r
29 </not>\r
30 </and>\r
1549f516 31 <then>\r
32 <if>\r
33 <available type="file" file="${DEST_DIR_OUTPUT}/AutoGen.h.gch"/>\r
34 <then>\r
35 <makedeps DepsFile="${DEST_DIR_OUTPUT}/AutoGen.h.dep">\r
36 <input file="${DEST_DIR_DEBUG}/AutoGen.h"/>\r
37 <EXTRA.INC/>\r
38 </makedeps>\r
39 </then>\r
40 </if>\r
41 \r
42 <OnDependency>\r
43 <sourcefiles>\r
44 <file ListFile="${DEST_DIR_OUTPUT}/AutoGen.h.dep"/>\r
45 </sourcefiles>\r
46 <targetfiles>\r
47 <file Name="${DEST_DIR_OUTPUT}/AutoGen.h.gch"/>\r
48 </targetfiles>\r
49 \r
50 <sequential>\r
51 <!-- Generate pre-compiled header -->\r
52 <cc userdefine="on">\r
53 <command type="CC" cmd="${PCH}" workdir="${DEST_DIR_OUTPUT}" family="${CC_FAMILY}"\r
877de749 54 outputFile="${DEST_DIR_OUTPUT}/AutoGen.h.obj" dpath="${CC_DPATH}" libpath="${CC_LIBPATH}" \r
55 include="${CC_INCLUDEPATH}">\r
1549f516 56 <EXTRA.INC/>\r
57 <argument value="${PCH_FLAGS}"/>\r
58 <EXTRA.ARG/>\r
59 <fileset casesensitive="on" file="${DEST_DIR_DEBUG}/AutoGen.h"/>\r
60 </command>\r
61 </cc>\r
62\r
63 <if>\r
64 <equals arg1="${CC_FAMILY}" arg2="GCC"/>\r
65 <then>\r
aba23ad9 66 <move file="${DEST_DIR_OUTPUT}/AutoGen.h.obj" tofile="${DEST_DIR_DEBUG}/AutoGen.h.gch" overwrite="true"/>\r
1549f516 67 </then>\r
1549f516 68 </if>\r
69 </sequential>\r
70 </OnDependency>\r
aba23ad9 71\r
72 <if>\r
73 <not>\r
74 <equals arg1="${CC_FAMILY}" arg2="GCC"/>\r
75 </not>\r
76 <then>\r
77 <var name="OBJECTS" value="${OBJECTS} AutoGen.h.obj"/>\r
78 </then>\r
79 </if>\r
1549f516 80 </then>\r
81 </if>\r
88f858a1 82 </sequential>\r
83 </macrodef>\r
84\r
85\r
878ddf1f 86 <!--\r
87 macro definitions for building files with different types\r
88 -->\r
89 <!--\r
90 C Code\r
91 -->\r
5fc17c92 92 <macrodef name="Build_CCode">\r
878ddf1f 93 <attribute name="FILEPATH"/>\r
94 <attribute name="FILENAME"/>\r
95 <attribute name="FILEEXT" default="c"/>\r
5fc17c92 96 \r
878ddf1f 97 <element name="EXTRA.INC" optional="yes"/>\r
98 <element name="EXTRA.ARG" optional="yes"/>\r
5fc17c92 99 \r
878ddf1f 100 <sequential>\r
5fc17c92 101 <var name="FILE_BASENAME" value="@{FILENAME}" />\r
102 <var name="FILE_PATH" value="@{FILEPATH}" />\r
22e0585c 103 <mkdir dir="${DEST_DIR_OUTPUT}/@{FILEPATH}"/>\r
878ddf1f 104\r
105 <if>\r
22e0585c 106 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 107 <then>\r
22e0585c 108 <makedeps DepsFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep">\r
109 <input file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
110 <input file="${DEST_DIR_DEBUG}/AutoGen.h"/>\r
878ddf1f 111 <EXTRA.INC/>\r
112 </makedeps>\r
113 </then>\r
114 </if>\r
115\r
116 <OnDependency>\r
117 <sourcefiles>\r
22e0585c 118 <file ListFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep"/>\r
878ddf1f 119 </sourcefiles>\r
120 <targetfiles>\r
22e0585c 121 <file Name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 122 </targetfiles>\r
123\r
124 <sequential>\r
125 <cc userdefine="on">\r
5fc17c92 126 <command type="CC" cmd="${CC}" workdir="${DEST_DIR_OUTPUT}" family="${CC_FAMILY}"\r
877de749 127 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj" dpath="${CC_DPATH}" \r
128 libpath="${CC_LIBPATH}" include="${CC_INCLUDEPATH}">\r
878ddf1f 129 <EXTRA.INC/>\r
1549f516 130 <argument value="${CC_FLAGS}"/>\r
878ddf1f 131 <EXTRA.ARG/>\r
3fc9d866 132 <fileset casesensitive="on" file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 133 </command>\r
134 </cc>\r
135 </sequential>\r
136 </OnDependency>\r
32a47954 137 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->\r
138 <if>\r
139 <equals arg1="@{FILEPATH}" arg2="." />\r
140 <then>\r
141 <var name="OBJECTS" value="${OBJECTS} @{FILENAME}.obj" />\r
142 </then>\r
143 <else>\r
144 <var name="OBJECTS" value="${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />\r
145 </else>\r
146 </if>\r
878ddf1f 147 </sequential>\r
148 </macrodef>\r
149\r
150\r
151 <macrodef name="Build_AUTOGEN">\r
152 <attribute name="FILEPATH"/>\r
153 <attribute name="FILENAME"/>\r
154 <attribute name="FILEEXT" default="c"/>\r
155\r
156 <element name="EXTRA.INC" optional="yes"/>\r
157 <element name="EXTRA.ARG" optional="yes"/>\r
158\r
159 <sequential>\r
5fc17c92 160 <var name="FILE_BASENAME" value="@{FILENAME}" />\r
161 <var name="FILE_PATH" value="@{FILEPATH}" />\r
22e0585c 162 <mkdir dir="${DEST_DIR_OUTPUT}/@{FILEPATH}"/>\r
878ddf1f 163\r
164 <if>\r
22e0585c 165 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 166 <then>\r
22e0585c 167 <makedeps DepsFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep">\r
168 <input file="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
169 <input file="${DEST_DIR_DEBUG}/AutoGen.h"/>\r
878ddf1f 170 <EXTRA.INC/>\r
171 </makedeps>\r
172 </then>\r
173 </if>\r
174\r
175 <OnDependency>\r
176 <sourcefiles>\r
22e0585c 177 <file ListFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep"/>\r
878ddf1f 178 </sourcefiles>\r
179 <targetfiles>\r
22e0585c 180 <file Name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 181 </targetfiles>\r
182\r
183 <sequential>\r
184 <cc userdefine="on">\r
5fc17c92 185 <command type="CC" cmd="${CC}" workdir="${DEST_DIR_OUTPUT}" family="${CC_FAMILY}"\r
877de749 186 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj" dpath="${CC_DPATH}"\r
187 libpath="${CC_LIBPATH}" include="${CC_INCLUDEPATH}">\r
878ddf1f 188 <EXTRA.INC/>\r
1549f516 189 <argument value="${CC_FLAGS}"/>\r
878ddf1f 190 <EXTRA.ARG/>\r
3fc9d866 191 <fileset casesensitive="on" file="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 192 </command>\r
193 </cc>\r
194 </sequential>\r
195 </OnDependency>\r
32a47954 196 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->\r
197 <if>\r
198 <equals arg1="@{FILEPATH}" arg2="." />\r
199 <then>\r
200 <var name="OBJECTS" value="${OBJECTS} @{FILENAME}.obj" />\r
201 </then>\r
202 <else>\r
203 <var name="OBJECTS" value="${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />\r
204 </else>\r
205 </if>\r
878ddf1f 206 </sequential>\r
207 </macrodef>\r
208\r
5fc17c92 209 <macrodef name="Build_DPX">\r
878ddf1f 210 <attribute name="FILEPATH"/>\r
211 <attribute name="FILENAME"/>\r
212 <attribute name="FILEEXT" default="dxs"/>\r
213\r
214 <element name="EXTRA.INC" optional="yes"/>\r
215 <element name="EXTRA.ARG" optional="yes"/>\r
5fc17c92 216 \r
878ddf1f 217\r
218 <sequential>\r
5fc17c92 219 <var name="FILE_BASENAME" value="@{FILENAME}" />\r
220 <var name="FILE_PATH" value="@{FILEPATH}" />\r
22e0585c 221 <mkdir dir="${DEST_DIR_OUTPUT}/@{FILEPATH}"/>\r
878ddf1f 222\r
223 <OnDependency>\r
224 <sourcefiles>\r
22e0585c 225 <file name="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 226 </sourcefiles>\r
227 <targetfiles>\r
5fc17c92 228 <file name="${DEST_DIR_OUTPUT}/${BASE_NAME}.depex"/>\r
878ddf1f 229 </targetfiles>\r
230\r
231 <sequential>\r
878ddf1f 232 <cc userdefine="on">\r
df569f61 233 <command type="CC" cmd="${CC}" workdir="${DEST_DIR_OUTPUT}/@{FILEPATH}" family="${CC_FAMILY}"\r
877de749 234 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i" dpath="${CC_DPATH}"\r
235 libpath="${CC_LIBPATH}" include="${CC_INCLUDEPATH}">\r
878ddf1f 236 <EXTRA.INC/>\r
237 <argument value="${PP_FLAGS}"/>\r
3fc9d866 238 <fileset casesensitive="on" file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 239 </command>\r
240 </cc>\r
5fc17c92 241 \r
df569f61 242 <gendepex inputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i" outputFile="${DEST_DIR_OUTPUT}/${BASE_NAME}.depex"/>\r
878ddf1f 243 </sequential>\r
244 </OnDependency>\r
245 </sequential>\r
246 </macrodef>\r
5fc17c92 247 \r
248 <macrodef name="Build_ASM">\r
878ddf1f 249 <attribute name="FILEPATH"/>\r
250 <attribute name="FILENAME"/>\r
251 <attribute name="FILEEXT" default="asm"/>\r
252\r
253 <element name="EXTRA.INC" optional="yes"/>\r
254 <element name="EXTRA.ARG" optional="yes"/>\r
5fc17c92 255 \r
256 <!-- Dispath ASM file, there are three type. \r
df569f61 257 asm - Build_Assembly\r
258 S - Build_Gcc_Assembly\r
259 s - Build_Ipf_Assembly -->\r
878ddf1f 260 <sequential>\r
5fc17c92 261 <if>\r
df569f61 262 <equals arg1="@{FILEEXT}" arg2="asm" />\r
5fc17c92 263 <then>\r
264 <Build_Assembly FILEPATH="@{FILEPATH}" FILENAME="@{FILENAME}" FILEEXT="@{FILEEXT}">\r
265 <EXTRA.INC.1><EXTRA.INC /></EXTRA.INC.1>\r
266 <EXTRA.ARG.1><EXTRA.ARG /></EXTRA.ARG.1>\r
267 </Build_Assembly>\r
268 </then>\r
df569f61 269 <elseif>\r
270 <equals arg1="@{FILEEXT}" arg2="S" />\r
271 <then>\r
272 <Build_Gcc_Assembly FILEPATH="@{FILEPATH}" FILENAME="@{FILENAME}" FILEEXT="@{FILEEXT}">\r
273 <EXTRA.INC.1><EXTRA.INC /></EXTRA.INC.1>\r
274 <EXTRA.ARG.1><EXTRA.ARG /></EXTRA.ARG.1>\r
275 </Build_Gcc_Assembly>\r
276 </then>\r
277 </elseif>\r
5fc17c92 278 <elseif>\r
25832ed3 279 <equals arg1="@{FILEEXT}" arg2="s" />\r
5fc17c92 280 <then>\r
281 <Build_IPF_Assembly_Code FILEPATH="@{FILEPATH}" FILENAME="@{FILENAME}" FILEEXT="@{FILEEXT}">\r
282 <EXTRA.INC.1><EXTRA.INC /></EXTRA.INC.1>\r
283 <EXTRA.ARG.1><EXTRA.ARG /></EXTRA.ARG.1>\r
284 </Build_IPF_Assembly_Code>\r
285 </then>\r
286 </elseif>\r
287 </if>\r
878ddf1f 288 </sequential>\r
289 </macrodef>\r
5fc17c92 290 \r
0fd9e137 291 <!--\r
5fc17c92 292 IA32/x64 Assembly\r
0fd9e137 293 -->\r
5fc17c92 294 <macrodef name="Build_Assembly">\r
0fd9e137 295 <attribute name="FILEPATH"/>\r
296 <attribute name="FILENAME"/>\r
297 <attribute name="FILEEXT" default="asm"/>\r
298\r
5fc17c92 299 <element name="EXTRA.INC.1" optional="yes"/>\r
300 <element name="EXTRA.ARG.1" optional="yes"/>\r
0fd9e137 301\r
302 <sequential>\r
5fc17c92 303 <var name="FILE_BASENAME" value="@{FILENAME}" />\r
304 <var name="FILE_PATH" value="@{FILEPATH}" />\r
0fd9e137 305 <mkdir dir="${DEST_DIR_OUTPUT}/@{FILEPATH}"/>\r
306\r
0fd9e137 307 <OnDependency>\r
308 <sourcefiles>\r
5fc17c92 309 <file Name="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
0fd9e137 310 </sourcefiles>\r
311 <targetfiles>\r
312 <file Name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
313 </targetfiles>\r
314\r
315 <sequential>\r
c44794ef 316 <cc userdefine="on">\r
877de749 317 <command type="PP" cmd="${PP}" workdir="${DEST_DIR_OUTPUT}/@{FILEPATH}" family="${PP_FAMILY}" \r
318 dpath="${PP_DPATH}" libpath="${PP_LIBPATH}" include="${PP_INCLUDEPATH}">\r
c44794ef 319 <EXTRA.INC.1/>\r
320 <argument value="${PP_FLAGS}"/>\r
3fc9d866 321 <fileset casesensitive="on" file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
c44794ef 322 </command>\r
323 </cc>\r
324\r
325 <replaceregexp file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"\r
326 match="^(#line +1 +.*@{FILEPATH}/@{FILENAME}\.@{FILEEXT}&quot;).+\1"\r
327 replace=";"\r
328 flags="gs"/>\r
329 <replaceregexp file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"\r
330 match="^(#line .*)$"\r
331 replace="; \1"\r
332 byline="true"/>\r
333 <replaceregexp file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"\r
334 match="([^_a-zA-Z])0x([0-9a-fA-F]+)"\r
335 replace="\10\2h"\r
336 flags="g"\r
337 byline="true"/>\r
0d2001d3 338\r
0fd9e137 339 <cc userdefine="on">\r
5fc17c92 340 <command type="ASM" cmd="${ASM}" workdir="${DEST_DIR_OUTPUT}" family="${ASM_FAMILY}"\r
877de749 341 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj" dpath="${ASM_DPATH}"\r
342 libpath="${ASM_LIBPATH}" include="${ASM_INCLUDEPATH}">\r
5fc17c92 343 <EXTRA.INC.1/>\r
344 \r
0fd9e137 345 <argument value="${ASM_FLAGS}"/>\r
5fc17c92 346 <EXTRA.ARG.1/>\r
347 \r
3fc9d866 348 <fileset casesensitive="on" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"/>\r
75d0c5b1 349 </command>\r
350 </cc>\r
351 </sequential>\r
352 </OnDependency>\r
32a47954 353 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->\r
354 <if>\r
355 <equals arg1="@{FILEPATH}" arg2="." />\r
356 <then>\r
357 <var name="OBJECTS" value="${OBJECTS} @{FILENAME}.obj" />\r
358 </then>\r
359 <else>\r
360 <var name="OBJECTS" value="${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />\r
361 </else>\r
362 </if>\r
75d0c5b1 363 </sequential>\r
df569f61 364 </macrodef>\r
365\r
366 <!--\r
367 Build GCC assembly code\r
368 -->\r
369 <macrodef name="Build_Gcc_Assembly">\r
370 <attribute name="FILEPATH"/>\r
371 <attribute name="FILENAME"/>\r
372 <attribute name="FILEEXT" default="asm"/>\r
373\r
374 <element name="EXTRA.INC.1" optional="yes"/>\r
375 <element name="EXTRA.ARG.1" optional="yes"/>\r
376\r
377 <sequential>\r
378 <var name="FILE_BASENAME" value="@{FILENAME}" />\r
379 <var name="FILE_PATH" value="@{FILEPATH}" />\r
380 <mkdir dir="${DEST_DIR_OUTPUT}/@{FILEPATH}"/>\r
381\r
382 <OnDependency>\r
383 <sourcefiles>\r
384 <file Name="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
385 </sourcefiles>\r
386 <targetfiles>\r
387 <file Name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
388 </targetfiles>\r
389\r
390 <sequential>\r
df569f61 391 <cc userdefine="on">\r
392 <command type="ASM" cmd="${ASM}" workdir="${DEST_DIR_OUTPUT}" family="${ASM_FAMILY}"\r
877de749 393 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj" dpath="${ASM_DPATH}"\r
394 libpath="${ASM_LIBPATH}" include="${ASM_INCLUDEPATH}">\r
df569f61 395 <EXTRA.INC.1/>\r
396 \r
397 <argument value="${ASM_FLAGS}"/>\r
398 <EXTRA.ARG.1/>\r
399 \r
3fc9d866 400 <fileset casesensitive="on" file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
df569f61 401 </command>\r
402 </cc>\r
403 </sequential>\r
404 </OnDependency>\r
32a47954 405 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->\r
406 <if>\r
407 <equals arg1="@{FILEPATH}" arg2="." />\r
408 <then>\r
409 <var name="OBJECTS" value="${OBJECTS} @{FILENAME}.obj" />\r
410 </then>\r
411 <else>\r
412 <var name="OBJECTS" value="${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />\r
413 </else>\r
414 </if>\r
df569f61 415 </sequential>\r
75d0c5b1 416 </macrodef>\r
417\r
878ddf1f 418 <!--\r
419 IPF Assembly\r
420 -->\r
421 <macrodef name="Build_IPF_Assembly_Code">\r
422 <attribute name="FILEPATH"/>\r
423 <attribute name="FILENAME"/>\r
424 <attribute name="FILEEXT" default="s"/>\r
425\r
5fc17c92 426 <element name="EXTRA.INC.1" optional="yes"/>\r
427 <element name="EXTRA.ARG.1" optional="yes"/>\r
878ddf1f 428\r
429 <sequential>\r
22e0585c 430 <mkdir dir="${DEST_DIR_OUTPUT}/@{FILEPATH}"/>\r
878ddf1f 431\r
432 <if>\r
22e0585c 433 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 434 <then>\r
22e0585c 435 <makedeps DepsFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep">\r
436 <input file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
adb6105a 437 <input file="${DEST_DIR_DEBUG}/AutoGen.h"/>\r
5fc17c92 438 <EXTRA.INC.1/>\r
878ddf1f 439 </makedeps>\r
440 </then>\r
441 </if>\r
442\r
443 <OnDependency>\r
444 <sourcefiles>\r
22e0585c 445 <file listfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep"/>\r
878ddf1f 446 </sourcefiles>\r
447 <targetfiles>\r
22e0585c 448 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 449 </targetfiles>\r
450\r
451 <sequential>\r
878ddf1f 452 <cc userdefine="on">\r
877de749 453 <command type="PP" cmd="${APP}" workdir="${DEST_DIR_OUTPUT}/@{FILEPATH}" family="${APP_FAMILY}" \r
454 dpath="${APP_DPATH}" libpath="${APP_LIBPATH}" include="${APP_INCLUDEPATH}">\r
5fc17c92 455 <EXTRA.INC.1/>\r
0b8fc154 456 <argument value="${APP_FLAGS}"/>\r
3fc9d866 457 <fileset casesensitive="on" file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 458 </command>\r
459 </cc>\r
5fc17c92 460 \r
878ddf1f 461 <cc userdefine="on">\r
5fc17c92 462 <command type="ASM" cmd="${ASM}" workdir="${DEST_DIR_OUTPUT}" family="${ASM_FAMILY}"\r
32c8b5a9 463 includepathDelimiter="-I" outputDelimiter="-o" dpath="${ASM_DPATH}"\r
877de749 464 libpath="${ASM_LIBPATH}" include="${ASM_INCLUDEPATH}"\r
5fc17c92 465 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj">\r
466 <EXTRA.INC.1/>\r
878ddf1f 467 <argument value="${ASM_FLAGS}"/>\r
5fc17c92 468 <EXTRA.ARG.1/>\r
3fc9d866 469 <fileset casesensitive="on" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"/>\r
878ddf1f 470 </command>\r
471 </cc>\r
472 </sequential>\r
473 </OnDependency>\r
32a47954 474 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->\r
475 <if>\r
476 <equals arg1="@{FILEPATH}" arg2="." />\r
477 <then>\r
478 <var name="OBJECTS" value="${OBJECTS} @{FILENAME}.obj" />\r
479 </then>\r
480 <else>\r
481 <var name="OBJECTS" value="${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />\r
482 </else>\r
483 </if>\r
878ddf1f 484 </sequential>\r
485 </macrodef>\r
486\r
487\r
488 <macrodef name="Build_IPF_PP_Code">\r
489 <attribute name="FILEPATH"/>\r
490 <attribute name="FILENAME"/>\r
491 <attribute name="FILEEXT" default="i"/>\r
492\r
493 <element name="EXTRA.INC" optional="yes"/>\r
494 <element name="EXTRA.ARG" optional="yes"/>\r
495\r
496 <sequential>\r
22e0585c 497 <mkdir dir="${DEST_DIR_OUTPUT}/@{FILEPATH}"/>\r
5fc17c92 498 \r
878ddf1f 499 <cc userdefine="on">\r
877de749 500 <command type="ASM" includepathDelimiter="-I" dpath="${ASM_DPATH}"\r
501 libpath="${ASM_LIBPATH}" include="${ASM_INCLUDEPATH}">\r
878ddf1f 502 <includepath path="${WORKSPACE_DIR}"/>\r
503 <includepath path="${MODULE_DIR}"/>\r
22e0585c 504 <includepath path="${MODULE_DIR}/${ARCH}"/>\r
878ddf1f 505 <EXTRA.INC/>\r
5fc17c92 506 \r
878ddf1f 507 <argument value="${ASM_FLAGS}"/>\r
508 <EXTRA.ARG/>\r
22e0585c 509 <OutputFile File="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
5fc17c92 510 \r
3fc9d866 511 <fileset casesensitive="on" file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 512 </command>\r
513 </cc>\r
878ddf1f 514 </sequential>\r
515 </macrodef>\r
5fc17c92 516 \r
517 \r
518 <!--\r
519 Library private HashMap map = new HashMap();\r
878ddf1f 520 -->\r
5fc17c92 521 <macrodef name="Build_Library">\r
522 <attribute name="FILENAME" />\r
523 <attribute name="FILEEXT" default="obj"/>\r
524 \r
525 <sequential>\r
526 <var name="FILE_BASENAME" value="@{FILENAME}" />\r
527 <var name="FILE_PATH" value="." />\r
528 <mkdir dir="${BIN_DIR}"/>\r
878ddf1f 529\r
5fc17c92 530 <OnDependency>\r
531 <sourcefiles>\r
32a47954 532 <fileset dir="${DEST_DIR_OUTPUT}" includes="${OBJECTS}" />\r
5fc17c92 533 </sourcefiles>\r
534 <targetfiles>\r
535 <file name="${BIN_DIR}/@{FILENAME}.lib"/>\r
536 </targetfiles>\r
878ddf1f 537\r
5fc17c92 538 <sequential>\r
539 <cc userdefine="on">\r
540 <command type="SLINK" cmd="${SLINK}" family="${SLINK_FAMILY}"\r
877de749 541 outputFile="${BIN_DIR}/@{FILENAME}.lib" dpath="${SLINK_DPATH}"\r
542 libpath="${SLINK_LIBPATH}" include="${SLINK_INCLUDEPATH}">\r
5fc17c92 543 <argument value="${SLINK_FLAGS}"/>\r
878ddf1f 544\r
32a47954 545 <fileset dir="${DEST_DIR_OUTPUT}" includes="${OBJECTS}"/>\r
5fc17c92 546 </command>\r
547 </cc>\r
548 </sequential>\r
549 </OnDependency>\r
878ddf1f 550 </sequential>\r
551 </macrodef>\r
552\r
553 <!--\r
554 Unicode -> .sdb\r
555 -->\r
5fc17c92 556 <macrodef name="Build_UNI">\r
878ddf1f 557 <attribute name="FILEPATH"/>\r
558 <attribute name="FILENAME"/>\r
559 <attribute name="FILEEXT" default="uni"/>\r
560\r
561 <element name="EXTRA.INC" optional="yes"/>\r
562 <element name="EXTRA.ARG" optional="yes"/>\r
563\r
564 <sequential>\r
22e0585c 565 <mkdir dir="${DEST_DIR_OUTPUT}/@{FILEPATH}"/>\r
878ddf1f 566\r
567 <OnDependency>\r
568 <sourcefiles>\r
22e0585c 569 <file name="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 570 </sourcefiles>\r
571 <targetfiles>\r
22e0585c 572 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>\r
878ddf1f 573 </targetfiles>\r
574\r
575 <sequential>\r
576 <strgather commandtype="parse" newdatabase="true">\r
22e0585c 577 <database name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>\r
878ddf1f 578 <EXTRA.INC/>\r
579 <EXTRA.ARG/>\r
22e0585c 580 <inputfile name="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 581 </strgather>\r
582 </sequential>\r
583 </OnDependency>\r
584\r
5fc17c92 585 <var name="SDB_FILES" value="${SDB_FILES}, ${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>\r
878ddf1f 586 </sequential>\r
587 </macrodef>\r
588\r
589 <!--\r
590 .sdb(s) -> .c, .h -> .obj\r
591 -->\r
592 <macrodef name="Build_Unicode_Database">\r
593 <attribute name="FILEPATH"/>\r
594 <attribute name="FILENAME"/>\r
595 <attribute name="FILEEXT" default="sdb"/>\r
596\r
597 <element name="EXTRA.INC" optional="yes"/>\r
598 <element name="EXTRA.ARG" optional="yes"/>\r
599\r
600 <sequential>\r
5fc17c92 601 <var name="FILE_BASENAME" value="@{FILENAME}" />\r
602 <var name="FILE_PATH" value="@{FILEPATH}" />\r
878ddf1f 603 <OnDependency>\r
604 <sourcefiles>\r
605 <file list="${SDB_FILES}"/>\r
606 <file list="${SOURCE_FILES}"/>\r
607 </sourcefiles>\r
608 <targetfiles>\r
22e0585c 609 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>\r
878ddf1f 610 </targetfiles>\r
5fc17c92 611 \r
878ddf1f 612 <sequential>\r
22e0585c 613 <strgather commandtype="scan" outputdatabase="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb" verbose="read">\r
878ddf1f 614 <skipext name=".uni"/>\r
615 <skipext name=".h"/>\r
616 <database list="${SDB_FILES}"/>\r
617 <inputfile name="${SOURCE_FILES}"/>\r
618 </strgather>\r
619 </sequential>\r
620 </OnDependency>\r
621\r
622 <OnDependency>\r
623 <sourcefiles>\r
22e0585c 624 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>\r
878ddf1f 625 </sourcefiles>\r
626 <targetfiles>\r
22e0585c 627 <file name="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}StrDefs.h"/>\r
628 <file name="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.hpk"/>\r
629 <file name="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.c"/>\r
878ddf1f 630 </targetfiles>\r
5fc17c92 631 \r
878ddf1f 632 <sequential>\r
633 <strgather basename="@{FILENAME}Strings" commandtype="dump"\r
22e0585c 634 outputdefines="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}StrDefs.h"\r
635 outputhpk="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.hpk"\r
636 outputstring="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.c">\r
637 <database name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>\r
878ddf1f 638 </strgather>\r
639 </sequential>\r
640 </OnDependency>\r
641\r
642 <OnDependency>\r
643 <sourcefiles>\r
22e0585c 644 <file name="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.c"/>\r
878ddf1f 645 </sourcefiles>\r
646 <targetfiles>\r
22e0585c 647 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Strings.obj"/>\r
878ddf1f 648 </targetfiles>\r
5fc17c92 649 \r
878ddf1f 650 <sequential>\r
651 <cc userdefine="on">\r
5fc17c92 652 <command type="CC" cmd="${CC}" workdir="${DEST_DIR_OUTPUT}" family="${CC_FAMILY}"\r
32c8b5a9 653 includepathDelimiter="-I" dpath="${CC_DPATH}"\r
877de749 654 libpath="${CC_LIBPATH}" include="${CC_INCLUDEPATH}"\r
5fc17c92 655 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Strings.obj">\r
1549f516 656 <argument value="${CC_FLAGS}"/>\r
5fc17c92 657 <EXTRA.INC />\r
3fc9d866 658 <fileset casesensitive="on" file="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.c"/>\r
878ddf1f 659 </command>\r
660 </cc>\r
661 </sequential>\r
662 </OnDependency>\r
4436ffdc 663\r
32a47954 664 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->\r
665 <if>\r
666 <equals arg1="@{FILEPATH}" arg2="." />\r
667 <then>\r
668 <var name="OBJECTS" value="${OBJECTS} @{FILENAME}Strings.obj" />\r
669 </then>\r
670 <else>\r
671 <var name="OBJECTS" value="${OBJECTS} @{FILEPATH}/@{FILENAME}Strings.obj" />\r
672 </else>\r
673 </if>\r
878ddf1f 674 </sequential>\r
675 </macrodef>\r
676\r
677 <!--\r
678 Vfr\r
679 -->\r
5fc17c92 680 <macrodef name="Build_VFR">\r
878ddf1f 681 <attribute name="FILEPATH"/>\r
682 <attribute name="FILENAME"/>\r
683 <attribute name="FILEEXT" default="vfr"/>\r
684\r
685 <element name="EXTRA.INC" optional="yes"/>\r
686 <element name="EXTRA.ARG" optional="yes"/>\r
687\r
688 <sequential>\r
689 <mkdir dir="${DEST_DIR_DEBUG}/@{FILEPATH}"/>\r
690\r
691 <if>\r
22e0585c 692 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 693 <then>\r
22e0585c 694 <makedeps DepsFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep">\r
695 <input file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
adb6105a 696 <input file="${DEST_DIR_DEBUG}/AutoGen.h"/>\r
878ddf1f 697 <EXTRA.INC/>\r
698 </makedeps>\r
699 </then>\r
700 </if>\r
701\r
702 <OnDependency>\r
703 <sourcefiles>\r
22e0585c 704 <file listfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep"/>\r
878ddf1f 705 </sourcefiles>\r
706 <targetfiles>\r
22e0585c 707 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 708 </targetfiles>\r
709\r
710 <sequential>\r
32c8b5a9 711 <vfrcompile createIfrBinFile="on" createListFile="on" outPutDir="${DEST_DIR_DEBUG}/@{FILEPATH}" vfrFile="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}">\r
878ddf1f 712 <EXTRA.INC/>\r
713 </vfrcompile>\r
5fc17c92 714 \r
878ddf1f 715 <cc userdefine="on">\r
5fc17c92 716 <command type="CC" cmd="${CC}" workdir="${DEST_DIR_OUTPUT}" \r
32c8b5a9 717 includepathDelimiter="-I" family="${CC_FAMILY}" dpath="${CC_DPATH}"\r
877de749 718 libpath="${CC_LIBPATH}" include="${CC_INCLUDEPATH}"\r
5fc17c92 719 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj" >\r
1549f516 720 <argument value="${CC_FLAGS}"/>\r
5fc17c92 721 <EXTRA.INC/>\r
878ddf1f 722 <EXTRA.ARG/>\r
3fc9d866 723 <fileset casesensitive="on" file="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.c"/>\r
878ddf1f 724 </command>\r
725 </cc>\r
878ddf1f 726 </sequential>\r
727 </OnDependency>\r
32a47954 728 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->\r
729 <if>\r
730 <equals arg1="@{FILEPATH}" arg2="." />\r
731 <then>\r
732 <var name="OBJECTS" value="${OBJECTS} @{FILENAME}.obj" />\r
733 </then>\r
734 <else>\r
735 <var name="OBJECTS" value="${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />\r
736 </else>\r
737 </if>\r
878ddf1f 738 </sequential>\r
739 </macrodef>\r
740\r
a99a79e4 741 <!--\r
742 DUMMY\r
743 -->\r
744 <macrodef name="Build_DUMMY">\r
745 <attribute name="FILEPATH"/>\r
746 <attribute name="FILENAME"/>\r
747 <attribute name="FILEEXT"/>\r
748\r
749 <element name="EXTRA.INC" optional="yes"/>\r
750 <element name="EXTRA.ARG" optional="yes"/>\r
751\r
752 <sequential>\r
1a0d7262 753 <echo message="Ignoring ${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" level="info" />\r
a99a79e4 754 </sequential>\r
755 </macrodef>\r
756\r
878ddf1f 757<!--############################################################################\r
758 Build Sections\r
759#############################################################################-->\r
760 <!--\r
761 DLL\r
762 -->\r
763 <macrodef name="GenDll">\r
764 <attribute name="FILEPATH"/>\r
765 <attribute name="FILENAME"/>\r
766 <attribute name="FILEEXT"/>\r
767\r
768 <element name="LIB.ARG" optional="yes"/>\r
769 <element name="LINK.ARG" optional="yes"/>\r
770\r
771 <sequential>\r
5fc17c92 772 <var name="FILE_BASENAME" value="@{FILENAME}" />\r
773 <var name="FILE_PATH" value="@{FILEPATH}" />\r
878ddf1f 774 <OnDependency>\r
775 <sourcefiles>\r
878ddf1f 776 <file list="${LIBS}"/>\r
32a47954 777 <fileset dir="${DEST_DIR_OUTPUT}" includes="${OBJECTS}" />\r
878ddf1f 778 </sourcefiles>\r
779 <targetfiles>\r
22e0585c 780 <file name="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.dll"/>\r
878ddf1f 781 </targetfiles>\r
782\r
783 <sequential>\r
8b41e66e 784 <cc userdefine="on">\r
32c8b5a9 785 <command type="SLINK" cmd="${SLINK}" family="${SLINK_FAMILY}" dpath="${SLINK_DPATH}"\r
877de749 786 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Local.lib"\r
787 libpath="${SLINKLIBPATH}" include="${SLINK_INCLUDEPATH}">\r
5fc17c92 788 <argument value="${SLINK_FLAGS}"/>\r
789\r
32a47954 790 <fileset dir="${DEST_DIR_OUTPUT}" includes="${OBJECTS}"/>\r
8b41e66e 791 </command>\r
792 </cc>\r
878ddf1f 793 <cc userdefine="on">\r
5fc17c92 794 <command type="DLINK" cmd="${DLINK}" family="${DLINK_FAMILY}"\r
877de749 795 outputFile="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.dll" dpath="${DLINK_DPATH}" \r
796 libpath="${DLINK_LIBPATH}" include="${DLINK_INCLUDEPATH}">\r
5fc17c92 797 <argument value="${DLINK_FLAGS}"/>\r
63062e1e 798 <libset libs="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Local.lib ${LIBS} ${DLINK_SPATH}"/>\r
878ddf1f 799 <LINK.ARG/>\r
878ddf1f 800 </command>\r
801 </cc>\r
802 </sequential>\r
803 </OnDependency>\r
804 </sequential>\r
805 </macrodef>\r
806\r
807 <!--\r
808 EFI\r
809 -->\r
810 <macrodef name="GenEfi">\r
811 <attribute name="FILEPATH"/>\r
812 <attribute name="FILENAME"/>\r
813 <attribute name="FILEEXT" default="dll"/>\r
814\r
815 <sequential>\r
816 <OnDependency>\r
817 <sourcefiles>\r
22e0585c 818 <file name="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 819 </sourcefiles>\r
820 <targetfiles>\r
22e0585c 821 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>\r
878ddf1f 822 </targetfiles>\r
823\r
824 <sequential>\r
5fc17c92 825 <fwimage componentType="${MODULE_TYPE}" outImage="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" \r
22e0585c 826 peImage="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" time="0"/>\r
878ddf1f 827 </sequential>\r
828 </OnDependency>\r
829 </sequential>\r
830 </macrodef>\r
831\r
832<!--\r
833 EFI_SECTION_FREEFORM_SUBTYPE_GUID\r
834 EFI_SECTION_VERSION\r
835 EFI_SECTION_USER_INTERFACE\r
836 EFI_SECTION_DXE_DEPEX\r
837 EFI_SECTION_PEI_DEPEX\r
838 EFI_SECTION_PE32\r
839 EFI_SECTION_PIC\r
840 EFI_SECTION_TE\r
841 EFI_SECTION_RAW\r
842 EFI_SECTION_COMPRESSION\r
843 EFI_SECTION_GUID_DEFINED\r
844 EFI_SECTION_COMPATIBILITY16\r
845 EFI_SECTION_FIRMWARE_VOLUME_IMAGE\r
846 -->\r
847 <!--\r
848 EFI_SECTION_PE32\r
849 -->\r
46dde08c
LG
850\r
851 <macrodef name="EFI_SECTION_TE">\r
852 <attribute name="FILEPATH"/>\r
853 <attribute name="FILENAME"/>\r
854 <attribute name="FILEEXT" default="" />\r
855\r
856 <element name="PRE.PROCESS" optional="yes"/>\r
857 <element name="POST.PROCESS" optional="yes"/>\r
858\r
859 <sequential>\r
860 <PRE.PROCESS/>\r
861 <if>\r
862 <not>\r
863 <equals arg1="${LIBS}" arg2=""/>\r
864 </not>\r
865\r
866 <then>\r
867 <GenDll FILEPATH="." FILENAME="@{FILENAME}" FILEEXT="">\r
868 <LIB.ARG></LIB.ARG>\r
869 <LINK.ARG></LINK.ARG>\r
870 </GenDll>\r
871\r
872 <GenEfi FILEPATH="." FILENAME="@{FILENAME}" FILEEXT="dll"/>\r
873 </then>\r
874 </if>\r
875\r
876 <OnDependency>\r
877 <sourcefiles>\r
878 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>\r
879 </sourcefiles>\r
880 <targetfiles>\r
881 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.tes"/>\r
882 </targetfiles>\r
883\r
884 <sequential>\r
885 <copy file="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile="${BIN_DIR}/@{FILENAME}.efi" />\r
886 <copy file="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile="${DEST_DIR_DEBUG}/@{FILENAME}.efi" /> \r
887 <genteimage Dump="false" Verbose="false" OutputDir="" OutputFile="${DEST_DIR_OUTPUT}/@{FILENAME}.te" InputFile="${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>\r
46dde08c
LG
888 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.te" \r
889 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.tes" \r
890 sectiontype="EFI_SECTION_TE"/>\r
891 <POST.PROCESS/>\r
892 </sequential>\r
893 </OnDependency>\r
894 </sequential>\r
895 </macrodef>\r
896\r
878ddf1f 897 <macrodef name="EFI_SECTION_PE32">\r
898 <attribute name="FILEPATH"/>\r
899 <attribute name="FILENAME"/>\r
900 <attribute name="FILEEXT" default="" />\r
901\r
902 <element name="PRE.PROCESS" optional="yes"/>\r
903 <element name="POST.PROCESS" optional="yes"/>\r
904\r
905 <sequential>\r
906 <PRE.PROCESS/>\r
878ddf1f 907 <if>\r
908 <not>\r
5fc17c92 909 <!-- TBD ${OBJECTS} -->\r
910 <equals arg1="${LIBS}" arg2=""/>\r
878ddf1f 911 </not>\r
912\r
913 <then>\r
914 <GenDll FILEPATH="." FILENAME="@{FILENAME}" FILEEXT="">\r
915 <LIB.ARG></LIB.ARG>\r
916 <LINK.ARG></LINK.ARG>\r
917 </GenDll>\r
0fd9e137 918\r
878ddf1f 919 <GenEfi FILEPATH="." FILENAME="@{FILENAME}" FILEEXT="dll"/>\r
920 </then>\r
921 </if>\r
5fc17c92 922 \r
878ddf1f 923 <OnDependency>\r
924 <sourcefiles>\r
22e0585c 925 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>\r
878ddf1f 926 </sourcefiles>\r
927 <targetfiles>\r
22e0585c 928 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.pe32"/>\r
878ddf1f 929 </targetfiles>\r
930\r
931 <sequential>\r
22e0585c 932 <copy file="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile="${BIN_DIR}/@{FILENAME}.efi" />\r
c084fb6e 933 <copy file="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile="${DEST_DIR_DEBUG}/@{FILENAME}.efi" />\r
5fc17c92 934 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" \r
935 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.pe32" \r
878ddf1f 936 sectiontype="EFI_SECTION_PE32"/>\r
5fc17c92 937 \r
878ddf1f 938 <POST.PROCESS/>\r
939 </sequential>\r
940 </OnDependency>\r
941 </sequential>\r
942 </macrodef>\r
943\r
944 <!--\r
945 EFI_SECTION_VERSION\r
946 -->\r
947 <macrodef name="EFI_SECTION_VERSION">\r
948 <attribute name="FILEPATH"/>\r
949 <attribute name="FILENAME"/>\r
950 <attribute name="FILEEXT" default="" />\r
951 <attribute name="VERSION" default="0000"/>\r
952\r
953 <element name="PRE.PROCESS" optional="yes"/>\r
954 <element name="POST.PROCESS" optional="yes"/>\r
955\r
956 <sequential>\r
957 <if>\r
958 <not>\r
22e0585c 959 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ver"/>\r
878ddf1f 960 </not>\r
961\r
962 <then>\r
963 <PRE.PROCESS/>\r
5fc17c92 964 <gensection outputfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ver" \r
878ddf1f 965 versionnum="@{VERSION}"\r
966 sectiontype="EFI_SECTION_VERSION"/>\r
967 <POST.PROCESS/>\r
968 </then>\r
969 </if>\r
970 </sequential>\r
971 </macrodef>\r
972\r
973 <!--\r
974 EFI_SECTION_USER_INTERFACE\r
975 -->\r
976 <macrodef name="EFI_SECTION_USER_INTERFACE">\r
977 <attribute name="FILEPATH"/>\r
978 <attribute name="FILENAME"/>\r
979 <attribute name="FILEEXT" default="" />\r
980 <attribute name="UI" default="${BASE_NAME}"/>\r
981\r
982 <element name="PRE.PROCESS" optional="yes"/>\r
983 <element name="POST.PROCESS" optional="yes"/>\r
984\r
985 <sequential>\r
986 <if>\r
987 <not>\r
22e0585c 988 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ui"/>\r
878ddf1f 989 </not>\r
990\r
991 <then>\r
992 <PRE.PROCESS/>\r
993 <gensection interfacestring="@{UI}"\r
5fc17c92 994 outputfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ui" \r
878ddf1f 995 sectiontype="EFI_SECTION_USER_INTERFACE"/>\r
996 <POST.PROCESS/>\r
997 </then>\r
998 </if>\r
999 </sequential>\r
1000 </macrodef>\r
1001\r
878ddf1f 1002 <!--\r
1003 EFI_SECTION_DXE_DEPEX\r
1004 -->\r
1005 <macrodef name="EFI_SECTION_DXE_DEPEX">\r
1006 <attribute name="FILEPATH"/>\r
1007 <attribute name="FILENAME"/>\r
1008 <attribute name="FILEEXT" default="dxs"/>\r
1009\r
1010 <element name="PRE.PROCESS" optional="yes"/>\r
1011 <element name="POST.PROCESS" optional="yes"/>\r
1012\r
1013 <sequential>\r
1014 <PRE.PROCESS/>\r
1015\r
1016 <if>\r
5fc17c92 1017 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>\r
878ddf1f 1018 <then>\r
1019 <OnDependency>\r
1020 <sourcefiles>\r
5fc17c92 1021 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>\r
878ddf1f 1022 </sourcefiles>\r
1023 <targetfiles>\r
22e0585c 1024 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1025 </targetfiles>\r
1026 <sequential>\r
5fc17c92 1027 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.depex" \r
1028 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx" \r
878ddf1f 1029 sectiontype="EFI_SECTION_DXE_DEPEX"/>\r
1030 </sequential>\r
1031 </OnDependency>\r
1032 </then>\r
1033 <else>\r
1034 <if>\r
1035 <not>\r
22e0585c 1036 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1037 </not>\r
1038 <then>\r
22e0585c 1039 <touch file="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1040 </then>\r
1041 </if>\r
1042 </else>\r
1043 </if>\r
1044\r
1045 <POST.PROCESS/>\r
1046 </sequential>\r
1047 </macrodef>\r
1048\r
1049 <!--\r
1050 EFI_SECTION_PEI_DEPEX\r
1051 -->\r
1052 <macrodef name="EFI_SECTION_PEI_DEPEX">\r
1053 <attribute name="FILEPATH"/>\r
1054 <attribute name="FILENAME"/>\r
1055 <attribute name="FILEEXT" default="dxs"/>\r
1056\r
1057 <element name="PRE.PROCESS" optional="yes"/>\r
1058 <element name="POST.PROCESS" optional="yes"/>\r
1059 <sequential>\r
1060 <PRE.PROCESS/>\r
1061 <if>\r
5fc17c92 1062 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>\r
878ddf1f 1063 <then>\r
1064 <OnDependency>\r
1065 <sourcefiles>\r
5fc17c92 1066 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>\r
878ddf1f 1067 </sourcefiles>\r
1068 <targetfiles>\r
22e0585c 1069 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1070 </targetfiles>\r
1071\r
1072 <sequential>\r
5fc17c92 1073 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.depex" \r
1074 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx" \r
878ddf1f 1075 sectiontype="EFI_SECTION_PEI_DEPEX"/>\r
1076 </sequential>\r
1077 </OnDependency>\r
5fc17c92 1078 \r
878ddf1f 1079 </then>\r
1080 <else>\r
1081 <if>\r
1082 <not>\r
22e0585c 1083 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1084 </not>\r
1085 <then>\r
22e0585c 1086 <touch file="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1087 </then>\r
1088 </if>\r
1089 </else>\r
1090 </if>\r
1091 <POST.PROCESS/>\r
1092 </sequential>\r
1093 </macrodef>\r
1094\r
878ddf1f 1095\r
1096 <!--\r
1097 EFI_SECTION_RAW\r
1098 -->\r
1099 <macrodef name="EFI_SECTION_RAW">\r
1100 <attribute name="FILEPATH"/>\r
1101 <attribute name="FILENAME"/>\r
1102 <attribute name="FILEEXT" default="bin"/>\r
1103\r
1104 <element name="PRE.PROCESS" optional="yes"/>\r
1105 <element name="POST.PROCESS" optional="yes"/>\r
1106\r
1107 <sequential>\r
1108 <OnDependency>\r
1109 <sourcefiles>\r
22e0585c 1110 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 1111 </sourcefiles>\r
1112 <targetfiles>\r
22e0585c 1113 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.sec"/>\r
878ddf1f 1114 </targetfiles>\r
1115\r
1116 <sequential>\r
1117 <PRE.PROCESS/>\r
5fc17c92 1118 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.@{FILEEXT}" \r
1119 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.sec" \r
878ddf1f 1120 sectiontype="EFI_SECTION_RAW"/>\r
1121 <POST.PROCESS/>\r
1122 </sequential>\r
1123 </OnDependency>\r
1124 </sequential>\r
1125 </macrodef>\r
1126\r
878ddf1f 1127 <!--\r
1128 EFI_SECTION_FIRMWARE_VOLUME_IMAGE\r
1129 -->\r
1130 <macrodef name="EFI_SECTION_FIRMWARE_VOLUME_IMAGE">\r
1131 <attribute name="FILEPATH"/>\r
1132 <attribute name="FILENAME"/>\r
1133 <attribute name="FILEEXT" default="fv"/>\r
1134\r
1135 <element name="PRE.PROCESS" optional="yes"/>\r
1136 <element name="POST.PROCESS" optional="yes"/>\r
1137\r
1138 <sequential>\r
1139 <OnDependency>\r
1140 <sourcefiles>\r
22e0585c 1141 <file name="${FV_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 1142 </sourcefiles>\r
1143 <targetfiles>\r
22e0585c 1144 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}fv.sec"/>\r
878ddf1f 1145 </targetfiles>\r
1146\r
1147 <sequential>\r
1148 <PRE.PROCESS/>\r
5fc17c92 1149 \r
1150 <copy file="${FV_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
1151 tofile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
878ddf1f 1152 overwrite="true"/>\r
5fc17c92 1153 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
1154 outputfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}fv.sec" \r
878ddf1f 1155 sectiontype="EFI_SECTION_FIRMWARE_VOLUME_IMAGE"/>\r
5fc17c92 1156 \r
878ddf1f 1157 <POST.PROCESS/>\r
1158 </sequential>\r
1159 </OnDependency>\r
1160 </sequential>\r
1161 </macrodef>\r
1162\r
1163 <!--\r
1164 Binary\r
1165 -->\r
1166 <macrodef name="Build_Binary">\r
1167 <attribute name="FILEPATH"/>\r
1168 <attribute name="FILENAME"/>\r
1169 <attribute name="FILEEXT" default="bin"/>\r
1170\r
1171 <element name="EXTRA.INC" optional="yes"/>\r
1172 <element name="EXTRA.ARG" optional="yes"/>\r
1173\r
1174 <sequential>\r
5fc17c92 1175 <copy file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
22e0585c 1176 tofile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.bin"/>\r
878ddf1f 1177 </sequential>\r
1178 </macrodef>\r
d6123759 1179 \r
473f57d4 1180 <!--\r
1181 Microcode\r
1182 -->\r
1183 <macrodef name="Build_MICROCODE">\r
1184 <attribute name="FILEPATH"/>\r
1185 <attribute name="FILENAME"/>\r
1186 <attribute name="FILEEXT" default="TXT"/>\r
1187\r
1188 <element name="EXTRA.INC" optional="yes"/>\r
1189 <element name="EXTRA.ARG" optional="yes"/>\r
1190\r
1191 <sequential>\r
50017606 1192 <mkdir dir="${TARGET_DIR}/Microcode"/>\r
1193 <flashmap MCIFile="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" MCOFILE="${TARGET_DIR}/Microcode/@{FILENAME}.bin"/>\r
473f57d4 1194 </sequential>\r
1195 </macrodef> \r
878ddf1f 1196\r
1197 <!--\r
1198 Graphics (bmp, ...)\r
1199 -->\r
d6123759 1200 <macrodef name="Build_BMP">\r
878ddf1f 1201 <attribute name="FILEPATH"/>\r
473f57d4 1202 <attribute name="FILENAME"/> \r
878ddf1f 1203 <attribute name="FILEEXT" default="bmp"/>\r
1204\r
1205 <element name="EXTRA.INC" optional="yes"/>\r
1206 <element name="EXTRA.ARG" optional="yes"/>\r
1207\r
1208 <sequential>\r
5fc17c92 1209 <mkdir dir="${MODULE_DIR}/@{FILEPATH}" /> \r
1210 <copy file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
22e0585c 1211 tofile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.bin"/>\r
878ddf1f 1212 </sequential>\r
5fc17c92 1213 </macrodef> \r
d6123759 1214\r
1215 <!--\r
1216 build EFI file\r
1217 -->\r
878ddf1f 1218 <macrodef name="Build_EFI">\r
1219 <attribute name="FILEPATH"/>\r
1220 <attribute name="FILENAME"/>\r
1221 <attribute name="FILEEXT" default="efi"/>\r
1222\r
1223 <element name="EXTRA.INC" optional="yes"/>\r
1224 <element name="EXTRA.ARG" optional="yes"/>\r
1225\r
1226 <sequential>\r
5fc17c92 1227 <mkdir dir="${MODULE_DIR}/@{FILEPATH}" /> \r
1228 <copy file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
22e0585c 1229 tofile="${DEST_DIR_OUTPUT}/${BASE_NAME}.efi"/>\r
878ddf1f 1230 </sequential>\r
1231 </macrodef>\r
1232</project>\r