xref: /openbmc/u-boot/include/configs/mx53smd.h (revision c4c596fb4653f163eaa704584b02a0adf5df70e8)
1860b32eeSFabio Estevam /*
2860b32eeSFabio Estevam  * Copyright (C) 2011 Freescale Semiconductor, Inc.
3860b32eeSFabio Estevam  *
4*c4c596fbSFabio 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 
32*c4c596fbSFabio Estevam #define CONFIG_MACH_TYPE	MACH_TYPE_MX53_SMD
33*c4c596fbSFabio 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_REVISION_TAG
38860b32eeSFabio Estevam #define CONFIG_SETUP_MEMORY_TAGS
39860b32eeSFabio Estevam #define CONFIG_INITRD_TAG
40860b32eeSFabio Estevam 
41860b32eeSFabio Estevam /* Size of malloc() pool */
42860b32eeSFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(CONFIG_ENV_SIZE + 2 * 1024 * 1024)
43860b32eeSFabio Estevam 
44860b32eeSFabio Estevam #define CONFIG_BOARD_EARLY_INIT_F
45860b32eeSFabio Estevam #define CONFIG_MXC_GPIO
46860b32eeSFabio Estevam 
47860b32eeSFabio Estevam #define CONFIG_MXC_UART
48860b32eeSFabio Estevam #define CONFIG_SYS_MX53_UART1
49860b32eeSFabio Estevam 
50860b32eeSFabio Estevam /* I2C Configs */
51860b32eeSFabio Estevam #define CONFIG_CMD_I2C
52860b32eeSFabio Estevam #define CONFIG_HARD_I2C
53860b32eeSFabio Estevam #define CONFIG_I2C_MXC
54860b32eeSFabio Estevam #define CONFIG_SYS_I2C_MX53_PORT2
55860b32eeSFabio Estevam #define CONFIG_SYS_I2C_SPEED            100000
56860b32eeSFabio Estevam #define CONFIG_SYS_I2C_SLAVE            0xfe
57860b32eeSFabio Estevam 
58860b32eeSFabio Estevam /* MMC Configs */
59860b32eeSFabio Estevam #define CONFIG_FSL_ESDHC
60860b32eeSFabio Estevam #define CONFIG_SYS_FSL_ESDHC_ADDR	0
61860b32eeSFabio Estevam #define CONFIG_SYS_FSL_ESDHC_NUM	1
62860b32eeSFabio Estevam 
63860b32eeSFabio Estevam #define CONFIG_MMC
64860b32eeSFabio Estevam #define CONFIG_CMD_MMC
65860b32eeSFabio Estevam #define CONFIG_GENERIC_MMC
66860b32eeSFabio Estevam #define CONFIG_CMD_FAT
67860b32eeSFabio Estevam #define CONFIG_DOS_PARTITION
68860b32eeSFabio Estevam 
69860b32eeSFabio Estevam /* Eth Configs */
70860b32eeSFabio Estevam #define CONFIG_HAS_ETH1
71860b32eeSFabio Estevam #define CONFIG_NET_MULTI
72860b32eeSFabio Estevam #define CONFIG_MII
73860b32eeSFabio Estevam #define CONFIG_DISCOVER_PHY
74860b32eeSFabio Estevam 
75860b32eeSFabio Estevam #define CONFIG_FEC_MXC
76860b32eeSFabio Estevam #define IMX_FEC_BASE	FEC_BASE_ADDR
77860b32eeSFabio Estevam #define CONFIG_FEC_MXC_PHYADDR	0x1F
78860b32eeSFabio Estevam 
79860b32eeSFabio Estevam #define CONFIG_CMD_PING
80860b32eeSFabio Estevam #define CONFIG_CMD_DHCP
81860b32eeSFabio Estevam #define CONFIG_CMD_MII
82860b32eeSFabio Estevam #define CONFIG_CMD_NET
83860b32eeSFabio Estevam 
84860b32eeSFabio Estevam /* allow to overwrite serial and ethaddr */
85860b32eeSFabio Estevam #define CONFIG_ENV_OVERWRITE
86860b32eeSFabio Estevam #define CONFIG_CONS_INDEX		1
87860b32eeSFabio Estevam #define CONFIG_BAUDRATE			115200
88860b32eeSFabio Estevam #define CONFIG_SYS_BAUDRATE_TABLE	{9600, 19200, 38400, 57600, 115200}
89860b32eeSFabio Estevam 
90860b32eeSFabio Estevam /* Command definition */
91860b32eeSFabio Estevam #include <config_cmd_default.h>
92860b32eeSFabio Estevam 
93860b32eeSFabio Estevam #undef CONFIG_CMD_IMLS
94860b32eeSFabio Estevam 
95860b32eeSFabio Estevam #define CONFIG_BOOTDELAY	3
96860b32eeSFabio Estevam 
97860b32eeSFabio Estevam #define CONFIG_PRIME	"FEC0"
98860b32eeSFabio Estevam 
99860b32eeSFabio Estevam #define CONFIG_LOADADDR		0x70800000	/* loadaddr env var */
100860b32eeSFabio Estevam #define CONFIG_SYS_TEXT_BASE    0x77800000
101860b32eeSFabio Estevam 
102860b32eeSFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
103860b32eeSFabio Estevam 	"script=boot.scr\0" \
104860b32eeSFabio Estevam 	"uimage=uImage\0" \
105860b32eeSFabio Estevam 	"mmcdev=0\0" \
106860b32eeSFabio Estevam 	"mmcpart=2\0" \
107860b32eeSFabio Estevam 	"mmcroot=/dev/mmcblk0p3 rw\0" \
108860b32eeSFabio Estevam 	"mmcrootfstype=ext3 rootwait\0" \
109860b32eeSFabio Estevam 	"mmcargs=setenv bootargs console=ttymxc0,${baudrate} " \
110860b32eeSFabio Estevam 		"root=${mmcroot} " \
111860b32eeSFabio Estevam 		"rootfstype=${mmcrootfstype}\0" \
112860b32eeSFabio Estevam 	"loadbootscript=" \
113860b32eeSFabio Estevam 		"fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
114860b32eeSFabio Estevam 	"bootscript=echo Running bootscript from mmc ...; " \
115860b32eeSFabio Estevam 		"source\0" \
116860b32eeSFabio Estevam 	"loaduimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${uimage}\0" \
117860b32eeSFabio Estevam 	"mmcboot=echo Booting from mmc ...; " \
118860b32eeSFabio Estevam 		"run mmcargs; " \
119860b32eeSFabio Estevam 		"bootm\0" \
120860b32eeSFabio Estevam 	"netargs=setenv bootargs console=ttymxc0,${baudrate} " \
121860b32eeSFabio Estevam 		"root=/dev/nfs " \
122860b32eeSFabio Estevam 		"ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
123860b32eeSFabio Estevam 	"netboot=echo Booting from net ...; " \
124860b32eeSFabio Estevam 		"run netargs; " \
125860b32eeSFabio Estevam 		"dhcp ${uimage}; bootm\0" \
126860b32eeSFabio Estevam 
127860b32eeSFabio Estevam #define CONFIG_BOOTCOMMAND \
128860b32eeSFabio Estevam 	"if mmc rescan ${mmcdev}; then " \
129860b32eeSFabio Estevam 		"if run loadbootscript; then " \
130860b32eeSFabio Estevam 			"run bootscript; " \
131860b32eeSFabio Estevam 		"else " \
132860b32eeSFabio Estevam 			"if run loaduimage; then " \
133860b32eeSFabio Estevam 				"run mmcboot; " \
134860b32eeSFabio Estevam 			"else run netboot; " \
135860b32eeSFabio Estevam 			"fi; " \
136860b32eeSFabio Estevam 		"fi; " \
137860b32eeSFabio Estevam 	"else run netboot; fi"
138860b32eeSFabio Estevam #define CONFIG_ARP_TIMEOUT	200UL
139860b32eeSFabio Estevam 
140860b32eeSFabio Estevam /* Miscellaneous configurable options */
141860b32eeSFabio Estevam #define CONFIG_SYS_LONGHELP		/* undef to save memory */
142860b32eeSFabio Estevam #define CONFIG_SYS_HUSH_PARSER		/* use "hush" command parser */
143860b32eeSFabio Estevam #define CONFIG_SYS_PROMPT_HUSH_PS2	"> "
144860b32eeSFabio Estevam #define CONFIG_SYS_PROMPT		"MX53SMD U-Boot > "
145860b32eeSFabio Estevam #define CONFIG_AUTO_COMPLETE
146860b32eeSFabio Estevam #define CONFIG_SYS_CBSIZE		256	/* Console I/O Buffer Size */
147860b32eeSFabio Estevam 
148860b32eeSFabio Estevam /* Print Buffer Size */
149860b32eeSFabio Estevam #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
150860b32eeSFabio Estevam #define CONFIG_SYS_MAXARGS	16	/* max number of command args */
151860b32eeSFabio Estevam #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE /* Boot Argument Buffer Size */
152860b32eeSFabio Estevam 
153860b32eeSFabio Estevam #define CONFIG_SYS_MEMTEST_START       0x70000000
154860b32eeSFabio Estevam #define CONFIG_SYS_MEMTEST_END         0x10000
155860b32eeSFabio Estevam 
156860b32eeSFabio Estevam #define CONFIG_SYS_LOAD_ADDR		CONFIG_LOADADDR
157860b32eeSFabio Estevam 
158860b32eeSFabio Estevam #define CONFIG_SYS_HZ		1000
159860b32eeSFabio Estevam #define CONFIG_CMDLINE_EDITING
160860b32eeSFabio Estevam 
161860b32eeSFabio Estevam /* Stack sizes */
162860b32eeSFabio Estevam #define CONFIG_STACKSIZE	(128 * 1024)	/* regular stack */
163860b32eeSFabio Estevam 
164860b32eeSFabio Estevam /* Physical Memory Map */
165860b32eeSFabio Estevam #define CONFIG_NR_DRAM_BANKS	2
166860b32eeSFabio Estevam #define PHYS_SDRAM_1		CSD0_BASE_ADDR
167860b32eeSFabio Estevam #define PHYS_SDRAM_1_SIZE	(512 * 1024 * 1024)
168860b32eeSFabio Estevam #define PHYS_SDRAM_2		CSD1_BASE_ADDR
169860b32eeSFabio Estevam #define PHYS_SDRAM_2_SIZE	(512 * 1024 * 1024)
170860b32eeSFabio Estevam #define PHYS_SDRAM_SIZE         (PHYS_SDRAM_1_SIZE + PHYS_SDRAM_2_SIZE)
171860b32eeSFabio Estevam 
172860b32eeSFabio Estevam #define CONFIG_SYS_SDRAM_BASE		(PHYS_SDRAM_1)
173860b32eeSFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR	(IRAM_BASE_ADDR)
174860b32eeSFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE	(IRAM_SIZE)
175860b32eeSFabio Estevam 
176860b32eeSFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
177860b32eeSFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
178860b32eeSFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
179860b32eeSFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
180860b32eeSFabio Estevam 
181860b32eeSFabio Estevam /* FLASH and environment organization */
182860b32eeSFabio Estevam #define CONFIG_SYS_NO_FLASH
183860b32eeSFabio Estevam 
184860b32eeSFabio Estevam #define CONFIG_ENV_OFFSET      (6 * 64 * 1024)
185860b32eeSFabio Estevam #define CONFIG_ENV_SIZE        (8 * 1024)
186860b32eeSFabio Estevam #define CONFIG_ENV_IS_IN_MMC
187860b32eeSFabio Estevam #define CONFIG_SYS_MMC_ENV_DEV 0
188860b32eeSFabio Estevam 
189860b32eeSFabio Estevam #define CONFIG_OF_LIBFDT
190860b32eeSFabio Estevam 
191860b32eeSFabio Estevam #endif				/* __CONFIG_H */
192