[PATCH 05/29] rockchip: Allow RAM init to happen in SPL on rk3399
Jonas Karlman
jonas at kwiboo.se
Wed Feb 5 23:18:03 CET 2025
Hi Simon,
On 2025-02-05 02:54, Simon Glass wrote:
> TPL runs before VPL. The earliest updatable phase with VBE is SPL. We
> want to be able to update the RAM-init code in the field.
If I understand your description here, you mean that both TPL and VPL
are meant to be "burned" onto the board and not intended to be updatable?
Is this a typo or do I misunderstand something? Else I do not understand
why you would need TPL->VPL->SPL, please explain.
>
> So when VPL is being used, init the RAM later, in SPL.
>
> Signed-off-by: Simon Glass <sjg at chromium.org>
> ---
>
> drivers/ram/rockchip/sdram_rk3399.c | 6 ++++--
> 1 file changed, 4 insertions(+), 2 deletions(-)
>
> diff --git a/drivers/ram/rockchip/sdram_rk3399.c b/drivers/ram/rockchip/sdram_rk3399.c
> index 6fa8f268770..9ac16dfdc71 100644
> --- a/drivers/ram/rockchip/sdram_rk3399.c
> +++ b/drivers/ram/rockchip/sdram_rk3399.c
> @@ -194,6 +194,7 @@ struct io_setting {
> static bool phase_sdram_init(void)
> {
> return xpl_phase() == PHASE_TPL ||
> + (IS_ENABLED(CONFIG_VPL) && xpl_phase() == PHASE_SPL) ||
> (!IS_ENABLED(CONFIG_TPL) &&
> !IS_ENABLED(CONFIG_ROCKCHIP_EXTERNAL_TPL) &&
> !not_xpl());
> @@ -3195,8 +3196,9 @@ U_BOOT_DRIVER(dmc_rk3399) = {
> .of_to_plat = rk3399_dmc_of_to_plat,
> .probe = rk3399_dmc_probe,
> .priv_auto = sizeof(struct dram_info),
> -#if defined(CONFIG_TPL_BUILD) || \
> - (!defined(CONFIG_TPL) && defined(CONFIG_XPL_BUILD))
> +#if defined(CONFIG_VPL) && defined(CONFIG_SPL_BUILD) || \
> + !defined(CONFIG_VPL) && defined(CONFIG_TPL_BUILD) || \
> + !defined(CONFIG_TPL) && defined(CONFIG_SPL_BUILD)
> .plat_auto = sizeof(struct rockchip_dmc_plat),
> #endif
> };
These two conditions are starting to get ridiculous.
With "[PATCH 24/29] rockchip: Allow SPL to set up SDRAM" you are
depending on TPL_RAM to decide if RAM should be initialized. Maybe that
is something we can use here to simplify?
Basically we will have 3 possible DRAM init scenarios to support:
- ROCKCHIP_EXTERNA_TPL=y -> DRAM init happen in external TPL and SPL
should only read DRAM size
- VPL=y or TPL=n -> both DRAM init and read DRAM size happen in SPL
- TPL=y -> DRAM init in TPL and SPL should only read DRAM size
Regards,
Jonas
More information about the U-Boot
mailing list