#\r
-# Copyright (c) 2007, Intel Corporation\r
+# Copyright (c) 2007-2008, Intel Corporation\r
#\r
# All rights reserved. This program and the accompanying materials\r
# are licensed and made available under the terms and conditions of the BSD License\r
# "*" is used to indicate that the source files will be processed at the same time.\r
# "?" is used to indicate that the source files will be processed one by one.\r
#\r
-# "[" Build.<File-Type>[.<version>][, Build.<File-Type>[.<version>]] "]" <EOL>\r
+# "[" <File-Type>[.<Build-Type>][.<Arch>][, <File-Type>[.<Build-Type>][.<Arch>]] "]" <EOL>\r
# <InputFile[.<ToolChainFamily>]> <EOL>\r
-# [File-Type =] (?|*).<File-Extension> [(\n|,|;) (?|*).<File-Extension>]\r
+# (?|*).<File-Extension> [(\n|,) (?|*).<File-Extension>]\r
#\r
# <OutputFile[.<ToolChainFamily>]> <EOL>\r
# <FileFullPath>\r
#\r
+# <ExtraDependency>\r
+# <FileFullPath>\r
+#\r
# <Command[.<ToolChainFamily>]> <EOL>\r
# <Command1>\r
# [<Command2>]\r
#\r
+# <Build-Type> is the MODULE_TYPE in EDK2 or COMPONENT_TYPE in EDK.\r
+# Missing <InputFile> will cause an exception and break build.\r
+# Missing <Command> will cause that related build target won't be generated but\r
+# won't break build.\r
+#\r
\r
## Placeholders for string substitution\r
#\r
\r
## Reserved File-Type\r
#\r
-# Dont't change following names of file types and their associated files,\r
+# Don't change following names of file types and their associated files,\r
# which are also used in tools' code\r
#\r
# C-Code-File\r
# Unicode-Text-File\r
#\r
\r
-[Build.C-Code-File]\r
+[C-Code-File]\r
<InputFile>\r
?.c\r
?.C\r
?.Cpp\r
?.CPP\r
\r
+ <ExtraDependency>\r
+ $(MAKE_FILE)\r
+\r
<OutputFile>\r
$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj\r
\r
<Command.GCC>\r
"$(CC)" -o ${dst} $(CC_FLAGS) $(INC) ${src}\r
\r
-[Build.C-Header-File]\r
+[C-Header-File]\r
<InputFile>\r
*.h, *.H\r
\r
<OutputFile>\r
- $(OUTPUT_DIR)(+)$(MODULE_NAME).gch\r
- $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj\r
\r
<Command>\r
\r
\r
-[Build.Assembly-Code-File]\r
+[Assembly-Code-File.COMMON.COMMON]\r
<InputFile.MSFT, InputFile.INTEL>\r
- Assembly-Code-File = ?.asm, ?.Asm, ?.ASM\r
+ ?.asm, ?.Asm, ?.ASM\r
\r
<InputFile.GCC>\r
?.S\r
\r
+ <ExtraDependency>\r
+ $(MAKE_FILE)\r
+\r
<OutputFile>\r
$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj\r
\r
<Command.MSFT, Command.INTEL>\r
"$(PP)" $(PP_FLAGS) $(INC) ${src} > ${d_path}(+)${s_base}.i\r
Trim --source-code --convert-hex -o ${d_path}(+)${s_base}.iii ${d_path}(+)${s_base}.i\r
- "$(ASM)" /Fo${dst} $(ASM_FLAGS) $(INC) ${d_path}(+)${s_base}.iii\r
+ "$(ASM)" /Fo${dst} $(ASM_FLAGS) /I${s_path} $(INC) ${d_path}(+)${s_base}.iii\r
\r
<Command.GCC>\r
- "$(ASM)" -o ${dst} $(ASM_FLAGS) $(INC) ${src}\r
+ "$(PP)" $(PP_FLAGS) $(INC) ${src} > ${d_path}(+)${s_base}.i\r
+ Trim --source-code -o ${d_path}(+)${s_base}.iii ${d_path}(+)${s_base}.i\r
+ "$(ASM)" -o ${dst} $(ASM_FLAGS) $(INC) ${d_path}(+)${s_base}.iii\r
\r
-[Build.Iasm-Code-File]\r
+[Assembly-Code-File.COMMON.IPF]\r
<InputFile>\r
?.s\r
\r
+ <ExtraDependency>\r
+ $(MAKE_FILE)\r
+\r
<OutputFile>\r
$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj\r
\r
Trim --source-code -o ${d_path}(+)${s_base}.iii ${d_path}(+)${s_base}.i\r
"$(ASM)" -o ${dst} $(ASM_FLAGS) ${d_path}(+)${s_base}.iii\r
\r
-[Build.Visual-Form-Representation-File]\r
+[Visual-Form-Representation-File]\r
<InputFile>\r
?.vfr\r
?.Vfr\r
?.VFR\r
\r
+ <ExtraDependency>\r
+ $(MAKE_FILE)\r
+\r
<OutputFile>\r
$(DEBUG_DIR)(+)${s_dir}(+)${s_base}.c\r
\r
<Command>\r
- "$(PP)" $(VFRPP_FLAGS) $(INC) ${src} > $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.i\r
+ "$(VFRPP)" $(VFRPP_FLAGS) $(INC) ${src} > $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.i\r
Trim --vfr-file -o $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.iii $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.i\r
-mkdir ${d_path} > NUL 2>&1\r
- VfrCompile -od ${d_path} $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.iii\r
+ "$(VFR)" $(VFR_FLAGS) --output-directory ${d_path} $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.iii\r
\r
-[Build.Object-File]\r
+[Object-File]\r
<InputFile>\r
*.obj\r
*.o\r
<Command.GCC>\r
"$(SLINK)" -cr ${dst} $(SLINK_FLAGS) ${src}\r
\r
-#[Build.Object-File, Build.Static-Library-File]\r
-#BUILD_VERSION = 0x00010000\r
-#\r
-# <InputFile>\r
-# Object-File = *.obj\r
-# Static-Library-File = *.lib, *.a\r
-#\r
-# <OutputFile>\r
-# $(OUTPUT_DIR)(+)$(MODULE_NAME).lib\r
-#\r
-# <Command.MSFT>\r
-# "$(SLINK)" /OUT:${dst} $(SLINK_FLAGS) ${src}\r
-#\r
-# <Command.GCC>\r
-# "$(SLINK)" -cr ${dst} $(SLINK_FLAGS) ${src1} -( ${src2} -)\r
-#\r
-[Build.Static-Library-File]\r
+[Static-Library-File]\r
<InputFile>\r
?.lib\r
+\r
+ <ExtraDependency>\r
$(LIBS)\r
- $(MODULE_BUILD_DIR)\Makefile\r
+ $(MAKE_FILE)\r
\r
<OutputFile>\r
$(DEBUG_DIR)(+)$(MODULE_NAME).dll\r
"$(DLINK)" /OUT:${dst} $(DLINK_FLAGS) $(DLINK_SPATH) $(LIBS) ${src}\r
\r
<Command.GCC>\r
- "$(DLINK)" -o ${dst} $(DLINK_FLAGS) -( $(DLINK_SPATH) $(LIBS) ${src} -)\r
+ "$(DLINK)" -o ${dst} $(DLINK_FLAGS) -\( $(DLINK_SPATH) $(LIBS) ${src} -\) $(DLINK2_FLAGS)\r
\r
-[Build.Dynamic-Library-File]\r
+[Dynamic-Library-File]\r
<InputFile>\r
?.dll\r
\r
$(CP) ${dst} $(BIN_DIR)\r
-$(CP) $(DEBUG_DIR)(+)*.map $(OUTPUT_DIR)\r
\r
-[Build.Dependency-Expression-File]\r
+[Dependency-Expression-File]\r
<InputFile>\r
?.dxs, ?.Dxs, ?.DXS\r
\r
$(OUTPUT_DIR)(+)$(MODULE_NAME).depex\r
\r
<Command>\r
-# GenDepex -o ${dst} ${src}\r
+ "$(PP)" $(CC_FLAGS) $(APP_FLAGS) $(INC) ${src} > $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.i\r
+ Trim --source-code -o $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.iii $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.i\r
+ GenDepex -t $(MODULE_TYPE) -o ${dst} $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.iii\r
\r
-[Build.Acpi-Source-Language-File]\r
+[Acpi-Source-Language-File]\r
<InputFile>\r
?.asl, ?.Asl, ?.ASL\r
\r
<OutputFile>\r
- $(OUTPUT_DIR)(+)${s_base}.aml\r
+ $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.aml\r
+\r
+ <ExtraDependency>\r
+ $(MAKE_FILE)\r
+\r
+ <Command.MSFT, Command.INTEL>\r
+ Trim --asl-file -o $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.i ${src}\r
+ "$(ASLPP)" $(ASLPP_FLAGS) $(INC) /I${s_path} $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.i > $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.iii\r
+ "$(ASL)" -p ${dst} $(ASL_FLAGS) $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.iii\r
+\r
+[C-Code-File.AcpiTable]\r
+ <InputFile>\r
+ ?.c\r
+\r
+ <OutputFile>\r
+ $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.acpi\r
+\r
+ <ExtraDependency>\r
+ $(MAKE_FILE)\r
\r
<Command.MSFT, Command.INTEL>\r
- "$(PP)" $(APP_FLAGS) $(INC) ${src} > ${d_path}(+)${s_base}.i\r
- "$(ASL)" -p ${dst} ${d_path}(+)${s_base}.i\r
+ "$(ASLCC)" /Fo$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj $(CC_FLAGS) $(ASLCC_FLAGS) $(INC) ${src}\r
+ "$(ASLDLINK)" /OUT:$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.dll $(ASLDLINK_FLAGS) $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj\r
+ GenFw -o ${dst} -c $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.dll\r
\r
-[Build.Acpi-Table-Code-File]\r
+[Acpi-Table-Code-File]\r
<InputFile>\r
- ?.aslc\r
+ ?.aslc, ?.act\r
\r
<OutputFile>\r
- $(OUTPUT_DIR)(+)${s_base}.acpi\r
+ $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.acpi\r
+\r
+ <ExtraDependency>\r
+ $(MAKE_FILE)\r
\r
<Command.MSFT, Command.INTEL>\r
- "$(CC)" /Fo$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj $(CC_FLAGS) $(INC) ${src}\r
- "$(DLINK)" /OUT:$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.dll $(SLINK_FLAGS) $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj\r
+ "$(ASLCC)" /Fo$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj $(CC_FLAGS) $(ASLCC_FLAGS) $(INC) ${src}\r
+ "$(ASLDLINK)" /OUT:$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.dll $(ASLDLINK_FLAGS) $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj\r
GenFw -o ${dst} -c $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.dll\r
\r
-[Build.Masm16-Code-File]\r
+[Masm16-Code-File]\r
<InputFile>\r
?.asm16, ?.Asm16, ?.ASM16\r
\r
+ <ExtraDependency>\r
+ $(MAKE_FILE)\r
+\r
<OutputFile>\r
- $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.com\r
+ $(OUTPUT_DIR)(+)${s_base}.com\r
\r
<Command.MSFT, Command.INTEL>\r
- pushd .\r
cd $(OUTPUT_DIR)(+)${s_dir}\r
- "$(ASM)" /nologo /omf ${src} /Bl"$(ASMLINK)" $(ASMLINK_FLAGS)\r
- -$(CP) ${dst} $(OUTPUT_DIR) & popd\r
+ "$(ASM)" /nologo /c /omf /Fo$(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj ${src}\r
+ "$(ASMLINK)" $(ASMLINK_FLAGS) $(OUTPUT_DIR)(+)${s_dir}(+)${s_base}.obj,${dst},,,,\r
\r
-[Build.Microcode-File]\r
+[Microcode-File]\r
<InputFile>\r
- ?.txt, ?.TXT, ?.Txt\r
+ ?.txt, ?.TXT, ?.Txt, ?.mut\r
\r
<OutputFile>\r
$(OUTPUT_DIR)(+)${s_base}.mcb\r
<Command>\r
GenFw -o ${dst} -m ${src}\r
\r
-[Build.Microcode-Binary-File]\r
+[Microcode-Binary-File]\r
<InputFile>\r
*.mcb\r
\r
\r
<Command>\r
GenFw -o ${dst} -j ${src}\r
+ -$(CP) ${dst} $(BIN_DIR)\r
\r
-[Build.Unicode-Text-File]\r
+[EFI-Image-File]\r
<InputFile>\r
- *.uni, *.Uni, *.UNI\r
+ ?.efi, ?.Efi, ?.EFI\r
\r
<OutputFile>\r
- $(DEBUG_DIR)(+)AutoGen.c\r
- $(DEBUG_DIR)(+)AutoGen.h\r
\r
<Command>\r
\r