Adding tools for IPF development.
[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
20480ea1 645 <file ListFile="${DEST_DIR_OUTPUT}/AutoGen.h.dep"/>\r
878ddf1f 646 </sourcefiles>\r
647 <targetfiles>\r
22e0585c 648 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Strings.obj"/>\r
878ddf1f 649 </targetfiles>\r
5fc17c92 650 \r
878ddf1f 651 <sequential>\r
652 <cc userdefine="on">\r
5fc17c92 653 <command type="CC" cmd="${CC}" workdir="${DEST_DIR_OUTPUT}" family="${CC_FAMILY}"\r
32c8b5a9 654 includepathDelimiter="-I" dpath="${CC_DPATH}"\r
877de749 655 libpath="${CC_LIBPATH}" include="${CC_INCLUDEPATH}"\r
5fc17c92 656 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Strings.obj">\r
1549f516 657 <argument value="${CC_FLAGS}"/>\r
5fc17c92 658 <EXTRA.INC />\r
3fc9d866 659 <fileset casesensitive="on" file="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.c"/>\r
878ddf1f 660 </command>\r
661 </cc>\r
662 </sequential>\r
663 </OnDependency>\r
4436ffdc 664\r
32a47954 665 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->\r
666 <if>\r
667 <equals arg1="@{FILEPATH}" arg2="." />\r
668 <then>\r
669 <var name="OBJECTS" value="${OBJECTS} @{FILENAME}Strings.obj" />\r
670 </then>\r
671 <else>\r
672 <var name="OBJECTS" value="${OBJECTS} @{FILEPATH}/@{FILENAME}Strings.obj" />\r
673 </else>\r
674 </if>\r
878ddf1f 675 </sequential>\r
676 </macrodef>\r
677\r
678 <!--\r
679 Vfr\r
680 -->\r
5fc17c92 681 <macrodef name="Build_VFR">\r
878ddf1f 682 <attribute name="FILEPATH"/>\r
683 <attribute name="FILENAME"/>\r
684 <attribute name="FILEEXT" default="vfr"/>\r
685\r
686 <element name="EXTRA.INC" optional="yes"/>\r
687 <element name="EXTRA.ARG" optional="yes"/>\r
688\r
689 <sequential>\r
690 <mkdir dir="${DEST_DIR_DEBUG}/@{FILEPATH}"/>\r
691\r
692 <if>\r
22e0585c 693 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 694 <then>\r
22e0585c 695 <makedeps DepsFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep">\r
696 <input file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
adb6105a 697 <input file="${DEST_DIR_DEBUG}/AutoGen.h"/>\r
878ddf1f 698 <EXTRA.INC/>\r
699 </makedeps>\r
700 </then>\r
701 </if>\r
702\r
703 <OnDependency>\r
704 <sourcefiles>\r
22e0585c 705 <file listfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep"/>\r
878ddf1f 706 </sourcefiles>\r
707 <targetfiles>\r
22e0585c 708 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>\r
878ddf1f 709 </targetfiles>\r
710\r
711 <sequential>\r
32c8b5a9 712 <vfrcompile createIfrBinFile="on" createListFile="on" outPutDir="${DEST_DIR_DEBUG}/@{FILEPATH}" vfrFile="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}">\r
878ddf1f 713 <EXTRA.INC/>\r
714 </vfrcompile>\r
5fc17c92 715 \r
878ddf1f 716 <cc userdefine="on">\r
5fc17c92 717 <command type="CC" cmd="${CC}" workdir="${DEST_DIR_OUTPUT}" \r
32c8b5a9 718 includepathDelimiter="-I" family="${CC_FAMILY}" dpath="${CC_DPATH}"\r
877de749 719 libpath="${CC_LIBPATH}" include="${CC_INCLUDEPATH}"\r
5fc17c92 720 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj" >\r
1549f516 721 <argument value="${CC_FLAGS}"/>\r
5fc17c92 722 <EXTRA.INC/>\r
878ddf1f 723 <EXTRA.ARG/>\r
3fc9d866 724 <fileset casesensitive="on" file="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.c"/>\r
878ddf1f 725 </command>\r
726 </cc>\r
878ddf1f 727 </sequential>\r
728 </OnDependency>\r
32a47954 729 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->\r
730 <if>\r
731 <equals arg1="@{FILEPATH}" arg2="." />\r
732 <then>\r
733 <var name="OBJECTS" value="${OBJECTS} @{FILENAME}.obj" />\r
734 </then>\r
735 <else>\r
736 <var name="OBJECTS" value="${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />\r
737 </else>\r
738 </if>\r
878ddf1f 739 </sequential>\r
740 </macrodef>\r
741\r
706c2ad4 742 <!--\r
743 Build the real mode ASM file\r
744 -->\r
745 <macrodef name="Build_RealAsm">\r
746 <attribute name="FILEPATH"/>\r
747 <attribute name="FILENAME"/>\r
748 <attribute name="FILEEXT" default="asm"/>\r
749\r
750 <element name="EXTRA.INC" optional="yes"/>\r
751 <element name="EXTRA.ARG" optional="yes"/>\r
752 \r
753 <sequential>\r
754 <!-- Lack Dependency Check -->\r
755 <exec dir="${DEST_DIR_OUTPUT}" executable="${ASM}" failonerror="true">\r
756 <arg line="/nologo /omf ${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT} /Bl${ASMLINK} ${ASMLINK_FLAGS}"/>\r
757 </exec>\r
758 <concat destfile="${DEST_DIR_OUTPUT}/@{FILENAME}.cat" binary="yes">\r
759 <filelist dir="${MODULE_DIR}" files="Blank2.pad"/>\r
760 <filelist dir="${DEST_DIR_OUTPUT}" files="@{FILENAME}.com"/>\r
761 </concat>\r
762 </sequential>\r
763 </macrodef>\r
764 \r
a99a79e4 765 <!--\r
766 DUMMY\r
767 -->\r
768 <macrodef name="Build_DUMMY">\r
769 <attribute name="FILEPATH"/>\r
770 <attribute name="FILENAME"/>\r
771 <attribute name="FILEEXT"/>\r
772\r
773 <element name="EXTRA.INC" optional="yes"/>\r
774 <element name="EXTRA.ARG" optional="yes"/>\r
775\r
776 <sequential>\r
1a0d7262 777 <echo message="Ignoring ${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" level="info" />\r
a99a79e4 778 </sequential>\r
779 </macrodef>\r
780\r
878ddf1f 781<!--############################################################################\r
782 Build Sections\r
783#############################################################################-->\r
784 <!--\r
785 DLL\r
786 -->\r
787 <macrodef name="GenDll">\r
788 <attribute name="FILEPATH"/>\r
789 <attribute name="FILENAME"/>\r
790 <attribute name="FILEEXT"/>\r
791\r
792 <element name="LIB.ARG" optional="yes"/>\r
793 <element name="LINK.ARG" optional="yes"/>\r
794\r
795 <sequential>\r
5fc17c92 796 <var name="FILE_BASENAME" value="@{FILENAME}" />\r
797 <var name="FILE_PATH" value="@{FILEPATH}" />\r
878ddf1f 798 <OnDependency>\r
799 <sourcefiles>\r
878ddf1f 800 <file list="${LIBS}"/>\r
32a47954 801 <fileset dir="${DEST_DIR_OUTPUT}" includes="${OBJECTS}" />\r
878ddf1f 802 </sourcefiles>\r
803 <targetfiles>\r
22e0585c 804 <file name="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.dll"/>\r
878ddf1f 805 </targetfiles>\r
806\r
807 <sequential>\r
8b41e66e 808 <cc userdefine="on">\r
32c8b5a9 809 <command type="SLINK" cmd="${SLINK}" family="${SLINK_FAMILY}" dpath="${SLINK_DPATH}"\r
877de749 810 outputFile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Local.lib"\r
811 libpath="${SLINKLIBPATH}" include="${SLINK_INCLUDEPATH}">\r
5fc17c92 812 <argument value="${SLINK_FLAGS}"/>\r
813\r
32a47954 814 <fileset dir="${DEST_DIR_OUTPUT}" includes="${OBJECTS}"/>\r
8b41e66e 815 </command>\r
816 </cc>\r
878ddf1f 817 <cc userdefine="on">\r
5fc17c92 818 <command type="DLINK" cmd="${DLINK}" family="${DLINK_FAMILY}"\r
877de749 819 outputFile="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.dll" dpath="${DLINK_DPATH}" \r
820 libpath="${DLINK_LIBPATH}" include="${DLINK_INCLUDEPATH}">\r
5fc17c92 821 <argument value="${DLINK_FLAGS}"/>\r
63062e1e 822 <libset libs="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Local.lib ${LIBS} ${DLINK_SPATH}"/>\r
878ddf1f 823 <LINK.ARG/>\r
878ddf1f 824 </command>\r
825 </cc>\r
826 </sequential>\r
827 </OnDependency>\r
828 </sequential>\r
829 </macrodef>\r
830\r
831 <!--\r
832 EFI\r
833 -->\r
834 <macrodef name="GenEfi">\r
835 <attribute name="FILEPATH"/>\r
836 <attribute name="FILENAME"/>\r
837 <attribute name="FILEEXT" default="dll"/>\r
838\r
839 <sequential>\r
840 <OnDependency>\r
841 <sourcefiles>\r
22e0585c 842 <file name="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 843 </sourcefiles>\r
844 <targetfiles>\r
22e0585c 845 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>\r
878ddf1f 846 </targetfiles>\r
847\r
848 <sequential>\r
5fc17c92 849 <fwimage componentType="${MODULE_TYPE}" outImage="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" \r
22e0585c 850 peImage="${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" time="0"/>\r
878ddf1f 851 </sequential>\r
852 </OnDependency>\r
853 </sequential>\r
854 </macrodef>\r
855\r
856<!--\r
857 EFI_SECTION_FREEFORM_SUBTYPE_GUID\r
858 EFI_SECTION_VERSION\r
859 EFI_SECTION_USER_INTERFACE\r
860 EFI_SECTION_DXE_DEPEX\r
861 EFI_SECTION_PEI_DEPEX\r
862 EFI_SECTION_PE32\r
863 EFI_SECTION_PIC\r
864 EFI_SECTION_TE\r
865 EFI_SECTION_RAW\r
866 EFI_SECTION_COMPRESSION\r
867 EFI_SECTION_GUID_DEFINED\r
868 EFI_SECTION_COMPATIBILITY16\r
869 EFI_SECTION_FIRMWARE_VOLUME_IMAGE\r
870 -->\r
871 <!--\r
872 EFI_SECTION_PE32\r
873 -->\r
46dde08c
LG
874\r
875 <macrodef name="EFI_SECTION_TE">\r
876 <attribute name="FILEPATH"/>\r
877 <attribute name="FILENAME"/>\r
878 <attribute name="FILEEXT" default="" />\r
879\r
880 <element name="PRE.PROCESS" optional="yes"/>\r
881 <element name="POST.PROCESS" optional="yes"/>\r
882\r
883 <sequential>\r
884 <PRE.PROCESS/>\r
885 <if>\r
886 <not>\r
887 <equals arg1="${LIBS}" arg2=""/>\r
888 </not>\r
889\r
890 <then>\r
891 <GenDll FILEPATH="." FILENAME="@{FILENAME}" FILEEXT="">\r
892 <LIB.ARG></LIB.ARG>\r
893 <LINK.ARG></LINK.ARG>\r
894 </GenDll>\r
895\r
896 <GenEfi FILEPATH="." FILENAME="@{FILENAME}" FILEEXT="dll"/>\r
897 </then>\r
898 </if>\r
899\r
900 <OnDependency>\r
901 <sourcefiles>\r
902 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>\r
903 </sourcefiles>\r
904 <targetfiles>\r
905 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.tes"/>\r
906 </targetfiles>\r
907\r
908 <sequential>\r
909 <copy file="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile="${BIN_DIR}/@{FILENAME}.efi" />\r
910 <copy file="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile="${DEST_DIR_DEBUG}/@{FILENAME}.efi" /> \r
911 <genteimage Dump="false" Verbose="false" OutputDir="" OutputFile="${DEST_DIR_OUTPUT}/@{FILENAME}.te" InputFile="${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>\r
46dde08c
LG
912 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.te" \r
913 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.tes" \r
914 sectiontype="EFI_SECTION_TE"/>\r
915 <POST.PROCESS/>\r
916 </sequential>\r
917 </OnDependency>\r
918 </sequential>\r
919 </macrodef>\r
920\r
878ddf1f 921 <macrodef name="EFI_SECTION_PE32">\r
922 <attribute name="FILEPATH"/>\r
923 <attribute name="FILENAME"/>\r
924 <attribute name="FILEEXT" default="" />\r
925\r
926 <element name="PRE.PROCESS" optional="yes"/>\r
927 <element name="POST.PROCESS" optional="yes"/>\r
928\r
929 <sequential>\r
930 <PRE.PROCESS/>\r
878ddf1f 931 <if>\r
932 <not>\r
5fc17c92 933 <!-- TBD ${OBJECTS} -->\r
934 <equals arg1="${LIBS}" arg2=""/>\r
878ddf1f 935 </not>\r
936\r
937 <then>\r
938 <GenDll FILEPATH="." FILENAME="@{FILENAME}" FILEEXT="">\r
939 <LIB.ARG></LIB.ARG>\r
940 <LINK.ARG></LINK.ARG>\r
941 </GenDll>\r
0fd9e137 942\r
878ddf1f 943 <GenEfi FILEPATH="." FILENAME="@{FILENAME}" FILEEXT="dll"/>\r
944 </then>\r
945 </if>\r
5fc17c92 946 \r
878ddf1f 947 <OnDependency>\r
948 <sourcefiles>\r
22e0585c 949 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>\r
878ddf1f 950 </sourcefiles>\r
951 <targetfiles>\r
22e0585c 952 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.pe32"/>\r
878ddf1f 953 </targetfiles>\r
954\r
955 <sequential>\r
22e0585c 956 <copy file="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile="${BIN_DIR}/@{FILENAME}.efi" />\r
c084fb6e 957 <copy file="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile="${DEST_DIR_DEBUG}/@{FILENAME}.efi" />\r
5fc17c92 958 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.efi" \r
959 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.pe32" \r
878ddf1f 960 sectiontype="EFI_SECTION_PE32"/>\r
5fc17c92 961 \r
878ddf1f 962 <POST.PROCESS/>\r
963 </sequential>\r
964 </OnDependency>\r
965 </sequential>\r
966 </macrodef>\r
967\r
968 <!--\r
969 EFI_SECTION_VERSION\r
970 -->\r
971 <macrodef name="EFI_SECTION_VERSION">\r
972 <attribute name="FILEPATH"/>\r
973 <attribute name="FILENAME"/>\r
974 <attribute name="FILEEXT" default="" />\r
975 <attribute name="VERSION" default="0000"/>\r
976\r
977 <element name="PRE.PROCESS" optional="yes"/>\r
978 <element name="POST.PROCESS" optional="yes"/>\r
979\r
980 <sequential>\r
981 <if>\r
982 <not>\r
22e0585c 983 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ver"/>\r
878ddf1f 984 </not>\r
985\r
986 <then>\r
987 <PRE.PROCESS/>\r
5fc17c92 988 <gensection outputfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ver" \r
878ddf1f 989 versionnum="@{VERSION}"\r
990 sectiontype="EFI_SECTION_VERSION"/>\r
991 <POST.PROCESS/>\r
992 </then>\r
993 </if>\r
994 </sequential>\r
995 </macrodef>\r
996\r
997 <!--\r
998 EFI_SECTION_USER_INTERFACE\r
999 -->\r
1000 <macrodef name="EFI_SECTION_USER_INTERFACE">\r
1001 <attribute name="FILEPATH"/>\r
1002 <attribute name="FILENAME"/>\r
1003 <attribute name="FILEEXT" default="" />\r
1004 <attribute name="UI" default="${BASE_NAME}"/>\r
1005\r
1006 <element name="PRE.PROCESS" optional="yes"/>\r
1007 <element name="POST.PROCESS" optional="yes"/>\r
1008\r
1009 <sequential>\r
1010 <if>\r
1011 <not>\r
22e0585c 1012 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ui"/>\r
878ddf1f 1013 </not>\r
1014\r
1015 <then>\r
1016 <PRE.PROCESS/>\r
1017 <gensection interfacestring="@{UI}"\r
5fc17c92 1018 outputfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ui" \r
878ddf1f 1019 sectiontype="EFI_SECTION_USER_INTERFACE"/>\r
1020 <POST.PROCESS/>\r
1021 </then>\r
1022 </if>\r
1023 </sequential>\r
1024 </macrodef>\r
1025\r
878ddf1f 1026 <!--\r
1027 EFI_SECTION_DXE_DEPEX\r
1028 -->\r
1029 <macrodef name="EFI_SECTION_DXE_DEPEX">\r
1030 <attribute name="FILEPATH"/>\r
1031 <attribute name="FILENAME"/>\r
1032 <attribute name="FILEEXT" default="dxs"/>\r
1033\r
1034 <element name="PRE.PROCESS" optional="yes"/>\r
1035 <element name="POST.PROCESS" optional="yes"/>\r
1036\r
1037 <sequential>\r
1038 <PRE.PROCESS/>\r
1039\r
1040 <if>\r
5fc17c92 1041 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>\r
878ddf1f 1042 <then>\r
1043 <OnDependency>\r
1044 <sourcefiles>\r
5fc17c92 1045 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>\r
878ddf1f 1046 </sourcefiles>\r
1047 <targetfiles>\r
22e0585c 1048 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1049 </targetfiles>\r
1050 <sequential>\r
5fc17c92 1051 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.depex" \r
1052 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx" \r
878ddf1f 1053 sectiontype="EFI_SECTION_DXE_DEPEX"/>\r
1054 </sequential>\r
1055 </OnDependency>\r
1056 </then>\r
1057 <else>\r
1058 <if>\r
1059 <not>\r
22e0585c 1060 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1061 </not>\r
1062 <then>\r
22e0585c 1063 <touch file="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1064 </then>\r
1065 </if>\r
1066 </else>\r
1067 </if>\r
1068\r
1069 <POST.PROCESS/>\r
1070 </sequential>\r
1071 </macrodef>\r
1072\r
1073 <!--\r
1074 EFI_SECTION_PEI_DEPEX\r
1075 -->\r
1076 <macrodef name="EFI_SECTION_PEI_DEPEX">\r
1077 <attribute name="FILEPATH"/>\r
1078 <attribute name="FILENAME"/>\r
1079 <attribute name="FILEEXT" default="dxs"/>\r
1080\r
1081 <element name="PRE.PROCESS" optional="yes"/>\r
1082 <element name="POST.PROCESS" optional="yes"/>\r
1083 <sequential>\r
1084 <PRE.PROCESS/>\r
1085 <if>\r
5fc17c92 1086 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>\r
878ddf1f 1087 <then>\r
1088 <OnDependency>\r
1089 <sourcefiles>\r
5fc17c92 1090 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>\r
878ddf1f 1091 </sourcefiles>\r
1092 <targetfiles>\r
22e0585c 1093 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1094 </targetfiles>\r
1095\r
1096 <sequential>\r
5fc17c92 1097 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.depex" \r
1098 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx" \r
878ddf1f 1099 sectiontype="EFI_SECTION_PEI_DEPEX"/>\r
1100 </sequential>\r
1101 </OnDependency>\r
5fc17c92 1102 \r
878ddf1f 1103 </then>\r
1104 <else>\r
1105 <if>\r
1106 <not>\r
22e0585c 1107 <available type="file" file="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1108 </not>\r
1109 <then>\r
22e0585c 1110 <touch file="${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>\r
878ddf1f 1111 </then>\r
1112 </if>\r
1113 </else>\r
1114 </if>\r
1115 <POST.PROCESS/>\r
1116 </sequential>\r
1117 </macrodef>\r
1118\r
878ddf1f 1119\r
1120 <!--\r
1121 EFI_SECTION_RAW\r
1122 -->\r
1123 <macrodef name="EFI_SECTION_RAW">\r
1124 <attribute name="FILEPATH"/>\r
1125 <attribute name="FILENAME"/>\r
1126 <attribute name="FILEEXT" default="bin"/>\r
1127\r
1128 <element name="PRE.PROCESS" optional="yes"/>\r
1129 <element name="POST.PROCESS" optional="yes"/>\r
1130\r
1131 <sequential>\r
1132 <OnDependency>\r
1133 <sourcefiles>\r
22e0585c 1134 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 1135 </sourcefiles>\r
1136 <targetfiles>\r
22e0585c 1137 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.sec"/>\r
878ddf1f 1138 </targetfiles>\r
1139\r
1140 <sequential>\r
1141 <PRE.PROCESS/>\r
5fc17c92 1142 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.@{FILEEXT}" \r
1143 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.sec" \r
878ddf1f 1144 sectiontype="EFI_SECTION_RAW"/>\r
1145 <POST.PROCESS/>\r
1146 </sequential>\r
1147 </OnDependency>\r
1148 </sequential>\r
1149 </macrodef>\r
1150\r
706c2ad4 1151 <!--\r
1152 EFI_SECTION_RAW_SEC\r
1153 -->\r
1154 <macrodef name="EFI_SECTION_RAW_SEC">\r
1155 <attribute name="FILEPATH"/>\r
1156 <attribute name="FILENAME"/>\r
1157 <attribute name="FILEEXT" default="cat"/>\r
1158\r
1159 <element name="PRE.PROCESS" optional="yes"/>\r
1160 <element name="POST.PROCESS" optional="yes"/>\r
1161\r
1162 <sequential>\r
1163 <OnDependency>\r
1164 <sourcefiles>\r
1165 <file name="${DEST_DIR_OUTPUT}/ResetVec.@{FILEEXT}"/>\r
1166 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.te"/>\r
1167 </sourcefiles>\r
1168 <targetfiles>\r
1169 <file name="${DEST_DIR_OUTPUT}/@{FILENAME}.sec"/>\r
1170 </targetfiles>\r
1171\r
1172 <sequential>\r
1173 <PRE.PROCESS/>\r
1174 <secfixup secexefile="${DEST_DIR_OUTPUT}/@{FILENAME}.te" resetvectorDatafile="${DEST_DIR_OUTPUT}/ResetVec.@{FILEEXT}"\r
1175 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.bin"/>\r
1176 \r
1177 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.bin" \r
1178 outputfile="${DEST_DIR_OUTPUT}/@{FILENAME}.sec" \r
1179 sectiontype="EFI_SECTION_RAW"/>\r
1180 <POST.PROCESS/>\r
1181 </sequential>\r
1182 </OnDependency>\r
1183 </sequential>\r
1184 </macrodef>\r
1185 \r
878ddf1f 1186 <!--\r
1187 EFI_SECTION_FIRMWARE_VOLUME_IMAGE\r
1188 -->\r
1189 <macrodef name="EFI_SECTION_FIRMWARE_VOLUME_IMAGE">\r
1190 <attribute name="FILEPATH"/>\r
1191 <attribute name="FILENAME"/>\r
1192 <attribute name="FILEEXT" default="fv"/>\r
1193\r
1194 <element name="PRE.PROCESS" optional="yes"/>\r
1195 <element name="POST.PROCESS" optional="yes"/>\r
1196\r
1197 <sequential>\r
1198 <OnDependency>\r
1199 <sourcefiles>\r
22e0585c 1200 <file name="${FV_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>\r
878ddf1f 1201 </sourcefiles>\r
1202 <targetfiles>\r
22e0585c 1203 <file name="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}fv.sec"/>\r
878ddf1f 1204 </targetfiles>\r
1205\r
1206 <sequential>\r
1207 <PRE.PROCESS/>\r
5fc17c92 1208 \r
1209 <copy file="${FV_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
1210 tofile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
878ddf1f 1211 overwrite="true"/>\r
5fc17c92 1212 <gensection inputfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
1213 outputfile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}fv.sec" \r
878ddf1f 1214 sectiontype="EFI_SECTION_FIRMWARE_VOLUME_IMAGE"/>\r
5fc17c92 1215 \r
878ddf1f 1216 <POST.PROCESS/>\r
1217 </sequential>\r
1218 </OnDependency>\r
1219 </sequential>\r
1220 </macrodef>\r
1221\r
1222 <!--\r
1223 Binary\r
1224 -->\r
1225 <macrodef name="Build_Binary">\r
1226 <attribute name="FILEPATH"/>\r
1227 <attribute name="FILENAME"/>\r
1228 <attribute name="FILEEXT" default="bin"/>\r
1229\r
1230 <element name="EXTRA.INC" optional="yes"/>\r
1231 <element name="EXTRA.ARG" optional="yes"/>\r
1232\r
1233 <sequential>\r
5fc17c92 1234 <copy file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
22e0585c 1235 tofile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.bin"/>\r
878ddf1f 1236 </sequential>\r
1237 </macrodef>\r
d6123759 1238 \r
473f57d4 1239 <!--\r
1240 Microcode\r
1241 -->\r
1242 <macrodef name="Build_MICROCODE">\r
1243 <attribute name="FILEPATH"/>\r
1244 <attribute name="FILENAME"/>\r
1245 <attribute name="FILEEXT" default="TXT"/>\r
1246\r
1247 <element name="EXTRA.INC" optional="yes"/>\r
1248 <element name="EXTRA.ARG" optional="yes"/>\r
1249\r
1250 <sequential>\r
50017606 1251 <mkdir dir="${TARGET_DIR}/Microcode"/>\r
1252 <flashmap MCIFile="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" MCOFILE="${TARGET_DIR}/Microcode/@{FILENAME}.bin"/>\r
473f57d4 1253 </sequential>\r
1254 </macrodef> \r
878ddf1f 1255\r
1256 <!--\r
1257 Graphics (bmp, ...)\r
1258 -->\r
d6123759 1259 <macrodef name="Build_BMP">\r
878ddf1f 1260 <attribute name="FILEPATH"/>\r
473f57d4 1261 <attribute name="FILENAME"/> \r
878ddf1f 1262 <attribute name="FILEEXT" default="bmp"/>\r
1263\r
1264 <element name="EXTRA.INC" optional="yes"/>\r
1265 <element name="EXTRA.ARG" optional="yes"/>\r
1266\r
1267 <sequential>\r
5fc17c92 1268 <mkdir dir="${MODULE_DIR}/@{FILEPATH}" /> \r
1269 <copy file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
22e0585c 1270 tofile="${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.bin"/>\r
878ddf1f 1271 </sequential>\r
5fc17c92 1272 </macrodef> \r
d6123759 1273\r
1274 <!--\r
1275 build EFI file\r
1276 -->\r
878ddf1f 1277 <macrodef name="Build_EFI">\r
1278 <attribute name="FILEPATH"/>\r
1279 <attribute name="FILENAME"/>\r
1280 <attribute name="FILEEXT" default="efi"/>\r
1281\r
1282 <element name="EXTRA.INC" optional="yes"/>\r
1283 <element name="EXTRA.ARG" optional="yes"/>\r
1284\r
1285 <sequential>\r
5fc17c92 1286 <mkdir dir="${MODULE_DIR}/@{FILEPATH}" /> \r
1287 <copy file="${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" \r
22e0585c 1288 tofile="${DEST_DIR_OUTPUT}/${BASE_NAME}.efi"/>\r
878ddf1f 1289 </sequential>\r
1290 </macrodef>\r
1291</project>\r