mirror of https://github.com/acidanthera/audk.git
BaseTools:Fix GenFds issue for BuildOption replace GenFdsOption
BZ:https://bugzilla.tianocore.org/show_bug.cgi?id=2455 BuildOption is used by TargetTxtClassObj.py GenFdsOption is used by GenFds.py When the GenFds tool is used alone (e.g. python3 -m GenFds.GenFds -h) With the OptionParser function, the first detected function prints the help message import TargetTxtClassObj to GenFds, The BuildOption will be executed and replace GenFdsOption We removed all objects associated with this problem that were created directly during the import process (e.g. BuildOption, BuildTarget = MyOptionParser(), TargetTxt = TargetTxtDict()) The Patch is going to fix this issue Signed-off-by: Zhiju.Fan <zhijux.fan@intel.com> Cc: Liming Gao <liming.gao@intel.com> Cc: Bob Feng <bob.c.feng@intel.com> Reviewed-by: Bob Feng <bob.c.feng@intel.com>
This commit is contained in:
parent
072b9c2839
commit
4465cd124f
BaseTools/Source/Python
|
@ -20,7 +20,7 @@ from Common.BuildToolError import *
|
||||||
from Common.Misc import tdict, PathClass
|
from Common.Misc import tdict, PathClass
|
||||||
from Common.StringUtils import NormPath
|
from Common.StringUtils import NormPath
|
||||||
from Common.DataType import *
|
from Common.DataType import *
|
||||||
from Common.TargetTxtClassObject import TargetTxt
|
from Common.TargetTxtClassObject import TargetTxtDict
|
||||||
gDefaultBuildRuleFile = 'build_rule.txt'
|
gDefaultBuildRuleFile = 'build_rule.txt'
|
||||||
AutoGenReqBuildRuleVerNum = '0.1'
|
AutoGenReqBuildRuleVerNum = '0.1'
|
||||||
|
|
||||||
|
@ -588,8 +588,28 @@ class BuildRule:
|
||||||
_UnknownSection : SkipSection,
|
_UnknownSection : SkipSection,
|
||||||
}
|
}
|
||||||
|
|
||||||
def GetBuildRule():
|
class ToolBuildRule():
|
||||||
|
|
||||||
|
def __new__(cls, *args, **kw):
|
||||||
|
if not hasattr(cls, '_instance'):
|
||||||
|
orig = super(ToolBuildRule, cls)
|
||||||
|
cls._instance = orig.__new__(cls, *args, **kw)
|
||||||
|
return cls._instance
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
if not hasattr(self, 'ToolBuildRule'):
|
||||||
|
self._ToolBuildRule = None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def ToolBuildRule(self):
|
||||||
|
if not self._ToolBuildRule:
|
||||||
|
self._GetBuildRule()
|
||||||
|
return self._ToolBuildRule
|
||||||
|
|
||||||
|
def _GetBuildRule(self):
|
||||||
BuildRuleFile = None
|
BuildRuleFile = None
|
||||||
|
TargetObj = TargetTxtDict()
|
||||||
|
TargetTxt = TargetObj.Target
|
||||||
if TAB_TAT_DEFINES_BUILD_RULE_CONF in TargetTxt.TargetTxtDictionary:
|
if TAB_TAT_DEFINES_BUILD_RULE_CONF in TargetTxt.TargetTxtDictionary:
|
||||||
BuildRuleFile = TargetTxt.TargetTxtDictionary[TAB_TAT_DEFINES_BUILD_RULE_CONF]
|
BuildRuleFile = TargetTxt.TargetTxtDictionary[TAB_TAT_DEFINES_BUILD_RULE_CONF]
|
||||||
if not BuildRuleFile:
|
if not BuildRuleFile:
|
||||||
|
@ -603,9 +623,7 @@ def GetBuildRule():
|
||||||
EdkLogger.error("build", AUTOGEN_ERROR,
|
EdkLogger.error("build", AUTOGEN_ERROR,
|
||||||
ExtraData="The version number [%s] of build_rule.txt is less than the version number required by the AutoGen.(the minimum required version number is [%s])"\
|
ExtraData="The version number [%s] of build_rule.txt is less than the version number required by the AutoGen.(the minimum required version number is [%s])"\
|
||||||
% (RetVal._FileVersion, AutoGenReqBuildRuleVerNum))
|
% (RetVal._FileVersion, AutoGenReqBuildRuleVerNum))
|
||||||
return RetVal
|
self._ToolBuildRule = RetVal
|
||||||
|
|
||||||
BuildRuleObj = GetBuildRule()
|
|
||||||
|
|
||||||
# This acts like the main() function for the script, unless it is 'import'ed into another
|
# This acts like the main() function for the script, unless it is 'import'ed into another
|
||||||
# script.
|
# script.
|
||||||
|
|
|
@ -70,7 +70,7 @@ gAutoGenPhase = False
|
||||||
# The Conf dir outside the workspace dir
|
# The Conf dir outside the workspace dir
|
||||||
#
|
#
|
||||||
gConfDirectory = ''
|
gConfDirectory = ''
|
||||||
|
gCmdConfDir = ''
|
||||||
gBuildDirectory = ''
|
gBuildDirectory = ''
|
||||||
#
|
#
|
||||||
# The relative default database file path
|
# The relative default database file path
|
||||||
|
|
|
@ -10,7 +10,7 @@
|
||||||
#
|
#
|
||||||
from __future__ import print_function
|
from __future__ import print_function
|
||||||
from __future__ import absolute_import
|
from __future__ import absolute_import
|
||||||
from Common.buildoptions import BuildOption,BuildTarget
|
|
||||||
import Common.GlobalData as GlobalData
|
import Common.GlobalData as GlobalData
|
||||||
import Common.LongFilePathOs as os
|
import Common.LongFilePathOs as os
|
||||||
from . import EdkLogger
|
from . import EdkLogger
|
||||||
|
@ -144,11 +144,31 @@ class TargetTxtClassObject(object):
|
||||||
#
|
#
|
||||||
# @retval Target An instance of TargetTxtClassObject() with loaded target.txt
|
# @retval Target An instance of TargetTxtClassObject() with loaded target.txt
|
||||||
#
|
#
|
||||||
def TargetTxtDict():
|
|
||||||
|
class TargetTxtDict():
|
||||||
|
|
||||||
|
def __new__(cls, *args, **kw):
|
||||||
|
if not hasattr(cls, '_instance'):
|
||||||
|
orig = super(TargetTxtDict, cls)
|
||||||
|
cls._instance = orig.__new__(cls, *args, **kw)
|
||||||
|
return cls._instance
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
if not hasattr(self, 'Target'):
|
||||||
|
self.TxtTarget = None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def Target(self):
|
||||||
|
if not self.TxtTarget:
|
||||||
|
self._GetTarget()
|
||||||
|
return self.TxtTarget
|
||||||
|
|
||||||
|
def _GetTarget(self):
|
||||||
Target = TargetTxtClassObject()
|
Target = TargetTxtClassObject()
|
||||||
if BuildOption.ConfDirectory:
|
ConfDirectory = GlobalData.gCmdConfDir
|
||||||
|
if ConfDirectory:
|
||||||
# Get alternate Conf location, if it is absolute, then just use the absolute directory name
|
# Get alternate Conf location, if it is absolute, then just use the absolute directory name
|
||||||
ConfDirectoryPath = os.path.normpath(BuildOption.ConfDirectory)
|
ConfDirectoryPath = os.path.normpath(ConfDirectory)
|
||||||
|
|
||||||
if not os.path.isabs(ConfDirectoryPath):
|
if not os.path.isabs(ConfDirectoryPath):
|
||||||
# Since alternate directory name is not absolute, the alternate directory is located within the WORKSPACE
|
# Since alternate directory name is not absolute, the alternate directory is located within the WORKSPACE
|
||||||
|
@ -164,9 +184,7 @@ def TargetTxtDict():
|
||||||
targettxt = os.path.normpath(os.path.join(ConfDirectoryPath, gDefaultTargetTxtFile))
|
targettxt = os.path.normpath(os.path.join(ConfDirectoryPath, gDefaultTargetTxtFile))
|
||||||
if os.path.exists(targettxt):
|
if os.path.exists(targettxt):
|
||||||
Target.LoadTargetTxtFile(targettxt)
|
Target.LoadTargetTxtFile(targettxt)
|
||||||
return Target
|
self.TxtTarget = Target
|
||||||
|
|
||||||
TargetTxt = TargetTxtDict()
|
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
|
|
|
@ -14,7 +14,7 @@ import re
|
||||||
from . import EdkLogger
|
from . import EdkLogger
|
||||||
|
|
||||||
from .BuildToolError import *
|
from .BuildToolError import *
|
||||||
from Common.TargetTxtClassObject import TargetTxt
|
from Common.TargetTxtClassObject import TargetTxtDict
|
||||||
from Common.LongFilePathSupport import OpenLongFilePath as open
|
from Common.LongFilePathSupport import OpenLongFilePath as open
|
||||||
from Common.Misc import PathClass
|
from Common.Misc import PathClass
|
||||||
from Common.StringUtils import NormPath
|
from Common.StringUtils import NormPath
|
||||||
|
@ -262,20 +262,40 @@ class ToolDefClassObject(object):
|
||||||
#
|
#
|
||||||
# @retval ToolDef An instance of ToolDefClassObject() with loaded tools_def.txt
|
# @retval ToolDef An instance of ToolDefClassObject() with loaded tools_def.txt
|
||||||
#
|
#
|
||||||
def ToolDefDict(ConfDir):
|
|
||||||
Target = TargetTxt
|
|
||||||
|
class ToolDefDict():
|
||||||
|
|
||||||
|
def __new__(cls, ConfDir, *args, **kw):
|
||||||
|
if not hasattr(cls, '_instance'):
|
||||||
|
orig = super(ToolDefDict, cls)
|
||||||
|
cls._instance = orig.__new__(cls, *args, **kw)
|
||||||
|
return cls._instance
|
||||||
|
|
||||||
|
def __init__(self, ConfDir):
|
||||||
|
self.ConfDir = ConfDir
|
||||||
|
if not hasattr(self, 'ToolDef'):
|
||||||
|
self._ToolDef = None
|
||||||
|
|
||||||
|
@property
|
||||||
|
def ToolDef(self):
|
||||||
|
if not self._ToolDef:
|
||||||
|
self._GetToolDef()
|
||||||
|
return self._ToolDef
|
||||||
|
|
||||||
|
def _GetToolDef(self):
|
||||||
|
TargetObj = TargetTxtDict()
|
||||||
|
Target = TargetObj.Target
|
||||||
ToolDef = ToolDefClassObject()
|
ToolDef = ToolDefClassObject()
|
||||||
if TAB_TAT_DEFINES_TOOL_CHAIN_CONF in Target.TargetTxtDictionary:
|
if TAB_TAT_DEFINES_TOOL_CHAIN_CONF in Target.TargetTxtDictionary:
|
||||||
ToolsDefFile = Target.TargetTxtDictionary[TAB_TAT_DEFINES_TOOL_CHAIN_CONF]
|
ToolsDefFile = Target.TargetTxtDictionary[TAB_TAT_DEFINES_TOOL_CHAIN_CONF]
|
||||||
if ToolsDefFile:
|
if ToolsDefFile:
|
||||||
ToolDef.LoadToolDefFile(os.path.normpath(ToolsDefFile))
|
ToolDef.LoadToolDefFile(os.path.normpath(ToolsDefFile))
|
||||||
else:
|
else:
|
||||||
ToolDef.LoadToolDefFile(os.path.normpath(os.path.join(ConfDir, gDefaultToolsDefFile)))
|
ToolDef.LoadToolDefFile(os.path.normpath(os.path.join(self.ConfDir, gDefaultToolsDefFile)))
|
||||||
else:
|
else:
|
||||||
ToolDef.LoadToolDefFile(os.path.normpath(os.path.join(ConfDir, gDefaultToolsDefFile)))
|
ToolDef.LoadToolDefFile(os.path.normpath(os.path.join(self.ConfDir, gDefaultToolsDefFile)))
|
||||||
return ToolDef
|
self._ToolDef = ToolDef
|
||||||
|
|
||||||
ToolDef = ToolDefDict((os.path.join(os.getenv("WORKSPACE"),"Conf")))
|
|
||||||
|
|
||||||
##
|
##
|
||||||
#
|
#
|
||||||
|
|
|
@ -1,93 +0,0 @@
|
||||||
## @file
|
|
||||||
# build a platform or a module
|
|
||||||
#
|
|
||||||
# Copyright (c) 2014, Hewlett-Packard Development Company, L.P.<BR>
|
|
||||||
# Copyright (c) 2007 - 2019, Intel Corporation. All rights reserved.<BR>
|
|
||||||
# Copyright (c) 2018, Hewlett Packard Enterprise Development, L.P.<BR>
|
|
||||||
#
|
|
||||||
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
|
||||||
#
|
|
||||||
|
|
||||||
# Version and Copyright
|
|
||||||
from Common.BuildVersion import gBUILD_VERSION
|
|
||||||
from optparse import OptionParser
|
|
||||||
VersionNumber = "0.60" + ' ' + gBUILD_VERSION
|
|
||||||
__version__ = "%prog Version " + VersionNumber
|
|
||||||
__copyright__ = "Copyright (c) 2007 - 2018, Intel Corporation All rights reserved."
|
|
||||||
|
|
||||||
gParamCheck = []
|
|
||||||
def SingleCheckCallback(option, opt_str, value, parser):
|
|
||||||
if option not in gParamCheck:
|
|
||||||
setattr(parser.values, option.dest, value)
|
|
||||||
gParamCheck.append(option)
|
|
||||||
else:
|
|
||||||
parser.error("Option %s only allows one instance in command line!" % option)
|
|
||||||
|
|
||||||
def MyOptionParser():
|
|
||||||
Parser = OptionParser(description=__copyright__, version=__version__, prog="build.exe", usage="%prog [options] [all|fds|genc|genmake|clean|cleanall|cleanlib|modules|libraries|run]")
|
|
||||||
Parser.add_option("-a", "--arch", action="append", type="choice", choices=['IA32', 'X64', 'EBC', 'ARM', 'AARCH64'], dest="TargetArch",
|
|
||||||
help="ARCHS is one of list: IA32, X64, ARM, AARCH64 or EBC, which overrides target.txt's TARGET_ARCH definition. To specify more archs, please repeat this option.")
|
|
||||||
Parser.add_option("-p", "--platform", action="callback", type="string", dest="PlatformFile", callback=SingleCheckCallback,
|
|
||||||
help="Build the platform specified by the DSC file name argument, overriding target.txt's ACTIVE_PLATFORM definition.")
|
|
||||||
Parser.add_option("-m", "--module", action="callback", type="string", dest="ModuleFile", callback=SingleCheckCallback,
|
|
||||||
help="Build the module specified by the INF file name argument.")
|
|
||||||
Parser.add_option("-b", "--buildtarget", type="string", dest="BuildTarget", help="Using the TARGET to build the platform, overriding target.txt's TARGET definition.",
|
|
||||||
action="append")
|
|
||||||
Parser.add_option("-t", "--tagname", action="append", type="string", dest="ToolChain",
|
|
||||||
help="Using the Tool Chain Tagname to build the platform, overriding target.txt's TOOL_CHAIN_TAG definition.")
|
|
||||||
Parser.add_option("-x", "--sku-id", action="callback", type="string", dest="SkuId", callback=SingleCheckCallback,
|
|
||||||
help="Using this name of SKU ID to build the platform, overriding SKUID_IDENTIFIER in DSC file.")
|
|
||||||
|
|
||||||
Parser.add_option("-n", action="callback", type="int", dest="ThreadNumber", callback=SingleCheckCallback,
|
|
||||||
help="Build the platform using multi-threaded compiler. The value overrides target.txt's MAX_CONCURRENT_THREAD_NUMBER. When value is set to 0, tool automatically detect number of "\
|
|
||||||
"processor threads, set value to 1 means disable multi-thread build, and set value to more than 1 means user specify the threads number to build.")
|
|
||||||
|
|
||||||
Parser.add_option("-f", "--fdf", action="callback", type="string", dest="FdfFile", callback=SingleCheckCallback,
|
|
||||||
help="The name of the FDF file to use, which overrides the setting in the DSC file.")
|
|
||||||
Parser.add_option("-r", "--rom-image", action="append", type="string", dest="RomImage", default=[],
|
|
||||||
help="The name of FD to be generated. The name must be from [FD] section in FDF file.")
|
|
||||||
Parser.add_option("-i", "--fv-image", action="append", type="string", dest="FvImage", default=[],
|
|
||||||
help="The name of FV to be generated. The name must be from [FV] section in FDF file.")
|
|
||||||
Parser.add_option("-C", "--capsule-image", action="append", type="string", dest="CapName", default=[],
|
|
||||||
help="The name of Capsule to be generated. The name must be from [Capsule] section in FDF file.")
|
|
||||||
Parser.add_option("-u", "--skip-autogen", action="store_true", dest="SkipAutoGen", help="Skip AutoGen step.")
|
|
||||||
Parser.add_option("-e", "--re-parse", action="store_true", dest="Reparse", help="Re-parse all meta-data files.")
|
|
||||||
|
|
||||||
Parser.add_option("-c", "--case-insensitive", action="store_true", dest="CaseInsensitive", default=False, help="Don't check case of file name.")
|
|
||||||
|
|
||||||
Parser.add_option("-w", "--warning-as-error", action="store_true", dest="WarningAsError", help="Treat warning in tools as error.")
|
|
||||||
Parser.add_option("-j", "--log", action="store", dest="LogFile", help="Put log in specified file as well as on console.")
|
|
||||||
|
|
||||||
Parser.add_option("-s", "--silent", action="store_true", type=None, dest="SilentMode",
|
|
||||||
help="Make use of silent mode of (n)make.")
|
|
||||||
Parser.add_option("-q", "--quiet", action="store_true", type=None, help="Disable all messages except FATAL ERRORS.")
|
|
||||||
Parser.add_option("-v", "--verbose", action="store_true", type=None, help="Turn on verbose output with informational messages printed, "\
|
|
||||||
"including library instances selected, final dependency expression, "\
|
|
||||||
"and warning messages, etc.")
|
|
||||||
Parser.add_option("-d", "--debug", action="store", type="int", help="Enable debug messages at specified level.")
|
|
||||||
Parser.add_option("-D", "--define", action="append", type="string", dest="Macros", help="Macro: \"Name [= Value]\".")
|
|
||||||
|
|
||||||
Parser.add_option("-y", "--report-file", action="store", dest="ReportFile", help="Create/overwrite the report to the specified filename.")
|
|
||||||
Parser.add_option("-Y", "--report-type", action="append", type="choice", choices=['PCD', 'LIBRARY', 'FLASH', 'DEPEX', 'BUILD_FLAGS', 'FIXED_ADDRESS', 'HASH', 'EXECUTION_ORDER'], dest="ReportType", default=[],
|
|
||||||
help="Flags that control the type of build report to generate. Must be one of: [PCD, LIBRARY, FLASH, DEPEX, BUILD_FLAGS, FIXED_ADDRESS, HASH, EXECUTION_ORDER]. "\
|
|
||||||
"To specify more than one flag, repeat this option on the command line and the default flag set is [PCD, LIBRARY, FLASH, DEPEX, HASH, BUILD_FLAGS, FIXED_ADDRESS]")
|
|
||||||
Parser.add_option("-F", "--flag", action="store", type="string", dest="Flag",
|
|
||||||
help="Specify the specific option to parse EDK UNI file. Must be one of: [-c, -s]. -c is for EDK framework UNI file, and -s is for EDK UEFI UNI file. "\
|
|
||||||
"This option can also be specified by setting *_*_*_BUILD_FLAGS in [BuildOptions] section of platform DSC. If they are both specified, this value "\
|
|
||||||
"will override the setting in [BuildOptions] section of platform DSC.")
|
|
||||||
Parser.add_option("-N", "--no-cache", action="store_true", dest="DisableCache", default=False, help="Disable build cache mechanism")
|
|
||||||
Parser.add_option("--conf", action="store", type="string", dest="ConfDirectory", help="Specify the customized Conf directory.")
|
|
||||||
Parser.add_option("--check-usage", action="store_true", dest="CheckUsage", default=False, help="Check usage content of entries listed in INF file.")
|
|
||||||
Parser.add_option("--ignore-sources", action="store_true", dest="IgnoreSources", default=False, help="Focus to a binary build and ignore all source files")
|
|
||||||
Parser.add_option("--pcd", action="append", dest="OptionPcd", help="Set PCD value by command line. Format: \"PcdName=Value\" ")
|
|
||||||
Parser.add_option("-l", "--cmd-len", action="store", type="int", dest="CommandLength", help="Specify the maximum line length of build command. Default is 4096.")
|
|
||||||
Parser.add_option("--hash", action="store_true", dest="UseHashCache", default=False, help="Enable hash-based caching during build process.")
|
|
||||||
Parser.add_option("--binary-destination", action="store", type="string", dest="BinCacheDest", help="Generate a cache of binary files in the specified directory.")
|
|
||||||
Parser.add_option("--binary-source", action="store", type="string", dest="BinCacheSource", help="Consume a cache of binary files from the specified directory.")
|
|
||||||
Parser.add_option("--genfds-multi-thread", action="store_true", dest="GenfdsMultiThread", default=True, help="Enable GenFds multi thread to generate ffs file.")
|
|
||||||
Parser.add_option("--no-genfds-multi-thread", action="store_true", dest="NoGenfdsMultiThread", default=False, help="Disable GenFds multi thread to generate ffs file.")
|
|
||||||
Parser.add_option("--disable-include-path-check", action="store_true", dest="DisableIncludePathCheck", default=False, help="Disable the include path check for outside of package.")
|
|
||||||
(Opt, Args) = Parser.parse_args()
|
|
||||||
return (Opt, Args)
|
|
||||||
|
|
||||||
BuildOption, BuildTarget = MyOptionParser()
|
|
|
@ -20,7 +20,7 @@ from linecache import getlines
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
|
|
||||||
import Common.LongFilePathOs as os
|
import Common.LongFilePathOs as os
|
||||||
from Common.TargetTxtClassObject import TargetTxt
|
from Common.TargetTxtClassObject import TargetTxtDict
|
||||||
from Common.DataType import *
|
from Common.DataType import *
|
||||||
import Common.GlobalData as GlobalData
|
import Common.GlobalData as GlobalData
|
||||||
from Common import EdkLogger
|
from Common import EdkLogger
|
||||||
|
@ -210,6 +210,8 @@ def GenFdsApi(FdsCommandDict, WorkSpaceDataBase=None):
|
||||||
BuildConfigurationFile = os.path.normpath(os.path.join(ConfDirectoryPath, "target.txt"))
|
BuildConfigurationFile = os.path.normpath(os.path.join(ConfDirectoryPath, "target.txt"))
|
||||||
if os.path.isfile(BuildConfigurationFile) == True:
|
if os.path.isfile(BuildConfigurationFile) == True:
|
||||||
# if no build target given in command line, get it from target.txt
|
# if no build target given in command line, get it from target.txt
|
||||||
|
TargetObj = TargetTxtDict()
|
||||||
|
TargetTxt = TargetObj.Target
|
||||||
if not GenFdsGlobalVariable.TargetName:
|
if not GenFdsGlobalVariable.TargetName:
|
||||||
BuildTargetList = TargetTxt.TargetTxtDictionary[TAB_TAT_DEFINES_TARGET]
|
BuildTargetList = TargetTxt.TargetTxtDictionary[TAB_TAT_DEFINES_TARGET]
|
||||||
if len(BuildTargetList) != 1:
|
if len(BuildTargetList) != 1:
|
||||||
|
|
|
@ -23,9 +23,9 @@ from Common.BuildToolError import COMMAND_FAILURE,GENFDS_ERROR
|
||||||
from Common import EdkLogger
|
from Common import EdkLogger
|
||||||
from Common.Misc import SaveFileOnChange
|
from Common.Misc import SaveFileOnChange
|
||||||
|
|
||||||
from Common.TargetTxtClassObject import TargetTxt
|
from Common.TargetTxtClassObject import TargetTxtDict
|
||||||
from Common.ToolDefClassObject import ToolDef
|
from Common.ToolDefClassObject import ToolDefDict
|
||||||
from AutoGen.BuildEngine import BuildRuleObj
|
from AutoGen.BuildEngine import ToolBuildRule
|
||||||
import Common.DataType as DataType
|
import Common.DataType as DataType
|
||||||
from Common.Misc import PathClass
|
from Common.Misc import PathClass
|
||||||
from Common.LongFilePathSupport import OpenLongFilePath as open
|
from Common.LongFilePathSupport import OpenLongFilePath as open
|
||||||
|
@ -96,12 +96,15 @@ class GenFdsGlobalVariable:
|
||||||
def _LoadBuildRule():
|
def _LoadBuildRule():
|
||||||
if GenFdsGlobalVariable.__BuildRuleDatabase:
|
if GenFdsGlobalVariable.__BuildRuleDatabase:
|
||||||
return GenFdsGlobalVariable.__BuildRuleDatabase
|
return GenFdsGlobalVariable.__BuildRuleDatabase
|
||||||
GenFdsGlobalVariable.__BuildRuleDatabase = BuildRuleObj
|
BuildRule = ToolBuildRule()
|
||||||
ToolDefinitionFile = TargetTxt.TargetTxtDictionary[DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF]
|
GenFdsGlobalVariable.__BuildRuleDatabase = BuildRule.ToolBuildRule
|
||||||
|
TargetObj = TargetTxtDict()
|
||||||
|
ToolDefinitionFile = TargetObj.Target.TargetTxtDictionary[DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF]
|
||||||
if ToolDefinitionFile == '':
|
if ToolDefinitionFile == '':
|
||||||
ToolDefinitionFile = "Conf/tools_def.txt"
|
ToolDefinitionFile = "Conf/tools_def.txt"
|
||||||
if os.path.isfile(ToolDefinitionFile):
|
if os.path.isfile(ToolDefinitionFile):
|
||||||
ToolDefinition = ToolDef.ToolsDefTxtDatabase
|
ToolDefObj = ToolDefDict((os.path.join(os.getenv("WORKSPACE"), "Conf")))
|
||||||
|
ToolDefinition = ToolDefObj.ToolDef.ToolsDefTxtDatabase
|
||||||
if DataType.TAB_TOD_DEFINES_BUILDRULEFAMILY in ToolDefinition \
|
if DataType.TAB_TOD_DEFINES_BUILDRULEFAMILY in ToolDefinition \
|
||||||
and GenFdsGlobalVariable.ToolChainTag in ToolDefinition[DataType.TAB_TOD_DEFINES_BUILDRULEFAMILY] \
|
and GenFdsGlobalVariable.ToolChainTag in ToolDefinition[DataType.TAB_TOD_DEFINES_BUILDRULEFAMILY] \
|
||||||
and ToolDefinition[DataType.TAB_TOD_DEFINES_BUILDRULEFAMILY][GenFdsGlobalVariable.ToolChainTag]:
|
and ToolDefinition[DataType.TAB_TOD_DEFINES_BUILDRULEFAMILY][GenFdsGlobalVariable.ToolChainTag]:
|
||||||
|
@ -830,6 +833,8 @@ class GenFdsGlobalVariable:
|
||||||
# @param NameGuid The Guid name
|
# @param NameGuid The Guid name
|
||||||
#
|
#
|
||||||
def FindExtendTool(KeyStringList, CurrentArchList, NameGuid):
|
def FindExtendTool(KeyStringList, CurrentArchList, NameGuid):
|
||||||
|
ToolDefObj = ToolDefDict((os.path.join(os.getenv("WORKSPACE"), "Conf")))
|
||||||
|
ToolDef = ToolDefObj.ToolDef
|
||||||
ToolDb = ToolDef.ToolsDefTxtDatabase
|
ToolDb = ToolDef.ToolsDefTxtDatabase
|
||||||
# if user not specify filter, try to deduce it from global data.
|
# if user not specify filter, try to deduce it from global data.
|
||||||
if KeyStringList is None or KeyStringList == []:
|
if KeyStringList is None or KeyStringList == []:
|
||||||
|
|
|
@ -19,8 +19,8 @@ from Common.Misc import *
|
||||||
from types import *
|
from types import *
|
||||||
from Common.Expression import *
|
from Common.Expression import *
|
||||||
from CommonDataClass.CommonClass import SkuInfoClass
|
from CommonDataClass.CommonClass import SkuInfoClass
|
||||||
from Common.TargetTxtClassObject import TargetTxt
|
from Common.TargetTxtClassObject import TargetTxtDict
|
||||||
from Common.ToolDefClassObject import ToolDef
|
from Common.ToolDefClassObject import ToolDefDict
|
||||||
from .MetaDataTable import *
|
from .MetaDataTable import *
|
||||||
from .MetaFileTable import *
|
from .MetaFileTable import *
|
||||||
from .MetaFileParser import *
|
from .MetaFileParser import *
|
||||||
|
@ -3296,6 +3296,8 @@ class DscBuildData(PlatformBuildClassObject):
|
||||||
@property
|
@property
|
||||||
def ToolChainFamily(self):
|
def ToolChainFamily(self):
|
||||||
self._ToolChainFamily = TAB_COMPILER_MSFT
|
self._ToolChainFamily = TAB_COMPILER_MSFT
|
||||||
|
TargetObj = TargetTxtDict()
|
||||||
|
TargetTxt = TargetObj.Target
|
||||||
BuildConfigurationFile = os.path.normpath(os.path.join(GlobalData.gConfDirectory, "target.txt"))
|
BuildConfigurationFile = os.path.normpath(os.path.join(GlobalData.gConfDirectory, "target.txt"))
|
||||||
if os.path.isfile(BuildConfigurationFile) == True:
|
if os.path.isfile(BuildConfigurationFile) == True:
|
||||||
ToolDefinitionFile = TargetTxt.TargetTxtDictionary[DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF]
|
ToolDefinitionFile = TargetTxt.TargetTxtDictionary[DataType.TAB_TAT_DEFINES_TOOL_CHAIN_CONF]
|
||||||
|
@ -3303,7 +3305,8 @@ class DscBuildData(PlatformBuildClassObject):
|
||||||
ToolDefinitionFile = "tools_def.txt"
|
ToolDefinitionFile = "tools_def.txt"
|
||||||
ToolDefinitionFile = os.path.normpath(mws.join(self.WorkspaceDir, 'Conf', ToolDefinitionFile))
|
ToolDefinitionFile = os.path.normpath(mws.join(self.WorkspaceDir, 'Conf', ToolDefinitionFile))
|
||||||
if os.path.isfile(ToolDefinitionFile) == True:
|
if os.path.isfile(ToolDefinitionFile) == True:
|
||||||
ToolDefinition = ToolDef.ToolsDefTxtDatabase
|
ToolDefObj = ToolDefDict((os.path.join(os.getenv("WORKSPACE"), "Conf")))
|
||||||
|
ToolDefinition = ToolDefObj.ToolDef.ToolsDefTxtDatabase
|
||||||
if TAB_TOD_DEFINES_FAMILY not in ToolDefinition \
|
if TAB_TOD_DEFINES_FAMILY not in ToolDefinition \
|
||||||
or self._Toolchain not in ToolDefinition[TAB_TOD_DEFINES_FAMILY] \
|
or self._Toolchain not in ToolDefinition[TAB_TOD_DEFINES_FAMILY] \
|
||||||
or not ToolDefinition[TAB_TOD_DEFINES_FAMILY][self._Toolchain]:
|
or not ToolDefinition[TAB_TOD_DEFINES_FAMILY][self._Toolchain]:
|
||||||
|
|
|
@ -26,7 +26,7 @@ from threading import Thread,Event,BoundedSemaphore
|
||||||
import threading
|
import threading
|
||||||
from subprocess import Popen,PIPE, STDOUT
|
from subprocess import Popen,PIPE, STDOUT
|
||||||
from collections import OrderedDict, defaultdict
|
from collections import OrderedDict, defaultdict
|
||||||
from Common.buildoptions import BuildOption,BuildTarget
|
|
||||||
from AutoGen.PlatformAutoGen import PlatformAutoGen
|
from AutoGen.PlatformAutoGen import PlatformAutoGen
|
||||||
from AutoGen.ModuleAutoGen import ModuleAutoGen
|
from AutoGen.ModuleAutoGen import ModuleAutoGen
|
||||||
from AutoGen.WorkspaceAutoGen import WorkspaceAutoGen
|
from AutoGen.WorkspaceAutoGen import WorkspaceAutoGen
|
||||||
|
@ -35,8 +35,9 @@ from AutoGen.AutoGenWorker import AutoGenWorkerInProcess,AutoGenManager,\
|
||||||
from AutoGen import GenMake
|
from AutoGen import GenMake
|
||||||
from Common import Misc as Utils
|
from Common import Misc as Utils
|
||||||
|
|
||||||
from Common.TargetTxtClassObject import TargetTxt
|
from Common.TargetTxtClassObject import TargetTxtDict
|
||||||
from Common.ToolDefClassObject import ToolDef
|
from Common.ToolDefClassObject import ToolDefDict
|
||||||
|
from buildoptions import MyOptionParser
|
||||||
from Common.Misc import PathClass,SaveFileOnChange,RemoveDirectory
|
from Common.Misc import PathClass,SaveFileOnChange,RemoveDirectory
|
||||||
from Common.StringUtils import NormPath
|
from Common.StringUtils import NormPath
|
||||||
from Common.MultipleWorkspace import MultipleWorkspace as mws
|
from Common.MultipleWorkspace import MultipleWorkspace as mws
|
||||||
|
@ -731,11 +732,13 @@ class Build():
|
||||||
self.ConfDirectory = BuildOptions.ConfDirectory
|
self.ConfDirectory = BuildOptions.ConfDirectory
|
||||||
self.SpawnMode = True
|
self.SpawnMode = True
|
||||||
self.BuildReport = BuildReport(BuildOptions.ReportFile, BuildOptions.ReportType)
|
self.BuildReport = BuildReport(BuildOptions.ReportFile, BuildOptions.ReportType)
|
||||||
self.TargetTxt = TargetTxt
|
|
||||||
self.ToolDef = ToolDef
|
|
||||||
self.AutoGenTime = 0
|
self.AutoGenTime = 0
|
||||||
self.MakeTime = 0
|
self.MakeTime = 0
|
||||||
self.GenFdsTime = 0
|
self.GenFdsTime = 0
|
||||||
|
TargetObj = TargetTxtDict()
|
||||||
|
ToolDefObj = ToolDefDict((os.path.join(os.getenv("WORKSPACE"),"Conf")))
|
||||||
|
self.TargetTxt = TargetObj.Target
|
||||||
|
self.ToolDef = ToolDefObj.ToolDef
|
||||||
GlobalData.BuildOptionPcd = BuildOptions.OptionPcd if BuildOptions.OptionPcd else []
|
GlobalData.BuildOptionPcd = BuildOptions.OptionPcd if BuildOptions.OptionPcd else []
|
||||||
#Set global flag for build mode
|
#Set global flag for build mode
|
||||||
GlobalData.gIgnoreSource = BuildOptions.IgnoreSources
|
GlobalData.gIgnoreSource = BuildOptions.IgnoreSources
|
||||||
|
@ -816,8 +819,10 @@ class Build():
|
||||||
EdkLogger.quiet("%-16s = %s" % ("POSTBUILD", self.Postbuild))
|
EdkLogger.quiet("%-16s = %s" % ("POSTBUILD", self.Postbuild))
|
||||||
if self.Prebuild:
|
if self.Prebuild:
|
||||||
self.LaunchPrebuild()
|
self.LaunchPrebuild()
|
||||||
self.TargetTxt = TargetTxt
|
TargetObj = TargetTxtDict()
|
||||||
self.ToolDef = ToolDef
|
ToolDefObj = ToolDefDict((os.path.join(os.getenv("WORKSPACE"), "Conf")))
|
||||||
|
self.TargetTxt = TargetObj.Target
|
||||||
|
self.ToolDef = ToolDefObj.ToolDef
|
||||||
if not (self.LaunchPrebuildFlag and os.path.exists(self.PlatformBuildPath)):
|
if not (self.LaunchPrebuildFlag and os.path.exists(self.PlatformBuildPath)):
|
||||||
self.InitBuild()
|
self.InitBuild()
|
||||||
|
|
||||||
|
@ -2438,9 +2443,15 @@ def LogBuildTime(Time):
|
||||||
else:
|
else:
|
||||||
return None
|
return None
|
||||||
def ThreadNum():
|
def ThreadNum():
|
||||||
|
OptionParser = MyOptionParser()
|
||||||
|
if not OptionParser.BuildOption and not OptionParser.BuildTarget:
|
||||||
|
OptionParser.GetOption()
|
||||||
|
BuildOption, BuildTarget = OptionParser.BuildOption, OptionParser.BuildTarget
|
||||||
ThreadNumber = BuildOption.ThreadNumber
|
ThreadNumber = BuildOption.ThreadNumber
|
||||||
|
GlobalData.gCmdConfDir = BuildOption.ConfDirectory
|
||||||
if ThreadNumber is None:
|
if ThreadNumber is None:
|
||||||
ThreadNumber = TargetTxt.TargetTxtDictionary[TAB_TAT_DEFINES_MAX_CONCURRENT_THREAD_NUMBER]
|
TargetObj = TargetTxtDict()
|
||||||
|
ThreadNumber = TargetObj.Target.TargetTxtDictionary[TAB_TAT_DEFINES_MAX_CONCURRENT_THREAD_NUMBER]
|
||||||
if ThreadNumber == '':
|
if ThreadNumber == '':
|
||||||
ThreadNumber = 0
|
ThreadNumber = 0
|
||||||
else:
|
else:
|
||||||
|
@ -2475,7 +2486,10 @@ def Main():
|
||||||
#
|
#
|
||||||
# Parse the options and args
|
# Parse the options and args
|
||||||
#
|
#
|
||||||
Option, Target = BuildOption, BuildTarget
|
OptionParser = MyOptionParser()
|
||||||
|
if not OptionParser.BuildOption and not OptionParser.BuildTarget:
|
||||||
|
OptionParser.GetOption()
|
||||||
|
Option, Target = OptionParser.BuildOption, OptionParser.BuildTarget
|
||||||
GlobalData.gOptions = Option
|
GlobalData.gOptions = Option
|
||||||
GlobalData.gCaseInsensitive = Option.CaseInsensitive
|
GlobalData.gCaseInsensitive = Option.CaseInsensitive
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,105 @@
|
||||||
|
## @file
|
||||||
|
# build a platform or a module
|
||||||
|
#
|
||||||
|
# Copyright (c) 2014, Hewlett-Packard Development Company, L.P.<BR>
|
||||||
|
# Copyright (c) 2007 - 2019, Intel Corporation. All rights reserved.<BR>
|
||||||
|
# Copyright (c) 2018, Hewlett Packard Enterprise Development, L.P.<BR>
|
||||||
|
#
|
||||||
|
# SPDX-License-Identifier: BSD-2-Clause-Patent
|
||||||
|
#
|
||||||
|
|
||||||
|
# Version and Copyright
|
||||||
|
from Common.BuildVersion import gBUILD_VERSION
|
||||||
|
from optparse import OptionParser
|
||||||
|
VersionNumber = "0.60" + ' ' + gBUILD_VERSION
|
||||||
|
__version__ = "%prog Version " + VersionNumber
|
||||||
|
__copyright__ = "Copyright (c) 2007 - 2018, Intel Corporation All rights reserved."
|
||||||
|
|
||||||
|
gParamCheck = []
|
||||||
|
def SingleCheckCallback(option, opt_str, value, parser):
|
||||||
|
if option not in gParamCheck:
|
||||||
|
setattr(parser.values, option.dest, value)
|
||||||
|
gParamCheck.append(option)
|
||||||
|
else:
|
||||||
|
parser.error("Option %s only allows one instance in command line!" % option)
|
||||||
|
|
||||||
|
|
||||||
|
class MyOptionParser():
|
||||||
|
|
||||||
|
def __new__(cls, *args, **kw):
|
||||||
|
if not hasattr(cls, '_instance'):
|
||||||
|
orig = super(MyOptionParser, cls)
|
||||||
|
cls._instance = orig.__new__(cls, *args, **kw)
|
||||||
|
return cls._instance
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
if not hasattr(self, 'BuildOption'):
|
||||||
|
self.BuildOption = None
|
||||||
|
if not hasattr(self, 'BuildTarget'):
|
||||||
|
self.BuildTarget = None
|
||||||
|
|
||||||
|
def GetOption(self):
|
||||||
|
Parser = OptionParser(description=__copyright__, version=__version__, prog="build.exe", usage="%prog [options] [all|fds|genc|genmake|clean|cleanall|cleanlib|modules|libraries|run]")
|
||||||
|
Parser.add_option("-a", "--arch", action="append", type="choice", choices=['IA32', 'X64', 'EBC', 'ARM', 'AARCH64'], dest="TargetArch",
|
||||||
|
help="ARCHS is one of list: IA32, X64, ARM, AARCH64 or EBC, which overrides target.txt's TARGET_ARCH definition. To specify more archs, please repeat this option.")
|
||||||
|
Parser.add_option("-p", "--platform", action="callback", type="string", dest="PlatformFile", callback=SingleCheckCallback,
|
||||||
|
help="Build the platform specified by the DSC file name argument, overriding target.txt's ACTIVE_PLATFORM definition.")
|
||||||
|
Parser.add_option("-m", "--module", action="callback", type="string", dest="ModuleFile", callback=SingleCheckCallback,
|
||||||
|
help="Build the module specified by the INF file name argument.")
|
||||||
|
Parser.add_option("-b", "--buildtarget", type="string", dest="BuildTarget", help="Using the TARGET to build the platform, overriding target.txt's TARGET definition.",
|
||||||
|
action="append")
|
||||||
|
Parser.add_option("-t", "--tagname", action="append", type="string", dest="ToolChain",
|
||||||
|
help="Using the Tool Chain Tagname to build the platform, overriding target.txt's TOOL_CHAIN_TAG definition.")
|
||||||
|
Parser.add_option("-x", "--sku-id", action="callback", type="string", dest="SkuId", callback=SingleCheckCallback,
|
||||||
|
help="Using this name of SKU ID to build the platform, overriding SKUID_IDENTIFIER in DSC file.")
|
||||||
|
|
||||||
|
Parser.add_option("-n", action="callback", type="int", dest="ThreadNumber", callback=SingleCheckCallback,
|
||||||
|
help="Build the platform using multi-threaded compiler. The value overrides target.txt's MAX_CONCURRENT_THREAD_NUMBER. When value is set to 0, tool automatically detect number of "\
|
||||||
|
"processor threads, set value to 1 means disable multi-thread build, and set value to more than 1 means user specify the threads number to build.")
|
||||||
|
|
||||||
|
Parser.add_option("-f", "--fdf", action="callback", type="string", dest="FdfFile", callback=SingleCheckCallback,
|
||||||
|
help="The name of the FDF file to use, which overrides the setting in the DSC file.")
|
||||||
|
Parser.add_option("-r", "--rom-image", action="append", type="string", dest="RomImage", default=[],
|
||||||
|
help="The name of FD to be generated. The name must be from [FD] section in FDF file.")
|
||||||
|
Parser.add_option("-i", "--fv-image", action="append", type="string", dest="FvImage", default=[],
|
||||||
|
help="The name of FV to be generated. The name must be from [FV] section in FDF file.")
|
||||||
|
Parser.add_option("-C", "--capsule-image", action="append", type="string", dest="CapName", default=[],
|
||||||
|
help="The name of Capsule to be generated. The name must be from [Capsule] section in FDF file.")
|
||||||
|
Parser.add_option("-u", "--skip-autogen", action="store_true", dest="SkipAutoGen", help="Skip AutoGen step.")
|
||||||
|
Parser.add_option("-e", "--re-parse", action="store_true", dest="Reparse", help="Re-parse all meta-data files.")
|
||||||
|
|
||||||
|
Parser.add_option("-c", "--case-insensitive", action="store_true", dest="CaseInsensitive", default=False, help="Don't check case of file name.")
|
||||||
|
|
||||||
|
Parser.add_option("-w", "--warning-as-error", action="store_true", dest="WarningAsError", help="Treat warning in tools as error.")
|
||||||
|
Parser.add_option("-j", "--log", action="store", dest="LogFile", help="Put log in specified file as well as on console.")
|
||||||
|
|
||||||
|
Parser.add_option("-s", "--silent", action="store_true", type=None, dest="SilentMode",
|
||||||
|
help="Make use of silent mode of (n)make.")
|
||||||
|
Parser.add_option("-q", "--quiet", action="store_true", type=None, help="Disable all messages except FATAL ERRORS.")
|
||||||
|
Parser.add_option("-v", "--verbose", action="store_true", type=None, help="Turn on verbose output with informational messages printed, "\
|
||||||
|
"including library instances selected, final dependency expression, "\
|
||||||
|
"and warning messages, etc.")
|
||||||
|
Parser.add_option("-d", "--debug", action="store", type="int", help="Enable debug messages at specified level.")
|
||||||
|
Parser.add_option("-D", "--define", action="append", type="string", dest="Macros", help="Macro: \"Name [= Value]\".")
|
||||||
|
|
||||||
|
Parser.add_option("-y", "--report-file", action="store", dest="ReportFile", help="Create/overwrite the report to the specified filename.")
|
||||||
|
Parser.add_option("-Y", "--report-type", action="append", type="choice", choices=['PCD', 'LIBRARY', 'FLASH', 'DEPEX', 'BUILD_FLAGS', 'FIXED_ADDRESS', 'HASH', 'EXECUTION_ORDER'], dest="ReportType", default=[],
|
||||||
|
help="Flags that control the type of build report to generate. Must be one of: [PCD, LIBRARY, FLASH, DEPEX, BUILD_FLAGS, FIXED_ADDRESS, HASH, EXECUTION_ORDER]. "\
|
||||||
|
"To specify more than one flag, repeat this option on the command line and the default flag set is [PCD, LIBRARY, FLASH, DEPEX, HASH, BUILD_FLAGS, FIXED_ADDRESS]")
|
||||||
|
Parser.add_option("-F", "--flag", action="store", type="string", dest="Flag",
|
||||||
|
help="Specify the specific option to parse EDK UNI file. Must be one of: [-c, -s]. -c is for EDK framework UNI file, and -s is for EDK UEFI UNI file. "\
|
||||||
|
"This option can also be specified by setting *_*_*_BUILD_FLAGS in [BuildOptions] section of platform DSC. If they are both specified, this value "\
|
||||||
|
"will override the setting in [BuildOptions] section of platform DSC.")
|
||||||
|
Parser.add_option("-N", "--no-cache", action="store_true", dest="DisableCache", default=False, help="Disable build cache mechanism")
|
||||||
|
Parser.add_option("--conf", action="store", type="string", dest="ConfDirectory", help="Specify the customized Conf directory.")
|
||||||
|
Parser.add_option("--check-usage", action="store_true", dest="CheckUsage", default=False, help="Check usage content of entries listed in INF file.")
|
||||||
|
Parser.add_option("--ignore-sources", action="store_true", dest="IgnoreSources", default=False, help="Focus to a binary build and ignore all source files")
|
||||||
|
Parser.add_option("--pcd", action="append", dest="OptionPcd", help="Set PCD value by command line. Format: \"PcdName=Value\" ")
|
||||||
|
Parser.add_option("-l", "--cmd-len", action="store", type="int", dest="CommandLength", help="Specify the maximum line length of build command. Default is 4096.")
|
||||||
|
Parser.add_option("--hash", action="store_true", dest="UseHashCache", default=False, help="Enable hash-based caching during build process.")
|
||||||
|
Parser.add_option("--binary-destination", action="store", type="string", dest="BinCacheDest", help="Generate a cache of binary files in the specified directory.")
|
||||||
|
Parser.add_option("--binary-source", action="store", type="string", dest="BinCacheSource", help="Consume a cache of binary files from the specified directory.")
|
||||||
|
Parser.add_option("--genfds-multi-thread", action="store_true", dest="GenfdsMultiThread", default=True, help="Enable GenFds multi thread to generate ffs file.")
|
||||||
|
Parser.add_option("--no-genfds-multi-thread", action="store_true", dest="NoGenfdsMultiThread", default=False, help="Disable GenFds multi thread to generate ffs file.")
|
||||||
|
Parser.add_option("--disable-include-path-check", action="store_true", dest="DisableIncludePathCheck", default=False, help="Disable the include path check for outside of package.")
|
||||||
|
self.BuildOption, self.BuildTarget = Parser.parse_args()
|
Loading…
Reference in New Issue