xref: /rk3399_rockchip-uboot/include/configs/mx6cuboxi.h (revision 6a305f22c58b5cef595b2e004fc6b299934dd82a)
1b8ce6fe2SFabio Estevam /*
2b8ce6fe2SFabio Estevam  * Copyright (C) 2015 Freescale Semiconductor, Inc.
3b8ce6fe2SFabio Estevam  *
4b8ce6fe2SFabio Estevam  * Configuration settings for the SolidRun mx6 based boards
5b8ce6fe2SFabio Estevam  *
6b8ce6fe2SFabio Estevam  * SPDX-License-Identifier:	GPL-2.0+
7b8ce6fe2SFabio Estevam  */
8b8ce6fe2SFabio Estevam #ifndef __MX6CUBOXI_CONFIG_H
9b8ce6fe2SFabio Estevam #define __MX6CUBOXI_CONFIG_H
10b8ce6fe2SFabio Estevam 
11b8ce6fe2SFabio Estevam #include <linux/sizes.h>
12b8ce6fe2SFabio Estevam #include <asm/arch/imx-regs.h>
13b8ce6fe2SFabio Estevam #include <asm/imx-common/gpio.h>
14b8ce6fe2SFabio Estevam #include "mx6_common.h"
15b8ce6fe2SFabio Estevam 
16b8ce6fe2SFabio Estevam #define CONFIG_MX6
17b8ce6fe2SFabio Estevam #define CONFIG_SPL_LIBCOMMON_SUPPORT
18b8ce6fe2SFabio Estevam #define CONFIG_SPL_MMC_SUPPORT
19b8ce6fe2SFabio Estevam #include "imx6_spl.h"
20b8ce6fe2SFabio Estevam 
21b8ce6fe2SFabio Estevam #define CONFIG_DISPLAY_CPUINFO
22b8ce6fe2SFabio Estevam #define CONFIG_DISPLAY_BOARDINFO
23b8ce6fe2SFabio Estevam #define CONFIG_CMDLINE_TAG
24b8ce6fe2SFabio Estevam #define CONFIG_SETUP_MEMORY_TAGS
25b8ce6fe2SFabio Estevam #define CONFIG_INITRD_TAG
26b8ce6fe2SFabio Estevam #define CONFIG_REVISION_TAG
27b8ce6fe2SFabio Estevam #define CONFIG_IMX6_THERMAL
28b8ce6fe2SFabio Estevam #define CONFIG_SYS_GENERIC_BOARD
29b8ce6fe2SFabio Estevam 
30b8ce6fe2SFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(2 * SZ_1M)
31b8ce6fe2SFabio Estevam #define CONFIG_BOARD_EARLY_INIT_F
32b8ce6fe2SFabio Estevam #define CONFIG_MXC_GPIO
33b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART
34b8ce6fe2SFabio Estevam #define CONFIG_CMD_FUSE
35b8ce6fe2SFabio Estevam #define CONFIG_MXC_OCOTP
36b8ce6fe2SFabio Estevam 
37b8ce6fe2SFabio Estevam /* MMC Configs */
38b8ce6fe2SFabio Estevam #define CONFIG_FSL_ESDHC
39b8ce6fe2SFabio Estevam #define CONFIG_FSL_USDHC
40b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	USDHC2_BASE_ADDR
41b8ce6fe2SFabio Estevam #define CONFIG_MMC
42b8ce6fe2SFabio Estevam #define CONFIG_CMD_MMC
43b8ce6fe2SFabio Estevam #define CONFIG_GENERIC_MMC
44b8ce6fe2SFabio Estevam #define CONFIG_BOUNCE_BUFFER
45b8ce6fe2SFabio Estevam #define CONFIG_CMD_EXT4
46b8ce6fe2SFabio Estevam #define CONFIG_CMD_EXT4_WRITE
47b8ce6fe2SFabio Estevam #define CONFIG_CMD_FAT
48b8ce6fe2SFabio Estevam #define CONFIG_DOS_PARTITION
49b8ce6fe2SFabio Estevam 
50b8ce6fe2SFabio Estevam /* Ethernet Configuration */
51b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC
52b8ce6fe2SFabio Estevam #define CONFIG_CMD_PING
53b8ce6fe2SFabio Estevam #define CONFIG_CMD_DHCP
54b8ce6fe2SFabio Estevam #define CONFIG_CMD_MII
55b8ce6fe2SFabio Estevam #define CONFIG_CMD_NET
56b8ce6fe2SFabio Estevam #define CONFIG_MII
57b8ce6fe2SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
58b8ce6fe2SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RGMII
59b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		0
60b8ce6fe2SFabio Estevam #define CONFIG_PHYLIB
61b8ce6fe2SFabio Estevam #define CONFIG_PHY_ATHEROS
62b8ce6fe2SFabio Estevam 
63b8ce6fe2SFabio Estevam /* allow to overwrite serial and ethaddr */
64b8ce6fe2SFabio Estevam #define CONFIG_ENV_OVERWRITE
65b8ce6fe2SFabio Estevam #define CONFIG_CONS_INDEX		1
66b8ce6fe2SFabio Estevam #define CONFIG_BAUDRATE			115200
67b8ce6fe2SFabio Estevam 
68b8ce6fe2SFabio Estevam #define CONFIG_SYS_NO_FLASH
69b8ce6fe2SFabio Estevam 
70b8ce6fe2SFabio Estevam /* Command definition */
71b8ce6fe2SFabio Estevam #include <config_cmd_default.h>
72b8ce6fe2SFabio Estevam 
73b8ce6fe2SFabio Estevam #define CONFIG_CMD_BOOTZ
74b8ce6fe2SFabio Estevam #define CONFIG_CMD_SETEXPR
75b8ce6fe2SFabio Estevam 
76b8ce6fe2SFabio Estevam #define CONFIG_BOOTDELAY		1
77b8ce6fe2SFabio Estevam 
78b8ce6fe2SFabio Estevam #define CONFIG_LOADADDR			0x12000000
79b8ce6fe2SFabio Estevam #define CONFIG_SYS_TEXT_BASE		0x17800000
80b8ce6fe2SFabio Estevam 
81b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART_BASE	UART1_BASE
82b8ce6fe2SFabio Estevam #define CONFIG_CONSOLE_DEV	"ttymxc0"
83b8ce6fe2SFabio Estevam #define CONFIG_MMCROOT		"/dev/mmcblk0p2"
84b8ce6fe2SFabio Estevam #define CONFIG_DEFAULT_FDT_FILE	"imx6q-hummingboard.dtb"
85b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_USDHC_NUM	1
86b8ce6fe2SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0	/* SDHC2 */
87b8ce6fe2SFabio Estevam 
88b8ce6fe2SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
89b8ce6fe2SFabio Estevam 	"script=boot.scr\0" \
90b8ce6fe2SFabio Estevam 	"image=zImage\0" \
91*6a305f22SFabio Estevam 	"fdtfile=" CONFIG_DEFAULT_FDT_FILE "\0" \
92*6a305f22SFabio Estevam 	"fdt_addr_r=0x18000000\0" \
93b8ce6fe2SFabio Estevam 	"boot_fdt=try\0" \
94b8ce6fe2SFabio Estevam 	"ip_dyn=yes\0" \
95b8ce6fe2SFabio Estevam 	"console=" CONFIG_CONSOLE_DEV "\0" \
96b8ce6fe2SFabio Estevam 	"bootm_size=0x10000000\0" \
97b8ce6fe2SFabio Estevam 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
98b8ce6fe2SFabio Estevam 	"mmcpart=1\0" \
99b8ce6fe2SFabio Estevam 	"mmcroot=" CONFIG_MMCROOT " rootwait rw\0" \
100b8ce6fe2SFabio Estevam 	"update_sd_firmware=" \
101b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
102b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
103b8ce6fe2SFabio Estevam 		"else " \
104b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
105b8ce6fe2SFabio Estevam 		"fi; " \
106b8ce6fe2SFabio Estevam 		"if mmc dev ${mmcdev}; then "	\
107b8ce6fe2SFabio Estevam 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
108b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${filesize} / 0x200; " \
109b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${fw_sz} + 1; "	\
110b8ce6fe2SFabio Estevam 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
111b8ce6fe2SFabio Estevam 			"fi; "	\
112b8ce6fe2SFabio Estevam 		"fi\0" \
113b8ce6fe2SFabio Estevam 	"mmcargs=setenv bootargs console=${console},${baudrate} " \
114b8ce6fe2SFabio Estevam 		"root=${mmcroot}\0" \
115b8ce6fe2SFabio Estevam 	"loadbootscript=" \
116b8ce6fe2SFabio Estevam 		"fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
117b8ce6fe2SFabio Estevam 	"bootscript=echo Running bootscript from mmc ...; " \
118b8ce6fe2SFabio Estevam 		"source\0" \
119b8ce6fe2SFabio Estevam 	"loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
120*6a305f22SFabio Estevam 	"loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr_r} ${fdtfile}\0" \
121b8ce6fe2SFabio Estevam 	"mmcboot=echo Booting from mmc ...; " \
122b8ce6fe2SFabio Estevam 		"run mmcargs; " \
123b8ce6fe2SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
124b8ce6fe2SFabio Estevam 			"if run loadfdt; then " \
125*6a305f22SFabio Estevam 				"bootz ${loadaddr} - ${fdt_addr_r}; " \
126b8ce6fe2SFabio Estevam 			"else " \
127b8ce6fe2SFabio Estevam 				"if test ${boot_fdt} = try; then " \
128b8ce6fe2SFabio Estevam 					"bootz; " \
129b8ce6fe2SFabio Estevam 				"else " \
130b8ce6fe2SFabio Estevam 					"echo WARN: Cannot load the DT; " \
131b8ce6fe2SFabio Estevam 				"fi; " \
132b8ce6fe2SFabio Estevam 			"fi; " \
133b8ce6fe2SFabio Estevam 		"else " \
134b8ce6fe2SFabio Estevam 			"bootz; " \
135b8ce6fe2SFabio Estevam 		"fi;\0" \
136b8ce6fe2SFabio Estevam 	"netargs=setenv bootargs console=${console},${baudrate} " \
137b8ce6fe2SFabio Estevam 		"root=/dev/nfs " \
138b8ce6fe2SFabio Estevam 		"ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
139b8ce6fe2SFabio Estevam 	"netboot=echo Booting from net ...; " \
140b8ce6fe2SFabio Estevam 		"run netargs; " \
141b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
142b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
143b8ce6fe2SFabio Estevam 		"else " \
144b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
145b8ce6fe2SFabio Estevam 		"fi; " \
146b8ce6fe2SFabio Estevam 		"${get_cmd} ${image}; " \
147b8ce6fe2SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
148*6a305f22SFabio Estevam 			"if ${get_cmd} ${fdt_addr_r} ${fdtfile}; then " \
149*6a305f22SFabio Estevam 				"bootz ${loadaddr} - ${fdt_addr_r}; " \
150b8ce6fe2SFabio Estevam 			"else " \
151b8ce6fe2SFabio Estevam 				"if test ${boot_fdt} = try; then " \
152b8ce6fe2SFabio Estevam 					"bootz; " \
153b8ce6fe2SFabio Estevam 				"else " \
154b8ce6fe2SFabio Estevam 					"echo WARN: Cannot load the DT; " \
155b8ce6fe2SFabio Estevam 				"fi; " \
156b8ce6fe2SFabio Estevam 			"fi; " \
157b8ce6fe2SFabio Estevam 		"else " \
158b8ce6fe2SFabio Estevam 			"bootz; " \
159b8ce6fe2SFabio Estevam 		"fi;\0"
160b8ce6fe2SFabio Estevam 
161b8ce6fe2SFabio Estevam #define CONFIG_BOOTCOMMAND \
162b8ce6fe2SFabio Estevam 	"mmc dev ${mmcdev};" \
163b8ce6fe2SFabio Estevam 	"if mmc rescan; then " \
164b8ce6fe2SFabio Estevam 		"if run loadbootscript; then " \
165b8ce6fe2SFabio Estevam 		"run bootscript; " \
166b8ce6fe2SFabio Estevam 		"else " \
167b8ce6fe2SFabio Estevam 			"if run loadimage; then " \
168b8ce6fe2SFabio Estevam 				"run mmcboot; " \
169b8ce6fe2SFabio Estevam 			"else run netboot; " \
170b8ce6fe2SFabio Estevam 			"fi; " \
171b8ce6fe2SFabio Estevam 		"fi; " \
172b8ce6fe2SFabio Estevam 	"else run netboot; fi"
173b8ce6fe2SFabio Estevam 
174b8ce6fe2SFabio Estevam /* Miscellaneous configurable options */
175b8ce6fe2SFabio Estevam #define CONFIG_SYS_LONGHELP
176b8ce6fe2SFabio Estevam #define CONFIG_SYS_HUSH_PARSER
177b8ce6fe2SFabio Estevam #define CONFIG_AUTO_COMPLETE
178b8ce6fe2SFabio Estevam #define CONFIG_SYS_CBSIZE              256
179b8ce6fe2SFabio Estevam #define CONFIG_SYS_MAXARGS             16
180b8ce6fe2SFabio Estevam #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
181b8ce6fe2SFabio Estevam 
182b8ce6fe2SFabio Estevam #define CONFIG_SYS_LOAD_ADDR           CONFIG_LOADADDR
183b8ce6fe2SFabio Estevam 
184b8ce6fe2SFabio Estevam #define CONFIG_CMDLINE_EDITING
185b8ce6fe2SFabio Estevam 
186b8ce6fe2SFabio Estevam /* Physical Memory Map */
187b8ce6fe2SFabio Estevam #define CONFIG_NR_DRAM_BANKS           1
188b8ce6fe2SFabio Estevam #define CONFIG_SYS_SDRAM_BASE          MMDC0_ARB_BASE_ADDR
189b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR       IRAM_BASE_ADDR
190b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE       IRAM_SIZE
191b8ce6fe2SFabio Estevam 
192b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
193b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
194b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
195b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
196b8ce6fe2SFabio Estevam 
197b8ce6fe2SFabio Estevam /* Environment organization */
198b8ce6fe2SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
199b8ce6fe2SFabio Estevam #define CONFIG_ENV_IS_IN_MMC
200b8ce6fe2SFabio Estevam #define CONFIG_ENV_OFFSET		(8 * 64 * 1024)
201b8ce6fe2SFabio Estevam 
202b8ce6fe2SFabio Estevam #define CONFIG_OF_LIBFDT
203b8ce6fe2SFabio Estevam #define CONFIG_CMD_CACHE
204b8ce6fe2SFabio Estevam 
205b8ce6fe2SFabio Estevam #endif                         /* __MX6CUBOXI_CONFIG_H */
206