xref: /openbmc/u-boot/include/configs/mx6cuboxi.h (revision d7869b2183d2b786e5410b97a5a6b2e630e7825e)
183d290c5STom Rini /* SPDX-License-Identifier: GPL-2.0+ */
2b8ce6fe2SFabio Estevam /*
3b8ce6fe2SFabio Estevam  * Copyright (C) 2015 Freescale Semiconductor, Inc.
4b8ce6fe2SFabio Estevam  *
5b8ce6fe2SFabio Estevam  * Configuration settings for the SolidRun mx6 based boards
6b8ce6fe2SFabio Estevam  */
7b8ce6fe2SFabio Estevam #ifndef __MX6CUBOXI_CONFIG_H
8b8ce6fe2SFabio Estevam #define __MX6CUBOXI_CONFIG_H
9b8ce6fe2SFabio Estevam 
10b8ce6fe2SFabio Estevam #include "mx6_common.h"
11b8ce6fe2SFabio Estevam 
12b8ce6fe2SFabio Estevam #include "imx6_spl.h"
13b8ce6fe2SFabio Estevam 
141368f993SAdrian Alonso #define CONFIG_IMX_THERMAL
15b8ce6fe2SFabio Estevam 
16f68a9c6bSFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(10 * SZ_1M)
17b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART
18b8ce6fe2SFabio Estevam 
19b8ce6fe2SFabio Estevam /* MMC Configs */
20b8ce6fe2SFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	USDHC2_BASE_ADDR
21b8ce6fe2SFabio Estevam 
22ff181563SPeter Robinson /* SATA Configuration */
23ff181563SPeter Robinson #ifdef CONFIG_CMD_SATA
24ff181563SPeter Robinson #define CONFIG_SYS_SATA_MAX_DEVICE      1
25ff181563SPeter Robinson #define CONFIG_DWC_AHSATA_PORT_ID       0
26ff181563SPeter Robinson #define CONFIG_DWC_AHSATA_BASE_ADDR     SATA_ARB_BASE_ADDR
27ff181563SPeter Robinson #define CONFIG_LBA48
28ff181563SPeter Robinson #endif
29ff181563SPeter Robinson 
30b8ce6fe2SFabio Estevam /* Ethernet Configuration */
31b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC
32b8ce6fe2SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
33b8ce6fe2SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RGMII
34b8ce6fe2SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		0
35b8ce6fe2SFabio Estevam #define CONFIG_PHY_ATHEROS
36b8ce6fe2SFabio Estevam 
37f68a9c6bSFabio Estevam /* Framebuffer */
38f68a9c6bSFabio Estevam #define CONFIG_VIDEO_IPUV3
39f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_RLE8
40f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN
41f68a9c6bSFabio Estevam #define CONFIG_SPLASH_SCREEN_ALIGN
42f68a9c6bSFabio Estevam #define CONFIG_BMP_16BPP
43f68a9c6bSFabio Estevam #define CONFIG_VIDEO_LOGO
44f68a9c6bSFabio Estevam #define CONFIG_VIDEO_BMP_LOGO
45f68a9c6bSFabio Estevam #define CONFIG_IMX_HDMI
46f68a9c6bSFabio Estevam #define CONFIG_IMX_VIDEO_SKIP
47f68a9c6bSFabio Estevam 
48e1d74379SFabio Estevam /* USB */
49e1d74379SFabio Estevam #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
50e1d74379SFabio Estevam #define CONFIG_MXC_USB_PORTSC		(PORT_PTS_UTMI | PORT_PTS_PTW)
51e1d74379SFabio Estevam #define CONFIG_MXC_USB_FLAGS		0
52e1d74379SFabio Estevam #define CONFIG_USB_MAX_CONTROLLER_COUNT	2
530e1f991eSFabio Estevam #define CONFIG_PREBOOT \
540e1f991eSFabio Estevam 	"if hdmidet; then " \
550e1f991eSFabio Estevam 		"usb start; "		       \
560e1f991eSFabio Estevam 		"setenv stdin  serial,usbkbd; "\
570e1f991eSFabio Estevam 		"setenv stdout serial,vga; "   \
580e1f991eSFabio Estevam 		"setenv stderr serial,vga; "   \
590e1f991eSFabio Estevam 	"else " \
600e1f991eSFabio Estevam 		"setenv stdin  serial; " \
610e1f991eSFabio Estevam 		"setenv stdout serial; " \
620e1f991eSFabio Estevam 		"setenv stderr serial; " \
630e1f991eSFabio Estevam 	"fi;"
64e1d74379SFabio Estevam 
65b8ce6fe2SFabio Estevam /* Command definition */
66b8ce6fe2SFabio Estevam 
67b8ce6fe2SFabio Estevam #define CONFIG_MXC_UART_BASE	UART1_BASE
6812ca05a3SSimon Glass #define CONSOLE_DEV	"ttymxc0"
69b8ce6fe2SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0	/* SDHC2 */
70b8ce6fe2SFabio Estevam 
711c5e6b6fSVagrant Cascadian #ifndef CONFIG_SPL_BUILD
72b8ce6fe2SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
73824705d5SJon Nettleton 	"som_rev=undefined\0" \
74824705d5SJon Nettleton 	"has_emmc=undefined\0" \
75205d5869SFabio Estevam 	"fdtfile=undefined\0" \
766a305f22SFabio Estevam 	"fdt_addr_r=0x18000000\0" \
771c5e6b6fSVagrant Cascadian 	"fdt_addr=0x18000000\0" \
781c5e6b6fSVagrant Cascadian 	"kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0"  \
791c5e6b6fSVagrant Cascadian 	"pxefile_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \
801c5e6b6fSVagrant Cascadian 	"scriptaddr=" __stringify(CONFIG_LOADADDR) "\0" \
811c5e6b6fSVagrant Cascadian 	"ramdisk_addr_r=0x13000000\0" \
821c5e6b6fSVagrant Cascadian 	"ramdiskaddr=0x13000000\0" \
831c5e6b6fSVagrant Cascadian 	"initrd_high=0xffffffff\0" \
841c5e6b6fSVagrant Cascadian 	"fdt_high=0xffffffff\0" \
85b8ce6fe2SFabio Estevam 	"ip_dyn=yes\0" \
8652526ba4SVagrant Cascadian 	"console=" CONSOLE_DEV ",115200\0" \
87b8ce6fe2SFabio Estevam 	"bootm_size=0x10000000\0" \
88b8ce6fe2SFabio Estevam 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
8935ba390dSFabio Berton 	"finduuid=part uuid mmc 0:1 uuid\0" \
90b8ce6fe2SFabio Estevam 	"update_sd_firmware=" \
91b8ce6fe2SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
92b8ce6fe2SFabio Estevam 			"setenv get_cmd dhcp; " \
93b8ce6fe2SFabio Estevam 		"else " \
94b8ce6fe2SFabio Estevam 			"setenv get_cmd tftp; " \
95b8ce6fe2SFabio Estevam 		"fi; " \
96b8ce6fe2SFabio Estevam 		"if mmc dev ${mmcdev}; then "	\
97b8ce6fe2SFabio Estevam 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
98b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${filesize} / 0x200; " \
99b8ce6fe2SFabio Estevam 				"setexpr fw_sz ${fw_sz} + 1; "	\
100b8ce6fe2SFabio Estevam 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
101b8ce6fe2SFabio Estevam 			"fi; "	\
102b8ce6fe2SFabio Estevam 		"fi\0" \
103205d5869SFabio Estevam 	"findfdt="\
104824705d5SJon Nettleton 		"if test ${board_rev} = MX6Q; then " \
10573708200SJon Nettleton 			"setenv fdtprefix imx6q; fi; " \
106824705d5SJon Nettleton 		"if test ${board_rev} = MX6DL; then " \
10773708200SJon Nettleton 			"setenv fdtprefix imx6dl; fi; " \
108824705d5SJon Nettleton 		"if test ${som_rev} = V15; then " \
10973708200SJon Nettleton 			"setenv fdtsuffix -som-v15; fi; " \
110824705d5SJon Nettleton 		"if test ${has_emmc} = yes; then " \
111824705d5SJon Nettleton 			"setenv emmcsuffix -emmc; fi; " \
112824705d5SJon Nettleton 		"if test ${board_name} = HUMMINGBOARD2 ; then " \
113824705d5SJon Nettleton 			"setenv fdtfile ${fdtprefix}-hummingboard2${emmcsuffix}${fdtsuffix}.dtb; fi; " \
114824705d5SJon Nettleton 		"if test ${board_name} = HUMMINGBOARD ; then " \
115824705d5SJon Nettleton 			"setenv fdtfile ${fdtprefix}-hummingboard${emmcsuffix}${fdtsuffix}.dtb; fi; " \
116824705d5SJon Nettleton 		"if test ${board_name} = CUBOXI ; then " \
117824705d5SJon Nettleton 			"setenv fdtfile ${fdtprefix}-cubox-i${emmcsuffix}${fdtsuffix}.dtb; fi; " \
118824705d5SJon Nettleton 		"if test ${fdtfile} = undefined; then " \
119205d5869SFabio Estevam 			"echo WARNING: Could not determine dtb to use; fi; \0" \
1201c5e6b6fSVagrant Cascadian 	BOOTENV
121b8ce6fe2SFabio Estevam 
1221c5e6b6fSVagrant Cascadian #define BOOT_TARGET_DEVICES(func) \
1231c5e6b6fSVagrant Cascadian 	func(MMC, mmc, 0) \
124ff181563SPeter Robinson 	func(SATA, sata, 0) \
1251c5e6b6fSVagrant Cascadian 	func(USB, usb, 0) \
1261c5e6b6fSVagrant Cascadian 	func(PXE, pxe, na) \
1271c5e6b6fSVagrant Cascadian 	func(DHCP, dhcp, na)
1281c5e6b6fSVagrant Cascadian 
1291c5e6b6fSVagrant Cascadian #include <config_distro_bootcmd.h>
1301c5e6b6fSVagrant Cascadian 
1311c5e6b6fSVagrant Cascadian #else
1321c5e6b6fSVagrant Cascadian #define CONFIG_EXTRA_ENV_SETTINGS
1331c5e6b6fSVagrant Cascadian #endif /* CONFIG_SPL_BUILD */
134b8ce6fe2SFabio Estevam 
135b8ce6fe2SFabio Estevam /* Physical Memory Map */
136b8ce6fe2SFabio Estevam #define CONFIG_SYS_SDRAM_BASE          MMDC0_ARB_BASE_ADDR
137b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR       IRAM_BASE_ADDR
138b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE       IRAM_SIZE
139b8ce6fe2SFabio Estevam 
140b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
141b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
142b8ce6fe2SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
143b8ce6fe2SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
144b8ce6fe2SFabio Estevam 
145b8ce6fe2SFabio Estevam /* Environment organization */
146b8ce6fe2SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
147*55314608SJon Nettleton #define CONFIG_ENV_OFFSET		(SZ_1M - CONFIG_ENV_SIZE)
148b8ce6fe2SFabio Estevam 
149b8ce6fe2SFabio Estevam #endif                         /* __MX6CUBOXI_CONFIG_H */
150