* [PATCH v2] BaseTools:Extend the binary cache to support library cache @ 2019-05-29 1:46 Steven Shi 2019-05-29 11:13 ` [edk2-devel] " Leif Lindholm 0 siblings, 1 reply; 3+ messages in thread From: Steven Shi @ 2019-05-29 1:46 UTC (permalink / raw) To: devel; +Cc: liming.gao, bob.c.feng, christian.rodriguez, zhijux.fan V2 change: Simplify the library cache implementation and remove CacheRestored flag based filter. Use the current CanSkipbyHash() filter in AddDependency() instead. V1 change: https://bugzilla.tianocore.org/show_bug.cgi?id=1797 Current binary cache doesn't support to save and restore the library module. If a driver module cache miss happen, all its dependency library modules need rebuild which is very time-consuming. This patch is to entend the binary cache to support library. Cc: Liming Gao <liming.gao@intel.com> Cc: Bob Feng <bob.c.feng@intel.com> Cc: Christian Rodriguez <christian.rodriguez@intel.com> Signed-off-by: Steven Shi <steven.shi@intel.com> --- BaseTools/Source/Python/AutoGen/AutoGen.py | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/BaseTools/Source/Python/AutoGen/AutoGen.py b/BaseTools/Source/Python/AutoGen/AutoGen.py index a5bef4f7c6..7b35f837f5 100644 --- a/BaseTools/Source/Python/AutoGen/AutoGen.py +++ b/BaseTools/Source/Python/AutoGen/AutoGen.py @@ -3906,6 +3906,12 @@ class ModuleAutoGen(AutoGen): ModuleFile = path.join(self.OutputDir, self.Name + '.inf') if os.path.exists(ModuleFile): shutil.copy2(ModuleFile, FileDir) + else: + OutputDir = self.OutputDir.replace('\\', '/').strip('/') + DebugDir = self.DebugDir.replace('\\', '/').strip('/') + for Item in self.CodaTargetList: + File = Item.Target.Path.replace('\\', '/').strip('/').replace(DebugDir, '').replace(OutputDir, '').strip('/') + self.OutputFile.add(File) if not self.OutputFile: Ma = self.BuildDatabase[self.MetaFile, self.Arch, self.BuildTarget, self.ToolChain] self.OutputFile = Ma.Binaries -- 2.17.1.windows.2 ^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [edk2-devel] [PATCH v2] BaseTools:Extend the binary cache to support library cache 2019-05-29 1:46 [PATCH v2] BaseTools:Extend the binary cache to support library cache Steven Shi @ 2019-05-29 11:13 ` Leif Lindholm 2019-05-30 2:28 ` Steven Shi 0 siblings, 1 reply; 3+ messages in thread From: Leif Lindholm @ 2019-05-29 11:13 UTC (permalink / raw) To: devel, steven.shi; +Cc: liming.gao, bob.c.feng, christian.rodriguez, zhijux.fan On Wed, May 29, 2019 at 09:46:54AM +0800, Steven Shi wrote: > V2 change: > Simplify the library cache implementation and remove > CacheRestored flag based filter. Use the current > CanSkipbyHash() filter in AddDependency() instead. > > V1 change: Please don't put change notices in the commit message. These go below ---, or in a cover letter. / Leif > > https://bugzilla.tianocore.org/show_bug.cgi?id=1797 > > Current binary cache doesn't support to save and restore > the library module. If a driver module cache miss happen, > all its dependency library modules need rebuild which > is very time-consuming. This patch is to entend the binary > cache to support library. > > Cc: Liming Gao <liming.gao@intel.com> > Cc: Bob Feng <bob.c.feng@intel.com> > Cc: Christian Rodriguez <christian.rodriguez@intel.com> > Signed-off-by: Steven Shi <steven.shi@intel.com> > --- > BaseTools/Source/Python/AutoGen/AutoGen.py | 6 ++++++ > 1 file changed, 6 insertions(+) > > diff --git a/BaseTools/Source/Python/AutoGen/AutoGen.py b/BaseTools/Source/Python/AutoGen/AutoGen.py > index a5bef4f7c6..7b35f837f5 100644 > --- a/BaseTools/Source/Python/AutoGen/AutoGen.py > +++ b/BaseTools/Source/Python/AutoGen/AutoGen.py > @@ -3906,6 +3906,12 @@ class ModuleAutoGen(AutoGen): > ModuleFile = path.join(self.OutputDir, self.Name + '.inf') > if os.path.exists(ModuleFile): > shutil.copy2(ModuleFile, FileDir) > + else: > + OutputDir = self.OutputDir.replace('\\', '/').strip('/') > + DebugDir = self.DebugDir.replace('\\', '/').strip('/') > + for Item in self.CodaTargetList: > + File = Item.Target.Path.replace('\\', '/').strip('/').replace(DebugDir, '').replace(OutputDir, '').strip('/') > + self.OutputFile.add(File) > if not self.OutputFile: > Ma = self.BuildDatabase[self.MetaFile, self.Arch, self.BuildTarget, self.ToolChain] > self.OutputFile = Ma.Binaries > -- > 2.17.1.windows.2 > > > > ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [edk2-devel] [PATCH v2] BaseTools:Extend the binary cache to support library cache 2019-05-29 11:13 ` [edk2-devel] " Leif Lindholm @ 2019-05-30 2:28 ` Steven Shi 0 siblings, 0 replies; 3+ messages in thread From: Steven Shi @ 2019-05-30 2:28 UTC (permalink / raw) To: Leif Lindholm, devel@edk2.groups.io Cc: Gao, Liming, Feng, Bob C, Rodriguez, Christian, Fan, ZhijuX OK, will move the change notices from commit message to cover letter. Thanks Steven Shi > -----Original Message----- > From: Leif Lindholm [mailto:leif.lindholm@linaro.org] > Sent: Wednesday, May 29, 2019 7:14 PM > To: devel@edk2.groups.io; Shi, Steven <steven.shi@intel.com> > Cc: Gao, Liming <liming.gao@intel.com>; Feng, Bob C <bob.c.feng@intel.com>; > Rodriguez, Christian <christian.rodriguez@intel.com>; Fan, ZhijuX > <zhijux.fan@intel.com> > Subject: Re: [edk2-devel] [PATCH v2] BaseTools:Extend the binary cache to > support library cache > > On Wed, May 29, 2019 at 09:46:54AM +0800, Steven Shi wrote: > > V2 change: > > Simplify the library cache implementation and remove > > CacheRestored flag based filter. Use the current > > CanSkipbyHash() filter in AddDependency() instead. > > > > V1 change: > > Please don't put change notices in the commit message. These go below > ---, or in a cover letter. > > / > Leif > > > > > https://bugzilla.tianocore.org/show_bug.cgi?id=1797 > > > > Current binary cache doesn't support to save and restore > > the library module. If a driver module cache miss happen, > > all its dependency library modules need rebuild which > > is very time-consuming. This patch is to entend the binary > > cache to support library. > > > > Cc: Liming Gao <liming.gao@intel.com> > > Cc: Bob Feng <bob.c.feng@intel.com> > > Cc: Christian Rodriguez <christian.rodriguez@intel.com> > > Signed-off-by: Steven Shi <steven.shi@intel.com> > > --- > > BaseTools/Source/Python/AutoGen/AutoGen.py | 6 ++++++ > > 1 file changed, 6 insertions(+) > > > > diff --git a/BaseTools/Source/Python/AutoGen/AutoGen.py > b/BaseTools/Source/Python/AutoGen/AutoGen.py > > index a5bef4f7c6..7b35f837f5 100644 > > --- a/BaseTools/Source/Python/AutoGen/AutoGen.py > > +++ b/BaseTools/Source/Python/AutoGen/AutoGen.py > > @@ -3906,6 +3906,12 @@ class ModuleAutoGen(AutoGen): > > ModuleFile = path.join(self.OutputDir, self.Name + '.inf') > > if os.path.exists(ModuleFile): > > shutil.copy2(ModuleFile, FileDir) > > + else: > > + OutputDir = self.OutputDir.replace('\\', '/').strip('/') > > + DebugDir = self.DebugDir.replace('\\', '/').strip('/') > > + for Item in self.CodaTargetList: > > + File = Item.Target.Path.replace('\\', '/').strip('/').replace(DebugDir, > '').replace(OutputDir, '').strip('/') > > + self.OutputFile.add(File) > > if not self.OutputFile: > > Ma = self.BuildDatabase[self.MetaFile, self.Arch, self.BuildTarget, > self.ToolChain] > > self.OutputFile = Ma.Binaries > > -- > > 2.17.1.windows.2 > > > > > > > > ^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2019-05-30 2:28 UTC | newest] Thread overview: 3+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2019-05-29 1:46 [PATCH v2] BaseTools:Extend the binary cache to support library cache Steven Shi 2019-05-29 11:13 ` [edk2-devel] " Leif Lindholm 2019-05-30 2:28 ` Steven Shi
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox