+ def _GetFmp(self):\r
+ if not self._GetNextToken():\r
+ return False\r
+ S = self._Token.upper()\r
+ if S.startswith(TAB_SECTION_START) and not S.startswith("[FMPPAYLOAD."):\r
+ self.SectionParser(S)\r
+ self._UndoToken()\r
+ return False\r
+\r
+ self._UndoToken()\r
+ self._SkipToToken("[FMPPAYLOAD.", True)\r
+ FmpUiName = self._GetUiName().upper()\r
+ if FmpUiName in self.Profile.FmpPayloadDict:\r
+ raise Warning("Duplicated FMP UI name found: %s" % FmpUiName, self.FileName, self.CurrentLineNumber)\r
+\r
+ FmpData = CapsulePayload()\r
+ FmpData.UiName = FmpUiName\r
+\r
+ if not self._IsToken(TAB_SECTION_END):\r
+ raise Warning.ExpectedBracketClose(self.FileName, self.CurrentLineNumber)\r
+\r
+ if not self._GetNextToken():\r
+ raise Warning("The FMP payload section is empty!", self.FileName, self.CurrentLineNumber)\r
+ FmpKeyList = ['IMAGE_HEADER_INIT_VERSION', 'IMAGE_TYPE_ID', 'IMAGE_INDEX', 'HARDWARE_INSTANCE', 'CERTIFICATE_GUID', 'MONOTONIC_COUNT']\r
+ while self._Token in FmpKeyList:\r
+ Name = self._Token\r
+ FmpKeyList.remove(Name)\r
+ if not self._IsToken(TAB_EQUAL_SPLIT):\r
+ raise Warning.ExpectedEquals(self.FileName, self.CurrentLineNumber)\r
+ if Name == 'IMAGE_TYPE_ID':\r
+ if not self._GetNextGuid():\r
+ raise Warning.Expected("GUID value for IMAGE_TYPE_ID.", self.FileName, self.CurrentLineNumber)\r
+ FmpData.ImageTypeId = self._Token\r
+ elif Name == 'CERTIFICATE_GUID':\r
+ if not self._GetNextGuid():\r
+ raise Warning.Expected("GUID value for CERTIFICATE_GUID.", self.FileName, self.CurrentLineNumber)\r
+ FmpData.Certificate_Guid = self._Token\r
+ if UUID(FmpData.Certificate_Guid) != EFI_CERT_TYPE_RSA2048_SHA256_GUID and UUID(FmpData.Certificate_Guid) != EFI_CERT_TYPE_PKCS7_GUID:\r
+ raise Warning("Only support EFI_CERT_TYPE_RSA2048_SHA256_GUID or EFI_CERT_TYPE_PKCS7_GUID for CERTIFICATE_GUID.", self.FileName, self.CurrentLineNumber)\r
+ else:\r
+ if not self._GetNextToken():\r
+ raise Warning.Expected("value of %s" % Name, self.FileName, self.CurrentLineNumber)\r
+ Value = self._Token\r
+ if Name == 'IMAGE_HEADER_INIT_VERSION':\r
+ if FdfParser._Verify(Name, Value, 'UINT8'):\r
+ FmpData.Version = Value\r
+ elif Name == 'IMAGE_INDEX':\r
+ if FdfParser._Verify(Name, Value, 'UINT8'):\r
+ FmpData.ImageIndex = Value\r
+ elif Name == 'HARDWARE_INSTANCE':\r
+ if FdfParser._Verify(Name, Value, 'UINT8'):\r
+ FmpData.HardwareInstance = Value\r
+ elif Name == 'MONOTONIC_COUNT':\r
+ if FdfParser._Verify(Name, Value, 'UINT64'):\r
+ FmpData.MonotonicCount = Value\r
+ if FmpData.MonotonicCount.upper().startswith('0X'):\r
+ FmpData.MonotonicCount = (long)(FmpData.MonotonicCount, 16)\r
+ else:\r
+ FmpData.MonotonicCount = (long)(FmpData.MonotonicCount)\r
+ if not self._GetNextToken():\r
+ break\r
+ else:\r
+ self._UndoToken()\r
+\r
+ if (FmpData.MonotonicCount and not FmpData.Certificate_Guid) or (not FmpData.MonotonicCount and FmpData.Certificate_Guid):\r
+ EdkLogger.error("FdfParser", FORMAT_INVALID, "CERTIFICATE_GUID and MONOTONIC_COUNT must be work as a pair.")\r
+\r
+ # Only the IMAGE_TYPE_ID is required item\r
+ if FmpKeyList and 'IMAGE_TYPE_ID' in FmpKeyList:\r
+ raise Warning("'IMAGE_TYPE_ID' in FMP payload section.", self.FileName, self.CurrentLineNumber)\r
+ # get the Image file and Vendor code file\r
+ self._GetFMPCapsuleData(FmpData)\r
+ if not FmpData.ImageFile:\r
+ raise Warning("Missing image file in FMP payload section.", self.FileName, self.CurrentLineNumber)\r
+ # check whether more than one Vendor code file\r
+ if len(FmpData.VendorCodeFile) > 1:\r
+ raise Warning("Vendor code file max of 1 per FMP payload section.", self.FileName, self.CurrentLineNumber)\r
+ self.Profile.FmpPayloadDict[FmpUiName] = FmpData\r
+ return True\r
+\r
+ ## _GetCapsule() method\r