On Mon, Jun 04, 2018 at 06:58:25PM +0200, Marcin Wojtas wrote: > Ard, > > 2018-06-04 18:47 GMT+02:00 Ard Biesheuvel <[email protected]>: > > On 4 June 2018 at 18:41, Marcin Wojtas <[email protected]> wrote: > >> All required components are in place, so we can now > >> add all necessary dependencies to build and use capsule support > >> for Armada7k8k platforms. It is conditionally enabled > >> with '-D CAPSULE_ENABLE' flag added during build time. > >> > >> Because the capsule generation must be sequential, > >> due to boot requirements and glueing all binaries > >> (BLE, ARM-TF, BL33) externally, introduce additional > >> .dsc and .fdf file solely for creating the capsule. > >> > >> In order to build the capsule following parameters > >> must be passed to the build command of the common file > >> Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.dsc: > >> > >> -D PLATFORM_NAME=<previously built platform name with capsule support> > >> -D ARM_TRUSTED_FIRMWARE_IMAGE_PREFIX=<path/to/flash-image.bin> > >> > > > > I think there was some miscommunication here: > > > > - PREFIX is not a full path, it is a prefix. So in this case, the > > 'flash-image.bin' part should still be hardcoded, but the DEFINE > > allows you to specify its location in the directory tree. > > - apologies for bikeshedding/disagreeing with what Leif said > > previously, but ARM_TRUSTED_FIRMWARE_IMAGE_PREFIX is not appropriate > > here, given that flash-image.bin is the entire firmware image, so > > ARM-TF, UEFI, and other bits and pieces that make up the full image. I > > understand that Leif wants a generic prefix, but using it in > > completely different ways (ARM-TF fip vs the entire firmware image) > > defeats the purpose of that.
Oh, I agree with all of the above and was fully hoping someone could come up with something better :) > So is passing a full path a valid way for you? > > If yes, how a about following parameter name: 'FIRMWARE_IMAGE_PATH' ? I generally prefer a PREFIX over a path, since this does not mandate a directory name, but could also contain a file prefix. While not strictly speaking relevant to the internals of edk2-platforms, could you explain to me where the "firmware-image.bin" images end up being generated in the first place? I.e., their complete path in ARM Trusted Firmware build output, with build targets and all? Best Regards, Leif > Best regards, > Marcin > > > > > > >> Contributed-under: TianoCore Contribution Agreement 1.1 > >> Signed-off-by: Marcin Wojtas <[email protected]> > >> Signed-off-by: David Sniatkiwicz <[email protected]> > >> --- > >> Platform/Marvell/Armada70x0Db/Armada70x0Db.fdf | 66 ++++++++++++++++++ > >> Silicon/Marvell/Armada7k8k/Armada7k8k.dsc.inc | 41 ++++++++++++ > >> Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.dsc | 46 +++++++++++++ > >> Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.fdf | 70 ++++++++++++++++++++ > >> 4 files changed, 223 insertions(+) > >> > >> diff --git a/Platform/Marvell/Armada70x0Db/Armada70x0Db.fdf > >> b/Platform/Marvell/Armada70x0Db/Armada70x0Db.fdf > >> index bf04f4d..e5e5443 100644 > >> --- a/Platform/Marvell/Armada70x0Db/Armada70x0Db.fdf > >> +++ b/Platform/Marvell/Armada70x0Db/Armada70x0Db.fdf > >> @@ -201,6 +201,15 @@ FvNameGuid = > >> 5eda4200-2c5f-43cb-9da3-0baf74b1b30c > >> INF MdeModulePkg/Universal/BdsDxe/BdsDxe.inf > >> INF MdeModulePkg/Application/UiApp/UiApp.inf > >> > >> +!if $(CAPSULE_ENABLE) > >> + # Firmware update > >> + INF MdeModulePkg/Universal/EsrtDxe/EsrtDxe.inf > >> + INF > >> SignedCapsulePkg/Universal/SystemFirmwareUpdate/SystemFirmwareReportDxe.inf > >> + FILE FREEFORM = > >> PCD(gEfiSignedCapsulePkgTokenSpaceGuid.PcdEdkiiPkcs7TestPublicKeyFileGuid) > >> { > >> + SECTION RAW = BaseTools/Source/Python/Pkcs7Sign/TestRoot.cer > >> + SECTION UI = "Pkcs7TestRoot" > >> + } > >> +!endif > >> > >> # PEI phase firmware volume > >> [FV.FVMAIN_COMPACT] > >> @@ -228,6 +237,11 @@ READ_LOCK_STATUS = TRUE > >> INF ArmPlatformPkg/MemoryInitPei/MemoryInitPeim.inf > >> INF ArmPkg/Drivers/CpuPei/CpuPei.inf > >> INF MdeModulePkg/Universal/Variable/Pei/VariablePei.inf > >> +!if $(CAPSULE_ENABLE) > >> + INF > >> MdeModulePkg/Universal/FaultTolerantWritePei/FaultTolerantWritePei.inf > >> + INF MdeModulePkg/Universal/CapsulePei/CapsulePei.inf > >> + INF RuleOverride = FMP_IMAGE_DESC > >> Silicon/Marvell/Armada7k8k/Feature/Capsule/SystemFirmwareDescriptor/SystemFirmwareDescriptor.inf > >> +!endif > >> INF MdeModulePkg/Core/DxeIplPeim/DxeIpl.inf > >> > >> FILE FV_IMAGE = 9E21FD93-9C72-4c15-8C4B-E77F1DB2D792 { > >> @@ -236,6 +250,49 @@ READ_LOCK_STATUS = TRUE > >> } > >> } > >> > >> +!if $(CAPSULE_ENABLE) > >> +[FV.SystemFirmwareDescriptor] > >> +FvAlignment = 8 > >> +ERASE_POLARITY = 1 > >> +MEMORY_MAPPED = TRUE > >> +STICKY_WRITE = TRUE > >> +LOCK_CAP = TRUE > >> +LOCK_STATUS = TRUE > >> +WRITE_DISABLED_CAP = TRUE > >> +WRITE_ENABLED_CAP = TRUE > >> +WRITE_STATUS = TRUE > >> +WRITE_LOCK_CAP = TRUE > >> +WRITE_LOCK_STATUS = TRUE > >> +READ_DISABLED_CAP = TRUE > >> +READ_ENABLED_CAP = TRUE > >> +READ_STATUS = TRUE > >> +READ_LOCK_CAP = TRUE > >> +READ_LOCK_STATUS = TRUE > >> + > >> + INF RuleOverride = FMP_IMAGE_DESC > >> Silicon/Marvell/Armada7k8k/Feature/Capsule/SystemFirmwareDescriptor/SystemFirmwareDescriptor.inf > >> + > >> +[FV.CapsuleDispatchFv] > >> +FvAlignment = 8 > >> +ERASE_POLARITY = 1 > >> +MEMORY_MAPPED = TRUE > >> +STICKY_WRITE = TRUE > >> +LOCK_CAP = TRUE > >> +LOCK_STATUS = TRUE > >> +WRITE_DISABLED_CAP = TRUE > >> +WRITE_ENABLED_CAP = TRUE > >> +WRITE_STATUS = TRUE > >> +WRITE_LOCK_CAP = TRUE > >> +WRITE_LOCK_STATUS = TRUE > >> +READ_DISABLED_CAP = TRUE > >> +READ_ENABLED_CAP = TRUE > >> +READ_STATUS = TRUE > >> +READ_LOCK_CAP = TRUE > >> +READ_LOCK_STATUS = TRUE > >> + > >> + INF > >> SignedCapsulePkg/Universal/SystemFirmwareUpdate/SystemFirmwareUpdateDxe.inf > >> + > >> +!endif > >> + > >> > >> ################################################################################ > >> # > >> # Rules are use with the [FV] section's module INF type to define > >> @@ -331,3 +388,12 @@ READ_LOCK_STATUS = TRUE > >> UI STRING ="$(MODULE_NAME)" Optional > >> PE32 PE32 $(INF_OUTPUT)/$(MODULE_NAME).efi > >> } > >> + > >> +[Rule.Common.PEIM.FMP_IMAGE_DESC] > >> + FILE PEIM = $(NAMED_GUID) { > >> + RAW BIN |.acpi > >> + PEI_DEPEX PEI_DEPEX Optional > >> $(INF_OUTPUT)/$(MODULE_NAME).depex > >> + PE32 PE32 Align=4K $(INF_OUTPUT)/$(MODULE_NAME).efi > >> + UI STRING="$(MODULE_NAME)" Optional > >> + VERSION STRING="$(INF_VERSION)" Optional BUILD_NUM=$(BUILD_NUMBER) > >> + } > >> diff --git a/Silicon/Marvell/Armada7k8k/Armada7k8k.dsc.inc > >> b/Silicon/Marvell/Armada7k8k/Armada7k8k.dsc.inc > >> index 8fb912b..75fa3d4 100644 > >> --- a/Silicon/Marvell/Armada7k8k/Armada7k8k.dsc.inc > >> +++ b/Silicon/Marvell/Armada7k8k/Armada7k8k.dsc.inc > >> @@ -42,8 +42,23 @@ > >> > >> DebugLib|MdePkg/Library/BaseDebugLibSerialPort/BaseDebugLibSerialPort.inf > >> > >> DebugPrintErrorLevelLib|MdePkg/Library/BaseDebugPrintErrorLevelLib/BaseDebugPrintErrorLevelLib.inf > >> > >> +!if $(CAPSULE_ENABLE) > >> + OpensslLib|CryptoPkg/Library/OpensslLib/OpensslLib.inf > >> + IntrinsicLib|CryptoPkg/Library/IntrinsicLib/IntrinsicLib.inf > >> + BaseCryptLib|CryptoPkg/Library/BaseCryptLib/BaseCryptLib.inf > >> + CapsuleLib|MdeModulePkg/Library/DxeCapsuleLibFmp/DxeCapsuleLib.inf > >> + > >> EdkiiSystemCapsuleLib|SignedCapsulePkg/Library/EdkiiSystemCapsuleLib/EdkiiSystemCapsuleLib.inf > >> + > >> FmpAuthenticationLib|SecurityPkg/Library/FmpAuthenticationLibPkcs7/FmpAuthenticationLibPkcs7.inf > >> + IniParsingLib|SignedCapsulePkg/Library/IniParsingLib/IniParsingLib.inf > >> + > >> PlatformFlashAccessLib|Silicon/Marvell/Armada7k8k/Feature/Capsule/PlatformFlashAccessLib/PlatformFlashAccessLib.inf > >> +!endif > >> + > >> # Basic utility libraries > >> BaseLib|MdePkg/Library/BaseLib/BaseLib.inf > >> +!if $(CAPSULE_ENABLE) > >> + > >> BmpSupportLib|MdeModulePkg/Library/BaseBmpSupportLib/BaseBmpSupportLib.inf > >> + SafeIntLib|MdePkg/Library/BaseSafeIntLib/BaseSafeIntLib.inf > >> +!endif > >> > >> SynchronizationLib|MdePkg/Library/BaseSynchronizationLib/BaseSynchronizationLib.inf > >> > >> PerformanceLib|MdePkg/Library/BasePerformanceLibNull/BasePerformanceLibNull.inf > >> PrintLib|MdePkg/Library/BasePrintLib/BasePrintLib.inf > >> @@ -199,7 +214,11 @@ > >> [LibraryClasses.common.DXE_RUNTIME_DRIVER] > >> HobLib|MdePkg/Library/DxeHobLib/DxeHobLib.inf > >> > >> MemoryAllocationLib|MdePkg/Library/UefiMemoryAllocationLib/UefiMemoryAllocationLib.inf > >> +!if $(CAPSULE_ENABLE) > >> + > >> CapsuleLib|MdeModulePkg/Library/DxeCapsuleLibFmp/DxeRuntimeCapsuleLib.inf > >> +!else > >> CapsuleLib|MdeModulePkg/Library/DxeCapsuleLibNull/DxeCapsuleLibNull.inf > >> +!endif > >> !if $(TARGET) != RELEASE > >> > >> DebugLib|MdePkg/Library/DxeRuntimeDebugLibSerialPort/DxeRuntimeDebugLibSerialPort.inf > >> !endif > >> @@ -376,6 +395,13 @@ > >> gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageFtwSpareBase|0xF93E0000 > >> gEfiMdeModulePkgTokenSpaceGuid.PcdFlashNvStorageFtwSpareSize|0x00010000 > >> > >> +!if $(CAPSULE_ENABLE) > >> +[PcdsDynamicExDefault.common.DEFAULT] > >> + > >> gEfiSignedCapsulePkgTokenSpaceGuid.PcdEdkiiSystemFirmwareImageDescriptor|{0x0}|VOID*|0x100 > >> + > >> gEfiSignedCapsulePkgTokenSpaceGuid.PcdEdkiiSystemFirmwareFileGuid|{0x02, > >> 0x0e, 0x89, 0xb3, 0x6b, 0xc4, 0x70, 0x49, 0x95, 0x36, 0x57, 0x78, 0x7a, > >> 0x9e, 0x06, 0xc7} > >> + > >> gEfiMdeModulePkgTokenSpaceGuid.PcdSystemFmpCapsuleImageTypeIdGuid|{0x75, > >> 0xc4, 0x7f, 0x75, 0x22, 0x6b, 0x82, 0x44, 0x86, 0x8e, 0xde, 0xd2, 0x86, > >> 0xf3, 0x09, 0x40} > >> +!endif > >> + > >> > >> ################################################################################ > >> # > >> # Components Section - list of all EDK II Modules needed by this Platform > >> @@ -394,6 +420,11 @@ > >> ArmPlatformPkg/MemoryInitPei/MemoryInitPeim.inf > >> ArmPkg/Drivers/CpuPei/CpuPei.inf > >> MdeModulePkg/Universal/Variable/Pei/VariablePei.inf > >> +!if $(CAPSULE_ENABLE) > >> + MdeModulePkg/Universal/FaultTolerantWritePei/FaultTolerantWritePei.inf > >> + MdeModulePkg/Universal/CapsulePei/CapsulePei.inf > >> + > >> Silicon/Marvell/Armada7k8k/Feature/Capsule/SystemFirmwareDescriptor/SystemFirmwareDescriptor.inf > >> +!endif > >> MdeModulePkg/Core/DxeIplPeim/DxeIpl.inf { > >> <LibraryClasses> > >> > >> NULL|MdeModulePkg/Library/LzmaCustomDecompressLib/LzmaCustomDecompressLib.inf > >> @@ -503,6 +534,16 @@ > >> > >> NULL|MdeModulePkg/Library/BootMaintenanceManagerUiLib/BootMaintenanceManagerUiLib.inf > >> } > >> > >> +!if $(CAPSULE_ENABLE) > >> + MdeModulePkg/Universal/EsrtDxe/EsrtDxe.inf > >> + > >> SignedCapsulePkg/Universal/SystemFirmwareUpdate/SystemFirmwareReportDxe.inf > >> + > >> SignedCapsulePkg/Universal/SystemFirmwareUpdate/SystemFirmwareUpdateDxe.inf > >> { > >> + <LibraryClasses> > >> + > >> FmpAuthenticationLib|SecurityPkg/Library/FmpAuthenticationLibPkcs7/FmpAuthenticationLibPkcs7.inf > >> + } > >> + MdeModulePkg/Application/CapsuleApp/CapsuleApp.inf > >> +!endif > >> + > >> # > >> # Variable services > >> # > >> diff --git a/Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.dsc > >> b/Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.dsc > >> new file mode 100644 > >> index 0000000..0498bce > >> --- /dev/null > >> +++ b/Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.dsc > >> @@ -0,0 +1,46 @@ > >> +#Copyright (C) 2018 Marvell International Ltd. > >> +# > >> +#Marvell BSD License Option > >> +# > >> +#If you received this File from Marvell, you may opt to use, redistribute > >> and/or > >> +#modify this File under the following licensing terms. > >> +#Redistribution and use in source and binary forms, with or without > >> modification, > >> +#are permitted provided that the following conditions are met: > >> +# > >> +# * Redistributions of source code must retain the above copyright notice, > >> +# this list of conditions and the following disclaimer. > >> +# > >> +# * Redistributions in binary form must reproduce the above copyright > >> +# notice, this list of conditions and the following disclaimer in the > >> +# documentation and/or other materials provided with the distribution. > >> +# > >> +# * Neither the name of Marvell nor the names of its contributors may be > >> +# used to endorse or promote products derived from this software without > >> +# specific prior written permission. > >> +# > >> +#THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS > >> IS" AND > >> +#ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE > >> IMPLIED > >> +#WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE > >> +#DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE > >> LIABLE FOR > >> +#ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL > >> DAMAGES > >> +#(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR > >> SERVICES; > >> +#LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED > >> AND ON > >> +#ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT > >> +#(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF > >> THIS > >> +#SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. > >> +# > >> +################################################################################ > >> +# > >> +# Defines Section - statements that will be processed to create a > >> Makefile. > >> +# > >> +################################################################################ > >> +[Defines] > >> + PLATFORM_NAME = ${PLATFORM_NAME} > >> + PLATFORM_GUID = 982e2ab1-26ca-4617-92e6-061bd6ba9ae3 > >> + PLATFORM_VERSION = 0.1 > >> + DSC_SPECIFICATION = 0x00010019 > >> + OUTPUT_DIRECTORY = Build/$(PLATFORM_NAME)-$(ARCH) > >> + SUPPORTED_ARCHITECTURES = AARCH64|ARM > >> + BUILD_TARGETS = DEBUG|RELEASE > >> + SKUID_IDENTIFIER = DEFAULT > >> + FLASH_DEFINITION = > >> Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.fdf > >> diff --git a/Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.fdf > >> b/Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.fdf > >> new file mode 100644 > >> index 0000000..c57f7dd > >> --- /dev/null > >> +++ b/Silicon/Marvell/Armada7k8k/Armada7k8kCapsule.fdf > >> @@ -0,0 +1,70 @@ > >> +# > >> +# Copyright (C) Marvell International Ltd. and its affiliates > >> +# > >> +# This program and the accompanying materials > >> +# are licensed and made available under the terms and conditions of the > >> BSD License > >> +# which accompanies this distribution. 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 > >> IMPLIED. > >> +# > >> + > >> +[FD.Armada_Capsule] > >> +BaseAddress = 0x00000000 #|gArmTokenSpaceGuid.PcdFdBaseAddress # The > >> base address of the Firmware in NOR Flash. > >> +Size = 0x00400000 #|gArmTokenSpaceGuid.PcdFdSize # The > >> size in bytes of the FLASH Device > >> +ErasePolarity = 1 > >> + > >> +0x00000000|0x00010000 > >> +FILE = > >> $(WORKSPACE)/$(OUTPUT_DIRECTORY)/$(TARGET)_$(TOOL_CHAIN_TAG)/FV/SYSTEMFIRMWAREDESCRIPTOR.Fv > >> + > >> +0x00100000|0x00300000 > >> +FILE = $(ARM_TRUSTED_FIRMWARE_IMAGE_PREFIX) > >> + > >> +[FV.SystemFirmwareUpdateCargo] > >> +FvAlignment = 8 > >> +ERASE_POLARITY = 1 > >> +MEMORY_MAPPED = TRUE > >> +STICKY_WRITE = TRUE > >> +LOCK_CAP = TRUE > >> +LOCK_STATUS = TRUE > >> +WRITE_DISABLED_CAP = TRUE > >> +WRITE_ENABLED_CAP = TRUE > >> +WRITE_STATUS = TRUE > >> +WRITE_LOCK_CAP = TRUE > >> +WRITE_LOCK_STATUS = TRUE > >> +READ_DISABLED_CAP = TRUE > >> +READ_ENABLED_CAP = TRUE > >> +READ_STATUS = TRUE > >> +READ_LOCK_CAP = TRUE > >> +READ_LOCK_STATUS = TRUE > >> + > >> + FILE RAW = b3890e02-c46b-4970-9536-57787a9e06c7 { # > >> PcdEdkiiSystemFirmwareFileGuid > >> + FD = Armada_Capsule > >> + } > >> + > >> + FILE RAW = ce57b167-b0e4-41e8-a897-5f4feb781d40 { # > >> gEdkiiSystemFmpCapsuleDriverFvFileGuid > >> + > >> $(WORKSPACE)/$(OUTPUT_DIRECTORY)/$(TARGET)_$(TOOL_CHAIN_TAG)/FV/CAPSULEDISPATCHFV.Fv > >> + } > >> + > >> + FILE RAW = 812136D3-4D3A-433A-9418-29BB9BF78F6E { # > >> gEdkiiSystemFmpCapsuleConfigFileGuid > >> + > >> Silicon/Marvell/Armada7k8k/Feature/Capsule/SystemFirmwareUpdateConfig/SystemFirmwareUpdateConfig.ini > >> + } > >> + > >> +[FmpPayload.FmpPayloadSystemFirmwarePkcs7] > >> +IMAGE_HEADER_INIT_VERSION = 0x02 > >> +IMAGE_TYPE_ID = 757fc475-6b22-4482-868e-ded286f30940 # > >> PcdSystemFmpCapsuleImageTypeIdGuid > >> +IMAGE_INDEX = 0x1 > >> +HARDWARE_INSTANCE = 0x0 > >> +MONOTONIC_COUNT = 0x1 > >> +CERTIFICATE_GUID = 4AAFD29D-68DF-49EE-8AA9-347D375665A7 # PKCS7 > >> + > >> + FV = SystemFirmwareUpdateCargo > >> + > >> +[Capsule.MvFirmwareUpdateCapsuleFmpPkcs7] > >> +CAPSULE_GUID = 6dcbd5ed-e82d-4c44-bda1-7194199ad92a # > >> gEfiFmpCapsuleGuid > >> +CAPSULE_HEADER_SIZE = 0x20 > >> +CAPSULE_HEADER_INIT_VERSION = 0x1 > >> + > >> + FMP_PAYLOAD = FmpPayloadSystemFirmwarePkcs7 > >> + > >> -- > >> 2.7.4 > >> _______________________________________________ edk2-devel mailing list [email protected] https://lists.01.org/mailman/listinfo/edk2-devel

