BaseTools: Enable the flag to treat dynamic pcd as dynamicEx
Ref: https://bugzilla.tianocore.org/show_bug.cgi?id=1688 In order to support binary build, build tool add a flag to convert type of Dynamic Pcd to DynamicEx Pcd User can append -D PCD_DYNAMIC_AS_DYNAMICEX to build command to enable this function. Also, user can add "PCD_DYNAMIC_AS_DYNAMICEX = TRUE/FALSE" to the defines section of Dsc file to enable this function. PCD_DYNAMIC_AS_DYNAMICEX is a new reserved key word for this function. Signed-off-by: Bob Feng <bob.c.feng@intel.com> Cc: Liming Gao <liming.gao@intel.com> Cc: Yuwei Chen <yuwei.chen@intel.com> Cc: Michael D Kinney <michael.d.kinney@intel.com> Cc: Nate DeSimone <nathaniel.l.desimone@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
This commit is contained in:
@ -12,7 +12,9 @@ import re
|
||||
from collections import OrderedDict
|
||||
from Common.Misc import CopyDict,ArrayIndex
|
||||
import copy
|
||||
from CommonDataClass.DataClass import *
|
||||
import Common.EdkLogger as EdkLogger
|
||||
import Common.GlobalData as GlobalData
|
||||
from Common.BuildToolError import OPTION_VALUE_INVALID
|
||||
from Common.caching import cached_property
|
||||
StructPattern = re.compile(r'[_a-zA-Z][0-9A-Za-z_\[\]]*$')
|
||||
@ -398,6 +400,67 @@ class StructurePcd(PcdClassObject):
|
||||
|
||||
LibraryClassObject = namedtuple('LibraryClassObject', ['LibraryClass','SupModList'])
|
||||
|
||||
class BuildData(object):
|
||||
# dict used to convert PCD type in database to string used by build tool
|
||||
|
||||
_PCD_TYPE_STRING_ = {
|
||||
MODEL_PCD_FIXED_AT_BUILD : TAB_PCDS_FIXED_AT_BUILD,
|
||||
MODEL_PCD_PATCHABLE_IN_MODULE : TAB_PCDS_PATCHABLE_IN_MODULE,
|
||||
MODEL_PCD_FEATURE_FLAG : TAB_PCDS_FEATURE_FLAG,
|
||||
MODEL_PCD_DYNAMIC : TAB_PCDS_DYNAMIC,
|
||||
MODEL_PCD_DYNAMIC_DEFAULT : TAB_PCDS_DYNAMIC,
|
||||
MODEL_PCD_DYNAMIC_HII : TAB_PCDS_DYNAMIC_HII,
|
||||
MODEL_PCD_DYNAMIC_VPD : TAB_PCDS_DYNAMIC_VPD,
|
||||
MODEL_PCD_DYNAMIC_EX : TAB_PCDS_DYNAMIC_EX,
|
||||
MODEL_PCD_DYNAMIC_EX_DEFAULT : TAB_PCDS_DYNAMIC_EX,
|
||||
MODEL_PCD_DYNAMIC_EX_HII : TAB_PCDS_DYNAMIC_EX_HII,
|
||||
MODEL_PCD_DYNAMIC_EX_VPD : TAB_PCDS_DYNAMIC_EX_VPD,
|
||||
}
|
||||
|
||||
def UpdatePcdTypeDict(self):
|
||||
if GlobalData.gCommandLineDefines.get(TAB_DSC_DEFINES_PCD_DYNAMIC_AS_DYNAMICEX,"FALSE").upper() == "TRUE":
|
||||
self._PCD_TYPE_STRING_ = {
|
||||
MODEL_PCD_FIXED_AT_BUILD : TAB_PCDS_FIXED_AT_BUILD,
|
||||
MODEL_PCD_PATCHABLE_IN_MODULE : TAB_PCDS_PATCHABLE_IN_MODULE,
|
||||
MODEL_PCD_FEATURE_FLAG : TAB_PCDS_FEATURE_FLAG,
|
||||
MODEL_PCD_DYNAMIC : TAB_PCDS_DYNAMIC_EX,
|
||||
MODEL_PCD_DYNAMIC_DEFAULT : TAB_PCDS_DYNAMIC_EX,
|
||||
MODEL_PCD_DYNAMIC_HII : TAB_PCDS_DYNAMIC_EX_HII,
|
||||
MODEL_PCD_DYNAMIC_VPD : TAB_PCDS_DYNAMIC_EX_VPD,
|
||||
MODEL_PCD_DYNAMIC_EX : TAB_PCDS_DYNAMIC_EX,
|
||||
MODEL_PCD_DYNAMIC_EX_DEFAULT : TAB_PCDS_DYNAMIC_EX,
|
||||
MODEL_PCD_DYNAMIC_EX_HII : TAB_PCDS_DYNAMIC_EX_HII,
|
||||
MODEL_PCD_DYNAMIC_EX_VPD : TAB_PCDS_DYNAMIC_EX_VPD,
|
||||
}
|
||||
|
||||
## Convert the class to a string
|
||||
#
|
||||
# Convert member MetaFile of the class to a string
|
||||
#
|
||||
# @retval string Formatted String
|
||||
#
|
||||
def __str__(self):
|
||||
return str(self.MetaFile)
|
||||
|
||||
## Override __eq__ function
|
||||
#
|
||||
# Check whether ModuleBuildClassObjects are the same
|
||||
#
|
||||
# @retval False The two ModuleBuildClassObjects are different
|
||||
# @retval True The two ModuleBuildClassObjects are the same
|
||||
#
|
||||
def __eq__(self, Other):
|
||||
return self.MetaFile == Other
|
||||
|
||||
## Override __hash__ function
|
||||
#
|
||||
# Use MetaFile as key in hash table
|
||||
#
|
||||
# @retval string Key for hash table
|
||||
#
|
||||
def __hash__(self):
|
||||
return hash(self.MetaFile)
|
||||
|
||||
## ModuleBuildClassObject
|
||||
#
|
||||
# This Class defines ModuleBuildClass
|
||||
@ -442,7 +505,7 @@ LibraryClassObject = namedtuple('LibraryClassObject', ['LibraryClass','SupModLis
|
||||
# { [BuildOptionKey] : BuildOptionValue}
|
||||
# @var Depex: To store value for Depex
|
||||
#
|
||||
class ModuleBuildClassObject(object):
|
||||
class ModuleBuildClassObject(BuildData):
|
||||
def __init__(self):
|
||||
self.AutoGenVersion = 0
|
||||
self.MetaFile = ''
|
||||
@ -476,34 +539,6 @@ class ModuleBuildClassObject(object):
|
||||
self.StrPcdSet = []
|
||||
self.StrPcdOverallValue = {}
|
||||
|
||||
## Convert the class to a string
|
||||
#
|
||||
# Convert member MetaFile of the class to a string
|
||||
#
|
||||
# @retval string Formatted String
|
||||
#
|
||||
def __str__(self):
|
||||
return str(self.MetaFile)
|
||||
|
||||
## Override __eq__ function
|
||||
#
|
||||
# Check whether ModuleBuildClassObjects are the same
|
||||
#
|
||||
# @retval False The two ModuleBuildClassObjects are different
|
||||
# @retval True The two ModuleBuildClassObjects are the same
|
||||
#
|
||||
def __eq__(self, Other):
|
||||
return self.MetaFile == Other
|
||||
|
||||
## Override __hash__ function
|
||||
#
|
||||
# Use MetaFile as key in hash table
|
||||
#
|
||||
# @retval string Key for hash table
|
||||
#
|
||||
def __hash__(self):
|
||||
return hash(self.MetaFile)
|
||||
|
||||
## PackageBuildClassObject
|
||||
#
|
||||
# This Class defines PackageBuildClass
|
||||
@ -527,7 +562,7 @@ class ModuleBuildClassObject(object):
|
||||
# @var Pcds: To store value for Pcds, it is a set structure as
|
||||
# { [(PcdCName, PcdGuidCName)] : PcdClassObject}
|
||||
#
|
||||
class PackageBuildClassObject(object):
|
||||
class PackageBuildClassObject(BuildData):
|
||||
def __init__(self):
|
||||
self.MetaFile = ''
|
||||
self.PackageName = ''
|
||||
@ -541,34 +576,6 @@ class PackageBuildClassObject(object):
|
||||
self.LibraryClasses = {}
|
||||
self.Pcds = {}
|
||||
|
||||
## Convert the class to a string
|
||||
#
|
||||
# Convert member MetaFile of the class to a string
|
||||
#
|
||||
# @retval string Formatted String
|
||||
#
|
||||
def __str__(self):
|
||||
return str(self.MetaFile)
|
||||
|
||||
## Override __eq__ function
|
||||
#
|
||||
# Check whether PackageBuildClassObjects are the same
|
||||
#
|
||||
# @retval False The two PackageBuildClassObjects are different
|
||||
# @retval True The two PackageBuildClassObjects are the same
|
||||
#
|
||||
def __eq__(self, Other):
|
||||
return self.MetaFile == Other
|
||||
|
||||
## Override __hash__ function
|
||||
#
|
||||
# Use MetaFile as key in hash table
|
||||
#
|
||||
# @retval string Key for hash table
|
||||
#
|
||||
def __hash__(self):
|
||||
return hash(self.MetaFile)
|
||||
|
||||
## PlatformBuildClassObject
|
||||
#
|
||||
# This Class defines PlatformBuildClass
|
||||
@ -597,7 +604,7 @@ class PackageBuildClassObject(object):
|
||||
# @var BuildOptions: To store value for BuildOptions, it is a set structure as
|
||||
# { [BuildOptionKey] : BuildOptionValue }
|
||||
#
|
||||
class PlatformBuildClassObject(object):
|
||||
class PlatformBuildClassObject(BuildData):
|
||||
def __init__(self):
|
||||
self.MetaFile = ''
|
||||
self.PlatformName = ''
|
||||
@ -616,31 +623,3 @@ class PlatformBuildClassObject(object):
|
||||
self.Libraries = {}
|
||||
self.Pcds = {}
|
||||
self.BuildOptions = {}
|
||||
|
||||
## Convert the class to a string
|
||||
#
|
||||
# Convert member MetaFile of the class to a string
|
||||
#
|
||||
# @retval string Formatted String
|
||||
#
|
||||
def __str__(self):
|
||||
return str(self.MetaFile)
|
||||
|
||||
## Override __eq__ function
|
||||
#
|
||||
# Check whether PlatformBuildClassObjects are the same
|
||||
#
|
||||
# @retval False The two PlatformBuildClassObjects are different
|
||||
# @retval True The two PlatformBuildClassObjects are the same
|
||||
#
|
||||
def __eq__(self, Other):
|
||||
return self.MetaFile == Other
|
||||
|
||||
## Override __hash__ function
|
||||
#
|
||||
# Use MetaFile as key in hash table
|
||||
#
|
||||
# @retval string Key for hash table
|
||||
#
|
||||
def __hash__(self):
|
||||
return hash(self.MetaFile)
|
||||
|
Reference in New Issue
Block a user