Message ID | 20200710012537.6264-7-takahiro.akashi@linaro.org |
---|---|
State | Superseded |
Headers | show |
Series | efi_loader: add capsule update support | expand |
On 10.07.20 03:25, AKASHI Takahiro wrote: > If this option, CONFIG_EFI_SETUP_EARLY, is enabled, the initialisation > of UEFI subsystem will be done as part of U-Boot initialisation. > > Please note that this option won't be enabled explicitly by users, > instead, should be enabled implicitly by other configuration options. > > Specifically, this feature will be utilised in implementing capsule-on-disk > feature. This breaks access to block devices in UEFI. You cannot do the initialization before the initialization of block devices which currently is not done automatically but requires commands like 'scsi scan' in a script or entered manually. It might make sense to scan all block devices automatically instead of requiring command entry. Best regards Heinrich > > Signed-off-by: AKASHI Takahiro <takahiro.akashi at linaro.org> > --- > common/board_r.c | 6 ++++++ > lib/efi_loader/Kconfig | 4 ++++ > 2 files changed, 10 insertions(+) > > diff --git a/common/board_r.c b/common/board_r.c > index fa57fa9b6993..dcb8c6f79d2f 100644 > --- a/common/board_r.c > +++ b/common/board_r.c > @@ -68,6 +68,9 @@ > #if defined(CONFIG_GPIO_HOG) > #include <asm/gpio.h> > #endif > +#ifdef CONFIG_EFI_SETUP_EARLY > +#include <efi_loader.h> > +#endif > > DECLARE_GLOBAL_DATA_PTR; > > @@ -858,6 +861,9 @@ static init_fnc_t init_sequence_r[] = { > #endif > #if defined(CONFIG_M68K) && defined(CONFIG_BLOCK_CACHE) > blkcache_init, > +#endif > +#ifdef CONFIG_EFI_SETUP_EARLY > + (init_fnc_t)efi_init_obj_list, > #endif > run_main_loop, > }; > diff --git a/lib/efi_loader/Kconfig b/lib/efi_loader/Kconfig > index 6c9df3a76763..f0a30a43bc48 100644 > --- a/lib/efi_loader/Kconfig > +++ b/lib/efi_loader/Kconfig > @@ -27,6 +27,10 @@ config EFI_LOADER > > if EFI_LOADER > > +config EFI_SETUP_EARLY > + bool > + default n > + > config EFI_GET_TIME > bool "GetTime() runtime service" > depends on DM_RTC >
diff --git a/common/board_r.c b/common/board_r.c index fa57fa9b6993..dcb8c6f79d2f 100644 --- a/common/board_r.c +++ b/common/board_r.c @@ -68,6 +68,9 @@ #if defined(CONFIG_GPIO_HOG) #include <asm/gpio.h> #endif +#ifdef CONFIG_EFI_SETUP_EARLY +#include <efi_loader.h> +#endif DECLARE_GLOBAL_DATA_PTR; @@ -858,6 +861,9 @@ static init_fnc_t init_sequence_r[] = { #endif #if defined(CONFIG_M68K) && defined(CONFIG_BLOCK_CACHE) blkcache_init, +#endif +#ifdef CONFIG_EFI_SETUP_EARLY + (init_fnc_t)efi_init_obj_list, #endif run_main_loop, }; diff --git a/lib/efi_loader/Kconfig b/lib/efi_loader/Kconfig index 6c9df3a76763..f0a30a43bc48 100644 --- a/lib/efi_loader/Kconfig +++ b/lib/efi_loader/Kconfig @@ -27,6 +27,10 @@ config EFI_LOADER if EFI_LOADER +config EFI_SETUP_EARLY + bool + default n + config EFI_GET_TIME bool "GetTime() runtime service" depends on DM_RTC
If this option, CONFIG_EFI_SETUP_EARLY, is enabled, the initialisation of UEFI subsystem will be done as part of U-Boot initialisation. Please note that this option won't be enabled explicitly by users, instead, should be enabled implicitly by other configuration options. Specifically, this feature will be utilised in implementing capsule-on-disk feature. Signed-off-by: AKASHI Takahiro <takahiro.akashi at linaro.org> --- common/board_r.c | 6 ++++++ lib/efi_loader/Kconfig | 4 ++++ 2 files changed, 10 insertions(+)