[PATCH v4 13/29] efi: lmb: Avoid access to _start

Simon Glass sjg at chromium.org
Fri Mar 28 12:34:12 CET 2025


Hi Caleb,

On Thu, 27 Mar 2025 at 10:21, Caleb Connolly <caleb.connolly at linaro.org> wrote:
>
>
>
> On 2/15/25 04:22, Simon Glass wrote:
> > The app does not have this symbol. Also the memory where the app is
> > loaded is not under U-Boot's control.
> >
> > There is no sense in relocating from one alloced region to another.
> > U-Boot is not able to relocate to the top of memory, nor decide what
> > other parts of memory are used for.
> >
> > For these reasons, the EFI app skips relocation. It is not running at
> > the address pointed to by the _start symbol.
>
> is there a symbol or not? If there is could we have some "relocate in
> place" mechanism so that it's valid? When I (finally...) get around to
> re-sending the symbol lookup support it would be nice if it worked for
> the EFI app, and it relies on _start.

Can I leave you to do that clean-up/investigation in your series,
then? Tom has already reviewed this patch and it has been sitting here
for 6 weeks. I applied it yesterday.

> >
> > So disable this reservation for the EFI app.
> >
> > Signed-off-by: Simon Glass <sjg at chromium.org>
> > Reviewed-by: Tom Rini <trini at konsulko.com>
> > ---
> >
> > (no changes since v2)
> >
> > Changes in v2:
> > - Expand commit message to explains that EFI_APP skips relocation
> >
> >   lib/lmb.c | 3 ++-
> >   1 file changed, 2 insertions(+), 1 deletion(-)
> >
> > diff --git a/lib/lmb.c b/lib/lmb.c
> > index 588787d2a90..420eae4d0b8 100644
> > --- a/lib/lmb.c
> > +++ b/lib/lmb.c
> > @@ -560,7 +560,8 @@ static void lmb_reserve_uboot_region(void)
> >               lmb_reserve_flags(rsv_start, bank_end - rsv_start + 1,
> >                                 LMB_NOOVERWRITE);
> >
> > -             if (gd->flags & GD_FLG_SKIP_RELOC)
> > +             if (!IS_ENABLED(CONFIG_EFI_APP) &&
> > +                 (gd->flags & GD_FLG_SKIP_RELOC))
> >                       lmb_reserve_flags((phys_addr_t)(uintptr_t)_start,
> >                                         gd->mon_len, LMB_NOOVERWRITE);
> >
>
> --
> Caleb (they/them)
>

Regards,
Simon


More information about the U-Boot mailing list