Message ID | 20200427181804.15787-5-andre.przywara@arm.com |
---|---|
State | Superseded |
Headers | show |
Series | Arm Juno board OF_CONTROL upgrade | expand |
On Mon, 27 Apr 2020 at 12:18, Andre Przywara <andre.przywara at arm.com> wrote: > > The Arm Juno board was still somewhat stuck in "hardcoded land", even > though there are stable DTs around, and one happens to actually be on > the memory mapped NOR flash. > > Enable the configuration options to let the board use OF_CONTROL, and > add a routine to find the address of the DTB partition in NOR > flash, to use that for U-Boot's own purposes. > This can also passed on via $fdtcontroladdr to any kernel or EFI > application, removing the need to actually load a device tree. > > Since the existing "afs" command and its flash routines require > flash_init() to be called before being usable, and this is done much > later in the boot process, we introduce a stripped-down partition finder > routine in vexpress64.c, to scan the NOR flash partitions for the > DT partition. This location is then used for U-Boot to find and probe > devices. > > The name of the partition can be configured, if needed, but defaults > to "board.dtb", which is used by Linaro's firmware image provided. > > Signed-off-by: Andre Przywara <andre.przywara at arm.com> > Reviewed-by: Linus Walleij <linus.walleij at linaro.org> > --- > arch/arm/Kconfig | 5 +++ > board/armltd/vexpress64/Kconfig | 7 ++++ > board/armltd/vexpress64/vexpress64.c | 57 ++++++++++++++++++++++++++ > configs/vexpress_aemv8a_juno_defconfig | 4 +- > 4 files changed, 70 insertions(+), 3 deletions(-) Reviewed-by: Simon Glass <sjg at chromium.org>
On Mon, Apr 27, 2020 at 07:18:01PM +0100, Andre Przywara wrote: > The Arm Juno board was still somewhat stuck in "hardcoded land", even > though there are stable DTs around, and one happens to actually be on > the memory mapped NOR flash. > > Enable the configuration options to let the board use OF_CONTROL, and > add a routine to find the address of the DTB partition in NOR > flash, to use that for U-Boot's own purposes. > This can also passed on via $fdtcontroladdr to any kernel or EFI > application, removing the need to actually load a device tree. > > Since the existing "afs" command and its flash routines require > flash_init() to be called before being usable, and this is done much > later in the boot process, we introduce a stripped-down partition finder > routine in vexpress64.c, to scan the NOR flash partitions for the > DT partition. This location is then used for U-Boot to find and probe > devices. > > The name of the partition can be configured, if needed, but defaults > to "board.dtb", which is used by Linaro's firmware image provided. > > Signed-off-by: Andre Przywara <andre.przywara at arm.com> > Reviewed-by: Linus Walleij <linus.walleij at linaro.org> > Reviewed-by: Simon Glass <sjg at chromium.org> Applied to u-boot/master, thanks!
diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 1bcf345028..cf8b629c0e 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig @@ -1133,6 +1133,11 @@ config TARGET_VEXPRESS64_JUNO bool "Support Versatile Express Juno Development Platform" select ARM64 select PL01X_SERIAL + select DM + select OF_CONTROL + select OF_BOARD + select CLK + select DM_SERIAL config TARGET_LS2080A_EMU bool "Support ls2080a_emu" diff --git a/board/armltd/vexpress64/Kconfig b/board/armltd/vexpress64/Kconfig index 9014418433..1d13f542e6 100644 --- a/board/armltd/vexpress64/Kconfig +++ b/board/armltd/vexpress64/Kconfig @@ -9,4 +9,11 @@ config SYS_VENDOR config SYS_CONFIG_NAME default "vexpress_aemv8a" +config JUNO_DTB_PART + string "NOR flash partition holding DTB" + default "board.dtb" + help + The ARM partition name in the NOR flash memory holding the + device tree blob to configure U-Boot. + endif diff --git a/board/armltd/vexpress64/vexpress64.c b/board/armltd/vexpress64/vexpress64.c index dd0ebdd303..ba49b32e58 100644 --- a/board/armltd/vexpress64/vexpress64.c +++ b/board/armltd/vexpress64/vexpress64.c @@ -82,6 +82,63 @@ int dram_init_banksize(void) return 0; } +#ifdef CONFIG_OF_BOARD +#define JUNO_FLASH_SEC_SIZE (256 * 1024) +static phys_addr_t find_dtb_in_nor_flash(const char *partname) +{ + phys_addr_t sector = CONFIG_SYS_FLASH_BASE; + int i; + + for (i = 0; + i < CONFIG_SYS_MAX_FLASH_SECT; + i++, sector += JUNO_FLASH_SEC_SIZE) { + int len = strlen(partname) + 1; + int offs; + phys_addr_t imginfo; + u32 reg; + + reg = readl(sector + JUNO_FLASH_SEC_SIZE - 0x04); + /* This makes up the string "HSLFTOOF" flash footer */ + if (reg != 0x464F4F54U) + continue; + reg = readl(sector + JUNO_FLASH_SEC_SIZE - 0x08); + if (reg != 0x464C5348U) + continue; + + for (offs = 0; offs < 32; offs += 4, len -= 4) { + reg = readl(sector + JUNO_FLASH_SEC_SIZE - 0x30 + offs); + if (strncmp(partname + offs, (char *)®, + len > 4 ? 4 : len)) + break; + + if (len > 4) + continue; + + reg = readl(sector + JUNO_FLASH_SEC_SIZE - 0x10); + imginfo = sector + JUNO_FLASH_SEC_SIZE - 0x30 - reg; + reg = readl(imginfo + 0x54); + + return CONFIG_SYS_FLASH_BASE + + reg * JUNO_FLASH_SEC_SIZE; + } + } + + printf("No DTB found\n"); + + return ~0; +} + +void *board_fdt_blob_setup(void) +{ + phys_addr_t fdt_rom_addr = find_dtb_in_nor_flash(CONFIG_JUNO_DTB_PART); + + if (fdt_rom_addr == ~0UL) + return NULL; + + return (void *)fdt_rom_addr; +} +#endif + /* * Board specific reset that is system reset. */ diff --git a/configs/vexpress_aemv8a_juno_defconfig b/configs/vexpress_aemv8a_juno_defconfig index 8628d05e68..6cb21e7a1b 100644 --- a/configs/vexpress_aemv8a_juno_defconfig +++ b/configs/vexpress_aemv8a_juno_defconfig @@ -10,6 +10,7 @@ CONFIG_DISTRO_DEFAULTS=y CONFIG_BOOTDELAY=1 CONFIG_USE_BOOTARGS=y CONFIG_BOOTARGS="console=ttyAMA0,115200n8 root=/dev/sda2 rw rootwait earlycon=pl011,0x7ff80000 debug user_debug=31 androidboot.hardware=juno loglevel=9" +CONFIG_OF_BOARD=y # CONFIG_USE_BOOTCOMMAND is not set # CONFIG_DISPLAY_CPUINFO is not set # CONFIG_DISPLAY_BOARDINFO is not set @@ -30,7 +31,6 @@ CONFIG_CMD_UBI=y # CONFIG_EFI_PARTITION is not set CONFIG_ENV_IS_IN_FLASH=y CONFIG_ENV_ADDR=0xBFC0000 -CONFIG_DM=y # CONFIG_MMC is not set CONFIG_MTD=y CONFIG_MTD_NOR_FLASH=y @@ -41,5 +41,3 @@ CONFIG_SYS_FLASH_CFI=y CONFIG_SMC911X=y CONFIG_SMC911X_BASE=0x018000000 CONFIG_SMC911X_32_BIT=y -CONFIG_DM_SERIAL=y -CONFIG_OF_LIBFDT=y