From: Cooper Jr., Franklin Date: Fri, 16 Jun 2017 22:25:12 +0000 (-0500) Subject: board_f: Add new function to allow runtime DTB selection X-Git-Tag: v2025.01-rc5-pxa1908~6427 X-Git-Url: http://git.dujemihanovic.xyz/%22mailto:Murray.Jensen%40csiro.au/static/%7B%7B%20%28.OutputFormats.Get?a=commitdiff_plain;h=af9e6ad4ab29ffed5d4e08a5ccf75f3f28a83ab7;p=u-boot.git board_f: Add new function to allow runtime DTB selection Runtime U-boot dtb selection is generally a two step process. First step is to simply use an initial generic dtb. The second step is to select the dtb and perhaps execute additional code ones U-boot knows what board it is running on. Embedded_dtb_select handles the second step by allowing board specific code to run and perform what ever necessary configuration that is needed. Signed-off-by: Franklin S Cooper Jr Reviewed-by: Tom Rini --- diff --git a/common/Kconfig b/common/Kconfig index a5e3a6b418..086b676937 100644 --- a/common/Kconfig +++ b/common/Kconfig @@ -437,6 +437,15 @@ config SYS_STDIO_DEREGISTER endmenu +config DTB_RESELECT + bool "Support swapping dtbs at a later point in boot" + depends on FIT_EMBED + help + It is possible during initial boot you may need to use a generic + dtb until you can fully determine the board your running on. This + config allows boards to implement a function at a later point + during boot to switch to the "correct" dtb. + config FIT_EMBED bool "Support a FIT image embedded in the U-boot image" help diff --git a/common/board_f.c b/common/board_f.c index 2cdd12a503..ffa84e3566 100644 --- a/common/board_f.c +++ b/common/board_f.c @@ -809,6 +809,9 @@ static const init_fnc_t init_sequence_f[] = { #if defined(CONFIG_DISPLAY_CPUINFO) print_cpuinfo, /* display cpu info (and speed) */ #endif +#if defined(CONFIG_DTB_RESELECT) + embedded_dtb_select, +#endif #if defined(CONFIG_DISPLAY_BOARDINFO) show_board_info, #endif diff --git a/include/common.h b/include/common.h index 1a98512ab6..751665f8a4 100644 --- a/include/common.h +++ b/include/common.h @@ -359,6 +359,10 @@ int get_env_id (void); void pci_init (void); void pci_init_board(void); +#if defined(CONFIG_DTB_RESELECT) +int embedded_dtb_select(void); +#endif + int misc_init_f (void); int misc_init_r (void);