xref: /rk3399_rockchip-uboot/include/configs/mx6cuboxi.h (revision ff1815632563a826cfe49fc9496a36d00febb6e3)
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 
24*ff181563SPeter Robinson /* SATA Configuration */
25*ff181563SPeter Robinson #define CONFIG_CMD_SATA
26*ff181563SPeter Robinson #ifdef CONFIG_CMD_SATA
27*ff181563SPeter Robinson #define CONFIG_DWC_AHSATA
28*ff181563SPeter Robinson #define CONFIG_SYS_SATA_MAX_DEVICE      1
29*ff181563SPeter Robinson #define CONFIG_DWC_AHSATA_PORT_ID       0
30*ff181563SPeter Robinson #define CONFIG_DWC_AHSATA_BASE_ADDR     SATA_ARB_BASE_ADDR
31*ff181563SPeter Robinson #define CONFIG_LBA48
32*ff181563SPeter Robinson #define CONFIG_LIBATA
33*ff181563SPeter Robinson #endif
34*ff181563SPeter Robinson 
35b8ce6fe2SFabio Estevam /* Ethernet Configuration */
36b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC
37b8ce6fe2SFabio Estevam #define CONFIG_MII
38b8ce6fe2SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
39b8ce6fe2SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RGMII
40b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		0
41b8ce6fe2SFabio Estevam #define CONFIG_PHYLIB
42b8ce6fe2SFabio Estevam #define CONFIG_PHY_ATHEROS
43b8ce6fe2SFabio Estevam 
44f68a9c6bSFabio Estevam /* Framebuffer */
45f68a9c6bSFabio Estevam #define CONFIG_VIDEO_IPUV3
46f68a9c6bSFabio Estevam #define CONFIG_IPUV3_CLK		260000000
47f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_RLE8
48f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN
49f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN_ALIGN
50f68a9c6bSFabio Estevam #define CONFIG_BMP_16BPP
51f68a9c6bSFabio Estevam #define CONFIG_VIDEO_LOGO
52f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_LOGO
53f68a9c6bSFabio Estevam #define CONFIG_IMX_HDMI
54f68a9c6bSFabio Estevam #define CONFIG_IMX_VIDEO_SKIP
55f68a9c6bSFabio Estevam 
56e1d74379SFabio Estevam /* USB */
57e1d74379SFabio Estevam #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
58e1d74379SFabio Estevam #define CONFIG_MXC_USB_PORTSC		(PORT_PTS_UTMI | PORT_PTS_PTW)
59e1d74379SFabio Estevam #define CONFIG_MXC_USB_FLAGS		0
60e1d74379SFabio Estevam #define CONFIG_USB_MAX_CONTROLLER_COUNT	2
61c49cfdcdSFabio Estevam #define CONFIG_SYS_USB_EVENT_POLL
620e1f991eSFabio Estevam #define CONFIG_PREBOOT \
630e1f991eSFabio Estevam 	"if hdmidet; then " \
640e1f991eSFabio Estevam 		"usb start; "		       \
650e1f991eSFabio Estevam 		"setenv stdin  serial,usbkbd; "\
660e1f991eSFabio Estevam 		"setenv stdout serial,vga; "   \
670e1f991eSFabio Estevam 		"setenv stderr serial,vga; "   \
680e1f991eSFabio Estevam 	"else " \
690e1f991eSFabio Estevam 		"setenv stdin  serial; " \
700e1f991eSFabio Estevam 		"setenv stdout serial; " \
710e1f991eSFabio Estevam 		"setenv stderr serial; " \
720e1f991eSFabio Estevam 	"fi;"
73e1d74379SFabio Estevam 
74b8ce6fe2SFabio Estevam /* Command definition */
75b8ce6fe2SFabio Estevam 
76b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART_BASE	UART1_BASE
7712ca05a3SSimon Glass #define CONSOLE_DEV	"ttymxc0"
78b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_USDHC_NUM	1
79b8ce6fe2SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0	/* SDHC2 */
80b8ce6fe2SFabio Estevam 
81205d5869SFabio Estevam #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
821c5e6b6fSVagrant Cascadian #ifndef CONFIG_SPL_BUILD
83b8ce6fe2SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
84205d5869SFabio Estevam 	"fdtfile=undefined\0" \
856a305f22SFabio Estevam 	"fdt_addr_r=0x18000000\0" \
861c5e6b6fSVagrant Cascadian 	"fdt_addr=0x18000000\0" \
871c5e6b6fSVagrant Cascadian 	"kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0"  \
881c5e6b6fSVagrant Cascadian 	"pxefile_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \
891c5e6b6fSVagrant Cascadian 	"scriptaddr=" __stringify(CONFIG_LOADADDR) "\0" \
901c5e6b6fSVagrant Cascadian 	"ramdisk_addr_r=0x13000000\0" \
911c5e6b6fSVagrant Cascadian 	"ramdiskaddr=0x13000000\0" \
921c5e6b6fSVagrant Cascadian 	"initrd_high=0xffffffff\0" \
931c5e6b6fSVagrant Cascadian 	"fdt_high=0xffffffff\0" \
94b8ce6fe2SFabio Estevam 	"ip_dyn=yes\0" \
9552526ba4SVagrant Cascadian 	"console=" CONSOLE_DEV ",115200\0" \
96b8ce6fe2SFabio Estevam 	"bootm_size=0x10000000\0" \
97b8ce6fe2SFabio Estevam 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
98b8ce6fe2SFabio Estevam 	"update_sd_firmware=" \
99b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
100b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
101b8ce6fe2SFabio Estevam 		"else " \
102b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
103b8ce6fe2SFabio Estevam 		"fi; " \
104b8ce6fe2SFabio Estevam 		"if mmc dev ${mmcdev}; then "	\
105b8ce6fe2SFabio Estevam 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
106b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${filesize} / 0x200; " \
107b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${fw_sz} + 1; "	\
108b8ce6fe2SFabio Estevam 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
109b8ce6fe2SFabio Estevam 			"fi; "	\
110b8ce6fe2SFabio Estevam 		"fi\0" \
111205d5869SFabio Estevam 	"findfdt="\
112205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6Q ; then " \
113205d5869SFabio Estevam 			"setenv fdtfile imx6q-hummingboard.dtb; fi; " \
114205d5869SFabio Estevam 		"if test $board_name = HUMMINGBOARD && test $board_rev = MX6DL ; then " \
115205d5869SFabio Estevam 			"setenv fdtfile imx6dl-hummingboard.dtb; fi; " \
116205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6Q ; then " \
117205d5869SFabio Estevam 			"setenv fdtfile imx6q-cubox-i.dtb; fi; " \
118205d5869SFabio Estevam 		"if test $board_name = CUBOXI && test $board_rev = MX6DL ; then " \
119205d5869SFabio Estevam 			"setenv fdtfile imx6dl-cubox-i.dtb; fi; " \
120205d5869SFabio Estevam 		"if test $fdtfile = undefined; then " \
121205d5869SFabio Estevam 			"echo WARNING: Could not determine dtb to use; fi; \0" \
1221c5e6b6fSVagrant Cascadian 	BOOTENV
123b8ce6fe2SFabio Estevam 
124b8ce6fe2SFabio Estevam #define CONFIG_BOOTCOMMAND \
125205d5869SFabio Estevam 	"run findfdt; " \
1261c5e6b6fSVagrant Cascadian 	"run distro_bootcmd"
1271c5e6b6fSVagrant Cascadian 
1281c5e6b6fSVagrant Cascadian #define BOOT_TARGET_DEVICES(func) \
1291c5e6b6fSVagrant Cascadian 	func(MMC, mmc, 0) \
130*ff181563SPeter Robinson 	func(SATA, sata, 0) \
1311c5e6b6fSVagrant Cascadian 	func(USB, usb, 0) \
1321c5e6b6fSVagrant Cascadian 	func(PXE, pxe, na) \
1331c5e6b6fSVagrant Cascadian 	func(DHCP, dhcp, na)
1341c5e6b6fSVagrant Cascadian 
1351c5e6b6fSVagrant Cascadian #include <config_distro_bootcmd.h>
1361c5e6b6fSVagrant Cascadian 
1371c5e6b6fSVagrant Cascadian #else
1381c5e6b6fSVagrant Cascadian #define CONFIG_EXTRA_ENV_SETTINGS
1391c5e6b6fSVagrant Cascadian #endif /* CONFIG_SPL_BUILD */
140b8ce6fe2SFabio Estevam 
141b8ce6fe2SFabio Estevam /* Physical Memory Map */
142b8ce6fe2SFabio Estevam #define CONFIG_NR_DRAM_BANKS           1
143b8ce6fe2SFabio Estevam #define CONFIG_SYS_SDRAM_BASE          MMDC0_ARB_BASE_ADDR
144b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR       IRAM_BASE_ADDR
145b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE       IRAM_SIZE
146b8ce6fe2SFabio Estevam 
147b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
148b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
149b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
150b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
151b8ce6fe2SFabio Estevam 
152b8ce6fe2SFabio Estevam /* Environment organization */
153b8ce6fe2SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
154b8ce6fe2SFabio Estevam #define CONFIG_ENV_IS_IN_MMC
155b8ce6fe2SFabio Estevam #define CONFIG_ENV_OFFSET		(8 * 64 * 1024)
156b8ce6fe2SFabio Estevam 
157b8ce6fe2SFabio Estevam #endif                         /* __MX6CUBOXI_CONFIG_H */
158