[PATCH v2 13/15] mach-snapdragon: Support booting as a coreboot payload

Caleb Connolly caleb.connolly at linaro.org
Thu Mar 27 19:56:05 CET 2025



On 2/26/25 23:15, Stephen Boyd wrote:
> Coreboot sets up the DRAM, CPU, and devices before booting a payload,
> meaning we can parse the coreboot tables at boot for memory info when
> running as a payload. Use the memory descriptors from coreboot if the
> tables are present so that Snapdragon SoCs can run U-boot as a coreboot
> payload.
> 
> Signed-off-by: Stephen Boyd <swboyd at chromium.org>

Reviewed-by: Caleb Connolly <caleb.connolly at linaro.org>
> ---
>   arch/arm/mach-snapdragon/board.c | 18 ++++++++++++++++++
>   1 file changed, 18 insertions(+)
> 
> diff --git a/arch/arm/mach-snapdragon/board.c b/arch/arm/mach-snapdragon/board.c
> index 2ef936aab757..cb3df1c2adec 100644
> --- a/arch/arm/mach-snapdragon/board.c
> +++ b/arch/arm/mach-snapdragon/board.c
> @@ -14,6 +14,7 @@
>   #include <asm/io.h>
>   #include <asm/psci.h>
>   #include <asm/system.h>
> +#include <cb_sysinfo.h>
>   #include <dm/device.h>
>   #include <dm/pinctrl.h>
>   #include <dm/uclass-internal.h>
> @@ -48,6 +49,10 @@ static struct {
>   
>   int dram_init(void)
>   {
> +#ifdef CONFIG_SYS_COREBOOT
> +	if (gd->arch.coreboot_table)
> +		return coreboot_dram_init();
> +#endif
>   	/*
>   	 * gd->ram_base / ram_size have been setup already
>   	 * in qcom_parse_memory().
> @@ -81,8 +86,21 @@ static void qcom_configure_bi_dram(void)
>   	}
>   }
>   
> +phys_addr_t board_get_usable_ram_top(phys_size_t total_size)
> +{
> +#ifdef CONFIG_SYS_COREBOOT
> +	if (gd->arch.coreboot_table)
> +		return coreboot_board_get_usable_ram_top(total_size);
> +#endif
> +	return gd->ram_top;
> +}
> +
>   int dram_init_banksize(void)
>   {
> +#ifdef CONFIG_SYS_COREBOOT
> +	if (gd->arch.coreboot_table)
> +		return coreboot_dram_init_banksize();
> +#endif
>   	qcom_configure_bi_dram();
>   
>   	return 0;

-- 
Caleb (they/them)



More information about the U-Boot mailing list