From: "Gao, Liming" <liming.gao@intel.com>
To: "Zhu, Yonghong" <yonghong.zhu@intel.com>,
"edk2-devel@lists.01.org" <edk2-devel@lists.01.org>
Subject: Re: [Patch] BaseTools: Fix two cases that use GUID CName as PCD Value
Date: Mon, 9 Apr 2018 05:38:52 +0000 [thread overview]
Message-ID: <4A89E2EF3DFEDB4C8BFDE51014F606A14E20A4C7@SHSMSX104.ccr.corp.intel.com> (raw)
In-Reply-To: <1522197771-18200-1-git-send-email-yonghong.zhu@intel.com>
Reviewed-by: Liming Gao <liming.gao@intel.com>
>-----Original Message-----
>From: edk2-devel [mailto:edk2-devel-bounces@lists.01.org] On Behalf Of
>Yonghong Zhu
>Sent: Wednesday, March 28, 2018 8:43 AM
>To: edk2-devel@lists.01.org
>Subject: [edk2] [Patch] BaseTools: Fix two cases that use GUID CName as PCD
>Value
>
>1. use CName format in components section:
> [Components]
> TestPkg/TestDriver.inf {
> <PcdsFixedAtBuild>
> PcdToken.PcdName |{GUID(TestGuid)}|VOID*|16
> }
>
>2. Use Guid CName format in INF and the Guid is defined in the DEC
>file but not write in driver's [Guids] section.
> PcdToken.PcdName | {GUID(TestGuid)}
>
>Contributed-under: TianoCore Contribution Agreement 1.1
>Signed-off-by: Yonghong Zhu <yonghong.zhu@intel.com>
>---
> BaseTools/Source/Python/AutoGen/AutoGen.py | 9 +++------
> BaseTools/Source/Python/Workspace/InfBuildData.py | 1 +
> 2 files changed, 4 insertions(+), 6 deletions(-)
>
>diff --git a/BaseTools/Source/Python/AutoGen/AutoGen.py
>b/BaseTools/Source/Python/AutoGen/AutoGen.py
>index 95e3e91..0057839 100644
>--- a/BaseTools/Source/Python/AutoGen/AutoGen.py
>+++ b/BaseTools/Source/Python/AutoGen/AutoGen.py
>@@ -395,16 +395,12 @@ class WorkspaceAutoGen(AutoGen):
> self.CapTargetList = []
>
> # apply SKU and inject PCDs from Flash Definition file
> for Arch in self.ArchList:
> Platform = self.BuildDatabase[self.MetaFile, Arch, Target, Toolchain]
>-
>-
>-
>-
>-
>-
>+ PlatformPcds = Platform.Pcds
>+ self._GuidDict = Platform._GuidDict
> SourcePcdDict = {'DynamicEx':[],
>'PatchableInModule':[],'Dynamic':[],'FixedAtBuild':[]}
> BinaryPcdDict = {'DynamicEx':[], 'PatchableInModule':[]}
> SourcePcdDict_Keys = SourcePcdDict.keys()
> BinaryPcdDict_Keys = BinaryPcdDict.keys()
>
>@@ -2797,10 +2793,11 @@ class ModuleAutoGen(AutoGen):
> EdkLogger.debug(EdkLogger.DEBUG_9, "AutoGen module [%s] [%s]" %
>(ModuleFile, Arch))
> GlobalData.gProcessingFile = "%s [%s, %s, %s]" % (ModuleFile, Arch,
>Toolchain, Target)
>
> self.Workspace = Workspace
> self.WorkspaceDir = Workspace.WorkspaceDir
>+ self._GuidDict = Workspace._GuidDict
>
> self.MetaFile = ModuleFile
> self.PlatformInfo = PlatformAutoGen(Workspace, PlatformFile, Target,
>Toolchain, Arch)
> # check if this module is employed by active platform
> if not self.PlatformInfo.ValidModule(self.MetaFile):
>diff --git a/BaseTools/Source/Python/Workspace/InfBuildData.py
>b/BaseTools/Source/Python/Workspace/InfBuildData.py
>index 7ea9b56..7e1b8ba 100644
>--- a/BaseTools/Source/Python/Workspace/InfBuildData.py
>+++ b/BaseTools/Source/Python/Workspace/InfBuildData.py
>@@ -1054,10 +1054,11 @@ class InfBuildData(ModuleBuildClassObject):
> # if platform doesn't give its type, use 'lowest' one in the
> # following order, if any
> #
> # "FixedAtBuild", "PatchableInModule", "FeatureFlag", "Dynamic",
>"DynamicEx"
> #
>+ self.Guids.update(Package.Guids)
> PcdType = self._PCD_TYPE_STRING_[Type]
> if Type == MODEL_PCD_DYNAMIC:
> Pcd.Pending = True
> for T in ["FixedAtBuild", "PatchableInModule", "FeatureFlag",
>"Dynamic", "DynamicEx"]:
> if (PcdRealName, TokenSpaceGuid) in GlobalData.MixedPcd:
>--
>2.6.1.windows.1
>
>_______________________________________________
>edk2-devel mailing list
>edk2-devel@lists.01.org
>https://lists.01.org/mailman/listinfo/edk2-devel
prev parent reply other threads:[~2018-04-09 5:38 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-03-28 0:42 [Patch] BaseTools: Fix two cases that use GUID CName as PCD Value Yonghong Zhu
2018-04-09 5:38 ` Gao, Liming [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-list from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4A89E2EF3DFEDB4C8BFDE51014F606A14E20A4C7@SHSMSX104.ccr.corp.intel.com \
--to=devel@edk2.groups.io \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox