Hi Marek,
On Thu, 13 Nov 2025 at 13:56, Marek Vasut <[email protected]> wrote: > > The fitImage may be stored in EFI update capsule at address that > is not aligned to 8 bytes. Since fitImage is a DT, new version of > libfdt 1.7.2 rejects such an unaligned DT. Patch the code and copy > the fitImage into aligned buffer in case it is not aligned. This > does increase overhead for unaligned fitImages in EFI capsules, but > tries to keep the overhead low for aligned ones. > > Signed-off-by: Marek Vasut <[email protected]> At some point I'd prefer getting rid of FIT images for capsules overall. It was implemented as an alternative to authenticated capsule updates, but since then proper capsule support has been added. The patch is ok though for now, > --- > Cc: Heinrich Schuchardt <[email protected]> > Cc: Ilias Apalodimas <[email protected]> > Cc: Jonathan Humphreys <[email protected]> > Cc: Mattijs Korpershoek <[email protected]> > Cc: Tom Rini <[email protected]> > Cc: Wadim Egorov <[email protected]> > Cc: [email protected] > --- > lib/efi_loader/efi_firmware.c | 16 +++++++++++++++- > 1 file changed, 15 insertions(+), 1 deletion(-) > > diff --git a/lib/efi_loader/efi_firmware.c b/lib/efi_loader/efi_firmware.c > index 216df83de67..953a310190b 100644 > --- a/lib/efi_loader/efi_firmware.c > +++ b/lib/efi_loader/efi_firmware.c > @@ -651,6 +651,7 @@ efi_status_t EFIAPI efi_firmware_fit_set_image( > efi_status_t status; > struct fmp_state state = { 0 }; > char *orig_dfu_env; > + void *img; > > EFI_ENTRY("%p %d %p %zu %p %p %p\n", this, image_index, image, > image_size, vendor_code, progress, abort_reason); > @@ -677,7 +678,20 @@ efi_status_t EFIAPI efi_firmware_fit_set_image( > return EFI_EXIT(EFI_DEVICE_ERROR); > } > > - ret = fit_update(image); > + /* Make sure the update fitImage is properly aligned to 8-bytes */ > + if ((uintptr_t)image & 7) { Can we replace this with IS_ALGINED? > + img = memalign(8, image_size); > + if (!img) > + return EFI_EXIT(EFI_BAD_BUFFER_SIZE); > + memcpy(img, image, image_size); > + } else { > + img = (void *)image; > + } > + > + ret = fit_update(img); > + > + if ((uintptr_t)image & 7) > + free(img); Initialize img to NULL and make the check a bit simpler to read (or get rid of it overall) Other than that LGTM Cheers /Ilias > > if (env_set("dfu_alt_info", orig_dfu_env)) > log_warning("Unable to restore env variable \"dfu_alt_info\". > Further DFU operations may fail!\n"); > -- > 2.51.0 >

