mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-12-11 05:42:58 +00:00
0a63fb960d
The recovery-firmware and OpenWrt-NAND do not yet have bootflow /bootstd entrypoints, so add bootmenu entries to make them accessible. Signed-off-by: Mathew McBride <matt@traverse.com.au> Reviewed-by: Peng Fan <peng.fan@nxp.com>
73 lines
2.3 KiB
C
73 lines
2.3 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ */
|
|
/*
|
|
* Copyright 2017 NXP
|
|
* Copyright 2019-2021 Traverse Technologies
|
|
*/
|
|
|
|
#ifndef __TEN64_H
|
|
#define __TEN64_H
|
|
|
|
#include "ls1088a_common.h"
|
|
|
|
|
|
#define CFG_SYS_LS_MC_BOOT_TIMEOUT_MS 5000
|
|
|
|
#define QSPI_NOR_BOOTCOMMAND "run distro_bootcmd"
|
|
#define SD_BOOTCOMMAND "run distro_bootcmd"
|
|
|
|
#define SD_FIRMWARE_PATH "firmware/traverse/ten64/"
|
|
|
|
#define QSPI_MC_INIT_CMD \
|
|
"sf probe 0:0 && sf read 0x80000000 0x300000 0x200000 &&" \
|
|
"sf read 0x80200000 0x5C0000 0x40000 &&" \
|
|
"fsl_mc start mc 0x80000000 0x80200000 && " \
|
|
"sf read 0x8E000000 0x580000 0x40000 && fsl_mc lazyapply DPL 0x8E000000 && "\
|
|
"echo 'default DPL loaded'\0"
|
|
#define SD_MC_INIT_CMD \
|
|
"mmcinfo; fatload mmc 0 0x80000000 " SD_FIRMWARE_PATH "mc_ls1088a.itb; "\
|
|
"fatload mmc 0 0x80200000 " SD_FIRMWARE_PATH "dpc.0x1D-0x0D.dtb; "\
|
|
"fsl_mc start mc 0x80000000 0x80200000 && " \
|
|
"fatload mmc 0 0x8E000000 " SD_FIRMWARE_PATH "eth-dpl-all.dtb && " \
|
|
"fsl_mc lazyapply DPL 0x8E000000 && echo 'default DPL loaded'\0"
|
|
|
|
#define BOOT_TARGET_DEVICES(func) \
|
|
func(NVME, nvme, 0) \
|
|
func(USB, usb, 0) \
|
|
func(MMC, mmc, 0) \
|
|
func(SCSI, scsi, 0) \
|
|
func(DHCP, dhcp, 0) \
|
|
func(PXE, pxe, 0)
|
|
#include <config_distro_bootcmd.h>
|
|
|
|
#define OPENWRT_NAND_BOOTCMD \
|
|
"bootcmd_openwrt_nand=ubi part ubi${openwrt_active_sys} && "\
|
|
"ubi read $load_addr kernel && " \
|
|
"setenv bootargs \"root=/dev/ubiblock0_1 earlycon ubi.mtd=ubi${openwrt_active_sys}\" &&"\
|
|
"bootm $load_addr#ten64\0"
|
|
#undef CFG_EXTRA_ENV_SETTINGS
|
|
|
|
#if CONFIG_IS_ENABLED(CMD_BOOTMENU)
|
|
#define DEFAULT_MENU_ENTRIES \
|
|
"bootmenu_0=Continue standard boot=run bootcmd\0" \
|
|
"bootmenu_1=Boot into recovery=run bootcmd_recovery\0" \
|
|
"bootmenu_2=Boot OpenWrt from NAND=run bootcmd_openwrt_nand\0"
|
|
#else
|
|
#define DEFAULT_MENU_ENTRIES ""
|
|
#endif /* CONFIG_IS_ENABLED(CMD_BOOTMENU) */
|
|
|
|
#define CFG_EXTRA_ENV_SETTINGS \
|
|
"BOARD=ten64\0" \
|
|
"fdt_addr_r=0x90000000\0" \
|
|
"fdt_high=0xa0000000\0" \
|
|
"kernel_addr_r=0x81000000\0" \
|
|
"load_addr=0xa0000000\0" \
|
|
BOOTENV \
|
|
OPENWRT_NAND_BOOTCMD \
|
|
"openwrt_active_sys=a\0" \
|
|
"load_efi_dtb=mtd read devicetree $fdt_addr_r && fdt addr $fdt_addr_r && " \
|
|
"fdt resize && fdt boardsetup\0" \
|
|
"bootcmd_recovery=mtd read recovery 0xa0000000; " \
|
|
"setenv bootargs \"earlycon root=/dev/ram0 ramdisk_size=0x3000000\" && bootm 0xa0000000#ten64\0" \
|
|
DEFAULT_MENU_ENTRIES
|
|
|
|
#endif /* __TEN64_H */
|