xref: /rk3399_rockchip-uboot/include/configs/mx6cuboxi.h (revision ecad7051b07b11fb17196ce45ed0cbe2f1c3234e)
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 
113d99e862SStefano Babic #include <config_distro_defaults.h>
12b8ce6fe2SFabio Estevam #include "mx6_common.h"
13b8ce6fe2SFabio Estevam 
14b8ce6fe2SFabio Estevam #include "imx6_spl.h"
15b8ce6fe2SFabio Estevam 
161368f993SAdrian Alonso #define CONFIG_IMX_THERMAL
17b8ce6fe2SFabio Estevam 
18f68a9c6bSFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(10 * SZ_1M)
19b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART
20b8ce6fe2SFabio Estevam 
21b8ce6fe2SFabio Estevam /* MMC Configs */
22b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	USDHC2_BASE_ADDR
23b8ce6fe2SFabio Estevam 
24ff181563SPeter Robinson /* SATA Configuration */
25ff181563SPeter Robinson #ifdef CONFIG_CMD_SATA
26ff181563SPeter Robinson #define CONFIG_DWC_AHSATA
27ff181563SPeter Robinson #define CONFIG_SYS_SATA_MAX_DEVICE      1
28ff181563SPeter Robinson #define CONFIG_DWC_AHSATA_PORT_ID       0
29ff181563SPeter Robinson #define CONFIG_DWC_AHSATA_BASE_ADDR     SATA_ARB_BASE_ADDR
30ff181563SPeter Robinson #define CONFIG_LBA48
31ff181563SPeter Robinson #define CONFIG_LIBATA
32ff181563SPeter Robinson #endif
33ff181563SPeter Robinson 
34b8ce6fe2SFabio Estevam /* Ethernet Configuration */
35b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC
36b8ce6fe2SFabio Estevam #define CONFIG_MII
37b8ce6fe2SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
38b8ce6fe2SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RGMII
39b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		0
40b8ce6fe2SFabio Estevam #define CONFIG_PHY_ATHEROS
41b8ce6fe2SFabio Estevam 
42f68a9c6bSFabio Estevam /* Framebuffer */
43f68a9c6bSFabio Estevam #define CONFIG_VIDEO_IPUV3
44f68a9c6bSFabio Estevam #define CONFIG_IPUV3_CLK		260000000
45f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_RLE8
46f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN
47f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN_ALIGN
48f68a9c6bSFabio Estevam #define CONFIG_BMP_16BPP
49f68a9c6bSFabio Estevam #define CONFIG_VIDEO_LOGO
50f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_LOGO
51f68a9c6bSFabio Estevam #define CONFIG_IMX_HDMI
52f68a9c6bSFabio Estevam #define CONFIG_IMX_VIDEO_SKIP
53f68a9c6bSFabio Estevam 
54e1d74379SFabio Estevam /* USB */
55e1d74379SFabio Estevam #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
56e1d74379SFabio Estevam #define CONFIG_MXC_USB_PORTSC		(PORT_PTS_UTMI | PORT_PTS_PTW)
57e1d74379SFabio Estevam #define CONFIG_MXC_USB_FLAGS		0
58e1d74379SFabio Estevam #define CONFIG_USB_MAX_CONTROLLER_COUNT	2
590e1f991eSFabio Estevam #define CONFIG_PREBOOT \
600e1f991eSFabio Estevam 	"if hdmidet; then " \
610e1f991eSFabio Estevam 		"usb start; "		       \
620e1f991eSFabio Estevam 		"setenv stdin  serial,usbkbd; "\
630e1f991eSFabio Estevam 		"setenv stdout serial,vga; "   \
640e1f991eSFabio Estevam 		"setenv stderr serial,vga; "   \
650e1f991eSFabio Estevam 	"else " \
660e1f991eSFabio Estevam 		"setenv stdin  serial; " \
670e1f991eSFabio Estevam 		"setenv stdout serial; " \
680e1f991eSFabio Estevam 		"setenv stderr serial; " \
690e1f991eSFabio Estevam 	"fi;"
70e1d74379SFabio Estevam 
71b8ce6fe2SFabio Estevam /* Command definition */
72b8ce6fe2SFabio Estevam 
73b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART_BASE	UART1_BASE
7412ca05a3SSimon Glass #define CONSOLE_DEV	"ttymxc0"
75b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_USDHC_NUM	1
76b8ce6fe2SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0	/* SDHC2 */
77b8ce6fe2SFabio Estevam 
78205d5869SFabio Estevam #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
791c5e6b6fSVagrant Cascadian #ifndef CONFIG_SPL_BUILD
80b8ce6fe2SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
81205d5869SFabio Estevam 	"fdtfile=undefined\0" \
826a305f22SFabio Estevam 	"fdt_addr_r=0x18000000\0" \
831c5e6b6fSVagrant Cascadian 	"fdt_addr=0x18000000\0" \
841c5e6b6fSVagrant Cascadian 	"kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0"  \
851c5e6b6fSVagrant Cascadian 	"pxefile_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \
861c5e6b6fSVagrant Cascadian 	"scriptaddr=" __stringify(CONFIG_LOADADDR) "\0" \
871c5e6b6fSVagrant Cascadian 	"ramdisk_addr_r=0x13000000\0" \
881c5e6b6fSVagrant Cascadian 	"ramdiskaddr=0x13000000\0" \
891c5e6b6fSVagrant Cascadian 	"initrd_high=0xffffffff\0" \
901c5e6b6fSVagrant Cascadian 	"fdt_high=0xffffffff\0" \
91b8ce6fe2SFabio Estevam 	"ip_dyn=yes\0" \
9252526ba4SVagrant Cascadian 	"console=" CONSOLE_DEV ",115200\0" \
93b8ce6fe2SFabio Estevam 	"bootm_size=0x10000000\0" \
94b8ce6fe2SFabio Estevam 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
95*35ba390dSFabio Berton 	"finduuid=part uuid mmc 0:1 uuid\0" \
96b8ce6fe2SFabio Estevam 	"update_sd_firmware=" \
97b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
98b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
99b8ce6fe2SFabio Estevam 		"else " \
100b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
101b8ce6fe2SFabio Estevam 		"fi; " \
102b8ce6fe2SFabio Estevam 		"if mmc dev ${mmcdev}; then "	\
103b8ce6fe2SFabio Estevam 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
104b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${filesize} / 0x200; " \
105b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${fw_sz} + 1; "	\
106b8ce6fe2SFabio Estevam 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
107b8ce6fe2SFabio Estevam 			"fi; "	\
108b8ce6fe2SFabio Estevam 		"fi\0" \
109205d5869SFabio Estevam 	"findfdt="\
110205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6Q ; then " \
111205d5869SFabio Estevam 			"setenv fdtfile imx6q-hummingboard.dtb; fi; " \
112205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6DL ; then " \
113205d5869SFabio Estevam 			"setenv fdtfile imx6dl-hummingboard.dtb; fi; " \
114205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6Q ; then " \
115205d5869SFabio Estevam 			"setenv fdtfile imx6q-cubox-i.dtb; fi; " \
116205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6DL ; then " \
117205d5869SFabio Estevam 			"setenv fdtfile imx6dl-cubox-i.dtb; fi; " \
118205d5869SFabio Estevam 		"if test $fdtfile = undefined; then " \
119205d5869SFabio Estevam 			"echo WARNING: Could not determine dtb to use; fi; \0" \
1201c5e6b6fSVagrant Cascadian 	BOOTENV
121b8ce6fe2SFabio Estevam 
122b8ce6fe2SFabio Estevam #define CONFIG_BOOTCOMMAND \
123205d5869SFabio Estevam 	"run findfdt; " \
124*35ba390dSFabio Berton 	"run finduuid; " \
1251c5e6b6fSVagrant Cascadian 	"run distro_bootcmd"
1261c5e6b6fSVagrant Cascadian 
1271c5e6b6fSVagrant Cascadian #define BOOT_TARGET_DEVICES(func) \
1281c5e6b6fSVagrant Cascadian 	func(MMC, mmc, 0) \
129ff181563SPeter Robinson 	func(SATA, sata, 0) \
1301c5e6b6fSVagrant Cascadian 	func(USB, usb, 0) \
1311c5e6b6fSVagrant Cascadian 	func(PXE, pxe, na) \
1321c5e6b6fSVagrant Cascadian 	func(DHCP, dhcp, na)
1331c5e6b6fSVagrant Cascadian 
1341c5e6b6fSVagrant Cascadian #include <config_distro_bootcmd.h>
1351c5e6b6fSVagrant Cascadian 
1361c5e6b6fSVagrant Cascadian #else
1371c5e6b6fSVagrant Cascadian #define CONFIG_EXTRA_ENV_SETTINGS
1381c5e6b6fSVagrant Cascadian #endif /* CONFIG_SPL_BUILD */
139b8ce6fe2SFabio Estevam 
140b8ce6fe2SFabio Estevam /* Physical Memory Map */
141b8ce6fe2SFabio Estevam #define CONFIG_NR_DRAM_BANKS           1
142b8ce6fe2SFabio Estevam #define CONFIG_SYS_SDRAM_BASE          MMDC0_ARB_BASE_ADDR
143b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR       IRAM_BASE_ADDR
144b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE       IRAM_SIZE
145b8ce6fe2SFabio Estevam 
146b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
147b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
148b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
149b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
150b8ce6fe2SFabio Estevam 
151b8ce6fe2SFabio Estevam /* Environment organization */
152b8ce6fe2SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
153b8ce6fe2SFabio Estevam #define CONFIG_ENV_OFFSET		(8 * 64 * 1024)
154b8ce6fe2SFabio Estevam 
155b8ce6fe2SFabio Estevam #endif                         /* __MX6CUBOXI_CONFIG_H */
156