* [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