xref: /rk3399_rockchip-uboot/include/configs/mx53smd.h (revision de6f604de245b19ce2e330bc63b6522af134d7ae)
1860b32eeSFabio Estevam /*
2860b32eeSFabio Estevam  * Copyright (C) 2011 Freescale Semiconductor, Inc.
3860b32eeSFabio Estevam  *
4c4c596fbSFabio Estevam  * Configuration settings for the MX53SMD Freescale board.
5860b32eeSFabio Estevam  *
6860b32eeSFabio Estevam  * This program is free software; you can redistribute it and/or
7860b32eeSFabio Estevam  * modify it under the terms of the GNU General Public License as
8860b32eeSFabio Estevam  * published by the Free Software Foundation; either version 2 of
9860b32eeSFabio Estevam  * the License, or (at your option) any later version.
10860b32eeSFabio Estevam  *
11860b32eeSFabio Estevam  * This program is distributed in the hope that it will be useful,
12860b32eeSFabio Estevam  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13860b32eeSFabio Estevam  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	 See the
14860b32eeSFabio Estevam  * GNU General Public License for more details.
15860b32eeSFabio Estevam  *
16860b32eeSFabio Estevam  * You should have received a copy of the GNU General Public License
17860b32eeSFabio Estevam  * along with this program; if not, write to the Free Software
18860b32eeSFabio Estevam  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
19860b32eeSFabio Estevam  * MA 02111-1307 USA
20860b32eeSFabio Estevam  */
21860b32eeSFabio Estevam 
22860b32eeSFabio Estevam #ifndef __CONFIG_H
23860b32eeSFabio Estevam #define __CONFIG_H
24860b32eeSFabio Estevam 
25860b32eeSFabio Estevam #define CONFIG_MX53
26860b32eeSFabio Estevam 
27860b32eeSFabio Estevam #define CONFIG_SYS_MX5_HCLK	24000000
28860b32eeSFabio Estevam #define CONFIG_SYS_MX5_CLK32		32768
29860b32eeSFabio Estevam #define CONFIG_DISPLAY_CPUINFO
30860b32eeSFabio Estevam #define CONFIG_DISPLAY_BOARDINFO
31860b32eeSFabio Estevam 
32c4c596fbSFabio Estevam #define CONFIG_MACH_TYPE	MACH_TYPE_MX53_SMD
33c4c596fbSFabio Estevam 
34860b32eeSFabio Estevam #include <asm/arch/imx-regs.h>
35860b32eeSFabio Estevam 
36860b32eeSFabio Estevam #define CONFIG_CMDLINE_TAG			/* enable passing of ATAGs */
37860b32eeSFabio Estevam #define CONFIG_SETUP_MEMORY_TAGS
38860b32eeSFabio Estevam #define CONFIG_INITRD_TAG
39860b32eeSFabio Estevam 
40860b32eeSFabio Estevam /* Size of malloc() pool */
41860b32eeSFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(CONFIG_ENV_SIZE + 2 * 1024 * 1024)
42860b32eeSFabio Estevam 
43860b32eeSFabio Estevam #define CONFIG_BOARD_EARLY_INIT_F
44860b32eeSFabio Estevam #define CONFIG_MXC_GPIO
45860b32eeSFabio Estevam 
46860b32eeSFabio Estevam #define CONFIG_MXC_UART
4740f6fffeSStefano Babic #define CONFIG_MXC_UART_BASE	UART1_BASE
48860b32eeSFabio Estevam 
49860b32eeSFabio Estevam /* I2C Configs */
50860b32eeSFabio Estevam #define CONFIG_CMD_I2C
51860b32eeSFabio Estevam #define CONFIG_HARD_I2C
52860b32eeSFabio Estevam #define CONFIG_I2C_MXC
53*de6f604dSTroy Kisky #define CONFIG_SYS_I2C_BASE		I2C2_BASE_ADDR
54860b32eeSFabio Estevam #define CONFIG_SYS_I2C_SPEED            100000
55860b32eeSFabio Estevam 
56860b32eeSFabio Estevam /* MMC Configs */
57860b32eeSFabio Estevam #define CONFIG_FSL_ESDHC
58860b32eeSFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	0
59860b32eeSFabio Estevam #define CONFIG_SYS_FSL_ESDHC_NUM	1
60860b32eeSFabio Estevam 
61860b32eeSFabio Estevam #define CONFIG_MMC
62860b32eeSFabio Estevam #define CONFIG_CMD_MMC
63860b32eeSFabio Estevam #define CONFIG_GENERIC_MMC
64860b32eeSFabio Estevam #define CONFIG_CMD_FAT
65860b32eeSFabio Estevam #define CONFIG_DOS_PARTITION
66860b32eeSFabio Estevam 
67860b32eeSFabio Estevam /* Eth Configs */
68860b32eeSFabio Estevam #define CONFIG_HAS_ETH1
69860b32eeSFabio Estevam #define CONFIG_MII
70860b32eeSFabio Estevam #define CONFIG_DISCOVER_PHY
71860b32eeSFabio Estevam 
72860b32eeSFabio Estevam #define CONFIG_FEC_MXC
73860b32eeSFabio Estevam #define IMX_FEC_BASE	FEC_BASE_ADDR
74860b32eeSFabio Estevam #define CONFIG_FEC_MXC_PHYADDR	0x1F
75860b32eeSFabio Estevam 
76860b32eeSFabio Estevam #define CONFIG_CMD_PING
77860b32eeSFabio Estevam #define CONFIG_CMD_DHCP
78860b32eeSFabio Estevam #define CONFIG_CMD_MII
79860b32eeSFabio Estevam #define CONFIG_CMD_NET
80860b32eeSFabio Estevam 
81860b32eeSFabio Estevam /* allow to overwrite serial and ethaddr */
82860b32eeSFabio Estevam #define CONFIG_ENV_OVERWRITE
83860b32eeSFabio Estevam #define CONFIG_CONS_INDEX		1
84860b32eeSFabio Estevam #define CONFIG_BAUDRATE			115200
85860b32eeSFabio Estevam 
86860b32eeSFabio Estevam /* Command definition */
87860b32eeSFabio Estevam #include <config_cmd_default.h>
88860b32eeSFabio Estevam 
89860b32eeSFabio Estevam #undef CONFIG_CMD_IMLS
90860b32eeSFabio Estevam 
91860b32eeSFabio Estevam #define CONFIG_BOOTDELAY	3
92860b32eeSFabio Estevam 
9328b119e9SWolfgang Grandegger #define CONFIG_ETHPRIME		"FEC0"
94860b32eeSFabio Estevam 
95860b32eeSFabio Estevam #define CONFIG_LOADADDR		0x70800000	/* loadaddr env var */
96860b32eeSFabio Estevam #define CONFIG_SYS_TEXT_BASE    0x77800000
97860b32eeSFabio Estevam 
98860b32eeSFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
99860b32eeSFabio Estevam 	"script=boot.scr\0" \
100860b32eeSFabio Estevam 	"uimage=uImage\0" \
101860b32eeSFabio Estevam 	"mmcdev=0\0" \
102860b32eeSFabio Estevam 	"mmcpart=2\0" \
103860b32eeSFabio Estevam 	"mmcroot=/dev/mmcblk0p3 rw\0" \
104860b32eeSFabio Estevam 	"mmcrootfstype=ext3 rootwait\0" \
105860b32eeSFabio Estevam 	"mmcargs=setenv bootargs console=ttymxc0,${baudrate} " \
106860b32eeSFabio Estevam 		"root=${mmcroot} " \
107860b32eeSFabio Estevam 		"rootfstype=${mmcrootfstype}\0" \
108860b32eeSFabio Estevam 	"loadbootscript=" \
109860b32eeSFabio Estevam 		"fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
110860b32eeSFabio Estevam 	"bootscript=echo Running bootscript from mmc ...; " \
111860b32eeSFabio Estevam 		"source\0" \
112860b32eeSFabio Estevam 	"loaduimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${uimage}\0" \
113860b32eeSFabio Estevam 	"mmcboot=echo Booting from mmc ...; " \
114860b32eeSFabio Estevam 		"run mmcargs; " \
115860b32eeSFabio Estevam 		"bootm\0" \
116860b32eeSFabio Estevam 	"netargs=setenv bootargs console=ttymxc0,${baudrate} " \
117860b32eeSFabio Estevam 		"root=/dev/nfs " \
118860b32eeSFabio Estevam 		"ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
119860b32eeSFabio Estevam 	"netboot=echo Booting from net ...; " \
120860b32eeSFabio Estevam 		"run netargs; " \
121860b32eeSFabio Estevam 		"dhcp ${uimage}; bootm\0" \
122860b32eeSFabio Estevam 
123860b32eeSFabio Estevam #define CONFIG_BOOTCOMMAND \
124860b32eeSFabio Estevam 	"if mmc rescan ${mmcdev}; then " \
125860b32eeSFabio Estevam 		"if run loadbootscript; then " \
126860b32eeSFabio Estevam 			"run bootscript; " \
127860b32eeSFabio Estevam 		"else " \
128860b32eeSFabio Estevam 			"if run loaduimage; then " \
129860b32eeSFabio Estevam 				"run mmcboot; " \
130860b32eeSFabio Estevam 			"else run netboot; " \
131860b32eeSFabio Estevam 			"fi; " \
132860b32eeSFabio Estevam 		"fi; " \
133860b32eeSFabio Estevam 	"else run netboot; fi"
134860b32eeSFabio Estevam #define CONFIG_ARP_TIMEOUT	200UL
135860b32eeSFabio Estevam 
136860b32eeSFabio Estevam /* Miscellaneous configurable options */
137860b32eeSFabio Estevam #define CONFIG_SYS_LONGHELP		/* undef to save memory */
138860b32eeSFabio Estevam #define CONFIG_SYS_HUSH_PARSER		/* use "hush" command parser */
139860b32eeSFabio Estevam #define CONFIG_SYS_PROMPT		"MX53SMD U-Boot > "
140860b32eeSFabio Estevam #define CONFIG_AUTO_COMPLETE
141860b32eeSFabio Estevam #define CONFIG_SYS_CBSIZE		256	/* Console I/O Buffer Size */
142860b32eeSFabio Estevam 
143860b32eeSFabio Estevam /* Print Buffer Size */
144860b32eeSFabio Estevam #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
145860b32eeSFabio Estevam #define CONFIG_SYS_MAXARGS	16	/* max number of command args */
146860b32eeSFabio Estevam #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE /* Boot Argument Buffer Size */
147860b32eeSFabio Estevam 
148860b32eeSFabio Estevam #define CONFIG_SYS_MEMTEST_START       0x70000000
149869aed7bSFabio Estevam #define CONFIG_SYS_MEMTEST_END         0x70010000
150860b32eeSFabio Estevam 
151860b32eeSFabio Estevam #define CONFIG_SYS_LOAD_ADDR		CONFIG_LOADADDR
152860b32eeSFabio Estevam 
153860b32eeSFabio Estevam #define CONFIG_SYS_HZ		1000
154860b32eeSFabio Estevam #define CONFIG_CMDLINE_EDITING
155860b32eeSFabio Estevam 
156860b32eeSFabio Estevam /* Stack sizes */
157860b32eeSFabio Estevam #define CONFIG_STACKSIZE	(128 * 1024)	/* regular stack */
158860b32eeSFabio Estevam 
159860b32eeSFabio Estevam /* Physical Memory Map */
160860b32eeSFabio Estevam #define CONFIG_NR_DRAM_BANKS	2
161860b32eeSFabio Estevam #define PHYS_SDRAM_1		CSD0_BASE_ADDR
162860b32eeSFabio Estevam #define PHYS_SDRAM_1_SIZE	(512 * 1024 * 1024)
163860b32eeSFabio Estevam #define PHYS_SDRAM_2		CSD1_BASE_ADDR
164860b32eeSFabio Estevam #define PHYS_SDRAM_2_SIZE	(512 * 1024 * 1024)
165860b32eeSFabio Estevam #define PHYS_SDRAM_SIZE         (PHYS_SDRAM_1_SIZE + PHYS_SDRAM_2_SIZE)
166860b32eeSFabio Estevam 
167860b32eeSFabio Estevam #define CONFIG_SYS_SDRAM_BASE		(PHYS_SDRAM_1)
168860b32eeSFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR	(IRAM_BASE_ADDR)
169860b32eeSFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE	(IRAM_SIZE)
170860b32eeSFabio Estevam 
171860b32eeSFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
172860b32eeSFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
173860b32eeSFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
174860b32eeSFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
175860b32eeSFabio Estevam 
176860b32eeSFabio Estevam /* FLASH and environment organization */
177860b32eeSFabio Estevam #define CONFIG_SYS_NO_FLASH
178860b32eeSFabio Estevam 
179860b32eeSFabio Estevam #define CONFIG_ENV_OFFSET      (6 * 64 * 1024)
180860b32eeSFabio Estevam #define CONFIG_ENV_SIZE        (8 * 1024)
181860b32eeSFabio Estevam #define CONFIG_ENV_IS_IN_MMC
182860b32eeSFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV 0
183860b32eeSFabio Estevam 
184860b32eeSFabio Estevam #define CONFIG_OF_LIBFDT
185860b32eeSFabio Estevam 
186860b32eeSFabio Estevam #endif				/* __CONFIG_H */
187