boottime->efi_allocate_pages() returning EFI_NOT_FOUND
Ben Schneider
ben at bens.haus
Fri Mar 14 00:20:09 CET 2025
On Thursday, March 13th, 2025 at 11:11 AM, Ard Biesheuvel <ardb at kernel.org> wrote:
>
>
> On Thu, 13 Mar 2025 at 18:27, Ben Schneider ben at bens.haus wrote:
>
> > Hi Ilias,
> >
> > On Thursday, March 13th, 2025 at 2:35 AM, Ilias Apalodimas ilias.apalodimas at linaro.org wrote:
> >
> > > Can you apply https://source.denx.de/u-boot/custodians/u-boot-tpm/-/commit/b04e708c615c15423ffc80d73430bf2d36fb7c21
> > > and see if it fixes your problem?
> >
> > With this patch applied, efi_zboot_entry() appears to proceed to
> > __decompress() using target = 0 (first entry on my device), but
> > then I get the following messages:
> >
> > EFI stub: ERROR: EFI decompressor: Out of memory while allocating output buffer
> > EFI stub: ERROR: EFI decompressor: Decompression failed
> > efi_free_pages: illegal free 0x0, 0x1140
>
>
> Seems like the compression code gets confused by a buffer residing at
> memory address 0x0.
>
> Could you try the below please?
>
> --- a/drivers/firmware/efi/libstub/randomalloc.c
> +++ b/drivers/firmware/efi/libstub/randomalloc.c
> @@ -75,6 +75,9 @@
> if (align < EFI_ALLOC_ALIGN)
> align = EFI_ALLOC_ALIGN;
>
> + if (alloc_min == 0)
> + alloc_min = align;
> +
> size = round_up(size, EFI_ALLOC_ALIGN);
>
> /* count the suitable slots in each memory map entry */
That did it! With both the patch for U-Boot and this one for the kernel applied, everything works perfectly.
Ben
More information about the U-Boot
mailing list