mirror of https://github.com/acidanthera/audk.git
BaseTools: Implement BUILDRULEORDER for tools_def
This feature allows the toolchain to choose a preference for source file extensions in tools_def.txt. The first extension is given the highest priority. Here is an example usage for tools_def.txt: *_*_*_*_BUILDRULEORDER = nasm Nasm NASM asm Asm ASM S s *_XCODE5_*_*_BUILDRULEORDER = S s nasm Nasm NASM Now, if a .inf lists these sources: 1.nasm, 1.asm and 1.S All toolchains, except XCODE5 will use the 1.nasm file. The XCODE5 toolchain will use the 1.S file. Note that the build_rule.txt file also impacts the decision, because, for instance there is no build rule for .asm files on GCC toolchains. Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Yingke Liu <yingke.d.liu@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@17509 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
419d989944
commit
fe4bf2f923
|
@ -2082,6 +2082,13 @@ class PlatformAutoGen(AutoGen):
|
|||
else:
|
||||
PlatformModuleOptions = {}
|
||||
|
||||
BuildRuleOrder = None
|
||||
for Options in [self.ToolDefinition, ModuleOptions, PlatformOptions, PlatformModuleOptions]:
|
||||
for Tool in Options:
|
||||
for Attr in Options[Tool]:
|
||||
if Attr == TAB_TOD_DEFINES_BUILDRULEORDER:
|
||||
BuildRuleOrder = Options[Tool][Attr]
|
||||
|
||||
AllTools = set(ModuleOptions.keys() + PlatformOptions.keys() + PlatformModuleOptions.keys() + self.ToolDefinition.keys())
|
||||
BuildOptions = {}
|
||||
for Tool in AllTools:
|
||||
|
@ -2093,6 +2100,11 @@ class PlatformAutoGen(AutoGen):
|
|||
continue
|
||||
for Attr in Options[Tool]:
|
||||
Value = Options[Tool][Attr]
|
||||
#
|
||||
# Do not generate it in Makefile
|
||||
#
|
||||
if Attr == TAB_TOD_DEFINES_BUILDRULEORDER:
|
||||
continue
|
||||
if Attr not in BuildOptions[Tool]:
|
||||
BuildOptions[Tool][Attr] = ""
|
||||
# check if override is indicated
|
||||
|
@ -2107,7 +2119,7 @@ class PlatformAutoGen(AutoGen):
|
|||
if 'BUILD' not in BuildOptions:
|
||||
BuildOptions['BUILD'] = {}
|
||||
BuildOptions['BUILD']['FLAGS'] = self.Workspace.UniFlag
|
||||
return BuildOptions
|
||||
return BuildOptions, BuildRuleOrder
|
||||
|
||||
Platform = property(_GetPlatform)
|
||||
Name = property(_GetName)
|
||||
|
@ -2195,6 +2207,7 @@ class ModuleAutoGen(AutoGen):
|
|||
self.DepexGenerated = False
|
||||
|
||||
self.BuildDatabase = self.Workspace.BuildDatabase
|
||||
self.BuildRuleOrder = None
|
||||
|
||||
self._Module = None
|
||||
self._Name = None
|
||||
|
@ -2587,7 +2600,9 @@ class ModuleAutoGen(AutoGen):
|
|||
#
|
||||
def _GetModuleBuildOption(self):
|
||||
if self._BuildOption == None:
|
||||
self._BuildOption = self.PlatformInfo.ApplyBuildOption(self.Module)
|
||||
self._BuildOption, self.BuildRuleOrder = self.PlatformInfo.ApplyBuildOption(self.Module)
|
||||
if self.BuildRuleOrder:
|
||||
self.BuildRuleOrder = ['.%s' % Ext for Ext in self.BuildRuleOrder.split()]
|
||||
return self._BuildOption
|
||||
|
||||
## Get include path list from tool option for the module build
|
||||
|
@ -2746,6 +2761,11 @@ class ModuleAutoGen(AutoGen):
|
|||
RuleChain = []
|
||||
SourceList = [File]
|
||||
Index = 0
|
||||
#
|
||||
# Make sure to get build rule order value
|
||||
#
|
||||
self._GetModuleBuildOption()
|
||||
|
||||
while Index < len(SourceList):
|
||||
Source = SourceList[Index]
|
||||
Index = Index + 1
|
||||
|
@ -2779,7 +2799,7 @@ class ModuleAutoGen(AutoGen):
|
|||
self._FinalBuildTargetList.add(LastTarget)
|
||||
break
|
||||
|
||||
Target = RuleObject.Apply(Source)
|
||||
Target = RuleObject.Apply(Source, self.BuildRuleOrder)
|
||||
if not Target:
|
||||
if LastTarget:
|
||||
self._FinalBuildTargetList.add(LastTarget)
|
||||
|
|
|
@ -220,7 +220,7 @@ class FileBuildRule:
|
|||
#
|
||||
# @retval tuple (Source file in full path, List of individual sourcefiles, Destionation file, List of build commands)
|
||||
#
|
||||
def Apply(self, SourceFile):
|
||||
def Apply(self, SourceFile, BuildRuleOrder=None):
|
||||
if not self.CommandList or not self.DestFileList:
|
||||
return None
|
||||
|
||||
|
@ -281,13 +281,20 @@ class FileBuildRule:
|
|||
|
||||
if DstFile[0] in self.BuildTargets:
|
||||
TargetDesc = self.BuildTargets[DstFile[0]]
|
||||
TargetDesc.AddInput(SourceFile)
|
||||
if BuildRuleOrder and SourceFile.Ext in BuildRuleOrder:
|
||||
Index = BuildRuleOrder.index(SourceFile.Ext)
|
||||
for Input in TargetDesc.Inputs:
|
||||
if Input.Ext not in BuildRuleOrder or BuildRuleOrder.index(Input.Ext) > Index:
|
||||
#
|
||||
# Command line should be regenerated since some macros are different
|
||||
#
|
||||
CommandList = self._BuildCommand(BuildRulePlaceholderDict)
|
||||
TargetDesc._Init([SourceFile], DstFile, CommandList, self.ExtraSourceFileList)
|
||||
break
|
||||
else:
|
||||
TargetDesc.AddInput(SourceFile)
|
||||
else:
|
||||
CommandList = []
|
||||
for CommandString in self.CommandList:
|
||||
CommandString = string.Template(CommandString).safe_substitute(BuildRulePlaceholderDict)
|
||||
CommandString = string.Template(CommandString).safe_substitute(BuildRulePlaceholderDict)
|
||||
CommandList.append(CommandString)
|
||||
CommandList = self._BuildCommand(BuildRulePlaceholderDict)
|
||||
TargetDesc = TargetDescBlock([SourceFile], DstFile, CommandList, self.ExtraSourceFileList)
|
||||
TargetDesc.ListFileMacro = self.ListFileMacro
|
||||
TargetDesc.FileListMacro = self.FileListMacro
|
||||
|
@ -298,6 +305,14 @@ class FileBuildRule:
|
|||
self.BuildTargets[DstFile[0]] = TargetDesc
|
||||
return TargetDesc
|
||||
|
||||
def _BuildCommand(self, Macros):
|
||||
CommandList = []
|
||||
for CommandString in self.CommandList:
|
||||
CommandString = string.Template(CommandString).safe_substitute(Macros)
|
||||
CommandString = string.Template(CommandString).safe_substitute(Macros)
|
||||
CommandList.append(CommandString)
|
||||
return CommandList
|
||||
|
||||
## Class for build rules
|
||||
#
|
||||
# BuildRule class parses rules defined in a file or passed by caller, and converts
|
||||
|
|
|
@ -432,6 +432,7 @@ TAB_TOD_DEFINES_TARGET_ARCH = 'TARGET_ARCH'
|
|||
TAB_TOD_DEFINES_COMMAND_TYPE = 'COMMAND_TYPE'
|
||||
TAB_TOD_DEFINES_FAMILY = 'FAMILY'
|
||||
TAB_TOD_DEFINES_BUILDRULEFAMILY = 'BUILDRULEFAMILY'
|
||||
TAB_TOD_DEFINES_BUILDRULEORDER = 'BUILDRULEORDER'
|
||||
|
||||
#
|
||||
# Conditional Statements
|
||||
|
|
Loading…
Reference in New Issue