blob: d5bb2e96c51a2e655f3b490545e6f1890178489b [file] [log] [blame]
/* 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 */