From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mga14.intel.com (mga14.intel.com [192.55.52.115]) (using TLSv1 with cipher CAMELLIA256-SHA (256/256 bits)) (No client certificate requested) by ml01.01.org (Postfix) with ESMTPS id 555FC81D31 for ; Tue, 1 Nov 2016 17:38:17 -0700 (PDT) Received: from fmsmga006.fm.intel.com ([10.253.24.20]) by fmsmga103.fm.intel.com with ESMTP; 01 Nov 2016 17:38:18 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.31,582,1473145200"; d="scan'208,217";a="26323224" Received: from fmsmsx108.amr.corp.intel.com ([10.18.124.206]) by fmsmga006.fm.intel.com with ESMTP; 01 Nov 2016 17:38:18 -0700 Received: from fmsmsx126.amr.corp.intel.com (10.18.125.43) by FMSMSX108.amr.corp.intel.com (10.18.124.206) with Microsoft SMTP Server (TLS) id 14.3.248.2; Tue, 1 Nov 2016 17:38:18 -0700 Received: from shsmsx101.ccr.corp.intel.com (10.239.4.153) by FMSMSX126.amr.corp.intel.com (10.18.125.43) with Microsoft SMTP Server (TLS) id 14.3.248.2; Tue, 1 Nov 2016 17:38:17 -0700 Received: from shsmsx102.ccr.corp.intel.com ([169.254.2.206]) by SHSMSX101.ccr.corp.intel.com ([169.254.1.104]) with mapi id 14.03.0248.002; Wed, 2 Nov 2016 08:38:15 +0800 From: "Gao, Liming" To: "Kinney, Michael D" , "Yao, Jiewen" , "edk2-devel@lists.01.org" CC: "Tian, Feng" , "Zeng, Star" , "Zhang, Chao B" Thread-Topic: [PATCH V5 06/12] SignedCapsulePkg/CapsulePkg.dec: Add capsule related definition. Thread-Index: AQHSMFgHHcgadjh9a0SE9BzjZDXQYaDELtIAgACyUZA= Date: Wed, 2 Nov 2016 00:38:14 +0000 Message-ID: <4A89E2EF3DFEDB4C8BFDE51014F606A14B49D19D@shsmsx102.ccr.corp.intel.com> References: <1477575745-3052-1-git-send-email-jiewen.yao@intel.com> <1477575745-3052-7-git-send-email-jiewen.yao@intel.com> In-Reply-To: Accept-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ctpclassification: CTP_IC x-titus-metadata-40: eyJDYXRlZ29yeUxhYmVscyI6IiIsIk1ldGFkYXRhIjp7Im5zIjoiaHR0cDpcL1wvd3d3LnRpdHVzLmNvbVwvbnNcL0ludGVsMyIsImlkIjoiYWZkMDFmNTMtNjE3My00YWVhLTgwYzctYTJiMWFmMWIxYTZkIiwicHJvcHMiOlt7Im4iOiJDVFBDbGFzc2lmaWNhdGlvbiIsInZhbHMiOlt7InZhbHVlIjoiQ1RQX0lDIn1dfV19LCJTdWJqZWN0TGFiZWxzIjpbXSwiVE1DVmVyc2lvbiI6IjE1LjkuNi42IiwiVHJ1c3RlZExhYmVsSGFzaCI6Im5iVm5pSytxOUI2Q2l1SVFnOEJ5XC9iMHowWERkbjVTaFgyNVBlejVCZG5nPSJ9 x-originating-ip: [10.239.127.40] MIME-Version: 1.0 X-Content-Filtered-By: Mailman/MimeDel 2.1.21 Subject: Re: [PATCH V5 06/12] SignedCapsulePkg/CapsulePkg.dec: Add capsule related definition. X-BeenThere: edk2-devel@lists.01.org X-Mailman-Version: 2.1.21 Precedence: list List-Id: EDK II Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 02 Nov 2016 00:38:17 -0000 Content-Language: en-US Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: quoted-printable Mike: To be simplification for below FILE statement, we can update tool to supp= ort GuidCName and PCD value as FILE GUID. FILE RAW =3D AF9C9EB2-12AD-4D3E-A4D4-96F6C9966215 { # PcdEdkiiSystemFirmwar= eFileGuid =3D=3D> FILE RAW =3D PcdEdkiiSystemFirmwareFileGuid $(WORKSPACE)/$(OUTPUT_DIRECTORY)/$(TARGET)_$(TOOL_CHAIN_TAG)/FV/Vlv.ROM } FILE RAW =3D ce57b167-b0e4-41e8-a897-5f4feb781d40 { # gEdkiiSystemFmpCapsul= eDriverFvFileGuid =3D=3D> FILE RAW =3D gEdkiiSystemFmpCapsuleDriverFvFil= eGuid $(WORKSPACE)/$(OUTPUT_DIRECTORY)/$(TARGET)_$(TOOL_CHAIN_TAG)/FV/CAPSULEDISP= ATCHFV.Fv } FILE RAW =3D 812136D3-4D3A-433A-9418-29BB9BF78F6E { # gEdkiiSystemFmpCapsul= eConfigFileGuid Vlv2TbltDevicePkg/Feature/Capsule/SystemFirmwareUpdateConfig/SystemFirmware= UpdateConfig.ini } Thanks Liming From: Kinney, Michael D Sent: Wednesday, November 2, 2016 5:57 AM To: Yao, Jiewen ; edk2-devel@lists.01.org; Kinney, Mi= chael D Cc: Tian, Feng ; Zeng, Star ; Gao= , Liming ; Zhang, Chao B Subject: RE: [PATCH V5 06/12] SignedCapsulePkg/CapsulePkg.dec: Add capsule = related definition. Jiewen, Why is PcdEdkiiSystemFirmwareFileGuid a PCD instead of a GUID like gEdkiiSystemFmpCapsuleDriverFvFileGuid and gEdkiiSystemFmpCapsuleConfigFileGuid? The PcdEdkiiSystemFirmwareFileGuid value from the DEC file default is used for both Quark and Vlv2 platforms, so it does not appear to be a value you expect a platform developer to make unique per platform. It makes sense to use a fixed value, so the system firmware update Processing can find the FFS file in the Cargo FV to find the Binary file described by the INI file with FFS file GUID of gEdkiiSystemFmpCapsuleConfigFileGuid. The following is an example of where this PCD and GUIDs are used In an FDF file to generate a firmware update image and recovery imaghe. [FV.SystemFirmwareUpdateCargo] FvAlignment =3D 16 ERASE_POLARITY =3D 1 MEMORY_MAPPED =3D TRUE STICKY_WRITE =3D TRUE LOCK_CAP =3D TRUE LOCK_STATUS =3D TRUE WRITE_DISABLED_CAP =3D TRUE WRITE_ENABLED_CAP =3D TRUE WRITE_STATUS =3D TRUE WRITE_LOCK_CAP =3D TRUE WRITE_LOCK_STATUS =3D TRUE READ_DISABLED_CAP =3D TRUE READ_ENABLED_CAP =3D TRUE READ_STATUS =3D TRUE READ_LOCK_CAP =3D TRUE READ_LOCK_STATUS =3D TRUE FILE RAW =3D AF9C9EB2-12AD-4D3E-A4D4-96F6C9966215 { # PcdEdkiiSystemFirmwar= eFileGuid $(WORKSPACE)/$(OUTPUT_DIRECTORY)/$(TARGET)_$(TOOL_CHAIN_TAG)/FV/Vlv.ROM } FILE RAW =3D ce57b167-b0e4-41e8-a897-5f4feb781d40 { # gEdkiiSystemFmpCapsul= eDriverFvFileGuid $(WORKSPACE)/$(OUTPUT_DIRECTORY)/$(TARGET)_$(TOOL_CHAIN_TAG)/FV/CAPSULEDISP= ATCHFV.Fv } FILE RAW =3D 812136D3-4D3A-433A-9418-29BB9BF78F6E { # gEdkiiSystemFmpCapsul= eConfigFileGuid Vlv2TbltDevicePkg/Feature/Capsule/SystemFirmwareUpdateConfig/SystemFirmware= UpdateConfig.ini } Best regards, Mike > -----Original Message----- > From: Yao, Jiewen > Sent: Thursday, October 27, 2016 6:42 AM > To: edk2-devel@lists.01.org > Cc: Tian, Feng ; Zeng, Star ; Kinney, Michael > D ; Gao, Liming ; Zhang, Chao B > > Subject: [PATCH V5 06/12] SignedCapsulePkg/CapsulePkg.dec: Add capsule re= lated > definition. > > 1) Add capsule related GUID. > EdkiiSystemFmpCapsule > 2) Add capsule related library. > EdkiiSystemCapsuleLib > IniParsingLib > PlatformFlashAccessLib > 3) Add EDKII system capsule related DynamicEx PCD > PcdEdkiiSystemFirmwareImageDescriptor > PcdEdkiiSystemFirmwareFileGuid > NOTE: We use DynamicEx here because the update driver may be in > the capsule FMP, instead of system firmware. > The update driver MUST use the PCD info produced system firmware. > 4) Add Test key file PCD > These PCDs indicate the GUID of FFS which contains test key file. > > Cc: Feng Tian > Cc: Star Zeng > Cc: Michael D Kinney > Cc: Liming Gao > Cc: Chao Zhang > Contributed-under: TianoCore Contribution Agreement 1.0 > Signed-off-by: Jiewen Yao > Reviewed-by: Liming Gao > --- > SignedCapsulePkg/SignedCapsulePkg.dec | 76 ++++++++++++++++++++ > 1 file changed, 76 insertions(+) > > diff --git a/SignedCapsulePkg/SignedCapsulePkg.dec > b/SignedCapsulePkg/SignedCapsulePkg.dec > new file mode 100644 > index 0000000..436d602 > --- /dev/null > +++ b/SignedCapsulePkg/SignedCapsulePkg.dec > @@ -0,0 +1,76 @@ > +## @file > +# This package provides EDKII capsule related support. > +# > +# Copyright (c) 2016, Intel Corporation. All rights reserved. > +# This program and the accompanying materials are licensed and made avai= lable under > +# the terms and conditions of the BSD License that accompanies this dist= ribution. > +# The full text of the license may be found at > +# http://opensource.org/licenses/bsd-license.php. > +# > +# THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS, > +# WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR I= MPLIED. > +# > +## > + > + > +[Defines] > + DEC_SPECIFICATION =3D 0x00010005 > + PACKAGE_NAME =3D SignedCapsulePkg > + PACKAGE_GUID =3D 75AA5D82-7BC4-44A9-82FB-0820EBC79BED > + PACKAGE_VERSION =3D 0.1 > + > +[Includes] > + Include > + > +[LibraryClasses] > + ## @libraryclass Provides services for EDKII system FMP capsule. > + # > + EdkiiSystemCapsuleLib|Include/Library/EdkiiSystemCapsuleLib.h > + > + ## @libraryclass Provides services to parse the INI configuration file. > + # > + IniParsingLib|Include/Library/IniParsingLib.h > + > + ## @libraryclass Provides services to access flash device. > + # > + PlatformFlashAccessLib|Include/Library/PlatformFlashAccessLib.h > + > +[Guids] > + gEfiSignedCapsulePkgTokenSpaceGuid =3D { 0xe1eb612f, 0x1c6c, 0x485d, { = 0x9d, 0x6, > 0x65, 0x8, 0x44, 0x88, 0x15, 0x69 }} > + > + ## Include/Guid/EdkiiSystemFmpCapsule.h > + gEdkiiSystemFirmwareImageDescriptorFileGuid =3D {0x90b2b846, 0xca6d, 0x= 4d6e, {0xa8, > 0xd3, 0xc1, 0x40, 0xa8, 0xe1, 0x10, 0xac}} > + gEdkiiSystemFmpCapsuleConfigFileGuid =3D {0x812136d3, 0x4d3a, 0x433a, {= 0x94, > 0x18, 0x29, 0xbb, 0x9b, 0xf7, 0x8f, 0x6e}} > + gEdkiiSystemFmpCapsuleDriverFvFileGuid =3D {0xce57b167, 0xb0e4, 0x41e8,= {0xa8, > 0x97, 0x5f, 0x4f, 0xeb, 0x78, 0x1d, 0x40}} > + > +[PcdsFixedAtBuild, PcdsPatchableInModule, PcdsDynamic, PcdsDynamicEx] > + ## This is the GUID of the FFS which contains the Rsa2048Sha256TestPubl= icKeyFile as > a RAW section. > + # @Prompt GUID of the FFS which contains the Rsa2048Sha256TestPublicKey= File. > + gEfiSignedCapsulePkgTokenSpaceGuid.PcdEdkiiRsa2048Sha256TestPublicKeyFi= leGuid|{0x04, > 0xe1, 0xfe, 0xc4, 0x57, 0x66, 0x36, 0x49, 0xa6, 0x11, 0x13, 0x8d, 0xbc, 0= x2a, 0x76, > 0xad}|VOID*|0xA0010001 > + > + ## This is the GUID of the FFS which contains the Pkcs7TestPublicKeyFil= e as a RAW > section. > + # @Prompt GUID of the FFS which contains the Pkcs7TestPublicKeyFile. > + gEfiSignedCapsulePkgTokenSpaceGuid.PcdEdkiiPkcs7TestPublicKeyFileGuid|{= 0xba, 0xf5, > 0x93, 0xf0, 0x37, 0x6f, 0x16, 0x48, 0x9e, 0x52, 0x91, 0xbe, 0xa0, 0xf7, 0= xe0, > 0xb8}|VOID*|0xA0010002 > + > +[PcdsDynamicEx] > + ## This dynamic PCD holds the EDKII system firmware image descriptor. > + # This information can be used for version check in EDKII system FMP ca= psule. > + # Only if the new EdkiiSystemFrimwareImageDescriptor.Version is not les= s than > + # the current PcdEdkiiSystemFirmwareImageDescriptor.LowestSupportedVers= ion, > + # the EDKII system FmpCapsule will be processed. > + # The data structure of this PCD is EDKII_SYSTEM_FIRMWARE_IMAGE_DESCRIP= TOR, > + # SignedCapsulePkg/Include/Guid/EdkiiSystemFmpCapsule.h. > + # It must be in [PcdsDynamicEx], because the EDKII system firmware upda= te module > may > + # consume the PCD produced in current system firmware. > + # @Prompt EDKII system firmware image descriptor. > + > gEfiSignedCapsulePkgTokenSpaceGuid.PcdEdkiiSystemFirmwareImageDescriptor|= {0x0}|VOID*|0x > 00000037 > + > + ## This dynamic PCD hold the GUID of a firmware FFS which includes EDKI= I > + # system firmware image. > + # An EDKII system firmware udpate module need consume this PCD to extra= ct > + # the EDKII system firmware from the capsule image. > + # It must be in [PcdsDynamicEx], because the EDKII system firmware upda= te module > may > + # consume the PCD produced in current system firmware image. > + # @Prompt EDKII system firmware image FFS GUID. > + gEfiSignedCapsulePkgTokenSpaceGuid.PcdEdkiiSystemFirmwareFileGuid|{0xb2= , 0x9e, 0x9c, > 0xaf, 0xad, 0x12, 0x3e, 0x4d, 0xa4, 0xd4, 0x96, 0xf6, 0xc9, 0x96, 0x62, > 0x15}|VOID*|0x00001010 > + > -- > 2.7.4.windows.1