mirror of https://github.com/acidanthera/audk.git
BaseTools: Add build info for binary modules that only list in FDF file
If the binary module is list in the FDF file but not list in the DSC file, current build report would not include these binary module's info in the report "Module section". The patch fix this issue. Cc: Liming Gao <liming.gao@intel.com> Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Yonghong Zhu <yonghong.zhu@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com>
This commit is contained in:
parent
d6c3ef2ed1
commit
25193a3339
|
@ -1942,6 +1942,10 @@ class PlatformAutoGen(AutoGen):
|
||||||
# @retval library_list List of library instances sorted
|
# @retval library_list List of library instances sorted
|
||||||
#
|
#
|
||||||
def ApplyLibraryInstance(self, Module):
|
def ApplyLibraryInstance(self, Module):
|
||||||
|
# Cover the case that the binary INF file is list in the FDF file but not DSC file, return empty list directly
|
||||||
|
if str(Module) not in self.Platform.Modules:
|
||||||
|
return []
|
||||||
|
|
||||||
ModuleType = Module.ModuleType
|
ModuleType = Module.ModuleType
|
||||||
|
|
||||||
# for overridding library instances with module specific setting
|
# for overridding library instances with module specific setting
|
||||||
|
|
|
@ -47,6 +47,9 @@ from Common.DataType import TAB_BACK_SLASH
|
||||||
from Common.LongFilePathSupport import OpenLongFilePath as open
|
from Common.LongFilePathSupport import OpenLongFilePath as open
|
||||||
from Common.MultipleWorkspace import MultipleWorkspace as mws
|
from Common.MultipleWorkspace import MultipleWorkspace as mws
|
||||||
import Common.GlobalData as GlobalData
|
import Common.GlobalData as GlobalData
|
||||||
|
from AutoGen.AutoGen import ModuleAutoGen
|
||||||
|
from Common.Misc import PathClass
|
||||||
|
from Common.String import NormPath
|
||||||
|
|
||||||
## Pattern to extract contents in EDK DXS files
|
## Pattern to extract contents in EDK DXS files
|
||||||
gDxsDependencyPattern = re.compile(r"DEPENDENCY_START(.+)DEPENDENCY_END", re.DOTALL)
|
gDxsDependencyPattern = re.compile(r"DEPENDENCY_START(.+)DEPENDENCY_END", re.DOTALL)
|
||||||
|
@ -1647,8 +1650,21 @@ class PlatformReport(object):
|
||||||
else:
|
else:
|
||||||
self._IsModuleBuild = False
|
self._IsModuleBuild = False
|
||||||
for Pa in Wa.AutoGenObjectList:
|
for Pa in Wa.AutoGenObjectList:
|
||||||
|
ModuleAutoGenList = []
|
||||||
for ModuleKey in Pa.Platform.Modules:
|
for ModuleKey in Pa.Platform.Modules:
|
||||||
self.ModuleReportList.append(ModuleReport(Pa.Platform.Modules[ModuleKey].M, ReportType))
|
ModuleAutoGenList.append(Pa.Platform.Modules[ModuleKey].M)
|
||||||
|
if GlobalData.gFdfParser != None:
|
||||||
|
if Pa.Arch in GlobalData.gFdfParser.Profile.InfDict:
|
||||||
|
INFList = GlobalData.gFdfParser.Profile.InfDict[Pa.Arch]
|
||||||
|
for InfName in INFList:
|
||||||
|
InfClass = PathClass(NormPath(InfName), Wa.WorkspaceDir, Pa.Arch)
|
||||||
|
Ma = ModuleAutoGen(Wa, InfClass, Pa.BuildTarget, Pa.ToolChain, Pa.Arch, Wa.MetaFile)
|
||||||
|
if Ma == None:
|
||||||
|
continue
|
||||||
|
if Ma not in ModuleAutoGenList:
|
||||||
|
ModuleAutoGenList.append(Ma)
|
||||||
|
for MGen in ModuleAutoGenList:
|
||||||
|
self.ModuleReportList.append(ModuleReport(MGen, ReportType))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue