xref: /rk3399_rockchip-uboot/include/configs/wandboard.h (revision 7bcb983feb8296f58a651c2b2a48683fc27174cd)
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 */
32*7bcb983fSFabio 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 
89*7bcb983fSFabio Estevam /* Framebuffer */
90*7bcb983fSFabio Estevam #define CONFIG_VIDEO
91*7bcb983fSFabio Estevam #define CONFIG_VIDEO_IPUV3
92*7bcb983fSFabio Estevam #define CONFIG_CFB_CONSOLE
93*7bcb983fSFabio Estevam #define CONFIG_VGA_AS_SINGLE_DEVICE
94*7bcb983fSFabio Estevam #define CONFIG_SYS_CONSOLE_IS_IN_ENV
95*7bcb983fSFabio Estevam #define CONFIG_SYS_CONSOLE_OVERWRITE_ROUTINE
96*7bcb983fSFabio Estevam #define CONFIG_VIDEO_BMP_RLE8
97*7bcb983fSFabio Estevam #define CONFIG_SPLASH_SCREEN
98*7bcb983fSFabio Estevam #define CONFIG_BMP_16BPP
99*7bcb983fSFabio Estevam #define CONFIG_VIDEO_LOGO
100*7bcb983fSFabio Estevam #define CONFIG_IPUV3_CLK 260000000
101*7bcb983fSFabio Estevam 
102e2d282a1SFabio Estevam #if defined(CONFIG_MX6DL)
103e2d282a1SFabio Estevam #define CONFIG_DEFAULT_FDT_FILE		"imx6dl-wandboard.dtb"
104e2d282a1SFabio Estevam #elif defined(CONFIG_MX6S)
105e2d282a1SFabio Estevam #define CONFIG_DEFAULT_FDT_FILE		"imx6s-wandboard.dtb"
106e2d282a1SFabio Estevam #endif
107e2d282a1SFabio Estevam 
108e2d282a1SFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
109e2d282a1SFabio Estevam 	"script=boot.scr\0" \
110e2d282a1SFabio Estevam 	"uimage=uImage\0" \
111e2d282a1SFabio Estevam 	"console=ttymxc0\0" \
112e2d282a1SFabio Estevam 	"fdt_high=0xffffffff\0" \
113e2d282a1SFabio Estevam 	"initrd_high=0xffffffff\0" \
114e2d282a1SFabio Estevam 	"fdt_file=" CONFIG_DEFAULT_FDT_FILE "\0" \
115e2d282a1SFabio Estevam 	"fdt_addr=0x11000000\0" \
116e2d282a1SFabio Estevam 	"boot_fdt=try\0" \
117e2d282a1SFabio Estevam 	"ip_dyn=yes\0" \
1181e1cbde0SOtavio Salvador 	"mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
1191e1cbde0SOtavio Salvador 	"mmcpart=" __stringify(CONFIG_SYS_MMC_ENV_PART) "\0" \
120e2d282a1SFabio Estevam 	"mmcroot=/dev/mmcblk0p3 rootwait rw\0" \
1210798d578SOtavio Salvador 	"update_sd_firmware_filename=u-boot.imx\0" \
1220798d578SOtavio Salvador 	"update_sd_firmware=" \
1230798d578SOtavio Salvador 		"if test ${ip_dyn} = yes; then " \
1240798d578SOtavio Salvador 			"setenv get_cmd dhcp; " \
1250798d578SOtavio Salvador 		"else " \
1260798d578SOtavio Salvador 			"setenv get_cmd tftp; " \
1270798d578SOtavio Salvador 		"fi; " \
1280798d578SOtavio Salvador 		"if mmc dev ${mmcdev}; then "	\
1290798d578SOtavio Salvador 			"if ${get_cmd} ${update_sd_firmware_filename}; then " \
1300798d578SOtavio Salvador 				"setexpr fw_sz ${filesize} / 0x200; " \
1310798d578SOtavio Salvador 				"setexpr fw_sz ${fw_sz} + 1; "	\
1320798d578SOtavio Salvador 				"mmc write ${loadaddr} 0x2 ${fw_sz}; " \
1330798d578SOtavio Salvador 			"fi; "	\
1340798d578SOtavio Salvador 		"fi\0" \
135e2d282a1SFabio Estevam 	"mmcargs=setenv bootargs console=${console},${baudrate} " \
136e2d282a1SFabio Estevam 		"root=${mmcroot}\0" \
137e2d282a1SFabio Estevam 	"loadbootscript=" \
138e2d282a1SFabio Estevam 		"fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
139e2d282a1SFabio Estevam 	"bootscript=echo Running bootscript from mmc ...; " \
140e2d282a1SFabio Estevam 		"source\0" \
141e2d282a1SFabio Estevam 	"loaduimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${uimage}\0" \
142e2d282a1SFabio Estevam 	"loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
143e2d282a1SFabio Estevam 	"mmcboot=echo Booting from mmc ...; " \
144e2d282a1SFabio Estevam 		"run mmcargs; " \
145e2d282a1SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
146e2d282a1SFabio Estevam 			"if run loadfdt; then " \
147e2d282a1SFabio Estevam 				"bootm ${loadaddr} - ${fdt_addr}; " \
148e2d282a1SFabio Estevam 			"else " \
149e2d282a1SFabio Estevam 				"if test ${boot_fdt} = try; then " \
150e2d282a1SFabio Estevam 					"bootm; " \
151e2d282a1SFabio Estevam 				"else " \
152e2d282a1SFabio Estevam 					"echo WARN: Cannot load the DT; " \
153e2d282a1SFabio Estevam 				"fi; " \
154e2d282a1SFabio Estevam 			"fi; " \
155e2d282a1SFabio Estevam 		"else " \
156e2d282a1SFabio Estevam 			"bootm; " \
157e2d282a1SFabio Estevam 		"fi;\0" \
158e2d282a1SFabio Estevam 	"netargs=setenv bootargs console=${console},${baudrate} " \
159e2d282a1SFabio Estevam 		"root=/dev/nfs " \
160e2d282a1SFabio Estevam 	"ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
161e2d282a1SFabio Estevam 		"netboot=echo Booting from net ...; " \
162e2d282a1SFabio Estevam 		"run netargs; " \
163e2d282a1SFabio Estevam 		"if test ${ip_dyn} = yes; then " \
164e2d282a1SFabio Estevam 			"setenv get_cmd dhcp; " \
165e2d282a1SFabio Estevam 		"else " \
166e2d282a1SFabio Estevam 			"setenv get_cmd tftp; " \
167e2d282a1SFabio Estevam 		"fi; " \
168e2d282a1SFabio Estevam 		"${get_cmd} ${uimage}; " \
169e2d282a1SFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
170e2d282a1SFabio Estevam 			"if ${get_cmd} ${fdt_addr} ${fdt_file}; then " \
171e2d282a1SFabio Estevam 				"bootm ${loadaddr} - ${fdt_addr}; " \
172e2d282a1SFabio Estevam 			"else " \
173e2d282a1SFabio Estevam 				"if test ${boot_fdt} = try; then " \
174e2d282a1SFabio Estevam 					"bootm; " \
175e2d282a1SFabio Estevam 				"else " \
176e2d282a1SFabio Estevam 					"echo WARN: Cannot load the DT; " \
177e2d282a1SFabio Estevam 				"fi; " \
178e2d282a1SFabio Estevam 			"fi; " \
179e2d282a1SFabio Estevam 		"else " \
180e2d282a1SFabio Estevam 			"bootm; " \
181e2d282a1SFabio Estevam 		"fi;\0"
182e2d282a1SFabio Estevam 
183e2d282a1SFabio Estevam #define CONFIG_BOOTCOMMAND \
184e2d282a1SFabio Estevam 	   "mmc dev ${mmcdev}; if mmc rescan; then " \
185e2d282a1SFabio Estevam 		   "if run loadbootscript; then " \
186e2d282a1SFabio Estevam 			   "run bootscript; " \
187e2d282a1SFabio Estevam 		   "else " \
188e2d282a1SFabio Estevam 			   "if run loaduimage; then " \
189e2d282a1SFabio Estevam 				   "run mmcboot; " \
190e2d282a1SFabio Estevam 			   "else run netboot; " \
191e2d282a1SFabio Estevam 			   "fi; " \
192e2d282a1SFabio Estevam 		   "fi; " \
193e2d282a1SFabio Estevam 	   "else run netboot; fi"
194e2d282a1SFabio Estevam 
195e2d282a1SFabio Estevam /* Miscellaneous configurable options */
196e2d282a1SFabio Estevam #define CONFIG_SYS_LONGHELP
197e2d282a1SFabio Estevam #define CONFIG_SYS_HUSH_PARSER
198e2d282a1SFabio Estevam #define CONFIG_SYS_PROMPT	       "=> "
199e2d282a1SFabio Estevam #define CONFIG_AUTO_COMPLETE
200e2d282a1SFabio Estevam #define CONFIG_SYS_CBSIZE		256
201e2d282a1SFabio Estevam 
202e2d282a1SFabio Estevam /* Print Buffer Size */
203e2d282a1SFabio Estevam #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
204e2d282a1SFabio Estevam #define CONFIG_SYS_MAXARGS	       16
205e2d282a1SFabio Estevam #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
206e2d282a1SFabio Estevam 
207e2d282a1SFabio Estevam #define CONFIG_SYS_LOAD_ADDR		CONFIG_LOADADDR
208e2d282a1SFabio Estevam #define CONFIG_SYS_HZ			1000
209e2d282a1SFabio Estevam 
210e2d282a1SFabio Estevam #define CONFIG_CMDLINE_EDITING
211e2d282a1SFabio Estevam 
212e2d282a1SFabio Estevam /* Physical Memory Map */
213e2d282a1SFabio Estevam #define CONFIG_NR_DRAM_BANKS		1
214e2d282a1SFabio Estevam #define PHYS_SDRAM			MMDC0_ARB_BASE_ADDR
215e2d282a1SFabio Estevam 
216e2d282a1SFabio Estevam #define CONFIG_SYS_SDRAM_BASE		PHYS_SDRAM
217e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR	IRAM_BASE_ADDR
218e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE	IRAM_SIZE
219e2d282a1SFabio Estevam 
220e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
221e2d282a1SFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
222e2d282a1SFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
223e2d282a1SFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
224e2d282a1SFabio Estevam 
225e2d282a1SFabio Estevam /* FLASH and environment organization */
226e2d282a1SFabio Estevam #define CONFIG_SYS_NO_FLASH
227e2d282a1SFabio Estevam 
228e2d282a1SFabio Estevam #define CONFIG_ENV_SIZE			(8 * 1024)
229e2d282a1SFabio Estevam 
230e2d282a1SFabio Estevam #define CONFIG_ENV_IS_IN_MMC
231e2d282a1SFabio Estevam #define CONFIG_ENV_OFFSET		(6 * 64 * 1024)
232e2d282a1SFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV		0
2331e1cbde0SOtavio Salvador #define CONFIG_SYS_MMC_ENV_PART		2
234e2d282a1SFabio Estevam 
235e2d282a1SFabio Estevam #define CONFIG_OF_LIBFDT
236e2d282a1SFabio Estevam #define CONFIG_CMD_BOOTZ
237e2d282a1SFabio Estevam 
238e2d282a1SFabio Estevam #ifndef CONFIG_SYS_DCACHE_OFF
239e2d282a1SFabio Estevam #define CONFIG_CMD_CACHE
240e2d282a1SFabio Estevam #endif
241e2d282a1SFabio Estevam 
242e2d282a1SFabio Estevam #endif			       /* __CONFIG_H * */
243