[PATCH v2 6/6] lmb: optimise the lmb allocation functions
Heinrich Schuchardt
heinrich.schuchardt at canonical.com
Thu Feb 20 11:50:11 CET 2025
On 20.02.25 10:56, Sughosh Ganu wrote:
> The actual logic to allocate a region of memory is in the
> _lmb_alloc_base() function. The lmb_alloc() API function calls
> lmb_alloc_base(), which then calls _lmb_alloc_base() to do the
> allocation. Instead, call the _lmb_alloc_base() directly from both the
> allocation API's, and move the error message to the _lmb_alloc_base().
>
> Signed-off-by: Sughosh Ganu <sughosh.ganu at linaro.org>
> ---
> Changes since V1: New patch
>
> lib/lmb.c | 16 ++++++----------
> 1 file changed, 6 insertions(+), 10 deletions(-)
>
> diff --git a/lib/lmb.c b/lib/lmb.c
> index 874063fc1f5..6bfc0dbc9ce 100644
> --- a/lib/lmb.c
> +++ b/lib/lmb.c
> @@ -758,26 +758,22 @@ static phys_addr_t _lmb_alloc_base(phys_size_t size, ulong align,
> base = ALIGN_DOWN(res_base - size, align);
> }
> }
> +
> + log_err("Failed to allocate 0x%lx bytes below 0x%lx\n", (ulong)size,
> + (ulong)max_addr);
Printing such a line is not expected in an EFI application. It would
mess up the output of menus in EFI applications like GRUB.
I think this line should be debug output.
Best regards
Heinrich
> +
> return 0;
> }
>
> phys_addr_t lmb_alloc(phys_size_t size, ulong align)
> {
> - return lmb_alloc_base(size, align, LMB_ALLOC_ANYWHERE, LMB_NONE);
> + return _lmb_alloc_base(size, align, LMB_ALLOC_ANYWHERE, LMB_NONE);
> }
>
> phys_addr_t lmb_alloc_base(phys_size_t size, ulong align, phys_addr_t max_addr,
> uint flags)
> {
> - phys_addr_t alloc;
> -
> - alloc = _lmb_alloc_base(size, align, max_addr, flags);
> -
> - if (alloc == 0)
> - printf("ERROR: Failed to allocate 0x%lx bytes below 0x%lx.\n",
> - (ulong)size, (ulong)max_addr);
> -
> - return alloc;
> + return _lmb_alloc_base(size, align, max_addr, flags);
> }
>
> phys_addr_t lmb_alloc_addr(phys_addr_t base, phys_size_t size, u32 flags)
More information about the U-Boot
mailing list