spl: Set up the bloblist in board_init_r()
At present the bloblist is set up in spl_common_init() which can be called from spl_early_init(), i.e. before SDRAM is ready. This prevents the bloblist from being located in SDRAM, which is useful on some platforms where SRAM is inaccessible after U-Boot relocates (e.g. x86 CAR region). It doesn't serve much purpose to have the bloblist available early, since very little is known about the platform then, and the handoff info is written when SPL is about to jump to U-Boot. Move the code to board_init_r() to avoid any restrictions. Signed-off-by: Simon Glass <sjg@chromium.org> Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
This commit is contained in:
parent
366291afe6
commit
3cd7198153
@ -410,23 +410,6 @@ static int spl_common_init(bool setup_malloc)
|
||||
return ret;
|
||||
}
|
||||
#endif
|
||||
if (CONFIG_IS_ENABLED(BLOBLIST)) {
|
||||
ret = bloblist_init();
|
||||
if (ret) {
|
||||
debug("%s: Failed to set up bloblist: ret=%d\n",
|
||||
__func__, ret);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
if (CONFIG_IS_ENABLED(HANDOFF)) {
|
||||
int ret;
|
||||
|
||||
ret = setup_spl_handoff();
|
||||
if (ret) {
|
||||
puts(SPL_TPL_PROMPT "Cannot set up SPL handoff\n");
|
||||
hang();
|
||||
}
|
||||
}
|
||||
if (CONFIG_IS_ENABLED(OF_CONTROL) && !CONFIG_IS_ENABLED(OF_PLATDATA)) {
|
||||
ret = fdtdec_setup();
|
||||
if (ret) {
|
||||
@ -604,6 +587,24 @@ void board_init_r(gd_t *dummy1, ulong dummy2)
|
||||
*/
|
||||
timer_init();
|
||||
#endif
|
||||
if (CONFIG_IS_ENABLED(BLOBLIST)) {
|
||||
ret = bloblist_init();
|
||||
if (ret) {
|
||||
debug("%s: Failed to set up bloblist: ret=%d\n",
|
||||
__func__, ret);
|
||||
puts(SPL_TPL_PROMPT "Cannot set up bloblist\n");
|
||||
hang();
|
||||
}
|
||||
}
|
||||
if (CONFIG_IS_ENABLED(HANDOFF)) {
|
||||
int ret;
|
||||
|
||||
ret = setup_spl_handoff();
|
||||
if (ret) {
|
||||
puts(SPL_TPL_PROMPT "Cannot set up SPL handoff\n");
|
||||
hang();
|
||||
}
|
||||
}
|
||||
|
||||
#if CONFIG_IS_ENABLED(BOARD_INIT)
|
||||
spl_board_init();
|
||||
|
Loading…
Reference in New Issue
Block a user