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