[U-Boot] [PATCH 19/48] efi: Display the correct initcall pre-relocation values
Bin Meng
bmeng.cn at gmail.com
Thu Jul 23 10:14:39 CEST 2015
Hi Simon,
On Wed, Jul 22, 2015 at 11:49 PM, Simon Glass <sjg at chromium.org> wrote:
> With EFI the start address of U-Boot is specified differently. We could
> consider just setting GD_FLG_RELOC and then setting up reloc_off. But that
> flag has other implementations and we are not able to use U-Boot relocation
> which this flag implies.
>
> Instead, just add a special case for EFI.
>
> Signed-off-by: Simon Glass <sjg at chromium.org>
> ---
Please check previous review comments regarding to CONFIG_ARCH_EFI and
ImageBase, otherwise:
Reviewed-by: Bin Meng <bmeng.cn at gmail.com>
>
> lib/initcall.c | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/lib/initcall.c b/lib/initcall.c
> index 7142744..1931655 100644
> --- a/lib/initcall.c
> +++ b/lib/initcall.c
> @@ -6,6 +6,7 @@
>
> #include <common.h>
> #include <initcall.h>
> +#include <efi.h>
>
> DECLARE_GLOBAL_DATA_PTR;
>
> @@ -19,6 +20,9 @@ int initcall_run_list(const init_fnc_t init_sequence[])
>
> if (gd->flags & GD_FLG_RELOC)
> reloc_ofs = gd->reloc_off;
> +#ifdef CONFIG_ARCH_EFI
> + reloc_ofs = (unsigned long)ImageBase;
> +#endif
> debug("initcall: %p", (char *)*init_fnc_ptr - reloc_ofs);
> if (gd->flags & GD_FLG_RELOC)
> debug(" (relocated to %p)\n", (char *)*init_fnc_ptr);
> --
Regards,
Bin
More information about the U-Boot
mailing list