blob: 981670ac069bde2084da8670c2eb7b494a408a52 [file] [log] [blame]
Matthew Fettke545c8e02008-01-24 14:02:32 -06001/*
2 * Configuation settings for the Motorola MC5275EVB board.
3 *
4 * By Arthur Shipkowski <art@videon-central.com>
5 * Copyright (C) 2005 Videon Central, Inc.
6 *
7 * Based off of M5272C3 board code by Josef Baumgartner
8 * <josef.baumgartner@telex.de>
9 *
10 * See file CREDITS for list of people who contributed to this
11 * project.
12 *
13 * This program is free software; you can redistribute it and/or
14 * modify it under the terms of the GNU General Public License as
15 * published by the Free Software Foundation; either version 2 of
16 * the License, or (at your option) any later version.
17 *
18 * This program is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU General Public License for more details.
22 *
23 * You should have received a copy of the GNU General Public License
24 * along with this program; if not, write to the Free Software
25 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
26 * MA 02111-1307 USA
27 */
28
29/*
30 * board/config.h - configuration options, board specific
31 */
32
33#ifndef _M5275EVB_H
34#define _M5275EVB_H
35
36/*
37 * High Level Configuration Options
38 * (easy to change)
39 */
40#define CONFIG_MCF52x2 /* define processor family */
41#define CONFIG_M5275 /* define processor type */
42#define CONFIG_M5275EVB /* define board type */
43
44#define CONFIG_MCFTMR
45
46#define CONFIG_MCFUART
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020047#define CONFIG_SYS_UART_PORT (0)
TsiChung Liew79e07992008-08-15 16:50:07 +000048#define CONFIG_BAUDRATE 115200
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020049#define CONFIG_SYS_BAUDRATE_TABLE { 9600 , 19200 , 38400 , 57600, 115200 }
Matthew Fettke545c8e02008-01-24 14:02:32 -060050
51/* Configuration for environment
52 * Environment is embedded in u-boot in the second sector of the flash
53 */
54#ifndef CONFIG_MONITOR_IS_IN_RAM
Jean-Christophe PLAGNIOL-VILLARD0e8d1582008-09-10 22:48:06 +020055#define CONFIG_ENV_OFFSET 0x4000
56#define CONFIG_ENV_SECT_SIZE 0x2000
Jean-Christophe PLAGNIOL-VILLARD5a1aceb2008-09-10 22:48:04 +020057#define CONFIG_ENV_IS_IN_FLASH 1
Matthew Fettke545c8e02008-01-24 14:02:32 -060058#else
Jean-Christophe PLAGNIOL-VILLARD0e8d1582008-09-10 22:48:06 +020059#define CONFIG_ENV_ADDR 0xffe04000
60#define CONFIG_ENV_SECT_SIZE 0x2000
Jean-Christophe PLAGNIOL-VILLARD5a1aceb2008-09-10 22:48:04 +020061#define CONFIG_ENV_IS_IN_FLASH 1
Matthew Fettke545c8e02008-01-24 14:02:32 -060062#endif
63
64/*
65 * BOOTP options
66 */
67#define CONFIG_BOOTP_BOOTFILESIZE
68#define CONFIG_BOOTP_BOOTPATH
69#define CONFIG_BOOTP_GATEWAY
70#define CONFIG_BOOTP_HOSTNAME
71
72/* Available command configuration */
73#include <config_cmd_default.h>
74
TsiChung Liewdd9f0542010-03-11 22:12:53 -060075#define CONFIG_CMD_CACHE
Matthew Fettke545c8e02008-01-24 14:02:32 -060076#define CONFIG_CMD_PING
77#define CONFIG_CMD_MII
78#define CONFIG_CMD_NET
79#define CONFIG_CMD_ELF
80#define CONFIG_CMD_FLASH
81#define CONFIG_CMD_I2C
82#define CONFIG_CMD_MEMORY
83#define CONFIG_CMD_DHCP
84
85#undef CONFIG_CMD_LOADS
86#undef CONFIG_CMD_LOADB
87
88#define CONFIG_MCFFEC
89#ifdef CONFIG_MCFFEC
90#define CONFIG_NET_MULTI 1
91#define CONFIG_MII 1
TsiChung Liew0f3ba7e2008-03-30 01:22:13 -050092#define CONFIG_MII_INIT 1
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +020093#define CONFIG_SYS_DISCOVER_PHY
94#define CONFIG_SYS_RX_ETH_BUFFER 8
95#define CONFIG_SYS_FAULT_ECHO_LINK_DOWN
96#define CONFIG_SYS_FEC0_PINMUX 0
97#define CONFIG_SYS_FEC0_MIIBASE CONFIG_SYS_FEC0_IOBASE
98#define CONFIG_SYS_FEC1_PINMUX 0
99#define CONFIG_SYS_FEC1_MIIBASE CONFIG_SYS_FEC1_IOBASE
Matthew Fettke545c8e02008-01-24 14:02:32 -0600100#define MCFFEC_TOUT_LOOP 50000
101#define CONFIG_HAS_ETH1
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200102/* If CONFIG_SYS_DISCOVER_PHY is not defined - hardcoded */
103#ifndef CONFIG_SYS_DISCOVER_PHY
Matthew Fettke545c8e02008-01-24 14:02:32 -0600104#define FECDUPLEX FULL
105#define FECSPEED _100BASET
106#else
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200107#ifndef CONFIG_SYS_FAULT_ECHO_LINK_DOWN
108#define CONFIG_SYS_FAULT_ECHO_LINK_DOWN
Matthew Fettke545c8e02008-01-24 14:02:32 -0600109#endif
110#endif
111#endif
112
113/* I2C */
114#define CONFIG_FSL_I2C
115#define CONFIG_HARD_I2C /* I2C with hw support */
116#undef CONFIG_SOFT_I2C
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200117#define CONFIG_SYS_I2C_SPEED 80000
118#define CONFIG_SYS_I2C_SLAVE 0x7F
119#define CONFIG_SYS_I2C_OFFSET 0x00000300
120#define CONFIG_SYS_IMMR CONFIG_SYS_MBAR
121#define CONFIG_SYS_I2C_PINMUX_REG (gpio_reg->par_feci2c)
122#define CONFIG_SYS_I2C_PINMUX_CLR (0xFFF0)
123#define CONFIG_SYS_I2C_PINMUX_SET (0x000F)
Matthew Fettke545c8e02008-01-24 14:02:32 -0600124
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200125#define CONFIG_SYS_PROMPT "-> "
126#define CONFIG_SYS_LONGHELP /* undef to save memory */
Matthew Fettke545c8e02008-01-24 14:02:32 -0600127
128#if (CONFIG_CMD_KGDB)
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200129# define CONFIG_SYS_CBSIZE 1024
Matthew Fettke545c8e02008-01-24 14:02:32 -0600130#else
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200131# define CONFIG_SYS_CBSIZE 256
Matthew Fettke545c8e02008-01-24 14:02:32 -0600132#endif
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200133#define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
134#define CONFIG_SYS_MAXARGS 16
135#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
Matthew Fettke545c8e02008-01-24 14:02:32 -0600136
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200137#define CONFIG_SYS_LOAD_ADDR 0x800000
Matthew Fettke545c8e02008-01-24 14:02:32 -0600138
139#define CONFIG_BOOTDELAY 5
140#define CONFIG_BOOTCOMMAND "bootm ffe40000"
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200141#define CONFIG_SYS_MEMTEST_START 0x400
142#define CONFIG_SYS_MEMTEST_END 0x380000
Matthew Fettke545c8e02008-01-24 14:02:32 -0600143
TsiChung Liew0e8a7552010-03-10 16:33:03 -0600144#ifdef CONFIG_MCFFEC
145# define CONFIG_NET_RETRY_COUNT 5
146# define CONFIG_OVERWRITE_ETHADDR_ONCE
147#endif /* FEC_ENET */
148
149#define CONFIG_EXTRA_ENV_SETTINGS \
150 "netdev=eth0\0" \
151 "loadaddr=10000\0" \
152 "uboot=u-boot.bin\0" \
153 "load=tftp ${loadaddr} ${uboot}\0" \
154 "upd=run load; run prog\0" \
155 "prog=prot off ffe00000 ffe3ffff;" \
156 "era ffe00000 ffe3ffff;" \
157 "cp.b ${loadaddr} ffe00000 ${filesize};"\
158 "save\0" \
159 ""
160
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200161#define CONFIG_SYS_HZ 1000
162#define CONFIG_SYS_CLK 150000000
Matthew Fettke545c8e02008-01-24 14:02:32 -0600163
164/*
165 * Low Level Configuration Settings
166 * (address mappings, register initial values, etc.)
167 * You should know what you are doing if you make changes here.
168 */
169
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200170#define CONFIG_SYS_MBAR 0x40000000
Matthew Fettke545c8e02008-01-24 14:02:32 -0600171
172/*-----------------------------------------------------------------------
173 * Definitions for initial stack pointer and data area (in DPRAM)
174 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200175#define CONFIG_SYS_INIT_RAM_ADDR 0x20000000
176#define CONFIG_SYS_INIT_RAM_END 0x10000 /* End of used area in internal SRAM */
177#define CONFIG_SYS_GBL_DATA_SIZE 1000 /* bytes reserved for initial data */
178#define CONFIG_SYS_GBL_DATA_OFFSET (CONFIG_SYS_INIT_RAM_END - CONFIG_SYS_GBL_DATA_SIZE)
179#define CONFIG_SYS_INIT_SP_OFFSET CONFIG_SYS_GBL_DATA_OFFSET
Matthew Fettke545c8e02008-01-24 14:02:32 -0600180
181/*-----------------------------------------------------------------------
182 * Start addresses for the final memory configuration
183 * (Set up by the startup code)
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200184 * Please note that CONFIG_SYS_SDRAM_BASE _must_ start at 0
Matthew Fettke545c8e02008-01-24 14:02:32 -0600185 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200186#define CONFIG_SYS_SDRAM_BASE 0x00000000
187#define CONFIG_SYS_SDRAM_SIZE 16 /* SDRAM size in MB */
TsiChung Liew012522f2008-10-21 10:03:07 +0000188#define CONFIG_SYS_FLASH_BASE CONFIG_SYS_CS0_BASE
Matthew Fettke545c8e02008-01-24 14:02:32 -0600189
190#ifdef CONFIG_MONITOR_IS_IN_RAM
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200191#define CONFIG_SYS_MONITOR_BASE 0x20000
Matthew Fettke545c8e02008-01-24 14:02:32 -0600192#else
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200193#define CONFIG_SYS_MONITOR_BASE (CONFIG_SYS_FLASH_BASE + 0x400)
Matthew Fettke545c8e02008-01-24 14:02:32 -0600194#endif
195
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200196#define CONFIG_SYS_MONITOR_LEN 0x20000
197#define CONFIG_SYS_MALLOC_LEN (256 << 10)
198#define CONFIG_SYS_BOOTPARAMS_LEN 64*1024
Matthew Fettke545c8e02008-01-24 14:02:32 -0600199
200/*
201 * For booting Linux, the board info and command line data
202 * have to be in the first 8 MB of memory, since this is
203 * the maximum mapped by the Linux kernel during initialization ??
204 */
TsiChung Liewd6e4baf2009-01-27 12:57:47 +0000205#define CONFIG_SYS_BOOTMAPSZ (CONFIG_SYS_SDRAM_BASE + (CONFIG_SYS_SDRAM_SIZE << 20))
206#define CONFIG_SYS_BOOTM_LEN (CONFIG_SYS_SDRAM_SIZE << 20)
Matthew Fettke545c8e02008-01-24 14:02:32 -0600207
208/*-----------------------------------------------------------------------
209 * FLASH organization
210 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200211#define CONFIG_SYS_MAX_FLASH_BANKS 1 /* max number of memory banks */
212#define CONFIG_SYS_MAX_FLASH_SECT 11 /* max number of sectors on one chip */
213#define CONFIG_SYS_FLASH_ERASE_TOUT 1000
Matthew Fettke545c8e02008-01-24 14:02:32 -0600214
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200215#define CONFIG_SYS_FLASH_CFI 1
Jean-Christophe PLAGNIOL-VILLARD00b18832008-08-13 01:40:42 +0200216#define CONFIG_FLASH_CFI_DRIVER 1
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200217#define CONFIG_SYS_FLASH_SIZE 0x200000
Matthew Fettke545c8e02008-01-24 14:02:32 -0600218
219/*-----------------------------------------------------------------------
220 * Cache Configuration
221 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200222#define CONFIG_SYS_CACHELINE_SIZE 16
Matthew Fettke545c8e02008-01-24 14:02:32 -0600223
TsiChung Liewdd9f0542010-03-11 22:12:53 -0600224#define ICACHE_STATUS (CONFIG_SYS_INIT_RAM_ADDR + \
225 CONFIG_SYS_INIT_RAM_END - 8)
226#define DCACHE_STATUS (CONFIG_SYS_INIT_RAM_ADDR + \
227 CONFIG_SYS_INIT_RAM_END - 4)
228#define CONFIG_SYS_ICACHE_INV (CF_CACR_CINV | CF_CACR_INVI)
229#define CONFIG_SYS_CACHE_ACR0 (CONFIG_SYS_SDRAM_BASE | \
230 CF_ADDRMASK(CONFIG_SYS_SDRAM_SIZE) | \
231 CF_ACR_EN | CF_ACR_SM_ALL)
232#define CONFIG_SYS_CACHE_ICACR (CF_CACR_CENB | CF_CACR_CINV | \
233 CF_CACR_DISD | CF_CACR_INVI | \
234 CF_CACR_CEIB | CF_CACR_DCM | \
235 CF_CACR_EUSP)
236
Matthew Fettke545c8e02008-01-24 14:02:32 -0600237/*-----------------------------------------------------------------------
238 * Memory bank definitions
239 */
TsiChung Liew012522f2008-10-21 10:03:07 +0000240#define CONFIG_SYS_CS0_BASE 0xffe00000
241#define CONFIG_SYS_CS0_CTRL 0x00001980
242#define CONFIG_SYS_CS0_MASK 0x001F0001
Matthew Fettke545c8e02008-01-24 14:02:32 -0600243
TsiChung Liew012522f2008-10-21 10:03:07 +0000244#define CONFIG_SYS_CS1_BASE 0x30000000
245#define CONFIG_SYS_CS1_CTRL 0x00001900
246#define CONFIG_SYS_CS1_MASK 0x00070001
Matthew Fettke545c8e02008-01-24 14:02:32 -0600247
248/*-----------------------------------------------------------------------
249 * Port configuration
250 */
Jean-Christophe PLAGNIOL-VILLARD6d0f6bc2008-10-16 15:01:15 +0200251#define CONFIG_SYS_FECI2C 0x0FA0
Matthew Fettke545c8e02008-01-24 14:02:32 -0600252
253#endif /* _M5275EVB_H */