mirror of
https://github.com/acidanthera/audk.git
synced 2025-07-31 01:24:12 +02:00
BaseTools:PCD value error in structure pcd sku case.
Defined 2 PCDs(Test4 & Test401) and 2 SKUs(DEFAULT & _), then set "SKUID_Defines" to ALL, for FixedAtBuild gEfiStructuredPcdPkgTokenSpaceGuid. Test401 in this case, its value should get from "Default" SKU, not from "_" SKU, but we does not set value in SKU "_" in dsc, so Test401 should only display the value get from dec. Cc: Bob Feng <bob.c.feng@intel.com> Cc: Liming Gao <liming.gao@intel.com> Contributed-under: TianoCore Contribution Agreement 1.1 Signed-off-by: Zhiju.Fan <zhijux.fan@intel.com> Reviewed-by: Bob Feng <bob.c.feng@intel.com>
This commit is contained in:
parent
e8d13fef90
commit
8a64c7ea00
@ -103,7 +103,7 @@ MixedPcd = {}
|
|||||||
|
|
||||||
# Structure Pcd dict
|
# Structure Pcd dict
|
||||||
gStructurePcd = {}
|
gStructurePcd = {}
|
||||||
|
gPcdSkuOverrides={}
|
||||||
# Pcd name for the Pcd which used in the Conditional directives
|
# Pcd name for the Pcd which used in the Conditional directives
|
||||||
gConditionalPcds = []
|
gConditionalPcds = []
|
||||||
|
|
||||||
|
@ -1537,6 +1537,9 @@ class DscBuildData(PlatformBuildClassObject):
|
|||||||
stru_pcd.SkuOverrideValues[skuid] = copy.deepcopy(stru_pcd.SkuOverrideValues[nextskuid]) if not NoDefault else copy.deepcopy({defaultstorename: stru_pcd.DefaultValues for defaultstorename in DefaultStores} if DefaultStores else {}) #{TAB_DEFAULT_STORES_DEFAULT:stru_pcd.DefaultValues})
|
stru_pcd.SkuOverrideValues[skuid] = copy.deepcopy(stru_pcd.SkuOverrideValues[nextskuid]) if not NoDefault else copy.deepcopy({defaultstorename: stru_pcd.DefaultValues for defaultstorename in DefaultStores} if DefaultStores else {}) #{TAB_DEFAULT_STORES_DEFAULT:stru_pcd.DefaultValues})
|
||||||
if not NoDefault:
|
if not NoDefault:
|
||||||
stru_pcd.ValueChain.add((skuid, ''))
|
stru_pcd.ValueChain.add((skuid, ''))
|
||||||
|
if 'DEFAULT' in stru_pcd.SkuOverrideValues and not GlobalData.gPcdSkuOverrides.get((stru_pcd.TokenCName, stru_pcd.TokenSpaceGuidCName)):
|
||||||
|
GlobalData.gPcdSkuOverrides.update(
|
||||||
|
{(stru_pcd.TokenCName, stru_pcd.TokenSpaceGuidCName): {'DEFAULT':stru_pcd.SkuOverrideValues['DEFAULT']}})
|
||||||
if stru_pcd.Type in [self._PCD_TYPE_STRING_[MODEL_PCD_DYNAMIC_HII], self._PCD_TYPE_STRING_[MODEL_PCD_DYNAMIC_EX_HII]]:
|
if stru_pcd.Type in [self._PCD_TYPE_STRING_[MODEL_PCD_DYNAMIC_HII], self._PCD_TYPE_STRING_[MODEL_PCD_DYNAMIC_EX_HII]]:
|
||||||
for skuid in SkuIds:
|
for skuid in SkuIds:
|
||||||
nextskuid = skuid
|
nextskuid = skuid
|
||||||
|
@ -1288,6 +1288,9 @@ class PcdReport(object):
|
|||||||
FileWrite(File, ' %-*s : %6s %10s = %s' % (self.MaxLen, Flag + ' ' + PcdTokenCName, TypeName, '(' + Pcd.DatumType + ')', Value))
|
FileWrite(File, ' %-*s : %6s %10s = %s' % (self.MaxLen, Flag + ' ' + PcdTokenCName, TypeName, '(' + Pcd.DatumType + ')', Value))
|
||||||
if IsStructure:
|
if IsStructure:
|
||||||
FiledOverrideFlag = False
|
FiledOverrideFlag = False
|
||||||
|
if (Pcd.TokenCName,Pcd.TokenSpaceGuidCName) in GlobalData.gPcdSkuOverrides:
|
||||||
|
OverrideValues = GlobalData.gPcdSkuOverrides[(Pcd.TokenCName,Pcd.TokenSpaceGuidCName)]
|
||||||
|
else:
|
||||||
OverrideValues = Pcd.SkuOverrideValues
|
OverrideValues = Pcd.SkuOverrideValues
|
||||||
if OverrideValues:
|
if OverrideValues:
|
||||||
for Data in OverrideValues.values():
|
for Data in OverrideValues.values():
|
||||||
|
Loading…
x
Reference in New Issue
Block a user