BaseTools:Make BaseTools support new rules to generate RAW FFS FILE
BZ:https://bugzilla.tianocore.org/show_bug.cgi?id=1765 If RAW FFS File Rule has no section for its data.For RAW FFS File, directly call GenFfs tool to generate FFS file. Ffs Rule: [Rule.Common.USER_DEFINED.MicroCode] FILE RAW = $(NAMED_GUID) { $(INF_OUTPUT)/$(MODULE_NAME).bin } [Rule.Common.USER_DEFINED.LOGO] FILE RAW = $(NAMED_GUID) { |.bmp } As shown in the rule above,if SectionType and FileType not defined, FFS files are generated directly, and no other type of file is generated. The patch is to make the BaseTools support these two rules Cc: Bob Feng <bob.c.feng@intel.com> Cc: Liming Gao <liming.gao@intel.com> Signed-off-by: Zhiju.Fan <zhijux.fan@intel.com> Reviewed-by: Liming Gao <liming.gao@intel.com> Reviewed-by: Bob Feng <bob.c.feng@intel.com>
This commit is contained in:
@ -3749,8 +3749,19 @@ class FdfParser:
|
||||
#
|
||||
def _GetEfiSection(self, Obj):
|
||||
OldPos = self.GetFileBufferPos()
|
||||
EfiSectionObj = EfiSection()
|
||||
if not self._GetNextWord():
|
||||
return False
|
||||
CurrentLine = self._CurrentLine()[self.CurrentOffsetWithinLine:].split()[0].strip()
|
||||
if self._Token == '{' and Obj.FvFileType == "RAW" and TAB_SPLIT in CurrentLine:
|
||||
if self._IsToken(TAB_VALUE_SPLIT):
|
||||
EfiSectionObj.FileExtension = self._GetFileExtension()
|
||||
elif self._GetNextToken():
|
||||
EfiSectionObj.FileName = self._Token
|
||||
EfiSectionObj.SectionType = BINARY_FILE_TYPE_RAW
|
||||
Obj.SectionList.append(EfiSectionObj)
|
||||
return True
|
||||
else:
|
||||
return False
|
||||
SectionName = self._Token
|
||||
|
||||
if SectionName not in {
|
||||
@ -3816,7 +3827,6 @@ class FdfParser:
|
||||
Obj.SectionList.append(FvImageSectionObj)
|
||||
return True
|
||||
|
||||
EfiSectionObj = EfiSection()
|
||||
EfiSectionObj.SectionType = SectionName
|
||||
|
||||
if not self._GetNextToken():
|
||||
|
Reference in New Issue
Block a user