~funderscore blog cgit wiki get in touch
aboutsummaryrefslogtreecommitdiff
blob: d2bef9b6e528d8b8bd8b9eb2dc3221924cef8b57 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/* 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 */