mirror of https://github.com/acidanthera/audk.git
BaseTools: Leverage compiler output to optimize binary cache
Redesign the binary cache and bases on the compiler to output the dependency header files info for every module. The binary cache will directly consume the dependency header files info and doesn't parse the C source code by iteself. Also redesign the dependency files list format for module and try to share the common lib hash result as more as possible in local process. Remove the unnecessary share data access across multiprocessing. Signed-off-by: Steven Shi <steven.shi@intel.com> Cc: Liming Gao <liming.gao@intel.com> Cc: Bob Feng <bob.c.feng@intel.com> Reviewed-by: Bob Feng <bob.c.feng@intel.com>
This commit is contained in:
parent
3bfbc91507
commit
fc8b8deac2
|
@ -128,12 +128,27 @@ class AutoGenManager(threading.Thread):
|
|||
clearQ(taskq)
|
||||
clearQ(self.feedback_q)
|
||||
clearQ(logq)
|
||||
# Copy the cache queue itmes to parent thread before clear
|
||||
cacheq = self.autogen_workers[0].cache_q
|
||||
try:
|
||||
cache_num = 0
|
||||
while True:
|
||||
item = cacheq.get()
|
||||
if item == "CacheDone":
|
||||
cache_num += 1
|
||||
else:
|
||||
GlobalData.gModuleAllCacheStatus.add(item)
|
||||
if cache_num == len(self.autogen_workers):
|
||||
break
|
||||
except:
|
||||
print ("cache_q error")
|
||||
|
||||
def TerminateWorkers(self):
|
||||
self.error_event.set()
|
||||
def kill(self):
|
||||
self.feedback_q.put(None)
|
||||
class AutoGenWorkerInProcess(mp.Process):
|
||||
def __init__(self,module_queue,data_pipe_file_path,feedback_q,file_lock,cache_lock,share_data,log_q,error_event):
|
||||
def __init__(self,module_queue,data_pipe_file_path,feedback_q,file_lock,cache_q,log_q,error_event):
|
||||
mp.Process.__init__(self)
|
||||
self.module_queue = module_queue
|
||||
self.data_pipe_file_path =data_pipe_file_path
|
||||
|
@ -141,8 +156,7 @@ class AutoGenWorkerInProcess(mp.Process):
|
|||
self.feedback_q = feedback_q
|
||||
self.PlatformMetaFileSet = {}
|
||||
self.file_lock = file_lock
|
||||
self.cache_lock = cache_lock
|
||||
self.share_data = share_data
|
||||
self.cache_q = cache_q
|
||||
self.log_q = log_q
|
||||
self.error_event = error_event
|
||||
def GetPlatformMetaFile(self,filepath,root):
|
||||
|
@ -184,12 +198,19 @@ class AutoGenWorkerInProcess(mp.Process):
|
|||
GlobalData.gDisableIncludePathCheck = False
|
||||
GlobalData.gFdfParser = self.data_pipe.Get("FdfParser")
|
||||
GlobalData.gDatabasePath = self.data_pipe.Get("DatabasePath")
|
||||
|
||||
GlobalData.gUseHashCache = self.data_pipe.Get("UseHashCache")
|
||||
GlobalData.gBinCacheSource = self.data_pipe.Get("BinCacheSource")
|
||||
GlobalData.gBinCacheDest = self.data_pipe.Get("BinCacheDest")
|
||||
GlobalData.gCacheIR = self.share_data
|
||||
GlobalData.gPlatformHashFile = self.data_pipe.Get("PlatformHashFile")
|
||||
GlobalData.gModulePreMakeCacheStatus = dict()
|
||||
GlobalData.gModuleMakeCacheStatus = dict()
|
||||
GlobalData.gHashChainStatus = dict()
|
||||
GlobalData.gCMakeHashFile = dict()
|
||||
GlobalData.gModuleHashFile = dict()
|
||||
GlobalData.gFileHashDict = dict()
|
||||
GlobalData.gEnableGenfdsMultiThread = self.data_pipe.Get("EnableGenfdsMultiThread")
|
||||
GlobalData.file_lock = self.file_lock
|
||||
GlobalData.cache_lock = self.cache_lock
|
||||
CommandTarget = self.data_pipe.Get("CommandTarget")
|
||||
pcd_from_build_option = []
|
||||
for pcd_tuple in self.data_pipe.Get("BuildOptPcd"):
|
||||
|
@ -205,10 +226,6 @@ class AutoGenWorkerInProcess(mp.Process):
|
|||
GlobalData.FfsCmd = FfsCmd
|
||||
PlatformMetaFile = self.GetPlatformMetaFile(self.data_pipe.Get("P_Info").get("ActivePlatform"),
|
||||
self.data_pipe.Get("P_Info").get("WorkspaceDir"))
|
||||
libConstPcd = self.data_pipe.Get("LibConstPcd")
|
||||
Refes = self.data_pipe.Get("REFS")
|
||||
GlobalData.libConstPcd = libConstPcd
|
||||
GlobalData.Refes = Refes
|
||||
while True:
|
||||
if self.module_queue.empty():
|
||||
break
|
||||
|
@ -230,27 +247,41 @@ class AutoGenWorkerInProcess(mp.Process):
|
|||
toolchain = self.data_pipe.Get("P_Info").get("ToolChain")
|
||||
Ma = ModuleAutoGen(self.Wa,module_metafile,target,toolchain,arch,PlatformMetaFile,self.data_pipe)
|
||||
Ma.IsLibrary = IsLib
|
||||
if IsLib:
|
||||
if (Ma.MetaFile.File,Ma.MetaFile.Root,Ma.Arch,Ma.MetaFile.Path) in libConstPcd:
|
||||
Ma.ConstPcd = libConstPcd[(Ma.MetaFile.File,Ma.MetaFile.Root,Ma.Arch,Ma.MetaFile.Path)]
|
||||
if (Ma.MetaFile.File,Ma.MetaFile.Root,Ma.Arch,Ma.MetaFile.Path) in Refes:
|
||||
Ma.ReferenceModules = Refes[(Ma.MetaFile.File,Ma.MetaFile.Root,Ma.Arch,Ma.MetaFile.Path)]
|
||||
if GlobalData.gBinCacheSource and CommandTarget in [None, "", "all"]:
|
||||
Ma.GenModuleFilesHash(GlobalData.gCacheIR)
|
||||
Ma.GenPreMakefileHash(GlobalData.gCacheIR)
|
||||
if Ma.CanSkipbyPreMakefileCache(GlobalData.gCacheIR):
|
||||
# SourceFileList calling sequence impact the makefile string sequence.
|
||||
# Create cached SourceFileList here to unify its calling sequence for both
|
||||
# CanSkipbyPreMakeCache and CreateCodeFile/CreateMakeFile.
|
||||
RetVal = Ma.SourceFileList
|
||||
if GlobalData.gUseHashCache and not GlobalData.gBinCacheDest and CommandTarget in [None, "", "all"]:
|
||||
try:
|
||||
CacheResult = Ma.CanSkipbyPreMakeCache()
|
||||
except:
|
||||
CacheResult = False
|
||||
traceback.print_exc(file=sys.stdout)
|
||||
self.feedback_q.put(taskname)
|
||||
|
||||
if CacheResult:
|
||||
self.cache_q.put((Ma.MetaFile.Path, Ma.Arch, "PreMakeCache", True))
|
||||
continue
|
||||
else:
|
||||
self.cache_q.put((Ma.MetaFile.Path, Ma.Arch, "PreMakeCache", False))
|
||||
|
||||
Ma.CreateCodeFile(False)
|
||||
Ma.CreateMakeFile(False,GenFfsList=FfsCmd.get((Ma.MetaFile.Path, Ma.Arch),[]))
|
||||
|
||||
if GlobalData.gBinCacheSource and CommandTarget in [None, "", "all"]:
|
||||
Ma.GenMakeHeaderFilesHash(GlobalData.gCacheIR)
|
||||
Ma.GenMakeHash(GlobalData.gCacheIR)
|
||||
if Ma.CanSkipbyMakeCache(GlobalData.gCacheIR):
|
||||
try:
|
||||
CacheResult = Ma.CanSkipbyMakeCache()
|
||||
except:
|
||||
CacheResult = False
|
||||
traceback.print_exc(file=sys.stdout)
|
||||
self.feedback_q.put(taskname)
|
||||
|
||||
if CacheResult:
|
||||
self.cache_q.put((Ma.MetaFile.Path, Ma.Arch, "MakeCache", True))
|
||||
continue
|
||||
else:
|
||||
Ma.PrintFirstMakeCacheMissFile(GlobalData.gCacheIR)
|
||||
self.cache_q.put((Ma.MetaFile.Path, Ma.Arch, "MakeCache", False))
|
||||
|
||||
except Empty:
|
||||
pass
|
||||
except:
|
||||
|
@ -258,6 +289,8 @@ class AutoGenWorkerInProcess(mp.Process):
|
|||
self.feedback_q.put(taskname)
|
||||
finally:
|
||||
self.feedback_q.put("Done")
|
||||
self.cache_q.put("CacheDone")
|
||||
|
||||
def printStatus(self):
|
||||
print("Processs ID: %d Run %d modules in AutoGen " % (os.getpid(),len(AutoGen.Cache())))
|
||||
print("Processs ID: %d Run %d modules in AutoGenInfo " % (os.getpid(),len(AutoGenInfo.GetCache())))
|
||||
|
|
|
@ -159,6 +159,8 @@ class MemoryDataPipe(DataPipe):
|
|||
|
||||
self.DataContainer = {"LogLevel": EdkLogger.GetLevel()}
|
||||
|
||||
self.DataContainer = {"UseHashCache":GlobalData.gUseHashCache}
|
||||
|
||||
self.DataContainer = {"BinCacheSource":GlobalData.gBinCacheSource}
|
||||
|
||||
self.DataContainer = {"BinCacheDest":GlobalData.gBinCacheDest}
|
||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -23,6 +23,7 @@ from Common.StringUtils import NormPath
|
|||
from Common.BuildToolError import *
|
||||
from Common.DataType import *
|
||||
from Common.Misc import *
|
||||
import json
|
||||
|
||||
## Regular expression for splitting Dependency Expression string into tokens
|
||||
gDepexTokenPattern = re.compile("(\(|\)|\w+| \S+\.inf)")
|
||||
|
@ -127,7 +128,7 @@ class WorkspaceAutoGen(AutoGen):
|
|||
|
||||
self.CreateBuildOptionsFile()
|
||||
self.CreatePcdTokenNumberFile()
|
||||
self.CreateModuleHashInfo()
|
||||
self.GeneratePlatformLevelHash()
|
||||
|
||||
#
|
||||
# Merge Arch
|
||||
|
@ -528,12 +529,12 @@ class WorkspaceAutoGen(AutoGen):
|
|||
PcdTokenNumber += str(Pa.PcdTokenNumber[Pcd.TokenCName, Pcd.TokenSpaceGuidCName])
|
||||
SaveFileOnChange(os.path.join(self.BuildDir, 'PcdTokenNumber'), PcdTokenNumber, False)
|
||||
|
||||
def CreateModuleHashInfo(self):
|
||||
def GeneratePlatformLevelHash(self):
|
||||
#
|
||||
# Get set of workspace metafiles
|
||||
#
|
||||
AllWorkSpaceMetaFiles = self._GetMetaFiles(self.BuildTarget, self.ToolChain)
|
||||
|
||||
AllWorkSpaceMetaFileList = sorted(AllWorkSpaceMetaFiles, key=lambda x: str(x))
|
||||
#
|
||||
# Retrieve latest modified time of all metafiles
|
||||
#
|
||||
|
@ -544,16 +545,35 @@ class WorkspaceAutoGen(AutoGen):
|
|||
self._SrcTimeStamp = SrcTimeStamp
|
||||
|
||||
if GlobalData.gUseHashCache:
|
||||
FileList = []
|
||||
m = hashlib.md5()
|
||||
for files in AllWorkSpaceMetaFiles:
|
||||
if files.endswith('.dec'):
|
||||
for file in AllWorkSpaceMetaFileList:
|
||||
if file.endswith('.dec'):
|
||||
continue
|
||||
f = open(files, 'rb')
|
||||
f = open(file, 'rb')
|
||||
Content = f.read()
|
||||
f.close()
|
||||
m.update(Content)
|
||||
SaveFileOnChange(os.path.join(self.BuildDir, 'AutoGen.hash'), m.hexdigest(), False)
|
||||
GlobalData.gPlatformHash = m.hexdigest()
|
||||
FileList.append((str(file), hashlib.md5(Content).hexdigest()))
|
||||
|
||||
HashDir = path.join(self.BuildDir, "Hash_Platform")
|
||||
HashFile = path.join(HashDir, 'Platform.hash.' + m.hexdigest())
|
||||
SaveFileOnChange(HashFile, m.hexdigest(), False)
|
||||
HashChainFile = path.join(HashDir, 'Platform.hashchain.' + m.hexdigest())
|
||||
GlobalData.gPlatformHashFile = HashChainFile
|
||||
try:
|
||||
with open(HashChainFile, 'w') as f:
|
||||
json.dump(FileList, f, indent=2)
|
||||
except:
|
||||
EdkLogger.quiet("[cache warning]: fail to save hashchain file:%s" % HashChainFile)
|
||||
|
||||
if GlobalData.gBinCacheDest:
|
||||
# Copy platform hash files to cache destination
|
||||
FileDir = path.join(GlobalData.gBinCacheDest, self.OutputDir, self.BuildTarget + "_" + self.ToolChain, "Hash_Platform")
|
||||
CacheFileDir = FileDir
|
||||
CreateDirectory(CacheFileDir)
|
||||
CopyFileOnChange(HashFile, CacheFileDir)
|
||||
CopyFileOnChange(HashChainFile, CacheFileDir)
|
||||
|
||||
#
|
||||
# Write metafile list to build directory
|
||||
|
@ -564,7 +584,7 @@ class WorkspaceAutoGen(AutoGen):
|
|||
if not os.path.exists(self.BuildDir):
|
||||
os.makedirs(self.BuildDir)
|
||||
with open(os.path.join(self.BuildDir, 'AutoGen'), 'w+') as file:
|
||||
for f in AllWorkSpaceMetaFiles:
|
||||
for f in AllWorkSpaceMetaFileList:
|
||||
print(f, file=file)
|
||||
return True
|
||||
|
||||
|
@ -572,15 +592,16 @@ class WorkspaceAutoGen(AutoGen):
|
|||
if Pkg.PackageName in GlobalData.gPackageHash:
|
||||
return
|
||||
|
||||
PkgDir = os.path.join(self.BuildDir, Pkg.Arch, Pkg.PackageName)
|
||||
PkgDir = os.path.join(self.BuildDir, Pkg.Arch, "Hash_Pkg", Pkg.PackageName)
|
||||
CreateDirectory(PkgDir)
|
||||
HashFile = os.path.join(PkgDir, Pkg.PackageName + '.hash')
|
||||
FileList = []
|
||||
m = hashlib.md5()
|
||||
# Get .dec file's hash value
|
||||
f = open(Pkg.MetaFile.Path, 'rb')
|
||||
Content = f.read()
|
||||
f.close()
|
||||
m.update(Content)
|
||||
FileList.append((str(Pkg.MetaFile.Path), hashlib.md5(Content).hexdigest()))
|
||||
# Get include files hash value
|
||||
if Pkg.Includes:
|
||||
for inc in sorted(Pkg.Includes, key=lambda x: str(x)):
|
||||
|
@ -591,9 +612,28 @@ class WorkspaceAutoGen(AutoGen):
|
|||
Content = f.read()
|
||||
f.close()
|
||||
m.update(Content)
|
||||
SaveFileOnChange(HashFile, m.hexdigest(), False)
|
||||
FileList.append((str(File_Path), hashlib.md5(Content).hexdigest()))
|
||||
GlobalData.gPackageHash[Pkg.PackageName] = m.hexdigest()
|
||||
|
||||
HashDir = PkgDir
|
||||
HashFile = path.join(HashDir, Pkg.PackageName + '.hash.' + m.hexdigest())
|
||||
SaveFileOnChange(HashFile, m.hexdigest(), False)
|
||||
HashChainFile = path.join(HashDir, Pkg.PackageName + '.hashchain.' + m.hexdigest())
|
||||
GlobalData.gPackageHashFile[(Pkg.PackageName, Pkg.Arch)] = HashChainFile
|
||||
try:
|
||||
with open(HashChainFile, 'w') as f:
|
||||
json.dump(FileList, f, indent=2)
|
||||
except:
|
||||
EdkLogger.quiet("[cache warning]: fail to save hashchain file:%s" % HashChainFile)
|
||||
|
||||
if GlobalData.gBinCacheDest:
|
||||
# Copy Pkg hash files to cache destination dir
|
||||
FileDir = path.join(GlobalData.gBinCacheDest, self.OutputDir, self.BuildTarget + "_" + self.ToolChain, Pkg.Arch, "Hash_Pkg", Pkg.PackageName)
|
||||
CacheFileDir = FileDir
|
||||
CreateDirectory(CacheFileDir)
|
||||
CopyFileOnChange(HashFile, CacheFileDir)
|
||||
CopyFileOnChange(HashChainFile, CacheFileDir)
|
||||
|
||||
def _GetMetaFiles(self, Target, Toolchain):
|
||||
AllWorkSpaceMetaFiles = set()
|
||||
#
|
||||
|
|
|
@ -104,29 +104,20 @@ gUseHashCache = None
|
|||
gBinCacheDest = None
|
||||
gBinCacheSource = None
|
||||
gPlatformHash = None
|
||||
gPackageHash = {}
|
||||
gModuleHash = {}
|
||||
gPlatformHashFile = None
|
||||
gPackageHash = None
|
||||
gPackageHashFile = None
|
||||
gModuleHashFile = None
|
||||
gCMakeHashFile = None
|
||||
gHashChainStatus = None
|
||||
gModulePreMakeCacheStatus = None
|
||||
gModuleMakeCacheStatus = None
|
||||
gFileHashDict = None
|
||||
gModuleAllCacheStatus = None
|
||||
gModuleCacheHit = None
|
||||
|
||||
gEnableGenfdsMultiThread = True
|
||||
gSikpAutoGenCache = set()
|
||||
|
||||
# Dictionary for tracking Module build status as success or failure
|
||||
# Top Dict: Key: Arch Type Value: Dictionary
|
||||
# Second Dict: Key: AutoGen Obj Value: 'SUCCESS'\'FAIL'\'FAIL_METAFILE'
|
||||
gModuleBuildTracking = dict()
|
||||
|
||||
# Dictionary of booleans that dictate whether a module or
|
||||
# library can be skiped
|
||||
# Top Dict: Key: Arch Type Value: Dictionary
|
||||
# Second Dict: Key: Module\Library Name Value: True\False
|
||||
gBuildHashSkipTracking = dict()
|
||||
|
||||
# Common dictionary to share module cache intermediate result and state
|
||||
gCacheIR = None
|
||||
# Common lock for the module cache intermediate data
|
||||
cache_lock = None
|
||||
# Common lock for the file access in multiple process AutoGens
|
||||
file_lock = None
|
||||
# Common dictionary to share platform libraries' constant Pcd
|
||||
libConstPcd = None
|
||||
# Common dictionary to share platform libraries' reference info
|
||||
Refes = None
|
||||
|
||||
|
|
|
@ -620,7 +620,7 @@ class BuildTask:
|
|||
#
|
||||
def AddDependency(self, Dependency):
|
||||
for Dep in Dependency:
|
||||
if not Dep.BuildObject.IsBinaryModule and not Dep.BuildObject.CanSkipbyCache(GlobalData.gCacheIR):
|
||||
if not Dep.BuildObject.IsBinaryModule and not Dep.BuildObject.CanSkipbyCache(GlobalData.gModuleCacheHit):
|
||||
self.DependencyList.append(BuildTask.New(Dep)) # BuildTask list
|
||||
|
||||
## The thread wrapper of LaunchCommand function
|
||||
|
@ -633,10 +633,13 @@ class BuildTask:
|
|||
self.BuildItem.BuildObject.BuildTime = LaunchCommand(Command, WorkingDir,self.BuildItem.BuildObject)
|
||||
self.CompleteFlag = True
|
||||
|
||||
# Run hash operation post dependency, to account for libs
|
||||
if GlobalData.gUseHashCache and self.BuildItem.BuildObject.IsLibrary:
|
||||
HashFile = path.join(self.BuildItem.BuildObject.BuildDir, self.BuildItem.BuildObject.Name + ".hash")
|
||||
SaveFileOnChange(HashFile, self.BuildItem.BuildObject.GenModuleHash(), True)
|
||||
# Run hash operation post dependency to account for libs
|
||||
# Run if --hash or --binary-destination
|
||||
if GlobalData.gUseHashCache and not GlobalData.gBinCacheSource:
|
||||
self.BuildItem.BuildObject.GenModuleHash()
|
||||
if GlobalData.gBinCacheDest:
|
||||
self.BuildItem.BuildObject.GenCMakeHash()
|
||||
|
||||
except:
|
||||
#
|
||||
# TRICK: hide the output of threads left running, so that the user can
|
||||
|
@ -653,14 +656,6 @@ class BuildTask:
|
|||
BuildTask._ErrorMessage = "%s broken\n %s [%s]" % \
|
||||
(threading.currentThread().getName(), Command, WorkingDir)
|
||||
|
||||
# Set the value used by hash invalidation flow in GlobalData.gModuleBuildTracking to 'SUCCESS'
|
||||
# If Module or Lib is being tracked, it did not fail header check test, and built successfully
|
||||
if (self.BuildItem.BuildObject in GlobalData.gModuleBuildTracking and
|
||||
GlobalData.gModuleBuildTracking[self.BuildItem.BuildObject] != 'FAIL_METAFILE' and
|
||||
not BuildTask._ErrorFlag.isSet()
|
||||
):
|
||||
GlobalData.gModuleBuildTracking[self.BuildItem.BuildObject] = 'SUCCESS'
|
||||
|
||||
# indicate there's a thread is available for another build task
|
||||
BuildTask._RunningQueueLock.acquire()
|
||||
BuildTask._RunningQueue.pop(self.BuildItem)
|
||||
|
@ -835,11 +830,20 @@ class Build():
|
|||
self.AutoGenMgr = None
|
||||
EdkLogger.info("")
|
||||
os.chdir(self.WorkspaceDir)
|
||||
GlobalData.gCacheIR = Manager().dict()
|
||||
self.log_q = log_q
|
||||
GlobalData.file_lock = mp.Lock()
|
||||
GlobalData.cache_lock = mp.Lock()
|
||||
def StartAutoGen(self,mqueue, DataPipe,SkipAutoGen,PcdMaList,share_data):
|
||||
# Init cache data for local only
|
||||
GlobalData.gPackageHashFile = dict()
|
||||
GlobalData.gModulePreMakeCacheStatus = dict()
|
||||
GlobalData.gModuleMakeCacheStatus = dict()
|
||||
GlobalData.gHashChainStatus = dict()
|
||||
GlobalData.gCMakeHashFile = dict()
|
||||
GlobalData.gModuleHashFile = dict()
|
||||
GlobalData.gFileHashDict = dict()
|
||||
GlobalData.gModuleAllCacheStatus = set()
|
||||
GlobalData.gModuleCacheHit = set()
|
||||
|
||||
def StartAutoGen(self,mqueue, DataPipe,SkipAutoGen,PcdMaList,cqueue):
|
||||
try:
|
||||
if SkipAutoGen:
|
||||
return True,0
|
||||
|
@ -849,29 +853,27 @@ class Build():
|
|||
if FfsCmd is None:
|
||||
FfsCmd = {}
|
||||
GlobalData.FfsCmd = FfsCmd
|
||||
GlobalData.libConstPcd = DataPipe.Get("LibConstPcd")
|
||||
GlobalData.Refes = DataPipe.Get("REFS")
|
||||
auto_workers = [AutoGenWorkerInProcess(mqueue,DataPipe.dump_file,feedback_q,GlobalData.file_lock,GlobalData.cache_lock,share_data,self.log_q,error_event) for _ in range(self.ThreadNumber)]
|
||||
auto_workers = [AutoGenWorkerInProcess(mqueue,DataPipe.dump_file,feedback_q,GlobalData.file_lock,cqueue,self.log_q,error_event) for _ in range(self.ThreadNumber)]
|
||||
self.AutoGenMgr = AutoGenManager(auto_workers,feedback_q,error_event)
|
||||
self.AutoGenMgr.start()
|
||||
for w in auto_workers:
|
||||
w.start()
|
||||
if PcdMaList is not None:
|
||||
for PcdMa in PcdMaList:
|
||||
if GlobalData.gBinCacheSource and self.Target in [None, "", "all"]:
|
||||
PcdMa.GenModuleFilesHash(share_data)
|
||||
PcdMa.GenPreMakefileHash(share_data)
|
||||
if PcdMa.CanSkipbyPreMakefileCache(share_data):
|
||||
continue
|
||||
# SourceFileList calling sequence impact the makefile string sequence.
|
||||
# Create cached SourceFileList here to unify its calling sequence for both
|
||||
# CanSkipbyPreMakeCache and CreateCodeFile/CreateMakeFile.
|
||||
RetVal = PcdMa.SourceFileList
|
||||
# Force cache miss for PCD driver
|
||||
if GlobalData.gUseHashCache and not GlobalData.gBinCacheDest and self.Target in [None, "", "all"]:
|
||||
cqueue.put((PcdMa.MetaFile.Path, PcdMa.Arch, "PreMakeCache", False))
|
||||
|
||||
PcdMa.CreateCodeFile(False)
|
||||
PcdMa.CreateMakeFile(False,GenFfsList = DataPipe.Get("FfsCommand").get((PcdMa.MetaFile.Path, PcdMa.Arch),[]))
|
||||
|
||||
# Force cache miss for PCD driver
|
||||
if GlobalData.gBinCacheSource and self.Target in [None, "", "all"]:
|
||||
PcdMa.GenMakeHeaderFilesHash(share_data)
|
||||
PcdMa.GenMakeHash(share_data)
|
||||
if PcdMa.CanSkipbyMakeCache(share_data):
|
||||
continue
|
||||
cqueue.put((PcdMa.MetaFile.Path, PcdMa.Arch, "MakeCache", False))
|
||||
|
||||
self.AutoGenMgr.join()
|
||||
rt = self.AutoGenMgr.Status
|
||||
|
@ -1182,38 +1184,6 @@ class Build():
|
|||
EdkLogger.error("Postbuild", POSTBUILD_ERROR, 'Postbuild process is not success!')
|
||||
EdkLogger.info("\n- Postbuild Done -\n")
|
||||
|
||||
## Error handling for hash feature
|
||||
#
|
||||
# On BuildTask error, iterate through the Module Build tracking
|
||||
# dictionary to determine wheather a module failed to build. Invalidate
|
||||
# the hash associated with that module by removing it from storage.
|
||||
#
|
||||
#
|
||||
def invalidateHash(self):
|
||||
# Only for hashing feature
|
||||
if not GlobalData.gUseHashCache:
|
||||
return
|
||||
|
||||
# GlobalData.gModuleBuildTracking contains only modules or libs that cannot be skipped by hash
|
||||
for Ma in GlobalData.gModuleBuildTracking:
|
||||
# Skip invalidating for Successful Module/Lib builds
|
||||
if GlobalData.gModuleBuildTracking[Ma] == 'SUCCESS':
|
||||
continue
|
||||
|
||||
# The module failed to build, failed to start building, or failed the header check test from this point on
|
||||
|
||||
# Remove .hash from build
|
||||
ModuleHashFile = os.path.join(Ma.BuildDir, Ma.Name + ".hash")
|
||||
if os.path.exists(ModuleHashFile):
|
||||
os.remove(ModuleHashFile)
|
||||
|
||||
# Remove .hash file from cache
|
||||
if GlobalData.gBinCacheDest:
|
||||
FileDir = os.path.join(GlobalData.gBinCacheDest, Ma.PlatformInfo.OutputDir, Ma.BuildTarget + "_" + Ma.ToolChain, Ma.Arch, Ma.SourceDir, Ma.MetaFile.BaseName)
|
||||
HashFile = os.path.join(FileDir, Ma.Name + '.hash')
|
||||
if os.path.exists(HashFile):
|
||||
os.remove(HashFile)
|
||||
|
||||
## Build a module or platform
|
||||
#
|
||||
# Create autogen code and makefile for a module or platform, and the launch
|
||||
|
@ -1251,7 +1221,8 @@ class Build():
|
|||
self.Progress.Start("Generating makefile and code")
|
||||
data_pipe_file = os.path.join(AutoGenObject.BuildDir, "GlobalVar_%s_%s.bin" % (str(AutoGenObject.Guid),AutoGenObject.Arch))
|
||||
AutoGenObject.DataPipe.dump(data_pipe_file)
|
||||
autogen_rt,errorcode = self.StartAutoGen(mqueue, AutoGenObject.DataPipe, self.SkipAutoGen, PcdMaList, GlobalData.gCacheIR)
|
||||
cqueue = mp.Queue()
|
||||
autogen_rt,errorcode = self.StartAutoGen(mqueue, AutoGenObject.DataPipe, self.SkipAutoGen, PcdMaList, cqueue)
|
||||
AutoGenIdFile = os.path.join(GlobalData.gConfDirectory,".AutoGenIdFile.txt")
|
||||
with open(AutoGenIdFile,"w") as fw:
|
||||
fw.write("Arch=%s\n" % "|".join((AutoGenObject.Workspace.ArchList)))
|
||||
|
@ -1292,7 +1263,11 @@ class Build():
|
|||
LaunchCommand(BuildCommand, AutoGenObject.MakeFileDir)
|
||||
self.CreateAsBuiltInf()
|
||||
if GlobalData.gBinCacheDest:
|
||||
self.UpdateBuildCache()
|
||||
self.GenDestCache()
|
||||
elif GlobalData.gUseHashCache and not GlobalData.gBinCacheSource:
|
||||
# Only for --hash
|
||||
# Update PreMakeCacheChain files
|
||||
self.GenLocalPreMakeCache()
|
||||
self.BuildModules = []
|
||||
return True
|
||||
|
||||
|
@ -1326,7 +1301,11 @@ class Build():
|
|||
LaunchCommand(NewBuildCommand, AutoGenObject.MakeFileDir,ModAutoGen)
|
||||
self.CreateAsBuiltInf()
|
||||
if GlobalData.gBinCacheDest:
|
||||
self.UpdateBuildCache()
|
||||
self.GenDestCache()
|
||||
elif GlobalData.gUseHashCache and not GlobalData.gBinCacheSource:
|
||||
# Only for --hash
|
||||
# Update PreMakeCacheChain files
|
||||
self.GenLocalPreMakeCache()
|
||||
self.BuildModules = []
|
||||
return True
|
||||
|
||||
|
@ -1422,7 +1401,11 @@ class Build():
|
|||
AutoGenObject.BuildTime = LaunchCommand(BuildCommand, AutoGenObject.MakeFileDir)
|
||||
self.CreateAsBuiltInf()
|
||||
if GlobalData.gBinCacheDest:
|
||||
self.UpdateBuildCache()
|
||||
self.GenDestCache()
|
||||
elif GlobalData.gUseHashCache and not GlobalData.gBinCacheSource:
|
||||
# Only for --hash
|
||||
# Update PreMakeCacheChain files
|
||||
self.GenLocalPreMakeCache()
|
||||
self.BuildModules = []
|
||||
return True
|
||||
|
||||
|
@ -1870,13 +1853,7 @@ class Build():
|
|||
if GlobalData.gEnableGenfdsMultiThread and self.Fdf:
|
||||
CmdListDict = self._GenFfsCmd(Wa.ArchList)
|
||||
|
||||
# Add Platform and Package level hash in share_data for module hash calculation later
|
||||
if GlobalData.gBinCacheSource or GlobalData.gBinCacheDest:
|
||||
GlobalData.gCacheIR[('PlatformHash')] = GlobalData.gPlatformHash
|
||||
for PkgName in GlobalData.gPackageHash.keys():
|
||||
GlobalData.gCacheIR[(PkgName, 'PackageHash')] = GlobalData.gPackageHash[PkgName]
|
||||
GlobalData.file_lock = mp.Lock()
|
||||
GlobalData.cache_lock = mp.Lock()
|
||||
GlobalData.FfsCmd = CmdListDict
|
||||
|
||||
self.Progress.Stop("done!")
|
||||
|
@ -1888,8 +1865,6 @@ class Build():
|
|||
AutoGenStart = time.time()
|
||||
GlobalData.gGlobalDefines['ARCH'] = Arch
|
||||
Pa = PlatformAutoGen(Wa, self.PlatformFile, BuildTarget, ToolChain, Arch)
|
||||
GlobalData.libConstPcd = Pa.DataPipe.Get("LibConstPcd")
|
||||
GlobalData.Refes = Pa.DataPipe.Get("REFS")
|
||||
for Module in Pa.Platform.Modules:
|
||||
if self.ModuleFile.Dir == Module.Dir and self.ModuleFile.Name == Module.Name:
|
||||
Ma = ModuleAutoGen(Wa, Module, BuildTarget, ToolChain, Arch, self.PlatformFile,Pa.DataPipe)
|
||||
|
@ -1900,13 +1875,11 @@ class Build():
|
|||
Ma.Workspace = Wa
|
||||
MaList.append(Ma)
|
||||
|
||||
if GlobalData.gBinCacheSource and self.Target in [None, "", "all"]:
|
||||
Ma.GenModuleFilesHash(GlobalData.gCacheIR)
|
||||
Ma.GenPreMakefileHash(GlobalData.gCacheIR)
|
||||
if Ma.CanSkipbyPreMakefileCache(GlobalData.gCacheIR):
|
||||
self.HashSkipModules.append(Ma)
|
||||
EdkLogger.quiet("cache hit: %s[%s]" % (Ma.MetaFile.Path, Ma.Arch))
|
||||
if GlobalData.gUseHashCache and not GlobalData.gBinCacheDest and self.Target in [None, "", "all"]:
|
||||
if Ma.CanSkipbyPreMakeCache():
|
||||
continue
|
||||
else:
|
||||
self.PreMakeCacheMiss.add(Ma)
|
||||
|
||||
# Not to auto-gen for targets 'clean', 'cleanlib', 'cleanall', 'run', 'fds'
|
||||
if self.Target not in ['clean', 'cleanlib', 'cleanall', 'run', 'fds']:
|
||||
|
@ -1929,19 +1902,12 @@ class Build():
|
|||
return True
|
||||
|
||||
if GlobalData.gBinCacheSource and self.Target in [None, "", "all"]:
|
||||
Ma.GenMakeHeaderFilesHash(GlobalData.gCacheIR)
|
||||
Ma.GenMakeHash(GlobalData.gCacheIR)
|
||||
if Ma.CanSkipbyMakeCache(GlobalData.gCacheIR):
|
||||
self.HashSkipModules.append(Ma)
|
||||
EdkLogger.quiet("cache hit: %s[%s]" % (Ma.MetaFile.Path, Ma.Arch))
|
||||
if Ma.CanSkipbyMakeCache():
|
||||
continue
|
||||
else:
|
||||
EdkLogger.quiet("cache miss: %s[%s]" % (Ma.MetaFile.Path, Ma.Arch))
|
||||
Ma.PrintFirstMakeCacheMissFile(GlobalData.gCacheIR)
|
||||
self.MakeCacheMiss.add(Ma)
|
||||
|
||||
self.BuildModules.append(Ma)
|
||||
# Initialize all modules in tracking to 'FAIL'
|
||||
GlobalData.gModuleBuildTracking[Ma] = 'FAIL'
|
||||
self.AutoGenTime += int(round((time.time() - AutoGenStart)))
|
||||
MakeStart = time.time()
|
||||
for Ma in self.BuildModules:
|
||||
|
@ -1952,7 +1918,6 @@ class Build():
|
|||
# we need a full version of makefile for platform
|
||||
ExitFlag.set()
|
||||
BuildTask.WaitForComplete()
|
||||
self.invalidateHash()
|
||||
Pa.CreateMakeFile(False)
|
||||
EdkLogger.error("build", BUILD_ERROR, "Failed to build module", ExtraData=GlobalData.gBuildingModule)
|
||||
# Start task scheduler
|
||||
|
@ -1962,7 +1927,6 @@ class Build():
|
|||
# in case there's an interruption. we need a full version of makefile for platform
|
||||
Pa.CreateMakeFile(False)
|
||||
if BuildTask.HasError():
|
||||
self.invalidateHash()
|
||||
EdkLogger.error("build", BUILD_ERROR, "Failed to build module", ExtraData=GlobalData.gBuildingModule)
|
||||
self.MakeTime += int(round((time.time() - MakeStart)))
|
||||
|
||||
|
@ -1971,11 +1935,14 @@ class Build():
|
|||
BuildTask.WaitForComplete()
|
||||
self.CreateAsBuiltInf()
|
||||
if GlobalData.gBinCacheDest:
|
||||
self.UpdateBuildCache()
|
||||
self.GenDestCache()
|
||||
elif GlobalData.gUseHashCache and not GlobalData.gBinCacheSource:
|
||||
# Only for --hash
|
||||
# Update PreMakeCacheChain files
|
||||
self.GenLocalPreMakeCache()
|
||||
self.BuildModules = []
|
||||
self.MakeTime += int(round((time.time() - MakeContiue)))
|
||||
if BuildTask.HasError():
|
||||
self.invalidateHash()
|
||||
EdkLogger.error("build", BUILD_ERROR, "Failed to build module", ExtraData=GlobalData.gBuildingModule)
|
||||
|
||||
self.BuildReport.AddPlatformReport(Wa, MaList)
|
||||
|
@ -2028,7 +1995,6 @@ class Build():
|
|||
# Save MAP buffer into MAP file.
|
||||
#
|
||||
self._SaveMapFile (MapBuffer, Wa)
|
||||
self.invalidateHash()
|
||||
|
||||
def _GenFfsCmd(self,ArchList):
|
||||
# convert dictionary of Cmd:(Inf,Arch)
|
||||
|
@ -2134,20 +2100,13 @@ class Build():
|
|||
self.BuildReport.AddPlatformReport(Wa)
|
||||
Wa.CreateMakeFile(False)
|
||||
|
||||
# Add ffs build to makefile
|
||||
# Add ffs build to makefile
|
||||
CmdListDict = {}
|
||||
if GlobalData.gEnableGenfdsMultiThread and self.Fdf:
|
||||
CmdListDict = self._GenFfsCmd(Wa.ArchList)
|
||||
|
||||
# Add Platform and Package level hash in share_data for module hash calculation later
|
||||
if GlobalData.gBinCacheSource or GlobalData.gBinCacheDest:
|
||||
GlobalData.gCacheIR[('PlatformHash')] = GlobalData.gPlatformHash
|
||||
for PkgName in GlobalData.gPackageHash.keys():
|
||||
GlobalData.gCacheIR[(PkgName, 'PackageHash')] = GlobalData.gPackageHash[PkgName]
|
||||
|
||||
self.AutoGenTime += int(round((time.time() - WorkspaceAutoGenTime)))
|
||||
BuildModules = []
|
||||
TotalModules = []
|
||||
for Arch in Wa.ArchList:
|
||||
PcdMaList = []
|
||||
AutoGenStart = time.time()
|
||||
|
@ -2158,7 +2117,7 @@ class Build():
|
|||
ModuleList = []
|
||||
for Inf in Pa.Platform.Modules:
|
||||
ModuleList.append(Inf)
|
||||
# Add the INF only list in FDF
|
||||
# Add the INF only list in FDF
|
||||
if GlobalData.gFdfParser is not None:
|
||||
for InfName in GlobalData.gFdfParser.Profile.InfList:
|
||||
Inf = PathClass(NormPath(InfName), self.WorkspaceDir, Arch)
|
||||
|
@ -2172,58 +2131,73 @@ class Build():
|
|||
Pa.DataPipe.DataContainer = {"LibraryBuildDirectoryList":Pa.LibraryBuildDirectoryList}
|
||||
Pa.DataPipe.DataContainer = {"ModuleBuildDirectoryList":Pa.ModuleBuildDirectoryList}
|
||||
Pa.DataPipe.DataContainer = {"FdsCommandDict": Wa.GenFdsCommandDict}
|
||||
# Prepare the cache share data for multiprocessing
|
||||
Pa.DataPipe.DataContainer = {"gPlatformHashFile":GlobalData.gPlatformHashFile}
|
||||
ModuleCodaFile = {}
|
||||
for ma in Pa.ModuleAutoGenList:
|
||||
ModuleCodaFile[(ma.MetaFile.File,ma.MetaFile.Root,ma.Arch,ma.MetaFile.Path)] = [item.Target for item in ma.CodaTargetList]
|
||||
Pa.DataPipe.DataContainer = {"ModuleCodaFile":ModuleCodaFile}
|
||||
# ModuleList contains all driver modules only
|
||||
for Module in ModuleList:
|
||||
# Get ModuleAutoGen object to generate C code file and makefile
|
||||
# Get ModuleAutoGen object to generate C code file and makefile
|
||||
Ma = ModuleAutoGen(Wa, Module, BuildTarget, ToolChain, Arch, self.PlatformFile,Pa.DataPipe)
|
||||
|
||||
if Ma is None:
|
||||
continue
|
||||
if Ma.PcdIsDriver:
|
||||
Ma.PlatformInfo = Pa
|
||||
Ma.Workspace = Wa
|
||||
PcdMaList.append(Ma)
|
||||
TotalModules.append(Ma)
|
||||
# Initialize all modules in tracking to 'FAIL'
|
||||
GlobalData.gModuleBuildTracking[Ma] = 'FAIL'
|
||||
|
||||
self.AllDrivers.add(Ma)
|
||||
self.AllModules.add(Ma)
|
||||
|
||||
mqueue = mp.Queue()
|
||||
cqueue = mp.Queue()
|
||||
for m in Pa.GetAllModuleInfo:
|
||||
mqueue.put(m)
|
||||
module_file,module_root,module_path,module_basename,\
|
||||
module_originalpath,module_arch,IsLib = m
|
||||
Ma = ModuleAutoGen(Wa, PathClass(module_path, Wa), BuildTarget,\
|
||||
ToolChain, Arch, self.PlatformFile,Pa.DataPipe)
|
||||
self.AllModules.add(Ma)
|
||||
data_pipe_file = os.path.join(Pa.BuildDir, "GlobalVar_%s_%s.bin" % (str(Pa.Guid),Pa.Arch))
|
||||
Pa.DataPipe.dump(data_pipe_file)
|
||||
|
||||
autogen_rt, errorcode = self.StartAutoGen(mqueue, Pa.DataPipe, self.SkipAutoGen, PcdMaList,GlobalData.gCacheIR)
|
||||
|
||||
# Skip cache hit modules
|
||||
if GlobalData.gBinCacheSource:
|
||||
for Ma in TotalModules:
|
||||
if (Ma.MetaFile.Path, Ma.Arch) in GlobalData.gCacheIR and \
|
||||
GlobalData.gCacheIR[(Ma.MetaFile.Path, Ma.Arch)].PreMakeCacheHit:
|
||||
self.HashSkipModules.append(Ma)
|
||||
continue
|
||||
if (Ma.MetaFile.Path, Ma.Arch) in GlobalData.gCacheIR and \
|
||||
GlobalData.gCacheIR[(Ma.MetaFile.Path, Ma.Arch)].MakeCacheHit:
|
||||
self.HashSkipModules.append(Ma)
|
||||
continue
|
||||
BuildModules.append(Ma)
|
||||
else:
|
||||
BuildModules.extend(TotalModules)
|
||||
autogen_rt, errorcode = self.StartAutoGen(mqueue, Pa.DataPipe, self.SkipAutoGen, PcdMaList, cqueue)
|
||||
|
||||
if not autogen_rt:
|
||||
self.AutoGenMgr.TerminateWorkers()
|
||||
self.AutoGenMgr.join(1)
|
||||
raise FatalError(errorcode)
|
||||
|
||||
if GlobalData.gUseHashCache:
|
||||
for item in GlobalData.gModuleAllCacheStatus:
|
||||
(MetaFilePath, Arch, CacheStr, Status) = item
|
||||
Ma = ModuleAutoGen(Wa, PathClass(MetaFilePath, Wa), BuildTarget,\
|
||||
ToolChain, Arch, self.PlatformFile,Pa.DataPipe)
|
||||
if CacheStr == "PreMakeCache" and Status == False:
|
||||
self.PreMakeCacheMiss.add(Ma)
|
||||
if CacheStr == "PreMakeCache" and Status == True:
|
||||
self.PreMakeCacheHit.add(Ma)
|
||||
GlobalData.gModuleCacheHit.add(Ma)
|
||||
if CacheStr == "MakeCache" and Status == False:
|
||||
self.MakeCacheMiss.add(Ma)
|
||||
if CacheStr == "MakeCache" and Status == True:
|
||||
self.MakeCacheHit.add(Ma)
|
||||
GlobalData.gModuleCacheHit.add(Ma)
|
||||
self.AutoGenTime += int(round((time.time() - AutoGenStart)))
|
||||
AutoGenIdFile = os.path.join(GlobalData.gConfDirectory,".AutoGenIdFile.txt")
|
||||
with open(AutoGenIdFile,"w") as fw:
|
||||
fw.write("Arch=%s\n" % "|".join((Wa.ArchList)))
|
||||
fw.write("BuildDir=%s\n" % Wa.BuildDir)
|
||||
fw.write("PlatformGuid=%s\n" % str(Wa.AutoGenObjectList[0].Guid))
|
||||
|
||||
if GlobalData.gBinCacheSource:
|
||||
BuildModules.extend(self.MakeCacheMiss)
|
||||
elif GlobalData.gUseHashCache and not GlobalData.gBinCacheDest:
|
||||
BuildModules.extend(self.PreMakeCacheMiss)
|
||||
else:
|
||||
BuildModules.extend(self.AllDrivers)
|
||||
|
||||
self.Progress.Stop("done!")
|
||||
return Wa, BuildModules
|
||||
|
||||
|
@ -2253,18 +2227,9 @@ class Build():
|
|||
GlobalData.gAutoGenPhase = False
|
||||
|
||||
if GlobalData.gBinCacheSource:
|
||||
EdkLogger.quiet("Total cache hit driver num: %s, cache miss driver num: %s" % (len(set(self.HashSkipModules)), len(set(self.BuildModules))))
|
||||
CacheHitMa = set()
|
||||
CacheNotHitMa = set()
|
||||
for IR in GlobalData.gCacheIR.keys():
|
||||
if 'PlatformHash' in IR or 'PackageHash' in IR:
|
||||
continue
|
||||
if GlobalData.gCacheIR[IR].PreMakeCacheHit or GlobalData.gCacheIR[IR].MakeCacheHit:
|
||||
CacheHitMa.add(IR)
|
||||
else:
|
||||
# There might be binary module or module which has .inc files, not count for cache miss
|
||||
CacheNotHitMa.add(IR)
|
||||
EdkLogger.quiet("Total module num: %s, cache hit module num: %s" % (len(CacheHitMa)+len(CacheNotHitMa), len(CacheHitMa)))
|
||||
EdkLogger.quiet("[cache Summary]: Total module num: %s" % len(self.AllModules))
|
||||
EdkLogger.quiet("[cache Summary]: PreMakecache miss num: %s " % len(self.PreMakeCacheMiss))
|
||||
EdkLogger.quiet("[cache Summary]: Makecache miss num: %s " % len(self.MakeCacheMiss))
|
||||
|
||||
for Arch in Wa.ArchList:
|
||||
MakeStart = time.time()
|
||||
|
@ -2277,7 +2242,6 @@ class Build():
|
|||
# we need a full version of makefile for platform
|
||||
ExitFlag.set()
|
||||
BuildTask.WaitForComplete()
|
||||
self.invalidateHash()
|
||||
Pa.CreateMakeFile(False)
|
||||
EdkLogger.error("build", BUILD_ERROR, "Failed to build module", ExtraData=GlobalData.gBuildingModule)
|
||||
# Start task scheduler
|
||||
|
@ -2287,7 +2251,6 @@ class Build():
|
|||
# in case there's an interruption. we need a full version of makefile for platform
|
||||
|
||||
if BuildTask.HasError():
|
||||
self.invalidateHash()
|
||||
EdkLogger.error("build", BUILD_ERROR, "Failed to build module", ExtraData=GlobalData.gBuildingModule)
|
||||
self.MakeTime += int(round((time.time() - MakeStart)))
|
||||
|
||||
|
@ -2301,7 +2264,11 @@ class Build():
|
|||
BuildTask.WaitForComplete()
|
||||
self.CreateAsBuiltInf()
|
||||
if GlobalData.gBinCacheDest:
|
||||
self.UpdateBuildCache()
|
||||
self.GenDestCache()
|
||||
elif GlobalData.gUseHashCache and not GlobalData.gBinCacheSource:
|
||||
# Only for --hash
|
||||
# Update PreMakeCacheChain files
|
||||
self.GenLocalPreMakeCache()
|
||||
#
|
||||
# Get Module List
|
||||
#
|
||||
|
@ -2313,7 +2280,6 @@ class Build():
|
|||
# has been signaled.
|
||||
#
|
||||
if BuildTask.HasError():
|
||||
self.invalidateHash()
|
||||
EdkLogger.error("build", BUILD_ERROR, "Failed to build module", ExtraData=GlobalData.gBuildingModule)
|
||||
|
||||
# Create MAP file when Load Fix Address is enabled.
|
||||
|
@ -2350,7 +2316,6 @@ class Build():
|
|||
#
|
||||
self._SaveMapFile(MapBuffer, Wa)
|
||||
self.CreateGuidedSectionToolsFile(Wa)
|
||||
self.invalidateHash()
|
||||
## Generate GuidedSectionTools.txt in the FV directories.
|
||||
#
|
||||
def CreateGuidedSectionToolsFile(self,Wa):
|
||||
|
@ -2406,6 +2371,12 @@ class Build():
|
|||
## Launch the module or platform build
|
||||
#
|
||||
def Launch(self):
|
||||
self.AllDrivers = set()
|
||||
self.AllModules = set()
|
||||
self.PreMakeCacheMiss = set()
|
||||
self.PreMakeCacheHit = set()
|
||||
self.MakeCacheMiss = set()
|
||||
self.MakeCacheHit = set()
|
||||
if not self.ModuleFile:
|
||||
if not self.SpawnMode or self.Target not in ["", "all"]:
|
||||
self.SpawnMode = False
|
||||
|
@ -2423,23 +2394,16 @@ class Build():
|
|||
for Module in self.BuildModules:
|
||||
Module.CreateAsBuiltInf()
|
||||
|
||||
def UpdateBuildCache(self):
|
||||
all_lib_set = set()
|
||||
all_mod_set = set()
|
||||
for Module in self.BuildModules:
|
||||
def GenDestCache(self):
|
||||
for Module in self.AllModules:
|
||||
Module.GenPreMakefileHashList()
|
||||
Module.GenMakefileHashList()
|
||||
Module.CopyModuleToCache()
|
||||
all_mod_set.add(Module)
|
||||
for Module in self.HashSkipModules:
|
||||
Module.CopyModuleToCache()
|
||||
all_mod_set.add(Module)
|
||||
for Module in all_mod_set:
|
||||
for lib in Module.LibraryAutoGenList:
|
||||
all_lib_set.add(lib)
|
||||
for lib in all_lib_set:
|
||||
lib.CopyModuleToCache()
|
||||
all_lib_set.clear()
|
||||
all_mod_set.clear()
|
||||
self.HashSkipModules = []
|
||||
|
||||
def GenLocalPreMakeCache(self):
|
||||
for Module in self.PreMakeCacheMiss:
|
||||
Module.GenPreMakefileHashList()
|
||||
|
||||
## Do some clean-up works when error occurred
|
||||
def Relinquish(self):
|
||||
OldLogLevel = EdkLogger.GetLevel()
|
||||
|
|
Loading…
Reference in New Issue