xref: /rk3399_rockchip-uboot/include/configs/wandboard.h (revision 86812c4d5bf2d4252e268ddf82503e8d392fe369)
1e2d282a1SFabio Estevam /*
2e2d282a1SFabio Estevam  * Copyright (C) 2013 Freescale Semiconductor, Inc.
3e2d282a1SFabio Estevam  *
4e2d282a1SFabio Estevam  * Configuration settings for the Wandboard.
5e2d282a1SFabio Estevam  *
6e2d282a1SFabio Estevam  * This program is free software; you can redistribute it and/or
7e2d282a1SFabio Estevam  * modify it under the terms of the GNU General Public License as
8e2d282a1SFabio Estevam  * published by the Free Software Foundation; either version 2 of
9e2d282a1SFabio Estevam  * the License, or (at your option) any later version.
10e2d282a1SFabio Estevam  */
11e2d282a1SFabio Estevam 
12e2d282a1SFabio Estevam #ifndef __CONFIG_H
13e2d282a1SFabio Estevam #define __CONFIG_H
14e2d282a1SFabio Estevam 
15e2d282a1SFabio Estevam #include <asm/arch/imx-regs.h>
16e2d282a1SFabio Estevam #include <asm/imx-common/gpio.h>
17e2d282a1SFabio Estevam #include <asm/sizes.h>
18e2d282a1SFabio Estevam 
19e2d282a1SFabio Estevam #define CONFIG_MX6
20e2d282a1SFabio Estevam #define CONFIG_DISPLAY_CPUINFO
21e2d282a1SFabio Estevam #define CONFIG_DISPLAY_BOARDINFO
22e2d282a1SFabio Estevam 
23e2d282a1SFabio Estevam #define MACH_TYPE_WANDBOARD		4412
24e2d282a1SFabio Estevam #define CONFIG_MACH_TYPE		MACH_TYPE_WANDBOARD
25e2d282a1SFabio Estevam 
26e2d282a1SFabio Estevam #define CONFIG_CMDLINE_TAG
27e2d282a1SFabio Estevam #define CONFIG_SETUP_MEMORY_TAGS
28e2d282a1SFabio Estevam #define CONFIG_INITRD_TAG
29e2d282a1SFabio Estevam #define CONFIG_REVISION_TAG
30e2d282a1SFabio 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 
61e2d282a1SFabio Estevam /* MMC Configuration */
62e2d282a1SFabio Estevam #define CONFIG_FSL_ESDHC
63e2d282a1SFabio Estevam #define CONFIG_FSL_USDHC
645ed15738SOtavio Salvador #define CONFIG_SYS_FSL_USDHC_NUM	2
65e2d282a1SFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	0
66e2d282a1SFabio Estevam 
67e2d282a1SFabio Estevam #define CONFIG_MMC
68e2d282a1SFabio Estevam #define CONFIG_CMD_MMC
69e2d282a1SFabio Estevam #define CONFIG_GENERIC_MMC
70e2d282a1SFabio Estevam #define CONFIG_BOUNCE_BUFFER
71e2d282a1SFabio Estevam #define CONFIG_CMD_EXT2
72e2d282a1SFabio Estevam #define CONFIG_CMD_FAT
73e2d282a1SFabio Estevam #define CONFIG_DOS_PARTITION
74e2d282a1SFabio Estevam 
75e2d282a1SFabio Estevam /* Ethernet Configuration */
76e2d282a1SFabio Estevam #define CONFIG_CMD_PING
77e2d282a1SFabio Estevam #define CONFIG_CMD_DHCP
78e2d282a1SFabio Estevam #define CONFIG_CMD_MII
79e2d282a1SFabio Estevam #define CONFIG_CMD_NET
80e2d282a1SFabio Estevam #define CONFIG_FEC_MXC
81e2d282a1SFabio Estevam #define CONFIG_MII
82e2d282a1SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
83e2d282a1SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RGMII
84e2d282a1SFabio Estevam #define CONFIG_ETHPRIME			"FEC"
85e2d282a1SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		1
86e2d282a1SFabio Estevam #define CONFIG_PHYLIB
87e2d282a1SFabio Estevam #define CONFIG_PHY_ATHEROS
88e2d282a1SFabio Estevam 
897bcb983fSFabio Estevam /* Framebuffer */
907bcb983fSFabio Estevam #define CONFIG_VIDEO
917bcb983fSFabio Estevam #define CONFIG_VIDEO_IPUV3
927bcb983fSFabio Estevam #define CONFIG_CFB_CONSOLE
937bcb983fSFabio Estevam #define CONFIG_VGA_AS_SINGLE_DEVICE
947bcb983fSFabio Estevam #define CONFIG_SYS_CONSOLE_IS_IN_ENV
957bcb983fSFabio Estevam #define CONFIG_SYS_CONSOLE_OVERWRITE_ROUTINE
967bcb983fSFabio Estevam #define CONFIG_VIDEO_BMP_RLE8
977bcb983fSFabio Estevam #define CONFIG_SPLASH_SCREEN
98a7efb026SOtavio Salvador #define CONFIG_SPLASH_SCREEN_ALIGN
997bcb983fSFabio Estevam #define CONFIG_BMP_16BPP
1007bcb983fSFabio Estevam #define CONFIG_VIDEO_LOGO
101a7efb026SOtavio Salvador #define CONFIG_VIDEO_BMP_LOGO
1027bcb983fSFabio Estevam #define CONFIG_IPUV3_CLK 260000000
1037bcb983fSFabio Estevam 
104e2d282a1SFabio Estevam #if defined(CONFIG_MX6DL)
105e2d282a1SFabio Estevam #define CONFIG_DEFAULT_FDT_FILE		"imx6dl-wandboard.dtb"
106491f2947STapani Utriainen #elif defined(CONFIG_MX6Q)
107491f2947STapani Utriainen #define CONFIG_DEFAULT_FDT_FILE		"imx6q-wandboard.dtb"
108e2d282a1SFabio Estevam #elif defined(CONFIG_MX6S)
109e2d282a1SFabio Estevam #define CONFIG_DEFAULT_FDT_FILE		"imx6s-wandboard.dtb"
110e2d282a1SFabio Estevam #endif
111e2d282a1SFabio Estevam 
112e2d282a1SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
113e2d282a1SFabio Estevam 	"script=boot.scr\0" \
114e2d282a1SFabio Estevam 	"uimage=uImage\0" \
115e2d282a1SFabio Estevam 	"console=ttymxc0\0" \
116e2d282a1SFabio Estevam 	"fdt_high=0xffffffff\0" \
117e2d282a1SFabio Estevam 	"initrd_high=0xffffffff\0" \
118e2d282a1SFabio Estevam 	"fdt_file=" CONFIG_DEFAULT_FDT_FILE "\0" \
119e2d282a1SFabio Estevam 	"fdt_addr=0x11000000\0" \
120e2d282a1SFabio Estevam 	"boot_fdt=try\0" \
121e2d282a1SFabio Estevam 	"ip_dyn=yes\0" \
1221e1cbde0SOtavio Salvador 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
123*86812c4dSOtavio Salvador 	"mmcpart=1\0" \
124*86812c4dSOtavio Salvador 	"mmcroot=/dev/mmcblk0p2 rootwait rw\0" \
1250798d578SOtavio Salvador 	"update_sd_firmware_filename=u-boot.imx\0" \
1260798d578SOtavio Salvador 	"update_sd_firmware=" \
1270798d578SOtavio Salvador 		"if test ${ip_dyn} = yes; then " \
1280798d578SOtavio Salvador 			"setenv get_cmd dhcp; " \
1290798d578SOtavio Salvador 		"else " \
1300798d578SOtavio Salvador 			"setenv get_cmd tftp; " \
1310798d578SOtavio Salvador 		"fi; " \
1320798d578SOtavio Salvador 		"if mmc dev ${mmcdev}; then "	\
1330798d578SOtavio Salvador 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
1340798d578SOtavio Salvador 				"setexpr fw_sz ${filesize} / 0x200; " \
1350798d578SOtavio Salvador 				"setexpr fw_sz ${fw_sz} + 1; "	\
1360798d578SOtavio Salvador 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
1370798d578SOtavio Salvador 			"fi; "	\
1380798d578SOtavio Salvador 		"fi\0" \
139e2d282a1SFabio Estevam 	"mmcargs=setenv bootargs console=${console},${baudrate} " \
140e2d282a1SFabio Estevam 		"root=${mmcroot}\0" \
141e2d282a1SFabio Estevam 	"loadbootscript=" \
142e2d282a1SFabio Estevam 		"fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
143e2d282a1SFabio Estevam 	"bootscript=echo Running bootscript from mmc ...; " \
144e2d282a1SFabio Estevam 		"source\0" \
145e2d282a1SFabio Estevam 	"loaduimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${uimage}\0" \
146e2d282a1SFabio Estevam 	"loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
147e2d282a1SFabio Estevam 	"mmcboot=echo Booting from mmc ...; " \
148e2d282a1SFabio Estevam 		"run mmcargs; " \
149e2d282a1SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
150e2d282a1SFabio Estevam 			"if run loadfdt; then " \
151e2d282a1SFabio Estevam 				"bootm ${loadaddr} - ${fdt_addr}; " \
152e2d282a1SFabio Estevam 			"else " \
153e2d282a1SFabio Estevam 				"if test ${boot_fdt} = try; then " \
154e2d282a1SFabio Estevam 					"bootm; " \
155e2d282a1SFabio Estevam 				"else " \
156e2d282a1SFabio Estevam 					"echo WARN: Cannot load the DT; " \
157e2d282a1SFabio Estevam 				"fi; " \
158e2d282a1SFabio Estevam 			"fi; " \
159e2d282a1SFabio Estevam 		"else " \
160e2d282a1SFabio Estevam 			"bootm; " \
161e2d282a1SFabio Estevam 		"fi;\0" \
162e2d282a1SFabio Estevam 	"netargs=setenv bootargs console=${console},${baudrate} " \
163e2d282a1SFabio Estevam 		"root=/dev/nfs " \
164e2d282a1SFabio Estevam 	"ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
165e2d282a1SFabio Estevam 		"netboot=echo Booting from net ...; " \
166e2d282a1SFabio Estevam 		"run netargs; " \
167e2d282a1SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
168e2d282a1SFabio Estevam 			"setenv get_cmd dhcp; " \
169e2d282a1SFabio Estevam 		"else " \
170e2d282a1SFabio Estevam 			"setenv get_cmd tftp; " \
171e2d282a1SFabio Estevam 		"fi; " \
172e2d282a1SFabio Estevam 		"${get_cmd} ${uimage}; " \
173e2d282a1SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
174e2d282a1SFabio Estevam 			"if ${get_cmd} ${fdt_addr} ${fdt_file}; then " \
175e2d282a1SFabio Estevam 				"bootm ${loadaddr} - ${fdt_addr}; " \
176e2d282a1SFabio Estevam 			"else " \
177e2d282a1SFabio Estevam 				"if test ${boot_fdt} = try; then " \
178e2d282a1SFabio Estevam 					"bootm; " \
179e2d282a1SFabio Estevam 				"else " \
180e2d282a1SFabio Estevam 					"echo WARN: Cannot load the DT; " \
181e2d282a1SFabio Estevam 				"fi; " \
182e2d282a1SFabio Estevam 			"fi; " \
183e2d282a1SFabio Estevam 		"else " \
184e2d282a1SFabio Estevam 			"bootm; " \
185e2d282a1SFabio Estevam 		"fi;\0"
186e2d282a1SFabio Estevam 
187e2d282a1SFabio Estevam #define CONFIG_BOOTCOMMAND \
188e2d282a1SFabio Estevam 	   "mmc dev ${mmcdev}; if mmc rescan; then " \
189e2d282a1SFabio Estevam 		   "if run loadbootscript; then " \
190e2d282a1SFabio Estevam 			   "run bootscript; " \
191e2d282a1SFabio Estevam 		   "else " \
192e2d282a1SFabio Estevam 			   "if run loaduimage; then " \
193e2d282a1SFabio Estevam 				   "run mmcboot; " \
194e2d282a1SFabio Estevam 			   "else run netboot; " \
195e2d282a1SFabio Estevam 			   "fi; " \
196e2d282a1SFabio Estevam 		   "fi; " \
197e2d282a1SFabio Estevam 	   "else run netboot; fi"
198e2d282a1SFabio Estevam 
199e2d282a1SFabio Estevam /* Miscellaneous configurable options */
200e2d282a1SFabio Estevam #define CONFIG_SYS_LONGHELP
201e2d282a1SFabio Estevam #define CONFIG_SYS_HUSH_PARSER
202e2d282a1SFabio Estevam #define CONFIG_SYS_PROMPT	       "=> "
203e2d282a1SFabio Estevam #define CONFIG_AUTO_COMPLETE
204e2d282a1SFabio Estevam #define CONFIG_SYS_CBSIZE		256
205e2d282a1SFabio Estevam 
206e2d282a1SFabio Estevam /* Print Buffer Size */
207e2d282a1SFabio Estevam #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
208e2d282a1SFabio Estevam #define CONFIG_SYS_MAXARGS	       16
209e2d282a1SFabio Estevam #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
210e2d282a1SFabio Estevam 
211e2d282a1SFabio Estevam #define CONFIG_SYS_LOAD_ADDR		CONFIG_LOADADDR
212e2d282a1SFabio Estevam #define CONFIG_SYS_HZ			1000
213e2d282a1SFabio Estevam 
214e2d282a1SFabio Estevam #define CONFIG_CMDLINE_EDITING
215e2d282a1SFabio Estevam 
216e2d282a1SFabio Estevam /* Physical Memory Map */
217e2d282a1SFabio Estevam #define CONFIG_NR_DRAM_BANKS		1
218e2d282a1SFabio Estevam #define PHYS_SDRAM			MMDC0_ARB_BASE_ADDR
219e2d282a1SFabio Estevam 
220e2d282a1SFabio Estevam #define CONFIG_SYS_SDRAM_BASE		PHYS_SDRAM
221e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR	IRAM_BASE_ADDR
222e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE	IRAM_SIZE
223e2d282a1SFabio Estevam 
224e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
225e2d282a1SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
226e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
227e2d282a1SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
228e2d282a1SFabio Estevam 
229e2d282a1SFabio Estevam /* FLASH and environment organization */
230e2d282a1SFabio Estevam #define CONFIG_SYS_NO_FLASH
231e2d282a1SFabio Estevam 
232e2d282a1SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
233e2d282a1SFabio Estevam 
234e2d282a1SFabio Estevam #define CONFIG_ENV_IS_IN_MMC
235e2d282a1SFabio Estevam #define CONFIG_ENV_OFFSET		(6 * 64 * 1024)
236e2d282a1SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0
237e2d282a1SFabio Estevam 
238e2d282a1SFabio Estevam #define CONFIG_OF_LIBFDT
239e2d282a1SFabio Estevam #define CONFIG_CMD_BOOTZ
240e2d282a1SFabio Estevam 
241e2d282a1SFabio Estevam #ifndef CONFIG_SYS_DCACHE_OFF
242e2d282a1SFabio Estevam #define CONFIG_CMD_CACHE
243e2d282a1SFabio Estevam #endif
244e2d282a1SFabio Estevam 
245e2d282a1SFabio Estevam #endif			       /* __CONFIG_H * */
246