xref: /rk3399_rockchip-uboot/include/configs/mx6cuboxi.h (revision 1c5e6b6fbb3835b1170c01844c862c0eaa9bffed)
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 
171368f993SAdrian 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_SYS_FSL_USDHC_NUM	1
85b8ce6fe2SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0	/* SDHC2 */
86b8ce6fe2SFabio Estevam 
87205d5869SFabio Estevam #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
88*1c5e6b6fSVagrant Cascadian #ifndef CONFIG_SPL_BUILD
89b8ce6fe2SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
90205d5869SFabio Estevam 	"fdtfile=undefined\0" \
916a305f22SFabio Estevam 	"fdt_addr_r=0x18000000\0" \
92*1c5e6b6fSVagrant Cascadian 	"fdt_addr=0x18000000\0" \
93*1c5e6b6fSVagrant Cascadian 	"kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0"  \
94*1c5e6b6fSVagrant Cascadian 	"pxefile_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \
95*1c5e6b6fSVagrant Cascadian 	"scriptaddr=" __stringify(CONFIG_LOADADDR) "\0" \
96*1c5e6b6fSVagrant Cascadian 	"ramdisk_addr_r=0x13000000\0" \
97*1c5e6b6fSVagrant Cascadian 	"ramdiskaddr=0x13000000\0" \
98*1c5e6b6fSVagrant Cascadian 	"initrd_high=0xffffffff\0" \
99*1c5e6b6fSVagrant Cascadian 	"fdt_high=0xffffffff\0" \
100b8ce6fe2SFabio Estevam 	"ip_dyn=yes\0" \
101b8ce6fe2SFabio Estevam 	"console=" CONFIG_CONSOLE_DEV "\0" \
102b8ce6fe2SFabio Estevam 	"bootm_size=0x10000000\0" \
103b8ce6fe2SFabio Estevam 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
104b8ce6fe2SFabio Estevam 	"update_sd_firmware=" \
105b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
106b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
107b8ce6fe2SFabio Estevam 		"else " \
108b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
109b8ce6fe2SFabio Estevam 		"fi; " \
110b8ce6fe2SFabio Estevam 		"if mmc dev ${mmcdev}; then "	\
111b8ce6fe2SFabio Estevam 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
112b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${filesize} / 0x200; " \
113b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${fw_sz} + 1; "	\
114b8ce6fe2SFabio Estevam 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
115b8ce6fe2SFabio Estevam 			"fi; "	\
116b8ce6fe2SFabio Estevam 		"fi\0" \
117205d5869SFabio Estevam 	"findfdt="\
118205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6Q ; then " \
119205d5869SFabio Estevam 			"setenv fdtfile imx6q-hummingboard.dtb; fi; " \
120205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6DL ; then " \
121205d5869SFabio Estevam 			"setenv fdtfile imx6dl-hummingboard.dtb; fi; " \
122205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6Q ; then " \
123205d5869SFabio Estevam 			"setenv fdtfile imx6q-cubox-i.dtb; fi; " \
124205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6DL ; then " \
125205d5869SFabio Estevam 			"setenv fdtfile imx6dl-cubox-i.dtb; fi; " \
126205d5869SFabio Estevam 		"if test $fdtfile = undefined; then " \
127205d5869SFabio Estevam 			"echo WARNING: Could not determine dtb to use; fi; \0" \
128*1c5e6b6fSVagrant Cascadian 	BOOTENV
129b8ce6fe2SFabio Estevam 
130b8ce6fe2SFabio Estevam #define CONFIG_BOOTCOMMAND \
131205d5869SFabio Estevam 	"run findfdt; " \
132*1c5e6b6fSVagrant Cascadian 	"run distro_bootcmd"
133*1c5e6b6fSVagrant Cascadian 
134*1c5e6b6fSVagrant Cascadian #define BOOT_TARGET_DEVICES(func) \
135*1c5e6b6fSVagrant Cascadian 	func(MMC, mmc, 0) \
136*1c5e6b6fSVagrant Cascadian 	func(USB, usb, 0) \
137*1c5e6b6fSVagrant Cascadian 	func(PXE, pxe, na) \
138*1c5e6b6fSVagrant Cascadian 	func(DHCP, dhcp, na)
139*1c5e6b6fSVagrant Cascadian 
140*1c5e6b6fSVagrant Cascadian #include <config_distro_defaults.h>
141*1c5e6b6fSVagrant Cascadian #include <config_distro_bootcmd.h>
142*1c5e6b6fSVagrant Cascadian 
143*1c5e6b6fSVagrant Cascadian #else
144*1c5e6b6fSVagrant Cascadian #define CONFIG_EXTRA_ENV_SETTINGS
145*1c5e6b6fSVagrant Cascadian #endif /* CONFIG_SPL_BUILD */
146b8ce6fe2SFabio Estevam 
147b8ce6fe2SFabio Estevam /* Physical Memory Map */
148b8ce6fe2SFabio Estevam #define CONFIG_NR_DRAM_BANKS           1
149b8ce6fe2SFabio Estevam #define CONFIG_SYS_SDRAM_BASE          MMDC0_ARB_BASE_ADDR
150b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR       IRAM_BASE_ADDR
151b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE       IRAM_SIZE
152b8ce6fe2SFabio Estevam 
153b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
154b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
155b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
156b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
157b8ce6fe2SFabio Estevam 
158b8ce6fe2SFabio Estevam /* Environment organization */
159b8ce6fe2SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
160b8ce6fe2SFabio Estevam #define CONFIG_ENV_IS_IN_MMC
161b8ce6fe2SFabio Estevam #define CONFIG_ENV_OFFSET		(8 * 64 * 1024)
162b8ce6fe2SFabio Estevam 
163b8ce6fe2SFabio Estevam #endif                         /* __MX6CUBOXI_CONFIG_H */
164