xref: /rk3399_rockchip-uboot/include/configs/mx6cuboxi.h (revision e1d74379efff764a41a2e151bd1e4c8fca203755)
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 
30f68a9c6bSFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(10 * SZ_1M)
31b8ce6fe2SFabio Estevam #define CONFIG_BOARD_EARLY_INIT_F
32205d5869SFabio Estevam #define CONFIG_BOARD_LATE_INIT
33b8ce6fe2SFabio Estevam #define CONFIG_MXC_GPIO
34b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART
35b8ce6fe2SFabio Estevam #define CONFIG_CMD_FUSE
36b8ce6fe2SFabio Estevam #define CONFIG_MXC_OCOTP
37b8ce6fe2SFabio Estevam 
38b8ce6fe2SFabio Estevam /* MMC Configs */
39b8ce6fe2SFabio Estevam #define CONFIG_FSL_ESDHC
40b8ce6fe2SFabio Estevam #define CONFIG_FSL_USDHC
41b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	USDHC2_BASE_ADDR
42b8ce6fe2SFabio Estevam #define CONFIG_MMC
43b8ce6fe2SFabio Estevam #define CONFIG_CMD_MMC
44b8ce6fe2SFabio Estevam #define CONFIG_GENERIC_MMC
45b8ce6fe2SFabio Estevam #define CONFIG_BOUNCE_BUFFER
46b8ce6fe2SFabio Estevam #define CONFIG_CMD_EXT4
47b8ce6fe2SFabio Estevam #define CONFIG_CMD_EXT4_WRITE
48b8ce6fe2SFabio Estevam #define CONFIG_CMD_FAT
49b8ce6fe2SFabio Estevam #define CONFIG_DOS_PARTITION
50b8ce6fe2SFabio Estevam 
51b8ce6fe2SFabio Estevam /* Ethernet Configuration */
52b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC
53b8ce6fe2SFabio Estevam #define CONFIG_CMD_PING
54b8ce6fe2SFabio Estevam #define CONFIG_CMD_DHCP
55b8ce6fe2SFabio Estevam #define CONFIG_CMD_MII
56b8ce6fe2SFabio Estevam #define CONFIG_CMD_NET
57b8ce6fe2SFabio Estevam #define CONFIG_MII
58b8ce6fe2SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
59b8ce6fe2SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RGMII
60b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		0
61b8ce6fe2SFabio Estevam #define CONFIG_PHYLIB
62b8ce6fe2SFabio Estevam #define CONFIG_PHY_ATHEROS
63b8ce6fe2SFabio Estevam 
64b8ce6fe2SFabio Estevam /* allow to overwrite serial and ethaddr */
65b8ce6fe2SFabio Estevam #define CONFIG_ENV_OVERWRITE
66b8ce6fe2SFabio Estevam #define CONFIG_CONS_INDEX		1
67b8ce6fe2SFabio Estevam #define CONFIG_BAUDRATE			115200
68b8ce6fe2SFabio Estevam 
69f68a9c6bSFabio Estevam /* Framebuffer */
70f68a9c6bSFabio Estevam #define CONFIG_VIDEO
71f68a9c6bSFabio Estevam #define CONFIG_VIDEO_IPUV3
72f68a9c6bSFabio Estevam #define CONFIG_IPUV3_CLK		260000000
73f68a9c6bSFabio Estevam #define CONFIG_CFB_CONSOLE
74f68a9c6bSFabio Estevam #define CONFIG_VGA_AS_SINGLE_DEVICE
75f68a9c6bSFabio Estevam #define CONFIG_SYS_CONSOLE_IS_IN_ENV
76f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_RLE8
77f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN
78f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN_ALIGN
79f68a9c6bSFabio Estevam #define CONFIG_BMP_16BPP
80f68a9c6bSFabio Estevam #define CONFIG_VIDEO_LOGO
81f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_LOGO
82f68a9c6bSFabio Estevam #define CONFIG_IMX_HDMI
83f68a9c6bSFabio Estevam #define CONFIG_IMX_VIDEO_SKIP
84f68a9c6bSFabio Estevam 
85*e1d74379SFabio Estevam /* USB */
86*e1d74379SFabio Estevam #define CONFIG_CMD_USB
87*e1d74379SFabio Estevam #define CONFIG_USB_EHCI
88*e1d74379SFabio Estevam #define CONFIG_USB_EHCI_MX6
89*e1d74379SFabio Estevam #define CONFIG_USB_STORAGE
90*e1d74379SFabio Estevam #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
91*e1d74379SFabio Estevam #define CONFIG_MXC_USB_PORTSC		(PORT_PTS_UTMI | PORT_PTS_PTW)
92*e1d74379SFabio Estevam #define CONFIG_MXC_USB_FLAGS		0
93*e1d74379SFabio Estevam #define CONFIG_USB_MAX_CONTROLLER_COUNT	2
94*e1d74379SFabio Estevam 
95b8ce6fe2SFabio Estevam #define CONFIG_SYS_NO_FLASH
96b8ce6fe2SFabio Estevam 
97b8ce6fe2SFabio Estevam /* Command definition */
98b8ce6fe2SFabio Estevam #include <config_cmd_default.h>
99b8ce6fe2SFabio Estevam 
100b8ce6fe2SFabio Estevam #define CONFIG_CMD_BOOTZ
101b8ce6fe2SFabio Estevam #define CONFIG_CMD_SETEXPR
102b8ce6fe2SFabio Estevam 
103b8ce6fe2SFabio Estevam #define CONFIG_BOOTDELAY		1
104b8ce6fe2SFabio Estevam 
105b8ce6fe2SFabio Estevam #define CONFIG_LOADADDR			0x12000000
106b8ce6fe2SFabio Estevam #define CONFIG_SYS_TEXT_BASE		0x17800000
107b8ce6fe2SFabio Estevam 
108b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART_BASE	UART1_BASE
109b8ce6fe2SFabio Estevam #define CONFIG_CONSOLE_DEV	"ttymxc0"
110b8ce6fe2SFabio Estevam #define CONFIG_MMCROOT		"/dev/mmcblk0p2"
111b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_USDHC_NUM	1
112b8ce6fe2SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0	/* SDHC2 */
113b8ce6fe2SFabio Estevam 
114205d5869SFabio Estevam #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
115b8ce6fe2SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
116b8ce6fe2SFabio Estevam 	"script=boot.scr\0" \
117b8ce6fe2SFabio Estevam 	"image=zImage\0" \
118205d5869SFabio Estevam 	"fdtfile=undefined\0" \
1196a305f22SFabio Estevam 	"fdt_addr_r=0x18000000\0" \
120b8ce6fe2SFabio Estevam 	"boot_fdt=try\0" \
121b8ce6fe2SFabio Estevam 	"ip_dyn=yes\0" \
122b8ce6fe2SFabio Estevam 	"console=" CONFIG_CONSOLE_DEV "\0" \
123b8ce6fe2SFabio Estevam 	"bootm_size=0x10000000\0" \
124b8ce6fe2SFabio Estevam 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
125b8ce6fe2SFabio Estevam 	"mmcpart=1\0" \
126b8ce6fe2SFabio Estevam 	"mmcroot=" CONFIG_MMCROOT " rootwait rw\0" \
127b8ce6fe2SFabio Estevam 	"update_sd_firmware=" \
128b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
129b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
130b8ce6fe2SFabio Estevam 		"else " \
131b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
132b8ce6fe2SFabio Estevam 		"fi; " \
133b8ce6fe2SFabio Estevam 		"if mmc dev ${mmcdev}; then "	\
134b8ce6fe2SFabio Estevam 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
135b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${filesize} / 0x200; " \
136b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${fw_sz} + 1; "	\
137b8ce6fe2SFabio Estevam 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
138b8ce6fe2SFabio Estevam 			"fi; "	\
139b8ce6fe2SFabio Estevam 		"fi\0" \
140b8ce6fe2SFabio Estevam 	"mmcargs=setenv bootargs console=${console},${baudrate} " \
141b8ce6fe2SFabio Estevam 		"root=${mmcroot}\0" \
142b8ce6fe2SFabio Estevam 	"loadbootscript=" \
143b8ce6fe2SFabio Estevam 		"fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
144b8ce6fe2SFabio Estevam 	"bootscript=echo Running bootscript from mmc ...; " \
145b8ce6fe2SFabio Estevam 		"source\0" \
146b8ce6fe2SFabio Estevam 	"loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
1476a305f22SFabio Estevam 	"loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr_r} ${fdtfile}\0" \
148b8ce6fe2SFabio Estevam 	"mmcboot=echo Booting from mmc ...; " \
149b8ce6fe2SFabio Estevam 		"run mmcargs; " \
150b8ce6fe2SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
151b8ce6fe2SFabio Estevam 			"if run loadfdt; then " \
1526a305f22SFabio Estevam 				"bootz ${loadaddr} - ${fdt_addr_r}; " \
153b8ce6fe2SFabio Estevam 			"else " \
154b8ce6fe2SFabio Estevam 				"if test ${boot_fdt} = try; then " \
155b8ce6fe2SFabio Estevam 					"bootz; " \
156b8ce6fe2SFabio Estevam 				"else " \
157b8ce6fe2SFabio Estevam 					"echo WARN: Cannot load the DT; " \
158b8ce6fe2SFabio Estevam 				"fi; " \
159b8ce6fe2SFabio Estevam 			"fi; " \
160b8ce6fe2SFabio Estevam 		"else " \
161b8ce6fe2SFabio Estevam 			"bootz; " \
162b8ce6fe2SFabio Estevam 		"fi;\0" \
163b8ce6fe2SFabio Estevam 	"netargs=setenv bootargs console=${console},${baudrate} " \
164b8ce6fe2SFabio Estevam 		"root=/dev/nfs " \
165b8ce6fe2SFabio Estevam 		"ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
166b8ce6fe2SFabio Estevam 	"netboot=echo Booting from net ...; " \
167b8ce6fe2SFabio Estevam 		"run netargs; " \
168b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
169b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
170b8ce6fe2SFabio Estevam 		"else " \
171b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
172b8ce6fe2SFabio Estevam 		"fi; " \
173b8ce6fe2SFabio Estevam 		"${get_cmd} ${image}; " \
174b8ce6fe2SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
1756a305f22SFabio Estevam 			"if ${get_cmd} ${fdt_addr_r} ${fdtfile}; then " \
1766a305f22SFabio Estevam 				"bootz ${loadaddr} - ${fdt_addr_r}; " \
177b8ce6fe2SFabio Estevam 			"else " \
178b8ce6fe2SFabio Estevam 				"if test ${boot_fdt} = try; then " \
179b8ce6fe2SFabio Estevam 					"bootz; " \
180b8ce6fe2SFabio Estevam 				"else " \
181b8ce6fe2SFabio Estevam 					"echo WARN: Cannot load the DT; " \
182b8ce6fe2SFabio Estevam 				"fi; " \
183b8ce6fe2SFabio Estevam 			"fi; " \
184b8ce6fe2SFabio Estevam 		"else " \
185b8ce6fe2SFabio Estevam 			"bootz; " \
186205d5869SFabio Estevam 		"fi;\0" \
187205d5869SFabio Estevam 	"findfdt="\
188205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6Q ; then " \
189205d5869SFabio Estevam 			"setenv fdtfile imx6q-hummingboard.dtb; fi; " \
190205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6DL ; then " \
191205d5869SFabio Estevam 			"setenv fdtfile imx6dl-hummingboard.dtb; fi; " \
192205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6Q ; then " \
193205d5869SFabio Estevam 			"setenv fdtfile imx6q-cubox-i.dtb; fi; " \
194205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6DL ; then " \
195205d5869SFabio Estevam 			"setenv fdtfile imx6dl-cubox-i.dtb; fi; " \
196205d5869SFabio Estevam 		"if test $fdtfile = undefined; then " \
197205d5869SFabio Estevam 			"echo WARNING: Could not determine dtb to use; fi; \0" \
198b8ce6fe2SFabio Estevam 
199b8ce6fe2SFabio Estevam #define CONFIG_BOOTCOMMAND \
200205d5869SFabio Estevam 	"run findfdt; " \
201b8ce6fe2SFabio Estevam 	"mmc dev ${mmcdev};" \
202b8ce6fe2SFabio Estevam 	"if mmc rescan; then " \
203b8ce6fe2SFabio Estevam 		"if run loadbootscript; then " \
204b8ce6fe2SFabio Estevam 		"run bootscript; " \
205b8ce6fe2SFabio Estevam 		"else " \
206b8ce6fe2SFabio Estevam 			"if run loadimage; then " \
207b8ce6fe2SFabio Estevam 				"run mmcboot; " \
208b8ce6fe2SFabio Estevam 			"else run netboot; " \
209b8ce6fe2SFabio Estevam 			"fi; " \
210b8ce6fe2SFabio Estevam 		"fi; " \
211b8ce6fe2SFabio Estevam 	"else run netboot; fi"
212b8ce6fe2SFabio Estevam 
213b8ce6fe2SFabio Estevam /* Miscellaneous configurable options */
214b8ce6fe2SFabio Estevam #define CONFIG_SYS_LONGHELP
215b8ce6fe2SFabio Estevam #define CONFIG_SYS_HUSH_PARSER
216b8ce6fe2SFabio Estevam #define CONFIG_AUTO_COMPLETE
217b8ce6fe2SFabio Estevam #define CONFIG_SYS_CBSIZE              256
218b8ce6fe2SFabio Estevam #define CONFIG_SYS_MAXARGS             16
219b8ce6fe2SFabio Estevam #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
220b8ce6fe2SFabio Estevam 
221b8ce6fe2SFabio Estevam #define CONFIG_SYS_LOAD_ADDR           CONFIG_LOADADDR
222b8ce6fe2SFabio Estevam 
223b8ce6fe2SFabio Estevam #define CONFIG_CMDLINE_EDITING
224b8ce6fe2SFabio Estevam 
225b8ce6fe2SFabio Estevam /* Physical Memory Map */
226b8ce6fe2SFabio Estevam #define CONFIG_NR_DRAM_BANKS           1
227b8ce6fe2SFabio Estevam #define CONFIG_SYS_SDRAM_BASE          MMDC0_ARB_BASE_ADDR
228b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR       IRAM_BASE_ADDR
229b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE       IRAM_SIZE
230b8ce6fe2SFabio Estevam 
231b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
232b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
233b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
234b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
235b8ce6fe2SFabio Estevam 
236b8ce6fe2SFabio Estevam /* Environment organization */
237b8ce6fe2SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
238b8ce6fe2SFabio Estevam #define CONFIG_ENV_IS_IN_MMC
239b8ce6fe2SFabio Estevam #define CONFIG_ENV_OFFSET		(8 * 64 * 1024)
240b8ce6fe2SFabio Estevam 
241b8ce6fe2SFabio Estevam #define CONFIG_OF_LIBFDT
242b8ce6fe2SFabio Estevam #define CONFIG_CMD_CACHE
243b8ce6fe2SFabio Estevam 
244b8ce6fe2SFabio Estevam #endif                         /* __MX6CUBOXI_CONFIG_H */
245