xref: /rk3399_rockchip-uboot/include/configs/wandboard.h (revision e355eec79dd150d6f44e52357b5e805aed6ebc4a)
1e2d282a1SFabio Estevam /*
2e2d282a1SFabio Estevam  * Copyright (C) 2013 Freescale Semiconductor, Inc.
3e2d282a1SFabio Estevam  *
4e2d282a1SFabio Estevam  * Configuration settings for the Wandboard.
5e2d282a1SFabio Estevam  *
61a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
7e2d282a1SFabio Estevam  */
8e2d282a1SFabio Estevam 
9e2d282a1SFabio Estevam #ifndef __CONFIG_H
10e2d282a1SFabio Estevam #define __CONFIG_H
11e2d282a1SFabio Estevam 
123d99e862SStefano Babic #include <config_distro_defaults.h>
1302824dc7SEric Nelson #include "mx6_common.h"
14e2d282a1SFabio Estevam 
150d1ea052SFabio Estevam #define CONFIG_SPL_LIBCOMMON_SUPPORT
160d1ea052SFabio Estevam #define CONFIG_SPL_MMC_SUPPORT
170d1ea052SFabio Estevam #include "imx6_spl.h"
180d1ea052SFabio Estevam 
19e2d282a1SFabio Estevam #define MACH_TYPE_WANDBOARD		4412
20e2d282a1SFabio Estevam #define CONFIG_MACH_TYPE		MACH_TYPE_WANDBOARD
21e2d282a1SFabio Estevam 
22e2d282a1SFabio Estevam /* Size of malloc() pool */
237bcb983fSFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(10 * SZ_1M)
24e2d282a1SFabio Estevam 
25e2d282a1SFabio Estevam #define CONFIG_BOARD_EARLY_INIT_F
26eaffaa2dSOtavio Salvador #define CONFIG_BOARD_LATE_INIT
27e2d282a1SFabio Estevam 
28e2d282a1SFabio Estevam #define CONFIG_MXC_UART
29e2d282a1SFabio Estevam #define CONFIG_MXC_UART_BASE		UART1_BASE
30e2d282a1SFabio Estevam 
31*e355eec7SGilles Chanteperdrix /* SATA Configs */
32*e355eec7SGilles Chanteperdrix 
33*e355eec7SGilles Chanteperdrix #define CONFIG_CMD_SATA
34*e355eec7SGilles Chanteperdrix #ifdef CONFIG_CMD_SATA
35*e355eec7SGilles Chanteperdrix #define CONFIG_DWC_AHSATA
36*e355eec7SGilles Chanteperdrix #define CONFIG_SYS_SATA_MAX_DEVICE	1
37*e355eec7SGilles Chanteperdrix #define CONFIG_DWC_AHSATA_PORT_ID	0
38*e355eec7SGilles Chanteperdrix #define CONFIG_DWC_AHSATA_BASE_ADDR	SATA_ARB_BASE_ADDR
39*e355eec7SGilles Chanteperdrix #define CONFIG_LBA48
40*e355eec7SGilles Chanteperdrix #define CONFIG_LIBATA
41*e355eec7SGilles Chanteperdrix #endif
42*e355eec7SGilles Chanteperdrix 
43e2d282a1SFabio Estevam /* Command definition */
44eaffaa2dSOtavio Salvador #define CONFIG_CMD_BMODE
450798d578SOtavio Salvador 
46e2d282a1SFabio Estevam #define CONFIG_SYS_MEMTEST_START	0x10000000
47e2d282a1SFabio Estevam #define CONFIG_SYS_MEMTEST_END		(CONFIG_SYS_MEMTEST_START + 500 * SZ_1M)
48e2d282a1SFabio Estevam 
498bc7c487SOtavio Salvador /* I2C Configs */
508bc7c487SOtavio Salvador #define CONFIG_SYS_I2C
518bc7c487SOtavio Salvador #define CONFIG_SYS_I2C_MXC
5203544c66SAlbert ARIBAUD \\(3ADEV\\) #define CONFIG_SYS_I2C_MXC_I2C1		/* enable I2C bus 1 */
5303544c66SAlbert ARIBAUD \\(3ADEV\\) #define CONFIG_SYS_I2C_MXC_I2C2		/* enable I2C bus 2 */
54f8cb101eSYork Sun #define CONFIG_SYS_I2C_MXC_I2C3		/* enable I2C bus 3 */
558bc7c487SOtavio Salvador #define CONFIG_SYS_I2C_SPEED		100000
568bc7c487SOtavio Salvador 
57e2d282a1SFabio Estevam /* MMC Configuration */
585ed15738SOtavio Salvador #define CONFIG_SYS_FSL_USDHC_NUM	2
59e2d282a1SFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	0
60e2d282a1SFabio Estevam 
619df47577SJeroen Hofstee /* USB Configs */
629df47577SJeroen Hofstee #define CONFIG_USB_EHCI
639df47577SJeroen Hofstee #define CONFIG_USB_EHCI_MX6
649df47577SJeroen Hofstee #define CONFIG_USB_STORAGE
659df47577SJeroen Hofstee #define CONFIG_USB_MAX_CONTROLLER_COUNT	2
669df47577SJeroen Hofstee #define CONFIG_MXC_USB_PORTSC		(PORT_PTS_UTMI | PORT_PTS_PTW)
679df47577SJeroen Hofstee #define CONFIG_MXC_USB_FLAGS		0
689df47577SJeroen Hofstee 
69e2d282a1SFabio Estevam /* Ethernet Configuration */
70e2d282a1SFabio Estevam #define CONFIG_FEC_MXC
71e2d282a1SFabio Estevam #define CONFIG_MII
72e2d282a1SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
73e2d282a1SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RGMII
74e2d282a1SFabio Estevam #define CONFIG_ETHPRIME			"FEC"
75e2d282a1SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		1
76e2d282a1SFabio Estevam #define CONFIG_PHYLIB
77e2d282a1SFabio Estevam #define CONFIG_PHY_ATHEROS
78e2d282a1SFabio Estevam 
797bcb983fSFabio Estevam /* Framebuffer */
807bcb983fSFabio Estevam #define CONFIG_VIDEO
817bcb983fSFabio Estevam #define CONFIG_VIDEO_IPUV3
827bcb983fSFabio Estevam #define CONFIG_CFB_CONSOLE
837bcb983fSFabio Estevam #define CONFIG_VGA_AS_SINGLE_DEVICE
847bcb983fSFabio Estevam #define CONFIG_SYS_CONSOLE_IS_IN_ENV
857bcb983fSFabio Estevam #define CONFIG_SYS_CONSOLE_OVERWRITE_ROUTINE
867bcb983fSFabio Estevam #define CONFIG_VIDEO_BMP_RLE8
877bcb983fSFabio Estevam #define CONFIG_SPLASH_SCREEN
88a7efb026SOtavio Salvador #define CONFIG_SPLASH_SCREEN_ALIGN
897bcb983fSFabio Estevam #define CONFIG_BMP_16BPP
907bcb983fSFabio Estevam #define CONFIG_VIDEO_LOGO
91a7efb026SOtavio Salvador #define CONFIG_VIDEO_BMP_LOGO
927bcb983fSFabio Estevam #define CONFIG_IPUV3_CLK 260000000
930ef797a5SOtavio Salvador #define CONFIG_CMD_HDMIDETECT
945ea7f0e3SPardeep Kumar Singla #define CONFIG_IMX_HDMI
958bc7c487SOtavio Salvador #define CONFIG_IMX_VIDEO_SKIP
967bcb983fSFabio Estevam 
970d1ea052SFabio Estevam #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
98e2d282a1SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
99acc6bb56SVagrant Cascadian 	"console=ttymxc0,115200\0" \
100d727ab3cSOtavio Salvador 	"splashpos=m,m\0" \
1010d1ea052SFabio Estevam 	"fdtfile=undefined\0" \
102e2d282a1SFabio Estevam 	"fdt_high=0xffffffff\0" \
103e2d282a1SFabio Estevam 	"initrd_high=0xffffffff\0" \
104acc6bb56SVagrant Cascadian 	"fdt_addr_r=0x18000000\0" \
1056584a1b5SOtavio Salvador 	"fdt_addr=0x18000000\0" \
106e2d282a1SFabio Estevam 	"ip_dyn=yes\0" \
1071e1cbde0SOtavio Salvador 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
1080798d578SOtavio Salvador 	"update_sd_firmware_filename=u-boot.imx\0" \
1090798d578SOtavio Salvador 	"update_sd_firmware=" \
1100798d578SOtavio Salvador 		"if test ${ip_dyn} = yes; then " \
1110798d578SOtavio Salvador 			"setenv get_cmd dhcp; " \
1120798d578SOtavio Salvador 		"else " \
1130798d578SOtavio Salvador 			"setenv get_cmd tftp; " \
1140798d578SOtavio Salvador 		"fi; " \
1150798d578SOtavio Salvador 		"if mmc dev ${mmcdev}; then "	\
1160798d578SOtavio Salvador 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
1170798d578SOtavio Salvador 				"setexpr fw_sz ${filesize} / 0x200; " \
1180798d578SOtavio Salvador 				"setexpr fw_sz ${fw_sz} + 1; "	\
1190798d578SOtavio Salvador 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
1200798d578SOtavio Salvador 			"fi; "	\
1210798d578SOtavio Salvador 		"fi\0" \
1220ef797a5SOtavio Salvador 	"videoargs=" \
1230ef797a5SOtavio Salvador 		"setenv nextcon 0; " \
1240ef797a5SOtavio Salvador 		"if hdmidet; then " \
1250ef797a5SOtavio Salvador 			"setenv bootargs ${bootargs} " \
1260ef797a5SOtavio Salvador 				"video=mxcfb${nextcon}:dev=hdmi,1280x720M@60," \
1270ef797a5SOtavio Salvador 					"if=RGB24; " \
1280ef797a5SOtavio Salvador 			"setenv fbmen fbmem=28M; " \
1290ef797a5SOtavio Salvador 			"setexpr nextcon ${nextcon} + 1; " \
1300ef797a5SOtavio Salvador 		"else " \
1310ef797a5SOtavio Salvador 			"echo - no HDMI monitor;" \
1320ef797a5SOtavio Salvador 		"fi; " \
1330ef797a5SOtavio Salvador 		"i2c dev 1; " \
1340ef797a5SOtavio Salvador 		"if i2c probe 0x10; then " \
1350ef797a5SOtavio Salvador 			"setenv bootargs ${bootargs} " \
1360ef797a5SOtavio Salvador 				"video=mxcfb${nextcon}:dev=lcd,800x480@60," \
13799c618ffSOtavio Salvador 					"if=RGB666,bpp=32; " \
1380ef797a5SOtavio Salvador 			"if test 0 -eq ${nextcon}; then " \
1390ef797a5SOtavio Salvador 				"setenv fbmem fbmem=10M; " \
1400ef797a5SOtavio Salvador 			"else " \
1410ef797a5SOtavio Salvador 				"setenv fbmem ${fbmem},10M; " \
1420ef797a5SOtavio Salvador 			"fi; " \
1430ef797a5SOtavio Salvador 			"setexpr nextcon ${nextcon} + 1; " \
1440ef797a5SOtavio Salvador 		"else " \
1450ef797a5SOtavio Salvador 			"echo '- no FWBADAPT-7WVGA-LCD-F07A-0102 display';" \
1460ef797a5SOtavio Salvador 		"fi; " \
1470ef797a5SOtavio Salvador 		"setenv bootargs ${bootargs} ${fbmem}\0" \
1480d1ea052SFabio Estevam 	"findfdt="\
1499a8804a8SFabio Estevam 		"if test $board_name = C1 && test $board_rev = MX6Q ; then " \
1500d1ea052SFabio Estevam 			"setenv fdtfile imx6q-wandboard.dtb; fi; " \
1519a8804a8SFabio Estevam 		"if test $board_name = C1 && test $board_rev = MX6DL ; then " \
1520d1ea052SFabio Estevam 			"setenv fdtfile imx6dl-wandboard.dtb; fi; " \
1539a8804a8SFabio Estevam 		"if test $board_name = B1 && test $board_rev = MX6Q ; then " \
1549a8804a8SFabio Estevam 			"setenv fdtfile imx6q-wandboard-revb1.dtb; fi; " \
1559a8804a8SFabio Estevam 		"if test $board_name = B1 && test $board_rev = MX6DL ; then " \
1569a8804a8SFabio Estevam 			"setenv fdtfile imx6dl-wandboard-revb1.dtb; fi; " \
1570d1ea052SFabio Estevam 		"if test $fdtfile = undefined; then " \
1580d1ea052SFabio Estevam 			"echo WARNING: Could not determine dtb to use; fi; \0" \
159acc6bb56SVagrant Cascadian 	"kernel_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \
160d3b78e18SPeter Robinson 	"pxefile_addr_r=" __stringify(CONFIG_LOADADDR) "\0" \
161acc6bb56SVagrant Cascadian 	"ramdisk_addr_r=0x13000000\0" \
162acc6bb56SVagrant Cascadian 	"ramdiskaddr=0x13000000\0" \
163acc6bb56SVagrant Cascadian 	"scriptaddr=" __stringify(CONFIG_LOADADDR) "\0" \
164acc6bb56SVagrant Cascadian 	BOOTENV
165acc6bb56SVagrant Cascadian 
166acc6bb56SVagrant Cascadian #define BOOT_TARGET_DEVICES(func) \
167acc6bb56SVagrant Cascadian 	func(MMC, mmc, 0) \
168acc6bb56SVagrant Cascadian 	func(MMC, mmc, 1) \
169acc6bb56SVagrant Cascadian 	func(USB, usb, 0) \
170acc6bb56SVagrant Cascadian 	func(PXE, pxe, na) \
171acc6bb56SVagrant Cascadian 	func(DHCP, dhcp, na)
172e2d282a1SFabio Estevam 
173e2d282a1SFabio Estevam #define CONFIG_BOOTCOMMAND \
1740d1ea052SFabio Estevam 	   "run findfdt; " \
175acc6bb56SVagrant Cascadian 	   "run distro_bootcmd"
176acc6bb56SVagrant Cascadian 
177acc6bb56SVagrant Cascadian #include <config_distro_bootcmd.h>
178e2d282a1SFabio Estevam 
179e2d282a1SFabio Estevam /* Physical Memory Map */
180e2d282a1SFabio Estevam #define CONFIG_NR_DRAM_BANKS		1
181e2d282a1SFabio Estevam #define PHYS_SDRAM			MMDC0_ARB_BASE_ADDR
182e2d282a1SFabio Estevam 
183e2d282a1SFabio Estevam #define CONFIG_SYS_SDRAM_BASE		PHYS_SDRAM
184e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR	IRAM_BASE_ADDR
185e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE	IRAM_SIZE
186e2d282a1SFabio Estevam 
187e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
188e2d282a1SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
189e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
190e2d282a1SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
191e2d282a1SFabio Estevam 
192056845c2SPeter Robinson /* Environment organization */
193e2d282a1SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
194e2d282a1SFabio Estevam 
195e2d282a1SFabio Estevam #define CONFIG_ENV_IS_IN_MMC
196e2d282a1SFabio Estevam #define CONFIG_ENV_OFFSET		(6 * 64 * 1024)
197e2d282a1SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0
198e2d282a1SFabio Estevam 
199e2d282a1SFabio Estevam #endif			       /* __CONFIG_H * */
200