xref: /rk3399_rockchip-uboot/include/configs/mx6cuboxi.h (revision 1368f99346b1a6c566095bcb1df662cdbdb129b3)
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 "mx6_common.h"
12b8ce6fe2SFabio Estevam 
13b8ce6fe2SFabio Estevam #define CONFIG_SPL_LIBCOMMON_SUPPORT
14b8ce6fe2SFabio Estevam #define CONFIG_SPL_MMC_SUPPORT
15b8ce6fe2SFabio Estevam #include "imx6_spl.h"
16b8ce6fe2SFabio Estevam 
17*1368f993SAdrian Alonso #define CONFIG_IMX_THERMAL
18b8ce6fe2SFabio Estevam 
19f68a9c6bSFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(10 * SZ_1M)
20b8ce6fe2SFabio Estevam #define CONFIG_BOARD_EARLY_INIT_F
21205d5869SFabio Estevam #define CONFIG_BOARD_LATE_INIT
22b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART
23b8ce6fe2SFabio Estevam 
24b8ce6fe2SFabio Estevam /* MMC Configs */
25b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	USDHC2_BASE_ADDR
26b8ce6fe2SFabio Estevam 
27b8ce6fe2SFabio Estevam /* Ethernet Configuration */
28b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC
29b8ce6fe2SFabio Estevam #define CONFIG_CMD_PING
30b8ce6fe2SFabio Estevam #define CONFIG_CMD_DHCP
31b8ce6fe2SFabio Estevam #define CONFIG_CMD_MII
32b8ce6fe2SFabio Estevam #define CONFIG_MII
33b8ce6fe2SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
34b8ce6fe2SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RGMII
35b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		0
36b8ce6fe2SFabio Estevam #define CONFIG_PHYLIB
37b8ce6fe2SFabio Estevam #define CONFIG_PHY_ATHEROS
38b8ce6fe2SFabio Estevam 
39f68a9c6bSFabio Estevam /* Framebuffer */
40f68a9c6bSFabio Estevam #define CONFIG_VIDEO
41f68a9c6bSFabio Estevam #define CONFIG_VIDEO_IPUV3
42f68a9c6bSFabio Estevam #define CONFIG_IPUV3_CLK		260000000
43f68a9c6bSFabio Estevam #define CONFIG_CFB_CONSOLE
44f68a9c6bSFabio Estevam #define CONFIG_VGA_AS_SINGLE_DEVICE
45f68a9c6bSFabio Estevam #define CONFIG_SYS_CONSOLE_IS_IN_ENV
46f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_RLE8
47f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN
48f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN_ALIGN
49f68a9c6bSFabio Estevam #define CONFIG_BMP_16BPP
50f68a9c6bSFabio Estevam #define CONFIG_VIDEO_LOGO
51f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_LOGO
52f68a9c6bSFabio Estevam #define CONFIG_IMX_HDMI
530e1f991eSFabio Estevam #define CONFIG_CMD_HDMIDETECT
54f68a9c6bSFabio Estevam #define CONFIG_IMX_VIDEO_SKIP
55c49cfdcdSFabio Estevam #define CONFIG_CONSOLE_MUX
56f68a9c6bSFabio Estevam 
57e1d74379SFabio Estevam /* USB */
58e1d74379SFabio Estevam #define CONFIG_CMD_USB
59e1d74379SFabio Estevam #define CONFIG_USB_EHCI
60e1d74379SFabio Estevam #define CONFIG_USB_EHCI_MX6
61e1d74379SFabio Estevam #define CONFIG_USB_STORAGE
62e1d74379SFabio Estevam #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
63e1d74379SFabio Estevam #define CONFIG_MXC_USB_PORTSC		(PORT_PTS_UTMI | PORT_PTS_PTW)
64e1d74379SFabio Estevam #define CONFIG_MXC_USB_FLAGS		0
65e1d74379SFabio Estevam #define CONFIG_USB_MAX_CONTROLLER_COUNT	2
66c49cfdcdSFabio Estevam #define CONFIG_USB_KEYBOARD
67c49cfdcdSFabio Estevam #define CONFIG_SYS_USB_EVENT_POLL
680e1f991eSFabio Estevam #define CONFIG_PREBOOT \
690e1f991eSFabio Estevam 	"if hdmidet; then " \
700e1f991eSFabio Estevam 		"usb start; "		       \
710e1f991eSFabio Estevam 		"setenv stdin  serial,usbkbd; "\
720e1f991eSFabio Estevam 		"setenv stdout serial,vga; "   \
730e1f991eSFabio Estevam 		"setenv stderr serial,vga; "   \
740e1f991eSFabio Estevam 	"else " \
750e1f991eSFabio Estevam 		"setenv stdin  serial; " \
760e1f991eSFabio Estevam 		"setenv stdout serial; " \
770e1f991eSFabio Estevam 		"setenv stderr serial; " \
780e1f991eSFabio Estevam 	"fi;"
79e1d74379SFabio Estevam 
80b8ce6fe2SFabio Estevam /* Command definition */
81b8ce6fe2SFabio Estevam 
82b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART_BASE	UART1_BASE
83b8ce6fe2SFabio Estevam #define CONFIG_CONSOLE_DEV	"ttymxc0"
84b8ce6fe2SFabio Estevam #define CONFIG_MMCROOT		"/dev/mmcblk0p2"
85b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_USDHC_NUM	1
86b8ce6fe2SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0	/* SDHC2 */
87b8ce6fe2SFabio Estevam 
88205d5869SFabio Estevam #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
89b8ce6fe2SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
90b8ce6fe2SFabio Estevam 	"script=boot.scr\0" \
91b8ce6fe2SFabio Estevam 	"image=zImage\0" \
92205d5869SFabio Estevam 	"fdtfile=undefined\0" \
936a305f22SFabio Estevam 	"fdt_addr_r=0x18000000\0" \
94b8ce6fe2SFabio Estevam 	"boot_fdt=try\0" \
95b8ce6fe2SFabio Estevam 	"ip_dyn=yes\0" \
96b8ce6fe2SFabio Estevam 	"console=" CONFIG_CONSOLE_DEV "\0" \
97b8ce6fe2SFabio Estevam 	"bootm_size=0x10000000\0" \
98b8ce6fe2SFabio Estevam 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
99b8ce6fe2SFabio Estevam 	"mmcpart=1\0" \
100b8ce6fe2SFabio Estevam 	"mmcroot=" CONFIG_MMCROOT " rootwait rw\0" \
101b8ce6fe2SFabio Estevam 	"update_sd_firmware=" \
102b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
103b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
104b8ce6fe2SFabio Estevam 		"else " \
105b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
106b8ce6fe2SFabio Estevam 		"fi; " \
107b8ce6fe2SFabio Estevam 		"if mmc dev ${mmcdev}; then "	\
108b8ce6fe2SFabio Estevam 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
109b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${filesize} / 0x200; " \
110b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${fw_sz} + 1; "	\
111b8ce6fe2SFabio Estevam 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
112b8ce6fe2SFabio Estevam 			"fi; "	\
113b8ce6fe2SFabio Estevam 		"fi\0" \
114b8ce6fe2SFabio Estevam 	"mmcargs=setenv bootargs console=${console},${baudrate} " \
115b8ce6fe2SFabio Estevam 		"root=${mmcroot}\0" \
116b8ce6fe2SFabio Estevam 	"loadbootscript=" \
117b8ce6fe2SFabio Estevam 		"fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
118b8ce6fe2SFabio Estevam 	"bootscript=echo Running bootscript from mmc ...; " \
119b8ce6fe2SFabio Estevam 		"source\0" \
120b8ce6fe2SFabio Estevam 	"loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
1216a305f22SFabio Estevam 	"loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr_r} ${fdtfile}\0" \
122b8ce6fe2SFabio Estevam 	"mmcboot=echo Booting from mmc ...; " \
123b8ce6fe2SFabio Estevam 		"run mmcargs; " \
124b8ce6fe2SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
125b8ce6fe2SFabio Estevam 			"if run loadfdt; then " \
1266a305f22SFabio Estevam 				"bootz ${loadaddr} - ${fdt_addr_r}; " \
127b8ce6fe2SFabio Estevam 			"else " \
128b8ce6fe2SFabio Estevam 				"if test ${boot_fdt} = try; then " \
129b8ce6fe2SFabio Estevam 					"bootz; " \
130b8ce6fe2SFabio Estevam 				"else " \
131b8ce6fe2SFabio Estevam 					"echo WARN: Cannot load the DT; " \
132b8ce6fe2SFabio Estevam 				"fi; " \
133b8ce6fe2SFabio Estevam 			"fi; " \
134b8ce6fe2SFabio Estevam 		"else " \
135b8ce6fe2SFabio Estevam 			"bootz; " \
136b8ce6fe2SFabio Estevam 		"fi;\0" \
137b8ce6fe2SFabio Estevam 	"netargs=setenv bootargs console=${console},${baudrate} " \
138b8ce6fe2SFabio Estevam 		"root=/dev/nfs " \
139b8ce6fe2SFabio Estevam 		"ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
140b8ce6fe2SFabio Estevam 	"netboot=echo Booting from net ...; " \
141b8ce6fe2SFabio Estevam 		"run netargs; " \
142b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
143b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
144b8ce6fe2SFabio Estevam 		"else " \
145b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
146b8ce6fe2SFabio Estevam 		"fi; " \
147b8ce6fe2SFabio Estevam 		"${get_cmd} ${image}; " \
148b8ce6fe2SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
1496a305f22SFabio Estevam 			"if ${get_cmd} ${fdt_addr_r} ${fdtfile}; then " \
1506a305f22SFabio Estevam 				"bootz ${loadaddr} - ${fdt_addr_r}; " \
151b8ce6fe2SFabio Estevam 			"else " \
152b8ce6fe2SFabio Estevam 				"if test ${boot_fdt} = try; then " \
153b8ce6fe2SFabio Estevam 					"bootz; " \
154b8ce6fe2SFabio Estevam 				"else " \
155b8ce6fe2SFabio Estevam 					"echo WARN: Cannot load the DT; " \
156b8ce6fe2SFabio Estevam 				"fi; " \
157b8ce6fe2SFabio Estevam 			"fi; " \
158b8ce6fe2SFabio Estevam 		"else " \
159b8ce6fe2SFabio Estevam 			"bootz; " \
160205d5869SFabio Estevam 		"fi;\0" \
161205d5869SFabio Estevam 	"findfdt="\
162205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6Q ; then " \
163205d5869SFabio Estevam 			"setenv fdtfile imx6q-hummingboard.dtb; fi; " \
164205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6DL ; then " \
165205d5869SFabio Estevam 			"setenv fdtfile imx6dl-hummingboard.dtb; fi; " \
166205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6Q ; then " \
167205d5869SFabio Estevam 			"setenv fdtfile imx6q-cubox-i.dtb; fi; " \
168205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6DL ; then " \
169205d5869SFabio Estevam 			"setenv fdtfile imx6dl-cubox-i.dtb; fi; " \
170205d5869SFabio Estevam 		"if test $fdtfile = undefined; then " \
171205d5869SFabio Estevam 			"echo WARNING: Could not determine dtb to use; fi; \0" \
172b8ce6fe2SFabio Estevam 
173b8ce6fe2SFabio Estevam #define CONFIG_BOOTCOMMAND \
174205d5869SFabio Estevam 	"run findfdt; " \
175b8ce6fe2SFabio Estevam 	"mmc dev ${mmcdev};" \
176b8ce6fe2SFabio Estevam 	"if mmc rescan; then " \
177b8ce6fe2SFabio Estevam 		"if run loadbootscript; then " \
178b8ce6fe2SFabio Estevam 		"run bootscript; " \
179b8ce6fe2SFabio Estevam 		"else " \
180b8ce6fe2SFabio Estevam 			"if run loadimage; then " \
181b8ce6fe2SFabio Estevam 				"run mmcboot; " \
182b8ce6fe2SFabio Estevam 			"else run netboot; " \
183b8ce6fe2SFabio Estevam 			"fi; " \
184b8ce6fe2SFabio Estevam 		"fi; " \
185b8ce6fe2SFabio Estevam 	"else run netboot; fi"
186b8ce6fe2SFabio Estevam 
187b8ce6fe2SFabio Estevam /* Physical Memory Map */
188b8ce6fe2SFabio Estevam #define CONFIG_NR_DRAM_BANKS           1
189b8ce6fe2SFabio Estevam #define CONFIG_SYS_SDRAM_BASE          MMDC0_ARB_BASE_ADDR
190b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR       IRAM_BASE_ADDR
191b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE       IRAM_SIZE
192b8ce6fe2SFabio Estevam 
193b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
194b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
195b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
196b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
197b8ce6fe2SFabio Estevam 
198b8ce6fe2SFabio Estevam /* Environment organization */
199b8ce6fe2SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
200b8ce6fe2SFabio Estevam #define CONFIG_ENV_IS_IN_MMC
201b8ce6fe2SFabio Estevam #define CONFIG_ENV_OFFSET		(8 * 64 * 1024)
202b8ce6fe2SFabio Estevam 
203b8ce6fe2SFabio Estevam #endif                         /* __MX6CUBOXI_CONFIG_H */
204