xref: /rk3399_rockchip-uboot/include/configs/wandboard.h (revision 99c618ff261e1b68e3245ecc467e5a5a8c5e7b8d)
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 
1202824dc7SEric Nelson #include "mx6_common.h"
13e2d282a1SFabio Estevam #include <asm/arch/imx-regs.h>
14e2d282a1SFabio Estevam #include <asm/imx-common/gpio.h>
151ace4022SAlexey Brodkin #include <linux/sizes.h>
16e2d282a1SFabio Estevam 
17e2d282a1SFabio Estevam #define CONFIG_MX6
18e2d282a1SFabio Estevam #define CONFIG_DISPLAY_CPUINFO
19e2d282a1SFabio Estevam #define CONFIG_DISPLAY_BOARDINFO
20e2d282a1SFabio Estevam 
21e2d282a1SFabio Estevam #define MACH_TYPE_WANDBOARD		4412
22e2d282a1SFabio Estevam #define CONFIG_MACH_TYPE		MACH_TYPE_WANDBOARD
23e2d282a1SFabio Estevam 
24e2d282a1SFabio Estevam #define CONFIG_CMDLINE_TAG
25e2d282a1SFabio Estevam #define CONFIG_SETUP_MEMORY_TAGS
26e2d282a1SFabio Estevam #define CONFIG_INITRD_TAG
27e2d282a1SFabio Estevam #define CONFIG_REVISION_TAG
28e2d282a1SFabio Estevam 
297f5d0af8SFabio Estevam #define CONFIG_SYS_GENERIC_BOARD
307f5d0af8SFabio Estevam 
31e2d282a1SFabio Estevam /* Size of malloc() pool */
327bcb983fSFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(10 * SZ_1M)
33e2d282a1SFabio Estevam 
34e2d282a1SFabio Estevam #define CONFIG_BOARD_EARLY_INIT_F
35eaffaa2dSOtavio Salvador #define CONFIG_BOARD_LATE_INIT
36e2d282a1SFabio Estevam #define CONFIG_MXC_GPIO
37e2d282a1SFabio Estevam 
38e2d282a1SFabio Estevam #define CONFIG_MXC_UART
39e2d282a1SFabio Estevam #define CONFIG_MXC_UART_BASE		UART1_BASE
40e2d282a1SFabio Estevam 
41e2d282a1SFabio Estevam /* allow to overwrite serial and ethaddr */
42e2d282a1SFabio Estevam #define CONFIG_ENV_OVERWRITE
43e2d282a1SFabio Estevam #define CONFIG_CONS_INDEX		1
44e2d282a1SFabio Estevam #define CONFIG_BAUDRATE			115200
45e2d282a1SFabio Estevam 
46e2d282a1SFabio Estevam /* Command definition */
47e2d282a1SFabio Estevam #include <config_cmd_default.h>
48e2d282a1SFabio Estevam 
49e2d282a1SFabio Estevam #undef CONFIG_CMD_IMLS
50e2d282a1SFabio Estevam 
51eaffaa2dSOtavio Salvador #define CONFIG_CMD_BMODE
520798d578SOtavio Salvador #define CONFIG_CMD_SETEXPR
530798d578SOtavio Salvador 
54e2d282a1SFabio Estevam #define CONFIG_BOOTDELAY		5
55e2d282a1SFabio Estevam 
56e2d282a1SFabio Estevam #define CONFIG_SYS_MEMTEST_START	0x10000000
57e2d282a1SFabio Estevam #define CONFIG_SYS_MEMTEST_END		(CONFIG_SYS_MEMTEST_START + 500 * SZ_1M)
58e2d282a1SFabio Estevam #define CONFIG_LOADADDR			0x12000000
59e2d282a1SFabio Estevam #define CONFIG_SYS_TEXT_BASE		0x17800000
60e2d282a1SFabio Estevam 
618bc7c487SOtavio Salvador /* I2C Configs */
628bc7c487SOtavio Salvador #define CONFIG_CMD_I2C
638bc7c487SOtavio Salvador #define CONFIG_SYS_I2C
648bc7c487SOtavio Salvador #define CONFIG_SYS_I2C_MXC
658bc7c487SOtavio Salvador #define CONFIG_SYS_I2C_SPEED		100000
668bc7c487SOtavio Salvador 
67e2d282a1SFabio Estevam /* MMC Configuration */
68e2d282a1SFabio Estevam #define CONFIG_FSL_ESDHC
69e2d282a1SFabio Estevam #define CONFIG_FSL_USDHC
705ed15738SOtavio Salvador #define CONFIG_SYS_FSL_USDHC_NUM	2
71e2d282a1SFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	0
72e2d282a1SFabio Estevam 
73e2d282a1SFabio Estevam #define CONFIG_MMC
74e2d282a1SFabio Estevam #define CONFIG_CMD_MMC
75e2d282a1SFabio Estevam #define CONFIG_GENERIC_MMC
76e2d282a1SFabio Estevam #define CONFIG_BOUNCE_BUFFER
77e2d282a1SFabio Estevam #define CONFIG_CMD_EXT2
78e2d282a1SFabio Estevam #define CONFIG_CMD_FAT
79e2d282a1SFabio Estevam #define CONFIG_DOS_PARTITION
80e2d282a1SFabio Estevam 
819df47577SJeroen Hofstee /* USB Configs */
829df47577SJeroen Hofstee #define CONFIG_CMD_USB
839df47577SJeroen Hofstee #define CONFIG_USB_EHCI
849df47577SJeroen Hofstee #define CONFIG_USB_EHCI_MX6
859df47577SJeroen Hofstee #define CONFIG_USB_STORAGE
869df47577SJeroen Hofstee #define CONFIG_USB_MAX_CONTROLLER_COUNT	2
879df47577SJeroen Hofstee #define CONFIG_MXC_USB_PORTSC		(PORT_PTS_UTMI | PORT_PTS_PTW)
889df47577SJeroen Hofstee #define CONFIG_MXC_USB_FLAGS		0
899df47577SJeroen Hofstee 
90e2d282a1SFabio Estevam /* Ethernet Configuration */
91e2d282a1SFabio Estevam #define CONFIG_CMD_PING
92e2d282a1SFabio Estevam #define CONFIG_CMD_DHCP
93e2d282a1SFabio Estevam #define CONFIG_CMD_MII
94e2d282a1SFabio Estevam #define CONFIG_CMD_NET
95e2d282a1SFabio Estevam #define CONFIG_FEC_MXC
96e2d282a1SFabio Estevam #define CONFIG_MII
97e2d282a1SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
98e2d282a1SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RGMII
99e2d282a1SFabio Estevam #define CONFIG_ETHPRIME			"FEC"
100e2d282a1SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		1
101e2d282a1SFabio Estevam #define CONFIG_PHYLIB
102e2d282a1SFabio Estevam #define CONFIG_PHY_ATHEROS
103e2d282a1SFabio Estevam 
1047bcb983fSFabio Estevam /* Framebuffer */
1057bcb983fSFabio Estevam #define CONFIG_VIDEO
1067bcb983fSFabio Estevam #define CONFIG_VIDEO_IPUV3
1077bcb983fSFabio Estevam #define CONFIG_CFB_CONSOLE
1087bcb983fSFabio Estevam #define CONFIG_VGA_AS_SINGLE_DEVICE
1097bcb983fSFabio Estevam #define CONFIG_SYS_CONSOLE_IS_IN_ENV
1107bcb983fSFabio Estevam #define CONFIG_SYS_CONSOLE_OVERWRITE_ROUTINE
1117bcb983fSFabio Estevam #define CONFIG_VIDEO_BMP_RLE8
1127bcb983fSFabio Estevam #define CONFIG_SPLASH_SCREEN
113a7efb026SOtavio Salvador #define CONFIG_SPLASH_SCREEN_ALIGN
1147bcb983fSFabio Estevam #define CONFIG_BMP_16BPP
1157bcb983fSFabio Estevam #define CONFIG_VIDEO_LOGO
116a7efb026SOtavio Salvador #define CONFIG_VIDEO_BMP_LOGO
1177bcb983fSFabio Estevam #define CONFIG_IPUV3_CLK 260000000
1180ef797a5SOtavio Salvador #define CONFIG_CMD_HDMIDETECT
1195ea7f0e3SPardeep Kumar Singla #define CONFIG_IMX_HDMI
1208bc7c487SOtavio Salvador #define CONFIG_IMX_VIDEO_SKIP
1217bcb983fSFabio Estevam 
1229f87640cSFabio Estevam #define CONFIG_CMD_FUSE
1239f87640cSFabio Estevam #ifdef CONFIG_CMD_FUSE
1249f87640cSFabio Estevam #define CONFIG_MXC_OCOTP
1259f87640cSFabio Estevam #endif
1269f87640cSFabio Estevam 
127f62cd00dSFabio Estevam #if defined(CONFIG_MX6DL) || defined(CONFIG_MX6S)
128e2d282a1SFabio Estevam #define CONFIG_DEFAULT_FDT_FILE		"imx6dl-wandboard.dtb"
129491f2947STapani Utriainen #elif defined(CONFIG_MX6Q)
130491f2947STapani Utriainen #define CONFIG_DEFAULT_FDT_FILE		"imx6q-wandboard.dtb"
131e2d282a1SFabio Estevam #endif
132e2d282a1SFabio Estevam 
133e2d282a1SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
134e2d282a1SFabio Estevam 	"script=boot.scr\0" \
135f3533970SJohn Weber 	"image=zImage\0" \
136e2d282a1SFabio Estevam 	"console=ttymxc0\0" \
137d727ab3cSOtavio Salvador 	"splashpos=m,m\0" \
138e2d282a1SFabio Estevam 	"fdt_high=0xffffffff\0" \
139e2d282a1SFabio Estevam 	"initrd_high=0xffffffff\0" \
140e2d282a1SFabio Estevam 	"fdt_file=" CONFIG_DEFAULT_FDT_FILE "\0" \
1416584a1b5SOtavio Salvador 	"fdt_addr=0x18000000\0" \
142e2d282a1SFabio Estevam 	"boot_fdt=try\0" \
143e2d282a1SFabio Estevam 	"ip_dyn=yes\0" \
1441e1cbde0SOtavio Salvador 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
14586812c4dSOtavio Salvador 	"mmcpart=1\0" \
14686812c4dSOtavio Salvador 	"mmcroot=/dev/mmcblk0p2 rootwait rw\0" \
1470798d578SOtavio Salvador 	"update_sd_firmware_filename=u-boot.imx\0" \
1480798d578SOtavio Salvador 	"update_sd_firmware=" \
1490798d578SOtavio Salvador 		"if test ${ip_dyn} = yes; then " \
1500798d578SOtavio Salvador 			"setenv get_cmd dhcp; " \
1510798d578SOtavio Salvador 		"else " \
1520798d578SOtavio Salvador 			"setenv get_cmd tftp; " \
1530798d578SOtavio Salvador 		"fi; " \
1540798d578SOtavio Salvador 		"if mmc dev ${mmcdev}; then "	\
1550798d578SOtavio Salvador 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
1560798d578SOtavio Salvador 				"setexpr fw_sz ${filesize} / 0x200; " \
1570798d578SOtavio Salvador 				"setexpr fw_sz ${fw_sz} + 1; "	\
1580798d578SOtavio Salvador 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
1590798d578SOtavio Salvador 			"fi; "	\
1600798d578SOtavio Salvador 		"fi\0" \
161e2d282a1SFabio Estevam 	"mmcargs=setenv bootargs console=${console},${baudrate} " \
1620ef797a5SOtavio Salvador 		"root=${mmcroot}; run videoargs\0" \
1630ef797a5SOtavio Salvador 	"videoargs=" \
1640ef797a5SOtavio Salvador 		"setenv nextcon 0; " \
1650ef797a5SOtavio Salvador 		"if hdmidet; then " \
1660ef797a5SOtavio Salvador 			"setenv bootargs ${bootargs} " \
1670ef797a5SOtavio Salvador 				"video=mxcfb${nextcon}:dev=hdmi,1280x720M@60," \
1680ef797a5SOtavio Salvador 					"if=RGB24; " \
1690ef797a5SOtavio Salvador 			"setenv fbmen fbmem=28M; " \
1700ef797a5SOtavio Salvador 			"setexpr nextcon ${nextcon} + 1; " \
1710ef797a5SOtavio Salvador 		"else " \
1720ef797a5SOtavio Salvador 			"echo - no HDMI monitor;" \
1730ef797a5SOtavio Salvador 		"fi; " \
1740ef797a5SOtavio Salvador 		"i2c dev 1; " \
1750ef797a5SOtavio Salvador 		"if i2c probe 0x10; then " \
1760ef797a5SOtavio Salvador 			"setenv bootargs ${bootargs} " \
1770ef797a5SOtavio Salvador 				"video=mxcfb${nextcon}:dev=lcd,800x480@60," \
178*99c618ffSOtavio Salvador 					"if=RGB666,bpp=32; " \
1790ef797a5SOtavio Salvador 			"if test 0 -eq ${nextcon}; then " \
1800ef797a5SOtavio Salvador 				"setenv fbmem fbmem=10M; " \
1810ef797a5SOtavio Salvador 			"else " \
1820ef797a5SOtavio Salvador 				"setenv fbmem ${fbmem},10M; " \
1830ef797a5SOtavio Salvador 			"fi; " \
1840ef797a5SOtavio Salvador 			"setexpr nextcon ${nextcon} + 1; " \
1850ef797a5SOtavio Salvador 		"else " \
1860ef797a5SOtavio Salvador 			"echo '- no FWBADAPT-7WVGA-LCD-F07A-0102 display';" \
1870ef797a5SOtavio Salvador 		"fi; " \
1880ef797a5SOtavio Salvador 		"setenv bootargs ${bootargs} ${fbmem}\0" \
189e2d282a1SFabio Estevam 	"loadbootscript=" \
190e2d282a1SFabio Estevam 		"fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
191e2d282a1SFabio Estevam 	"bootscript=echo Running bootscript from mmc ...; " \
192e2d282a1SFabio Estevam 		"source\0" \
193f3533970SJohn Weber 	"loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
194e2d282a1SFabio Estevam 	"loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
195e2d282a1SFabio Estevam 	"mmcboot=echo Booting from mmc ...; " \
196e2d282a1SFabio Estevam 		"run mmcargs; " \
197e2d282a1SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
198e2d282a1SFabio Estevam 			"if run loadfdt; then " \
199f3533970SJohn Weber 				"bootz ${loadaddr} - ${fdt_addr}; " \
200e2d282a1SFabio Estevam 			"else " \
201e2d282a1SFabio Estevam 				"if test ${boot_fdt} = try; then " \
202f3533970SJohn Weber 					"bootz; " \
203e2d282a1SFabio Estevam 				"else " \
204e2d282a1SFabio Estevam 					"echo WARN: Cannot load the DT; " \
205e2d282a1SFabio Estevam 				"fi; " \
206e2d282a1SFabio Estevam 			"fi; " \
207e2d282a1SFabio Estevam 		"else " \
208f3533970SJohn Weber 			"bootz; " \
209e2d282a1SFabio Estevam 		"fi;\0" \
210e2d282a1SFabio Estevam 	"netargs=setenv bootargs console=${console},${baudrate} " \
211e2d282a1SFabio Estevam 		"root=/dev/nfs " \
212e2d282a1SFabio Estevam 	"ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
213e2d282a1SFabio Estevam 		"netboot=echo Booting from net ...; " \
214e2d282a1SFabio Estevam 		"run netargs; " \
215e2d282a1SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
216e2d282a1SFabio Estevam 			"setenv get_cmd dhcp; " \
217e2d282a1SFabio Estevam 		"else " \
218e2d282a1SFabio Estevam 			"setenv get_cmd tftp; " \
219e2d282a1SFabio Estevam 		"fi; " \
220f3533970SJohn Weber 		"${get_cmd} ${image}; " \
221e2d282a1SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
222e2d282a1SFabio Estevam 			"if ${get_cmd} ${fdt_addr} ${fdt_file}; then " \
223f3533970SJohn Weber 				"bootz ${loadaddr} - ${fdt_addr}; " \
224e2d282a1SFabio Estevam 			"else " \
225e2d282a1SFabio Estevam 				"if test ${boot_fdt} = try; then " \
226f3533970SJohn Weber 					"bootz; " \
227e2d282a1SFabio Estevam 				"else " \
228e2d282a1SFabio Estevam 					"echo WARN: Cannot load the DT; " \
229e2d282a1SFabio Estevam 				"fi; " \
230e2d282a1SFabio Estevam 			"fi; " \
231e2d282a1SFabio Estevam 		"else " \
232f3533970SJohn Weber 			"bootz; " \
233e2d282a1SFabio Estevam 		"fi;\0"
234e2d282a1SFabio Estevam 
235e2d282a1SFabio Estevam #define CONFIG_BOOTCOMMAND \
236e2d282a1SFabio Estevam 	   "mmc dev ${mmcdev}; if mmc rescan; then " \
237e2d282a1SFabio Estevam 		   "if run loadbootscript; then " \
238e2d282a1SFabio Estevam 			   "run bootscript; " \
239e2d282a1SFabio Estevam 		   "else " \
240f3533970SJohn Weber 			   "if run loadimage; then " \
241e2d282a1SFabio Estevam 				   "run mmcboot; " \
242e2d282a1SFabio Estevam 			   "else run netboot; " \
243e2d282a1SFabio Estevam 			   "fi; " \
244e2d282a1SFabio Estevam 		   "fi; " \
245e2d282a1SFabio Estevam 	   "else run netboot; fi"
246e2d282a1SFabio Estevam 
247e2d282a1SFabio Estevam /* Miscellaneous configurable options */
248e2d282a1SFabio Estevam #define CONFIG_SYS_LONGHELP
249e2d282a1SFabio Estevam #define CONFIG_SYS_HUSH_PARSER
250e2d282a1SFabio Estevam #define CONFIG_AUTO_COMPLETE
251e2d282a1SFabio Estevam #define CONFIG_SYS_CBSIZE		256
252e2d282a1SFabio Estevam 
253e2d282a1SFabio Estevam /* Print Buffer Size */
254e2d282a1SFabio Estevam #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
255e2d282a1SFabio Estevam #define CONFIG_SYS_MAXARGS	       16
256e2d282a1SFabio Estevam #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
257e2d282a1SFabio Estevam 
258e2d282a1SFabio Estevam #define CONFIG_SYS_LOAD_ADDR		CONFIG_LOADADDR
259e2d282a1SFabio Estevam 
260e2d282a1SFabio Estevam #define CONFIG_CMDLINE_EDITING
261e2d282a1SFabio Estevam 
262e2d282a1SFabio Estevam /* Physical Memory Map */
263e2d282a1SFabio Estevam #define CONFIG_NR_DRAM_BANKS		1
264e2d282a1SFabio Estevam #define PHYS_SDRAM			MMDC0_ARB_BASE_ADDR
265e2d282a1SFabio Estevam 
266e2d282a1SFabio Estevam #define CONFIG_SYS_SDRAM_BASE		PHYS_SDRAM
267e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR	IRAM_BASE_ADDR
268e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE	IRAM_SIZE
269e2d282a1SFabio Estevam 
270e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
271e2d282a1SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
272e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
273e2d282a1SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
274e2d282a1SFabio Estevam 
275e2d282a1SFabio Estevam /* FLASH and environment organization */
276e2d282a1SFabio Estevam #define CONFIG_SYS_NO_FLASH
277e2d282a1SFabio Estevam 
278e2d282a1SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
279e2d282a1SFabio Estevam 
280e2d282a1SFabio Estevam #define CONFIG_ENV_IS_IN_MMC
281e2d282a1SFabio Estevam #define CONFIG_ENV_OFFSET		(6 * 64 * 1024)
282e2d282a1SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0
283e2d282a1SFabio Estevam 
284e2d282a1SFabio Estevam #define CONFIG_OF_LIBFDT
285e2d282a1SFabio Estevam #define CONFIG_CMD_BOOTZ
286e2d282a1SFabio Estevam 
287e2d282a1SFabio Estevam #ifndef CONFIG_SYS_DCACHE_OFF
288e2d282a1SFabio Estevam #define CONFIG_CMD_CACHE
289e2d282a1SFabio Estevam #endif
290e2d282a1SFabio Estevam 
291e2d282a1SFabio Estevam #endif			       /* __CONFIG_H * */
292