if not (self.__GetBlockStatement(FvObj) or self.__GetFvBaseAddress(FvObj) or \r
self.__GetFvForceRebase(FvObj) or self.__GetFvAlignment(FvObj) or \r
self.__GetFvAttributes(FvObj) or self.__GetFvNameGuid(FvObj) or \r
- self.__GetFvExtEntryStatement(FvObj)):\r
+ self.__GetFvExtEntryStatement(FvObj) or self.__GetFvNameString(FvObj)):\r
break\r
\r
+ if FvObj.FvNameString == 'TRUE' and not FvObj.FvNameGuid:\r
+ raise Warning("FvNameString found but FvNameGuid was not found", self.FileName, self.CurrentLineNumber)\r
+\r
self.__GetAprioriSection(FvObj, FvObj.DefineVarDict.copy())\r
self.__GetAprioriSection(FvObj, FvObj.DefineVarDict.copy())\r
\r
\r
return True\r
\r
+ def __GetFvNameString(self, FvObj):\r
+\r
+ if not self.__IsKeyword( "FvNameString"):\r
+ return False\r
+\r
+ if not self.__IsToken( "="):\r
+ raise Warning("expected '='", self.FileName, self.CurrentLineNumber)\r
+\r
+ if not self.__GetNextToken() or self.__Token not in ('TRUE', 'FALSE'):\r
+ raise Warning("expected TRUE or FALSE for FvNameString", self.FileName, self.CurrentLineNumber)\r
+\r
+ FvObj.FvNameString = self.__Token\r
+\r
+ return True\r
+\r
def __GetFvExtEntryStatement(self, FvObj):\r
\r
if not self.__IsKeyword( "FV_EXT_ENTRY"):\r
if self.FvNameGuid <> None and self.FvNameGuid <> '':\r
TotalSize = 16 + 4\r
Buffer = ''\r
- #\r
- # Create EXT entry for FV UI name\r
- # This GUID is used: A67DF1FA-8DE8-4E98-AF09-4BDF2EFFBC7C\r
- #\r
- FvUiLen = len(self.UiFvName)\r
- TotalSize += (FvUiLen + 16 + 4)\r
- Guid = FV_UI_EXT_ENTY_GUID.split('-')\r
- #\r
- # Layout:\r
- # EFI_FIRMWARE_VOLUME_EXT_ENTRY : size 4\r
- # GUID : size 16\r
- # FV UI name\r
- #\r
- Buffer += (pack('HH', (FvUiLen + 16 + 4), 0x0002)\r
- + pack('=LHHBBBBBBBB', int(Guid[0], 16), int(Guid[1], 16), int(Guid[2], 16),\r
- int(Guid[3][-4:-2], 16), int(Guid[3][-2:], 16), int(Guid[4][-12:-10], 16),\r
- int(Guid[4][-10:-8], 16), int(Guid[4][-8:-6], 16), int(Guid[4][-6:-4], 16),\r
- int(Guid[4][-4:-2], 16), int(Guid[4][-2:], 16))\r
- + self.UiFvName)\r
+ if self.FvNameString == 'TRUE':\r
+ #\r
+ # Create EXT entry for FV UI name\r
+ # This GUID is used: A67DF1FA-8DE8-4E98-AF09-4BDF2EFFBC7C\r
+ #\r
+ FvUiLen = len(self.UiFvName)\r
+ TotalSize += (FvUiLen + 16 + 4)\r
+ Guid = FV_UI_EXT_ENTY_GUID.split('-')\r
+ #\r
+ # Layout:\r
+ # EFI_FIRMWARE_VOLUME_EXT_ENTRY : size 4\r
+ # GUID : size 16\r
+ # FV UI name\r
+ #\r
+ Buffer += (pack('HH', (FvUiLen + 16 + 4), 0x0002)\r
+ + pack('=LHHBBBBBBBB', int(Guid[0], 16), int(Guid[1], 16), int(Guid[2], 16),\r
+ int(Guid[3][-4:-2], 16), int(Guid[3][-2:], 16), int(Guid[4][-12:-10], 16),\r
+ int(Guid[4][-10:-8], 16), int(Guid[4][-8:-6], 16), int(Guid[4][-6:-4], 16),\r
+ int(Guid[4][-4:-2], 16), int(Guid[4][-2:], 16))\r
+ + self.UiFvName)\r
\r
for Index in range (0, len(self.FvExtEntryType)):\r
if self.FvExtEntryType[Index] == 'FILE':\r