1 <?xml version=
"1.0" encoding=
"UTF-8"?>
3 Copyright (c) 2006, Intel Corporation
4 All rights reserved. This program and the accompanying materials
5 are licensed and made available under the terms and conditions of the BSD License
6 which accompanies this distribution. The full text of the license may be found at
7 http://opensource.org/licenses/bsd-license.php
9 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
10 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
12 <project name=
"common">
14 Macro for intialize some properties. This Macro build will be called before source file build.
16 <macrodef name=
"Build_Init">
18 <var name=
"OBJECTS" value=
"" />
19 <var name=
"SDB_FILES" value=
"" />
25 macro definitions for building files with different types
30 <macrodef name=
"Build_CCode">
31 <attribute name=
"FILEPATH"/>
32 <attribute name=
"FILENAME"/>
33 <attribute name=
"FILEEXT" default=
"c"/>
35 <element name=
"EXTRA.INC" optional=
"yes"/>
36 <element name=
"EXTRA.ARG" optional=
"yes"/>
39 <var name=
"FILE_BASENAME" value=
"@{FILENAME}" />
40 <var name=
"FILE_PATH" value=
"@{FILEPATH}" />
41 <mkdir dir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}"/>
44 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
46 <makedeps DepsFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep">
47 <input file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
48 <input file=
"${DEST_DIR_DEBUG}/AutoGen.h"/>
56 <file ListFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep"/>
59 <file Name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
63 <!-- Use pre-compiled header if available -->
66 <equals arg1=
"${CC_FAMILY}" arg2=
"MSFT" casesensitive=
"false"/>
67 <available file=
"${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
70 <var name=
"LOCAL_CC_FLAGS" value=
"${CC_FLAGS} /Yu${DEST_DIR_DEBUG}/AutoGen.h /Fp${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
73 <var name=
"LOCAL_CC_FLAGS" value=
"${CC_FLAGS}"/>
78 <command type=
"CC" cmd=
"${CC}" workdir=
"${DEST_DIR_OUTPUT}" family=
"${CC_FAMILY}"
79 outputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj">
81 <argument value=
"${LOCAL_CC_FLAGS}"/>
83 <fileset casesensitive=
"on" file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
88 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->
90 <equals arg1=
"@{FILEPATH}" arg2=
"." />
92 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILENAME}.obj" />
95 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />
102 <macrodef name=
"Build_AUTOGEN">
103 <attribute name=
"FILEPATH"/>
104 <attribute name=
"FILENAME"/>
105 <attribute name=
"FILEEXT" default=
"c"/>
107 <element name=
"EXTRA.INC" optional=
"yes"/>
108 <element name=
"EXTRA.ARG" optional=
"yes"/>
111 <var name=
"FILE_BASENAME" value=
"@{FILENAME}" />
112 <var name=
"FILE_PATH" value=
"@{FILEPATH}" />
113 <mkdir dir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}"/>
116 <available type=
"file" file=
"${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
118 <makedeps DepsFile=
"${DEST_DIR_OUTPUT}/AutoGen.h.dep">
119 <input file=
"${DEST_DIR_DEBUG}/AutoGen.h"/>
127 <file ListFile=
"${DEST_DIR_OUTPUT}/AutoGen.h.dep"/>
130 <file Name=
"${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
134 <!-- Generate pre-compiled header -->
136 <equals arg1=
"${CC_FAMILY}" arg2=
"MSFT" casesensitive=
"false"/>
138 <var name=
"LOCAL_CC_FLAGS" value=
"${CC_FLAGS} /TC /Yc /Fp${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
140 <command type=
"CC" cmd=
"${CC}" workdir=
"${DEST_DIR_OUTPUT}" family=
"${CC_FAMILY}"
141 outputFile=
"${DEST_DIR_OUTPUT}/AutoGen.h.obj">
143 <argument value=
"${LOCAL_CC_FLAGS}"/>
145 <fileset casesensitive=
"on" file=
"${DEST_DIR_DEBUG}/AutoGen.h"/>
154 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
156 <makedeps DepsFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep">
157 <input file=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
158 <input file=
"${DEST_DIR_DEBUG}/AutoGen.h"/>
166 <file ListFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep"/>
169 <file Name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
173 <!-- Generate pre-compiled header -->
175 <equals arg1=
"${CC_FAMILY}" arg2=
"MSFT" casesensitive=
"false"/>
177 <var name=
"LOCAL_CC_FLAGS" value=
"${CC_FLAGS} /Yu${DEST_DIR_DEBUG}/AutoGen.h /Fp${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
180 <var name=
"LOCAL_CC_FLAGS" value=
"${CC_FLAGS}"/>
185 <command type=
"CC" cmd=
"${CC}" workdir=
"${DEST_DIR_OUTPUT}" family=
"${CC_FAMILY}"
186 outputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj">
188 <argument value=
"${LOCAL_CC_FLAGS}"/>
190 <fileset casesensitive=
"on" file=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
195 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->
197 <equals arg1=
"@{FILEPATH}" arg2=
"." />
199 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILENAME}.obj" />
202 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />
208 <macrodef name=
"Build_DPX">
209 <attribute name=
"FILEPATH"/>
210 <attribute name=
"FILENAME"/>
211 <attribute name=
"FILEEXT" default=
"dxs"/>
213 <element name=
"EXTRA.INC" optional=
"yes"/>
214 <element name=
"EXTRA.ARG" optional=
"yes"/>
218 <var name=
"FILE_BASENAME" value=
"@{FILENAME}" />
219 <var name=
"FILE_PATH" value=
"@{FILEPATH}" />
220 <mkdir dir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}"/>
224 <file name=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
227 <file name=
"${DEST_DIR_OUTPUT}/${BASE_NAME}.depex"/>
232 <command type=
"CC" cmd=
"${CC}" workdir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}" family=
"${CC_FAMILY}"
233 outputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i">
235 <argument value=
"${PP_FLAGS}"/>
236 <fileset casesensitive=
"on" file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
240 <gendepex inputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i" outputFile=
"${DEST_DIR_OUTPUT}/${BASE_NAME}.depex"/>
246 <macrodef name=
"Build_ASM">
247 <attribute name=
"FILEPATH"/>
248 <attribute name=
"FILENAME"/>
249 <attribute name=
"FILEEXT" default=
"asm"/>
251 <element name=
"EXTRA.INC" optional=
"yes"/>
252 <element name=
"EXTRA.ARG" optional=
"yes"/>
254 <!-- Dispath ASM file, there are three type.
256 S - Build_Gcc_Assembly
257 s - Build_Ipf_Assembly -->
260 <equals arg1=
"@{FILEEXT}" arg2=
"asm" />
262 <Build_Assembly FILEPATH=
"@{FILEPATH}" FILENAME=
"@{FILENAME}" FILEEXT=
"@{FILEEXT}">
263 <EXTRA.INC
.1><EXTRA.INC
/></EXTRA.INC
.1>
264 <EXTRA.ARG
.1><EXTRA.ARG
/></EXTRA.ARG
.1>
268 <equals arg1=
"@{FILEEXT}" arg2=
"S" />
270 <Build_Gcc_Assembly FILEPATH=
"@{FILEPATH}" FILENAME=
"@{FILENAME}" FILEEXT=
"@{FILEEXT}">
271 <EXTRA.INC
.1><EXTRA.INC
/></EXTRA.INC
.1>
272 <EXTRA.ARG
.1><EXTRA.ARG
/></EXTRA.ARG
.1>
273 </Build_Gcc_Assembly>
277 <equals arg1=
"@{FILEEXT}" arg2=
"s" />
279 <Build_IPF_Assembly_Code FILEPATH=
"@{FILEPATH}" FILENAME=
"@{FILENAME}" FILEEXT=
"@{FILEEXT}">
280 <EXTRA.INC
.1><EXTRA.INC
/></EXTRA.INC
.1>
281 <EXTRA.ARG
.1><EXTRA.ARG
/></EXTRA.ARG
.1>
282 </Build_IPF_Assembly_Code>
292 <macrodef name=
"Build_Assembly">
293 <attribute name=
"FILEPATH"/>
294 <attribute name=
"FILENAME"/>
295 <attribute name=
"FILEEXT" default=
"asm"/>
297 <element name=
"EXTRA.INC.1" optional=
"yes"/>
298 <element name=
"EXTRA.ARG.1" optional=
"yes"/>
301 <var name=
"FILE_BASENAME" value=
"@{FILENAME}" />
302 <var name=
"FILE_PATH" value=
"@{FILEPATH}" />
303 <mkdir dir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}"/>
307 <file Name=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
310 <file Name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
315 <command type=
"PP" cmd=
"${PP}" workdir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}" family=
"${PP_FAMILY}">
317 <argument value=
"${PP_FLAGS}"/>
318 <fileset casesensitive=
"on" file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
322 <replaceregexp file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"
323 match=
"^(#line +1 +.*@{FILEPATH}/@{FILENAME}\.@{FILEEXT}").+\1"
326 <replaceregexp file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"
330 <replaceregexp file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"
331 match=
"([^_a-zA-Z])0x([0-9a-fA-F]+)"
337 <command type=
"ASM" cmd=
"${ASM}" workdir=
"${DEST_DIR_OUTPUT}" family=
"${ASM_FAMILY}"
338 outputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj">
341 <argument value=
"${ASM_FLAGS}"/>
344 <fileset casesensitive=
"on" file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"/>
349 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->
351 <equals arg1=
"@{FILEPATH}" arg2=
"." />
353 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILENAME}.obj" />
356 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />
363 Build GCC assembly code
365 <macrodef name=
"Build_Gcc_Assembly">
366 <attribute name=
"FILEPATH"/>
367 <attribute name=
"FILENAME"/>
368 <attribute name=
"FILEEXT" default=
"asm"/>
370 <element name=
"EXTRA.INC.1" optional=
"yes"/>
371 <element name=
"EXTRA.ARG.1" optional=
"yes"/>
374 <var name=
"FILE_BASENAME" value=
"@{FILENAME}" />
375 <var name=
"FILE_PATH" value=
"@{FILEPATH}" />
376 <mkdir dir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}"/>
380 <file Name=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
383 <file Name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
388 <command type=
"ASM" cmd=
"${ASM}" workdir=
"${DEST_DIR_OUTPUT}" family=
"${ASM_FAMILY}"
389 outputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj">
392 <argument value=
"${ASM_FLAGS}"/>
395 <fileset casesensitive=
"on" file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
400 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->
402 <equals arg1=
"@{FILEPATH}" arg2=
"." />
404 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILENAME}.obj" />
407 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />
416 <macrodef name=
"Build_IPF_Assembly_Code">
417 <attribute name=
"FILEPATH"/>
418 <attribute name=
"FILENAME"/>
419 <attribute name=
"FILEEXT" default=
"s"/>
421 <element name=
"EXTRA.INC.1" optional=
"yes"/>
422 <element name=
"EXTRA.ARG.1" optional=
"yes"/>
425 <mkdir dir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}"/>
428 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
430 <makedeps DepsFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep">
431 <input file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
432 <input file=
"${DEST_DIR_DEBUG}/AutoGen.h"/>
440 <file listfile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep"/>
443 <file name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
448 <command type=
"PP" cmd=
"${PP}" workdir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}" family=
"${PP_FAMILY}">
450 <argument value=
"${PP_FLAGS}"/>
451 <fileset casesensitive=
"on" file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
456 <command type=
"ASM" cmd=
"${ASM}" workdir=
"${DEST_DIR_OUTPUT}" family=
"${ASM_FAMILY}"
457 includepathDelimiter=
"-I" outputDelimiter=
"-o"
458 outputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj">
460 <argument value=
"${ASM_FLAGS}"/>
462 <fileset casesensitive=
"on" file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.i"/>
467 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->
469 <equals arg1=
"@{FILEPATH}" arg2=
"." />
471 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILENAME}.obj" />
474 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />
481 <macrodef name=
"Build_IPF_PP_Code">
482 <attribute name=
"FILEPATH"/>
483 <attribute name=
"FILENAME"/>
484 <attribute name=
"FILEEXT" default=
"i"/>
486 <element name=
"EXTRA.INC" optional=
"yes"/>
487 <element name=
"EXTRA.ARG" optional=
"yes"/>
490 <mkdir dir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}"/>
493 <command type=
"ASM" includepathDelimiter=
"-I">
494 <includepath path=
"${WORKSPACE_DIR}"/>
495 <includepath path=
"${MODULE_DIR}"/>
496 <includepath path=
"${MODULE_DIR}/${ARCH}"/>
499 <argument value=
"${ASM_FLAGS}"/>
501 <OutputFile File=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
503 <fileset casesensitive=
"on" file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
511 Library private HashMap map = new HashMap();
513 <macrodef name=
"Build_Library">
514 <attribute name=
"FILENAME" />
515 <attribute name=
"FILEEXT" default=
"obj"/>
518 <var name=
"FILE_BASENAME" value=
"@{FILENAME}" />
519 <var name=
"FILE_PATH" value=
"." />
520 <mkdir dir=
"${BIN_DIR}"/>
524 <fileset dir=
"${DEST_DIR_OUTPUT}" includes=
"${OBJECTS}" />
527 <file name=
"${BIN_DIR}/@{FILENAME}.lib"/>
532 <command type=
"SLINK" cmd=
"${SLINK}" family=
"${SLINK_FAMILY}"
533 outputFile=
"${BIN_DIR}/@{FILENAME}.lib">
534 <argument value=
"${SLINK_FLAGS}"/>
536 <fileset dir=
"${DEST_DIR_OUTPUT}" includes=
"${OBJECTS}"/>
547 <macrodef name=
"Build_UNI">
548 <attribute name=
"FILEPATH"/>
549 <attribute name=
"FILENAME"/>
550 <attribute name=
"FILEEXT" default=
"uni"/>
552 <element name=
"EXTRA.INC" optional=
"yes"/>
553 <element name=
"EXTRA.ARG" optional=
"yes"/>
556 <mkdir dir=
"${DEST_DIR_OUTPUT}/@{FILEPATH}"/>
560 <file name=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
563 <file name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>
567 <strgather commandtype=
"parse" newdatabase=
"true">
568 <database name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>
571 <inputfile name=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
576 <var name=
"SDB_FILES" value=
"${SDB_FILES}, ${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>
581 .sdb(s) -> .c, .h -> .obj
583 <macrodef name=
"Build_Unicode_Database">
584 <attribute name=
"FILEPATH"/>
585 <attribute name=
"FILENAME"/>
586 <attribute name=
"FILEEXT" default=
"sdb"/>
588 <element name=
"EXTRA.INC" optional=
"yes"/>
589 <element name=
"EXTRA.ARG" optional=
"yes"/>
592 <var name=
"FILE_BASENAME" value=
"@{FILENAME}" />
593 <var name=
"FILE_PATH" value=
"@{FILEPATH}" />
596 <file list=
"${SDB_FILES}"/>
597 <file list=
"${SOURCE_FILES}"/>
600 <file name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>
604 <strgather commandtype=
"scan" outputdatabase=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb" verbose=
"read">
605 <skipext name=
".uni"/>
607 <database list=
"${SDB_FILES}"/>
608 <inputfile name=
"${SOURCE_FILES}"/>
615 <file name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>
618 <file name=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}StrDefs.h"/>
619 <file name=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.hpk"/>
620 <file name=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.c"/>
624 <strgather basename=
"@{FILENAME}Strings" commandtype=
"dump"
625 outputdefines=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}StrDefs.h"
626 outputhpk=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.hpk"
627 outputstring=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.c">
628 <database name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.sdb"/>
635 <file name=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.c"/>
638 <file name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Strings.obj"/>
642 <!-- Use pre-compiled header if available -->
645 <equals arg1=
"${CC_FAMILY}" arg2=
"MSFT" casesensitive=
"false"/>
646 <available file=
"${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
649 <var name=
"LOCAL_CC_FLAGS" value=
"${CC_FLAGS} /Yc${DEST_DIR_DEBUG}/AutoGen.h /Yu${DEST_DIR_DEBUG}/AutoGen.h /Fp${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
652 <var name=
"LOCAL_CC_FLAGS" value=
"${CC_FLAGS}"/>
657 <command type=
"CC" cmd=
"${CC}" workdir=
"${DEST_DIR_OUTPUT}" family=
"${CC_FAMILY}"
658 includepathDelimiter=
"-I"
659 outputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Strings.obj">
660 <argument value=
"${LOCAL_CC_FLAGS}"/>
662 <fileset casesensitive=
"on" file=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}Strings.c"/>
668 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->
670 <equals arg1=
"@{FILEPATH}" arg2=
"." />
672 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILENAME}Strings.obj" />
675 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILEPATH}/@{FILENAME}Strings.obj" />
684 <macrodef name=
"Build_VFR">
685 <attribute name=
"FILEPATH"/>
686 <attribute name=
"FILENAME"/>
687 <attribute name=
"FILEEXT" default=
"vfr"/>
689 <element name=
"EXTRA.INC" optional=
"yes"/>
690 <element name=
"EXTRA.ARG" optional=
"yes"/>
693 <mkdir dir=
"${DEST_DIR_DEBUG}/@{FILEPATH}"/>
696 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
698 <makedeps DepsFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep">
699 <input file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
700 <input file=
"${DEST_DIR_DEBUG}/AutoGen.h"/>
708 <file listfile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}.dep"/>
711 <file name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj"/>
715 <vfrcompile createIfrBinFile=
"on" createListFile=
"on" outPutDir=
"${DEST_DIR_DEBUG}/@{FILEPATH}" vfrFile=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" DllPath=
"${DPATH}">
719 <!-- Use pre-compiled header if available -->
722 <equals arg1=
"${CC_FAMILY}" arg2=
"MSFT" casesensitive=
"false"/>
723 <available file=
"${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
726 <var name=
"LOCAL_CC_FLAGS" value=
"${CC_FLAGS} /Yu${DEST_DIR_DEBUG}/AutoGen.h /Fp${DEST_DIR_DEBUG}/AutoGen.h.gch"/>
729 <var name=
"LOCAL_CC_FLAGS" value=
"${CC_FLAGS}"/>
734 <command type=
"CC" cmd=
"${CC}" workdir=
"${DEST_DIR_OUTPUT}"
735 includepathDelimiter=
"-I" family=
"${CC_FAMILY}"
736 outputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.obj" >
737 <argument value=
"${LOCAL_CC_FLAGS}"/>
740 <fileset casesensitive=
"on" file=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.c"/>
745 <!-- Since fileset can't scan file start with ./, remove ./ in previous. -->
747 <equals arg1=
"@{FILEPATH}" arg2=
"." />
749 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILENAME}.obj" />
752 <var name=
"OBJECTS" value=
"${OBJECTS} @{FILEPATH}/@{FILENAME}.obj" />
761 <macrodef name=
"Build_DUMMY">
762 <attribute name=
"FILEPATH"/>
763 <attribute name=
"FILENAME"/>
764 <attribute name=
"FILEEXT"/>
766 <element name=
"EXTRA.INC" optional=
"yes"/>
767 <element name=
"EXTRA.ARG" optional=
"yes"/>
770 <echo message=
"Ignoring ${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" level=
"info" />
774 <!--############################################################################
776 #############################################################################-->
780 <macrodef name=
"GenDll">
781 <attribute name=
"FILEPATH"/>
782 <attribute name=
"FILENAME"/>
783 <attribute name=
"FILEEXT"/>
785 <element name=
"LIB.ARG" optional=
"yes"/>
786 <element name=
"LINK.ARG" optional=
"yes"/>
789 <var name=
"FILE_BASENAME" value=
"@{FILENAME}" />
790 <var name=
"FILE_PATH" value=
"@{FILEPATH}" />
793 <file list=
"${LIBS}"/>
794 <fileset dir=
"${DEST_DIR_OUTPUT}" includes=
"${OBJECTS}" />
797 <file name=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.dll"/>
802 <command type=
"SLINK" cmd=
"${SLINK}" family=
"${SLINK_FAMILY}"
803 outputFile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Local.lib">
804 <argument value=
"${SLINK_FLAGS}"/>
806 <fileset dir=
"${DEST_DIR_OUTPUT}" includes=
"${OBJECTS}"/>
810 <command type=
"DLINK" cmd=
"${DLINK}" family=
"${DLINK_FAMILY}"
811 outputFile=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.dll" >
812 <argument value=
"${DLINK_FLAGS}"/>
813 <libset libs=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}Local.lib ${LIBS} ${DLINK_SPATH}"/>
825 <macrodef name=
"GenEfi">
826 <attribute name=
"FILEPATH"/>
827 <attribute name=
"FILENAME"/>
828 <attribute name=
"FILEEXT" default=
"dll"/>
833 <file name=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
836 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>
840 <fwimage componentType=
"${MODULE_TYPE}" outImage=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi"
841 peImage=
"${DEST_DIR_DEBUG}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" time=
"0"/>
848 EFI_SECTION_FREEFORM_SUBTYPE_GUID
850 EFI_SECTION_USER_INTERFACE
851 EFI_SECTION_DXE_DEPEX
852 EFI_SECTION_PEI_DEPEX
857 EFI_SECTION_COMPRESSION
858 EFI_SECTION_GUID_DEFINED
859 EFI_SECTION_COMPATIBILITY16
860 EFI_SECTION_FIRMWARE_VOLUME_IMAGE
866 <macrodef name=
"EFI_SECTION_TE">
867 <attribute name=
"FILEPATH"/>
868 <attribute name=
"FILENAME"/>
869 <attribute name=
"FILEEXT" default=
"" />
871 <element name=
"PRE.PROCESS" optional=
"yes"/>
872 <element name=
"POST.PROCESS" optional=
"yes"/>
878 <equals arg1=
"${LIBS}" arg2=
""/>
882 <GenDll FILEPATH=
"." FILENAME=
"@{FILENAME}" FILEEXT=
"">
884 <LINK.ARG
></LINK.ARG
>
887 <GenEfi FILEPATH=
"." FILENAME=
"@{FILENAME}" FILEEXT=
"dll"/>
893 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>
896 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.tes"/>
900 <copy file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile=
"${BIN_DIR}/@{FILENAME}.efi" />
901 <copy file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile=
"${DEST_DIR_DEBUG}/@{FILENAME}.efi" />
902 <genteimage Dump=
"false" Verbose=
"false" OutputDir=
"" OutputFile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.te" InputFile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>
903 <gensection inputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.te"
904 outputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.tes"
905 sectiontype=
"EFI_SECTION_TE"/>
912 <macrodef name=
"EFI_SECTION_PE32">
913 <attribute name=
"FILEPATH"/>
914 <attribute name=
"FILENAME"/>
915 <attribute name=
"FILEEXT" default=
"" />
917 <element name=
"PRE.PROCESS" optional=
"yes"/>
918 <element name=
"POST.PROCESS" optional=
"yes"/>
924 <!-- TBD ${OBJECTS} -->
925 <equals arg1=
"${LIBS}" arg2=
""/>
929 <GenDll FILEPATH=
"." FILENAME=
"@{FILENAME}" FILEEXT=
"">
931 <LINK.ARG
></LINK.ARG
>
934 <GenEfi FILEPATH=
"." FILENAME=
"@{FILENAME}" FILEEXT=
"dll"/>
940 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi"/>
943 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.pe32"/>
947 <copy file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile=
"${BIN_DIR}/@{FILENAME}.efi" />
948 <copy file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi" tofile=
"${DEST_DIR_DEBUG}/@{FILENAME}.efi" />
949 <gensection inputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.efi"
950 outputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.pe32"
951 sectiontype=
"EFI_SECTION_PE32"/>
962 <macrodef name=
"EFI_SECTION_VERSION">
963 <attribute name=
"FILEPATH"/>
964 <attribute name=
"FILENAME"/>
965 <attribute name=
"FILEEXT" default=
"" />
966 <attribute name=
"VERSION" default=
"0000"/>
968 <element name=
"PRE.PROCESS" optional=
"yes"/>
969 <element name=
"POST.PROCESS" optional=
"yes"/>
974 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ver"/>
979 <gensection outputfile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ver"
980 versionnum=
"@{VERSION}"
981 sectiontype=
"EFI_SECTION_VERSION"/>
989 EFI_SECTION_USER_INTERFACE
991 <macrodef name=
"EFI_SECTION_USER_INTERFACE">
992 <attribute name=
"FILEPATH"/>
993 <attribute name=
"FILENAME"/>
994 <attribute name=
"FILEEXT" default=
"" />
995 <attribute name=
"UI" default=
"${BASE_NAME}"/>
997 <element name=
"PRE.PROCESS" optional=
"yes"/>
998 <element name=
"POST.PROCESS" optional=
"yes"/>
1003 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ui"/>
1008 <gensection interfacestring=
"@{UI}"
1009 outputfile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.ui"
1010 sectiontype=
"EFI_SECTION_USER_INTERFACE"/>
1018 EFI_SECTION_DXE_DEPEX
1020 <macrodef name=
"EFI_SECTION_DXE_DEPEX">
1021 <attribute name=
"FILEPATH"/>
1022 <attribute name=
"FILENAME"/>
1023 <attribute name=
"FILEEXT" default=
"dxs"/>
1025 <element name=
"PRE.PROCESS" optional=
"yes"/>
1026 <element name=
"POST.PROCESS" optional=
"yes"/>
1032 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>
1036 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>
1039 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>
1042 <gensection inputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.depex"
1043 outputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"
1044 sectiontype=
"EFI_SECTION_DXE_DEPEX"/>
1051 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>
1054 <touch file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>
1065 EFI_SECTION_PEI_DEPEX
1067 <macrodef name=
"EFI_SECTION_PEI_DEPEX">
1068 <attribute name=
"FILEPATH"/>
1069 <attribute name=
"FILENAME"/>
1070 <attribute name=
"FILEEXT" default=
"dxs"/>
1072 <element name=
"PRE.PROCESS" optional=
"yes"/>
1073 <element name=
"POST.PROCESS" optional=
"yes"/>
1077 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>
1081 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.depex"/>
1084 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>
1088 <gensection inputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.depex"
1089 outputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"
1090 sectiontype=
"EFI_SECTION_PEI_DEPEX"/>
1098 <available type=
"file" file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>
1101 <touch file=
"${DEST_DIR_OUTPUT}/@{FILENAME}.dpx"/>
1114 <macrodef name=
"EFI_SECTION_RAW">
1115 <attribute name=
"FILEPATH"/>
1116 <attribute name=
"FILENAME"/>
1117 <attribute name=
"FILEEXT" default=
"bin"/>
1119 <element name=
"PRE.PROCESS" optional=
"yes"/>
1120 <element name=
"POST.PROCESS" optional=
"yes"/>
1125 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.@{FILEEXT}"/>
1128 <file name=
"${DEST_DIR_OUTPUT}/@{FILENAME}.sec"/>
1133 <gensection inputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.@{FILEEXT}"
1134 outputfile=
"${DEST_DIR_OUTPUT}/@{FILENAME}.sec"
1135 sectiontype=
"EFI_SECTION_RAW"/>
1143 EFI_SECTION_FIRMWARE_VOLUME_IMAGE
1145 <macrodef name=
"EFI_SECTION_FIRMWARE_VOLUME_IMAGE">
1146 <attribute name=
"FILEPATH"/>
1147 <attribute name=
"FILENAME"/>
1148 <attribute name=
"FILEEXT" default=
"fv"/>
1150 <element name=
"PRE.PROCESS" optional=
"yes"/>
1151 <element name=
"POST.PROCESS" optional=
"yes"/>
1156 <file name=
"${FV_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"/>
1159 <file name=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}fv.sec"/>
1165 <copy file=
"${FV_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"
1166 tofile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"
1168 <gensection inputfile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"
1169 outputfile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}fv.sec"
1170 sectiontype=
"EFI_SECTION_FIRMWARE_VOLUME_IMAGE"/>
1181 <macrodef name=
"Build_Binary">
1182 <attribute name=
"FILEPATH"/>
1183 <attribute name=
"FILENAME"/>
1184 <attribute name=
"FILEEXT" default=
"bin"/>
1186 <element name=
"EXTRA.INC" optional=
"yes"/>
1187 <element name=
"EXTRA.ARG" optional=
"yes"/>
1190 <copy file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"
1191 tofile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.bin"/>
1197 <macrodef name=
"Build_MICROCODE">
1198 <attribute name=
"FILEPATH"/>
1199 <attribute name=
"FILENAME"/>
1200 <attribute name=
"FILEEXT" default=
"TXT"/>
1202 <element name=
"EXTRA.INC" optional=
"yes"/>
1203 <element name=
"EXTRA.ARG" optional=
"yes"/>
1206 <mkdir dir=
"${TARGET_DIR}/Microcode"/>
1207 <flashmap MCIFile=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}" MCOFILE=
"${TARGET_DIR}/Microcode/@{FILENAME}.bin"/>
1214 <macrodef name=
"Build_Graphics">
1215 <attribute name=
"FILEPATH"/>
1216 <attribute name=
"FILENAME"/>
1217 <attribute name=
"FILEEXT" default=
"bmp"/>
1219 <element name=
"EXTRA.INC" optional=
"yes"/>
1220 <element name=
"EXTRA.ARG" optional=
"yes"/>
1223 <mkdir dir=
"${MODULE_DIR}/@{FILEPATH}" />
1224 <copy file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"
1225 tofile=
"${DEST_DIR_OUTPUT}/@{FILEPATH}/@{FILENAME}.bin"/>
1228 <macrodef name=
"Build_EFI">
1229 <attribute name=
"FILEPATH"/>
1230 <attribute name=
"FILENAME"/>
1231 <attribute name=
"FILEEXT" default=
"efi"/>
1233 <element name=
"EXTRA.INC" optional=
"yes"/>
1234 <element name=
"EXTRA.ARG" optional=
"yes"/>
1237 <mkdir dir=
"${MODULE_DIR}/@{FILEPATH}" />
1238 <copy file=
"${MODULE_DIR}/@{FILEPATH}/@{FILENAME}.@{FILEEXT}"
1239 tofile=
"${DEST_DIR_OUTPUT}/${BASE_NAME}.efi"/>