riscv: ax25-ae350: Pass dtb address to u-boot with a1 register
ax25-ae350 use CONFIG_OF_BOARD via a2 and CONFIG_SYS_SDRAM_BASE to boot from ram which allow the board to override the fdt address originally. But after this patch riscv: save hart ID and device tree passed by prior boot stage It provide prior_stage_fdt_address which offer a temporary memory address to keep the dtb address passing from loader(gdb) to u-boot with a1. So passing via a2 and CONFIG_SYS_SDRAM_BASE is redundant and can be removed. And it also somehow may corrupted BBL if it was be arranged in CONFIG_SYS_SDRAM_BASE. In board_fdt_blob_setup() When boting from ram: prior_stage_fdt_address will be use to reserved dtb temporarily. When booting from ROM: dtb will be pre-burned in CONFIG_SYS_FDT_BASE, if it is flash base. Or CONFIG_SYS_FDT_BASE maybe a memory map space (NOT RAM or ROM) which is provided by HW. Signed-off-by: Rick Chen <rick@andestech.com> Cc: Greentime Hu <greentime@andestech.com>
This commit is contained in:
parent
4c60113647
commit
48cbf62460
@ -38,8 +38,6 @@ _start:
|
||||
mv s0, a0
|
||||
mv s1, a1
|
||||
|
||||
li t0, CONFIG_SYS_SDRAM_BASE
|
||||
SREG a2, 0(t0)
|
||||
la t0, trap_entry
|
||||
csrw MODE_PREFIX(tvec), t0
|
||||
|
||||
|
@ -14,6 +14,7 @@
|
||||
|
||||
DECLARE_GLOBAL_DATA_PTR;
|
||||
|
||||
extern phys_addr_t prior_stage_fdt_address;
|
||||
/*
|
||||
* Miscellaneous platform dependent initializations
|
||||
*/
|
||||
@ -66,7 +67,7 @@ ulong board_flash_get_legacy(ulong base, int banknum, flash_info_t *info)
|
||||
|
||||
void *board_fdt_blob_setup(void)
|
||||
{
|
||||
void **ptr = (void *)CONFIG_SYS_SDRAM_BASE;
|
||||
void **ptr = (void *)&prior_stage_fdt_address;
|
||||
if (fdt_magic(*ptr) == FDT_MAGIC)
|
||||
return (void *)*ptr;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user